diff options
author | Denis Kenzior <denkenz@gmail.com> | 2010-03-28 23:30:32 -0500 |
---|---|---|
committer | Denis Kenzior <denkenz@gmail.com> | 2010-03-28 23:49:57 -0500 |
commit | 21dd4f040a040254a9ac1ece8e3ba0b7d47f57d4 (patch) | |
tree | b23e1a6d96800679061e3ef7735ca4990aa6305a | |
parent | 6af65670040c3e8ca51783fe74b785842a3002ca (diff) | |
download | ofono-21dd4f040a040254a9ac1ece8e3ba0b7d47f57d4.tar.bz2 |
Move erinfo notify to atmodem netreg driver
-rw-r--r-- | drivers/atmodem/network-registration.c | 27 | ||||
-rw-r--r-- | plugins/mbm.c | 23 |
2 files changed, 27 insertions, 23 deletions
diff --git a/drivers/atmodem/network-registration.c b/drivers/atmodem/network-registration.c index c659e770..94ca2514 100644 --- a/drivers/atmodem/network-registration.c +++ b/drivers/atmodem/network-registration.c @@ -688,6 +688,23 @@ error: CALLBACK_WITH_FAILURE(cb, -1, data); } +static void mbm_erinfo_notify(GAtResult *result, gpointer user_data) +{ + GAtResultIter iter; + int mode, gsm, umts; + + g_at_result_iter_init(&iter, result); + + if (g_at_result_iter_next(&iter, "*ERINFO:") == FALSE) + return; + + g_at_result_iter_next_number(&iter, &mode); + g_at_result_iter_next_number(&iter, &gsm); + g_at_result_iter_next_number(&iter, &umts); + + ofono_info("network capability: GSM %d UMTS %d", gsm, umts); +} + static void creg_notify(GAtResult *result, gpointer user_data) { struct ofono_netreg *netreg = user_data; @@ -837,6 +854,16 @@ static void at_creg_set_cb(gboolean ok, GAtResult *result, gpointer user_data) ofono_netreg_register(netreg); break; + + case OFONO_VENDOR_MBM: + g_at_chat_send(nd->chat, "AT*ERINFO=1", none_prefix, + NULL, NULL, NULL); + g_at_chat_register(nd->chat, "*ERINFO:", mbm_erinfo_notify, + FALSE, netreg, NULL); + g_at_chat_send(nd->chat, "AT+CIND=?", cind_prefix, + cind_support_cb, netreg, NULL); + + break; default: g_at_chat_send(nd->chat, "AT+CIND=?", cind_prefix, cind_support_cb, netreg, NULL); diff --git a/plugins/mbm.c b/plugins/mbm.c index 9f3965d0..045041ca 100644 --- a/plugins/mbm.c +++ b/plugins/mbm.c @@ -59,23 +59,6 @@ struct mbm_data { GAtChat *chat; }; -static void erinfo_notifier(GAtResult *result, gpointer user_data) -{ - GAtResultIter iter; - int mode, gsm, umts; - - g_at_result_iter_init(&iter, result); - - if (g_at_result_iter_next(&iter, "*ERINFO:") == FALSE) - return; - - g_at_result_iter_next_number(&iter, &mode); - g_at_result_iter_next_number(&iter, &gsm); - g_at_result_iter_next_number(&iter, &umts); - - ofono_info("network capability: GSM %d UMTS %d", gsm, umts); -} - static int mbm_probe(struct ofono_modem *modem) { struct mbm_data *data; @@ -111,7 +94,6 @@ static void mbm_debug(const char *str, void *user_data) static void cfun_enable(gboolean ok, GAtResult *result, gpointer user_data) { struct ofono_modem *modem = user_data; - struct mbm_data *data = ofono_modem_get_data(modem); DBG(""); @@ -119,11 +101,6 @@ static void cfun_enable(gboolean ok, GAtResult *result, gpointer user_data) ofono_modem_set_powered(modem, FALSE); ofono_modem_set_powered(modem, TRUE); - - g_at_chat_send(data->chat, "AT*ERINFO=1", none_prefix, - NULL, NULL, NULL); - g_at_chat_register(data->chat, "*ERINFO:", erinfo_notifier, - FALSE, modem, NULL); } static void cfun_query(gboolean ok, GAtResult *result, gpointer user_data) |