libmm-common: include CDMA-specific items in the simple properties
This commit is contained in:
@@ -20,6 +20,9 @@
|
|||||||
#include "mm-common-helpers.h"
|
#include "mm-common-helpers.h"
|
||||||
#include "mm-common-simple-properties.h"
|
#include "mm-common-simple-properties.h"
|
||||||
|
|
||||||
|
#define SID_UNKNOWN 99999
|
||||||
|
#define NID_UNKNOWN 99999
|
||||||
|
|
||||||
G_DEFINE_TYPE (MMCommonSimpleProperties, mm_common_simple_properties, G_TYPE_OBJECT);
|
G_DEFINE_TYPE (MMCommonSimpleProperties, mm_common_simple_properties, G_TYPE_OBJECT);
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
@@ -31,6 +34,10 @@ enum {
|
|||||||
PROP_3GPP_REGISTRATION_STATE,
|
PROP_3GPP_REGISTRATION_STATE,
|
||||||
PROP_3GPP_OPERATOR_CODE,
|
PROP_3GPP_OPERATOR_CODE,
|
||||||
PROP_3GPP_OPERATOR_NAME,
|
PROP_3GPP_OPERATOR_NAME,
|
||||||
|
PROP_CDMA_CDMA1X_REGISTRATION_STATE,
|
||||||
|
PROP_CDMA_EVDO_REGISTRATION_STATE,
|
||||||
|
PROP_CDMA_SID,
|
||||||
|
PROP_CDMA_NID,
|
||||||
PROP_LAST
|
PROP_LAST
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -55,6 +62,16 @@ struct _MMCommonSimplePropertiesPrivate {
|
|||||||
gchar *modem_3gpp_operator_code;
|
gchar *modem_3gpp_operator_code;
|
||||||
/* 3GPP operator name, given only when registered, signature 's' */
|
/* 3GPP operator name, given only when registered, signature 's' */
|
||||||
gchar *modem_3gpp_operator_name;
|
gchar *modem_3gpp_operator_name;
|
||||||
|
|
||||||
|
/* <--- From the Modem CDMA interface ---> */
|
||||||
|
/* CDMA/CDMA1x registration state, signature 'u' */
|
||||||
|
MMModemCdmaRegistrationState modem_cdma_cdma1x_registration_state;
|
||||||
|
/* CDMA/EV-DO registration state, signature 'u' */
|
||||||
|
MMModemCdmaRegistrationState modem_cdma_evdo_registration_state;
|
||||||
|
/* SID, signature 'u' */
|
||||||
|
guint modem_cdma_sid;
|
||||||
|
/* NID, signature 'u' */
|
||||||
|
guint modem_cdma_nid;
|
||||||
};
|
};
|
||||||
|
|
||||||
/*****************************************************************************/
|
/*****************************************************************************/
|
||||||
@@ -120,6 +137,30 @@ mm_common_simple_properties_get_3gpp_operator_name (MMCommonSimpleProperties *se
|
|||||||
return self->priv->modem_3gpp_operator_name;
|
return self->priv->modem_3gpp_operator_name;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
MMModemCdmaRegistrationState
|
||||||
|
mm_common_simple_properties_get_cdma_cdma1x_registration_state (MMCommonSimpleProperties *self)
|
||||||
|
{
|
||||||
|
return self->priv->modem_cdma_cdma1x_registration_state;
|
||||||
|
}
|
||||||
|
|
||||||
|
MMModemCdmaRegistrationState
|
||||||
|
mm_common_simple_properties_get_cdma_evdo_registration_state (MMCommonSimpleProperties *self)
|
||||||
|
{
|
||||||
|
return self->priv->modem_cdma_evdo_registration_state;
|
||||||
|
}
|
||||||
|
|
||||||
|
guint
|
||||||
|
mm_common_simple_properties_get_cdma_sid (MMCommonSimpleProperties *self)
|
||||||
|
{
|
||||||
|
return self->priv->modem_cdma_sid;
|
||||||
|
}
|
||||||
|
|
||||||
|
guint
|
||||||
|
mm_common_simple_properties_get_cdma_nid (MMCommonSimpleProperties *self)
|
||||||
|
{
|
||||||
|
return self->priv->modem_cdma_nid;
|
||||||
|
}
|
||||||
|
|
||||||
/*****************************************************************************/
|
/*****************************************************************************/
|
||||||
|
|
||||||
GVariant *
|
GVariant *
|
||||||
@@ -148,6 +189,7 @@ mm_common_simple_properties_get_dictionary (MMCommonSimpleProperties *self)
|
|||||||
"{sv}",
|
"{sv}",
|
||||||
MM_COMMON_SIMPLE_PROPERTY_ACCESS_TECHNOLOGIES,
|
MM_COMMON_SIMPLE_PROPERTY_ACCESS_TECHNOLOGIES,
|
||||||
g_variant_new_uint32 (self->priv->access_technologies));
|
g_variant_new_uint32 (self->priv->access_technologies));
|
||||||
|
|
||||||
g_variant_builder_add (&builder,
|
g_variant_builder_add (&builder,
|
||||||
"{sv}",
|
"{sv}",
|
||||||
MM_COMMON_SIMPLE_PROPERTY_3GPP_REGISTRATION_STATE,
|
MM_COMMON_SIMPLE_PROPERTY_3GPP_REGISTRATION_STATE,
|
||||||
@@ -162,6 +204,29 @@ mm_common_simple_properties_get_dictionary (MMCommonSimpleProperties *self)
|
|||||||
"{sv}",
|
"{sv}",
|
||||||
MM_COMMON_SIMPLE_PROPERTY_3GPP_OPERATOR_NAME,
|
MM_COMMON_SIMPLE_PROPERTY_3GPP_OPERATOR_NAME,
|
||||||
g_variant_new_string (self->priv->modem_3gpp_operator_name));
|
g_variant_new_string (self->priv->modem_3gpp_operator_name));
|
||||||
|
|
||||||
|
if (self->priv->modem_cdma_cdma1x_registration_state != MM_MODEM_CDMA_REGISTRATION_STATE_UNKNOWN) {
|
||||||
|
g_variant_builder_add (&builder,
|
||||||
|
"{sv}",
|
||||||
|
MM_COMMON_SIMPLE_PROPERTY_CDMA_CDMA1X_REGISTRATION_STATE,
|
||||||
|
g_variant_new_uint32 (self->priv->modem_cdma_cdma1x_registration_state));
|
||||||
|
if (self->priv->modem_cdma_sid != SID_UNKNOWN)
|
||||||
|
g_variant_builder_add (&builder,
|
||||||
|
"{sv}",
|
||||||
|
MM_COMMON_SIMPLE_PROPERTY_CDMA_SID,
|
||||||
|
g_variant_new_uint32 (self->priv->modem_cdma_sid));
|
||||||
|
if (self->priv->modem_cdma_nid != NID_UNKNOWN)
|
||||||
|
g_variant_builder_add (&builder,
|
||||||
|
"{sv}",
|
||||||
|
MM_COMMON_SIMPLE_PROPERTY_CDMA_NID,
|
||||||
|
g_variant_new_uint32 (self->priv->modem_cdma_nid));
|
||||||
|
}
|
||||||
|
if (self->priv->modem_cdma_evdo_registration_state != MM_MODEM_CDMA_REGISTRATION_STATE_UNKNOWN)
|
||||||
|
g_variant_builder_add (&builder,
|
||||||
|
"{sv}",
|
||||||
|
MM_COMMON_SIMPLE_PROPERTY_CDMA_EVDO_REGISTRATION_STATE,
|
||||||
|
g_variant_new_uint32 (self->priv->modem_cdma_evdo_registration_state));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return g_variant_ref_sink (g_variant_builder_end (&builder));
|
return g_variant_ref_sink (g_variant_builder_end (&builder));
|
||||||
@@ -192,7 +257,11 @@ mm_common_simple_properties_new_from_dictionary (GVariant *dictionary,
|
|||||||
*/
|
*/
|
||||||
if (g_str_equal (key, MM_COMMON_SIMPLE_PROPERTY_STATE) ||
|
if (g_str_equal (key, MM_COMMON_SIMPLE_PROPERTY_STATE) ||
|
||||||
g_str_equal (key, MM_COMMON_SIMPLE_PROPERTY_ACCESS_TECHNOLOGIES) ||
|
g_str_equal (key, MM_COMMON_SIMPLE_PROPERTY_ACCESS_TECHNOLOGIES) ||
|
||||||
g_str_equal (key, MM_COMMON_SIMPLE_PROPERTY_3GPP_REGISTRATION_STATE)) {
|
g_str_equal (key, MM_COMMON_SIMPLE_PROPERTY_3GPP_REGISTRATION_STATE) ||
|
||||||
|
g_str_equal (key, MM_COMMON_SIMPLE_PROPERTY_CDMA_CDMA1X_REGISTRATION_STATE) ||
|
||||||
|
g_str_equal (key, MM_COMMON_SIMPLE_PROPERTY_CDMA_EVDO_REGISTRATION_STATE) ||
|
||||||
|
g_str_equal (key, MM_COMMON_SIMPLE_PROPERTY_CDMA_SID) ||
|
||||||
|
g_str_equal (key, MM_COMMON_SIMPLE_PROPERTY_CDMA_NID)) {
|
||||||
/* uint properties */
|
/* uint properties */
|
||||||
g_object_set (properties,
|
g_object_set (properties,
|
||||||
key, g_variant_get_uint32 (value),
|
key, g_variant_get_uint32 (value),
|
||||||
@@ -280,6 +349,18 @@ set_property (GObject *object,
|
|||||||
g_free (self->priv->modem_3gpp_operator_name);
|
g_free (self->priv->modem_3gpp_operator_name);
|
||||||
self->priv->modem_3gpp_operator_name = g_value_dup_string (value);
|
self->priv->modem_3gpp_operator_name = g_value_dup_string (value);
|
||||||
break;
|
break;
|
||||||
|
case PROP_CDMA_CDMA1X_REGISTRATION_STATE:
|
||||||
|
self->priv->modem_cdma_cdma1x_registration_state = g_value_get_enum (value);
|
||||||
|
break;
|
||||||
|
case PROP_CDMA_EVDO_REGISTRATION_STATE:
|
||||||
|
self->priv->modem_cdma_evdo_registration_state = g_value_get_enum (value);
|
||||||
|
break;
|
||||||
|
case PROP_CDMA_SID:
|
||||||
|
self->priv->modem_cdma_sid = g_value_get_enum (value);
|
||||||
|
break;
|
||||||
|
case PROP_CDMA_NID:
|
||||||
|
self->priv->modem_cdma_nid = g_value_get_enum (value);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||||
break;
|
break;
|
||||||
@@ -316,6 +397,18 @@ get_property (GObject *object,
|
|||||||
case PROP_3GPP_OPERATOR_NAME:
|
case PROP_3GPP_OPERATOR_NAME:
|
||||||
g_value_set_string (value, self->priv->modem_3gpp_operator_name);
|
g_value_set_string (value, self->priv->modem_3gpp_operator_name);
|
||||||
break;
|
break;
|
||||||
|
case PROP_CDMA_CDMA1X_REGISTRATION_STATE:
|
||||||
|
g_value_set_enum (value, self->priv->modem_cdma_cdma1x_registration_state);
|
||||||
|
break;
|
||||||
|
case PROP_CDMA_EVDO_REGISTRATION_STATE:
|
||||||
|
g_value_set_enum (value, self->priv->modem_cdma_evdo_registration_state);
|
||||||
|
break;
|
||||||
|
case PROP_CDMA_SID:
|
||||||
|
g_value_set_enum (value, self->priv->modem_cdma_sid);
|
||||||
|
break;
|
||||||
|
case PROP_CDMA_NID:
|
||||||
|
g_value_set_enum (value, self->priv->modem_cdma_nid);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||||
break;
|
break;
|
||||||
@@ -335,6 +428,10 @@ mm_common_simple_properties_init (MMCommonSimpleProperties *self)
|
|||||||
self->priv->modem_3gpp_registration_state = MM_MODEM_3GPP_REGISTRATION_STATE_UNKNOWN;
|
self->priv->modem_3gpp_registration_state = MM_MODEM_3GPP_REGISTRATION_STATE_UNKNOWN;
|
||||||
self->priv->bands = g_variant_ref_sink (mm_common_build_bands_unknown ());
|
self->priv->bands = g_variant_ref_sink (mm_common_build_bands_unknown ());
|
||||||
self->priv->signal_quality = g_variant_ref_sink (g_variant_new ("(ub)", 0, 0));
|
self->priv->signal_quality = g_variant_ref_sink (g_variant_new ("(ub)", 0, 0));
|
||||||
|
self->priv->modem_cdma_cdma1x_registration_state = MM_MODEM_CDMA_REGISTRATION_STATE_UNKNOWN;
|
||||||
|
self->priv->modem_cdma_evdo_registration_state = MM_MODEM_CDMA_REGISTRATION_STATE_UNKNOWN;
|
||||||
|
self->priv->modem_cdma_sid = SID_UNKNOWN;
|
||||||
|
self->priv->modem_cdma_nid = NID_UNKNOWN;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@@ -424,4 +521,42 @@ mm_common_simple_properties_class_init (MMCommonSimplePropertiesClass *klass)
|
|||||||
NULL,
|
NULL,
|
||||||
G_PARAM_READWRITE);
|
G_PARAM_READWRITE);
|
||||||
g_object_class_install_property (object_class, PROP_3GPP_OPERATOR_NAME, properties[PROP_3GPP_OPERATOR_NAME]);
|
g_object_class_install_property (object_class, PROP_3GPP_OPERATOR_NAME, properties[PROP_3GPP_OPERATOR_NAME]);
|
||||||
|
|
||||||
|
properties[PROP_CDMA_CDMA1X_REGISTRATION_STATE] =
|
||||||
|
g_param_spec_enum (MM_COMMON_SIMPLE_PROPERTY_CDMA_CDMA1X_REGISTRATION_STATE,
|
||||||
|
"CDMA1x registration state",
|
||||||
|
"Registration state in the CDMA1x network",
|
||||||
|
MM_TYPE_MODEM_CDMA_REGISTRATION_STATE,
|
||||||
|
MM_MODEM_CDMA_REGISTRATION_STATE_UNKNOWN,
|
||||||
|
G_PARAM_READWRITE);
|
||||||
|
g_object_class_install_property (object_class, PROP_CDMA_CDMA1X_REGISTRATION_STATE, properties[PROP_CDMA_CDMA1X_REGISTRATION_STATE]);
|
||||||
|
|
||||||
|
properties[PROP_CDMA_EVDO_REGISTRATION_STATE] =
|
||||||
|
g_param_spec_enum (MM_COMMON_SIMPLE_PROPERTY_CDMA_EVDO_REGISTRATION_STATE,
|
||||||
|
"EV-DO registration state",
|
||||||
|
"Registration state in the EV-DO network",
|
||||||
|
MM_TYPE_MODEM_CDMA_REGISTRATION_STATE,
|
||||||
|
MM_MODEM_CDMA_REGISTRATION_STATE_UNKNOWN,
|
||||||
|
G_PARAM_READWRITE);
|
||||||
|
g_object_class_install_property (object_class, PROP_CDMA_EVDO_REGISTRATION_STATE, properties[PROP_CDMA_EVDO_REGISTRATION_STATE]);
|
||||||
|
|
||||||
|
properties[PROP_CDMA_SID] =
|
||||||
|
g_param_spec_uint (MM_COMMON_SIMPLE_PROPERTY_CDMA_SID,
|
||||||
|
"CDMA1x SID",
|
||||||
|
"System Identifier of the serving CDMA1x network",
|
||||||
|
0,
|
||||||
|
SID_UNKNOWN,
|
||||||
|
SID_UNKNOWN,
|
||||||
|
G_PARAM_READWRITE);
|
||||||
|
g_object_class_install_property (object_class, PROP_CDMA_SID, properties[PROP_CDMA_SID]);
|
||||||
|
|
||||||
|
properties[PROP_CDMA_NID] =
|
||||||
|
g_param_spec_uint (MM_COMMON_SIMPLE_PROPERTY_CDMA_NID,
|
||||||
|
"CDMA1x NID",
|
||||||
|
"Network Identifier of the serving CDMA1x network",
|
||||||
|
0,
|
||||||
|
NID_UNKNOWN,
|
||||||
|
NID_UNKNOWN,
|
||||||
|
G_PARAM_READWRITE);
|
||||||
|
g_object_class_install_property (object_class, PROP_CDMA_NID, properties[PROP_CDMA_NID]);
|
||||||
}
|
}
|
||||||
|
@@ -37,6 +37,11 @@ G_BEGIN_DECLS
|
|||||||
#define MM_COMMON_SIMPLE_PROPERTY_3GPP_OPERATOR_CODE "m3gpp-operator-code"
|
#define MM_COMMON_SIMPLE_PROPERTY_3GPP_OPERATOR_CODE "m3gpp-operator-code"
|
||||||
#define MM_COMMON_SIMPLE_PROPERTY_3GPP_OPERATOR_NAME "m3gpp-operator-name"
|
#define MM_COMMON_SIMPLE_PROPERTY_3GPP_OPERATOR_NAME "m3gpp-operator-name"
|
||||||
|
|
||||||
|
#define MM_COMMON_SIMPLE_PROPERTY_CDMA_CDMA1X_REGISTRATION_STATE "cdma-cdma1x-registration-state"
|
||||||
|
#define MM_COMMON_SIMPLE_PROPERTY_CDMA_EVDO_REGISTRATION_STATE "cdma-evdo-registration-state"
|
||||||
|
#define MM_COMMON_SIMPLE_PROPERTY_CDMA_SID "cdma-sid"
|
||||||
|
#define MM_COMMON_SIMPLE_PROPERTY_CDMA_NID "cdma-nid"
|
||||||
|
|
||||||
typedef struct _MMCommonSimpleProperties MMCommonSimpleProperties;
|
typedef struct _MMCommonSimpleProperties MMCommonSimpleProperties;
|
||||||
typedef struct _MMCommonSimplePropertiesClass MMCommonSimplePropertiesClass;
|
typedef struct _MMCommonSimplePropertiesClass MMCommonSimplePropertiesClass;
|
||||||
typedef struct _MMCommonSimplePropertiesPrivate MMCommonSimplePropertiesPrivate;
|
typedef struct _MMCommonSimplePropertiesPrivate MMCommonSimplePropertiesPrivate;
|
||||||
@@ -64,10 +69,16 @@ void mm_common_simple_properties_get_bands
|
|||||||
const MMModemBand **bands,
|
const MMModemBand **bands,
|
||||||
guint *n_bands);
|
guint *n_bands);
|
||||||
MMModemAccessTechnology mm_common_simple_properties_get_access_technologies (MMCommonSimpleProperties *self);
|
MMModemAccessTechnology mm_common_simple_properties_get_access_technologies (MMCommonSimpleProperties *self);
|
||||||
|
|
||||||
MMModem3gppRegistrationState mm_common_simple_properties_get_3gpp_registration_state (MMCommonSimpleProperties *self);
|
MMModem3gppRegistrationState mm_common_simple_properties_get_3gpp_registration_state (MMCommonSimpleProperties *self);
|
||||||
const gchar *mm_common_simple_properties_get_3gpp_operator_code (MMCommonSimpleProperties *self);
|
const gchar *mm_common_simple_properties_get_3gpp_operator_code (MMCommonSimpleProperties *self);
|
||||||
const gchar *mm_common_simple_properties_get_3gpp_operator_name (MMCommonSimpleProperties *self);
|
const gchar *mm_common_simple_properties_get_3gpp_operator_name (MMCommonSimpleProperties *self);
|
||||||
|
|
||||||
|
MMModemCdmaRegistrationState mm_common_simple_properties_get_cdma_cdma1x_registration_state (MMCommonSimpleProperties *self);
|
||||||
|
MMModemCdmaRegistrationState mm_common_simple_properties_get_cdma_evdo_registration_state (MMCommonSimpleProperties *self);
|
||||||
|
guint mm_common_simple_properties_get_cdma_sid (MMCommonSimpleProperties *self);
|
||||||
|
guint mm_common_simple_properties_get_cdma_nid (MMCommonSimpleProperties *self);
|
||||||
|
|
||||||
GVariant *mm_common_simple_properties_get_dictionary (MMCommonSimpleProperties *self);
|
GVariant *mm_common_simple_properties_get_dictionary (MMCommonSimpleProperties *self);
|
||||||
|
|
||||||
G_END_DECLS
|
G_END_DECLS
|
||||||
|
Reference in New Issue
Block a user