aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorDavid McCullough <david.mccullough@accelecon.com>2014-09-11 11:55:01 +1000
committerAleksander Morgado <aleksander@aleksander.es>2014-09-11 11:01:20 +0200
commit84db93956591947843f640d11ab474c77486f6b5 (patch)
tree41830a17654c4f5a6efefeedd651659ae891a23e /src
parentfd7d0a08f73cb0f8e7166dd34bc713ec0089f62f (diff)
broadband-modem-qmi: fix signal strength when built with --with-newest-qmi-commands
This patch fixes the signal strength values when using ModemManager built with --with-newest-qmi-commands. It was never getting a valid signal strength because the default (0) is always greater than a valid signal strength, and the rssi_max handling was completely wrong. Signed-off-by: David McCullough <david.mccullough@accelecon.com>
Diffstat (limited to 'src')
-rw-r--r--src/mm-broadband-modem-qmi.c26
1 files changed, 13 insertions, 13 deletions
diff --git a/src/mm-broadband-modem-qmi.c b/src/mm-broadband-modem-qmi.c
index d0d672a7..045b3702 100644
--- a/src/mm-broadband-modem-qmi.c
+++ b/src/mm-broadband-modem-qmi.c
@@ -2237,7 +2237,7 @@ signal_info_get_quality (MMBroadbandModemQmi *self,
QmiMessageNasGetSignalInfoOutput *output,
gint8 *out_quality)
{
- gint8 rssi_max = 0;
+ gint8 rssi_max = -125;
gint8 rssi;
g_assert (out_quality != NULL);
@@ -2248,31 +2248,31 @@ signal_info_get_quality (MMBroadbandModemQmi *self,
if (qmi_message_nas_get_signal_info_output_get_cdma_signal_strength (output, &rssi, NULL, NULL)) {
mm_dbg ("RSSI (CDMA): %d dBm", rssi);
if (qmi_dbm_valid (rssi, QMI_NAS_RADIO_INTERFACE_CDMA_1X))
- rssi = MAX (rssi, rssi_max);
+ rssi_max = MAX (rssi, rssi_max);
}
if (qmi_message_nas_get_signal_info_output_get_hdr_signal_strength (output, &rssi, NULL, NULL, NULL, NULL)) {
mm_dbg ("RSSI (HDR): %d dBm", rssi);
if (qmi_dbm_valid (rssi, QMI_NAS_RADIO_INTERFACE_CDMA_1XEVDO))
- rssi = MAX (rssi, rssi_max);
+ rssi_max = MAX (rssi, rssi_max);
}
if (qmi_message_nas_get_signal_info_output_get_gsm_signal_strength (output, &rssi, NULL)) {
mm_dbg ("RSSI (GSM): %d dBm", rssi);
if (qmi_dbm_valid (rssi, QMI_NAS_RADIO_INTERFACE_GSM))
- rssi = MAX (rssi, rssi_max);
+ rssi_max = MAX (rssi, rssi_max);
}
if (qmi_message_nas_get_signal_info_output_get_wcdma_signal_strength (output, &rssi, NULL, NULL)) {
mm_dbg ("RSSI (WCDMA): %d dBm", rssi);
if (qmi_dbm_valid (rssi, QMI_NAS_RADIO_INTERFACE_UMTS))
- rssi = MAX (rssi, rssi_max);
+ rssi_max = MAX (rssi, rssi_max);
}
if (qmi_message_nas_get_signal_info_output_get_lte_signal_strength (output, &rssi, NULL, NULL, NULL, NULL)) {
mm_dbg ("RSSI (LTE): %d dBm", rssi);
if (qmi_dbm_valid (rssi, QMI_NAS_RADIO_INTERFACE_LTE))
- rssi = MAX (rssi, rssi_max);
+ rssi_max = MAX (rssi, rssi_max);
}
/* This RSSI comes as negative dBms */
@@ -2280,7 +2280,7 @@ signal_info_get_quality (MMBroadbandModemQmi *self,
mm_dbg ("RSSI: %d dBm --> %u%%", rssi_max, *out_quality);
- return (rssi_max < 0);
+ return (rssi_max > -125);
}
static void
@@ -6348,7 +6348,7 @@ signal_info_indication_cb (QmiClientNas *client,
QmiIndicationNasSignalInfoOutput *output,
MMBroadbandModemQmi *self)
{
- gint8 rssi_max = 0;
+ gint8 rssi_max = -125;
gint8 rssi;
guint8 quality;
@@ -6361,31 +6361,31 @@ signal_info_indication_cb (QmiClientNas *client,
if (qmi_indication_nas_signal_info_output_get_cdma_signal_strength (output, &rssi, NULL, NULL)) {
mm_dbg ("RSSI (CDMA): %d dBm", rssi);
if (qmi_dbm_valid (rssi, QMI_NAS_RADIO_INTERFACE_CDMA_1X))
- rssi = MAX (rssi, rssi_max);
+ rssi_max = MAX (rssi, rssi_max);
}
if (qmi_indication_nas_signal_info_output_get_hdr_signal_strength (output, &rssi, NULL, NULL, NULL, NULL)) {
mm_dbg ("RSSI (HDR): %d dBm", rssi);
if (qmi_dbm_valid (rssi, QMI_NAS_RADIO_INTERFACE_CDMA_1XEVDO))
- rssi = MAX (rssi, rssi_max);
+ rssi_max = MAX (rssi, rssi_max);
}
if (qmi_indication_nas_signal_info_output_get_gsm_signal_strength (output, &rssi, NULL)) {
mm_dbg ("RSSI (GSM): %d dBm", rssi);
if (qmi_dbm_valid (rssi, QMI_NAS_RADIO_INTERFACE_GSM))
- rssi = MAX (rssi, rssi_max);
+ rssi_max = MAX (rssi, rssi_max);
}
if (qmi_indication_nas_signal_info_output_get_wcdma_signal_strength (output, &rssi, NULL, NULL)) {
mm_dbg ("RSSI (WCDMA): %d dBm", rssi);
if (qmi_dbm_valid (rssi, QMI_NAS_RADIO_INTERFACE_UMTS))
- rssi = MAX (rssi, rssi_max);
+ rssi_max = MAX (rssi, rssi_max);
}
if (qmi_indication_nas_signal_info_output_get_lte_signal_strength (output, &rssi, NULL, NULL, NULL, NULL)) {
mm_dbg ("RSSI (LTE): %d dBm", rssi);
if (qmi_dbm_valid (rssi, QMI_NAS_RADIO_INTERFACE_LTE))
- rssi = MAX (rssi, rssi_max);
+ rssi_max = MAX (rssi, rssi_max);
}
if (rssi_max < 0) {