diff options
Diffstat (limited to 'plugins')
-rw-r--r-- | plugins/mm-modem-novatel-gsm.c | 29 | ||||
-rw-r--r-- | plugins/mm-modem-sierra-gsm.c | 29 | ||||
-rw-r--r-- | plugins/mm-modem-zte.c | 30 |
3 files changed, 14 insertions, 74 deletions
diff --git a/plugins/mm-modem-novatel-gsm.c b/plugins/mm-modem-novatel-gsm.c index baaa92d5..584156fc 100644 --- a/plugins/mm-modem-novatel-gsm.c +++ b/plugins/mm-modem-novatel-gsm.c @@ -261,32 +261,15 @@ get_act_request_done (MMAtSerialPort *port, MMModemGsmAccessTech act = MM_MODEM_GSM_ACCESS_TECH_UNKNOWN; const char *p; - if (error) { + if (error) info->error = g_error_copy (error); - goto done; - } - - p = mm_strip_tag (response->str, "$CNTI:"); - p = strchr (p, ','); - if (p) { - p++; - if (strcasestr (p, "HSDPA/HSUPA")) - act = MM_MODEM_GSM_ACCESS_TECH_HSPA; - else if (strcasestr (p, "HSUPA")) - act = MM_MODEM_GSM_ACCESS_TECH_HSUPA; - else if (strcasestr (p, "HSDPA")) - act = MM_MODEM_GSM_ACCESS_TECH_HSDPA; - else if (strcasestr (p, "UMTS")) - act = MM_MODEM_GSM_ACCESS_TECH_UMTS; - else if (strcasestr (p, "EDGE")) - act = MM_MODEM_GSM_ACCESS_TECH_EDGE; - else if (strcasestr (p, "GPRS")) - act = MM_MODEM_GSM_ACCESS_TECH_GPRS; - else if (strcasestr (p, "GSM")) - act = MM_MODEM_GSM_ACCESS_TECH_GSM; + else { + p = mm_strip_tag (response->str, "$CNTI:"); + p = strchr (p, ','); + if (p) + act = mm_gsm_string_to_access_tech (p + 1); } -done: mm_callback_info_set_result (info, GUINT_TO_POINTER (act), NULL); mm_callback_info_schedule (info); } diff --git a/plugins/mm-modem-sierra-gsm.c b/plugins/mm-modem-sierra-gsm.c index 2ffba638..bf5df313 100644 --- a/plugins/mm-modem-sierra-gsm.c +++ b/plugins/mm-modem-sierra-gsm.c @@ -206,32 +206,15 @@ get_act_request_done (MMAtSerialPort *port, MMModemGsmAccessTech act = MM_MODEM_GSM_ACCESS_TECH_UNKNOWN; const char *p; - if (error) { + if (error) info->error = g_error_copy (error); - goto done; + else { + p = mm_strip_tag (response->str, "*CNTI:"); + p = strchr (p, ','); + if (p) + act = mm_gsm_string_to_access_tech (p + 1); } - p = mm_strip_tag (response->str, "*CNTI:"); - p = strchr (p, ','); - if (p) { - p++; - if (strcasestr (p, "HSDPA/HSUPA")) - act = MM_MODEM_GSM_ACCESS_TECH_HSPA; - else if (strcasestr (p, "HSUPA")) - act = MM_MODEM_GSM_ACCESS_TECH_HSUPA; - else if (strcasestr (p, "HSDPA")) - act = MM_MODEM_GSM_ACCESS_TECH_HSDPA; - else if (strcasestr (p, "UMTS")) - act = MM_MODEM_GSM_ACCESS_TECH_UMTS; - else if (strcasestr (p, "EDGE")) - act = MM_MODEM_GSM_ACCESS_TECH_EDGE; - else if (strcasestr (p, "GPRS")) - act = MM_MODEM_GSM_ACCESS_TECH_GPRS; - else if (strcasestr (p, "GSM")) - act = MM_MODEM_GSM_ACCESS_TECH_GSM; - } - -done: mm_callback_info_set_result (info, GUINT_TO_POINTER (act), NULL); mm_callback_info_schedule (info); } diff --git a/plugins/mm-modem-zte.c b/plugins/mm-modem-zte.c index 0bbf0d24..ba8a1db6 100644 --- a/plugins/mm-modem-zte.c +++ b/plugins/mm-modem-zte.c @@ -56,32 +56,6 @@ mm_modem_zte_new (const char *device, /*****************************************************************************/ -static MMModemGsmAccessTech -zte_act_to_mm (const char *str) -{ - g_return_val_if_fail (str != NULL, MM_MODEM_GSM_ACCESS_TECH_UNKNOWN); - - /* Better technologies are listed first since modem sometimes says - * stuff like "GPRS/EDGE" and that should be handled as EDGE. - */ - if (strcasestr (str, "HSPA")) - return MM_MODEM_GSM_ACCESS_TECH_HSPA; - else if (strcasestr (str, "HSUPA")) - return MM_MODEM_GSM_ACCESS_TECH_HSUPA; - else if (strcasestr (str, "HSDPA")) - return MM_MODEM_GSM_ACCESS_TECH_HSDPA; - else if (strcasestr (str, "UMTS")) - return MM_MODEM_GSM_ACCESS_TECH_UMTS; - else if (strcasestr (str, "EDGE")) - return MM_MODEM_GSM_ACCESS_TECH_EDGE; - else if (strcasestr (str, "GPRS")) - return MM_MODEM_GSM_ACCESS_TECH_GPRS; - else if (strcasestr (str, "GSM")) - return MM_MODEM_GSM_ACCESS_TECH_GSM; - - return MM_MODEM_GSM_ACCESS_TECH_UNKNOWN; -} - static void zte_access_tech_changed (MMAtSerialPort *port, GMatchInfo *info, @@ -92,7 +66,7 @@ zte_access_tech_changed (MMAtSerialPort *port, str = g_match_info_fetch (info, 1); if (str) - act = zte_act_to_mm (str); + act = mm_gsm_string_to_access_tech (str); g_free (str); mm_generic_gsm_update_access_technology (MM_GENERIC_GSM (user_data), act); @@ -262,7 +236,7 @@ get_act_request_done (MMAtSerialPort *port, * +ZPAS: "GPRS/EDGE","CS_ONLY" */ p = mm_strip_tag (response->str, "+ZPAS:"); - act = zte_act_to_mm (p); + act = mm_gsm_string_to_access_tech (p); } mm_callback_info_set_result (info, GUINT_TO_POINTER (act), NULL); |