aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAleksander Morgado <aleksander@lanedo.com>2012-09-07 11:19:26 +0200
committerAleksander Morgado <aleksander@lanedo.com>2012-09-07 11:19:26 +0200
commit997848ef4f6417bbd10696447e6754b7b69d8ee2 (patch)
tree78bbf6e1394a90d0e7ec6e7cbbe327c121f25cbd
parentc2952e0adc3534bfb28ad57f30e9690b236c49a9 (diff)
broadband-modem-qmi: try to use Band Preference for current caps if available
The "NAS Get System Selection Preference" response may come without "Mode Preference". If that is found, look for "Band Preference" and "LTE Band Preference" TLVs and try to build capabilities from those. This makes my UML290 properly report CDMA/EVDO+LTE capabilities: ModemManager[16586]: [/dev/cdc-wdm0] Received message... >>>>>> QMUX: >>>>>> length = 55 >>>>>> flags = 0x80 >>>>>> service = "nas" >>>>>> client = 1 >>>>>> QMI: >>>>>> flags = "response" >>>>>> transaction = 1 >>>>>> tlv_length = 43 >>>>>> message = "Get System Selection Preference" (0x0034) >>>>>> TLV: >>>>>> type = "Result" (0x02) >>>>>> length = 4 >>>>>> value = 00:00:00:00 >>>>>> translated = SUCCESS >>>>>> TLV: >>>>>> type = "Emergency mode" (0x10) >>>>>> length = 1 >>>>>> value = 00 >>>>>> translated = 0 >>>>>> TLV: >>>>>> type = "Band Preference" (0x12) >>>>>> length = 8 >>>>>> value = 07:00:00:00:00:00:00:00 >>>>>> translated = 7 >>>>>> TLV: >>>>>> type = "CDMA PRL Preference" (0x13) >>>>>> length = 2 >>>>>> value = FF:3F >>>>>> translated = 16383 >>>>>> TLV: >>>>>> type = "Roaming Preference" (0x14) >>>>>> length = 2 >>>>>> value = FF:00 >>>>>> translated = 255 >>>>>> TLV: >>>>>> type = "LTE Band Preference" (0x15) >>>>>> length = 8 >>>>>> value = 00:00:00:00:00:00:00:00 >>>>>> translated = 0 ModemManager[16586]: KEY: 01:00:01:03:00:00:00:00 ModemManager[16586]: Service: 03 ModemManager[16586]: Client ID: 01 ModemManager[16586]: Transaction ID: 01:00 ModemManager[16586]: <debug> [1347005734.979115] [mm-broadband-modem-qmi.c:321] load_current_capabilities_get_system_selection_preference_ready(): Mode preference not reported in system selection preference ModemManager[16586]: <debug> [1347005734.979131] [mm-broadband-modem-qmi.c:333] load_current_capabilities_get_system_selection_preference_ready(): Valid bands reported in system selection preference: 'bc-0-a-system, bc-0-b-system, bc-1-all-blocks' ModemManager[16586]: <debug> [1347005734.979141] [mm-broadband-modem-qmi.c:341] load_current_capabilities_get_system_selection_preference_ready(): LTE band preference found ModemManager[16586]: [/dev/cdc-wdm0] Sending message... <<<<<< QMUX: <<<<<< length = 12 <<<<<< flags = 0x00 <<<<<< service = "dms" <<<<<< client = 1 <<<<<< QMI: <<<<<< flags = "none" <<<<<< transaction = 1 <<<<<< tlv_length = 0 <<<<<< message = "Get Capabilities" (0x0020) ModemManager[16586]: KEY: 01:00:01:02:00:00:00:00 ModemManager[16586]: Service: 02 ModemManager[16586]: Client ID: 01 ModemManager[16586]: Transaction ID: 01:00 ModemManager[16586]: <debug> [1347005734.982676] [mm-at-serial-port.c:392] debug_log(): (ttyACM0): <-- '<CR><LF>OK<CR><LF>' ModemManager[16586]: <debug> [1347005734.982751] [mm-serial-port.c:969] mm_serial_port_close(): (ttyACM0) device open count is 2 (close) ModemManager[16586]: <debug> [1347005734.982797] [mm-at-serial-port.c:392] debug_log(): (ttyACM0): --> 'AT+CMEE=1<CR>' ModemManager[16586]: [/dev/cdc-wdm0] Received message... >>>>>> QMUX: >>>>>> length = 38 >>>>>> flags = 0x80 >>>>>> service = "dms" >>>>>> client = 1 >>>>>> QMI: >>>>>> flags = "response" >>>>>> transaction = 1 >>>>>> tlv_length = 26 >>>>>> message = "Get Capabilities" (0x0020) >>>>>> TLV: >>>>>> type = "Result" (0x02) >>>>>> length = 4 >>>>>> value = 00:00:00:00 >>>>>> translated = SUCCESS >>>>>> TLV: >>>>>> type = "Info" (0x01) >>>>>> length = 16 >>>>>> value = B0:9D:57:00:00:DD:6D:00:03:02:05:01:02:04:05:08 >>>>>> translated = [ max_tx_channel_rate = '5742000' max_rx_channel_rate = '7200000' data_service_capability = '3' sim_capability = '2' radio_interface_list = '{ [0] = '1 ' [1] = '2 ' [2] = '4 ' [3] = '5 ' [4] = '8 '}' ] ModemManager[16586]: KEY: 01:00:01:02:00:00:00:00 ModemManager[16586]: Service: 02 ModemManager[16586]: Client ID: 01 ModemManager[16586]: Transaction ID: 01:00 ModemManager[16586]: <debug> [1347005734.983353] [mm-broadband-modem-qmi.c:183] modem_load_current_capabilities_finish(): loaded current capabilities: cdma-evdo, lte
-rw-r--r--src/mm-broadband-modem-qmi.c26
-rw-r--r--src/mm-modem-helpers-qmi.c58
-rw-r--r--src/mm-modem-helpers-qmi.h2
3 files changed, 86 insertions, 0 deletions
diff --git a/src/mm-broadband-modem-qmi.c b/src/mm-broadband-modem-qmi.c
index 11f697a1..929722e5 100644
--- a/src/mm-broadband-modem-qmi.c
+++ b/src/mm-broadband-modem-qmi.c
@@ -316,7 +316,33 @@ load_current_capabilities_get_system_selection_preference_ready (QmiClientNas *c
output,
&mode_preference_mask,
NULL)) {
+ QmiNasBandPreference band_preference_mask;
+
mm_dbg ("Mode preference not reported in system selection preference");
+
+ if (qmi_message_nas_get_system_selection_preference_output_get_band_preference (
+ output,
+ &band_preference_mask,
+ NULL)) {
+ gchar *str;
+
+ str = qmi_nas_band_preference_build_string_from_mask (band_preference_mask);
+ ctx->capabilities = mm_modem_capability_from_qmi_band_preference (band_preference_mask);
+ mm_dbg ("%s bands reported in system selection preference: '%s'",
+ ctx->capabilities == MM_MODEM_CAPABILITY_NONE ? "Unsupported" : "Valid",
+ str);
+ g_free (str);
+
+ /* Just the presence of the LTE band preference tells us it's LTE */
+ if (qmi_message_nas_get_system_selection_preference_output_get_lte_band_preference (
+ output,
+ NULL,
+ NULL)) {
+ mm_dbg ("LTE band preference found");
+ ctx->capabilities |= MM_MODEM_CAPABILITY_LTE;
+ }
+ } else
+ mm_dbg ("Band preference not reported in system selection preference");
} else {
gchar *str;
diff --git a/src/mm-modem-helpers-qmi.c b/src/mm-modem-helpers-qmi.c
index 9a986cac..af1a390c 100644
--- a/src/mm-modem-helpers-qmi.c
+++ b/src/mm-modem-helpers-qmi.c
@@ -687,6 +687,64 @@ mm_modem_capability_from_qmi_radio_technology_preference (QmiNasRadioTechnologyP
/*****************************************************************************/
+#define ALL_3GPP2_BANDS \
+ (QMI_NAS_BAND_PREFERENCE_BC_0_A_SYSTEM | \
+ QMI_NAS_BAND_PREFERENCE_BC_0_B_SYSTEM | \
+ QMI_NAS_BAND_PREFERENCE_BC_1_ALL_BLOCKS | \
+ QMI_NAS_BAND_PREFERENCE_BC_2 | \
+ QMI_NAS_BAND_PREFERENCE_BC_3_A_SYSTEM | \
+ QMI_NAS_BAND_PREFERENCE_BC_4_ALL_BLOCKS | \
+ QMI_NAS_BAND_PREFERENCE_BC_5_ALL_BLOCKS | \
+ QMI_NAS_BAND_PREFERENCE_BC_6 | \
+ QMI_NAS_BAND_PREFERENCE_BC_7 | \
+ QMI_NAS_BAND_PREFERENCE_BC_8 | \
+ QMI_NAS_BAND_PREFERENCE_BC_9 | \
+ QMI_NAS_BAND_PREFERENCE_BC_10 | \
+ QMI_NAS_BAND_PREFERENCE_BC_11 | \
+ QMI_NAS_BAND_PREFERENCE_BC_12 | \
+ QMI_NAS_BAND_PREFERENCE_BC_14 | \
+ QMI_NAS_BAND_PREFERENCE_BC_15 | \
+ QMI_NAS_BAND_PREFERENCE_BC_16 | \
+ QMI_NAS_BAND_PREFERENCE_BC_17 | \
+ QMI_NAS_BAND_PREFERENCE_BC_18 | \
+ QMI_NAS_BAND_PREFERENCE_BC_19)
+
+#define ALL_3GPP_BANDS \
+ (QMI_NAS_BAND_PREFERENCE_GSM_DCS_1800 | \
+ QMI_NAS_BAND_PREFERENCE_GSM_900_EXTENDED | \
+ QMI_NAS_BAND_PREFERENCE_GSM_900_PRIMARY | \
+ QMI_NAS_BAND_PREFERENCE_GSM_450 | \
+ QMI_NAS_BAND_PREFERENCE_GSM_480 | \
+ QMI_NAS_BAND_PREFERENCE_GSM_750 | \
+ QMI_NAS_BAND_PREFERENCE_GSM_850 | \
+ QMI_NAS_BAND_PREFERENCE_GSM_900_RAILWAYS | \
+ QMI_NAS_BAND_PREFERENCE_GSM_PCS_1900 | \
+ QMI_NAS_BAND_PREFERENCE_WCDMA_2100 | \
+ QMI_NAS_BAND_PREFERENCE_WCDMA_PCS_1900 | \
+ QMI_NAS_BAND_PREFERENCE_WCDMA_DCS_1800 | \
+ QMI_NAS_BAND_PREFERENCE_WCDMA_1700_US | \
+ QMI_NAS_BAND_PREFERENCE_WCDMA_850_US | \
+ QMI_NAS_BAND_PREFERENCE_WCDMA_800 | \
+ QMI_NAS_BAND_PREFERENCE_WCDMA_2600 | \
+ QMI_NAS_BAND_PREFERENCE_WCDMA_900 | \
+ QMI_NAS_BAND_PREFERENCE_WCDMA_1700_JAPAN)
+
+MMModemCapability
+mm_modem_capability_from_qmi_band_preference (QmiNasBandPreference qmi)
+{
+ MMModemCapability caps = MM_MODEM_CAPABILITY_NONE;
+
+ if (qmi & ALL_3GPP_BANDS)
+ caps |= MM_MODEM_CAPABILITY_GSM_UMTS;
+
+ if (qmi & ALL_3GPP2_BANDS)
+ caps |= MM_MODEM_CAPABILITY_CDMA_EVDO;
+
+ return caps;
+}
+
+/*****************************************************************************/
+
MMModemMode
mm_modem_mode_from_qmi_gsm_wcdma_acquisition_order_preference (QmiNasGsmWcdmaAcquisitionOrderPreference qmi)
{
diff --git a/src/mm-modem-helpers-qmi.h b/src/mm-modem-helpers-qmi.h
index 8bdf6e67..9c3b1966 100644
--- a/src/mm-modem-helpers-qmi.h
+++ b/src/mm-modem-helpers-qmi.h
@@ -56,6 +56,8 @@ MMModemCapability mm_modem_capability_from_qmi_rat_mode_preference (QmiNasRatMod
MMModemCapability mm_modem_capability_from_qmi_radio_technology_preference (QmiNasRadioTechnologyPreference qmi);
+MMModemCapability mm_modem_capability_from_qmi_band_preference (QmiNasBandPreference qmi);
+
MMModemMode mm_modem_mode_from_qmi_gsm_wcdma_acquisition_order_preference (QmiNasGsmWcdmaAcquisitionOrderPreference qmi);
QmiNasGsmWcdmaAcquisitionOrderPreference mm_modem_mode_to_qmi_gsm_wcdma_acquisition_order_preference (MMModemMode mode);