summaryrefslogtreecommitdiffstats
path: root/src/stkutil.c
diff options
context:
space:
mode:
authorDenis Kenzior <denkenz@gmail.com>2010-03-15 20:59:02 -0500
committerDenis Kenzior <denkenz@gmail.com>2010-03-15 21:02:06 -0500
commita16f270eb1795cf1d96dc8b9f0d879861214eee8 (patch)
treef6d1cf9c4f3293635d144122b0c43635e6aa381f /src/stkutil.c
parent6986cc4760f61eb1d5d078051cdab8ef1489927a (diff)
downloadofono-a16f270eb1795cf1d96dc8b9f0d879861214eee8.tar.bz2
Refactor: stk send_sms datastructure
Diffstat (limited to 'src/stkutil.c')
-rw-r--r--src/stkutil.c28
1 files changed, 18 insertions, 10 deletions
diff --git a/src/stkutil.c b/src/stkutil.c
index 7655b60a..29643cc2 100644
--- a/src/stkutil.c
+++ b/src/stkutil.c
@@ -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;