stk: Use envelope encoding utility from stkutil.c
authorAndrzej Zaborowski <andrew.zaborowski@intel.com>
Mon, 7 Jun 2010 10:08:27 +0000 (12:08 +0200)
committerDenis Kenzior <denkenz@gmail.com>
Wed, 9 Jun 2010 17:26:32 +0000 (12:26 -0500)
src/cbs.c
src/ofono.h
src/stk.c

index 56607a8..27185ba 100644 (file)
--- a/src/cbs.c
+++ b/src/cbs.c
@@ -197,7 +197,7 @@ void ofono_cbs_notify(struct ofono_cbs *cbs, const unsigned char *pdu,
 
        if (cbs_topic_in_range(c.message_identifier, cbs->efcbmid_contents)) {
                if (cbs->stk)
-                       __ofono_cbs_sim_download(cbs->stk, pdu, pdu_len);
+                       __ofono_cbs_sim_download(cbs->stk, &c);
                return;
        }
 
index a1e4911..e2271e6 100644 (file)
@@ -177,8 +177,8 @@ void __ofono_atom_free(struct ofono_atom *atom);
 #include <ofono/sim.h>
 #include <ofono/stk.h>
 
-void __ofono_cbs_sim_download(struct ofono_stk *stk,
-                               const guint8 *pdu, int pdu_len);
+struct cbs;
+void __ofono_cbs_sim_download(struct ofono_stk *stk, const struct cbs *msg);
 
 #include <ofono/ssn.h>
 
index 8573d2c..14d1a0c 100644 (file)
--- a/src/stk.c
+++ b/src/stk.c
@@ -49,32 +49,33 @@ static void stk_cbs_download_cb(const struct ofono_error *error,
 {
        if (error->type != OFONO_ERROR_TYPE_NO_ERROR) {
                ofono_error("CellBroadcast download to UICC failed");
+               /* "The ME may retry to deliver the same Cell Broadcast
+                * page." */
                return;
        }
 
        DBG("CellBroadcast download to UICC reported no error");
 }
 
-void __ofono_cbs_sim_download(struct ofono_stk *stk,
-                               const guint8 *pdu, int pdu_len)
+void __ofono_cbs_sim_download(struct ofono_stk *stk, const struct cbs *msg)
 {
-       guint8 tlv[pdu_len + 8];
+       const guint8 *tlv;
+       unsigned int tlv_len;
+       struct stk_envelope e;
 
        if (stk->driver->envelope == NULL)
                return;
 
-       tlv[0] = STK_ENVELOPE_TYPE_CBS_PP_DOWNLOAD;
-       tlv[1] = 6 + pdu_len;
-       tlv[2] = 0x80 | STK_DATA_OBJECT_TYPE_DEVICE_IDENTITIES;
-       tlv[3] = 0x02; /* Device Identities length */
-       tlv[4] = STK_DEVICE_IDENTITY_TYPE_NETWORK;
-       tlv[5] = STK_DEVICE_IDENTITY_TYPE_UICC;
-       tlv[6] = 0x80 | STK_DATA_OBJECT_TYPE_CBS_PAGE;
-       tlv[7] = pdu_len;
+       e.type = STK_ENVELOPE_TYPE_CBS_PP_DOWNLOAD;
+       e.src = STK_DEVICE_IDENTITY_TYPE_NETWORK;
+       e.dst = STK_DEVICE_IDENTITY_TYPE_UICC;
+       memcpy(&e.cbs_pp_download.page, msg, sizeof(msg));
 
-       memcpy(tlv + 8, pdu, pdu_len);
+       tlv = stk_pdu_from_envelope(&e, &tlv_len);
+       if (!tlv)
+               return;
 
-       stk->driver->envelope(stk, pdu_len + 8, tlv, stk_cbs_download_cb, stk);
+       stk->driver->envelope(stk, tlv_len, tlv, stk_cbs_download_cb, stk);
 }
 
 void ofono_stk_proactive_command_notify(struct ofono_stk *stk,