diff options
author | Yang Gu <gyagp0@gmail.com> | 2010-04-22 23:12:22 +0800 |
---|---|---|
committer | Denis Kenzior <denkenz@gmail.com> | 2010-04-23 11:52:17 -0500 |
commit | b1b75d90d5237344c56a5b72084a913bc59cc4b7 (patch) | |
tree | f6efaaed574197bfdeec94e67929969a38d461ab /src | |
parent | d6c5def9643b37c7e909b1cc4d17b18fb68654e7 (diff) | |
download | ofono-b1b75d90d5237344c56a5b72084a913bc59cc4b7.tar.bz2 |
stkutil: Add parser for MMS reference objects
Diffstat (limited to 'src')
-rw-r--r-- | src/stkutil.c | 20 | ||||
-rw-r--r-- | src/stkutil.h | 9 |
2 files changed, 29 insertions, 0 deletions
diff --git a/src/stkutil.c b/src/stkutil.c index 3dca39c2..a33c4e9e 100644 --- a/src/stkutil.c +++ b/src/stkutil.c @@ -1669,6 +1669,24 @@ static gboolean parse_dataobj_meid(struct comprehension_tlv_iter *iter, return TRUE; } +/* Defined in TS 102.223 Section 8.82 */ +static gboolean parse_dataobj_mms_reference(struct comprehension_tlv_iter *iter, + void *user) +{ + struct stk_mms_reference *mr = user; + const unsigned char *data; + unsigned int len = comprehension_tlv_iter_get_length(iter); + + if (len < 1) + return FALSE; + + data = comprehension_tlv_iter_get_data(iter); + mr->len = len; + memcpy(mr->ref, data, len); + + return TRUE; +} + static dataobj_handler handler_for_type(enum stk_data_object_type type) { switch (type) { @@ -1820,6 +1838,8 @@ static dataobj_handler handler_for_type(enum stk_data_object_type type) return parse_dataobj_frame_id; case STK_DATA_OBJECT_TYPE_MEID: return parse_dataobj_meid; + case STK_DATA_OBJECT_TYPE_MMS_REFERENCE: + return parse_dataobj_mms_reference; default: return NULL; }; diff --git a/src/stkutil.h b/src/stkutil.h index c2579dc6..b1e4c5e9 100644 --- a/src/stkutil.h +++ b/src/stkutil.h @@ -721,6 +721,15 @@ struct stk_frames_info { unsigned int len; }; +/* + * According to 102.223 Section 8.82 the length of CTLV is 1 byte. This means + * that the maximum size is 127 according to the rules of CTLVs. + */ +struct stk_mms_reference { + unsigned char ref[127]; + unsigned char len; +}; + struct stk_command_display_text { char *text; struct stk_icon_id icon_id; |