diff options
author | Philip Paeps <philip@paeps.cx> | 2014-06-26 20:28:17 +0200 |
---|---|---|
committer | Denis Kenzior <denkenz@gmail.com> | 2014-06-30 14:03:08 -0500 |
commit | 6df64cd1a950c0aa5cf45c0a3920100ec99c0b4f (patch) | |
tree | c2bad76e35d747ee57b1b6a829b342bf7734f253 /drivers/atmodem | |
parent | 4a0831bc80675ad2441ac1e0965a48257ec9f274 (diff) | |
download | ofono-6df64cd1a950c0aa5cf45c0a3920100ec99c0b4f.tar.bz2 |
gprs: add support for u-blox +UREG URCs
Diffstat (limited to 'drivers/atmodem')
-rw-r--r-- | drivers/atmodem/gprs.c | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/drivers/atmodem/gprs.c b/drivers/atmodem/gprs.c index 3005867b..55513169 100644 --- a/drivers/atmodem/gprs.c +++ b/drivers/atmodem/gprs.c @@ -282,6 +282,44 @@ static void telit_mode_notify(GAtResult *result, gpointer user_data) ofono_gprs_bearer_notify(gprs, bearer); } +static void ublox_ureg_notify(GAtResult *result, gpointer user_data) +{ + struct ofono_gprs *gprs = user_data; + GAtResultIter iter; + gint state, bearer; + + g_at_result_iter_init(&iter, result); + + if (!g_at_result_iter_next(&iter, "+UREG:")) + return; + + if (!g_at_result_iter_next_number(&iter, &state)) + return; + + switch (state) { + case 4: + bearer = 5; + break; + case 5: + bearer = 4; + break; + case 7: + /* XXX: reserved - assume none. */ + bearer = 0; + break; + case 8: + bearer = 1; + break; + case 9: + bearer = 2; + break; + default: + bearer = state; + } + + ofono_gprs_bearer_notify(gprs, bearer); +} + static void cpsb_notify(GAtResult *result, gpointer user_data) { struct ofono_gprs *gprs = user_data; @@ -316,6 +354,12 @@ static void gprs_initialized(gboolean ok, GAtResult *result, gpointer user_data) g_at_chat_register(gd->chat, "^MODE:", huawei_mode_notify, FALSE, gprs, NULL); break; + case OFONO_VENDOR_UBLOX: + g_at_chat_register(gd->chat, "+UREG:", ublox_ureg_notify, + FALSE, gprs, NULL); + g_at_chat_send(gd->chat, "AT+UREG=1", none_prefix, + NULL, NULL, NULL); + break; case OFONO_VENDOR_TELIT: g_at_chat_register(gd->chat, "#PSNT:", telit_mode_notify, FALSE, gprs, NULL); |