summaryrefslogtreecommitdiffstats
path: root/drivers/atmodem
diff options
context:
space:
mode:
authorPhilip Paeps <philip@paeps.cx>2014-06-26 20:28:17 +0200
committerDenis Kenzior <denkenz@gmail.com>2014-06-30 14:03:08 -0500
commit6df64cd1a950c0aa5cf45c0a3920100ec99c0b4f (patch)
treec2bad76e35d747ee57b1b6a829b342bf7734f253 /drivers/atmodem
parent4a0831bc80675ad2441ac1e0965a48257ec9f274 (diff)
downloadofono-6df64cd1a950c0aa5cf45c0a3920100ec99c0b4f.tar.bz2
gprs: add support for u-blox +UREG URCs
Diffstat (limited to 'drivers/atmodem')
-rw-r--r--drivers/atmodem/gprs.c44
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);