summaryrefslogtreecommitdiffstats
path: root/drivers/atmodem
diff options
context:
space:
mode:
authorAlex J Lennon <ajlennon@dynamicdevices.co.uk>2015-05-12 18:23:00 +0100
committerDenis Kenzior <denkenz@gmail.com>2015-05-13 09:57:53 -0500
commit4242f6ee72a39b73bbbfba28c58a026dd33d0728 (patch)
tree89ea28784172deacf490ffa771c8aac2a344c49b /drivers/atmodem
parentb31a3c2390e7d18833396e5e8a4d61bc32c7aaec (diff)
downloadofono-4242f6ee72a39b73bbbfba28c58a026dd33d0728.tar.bz2
atmodem: Add Cinterion quirk for signal strength
Implement OFONO_VENDOR_CINTERION specific vendor support to register textual +CIEV indications for signal strength using AT^SIND command.
Diffstat (limited to 'drivers/atmodem')
-rw-r--r--drivers/atmodem/network-registration.c54
-rw-r--r--drivers/atmodem/vendor.h1
2 files changed, 55 insertions, 0 deletions
diff --git a/drivers/atmodem/network-registration.c b/drivers/atmodem/network-registration.c
index a438726c..7cfd6b2c 100644
--- a/drivers/atmodem/network-registration.c
+++ b/drivers/atmodem/network-registration.c
@@ -838,6 +838,39 @@ static void telit_ciev_notify(GAtResult *result, gpointer user_data)
ofono_netreg_strength_notify(netreg, strength);
}
+static void cinterion_ciev_notify(GAtResult *result, gpointer user_data)
+{
+ struct ofono_netreg *netreg = user_data;
+ struct netreg_data *nd = ofono_netreg_get_data(netreg);
+ const char *signal_identifier = "rssi";
+ const char *ind_str;
+ int strength;
+ GAtResultIter iter;
+
+ g_at_result_iter_init(&iter, result);
+
+ if (!g_at_result_iter_next(&iter, "+CIEV:"))
+ return;
+
+ if (!g_at_result_iter_next_unquoted_string(&iter, &ind_str))
+ return;
+
+ if (!g_str_equal(signal_identifier, ind_str))
+ return;
+
+ if (!g_at_result_iter_next_number(&iter, &strength))
+ return;
+
+ DBG("rssi %d", strength);
+
+ if (strength == nd->signal_invalid)
+ strength = -1;
+ else
+ strength = (strength * 100) / (nd->signal_max - nd->signal_min);
+
+ ofono_netreg_strength_notify(netreg, strength);
+}
+
static void ctzv_notify(GAtResult *result, gpointer user_data)
{
struct ofono_netreg *netreg = user_data;
@@ -1915,6 +1948,27 @@ static void at_creg_set_cb(gboolean ok, GAtResult *result, gpointer user_data)
g_at_chat_send(nd->chat, "AT*TLTS=1", none_prefix,
NULL, NULL, NULL);
break;
+ case OFONO_VENDOR_CINTERION:
+ /*
+ * We can't set rssi bounds from Cinterion responses
+ * so set them up to specified values here
+ *
+ * Cinterion rssi signal strength specified as:
+ * 0 <= -112dBm
+ * 1 - 4 signal strengh in 15 dB steps
+ * 5 >= -51 dBm
+ * 99 not known or undetectable
+ */
+ nd->signal_min = 0;
+ nd->signal_max = 5;
+ nd->signal_invalid = 99;
+
+ /* Register for specific signal strength reports */
+ g_at_chat_send(nd->chat, "AT^SIND=\"rssi\",1", none_prefix,
+ NULL, NULL, NULL);
+ g_at_chat_register(nd->chat, "+CIEV:",
+ cinterion_ciev_notify, FALSE, netreg, NULL);
+ break;
case OFONO_VENDOR_NOKIA:
case OFONO_VENDOR_SAMSUNG:
/* Signal strength reporting via CIND is not supported */
diff --git a/drivers/atmodem/vendor.h b/drivers/atmodem/vendor.h
index c132e453..52071c85 100644
--- a/drivers/atmodem/vendor.h
+++ b/drivers/atmodem/vendor.h
@@ -45,4 +45,5 @@ enum ofono_vendor {
OFONO_VENDOR_ALCATEL,
OFONO_VENDOR_QUECTEL,
OFONO_VENDOR_UBLOX,
+ OFONO_VENDOR_CINTERION,
};