summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorAndrzej Zaborowski <andrew.zaborowski@intel.com>2010-06-07 12:08:27 +0200
committerDenis Kenzior <denkenz@gmail.com>2010-06-09 12:26:32 -0500
commit7e5ef25c5a58898a408e3e5d4809a1d6f6c0d09a (patch)
tree6cec35880d0a923663a66b0108a11559a1981404 /src
parentf98954116191946a2c043406db9177d41b3b37ab (diff)
downloadofono-7e5ef25c5a58898a408e3e5d4809a1d6f6c0d09a.tar.bz2
stk: Use envelope encoding utility from stkutil.c
Diffstat (limited to 'src')
-rw-r--r--src/cbs.c2
-rw-r--r--src/ofono.h4
-rw-r--r--src/stk.c27
3 files changed, 17 insertions, 16 deletions
diff --git a/src/cbs.c b/src/cbs.c
index 56607a88..27185ba8 100644
--- 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;
}
diff --git a/src/ofono.h b/src/ofono.h
index a1e4911a..e2271e60 100644
--- a/src/ofono.h
+++ b/src/ofono.h
@@ -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>
diff --git a/src/stk.c b/src/stk.c
index 8573d2ca..14d1a0c2 100644
--- 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,