diff options
Diffstat (limited to 'src/mm-broadband-modem-qmi.c')
-rw-r--r-- | src/mm-broadband-modem-qmi.c | 581 |
1 files changed, 28 insertions, 553 deletions
diff --git a/src/mm-broadband-modem-qmi.c b/src/mm-broadband-modem-qmi.c index 5d16e292..19af9e56 100644 --- a/src/mm-broadband-modem-qmi.c +++ b/src/mm-broadband-modem-qmi.c @@ -27,6 +27,7 @@ #include "mm-log.h" #include "mm-errors-types.h" #include "mm-modem-helpers.h" +#include "mm-modem-helpers-qmi.h" #include "mm-iface-modem.h" #include "mm-iface-modem-3gpp.h" #include "mm-iface-modem-3gpp-ussd.h" @@ -172,27 +173,6 @@ modem_load_current_capabilities_finish (MMIfaceModem *self, return caps; } -static MMModemCapability -qmi_network_to_modem_capability (QmiDmsRadioInterface network) -{ - switch (network) { - case QMI_DMS_RADIO_INTERFACE_CDMA20001X: - return MM_MODEM_CAPABILITY_CDMA_EVDO; - case QMI_DMS_RADIO_INTERFACE_EVDO: - return MM_MODEM_CAPABILITY_CDMA_EVDO; - case QMI_DMS_RADIO_INTERFACE_GSM: - return MM_MODEM_CAPABILITY_GSM_UMTS; - case QMI_DMS_RADIO_INTERFACE_UMTS: - return MM_MODEM_CAPABILITY_GSM_UMTS; - case QMI_DMS_RADIO_INTERFACE_LTE: - return MM_MODEM_CAPABILITY_LTE; - default: - mm_warn ("Unhandled QMI radio interface received (%u)", - (guint)network); - return MM_MODEM_CAPABILITY_NONE; - } -} - static void dms_get_capabilities_ready (QmiClientDms *client, GAsyncResult *res, @@ -223,9 +203,9 @@ dms_get_capabilities_ready (QmiClientDms *client, NULL); for (i = 0; i < radio_interface_list->len; i++) { - mask |= qmi_network_to_modem_capability (g_array_index (radio_interface_list, - QmiDmsRadioInterface, - i)); + mask |= mm_modem_capability_from_qmi_radio_interface (g_array_index (radio_interface_list, + QmiDmsRadioInterface, + i)); } g_simple_async_result_set_op_res_gpointer (simple, @@ -760,36 +740,6 @@ modem_load_unlock_required_finish (MMIfaceModem *self, G_SIMPLE_ASYNC_RESULT (res))); } -static MMModemLock -uim_pin_status_to_modem_lock (QmiDmsUimPinStatus status, - gboolean pin1) /* TRUE for PIN1, FALSE for PIN2 */ -{ - switch (status) { - case QMI_DMS_UIM_PIN_STATUS_NOT_INITIALIZED: - return MM_MODEM_LOCK_UNKNOWN; - case QMI_DMS_UIM_PIN_STATUS_ENABLED_NOT_VERIFIED: - return pin1 ? MM_MODEM_LOCK_SIM_PIN : MM_MODEM_LOCK_SIM_PIN2; - case QMI_DMS_UIM_PIN_STATUS_ENABLED_VERIFIED: - return MM_MODEM_LOCK_NONE; - case QMI_DMS_UIM_PIN_STATUS_DISABLED: - return MM_MODEM_LOCK_NONE; - case QMI_DMS_UIM_PIN_STATUS_BLOCKED: - return pin1 ? MM_MODEM_LOCK_SIM_PUK : MM_MODEM_LOCK_SIM_PUK2; - case QMI_DMS_UIM_PIN_STATUS_PERMANENTLY_BLOCKED: - return MM_MODEM_LOCK_UNKNOWN; - case QMI_DMS_UIM_PIN_STATUS_UNBLOCKED: - /* This state is possibly given when after an Unblock() operation has been performed. - * We'll assume the PIN is verified after this. */ - return MM_MODEM_LOCK_NONE; - case QMI_DMS_UIM_PIN_STATUS_CHANGED: - /* This state is possibly given when after an ChangePin() operation has been performed. - * We'll assume the PIN is verified after this. */ - return MM_MODEM_LOCK_NONE; - default: - return MM_MODEM_LOCK_UNKNOWN; - } -} - static void dms_uim_get_pin_status_ready (QmiClientDms *client, GAsyncResult *res, @@ -828,7 +778,7 @@ dms_uim_get_pin_status_ready (QmiClientDms *client, NULL, /* verify_retries_left */ NULL, /* unblock_retries_left */ NULL)) - lock = uim_pin_status_to_modem_lock (current_status, TRUE); + lock = mm_modem_lock_from_qmi_uim_pin_status (current_status, TRUE); if (lock == MM_MODEM_LOCK_NONE && qmi_message_dms_uim_get_pin_status_output_get_pin2_status ( @@ -837,7 +787,7 @@ dms_uim_get_pin_status_ready (QmiClientDms *client, NULL, /* verify_retries_left */ NULL, /* unblock_retries_left */ NULL)) - lock = uim_pin_status_to_modem_lock (current_status, FALSE); + lock = mm_modem_lock_from_qmi_uim_pin_status (current_status, FALSE); g_simple_async_result_set_op_res_gpointer (simple, GUINT_TO_POINTER (lock), NULL); } @@ -984,165 +934,6 @@ modem_load_supported_bands_finish (MMIfaceModem *self, G_SIMPLE_ASYNC_RESULT (res))); } -typedef struct { - QmiDmsBandCapability qmi_band; - MMModemBand mm_band; -} BandsMap; - -static const BandsMap bands_map [] = { - /* CDMA bands */ - { - (QMI_DMS_BAND_CAPABILITY_BC_0_A_SYSTEM | QMI_DMS_BAND_CAPABILITY_BC_0_B_SYSTEM), - MM_MODEM_BAND_CDMA_BC0_CELLULAR_800 - }, - { QMI_DMS_BAND_CAPABILITY_BC_1_ALL_BLOCKS, MM_MODEM_BAND_CDMA_BC1_PCS_1900 }, - { QMI_DMS_BAND_CAPABILITY_BC_2, MM_MODEM_BAND_CDMA_BC2_TACS }, - { QMI_DMS_BAND_CAPABILITY_BC_3_A_SYSTEM, MM_MODEM_BAND_CDMA_BC3_JTACS }, - { QMI_DMS_BAND_CAPABILITY_BC_4_ALL_BLOCKS, MM_MODEM_BAND_CDMA_BC4_KOREAN_PCS }, - { QMI_DMS_BAND_CAPABILITY_BC_5_ALL_BLOCKS, MM_MODEM_BAND_CDMA_BC5_NMT450 }, - { QMI_DMS_BAND_CAPABILITY_BC_6, MM_MODEM_BAND_CDMA_BC6_IMT2000 }, - { QMI_DMS_BAND_CAPABILITY_BC_7, MM_MODEM_BAND_CDMA_BC7_CELLULAR_700 }, - { QMI_DMS_BAND_CAPABILITY_BC_8, MM_MODEM_BAND_CDMA_BC8_1800 }, - { QMI_DMS_BAND_CAPABILITY_BC_9, MM_MODEM_BAND_CDMA_BC9_900 }, - { QMI_DMS_BAND_CAPABILITY_BC_10, MM_MODEM_BAND_CDMA_BC10_SECONDARY_800 }, - { QMI_DMS_BAND_CAPABILITY_BC_11, MM_MODEM_BAND_CDMA_BC11_PAMR_400 }, - { QMI_DMS_BAND_CAPABILITY_BC_12, MM_MODEM_BAND_CDMA_BC12_PAMR_800 }, - { QMI_DMS_BAND_CAPABILITY_BC_14, MM_MODEM_BAND_CDMA_BC14_PCS2_1900 }, - { QMI_DMS_BAND_CAPABILITY_BC_15, MM_MODEM_BAND_CDMA_BC15_AWS }, - { QMI_DMS_BAND_CAPABILITY_BC_16, MM_MODEM_BAND_CDMA_BC16_US_2500 }, - { QMI_DMS_BAND_CAPABILITY_BC_17, MM_MODEM_BAND_CDMA_BC17_US_FLO_2500 }, - { QMI_DMS_BAND_CAPABILITY_BC_18, MM_MODEM_BAND_CDMA_BC18_US_PS_700 }, - { QMI_DMS_BAND_CAPABILITY_BC_19, MM_MODEM_BAND_CDMA_BC19_US_LOWER_700 }, - - /* GSM bands */ - { QMI_DMS_BAND_CAPABILITY_GSM_DCS_1800, MM_MODEM_BAND_DCS }, - { QMI_DMS_BAND_CAPABILITY_GSM_900_EXTENDED, MM_MODEM_BAND_EGSM }, - { QMI_DMS_BAND_CAPABILITY_GSM_PCS_1900, MM_MODEM_BAND_PCS }, - { QMI_DMS_BAND_CAPABILITY_GSM_850, MM_MODEM_BAND_G850 }, - - /* UMTS/WCDMA bands */ - { QMI_DMS_BAND_CAPABILITY_WCDMA_2100, MM_MODEM_BAND_U2100 }, - { QMI_DMS_BAND_CAPABILITY_WCDMA_DCS_1800, MM_MODEM_BAND_U1800 }, - { QMI_DMS_BAND_CAPABILITY_WCDMA_1700_US, MM_MODEM_BAND_U17IV }, - { QMI_DMS_BAND_CAPABILITY_WCDMA_800, MM_MODEM_BAND_U800 }, - { - (QMI_DMS_BAND_CAPABILITY_WCDMA_850_US | QMI_DMS_BAND_CAPABILITY_WCDMA_850_JAPAN), - MM_MODEM_BAND_U850 - }, - { QMI_DMS_BAND_CAPABILITY_WCDMA_900, MM_MODEM_BAND_U900 }, - { QMI_DMS_BAND_CAPABILITY_WCDMA_1700_JAPAN, MM_MODEM_BAND_U17IX }, - { QMI_DMS_BAND_CAPABILITY_WCDMA_2600, MM_MODEM_BAND_U2600 } - - /* NOTE. The following bands were unmatched: - * - * - QMI_DMS_BAND_CAPABILITY_GSM_900_PRIMARY - * - QMI_DMS_BAND_CAPABILITY_GSM_450 - * - QMI_DMS_BAND_CAPABILITY_GSM_480 - * - QMI_DMS_BAND_CAPABILITY_GSM_750 - * - QMI_DMS_BAND_CAPABILITY_GSM_900_RAILWAILS - * - QMI_DMS_BAND_CAPABILITY_WCDMA_1500 - * - MM_MODEM_BAND_CDMA_BC13_IMT2000_2500 - * - MM_MODEM_BAND_U1900 - */ -}; - -static void -add_qmi_bands (GArray *mm_bands, - QmiDmsBandCapability qmi_bands) -{ - static QmiDmsBandCapability qmi_bands_expected = 0; - QmiDmsBandCapability not_expected; - guint i; - - g_assert (mm_bands != NULL); - - /* Build mask of expected bands only once */ - if (G_UNLIKELY (qmi_bands_expected == 0)) { - for (i = 0; i < G_N_ELEMENTS (bands_map); i++) { - qmi_bands_expected |= bands_map[i].qmi_band; - } - } - - /* Log about the bands that cannot be represented in ModemManager */ - not_expected = ((qmi_bands_expected ^ qmi_bands) & qmi_bands); - if (not_expected) { - gchar *aux; - - aux = qmi_dms_band_capability_build_string_from_mask (not_expected); - mm_dbg ("Cannot add the following bands: '%s'", aux); - g_free (aux); - } - - /* And add the expected ones */ - for (i = 0; i < G_N_ELEMENTS (bands_map); i++) { - if (qmi_bands & bands_map[i].qmi_band) - g_array_append_val (mm_bands, bands_map[i].mm_band); - } -} - -typedef struct { - QmiDmsLteBandCapability qmi_band; - MMModemBand mm_band; -} LteBandsMap; - -static const LteBandsMap lte_bands_map [] = { - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_1, MM_MODEM_BAND_EUTRAN_I }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_2, MM_MODEM_BAND_EUTRAN_II }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_3, MM_MODEM_BAND_EUTRAN_III }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_4, MM_MODEM_BAND_EUTRAN_IV }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_5, MM_MODEM_BAND_EUTRAN_V }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_6, MM_MODEM_BAND_EUTRAN_VI }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_7, MM_MODEM_BAND_EUTRAN_VII }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_8, MM_MODEM_BAND_EUTRAN_VIII }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_9, MM_MODEM_BAND_EUTRAN_IX }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_10, MM_MODEM_BAND_EUTRAN_X }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_11, MM_MODEM_BAND_EUTRAN_XI }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_12, MM_MODEM_BAND_EUTRAN_XII }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_13, MM_MODEM_BAND_EUTRAN_XIII }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_14, MM_MODEM_BAND_EUTRAN_XIV }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_17, MM_MODEM_BAND_EUTRAN_XVII }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_18, MM_MODEM_BAND_EUTRAN_XVIII }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_19, MM_MODEM_BAND_EUTRAN_XIX }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_20, MM_MODEM_BAND_EUTRAN_XX }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_21, MM_MODEM_BAND_EUTRAN_XXI }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_24, MM_MODEM_BAND_EUTRAN_XXIV }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_25, MM_MODEM_BAND_EUTRAN_XXV }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_33, MM_MODEM_BAND_EUTRAN_XXXIII }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_34, MM_MODEM_BAND_EUTRAN_XXXIV }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_35, MM_MODEM_BAND_EUTRAN_XXXV }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_36, MM_MODEM_BAND_EUTRAN_XXXVI }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_37, MM_MODEM_BAND_EUTRAN_XXXVII }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_38, MM_MODEM_BAND_EUTRAN_XXXVIII }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_39, MM_MODEM_BAND_EUTRAN_XXXIX }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_40, MM_MODEM_BAND_EUTRAN_XL }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_41, MM_MODEM_BAND_EUTRAN_XLI }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_42, MM_MODEM_BAND_EUTRAN_XLI }, - { QMI_DMS_LTE_BAND_CAPABILITY_EUTRAN_43, MM_MODEM_BAND_EUTRAN_XLIII } - - /* NOTE. The following bands were unmatched: - * - * - MM_MODEM_BAND_EUTRAN_XXII - * - MM_MODEM_BAND_EUTRAN_XXIII - * - MM_MODEM_BAND_EUTRAN_XXVI - */ -}; - -static void -add_qmi_lte_bands (GArray *mm_bands, - QmiDmsLteBandCapability qmi_bands) -{ - /* All QMI LTE bands have a counterpart in ModemManager, no need to check - * for unexpected ones */ - guint i; - - g_assert (mm_bands != NULL); - - for (i = 0; i < G_N_ELEMENTS (lte_bands_map); i++) { - if (qmi_bands & lte_bands_map[i].qmi_band) - g_array_append_val (mm_bands, lte_bands_map[i].mm_band); - } -} - static void dms_get_band_capabilities_ready (QmiClientDms *client, GAsyncResult *res, @@ -1160,24 +951,19 @@ dms_get_band_capabilities_ready (QmiClientDms *client, g_simple_async_result_take_error (simple, error); } else { GArray *mm_bands; - QmiDmsBandCapability qmi_bands; - QmiDmsLteBandCapability qmi_lte_bands; - - mm_bands = g_array_new (FALSE, FALSE, sizeof (MMModemBand)); + QmiDmsBandCapability qmi_bands = 0; + QmiDmsLteBandCapability qmi_lte_bands = 0; qmi_message_dms_get_band_capabilities_output_get_band_capability ( output, &qmi_bands, NULL); + qmi_message_dms_get_band_capabilities_output_get_lte_band_capability ( + output, + &qmi_lte_bands, + NULL); - add_qmi_bands (mm_bands, qmi_bands); - - if (qmi_message_dms_get_band_capabilities_output_get_lte_band_capability ( - output, - &qmi_lte_bands, - NULL)) { - add_qmi_lte_bands (mm_bands, qmi_lte_bands); - } + mm_bands = mm_modem_bands_from_qmi_band_capabilities (qmi_bands, qmi_lte_bands); if (mm_bands->len == 0) { g_array_unref (mm_bands); @@ -1759,33 +1545,6 @@ load_allowed_modes_finish (MMIfaceModem *self, static void load_allowed_modes_context_step (LoadAllowedModesContext *ctx); -static MMModemMode -modem_mode_from_qmi_radio_technology_preference (QmiNasRatModePreference qmi) -{ - MMModemMode mode = MM_MODEM_MODE_NONE; - - if (qmi & QMI_NAS_RADIO_TECHNOLOGY_PREFERENCE_3GPP2) { - if (qmi & QMI_NAS_RADIO_TECHNOLOGY_PREFERENCE_AMPS_OR_GSM) - mode |= MM_MODEM_MODE_CS; /* AMPS */ - if (qmi & QMI_NAS_RADIO_TECHNOLOGY_PREFERENCE_CDMA_OR_WCDMA) - mode |= MM_MODEM_MODE_2G; /* CDMA */ - if (qmi & QMI_NAS_RADIO_TECHNOLOGY_PREFERENCE_HDR) - mode |= MM_MODEM_MODE_3G; /* EV-DO */ - } - - if (qmi & QMI_NAS_RADIO_TECHNOLOGY_PREFERENCE_3GPP) { - if (qmi & QMI_NAS_RADIO_TECHNOLOGY_PREFERENCE_AMPS_OR_GSM) - mode |= (MM_MODEM_MODE_CS | MM_MODEM_MODE_2G); /* GSM */ - if (qmi & QMI_NAS_RADIO_TECHNOLOGY_PREFERENCE_CDMA_OR_WCDMA) - mode |= MM_MODEM_MODE_3G; /* WCDMA */ - } - - if (qmi & QMI_NAS_RADIO_TECHNOLOGY_PREFERENCE_LTE) - mode |= MM_MODEM_MODE_4G; - - return mode; -} - static void get_technology_preference_ready (QmiClientNas *client, GAsyncResult *res, @@ -1811,7 +1570,7 @@ get_technology_preference_ready (QmiClientNas *client, &preference_mask, NULL, /* duration */ NULL); - allowed = modem_mode_from_qmi_radio_technology_preference (preference_mask); + allowed = mm_modem_mode_from_qmi_radio_technology_preference (preference_mask); if (allowed == MM_MODEM_MODE_NONE) { gchar *str; @@ -1844,50 +1603,6 @@ get_technology_preference_ready (QmiClientNas *client, #if defined WITH_NEWEST_QMI_COMMANDS -static MMModemMode -modem_mode_from_qmi_rat_mode_preference (QmiNasRatModePreference qmi) -{ - MMModemMode mode = MM_MODEM_MODE_NONE; - - if (qmi & QMI_NAS_RAT_MODE_PREFERENCE_CDMA_1X) - mode |= MM_MODEM_MODE_2G; - - if (qmi & QMI_NAS_RAT_MODE_PREFERENCE_CDMA_1XEVDO) - mode |= MM_MODEM_MODE_3G; - - if (qmi & QMI_NAS_RAT_MODE_PREFERENCE_GSM) - mode |= MM_MODEM_MODE_2G; - - if (qmi & QMI_NAS_RAT_MODE_PREFERENCE_UMTS) - mode |= MM_MODEM_MODE_3G; - - if (qmi & QMI_NAS_RAT_MODE_PREFERENCE_LTE) - mode |= MM_MODEM_MODE_4G; - - /* Assume CS if 2G supported */ - if (mode & MM_MODEM_MODE_2G) - mode |= MM_MODEM_MODE_CS; - - return mode; -} - -static MMModemMode -modem_mode_from_qmi_gsm_wcdma_acquisition_order_preference (QmiNasGsmWcdmaAcquisitionOrderPreference qmi) -{ - switch (qmi) { - case QMI_NAS_GSM_WCDMA_ACQUISITION_ORDER_PREFERENCE_AUTOMATIC: - return MM_MODEM_MODE_NONE; - case QMI_NAS_GSM_WCDMA_ACQUISITION_ORDER_PREFERENCE_GSM: - return MM_MODEM_MODE_2G; - case QMI_NAS_GSM_WCDMA_ACQUISITION_ORDER_PREFERENCE_WCDMA: - return MM_MODEM_MODE_3G; - default: - mm_dbg ("Unknown acquisition order preference: '%s'", - qmi_nas_gsm_wcdma_acquisition_order_preference_get_string (qmi)); - return MM_MODEM_MODE_NONE; - } -} - static void allowed_modes_get_system_selection_preference_ready (QmiClientNas *client, GAsyncResult *res, @@ -1916,7 +1631,7 @@ allowed_modes_get_system_selection_preference_ready (QmiClientNas *client, } else { MMModemMode allowed; - allowed = modem_mode_from_qmi_rat_mode_preference (mode_preference_mask); + allowed = mm_modem_mode_from_qmi_rat_mode_preference (mode_preference_mask); if (allowed == MM_MODEM_MODE_NONE) { gchar *str; @@ -1937,7 +1652,7 @@ allowed_modes_get_system_selection_preference_ready (QmiClientNas *client, output, &gsm_or_wcdma, NULL)) { - result->preferred = modem_mode_from_qmi_gsm_wcdma_acquisition_order_preference (gsm_or_wcdma); + result->preferred = mm_modem_mode_from_qmi_gsm_wcdma_acquisition_order_preference (gsm_or_wcdma); } } } @@ -2131,89 +1846,6 @@ allowed_modes_set_system_selection_preference_ready (QmiClientNas *client, #endif /* WITH_NEWEST_QMI_COMMANDS */ -static QmiNasRatModePreference -modem_mode_to_qmi_radio_technology_preference (MMModemMode mode, - gboolean is_cdma) -{ - QmiNasRatModePreference pref = 0; - - if (is_cdma) { - pref |= QMI_NAS_RADIO_TECHNOLOGY_PREFERENCE_3GPP2; - if (mode & MM_MODEM_MODE_2G) - pref |= QMI_NAS_RADIO_TECHNOLOGY_PREFERENCE_CDMA_OR_WCDMA; /* CDMA */ - if (mode & MM_MODEM_MODE_3G) - pref |= QMI_NAS_RADIO_TECHNOLOGY_PREFERENCE_HDR; /* EV-DO */ - } else { - pref |= QMI_NAS_RADIO_TECHNOLOGY_PREFERENCE_3GPP; - if (mode & MM_MODEM_MODE_2G) - pref |= QMI_NAS_RADIO_TECHNOLOGY_PREFERENCE_AMPS_OR_GSM; /* GSM */ - if (mode & MM_MODEM_MODE_3G) - pref |= QMI_NAS_RADIO_TECHNOLOGY_PREFERENCE_CDMA_OR_WCDMA; /* WCDMA */ - } - - if (mode & MM_MODEM_MODE_4G) - pref |= QMI_NAS_RADIO_TECHNOLOGY_PREFERENCE_LTE; - - return pref; -} - -#if defined WITH_NEWEST_QMI_COMMANDS - -static QmiNasRatModePreference -modem_mode_to_qmi_rat_mode_preference (MMModemMode mode, - gboolean is_cdma, - gboolean is_3gpp) -{ - QmiNasRatModePreference pref = 0; - - if (is_cdma) { - if (mode & MM_MODEM_MODE_2G) - pref |= QMI_NAS_RAT_MODE_PREFERENCE_CDMA_1X; - - if (mode & MM_MODEM_MODE_3G) - pref |= QMI_NAS_RAT_MODE_PREFERENCE_CDMA_1XEVDO; - } - - if (is_3gpp) { - if (mode & MM_MODEM_MODE_2G) - pref |= QMI_NAS_RAT_MODE_PREFERENCE_GSM; - - if (mode & MM_MODEM_MODE_3G) - pref |= QMI_NAS_RAT_MODE_PREFERENCE_UMTS; - - if (mode & MM_MODEM_MODE_4G) - pref |= QMI_NAS_RAT_MODE_PREFERENCE_LTE; - } - - return mode; -} - -static QmiNasGsmWcdmaAcquisitionOrderPreference -modem_mode_to_qmi_gsm_wcdma_acquisition_order_preference (MMModemMode mode) -{ - gchar *str; - - /* mode is not a mask in this case, only a value */ - - switch (mode) { - case MM_MODEM_MODE_3G: - return QMI_NAS_GSM_WCDMA_ACQUISITION_ORDER_PREFERENCE_WCDMA; - case MM_MODEM_MODE_2G: - return QMI_NAS_GSM_WCDMA_ACQUISITION_ORDER_PREFERENCE_GSM; - case MM_MODEM_MODE_NONE: - return QMI_NAS_GSM_WCDMA_ACQUISITION_ORDER_PREFERENCE_AUTOMATIC; - default: - break; - } - - str = mm_modem_mode_build_string_from_mask (mode); - mm_dbg ("Unhandled modem mode: '%s'", str); - g_free (str); - return MM_MODEM_MODE_NONE; -} - -#endif /* WITH_NEWEST_QMI_COMMANDS */ - static void set_allowed_modes_context_step (SetAllowedModesContext *ctx) { @@ -2276,8 +1908,8 @@ set_allowed_modes_context_step (SetAllowedModesContext *ctx) return; } - pref = modem_mode_to_qmi_radio_technology_preference (ctx->allowed, - mm_iface_modem_is_cdma (MM_IFACE_MODEM (ctx->self))); + pref = mm_modem_mode_to_qmi_radio_technology_preference (ctx->allowed, + mm_iface_modem_is_cdma (MM_IFACE_MODEM (ctx->self))); if (!pref) { gchar *str; @@ -2434,32 +2066,6 @@ modem_3gpp_load_enabled_facility_locks_finish (MMIfaceModem3gpp *self, g_simple_async_result_get_op_res_gpointer (G_SIMPLE_ASYNC_RESULT (res)))); } -static QmiDmsUimFacility -get_qmi_facility_from_mm_facility (MMModem3gppFacility mm) -{ - switch (mm) { - case MM_MODEM_3GPP_FACILITY_PH_SIM: - /* Not really sure about this one; it may be PH_FSIM? */ - return QMI_DMS_UIM_FACILITY_PF; - - case MM_MODEM_3GPP_FACILITY_NET_PERS: - return QMI_DMS_UIM_FACILITY_PN; - - case MM_MODEM_3GPP_FACILITY_NET_SUB_PERS: - return QMI_DMS_UIM_FACILITY_PU; - - case MM_MODEM_3GPP_FACILITY_PROVIDER_PERS: - return QMI_DMS_UIM_FACILITY_PP; - - case MM_MODEM_3GPP_FACILITY_CORP_PERS: - return QMI_DMS_UIM_FACILITY_PC; - - default: - /* Never try to ask for a facility we cannot translate */ - g_assert_not_reached (); - } -} - static void dms_uim_get_ck_status_ready (QmiClientDms *client, GAsyncResult *res, @@ -2525,7 +2131,7 @@ get_next_facility_lock_status (LoadEnabledFacilityLocksContext *ctx) input = qmi_message_dms_uim_get_ck_status_input_new (); qmi_message_dms_uim_get_ck_status_input_set_facility ( input, - get_qmi_facility_from_mm_facility (facility), + mm_3gpp_facility_to_qmi_uim_facility (facility), NULL); qmi_client_dms_uim_get_ck_status (QMI_CLIENT_DMS (ctx->client), input, @@ -2634,28 +2240,6 @@ get_3gpp_network_info (QmiMessageNasNetworkScanOutputNetworkInformationElement * } static MMModemAccessTechnology -access_technology_from_qmi_rat (QmiNasRadioInterface interface) -{ - switch (interface) { - case QMI_NAS_RADIO_INTERFACE_CDMA_1X: - return MM_MODEM_ACCESS_TECHNOLOGY_1XRTT; - case QMI_NAS_RADIO_INTERFACE_CDMA_1XEVDO: - return MM_MODEM_ACCESS_TECHNOLOGY_EVDO0; - case QMI_NAS_RADIO_INTERFACE_GSM: - return MM_MODEM_ACCESS_TECHNOLOGY_GSM; - case QMI_NAS_RADIO_INTERFACE_UMTS: - return MM_MODEM_ACCESS_TECHNOLOGY_UMTS; - case QMI_NAS_RADIO_INTERFACE_LTE: - return MM_MODEM_ACCESS_TECHNOLOGY_LTE; - case QMI_NAS_RADIO_INTERFACE_TD_SCDMA: - case QMI_NAS_RADIO_INTERFACE_AMPS: - case QMI_NAS_RADIO_INTERFACE_NONE: - default: - return MM_MODEM_ACCESS_TECHNOLOGY_UNKNOWN; - } -} - -static MMModemAccessTechnology get_3gpp_access_technology (GArray *array, gboolean *array_used_flags, guint16 mcc, @@ -2673,7 +2257,7 @@ get_3gpp_access_technology (GArray *array, if (element->mcc == mcc && element->mnc == mnc) { array_used_flags[i] = TRUE; - return access_technology_from_qmi_rat (element->radio_interface); + return mm_modem_access_technology_from_qmi_radio_interface (element->radio_interface); } } @@ -2981,100 +2565,6 @@ modem_3gpp_run_registration_checks_finish (MMIfaceModem3gpp *self, return !g_simple_async_result_propagate_error (G_SIMPLE_ASYNC_RESULT (res), error); } -static MMModem3gppRegistrationState -qmi_registration_state_to_3gpp_registration_state (QmiNasAttachState attach_state, - QmiNasRegistrationState registration_state, - gboolean roaming) -{ - if (attach_state == QMI_NAS_ATTACH_STATE_UNKNOWN) - return MM_MODEM_3GPP_REGISTRATION_STATE_UNKNOWN; - - if (attach_state == QMI_NAS_ATTACH_STATE_DETACHED) - return QMI_NAS_REGISTRATION_STATE_NOT_REGISTERED; - - /* attached */ - - switch (registration_state) { - case QMI_NAS_REGISTRATION_STATE_NOT_REGISTERED: - return MM_MODEM_3GPP_REGISTRATION_STATE_IDLE; - case QMI_NAS_REGISTRATION_STATE_REGISTERED: - return (roaming ? MM_MODEM_3GPP_REGISTRATION_STATE_ROAMING : MM_MODEM_3GPP_REGISTRATION_STATE_HOME); - case QMI_NAS_REGISTRATION_STATE_NOT_REGISTERED_SEARCHING: - return MM_MODEM_3GPP_REGISTRATION_STATE_SEARCHING; - case QMI_NAS_REGISTRATION_STATE_REGISTRATION_DENIED: - return MM_MODEM_3GPP_REGISTRATION_STATE_DENIED; - case QMI_NAS_REGISTRATION_STATE_UNKNOWN: - default: - return MM_MODEM_3GPP_REGISTRATION_STATE_UNKNOWN; - } -} - -static MMModemAccessTechnology -qmi_radio_interface_list_to_access_technologies (GArray *radio_interfaces) -{ - MMModemAccessTechnology access_technology = 0; - guint i; - - for (i = 0; i < radio_interfaces->len; i++) { - QmiNasRadioInterface iface; - - iface = g_array_index (radio_interfaces, QmiNasRadioInterface, i); - access_technology |= access_technology_from_qmi_rat (iface); - } - - return access_technology; -} - -static MMModemAccessTechnology -access_technology_from_qmi_data_capability (QmiNasDataCapability cap) -{ - switch (cap) { - case QMI_NAS_DATA_CAPABILITY_GPRS: - return MM_MODEM_ACCESS_TECHNOLOGY_GPRS; - case QMI_NAS_DATA_CAPABILITY_EDGE: - return MM_MODEM_ACCESS_TECHNOLOGY_EDGE; - case QMI_NAS_DATA_CAPABILITY_HSDPA: - return MM_MODEM_ACCESS_TECHNOLOGY_HSDPA; - case QMI_NAS_DATA_CAPABILITY_HSUPA: - return MM_MODEM_ACCESS_TECHNOLOGY_HSUPA; - case QMI_NAS_DATA_CAPABILITY_WCDMA: - return MM_MODEM_ACCESS_TECHNOLOGY_UMTS; - case QMI_NAS_DATA_CAPABILITY_CDMA: - return MM_MODEM_ACCESS_TECHNOLOGY_1XRTT; - case QMI_NAS_DATA_CAPABILITY_EVDO_REV_0: - return MM_MODEM_ACCESS_TECHNOLOGY_EVDO0; - case QMI_NAS_DATA_CAPABILITY_EVDO_REV_A: - return MM_MODEM_ACCESS_TECHNOLOGY_EVDOA; - case QMI_NAS_DATA_CAPABILITY_GSM: - return MM_MODEM_ACCESS_TECHNOLOGY_GSM; - case QMI_NAS_DATA_CAPABILITY_EVDO_REV_B: - return MM_MODEM_ACCESS_TECHNOLOGY_EVDOB; - case QMI_NAS_DATA_CAPABILITY_LTE: - return MM_MODEM_ACCESS_TECHNOLOGY_LTE; - case QMI_NAS_DATA_CAPABILITY_HSDPA_PLUS: - case QMI_NAS_DATA_CAPABILITY_DC_HSDPA_PLUS: - return MM_MODEM_ACCESS_TECHNOLOGY_HSPA_PLUS; - default: - return MM_MODEM_ACCESS_TECHNOLOGY_UNKNOWN; - } -} - -static MMModemAccessTechnology -qmi_data_capability_list_to_access_technologies (GArray *data_capabilities) -{ - MMModemAccessTechnology access_technology = 0; - guint i; - - for (i = 0; i < data_capabilities->len; i++) { - QmiNasDataCapability cap; - - cap = g_array_index (data_capabilities, QmiNasDataCapability, i); - access_technology |= access_technology_from_qmi_data_capability (cap); - } - - return access_technology; -} - static void common_process_serving_system_3gpp (MMBroadbandModemQmi *self, QmiMessageNasGetServingSystemOutput *response_output, @@ -3125,10 +2615,10 @@ common_process_serving_system_3gpp (MMBroadbandModemQmi *self, if (data_service_capabilities) mm_access_technologies = - qmi_data_capability_list_to_access_technologies (data_service_capabilities); + mm_modem_access_technologies_from_qmi_data_capability_array (data_service_capabilities); else mm_access_technologies = - qmi_radio_interface_list_to_access_technologies (radio_interfaces); + mm_modem_access_technologies_from_qmi_radio_interface_array (radio_interfaces); /* Only process 3GPP info. * Seen the case already where 'selected_network' gives UNKNOWN but we still @@ -3161,12 +2651,12 @@ common_process_serving_system_3gpp (MMBroadbandModemQmi *self, /* Build MM registration states */ mm_cs_registration_state = - qmi_registration_state_to_3gpp_registration_state ( + mm_modem_3gpp_registration_state_from_qmi_registration_state ( cs_attach_state, registration_state, (roaming == QMI_NAS_ROAMING_INDICATOR_STATUS_ON)); mm_ps_registration_state = - qmi_registration_state_to_3gpp_registration_state ( + mm_modem_3gpp_registration_state_from_qmi_registration_state ( ps_attach_state, registration_state, (roaming == QMI_NAS_ROAMING_INDICATOR_STATUS_ON)); @@ -4057,21 +3547,6 @@ modem_cdma_run_registration_checks_finish (MMIfaceModemCdma *self, return !g_simple_async_result_propagate_error (G_SIMPLE_ASYNC_RESULT (res), error); } -static MMModemCdmaRegistrationState -qmi_registration_state_to_cdma_registration_state (QmiNasRegistrationState registration_state) -{ - switch (registration_state) { - case QMI_NAS_REGISTRATION_STATE_REGISTERED: - return MM_MODEM_CDMA_REGISTRATION_STATE_REGISTERED; - case QMI_NAS_REGISTRATION_STATE_NOT_REGISTERED: - case QMI_NAS_REGISTRATION_STATE_NOT_REGISTERED_SEARCHING: - case QMI_NAS_REGISTRATION_STATE_REGISTRATION_DENIED: - case QMI_NAS_REGISTRATION_STATE_UNKNOWN: - default: - return MM_MODEM_3GPP_REGISTRATION_STATE_UNKNOWN; - } -} - static void common_process_serving_system_cdma (MMBroadbandModemQmi *self, QmiMessageNasGetServingSystemOutput *response_output, @@ -4118,10 +3593,10 @@ common_process_serving_system_cdma (MMBroadbandModemQmi *self, NULL); if (data_service_capabilities) mm_access_technologies = - qmi_data_capability_list_to_access_technologies (data_service_capabilities); + mm_modem_access_technologies_from_qmi_data_capability_array (data_service_capabilities); else mm_access_technologies = - qmi_radio_interface_list_to_access_technologies (radio_interfaces); + mm_modem_access_technologies_from_qmi_radio_interface_array (radio_interfaces); /* Only process 3GPP2 info */ if (selected_network == QMI_NAS_NETWORK_TYPE_3GPP2 || @@ -4151,12 +3626,12 @@ common_process_serving_system_cdma (MMBroadbandModemQmi *self, /* Build registration states */ if (mm_access_technologies & MM_IFACE_MODEM_CDMA_ALL_CDMA1X_ACCESS_TECHNOLOGIES_MASK) - mm_cdma1x_registration_state = qmi_registration_state_to_cdma_registration_state (registration_state); + mm_cdma1x_registration_state = mm_modem_cdma_registration_state_from_qmi_registration_state (registration_state); else mm_cdma1x_registration_state = MM_MODEM_CDMA_REGISTRATION_STATE_UNKNOWN; if (mm_access_technologies & MM_IFACE_MODEM_CDMA_ALL_EVDO_ACCESS_TECHNOLOGIES_MASK) - mm_evdo_registration_state = qmi_registration_state_to_cdma_registration_state (registration_state); + mm_evdo_registration_state = mm_modem_cdma_registration_state_from_qmi_registration_state (registration_state); else mm_evdo_registration_state = MM_MODEM_CDMA_REGISTRATION_STATE_UNKNOWN; |