Refactor: stk send_sms datastructure

This commit is contained in:
Denis Kenzior 2010-03-15 20:59:02 -05:00
parent 6986cc4760
commit a16f270eb1
2 changed files with 19 additions and 17 deletions

View File

@ -29,8 +29,8 @@
#include <glib.h>
#include <ofono/types.h>
#include "stkutil.h"
#include "smsutil.h"
#include "stkutil.h"
#include "simutil.h"
#include "util.h"
@ -41,6 +41,15 @@ enum stk_data_object_flag {
typedef gboolean (*dataobj_handler)(struct comprehension_tlv_iter *, void *);
/*
* Defined in TS 102.223 Section 8.13
* GSM SMS PDUs are limited to 164 bytes according to 23.040
*/
struct gsm_sms_tpdu {
unsigned int len;
unsigned char tpdu[164];
};
/* Defined in TS 102.223 Section 8.1 */
static gboolean parse_dataobj_address(struct comprehension_tlv_iter *iter,
void *user)
@ -277,26 +286,25 @@ static gboolean parse_dataobj_result(struct comprehension_tlv_iter *iter,
}
/* Defined in TS 102.223 Section 8.13 */
static gboolean parse_dataobj_sms_tpdu(struct comprehension_tlv_iter *iter,
static gboolean parse_dataobj_gsm_sms_tpdu(struct comprehension_tlv_iter *iter,
void *user)
{
struct stk_sms_tpdu *tpdu = user;
struct gsm_sms_tpdu *tpdu = user;
const unsigned char *data;
unsigned int len;
if (comprehension_tlv_iter_get_tag(iter) !=
STK_DATA_OBJECT_TYPE_SMS_TPDU)
STK_DATA_OBJECT_TYPE_GSM_SMS_TPDU)
return FALSE;
len = comprehension_tlv_iter_get_length(iter);
if (len < 1)
if (len < 1 || len > 164)
return FALSE;
data = comprehension_tlv_iter_get_data(iter);
tpdu->tpdu_len = data[0];
tpdu->tpdu = g_malloc(len-1);
memcpy(tpdu->tpdu, data+1, len-1);
tpdu->len = len;
memcpy(tpdu->tpdu, data, len);
return TRUE;
}
@ -502,8 +510,8 @@ static dataobj_handler handler_for_type(enum stk_data_object_type type)
return parse_dataobj_response_len;
case STK_DATA_OBJECT_TYPE_RESULT:
return parse_dataobj_result;
case STK_DATA_OBJECT_TYPE_SMS_TPDU:
return parse_dataobj_sms_tpdu;
case STK_DATA_OBJECT_TYPE_GSM_SMS_TPDU:
return parse_dataobj_gsm_sms_tpdu;
case STK_DATA_OBJECT_TYPE_TEXT:
case STK_DATA_OBJECT_TYPE_DEFAULT_TEXT:
return parse_dataobj_text;

View File

@ -91,7 +91,7 @@ enum stk_data_object_type {
STK_DATA_OBJECT_TYPE_SUBADDRESS = 0x08,
STK_DATA_OBJECT_TYPE_SS_STRING = 0x09,
STK_DATA_OBJECT_TYPE_USSD_STRING = 0x0A,
STK_DATA_OBJECT_TYPE_SMS_TPDU = 0x0B,
STK_DATA_OBJECT_TYPE_GSM_SMS_TPDU = 0x0B,
STK_DATA_OBJECT_TYPE_CBS_PAGE = 0x0C,
STK_DATA_OBJECT_TYPE_TEXT = 0x0D,
STK_DATA_OBJECT_TYPE_TONE = 0x0E,
@ -314,12 +314,6 @@ struct stk_result {
unsigned char *additional;
};
/* Defined in TS 102.223 Section 8.13 */
struct stk_sms_tpdu {
unsigned int tpdu_len;
unsigned char *tpdu;
};
/*
* According to 102.223 Section 8.72 the length of text attribute CTLV is 1
* byte. This means that the maximum size is 127 according to the rules