From: Andrzej Zaborowski Date: Sun, 7 Nov 2010 17:42:19 +0000 (+0100) Subject: sms: Handle "USIM Download" SMS type. X-Git-Tag: 0.36~55 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=028c8c011b2e499f3f417b3fed9ccf71c3280128;p=platform%2Fupstream%2Fofono.git sms: Handle "USIM Download" SMS type. --- diff --git a/src/sms.c b/src/sms.c index 456dda9..eba4564 100644 --- a/src/sms.c +++ b/src/sms.c @@ -1415,6 +1415,8 @@ static inline gboolean handle_mwi(struct ofono_sms *sms, struct sms *s) void ofono_sms_deliver_notify(struct ofono_sms *sms, unsigned char *pdu, int len, int tpdu_len) { + struct ofono_modem *modem = __ofono_atom_get_modem(sms->atom); + struct ofono_atom *stk_atom; struct sms s; enum sms_class cls; @@ -1479,13 +1481,22 @@ void ofono_sms_deliver_notify(struct ofono_sms *sms, unsigned char *pdu, break; case SMS_PID_TYPE_USIM_DOWNLOAD: case SMS_PID_TYPE_ANSI136: - if (cls == SMS_CLASS_2) { - ofono_error("(U)SIM Download messages not supported"); + /* If not Class 2, handle in a "normal" way */ + if (cls != SMS_CLASS_2) + break; + + stk_atom = __ofono_modem_find_atom(modem, OFONO_ATOM_TYPE_STK); + + if (!stk_atom) return; - } - /* Otherwise handle in a "normal" way */ - break; + __ofono_sms_sim_download(__ofono_atom_get_data(stk_atom), + &s, NULL, sms); + + /* Passing the USIM response back to network is not + * currently support */ + /* TODO: store in EFsms if not handled */ + return; default: break; }