summaryrefslogtreecommitdiffstats
path: root/drivers/atmodem/network-registration.c
diff options
context:
space:
mode:
authorMarcel Holtmann <marcel@holtmann.org>2012-05-24 04:59:12 +0200
committerMarcel Holtmann <marcel@holtmann.org>2012-05-24 05:00:01 +0200
commit119b4434b4777b0db8270944dc2786edbc725250 (patch)
tree43d08c4e1f67deca9650f9ccd4cac4a155cac1cd /drivers/atmodem/network-registration.c
parenta96422cd5028374963964f24fcebde9c508da7d1 (diff)
downloadofono-119b4434b4777b0db8270944dc2786edbc725250.tar.bz2
atmodem: Add support for Icera network status updates
Diffstat (limited to 'drivers/atmodem/network-registration.c')
-rw-r--r--drivers/atmodem/network-registration.c53
1 files changed, 53 insertions, 0 deletions
diff --git a/drivers/atmodem/network-registration.c b/drivers/atmodem/network-registration.c
index d082e5ad..413ebde4 100644
--- a/drivers/atmodem/network-registration.c
+++ b/drivers/atmodem/network-registration.c
@@ -1181,6 +1181,53 @@ static void mbm_erinfo_notify(GAtResult *result, gpointer user_data)
}
}
+static void icera_nwstate_notify(GAtResult *result, gpointer user_data)
+{
+ struct ofono_netreg *netreg = user_data;
+ struct netreg_data *nd = ofono_netreg_get_data(netreg);
+ GAtResultIter iter;
+ const char *mccmnc, *tech;
+ int rssi;
+
+ g_at_result_iter_init(&iter, result);
+
+ if (g_at_result_iter_next(&iter, "%NWSTATE:") == FALSE)
+ return;
+
+ if (g_at_result_iter_next_number(&iter, &rssi) == FALSE)
+ return;
+
+ if (g_at_result_iter_next_unquoted_string(&iter, &mccmnc) == FALSE)
+ return;
+
+ if (g_at_result_iter_next_unquoted_string(&iter, &tech) == FALSE)
+ return;
+
+ DBG("rssi %d tech %s", rssi, tech);
+
+ /* small 'g' means CS, big 'G' means PS */
+ if (g_str_equal(tech, "2g") == TRUE ||
+ g_str_equal(tech, "2G-GPRS") == TRUE)
+ nd->tech = ACCESS_TECHNOLOGY_GSM;
+ else if (g_str_equal(tech, "2G-EDGE") == TRUE)
+ nd->tech = ACCESS_TECHNOLOGY_GSM_EGPRS;
+ else if (g_str_equal(tech, "3g") == TRUE ||
+ g_str_equal(tech, "3G") == TRUE ||
+ g_str_equal(tech, "R99") == TRUE)
+ nd->tech = ACCESS_TECHNOLOGY_UTRAN;
+ else if (g_str_equal(tech, "3G-HSDPA") == TRUE ||
+ g_str_equal(tech, "HSDPA") == TRUE)
+ nd->tech = ACCESS_TECHNOLOGY_UTRAN_HSDPA;
+ else if (g_str_equal(tech, "3G-HSUPA") == TRUE ||
+ g_str_equal(tech, "HSUPA") == TRUE)
+ nd->tech = ACCESS_TECHNOLOGY_UTRAN_HSUPA;
+ else if (g_str_equal(tech, "3G-HSDPA-HSUPA") == TRUE ||
+ g_str_equal(tech, "HSDPA-HSUPA") == TRUE)
+ nd->tech = ACCESS_TECHNOLOGY_UTRAN_HSDPA_HSUPA;
+ else
+ nd->tech = -1;
+}
+
static int cnti_to_tech(const char *cnti)
{
if (g_str_equal(cnti, "GSM") == TRUE ||
@@ -1561,6 +1608,12 @@ static void at_creg_set_cb(gboolean ok, GAtResult *result, gpointer user_data)
NULL, NULL, NULL);
break;
case OFONO_VENDOR_ICERA:
+ /* Register for network technology updates */
+ g_at_chat_register(nd->chat, "%NWSTATE:", icera_nwstate_notify,
+ FALSE, netreg, NULL);
+ g_at_chat_send(nd->chat, "AT%NWSTATE=1", none_prefix,
+ NULL, NULL, NULL);
+
/* Register for network time update reports */
g_at_chat_register(nd->chat, "*TLTS:", tlts_notify,
FALSE, netreg, NULL);