diff options
author | Paul Bartell <p.bartell@temperednetworks.com> | 2018-09-10 15:25:15 -0700 |
---|---|---|
committer | Aleksander Morgado <aleksander@gnu.org> | 2018-09-13 07:17:51 +0000 |
commit | 6b30f552a91ec0478f6a06fdc4e3d6740064bc0a (patch) | |
tree | 7f0be34a42d3f0a60e1f2e98f1dd3caa58f043a7 /plugins/xmm/mm-shared-xmm.c | |
parent | 73045e931bd0cdef99c89ee56639850430430f41 (diff) |
xmm: implement signal interface with +XCESQ polling
Diffstat (limited to 'plugins/xmm/mm-shared-xmm.c')
-rw-r--r-- | plugins/xmm/mm-shared-xmm.c | 64 |
1 files changed, 64 insertions, 0 deletions
diff --git a/plugins/xmm/mm-shared-xmm.c b/plugins/xmm/mm-shared-xmm.c index 5e562dff..6181a444 100644 --- a/plugins/xmm/mm-shared-xmm.c +++ b/plugins/xmm/mm-shared-xmm.c @@ -23,6 +23,7 @@ #include "mm-log.h" #include "mm-iface-modem.h" +#include "mm-iface-modem-signal.h" #include "mm-base-modem.h" #include "mm-base-modem-at.h" #include "mm-shared-xmm.h" @@ -689,6 +690,69 @@ mm_shared_xmm_power_up (MMIfaceModem *self, /*****************************************************************************/ + +/*****************************************************************************/ +/* Check support (Signal interface) */ + +gboolean +mm_shared_xmm_signal_check_support_finish (MMIfaceModemSignal *self, + GAsyncResult *res, + GError **error) +{ + return !!mm_base_modem_at_command_finish (MM_BASE_MODEM (self), res, error); +} + +void +mm_shared_xmm_signal_check_support (MMIfaceModemSignal *self, + GAsyncReadyCallback callback, + gpointer user_data) +{ + mm_base_modem_at_command (MM_BASE_MODEM (self), + "+XCESQ=?", + 3, + FALSE, + callback, + user_data); +} + +/*****************************************************************************/ +/* Load extended signal information (Signal interface) */ + +gboolean +mm_shared_xmm_signal_load_values_finish (MMIfaceModemSignal *self, + GAsyncResult *res, + MMSignal **cdma, + MMSignal **evdo, + MMSignal **gsm, + MMSignal **umts, + MMSignal **lte, + GError **error) +{ + const gchar *response; + + response = mm_base_modem_at_command_finish (MM_BASE_MODEM (self), res, error); + if (!response || !mm_xmm_xcesq_response_to_signal_info (response, gsm, umts, lte, error)) + return FALSE; + + return TRUE; +} + +void +mm_shared_xmm_signal_load_values (MMIfaceModemSignal *self, + GCancellable *cancellable, + GAsyncReadyCallback callback, + gpointer user_data) +{ + mm_base_modem_at_command (MM_BASE_MODEM (self), + "+XCESQ?", + 3, + FALSE, + callback, + user_data); +} + +/*****************************************************************************/ + static void shared_xmm_init (gpointer g_iface) { |