aboutsummaryrefslogtreecommitdiff
path: root/plugins/wavecom
diff options
context:
space:
mode:
authorAleksander Morgado <aleksandermj@chromium.org>2022-12-08 13:37:55 +0000
committerAleksander Morgado <aleksander@aleksander.es>2023-01-03 13:56:25 +0000
commite14b904cbd6816cb0227d519d308ae71ddaf6e07 (patch)
tree4997ab68cc606fdf4d72a571e821cec0c8df42ef /plugins/wavecom
parent072d7ac9065f444e83b390a1e2af5471ac0d48f6 (diff)
build: move plugins directory to src/plugins
We are going to allow including the plugin sources built within the ModemManager daemon binary; moving the sources within the daemon sources directory makes it easier.
Diffstat (limited to 'plugins/wavecom')
-rw-r--r--plugins/wavecom/mm-broadband-modem-wavecom.c1320
-rw-r--r--plugins/wavecom/mm-broadband-modem-wavecom.h50
-rw-r--r--plugins/wavecom/mm-plugin-wavecom.c88
-rw-r--r--plugins/wavecom/mm-plugin-wavecom.h49
4 files changed, 0 insertions, 1507 deletions
diff --git a/plugins/wavecom/mm-broadband-modem-wavecom.c b/plugins/wavecom/mm-broadband-modem-wavecom.c
deleted file mode 100644
index 521e72de..00000000
--- a/plugins/wavecom/mm-broadband-modem-wavecom.c
+++ /dev/null
@@ -1,1320 +0,0 @@
-/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
-/*
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details:
- *
- * Copyright (C) 2011 Ammonit Measurement GmbH
- * Copyright (C) 2012 Aleksander Morgado <aleksander@gnu.org>
- * Author: Aleksander Morgado <aleksander@lanedo.com>
- */
-
-#include <config.h>
-
-#include <stdlib.h>
-#include <stdio.h>
-#include <string.h>
-#include <unistd.h>
-#include <ctype.h>
-
-#define _LIBMM_INSIDE_MM
-#include <libmm-glib.h>
-
-#include "ModemManager.h"
-#include "mm-log-object.h"
-#include "mm-serial-parsers.h"
-#include "mm-modem-helpers.h"
-#include "mm-iface-modem.h"
-#include "mm-iface-modem-3gpp.h"
-#include "mm-base-modem-at.h"
-#include "mm-broadband-modem-wavecom.h"
-
-static void iface_modem_init (MMIfaceModem *iface);
-static void iface_modem_3gpp_init (MMIfaceModem3gpp *iface);
-
-static MMIfaceModem3gpp *iface_modem_3gpp_parent;
-
-G_DEFINE_TYPE_EXTENDED (MMBroadbandModemWavecom, mm_broadband_modem_wavecom, MM_TYPE_BROADBAND_MODEM, 0,
- G_IMPLEMENT_INTERFACE (MM_TYPE_IFACE_MODEM, iface_modem_init)
- G_IMPLEMENT_INTERFACE (MM_TYPE_IFACE_MODEM_3GPP, iface_modem_3gpp_init))
-
-#define WAVECOM_MS_CLASS_CC_IDSTR "\"CC\""
-#define WAVECOM_MS_CLASS_CG_IDSTR "\"CG\""
-#define WAVECOM_MS_CLASS_B_IDSTR "\"B\""
-#define WAVECOM_MS_CLASS_A_IDSTR "\"A\""
-
-/* Setup relationship between 2G bands in the modem (identified by a
- * single digit in ASCII) and the bitmask in ModemManager. */
-typedef struct {
- gchar wavecom_band;
- guint n_mm_bands;
- MMModemBand mm_bands[4];
-} WavecomBand2G;
-static const WavecomBand2G bands_2g[] = {
- { '0', 1, { MM_MODEM_BAND_G850, 0, 0, 0 }},
- { '1', 1, { MM_MODEM_BAND_EGSM, 0, 0, 0 }},
- { '2', 1, { MM_MODEM_BAND_DCS, 0, 0, 0 }},
- { '3', 1, { MM_MODEM_BAND_PCS, 0, 0, 0 }},
- { '4', 2, { MM_MODEM_BAND_G850, MM_MODEM_BAND_PCS, 0, 0 }},
- { '5', 2, { MM_MODEM_BAND_EGSM, MM_MODEM_BAND_DCS, 0, 0 }},
- { '6', 2, { MM_MODEM_BAND_EGSM, MM_MODEM_BAND_PCS, 0, 0 }},
- { '7', 4, { MM_MODEM_BAND_DCS, MM_MODEM_BAND_PCS, MM_MODEM_BAND_G850, MM_MODEM_BAND_EGSM }}
-};
-
-/* Setup relationship between the 3G band bitmask in the modem and the bitmask
- * in ModemManager. */
-typedef struct {
- guint32 wavecom_band_flag;
- MMModemBand mm_band;
-} WavecomBand3G;
-static const WavecomBand3G bands_3g[] = {
- { (1 << 0), MM_MODEM_BAND_UTRAN_1 },
- { (1 << 1), MM_MODEM_BAND_UTRAN_2 },
- { (1 << 2), MM_MODEM_BAND_UTRAN_3 },
- { (1 << 3), MM_MODEM_BAND_UTRAN_4 },
- { (1 << 4), MM_MODEM_BAND_UTRAN_5 },
- { (1 << 5), MM_MODEM_BAND_UTRAN_6 },
- { (1 << 6), MM_MODEM_BAND_UTRAN_7 },
- { (1 << 7), MM_MODEM_BAND_UTRAN_8 },
- { (1 << 8), MM_MODEM_BAND_UTRAN_9 }
-};
-
-/*****************************************************************************/
-/* Load supported modes (Modem interface) */
-
-static GArray *
-load_supported_modes_finish (MMIfaceModem *self,
- GAsyncResult *res,
- GError **error)
-{
- return g_task_propagate_pointer (G_TASK (res), error);
-}
-
-static void
-supported_ms_classes_query_ready (MMBaseModem *self,
- GAsyncResult *res,
- GTask *task)
-{
- GArray *all;
- GArray *combinations;
- GArray *filtered;
- const gchar *response;
- GError *error = NULL;
- MMModemModeCombination mode;
- MMModemMode mode_all;
-
- response = mm_base_modem_at_command_finish (MM_BASE_MODEM (self), res, &error);
- if (!response) {
- g_task_return_error (task, error);
- g_object_unref (task);
- return;
- }
-
- response = mm_strip_tag (response, "+CGCLASS:");
- mode_all = MM_MODEM_MODE_NONE;
- if (strstr (response, WAVECOM_MS_CLASS_A_IDSTR))
- mode_all |= MM_MODEM_MODE_3G;
- if (strstr (response, WAVECOM_MS_CLASS_B_IDSTR))
- mode_all |= (MM_MODEM_MODE_2G | MM_MODEM_MODE_CS);
- if (strstr (response, WAVECOM_MS_CLASS_CG_IDSTR))
- mode_all |= MM_MODEM_MODE_2G;
- if (strstr (response, WAVECOM_MS_CLASS_CC_IDSTR))
- mode_all |= MM_MODEM_MODE_CS;
-
- /* If none received, error */
- if (mode_all == MM_MODEM_MODE_NONE) {
- g_task_return_new_error (task,
- MM_CORE_ERROR,
- MM_CORE_ERROR_FAILED,
- "Couldn't get supported mobile station classes: '%s'",
- response);
- g_object_unref (task);
- return;
- }
-
- /* Build ALL mask */
- all = g_array_sized_new (FALSE, FALSE, sizeof (MMModemModeCombination), 1);
- mode.allowed = mode_all;
- mode.preferred = MM_MODEM_MODE_NONE;
- g_array_append_val (all, mode);
-
- /* Build list of combinations */
- combinations = g_array_sized_new (FALSE, FALSE, sizeof (MMModemModeCombination), 7);
- /* CS only */
- mode.allowed = MM_MODEM_MODE_CS;
- mode.preferred = MM_MODEM_MODE_NONE;
- g_array_append_val (combinations, mode);
- /* 2G only */
- mode.allowed = MM_MODEM_MODE_2G;
- mode.preferred = MM_MODEM_MODE_NONE;
- g_array_append_val (combinations, mode);
- /* CS and 2G */
- mode.allowed = (MM_MODEM_MODE_CS | MM_MODEM_MODE_2G);
- mode.preferred = MM_MODEM_MODE_2G;
- g_array_append_val (combinations, mode);
- /* 3G only */
- mode.allowed = MM_MODEM_MODE_3G;
- mode.preferred = MM_MODEM_MODE_NONE;
- g_array_append_val (combinations, mode);
- /* 2G and 3G */
- mode.allowed = (MM_MODEM_MODE_2G | MM_MODEM_MODE_3G);
- mode.preferred = MM_MODEM_MODE_NONE;
- g_array_append_val (combinations, mode);
- /* 2G and 3G, 2G preferred */
- mode.allowed = (MM_MODEM_MODE_2G | MM_MODEM_MODE_3G);
- mode.preferred = MM_MODEM_MODE_2G;
- g_array_append_val (combinations, mode);
- /* 2G and 3G, 3G preferred */
- mode.allowed = (MM_MODEM_MODE_2G | MM_MODEM_MODE_3G);
- mode.preferred = MM_MODEM_MODE_3G;
- g_array_append_val (combinations, mode);
-
- /* Filter out those unsupported modes */
- filtered = mm_filter_supported_modes (all, combinations, self);
- g_array_unref (all);
- g_array_unref (combinations);
-
- g_task_return_pointer (task, filtered, (GDestroyNotify) g_array_unref);
- g_object_unref (task);
-}
-
-static void
-load_supported_modes (MMIfaceModem *self,
- GAsyncReadyCallback callback,
- gpointer user_data)
-{
- GTask *task;
-
- task = g_task_new (self, NULL, callback, user_data);
-
- mm_base_modem_at_command (
- MM_BASE_MODEM (self),
- "+CGCLASS=?",
- 3,
- FALSE,
- (GAsyncReadyCallback)supported_ms_classes_query_ready,
- task);
-}
-
-/*****************************************************************************/
-/* Load initial allowed/preferred modes (Modem interface) */
-
-typedef struct {
- MMModemMode allowed;
- MMModemMode preferred;
-} LoadCurrentModesResult;
-
-static gboolean
-load_current_modes_finish (MMIfaceModem *self,
- GAsyncResult *res,
- MMModemMode *allowed,
- MMModemMode *preferred,
- GError **error)
-{
- g_autofree LoadCurrentModesResult *result = NULL;
-
- result = g_task_propagate_pointer (G_TASK (res), error);
- if (!result)
- return FALSE;
-
- *allowed = result->allowed;
- *preferred = result->preferred;
- return TRUE;
-}
-
-static void
-wwsm_read_ready (MMBaseModem *self,
- GAsyncResult *res,
- GTask *task)
-{
- g_autoptr(GRegex) r = NULL;
- g_autoptr(GMatchInfo) match_info = NULL;
- g_autofree LoadCurrentModesResult *result = NULL;
- const gchar *response;
- GError *error = NULL;
-
- response = mm_base_modem_at_command_finish (MM_BASE_MODEM (self), res, &error);
- if (!response) {
- g_task_return_error (task, error);
- g_object_unref (task);
- return;
- }
-
- result = g_new0 (LoadCurrentModesResult, 1);
- result->allowed = MM_MODEM_MODE_NONE;
- result->preferred = MM_MODEM_MODE_NONE;
-
- /* Possible responses:
- * +WWSM: 0 (2G only)
- * +WWSM: 1 (3G only)
- * +WWSM: 2,0 (Any)
- * +WWSM: 2,1 (2G preferred)
- * +WWSM: 2,2 (3G preferred)
- */
- r = g_regex_new ("\\r\\n\\+WWSM: ([0-2])(,([0-2]))?.*$", 0, 0, NULL);
- g_assert (r != NULL);
-
- if (g_regex_match (r, response, 0, &match_info)) {
- guint allowed = 0;
-
- if (mm_get_uint_from_match_info (match_info, 1, &allowed)) {
- switch (allowed) {
- case 0:
- result->allowed = MM_MODEM_MODE_2G;
- result->preferred = MM_MODEM_MODE_NONE;
- break;
- case 1:
- result->allowed = MM_MODEM_MODE_3G;
- result->preferred = MM_MODEM_MODE_NONE;
- break;
- case 2: {
- guint preferred = 0;
-
- result->allowed = (MM_MODEM_MODE_2G | MM_MODEM_MODE_3G);
-
- /* 3, to avoid the comma */
- if (mm_get_uint_from_match_info (match_info, 3, &preferred)) {
- switch (preferred) {
- case 0:
- result->preferred = MM_MODEM_MODE_NONE;
- break;
- case 1:
- result->preferred = MM_MODEM_MODE_2G;
- break;
- case 2:
- result->preferred = MM_MODEM_MODE_3G;
- break;
- default:
- g_warn_if_reached ();
- break;
- }
- }
- break;
- }
- default:
- g_warn_if_reached ();
- break;
- }
- }
- }
-
- if (result->allowed == MM_MODEM_MODE_NONE)
- g_task_return_new_error (task,
- MM_CORE_ERROR,
- MM_CORE_ERROR_FAILED,
- "Unknown wireless data service reply: '%s'",
- response);
- else
- g_task_return_pointer (task, g_steal_pointer (&result), g_free);
- g_object_unref (task);
-}
-
-static void
-current_ms_class_ready (MMBaseModem *self,
- GAsyncResult *res,
- GTask *task)
-{
- g_autofree LoadCurrentModesResult *result = NULL;
- const gchar *response;
- GError *error = NULL;
-
- response = mm_base_modem_at_command_finish (self, res, &error);
- if (!response) {
- g_task_return_error (task, error);
- g_object_unref (task);
- return;
- }
-
- response = mm_strip_tag (response, "+CGCLASS:");
-
- if (strncmp (response,
- WAVECOM_MS_CLASS_A_IDSTR,
- strlen (WAVECOM_MS_CLASS_A_IDSTR)) == 0) {
- mm_obj_dbg (self, "configured as a Class A mobile station");
- /* For 3G devices, query WWSM status */
- mm_base_modem_at_command (self,
- "+WWSM?",
- 3,
- FALSE,
- (GAsyncReadyCallback)wwsm_read_ready,
- task);
- return;
- }
-
- result = g_new0 (LoadCurrentModesResult, 1);
- result->allowed = MM_MODEM_MODE_NONE;
- result->preferred = MM_MODEM_MODE_NONE;
-
- if (strncmp (response,
- WAVECOM_MS_CLASS_B_IDSTR,
- strlen (WAVECOM_MS_CLASS_B_IDSTR)) == 0) {
- mm_obj_dbg (self, "configured as a Class B mobile station");
- result->allowed = (MM_MODEM_MODE_2G | MM_MODEM_MODE_CS);
- result->preferred = MM_MODEM_MODE_2G;
- } else if (strncmp (response,
- WAVECOM_MS_CLASS_CG_IDSTR,
- strlen (WAVECOM_MS_CLASS_CG_IDSTR)) == 0) {
- mm_obj_dbg (self, "configured as a Class CG mobile station");
- result->allowed = MM_MODEM_MODE_2G;
- result->preferred = MM_MODEM_MODE_NONE;
- } else if (strncmp (response,
- WAVECOM_MS_CLASS_CC_IDSTR,
- strlen (WAVECOM_MS_CLASS_CC_IDSTR)) == 0) {
- mm_obj_dbg (self, "configured as a Class CC mobile station");
- result->allowed = MM_MODEM_MODE_CS;
- result->preferred = MM_MODEM_MODE_NONE;
- }
-
- if (result->allowed == MM_MODEM_MODE_NONE)
- g_task_return_new_error (task,
- MM_CORE_ERROR,
- MM_CORE_ERROR_FAILED,
- "Unknown mobile station class: '%s'",
- response);
- else
- g_task_return_pointer (task, g_steal_pointer (&result), g_free);
- g_object_unref (task);
-}
-
-static void
-load_current_modes (MMIfaceModem *self,
- GAsyncReadyCallback callback,
- gpointer user_data)
-{
- GTask *task;
-
- task = g_task_new (self, NULL, callback, user_data);
-
- mm_base_modem_at_command (MM_BASE_MODEM (self),
- "+CGCLASS?",
- 3,
- FALSE,
- (GAsyncReadyCallback)current_ms_class_ready,
- task);
-}
-
-/*****************************************************************************/
-/* Set allowed modes (Modem interface) */
-
-typedef struct {
- gchar *cgclass_command;
- gchar *wwsm_command;
-} SetCurrentModesContext;
-
-static void
-set_current_modes_context_free (SetCurrentModesContext *ctx)
-{
- g_free (ctx->cgclass_command);
- g_free (ctx->wwsm_command);
- g_free (ctx);
-}
-
-static gboolean
-set_current_modes_finish (MMIfaceModem *self,
- GAsyncResult *res,
- GError **error)
-{
- return g_task_propagate_boolean (G_TASK (res), error);
-}
-
-static void
-wwsm_update_ready (MMBaseModem *self,
- GAsyncResult *res,
- GTask *task)
-{
- GError *error = NULL;
-
- mm_base_modem_at_command_finish (self, res, &error);
- if (error)
- g_task_return_error (task, error);
- else
- g_task_return_boolean (task, TRUE);
- g_object_unref (task);
-}
-
-static void
-cgclass_update_ready (MMBaseModem *self,
- GAsyncResult *res,
- GTask *task)
-{
- SetCurrentModesContext *ctx;
- GError *error = NULL;
-
- ctx = g_task_get_task_data (task);
-
- mm_base_modem_at_command_finish (MM_BASE_MODEM (self), res, &error);
- if (error) {
- g_task_return_error (task, error);
- g_object_unref (task);
- return;
- }
-
- if (!ctx->wwsm_command) {
- g_task_return_boolean (task, TRUE);
- g_object_unref (task);
- return;
- }
-
- mm_base_modem_at_command (MM_BASE_MODEM (self),
- ctx->wwsm_command,
- 3,
- FALSE,
- (GAsyncReadyCallback)wwsm_update_ready,
- task);
-}
-
-static void
-set_current_modes (MMIfaceModem *self,
- MMModemMode allowed,
- MMModemMode preferred,
- GAsyncReadyCallback callback,
- gpointer user_data)
-{
- GTask *task;
- SetCurrentModesContext *ctx;
-
- task = g_task_new (self, NULL, callback, user_data);
-
- ctx = g_new0 (SetCurrentModesContext, 1);
- g_task_set_task_data (task, ctx, (GDestroyNotify) set_current_modes_context_free);
-
- /* Handle ANY/NONE */
- if (allowed == MM_MODEM_MODE_ANY && preferred == MM_MODEM_MODE_NONE) {
- if (mm_iface_modem_is_3g (self)) {
- allowed = (MM_MODEM_MODE_2G | MM_MODEM_MODE_3G);
- preferred = MM_MODEM_MODE_NONE;
- } else {
- allowed = (MM_MODEM_MODE_CS | MM_MODEM_MODE_2G);
- preferred = MM_MODEM_MODE_2G;
- }
- }
-
- if (allowed == MM_MODEM_MODE_CS)
- ctx->cgclass_command = g_strdup ("+CGCLASS=" WAVECOM_MS_CLASS_CC_IDSTR);
- else if (allowed == MM_MODEM_MODE_2G)
- ctx->cgclass_command = g_strdup ("+CGCLASS=" WAVECOM_MS_CLASS_CG_IDSTR);
- else if (allowed == (MM_MODEM_MODE_2G | MM_MODEM_MODE_CS) &&
- preferred == MM_MODEM_MODE_2G)
- ctx->cgclass_command = g_strdup ("+CGCLASS=" WAVECOM_MS_CLASS_B_IDSTR);
- else if (allowed & MM_MODEM_MODE_3G) {
- if (allowed == (MM_MODEM_MODE_2G | MM_MODEM_MODE_3G)) {
- if (preferred == MM_MODEM_MODE_2G)
- ctx->wwsm_command = g_strdup ("+WWSM=2,1");
- else if (preferred == MM_MODEM_MODE_3G)
- ctx->wwsm_command = g_strdup ("+WWSM=2,2");
- else if (preferred == MM_MODEM_MODE_NONE)
- ctx->wwsm_command = g_strdup ("+WWSM=2,0");
- } else if (allowed == MM_MODEM_MODE_3G)
- ctx->wwsm_command = g_strdup ("+WWSM=1");
-
- if (ctx->wwsm_command)
- ctx->cgclass_command = g_strdup ("+CGCLASS=" WAVECOM_MS_CLASS_A_IDSTR);
- }
-
- if (!ctx->cgclass_command) {
- g_autofree gchar *allowed_str = NULL;
- g_autofree gchar *preferred_str = NULL;
-
- allowed_str = mm_modem_mode_build_string_from_mask (allowed);
- preferred_str = mm_modem_mode_build_string_from_mask (preferred);
- g_task_return_new_error (task,
- MM_CORE_ERROR,
- MM_CORE_ERROR_FAILED,
- "Requested mode (allowed: '%s', preferred: '%s') not "
- "supported by the modem.",
- allowed_str, preferred_str);
- g_object_unref (task);
- return;
- }
-
- mm_base_modem_at_command (MM_BASE_MODEM (self),
- ctx->cgclass_command,
- 3,
- FALSE,
- (GAsyncReadyCallback)cgclass_update_ready,
- task);
-}
-
-/*****************************************************************************/
-/* Load supported bands (Modem interface) */
-
-static GArray *
-load_supported_bands_finish (MMIfaceModem *self,
- GAsyncResult *res,
- GError **error)
-{
- return g_task_propagate_pointer (G_TASK (res), error);
-}
-
-static void
-load_supported_bands (MMIfaceModem *self,
- GAsyncReadyCallback callback,
- gpointer user_data)
-{
- GTask *task;
- GArray *bands;
-
- task = g_task_new (self, NULL, callback, user_data);
-
- /* We do assume that we already know if the modem is 2G-only, 3G-only or
- * 2G+3G. This is checked quite before trying to load supported bands. */
-
-#define _g_array_insert_enum(array,index,type,val) do { \
- type aux = (type)val; \
- g_array_insert_val (array, index, aux); \
- } while (0)
-
- /* Add 3G-specific bands */
- if (mm_iface_modem_is_3g (self)) {
- bands = g_array_sized_new (FALSE, FALSE, sizeof (MMModemBand), 10);
- _g_array_insert_enum (bands, 0, MMModemBand, MM_MODEM_BAND_UTRAN_1);
- _g_array_insert_enum (bands, 1, MMModemBand, MM_MODEM_BAND_UTRAN_2);
- _g_array_insert_enum (bands, 2, MMModemBand, MM_MODEM_BAND_UTRAN_3);
- _g_array_insert_enum (bands, 3, MMModemBand, MM_MODEM_BAND_UTRAN_4);
- _g_array_insert_enum (bands, 4, MMModemBand, MM_MODEM_BAND_UTRAN_5);
- _g_array_insert_enum (bands, 5, MMModemBand, MM_MODEM_BAND_UTRAN_6);
- _g_array_insert_enum (bands, 6, MMModemBand, MM_MODEM_BAND_UTRAN_7);
- _g_array_insert_enum (bands, 7, MMModemBand, MM_MODEM_BAND_UTRAN_8);
- _g_array_insert_enum (bands, 8, MMModemBand, MM_MODEM_BAND_UTRAN_9);
- }
- /* Add 2G-specific bands */
- else {
- bands = g_array_sized_new (FALSE, FALSE, sizeof (MMModemBand), 4);
- _g_array_insert_enum (bands, 0, MMModemBand, MM_MODEM_BAND_EGSM);
- _g_array_insert_enum (bands, 1, MMModemBand, MM_MODEM_BAND_DCS);
- _g_array_insert_enum (bands, 2, MMModemBand, MM_MODEM_BAND_PCS);
- _g_array_insert_enum (bands, 3, MMModemBand, MM_MODEM_BAND_G850);
- }
-
- g_task_return_pointer (task, bands, (GDestroyNotify) g_array_unref);
- g_object_unref (task);
-}
-
-/*****************************************************************************/
-/* Load current bands (Modem interface) */
-
-static GArray *
-load_current_bands_finish (MMIfaceModem *self,
- GAsyncResult *res,
- GError **error)
-{
- return g_task_propagate_pointer (G_TASK (res), error);
-}
-
-static void
-get_2g_band_ready (MMBaseModem *self,
- GAsyncResult *res,
- GTask *task)
-{
- const gchar *response;
- const gchar *p;
- GError *error = NULL;
- GArray *bands_array = NULL;
-
- response = mm_base_modem_at_command_finish (MM_BASE_MODEM (self), res, &error);
- if (!response) {
- g_task_return_error (task, error);
- g_object_unref (task);
- return;
- }
-
- p = mm_strip_tag (response, "+WMBS:");
- if (p) {
- guint i;
-
- for (i = 0; i < G_N_ELEMENTS (bands_2g); i++) {
- if (bands_2g[i].wavecom_band == *p) {
- guint j;
-
- if (G_UNLIKELY (!bands_array))
- bands_array = g_array_new (FALSE, FALSE, sizeof (MMModemBand));
-
- for (j = 0; j < bands_2g[i].n_mm_bands; j++)
- g_array_append_val (bands_array, bands_2g[i].mm_bands[j]);
- }
- }
- }
-
- if (!bands_array)
- g_task_return_new_error (task,
- MM_CORE_ERROR,
- MM_CORE_ERROR_FAILED,
- "Couldn't parse current bands reply: '%s'",
- response);
- else
- g_task_return_pointer (task, bands_array, (GDestroyNotify)g_array_unref);
- g_object_unref (task);
-}
-
-static void
-get_3g_band_ready (MMBaseModem *self,
- GAsyncResult *res,
- GTask *task)
-{
- const gchar *response;
- const gchar *p;
- GError *error = NULL;
- GArray *bands_array = NULL;
- guint32 wavecom_band;
-
- response = mm_base_modem_at_command_finish (self, res, &error);
- if (!response) {
- g_task_return_error (task, error);
- g_object_unref (task);
- return;
- }
-
- /* Example reply:
- * AT+WUBS? -->
- * <-- +WUBS: "3",1
- * <-- OK
- * The "3" meaning here Band I and II are selected.
- */
-
- p = mm_strip_tag (response, "+WUBS:");
- if (*p == '"')
- p++;
-
- wavecom_band = atoi (p);
- if (wavecom_band > 0) {
- guint i;
-
- for (i = 0; i < G_N_ELEMENTS (bands_3g); i++) {
- if (bands_3g[i].wavecom_band_flag & wavecom_band) {
- if (G_UNLIKELY (!bands_array))
- bands_array = g_array_new (FALSE, FALSE, sizeof (MMModemBand));
- g_array_append_val (bands_array, bands_3g[i].mm_band);
- }
- }
- }
-
- if (!bands_array)
- g_task_return_new_error (task,
- MM_CORE_ERROR,
- MM_CORE_ERROR_FAILED,
- "Couldn't parse current bands reply: '%s'",
- response);
- else
- g_task_return_pointer (task, bands_array, (GDestroyNotify)g_array_unref);
- g_object_unref (task);
-}
-
-static void
-load_current_bands (MMIfaceModem *self,
- GAsyncReadyCallback callback,
- gpointer user_data)
-{
- GTask *task;
-
- task = g_task_new (self, NULL, callback, user_data);
-
- if (mm_iface_modem_is_3g (self))
- mm_base_modem_at_command (MM_BASE_MODEM (self),
- "AT+WUBS?",
- 3,
- FALSE,
- (GAsyncReadyCallback)get_3g_band_ready,
- task);
- else
- mm_base_modem_at_command (MM_BASE_MODEM (self),
- "AT+WMBS?",
- 3,
- FALSE,
- (GAsyncReadyCallback)get_2g_band_ready,
- task);
-}
-
-/*****************************************************************************/
-/* Set current_bands (Modem interface) */
-
-static gboolean
-set_current_bands_finish (MMIfaceModem *self,
- GAsyncResult *res,
- GError **error)
-{
- return g_task_propagate_boolean (G_TASK (res), error);
-}
-
-static void
-wmbs_set_ready (MMBaseModem *self,
- GAsyncResult *res,
- GTask *task)
-{
- GError *error = NULL;
-
- if (!mm_base_modem_at_command_finish (MM_BASE_MODEM (self), res, &error))
- g_task_return_error (task, error);
- else
- g_task_return_boolean (task, TRUE);
- g_object_unref (task);
-}
-
-static void
-set_bands_3g (GTask *task,
- GArray *bands_array)
-{
- MMBroadbandModemWavecom *self;
- guint wavecom_band = 0;
- guint i;
- g_autoptr(GArray) bands_array_final = NULL;
- g_autofree gchar *cmd = NULL;
-
- self = g_task_get_source_object (task);
-
- /* The special case of ANY should be treated separately. */
- if (bands_array->len == 1 &&
- g_array_index (bands_array, MMModemBand, 0) == MM_MODEM_BAND_ANY) {
- /* We build an array with all bands to set; so that we use the same
- * logic to build the cinterion_band, and so that we can log the list of
- * bands being set properly */
- bands_array_final = g_array_sized_new (FALSE, FALSE, sizeof (MMModemBand), G_N_ELEMENTS (bands_3g));
- for (i = 0; i < G_N_ELEMENTS (bands_3g); i++)
- g_array_append_val (bands_array_final, bands_3g[i].mm_band);
- } else
- bands_array_final = g_array_ref (bands_array);
-
- for (i = 0; i < G_N_ELEMENTS (bands_3g); i++) {
- guint j;
-
- for (j = 0; j < bands_array_final->len; j++) {
- if (g_array_index (bands_array_final, MMModemBand, j) == bands_3g[i].mm_band) {
- wavecom_band |= bands_3g[i].wavecom_band_flag;
- break;
- }
- }
- }
-
- if (wavecom_band == 0) {
- g_autofree gchar *bands_string = NULL;
-
- bands_string = mm_common_build_bands_string ((MMModemBand *)(gpointer)bands_array_final->data, bands_array_final->len);
- g_task_return_new_error (task,
- MM_CORE_ERROR,
- MM_CORE_ERROR_UNSUPPORTED,
- "The given band combination is not supported: '%s'",
- bands_string);
- g_object_unref (task);
- return;
- }
-
- cmd = g_strdup_printf ("+WMBS=\"%u\",1", wavecom_band);
- mm_base_modem_at_command (MM_BASE_MODEM (self),
- cmd,
- 3,
- FALSE,
- (GAsyncReadyCallback)wmbs_set_ready,
- task);
-}
-
-static void
-set_bands_2g (GTask *task,
- GArray *bands_array)
-{
- MMBroadbandModemWavecom *self;
- gchar wavecom_band = '\0';
- guint i;
- g_autofree gchar *cmd = NULL;
- g_autoptr(GArray) bands_array_final = NULL;
-
- self = g_task_get_source_object (task);
-
- /* If the iface properly checked the given list against the supported bands,
- * it's not possible to get an array longer than 4 here. */
- g_assert (bands_array->len <= 4);
-
- /* The special case of ANY should be treated separately. */
- if (bands_array->len == 1 &&
- g_array_index (bands_array, MMModemBand, 0) == MM_MODEM_BAND_ANY) {
- const WavecomBand2G *all;
-
- /* All bands is the last element in our 2G bands array */
- all = &bands_2g[G_N_ELEMENTS (bands_2g) - 1];
-
- /* We build an array with all bands to set; so that we use the same
- * logic to build the cinterion_band, and so that we can log the list of
- * bands being set properly */
- bands_array_final = g_array_sized_new (FALSE, FALSE, sizeof (MMModemBand), 4);
- g_array_append_vals (bands_array_final, all->mm_bands, all->n_mm_bands);
- } else
- bands_array_final = g_array_ref (bands_array);
-
- for (i = 0; wavecom_band == '\0' && i < G_N_ELEMENTS (bands_2g); i++) {
- g_autoptr(GArray) supported_combination = NULL;
-
- supported_combination = g_array_sized_new (FALSE, FALSE, sizeof (MMModemBand), bands_2g[i].n_mm_bands);
- g_array_append_vals (supported_combination, bands_2g[i].mm_bands, bands_2g[i].n_mm_bands);
-
- /* Check if the given array is exactly one of the supported combinations */
- if (mm_common_bands_garray_cmp (bands_array_final, supported_combination)) {
- wavecom_band = bands_2g[i].wavecom_band;
- break;
- }
- }
-
- if (wavecom_band == '\0') {
- g_autofree gchar *bands_string = NULL;
-
- bands_string = mm_common_build_bands_string ((MMModemBand *)(gpointer)bands_array_final->data, bands_array_final->len);
- g_task_return_new_error (task,
- MM_CORE_ERROR,
- MM_CORE_ERROR_UNSUPPORTED,
- "The given band combination is not supported: '%s'",
- bands_string);
- g_object_unref (task);
- return;
- }
-
- cmd = g_strdup_printf ("+WMBS=%c,1", wavecom_band);
- mm_base_modem_at_command (MM_BASE_MODEM (self),
- cmd,
- 3,
- FALSE,
- (GAsyncReadyCallback)wmbs_set_ready,
- task);
-}
-
-static void
-set_current_bands (MMIfaceModem *self,
- GArray *bands_array,
- GAsyncReadyCallback callback,
- gpointer user_data)
-{
- GTask *task;
-
- /* The bands that we get here are previously validated by the interface, and
- * that means that ALL the bands given here were also given in the list of
- * supported bands. BUT BUT, that doesn't mean that the exact list of bands
- * will end up being valid, as not all combinations are possible. E.g,
- * Wavecom modems supporting only 2G have specific combinations allowed.
- */
- task = g_task_new (self, NULL, callback, user_data);
-
- if (mm_iface_modem_is_3g (self))
- set_bands_3g (task, bands_array);
- else
- set_bands_2g (task, bands_array);
-}
-
-/*****************************************************************************/
-/* Load access technologies (Modem interface) */
-
-static gboolean
-load_access_technologies_finish (MMIfaceModem *self,
- GAsyncResult *res,
- MMModemAccessTechnology *access_technologies,
- guint *mask,
- GError **error)
-{
- MMModemAccessTechnology act;
- const gchar *p;
- const gchar *response;
-
- response = mm_base_modem_at_command_finish (MM_BASE_MODEM (self), res, error);
- if (!response)
- return FALSE;
-
- act = MM_MODEM_ACCESS_TECHNOLOGY_UNKNOWN;
- p = mm_strip_tag (response, "+WGPRSIND:");
- if (p) {
- switch (*p) {
- case '1':
- /* GPRS only */
- act = MM_MODEM_ACCESS_TECHNOLOGY_GPRS;
- break;
- case '2':
- /* EGPRS/EDGE supported */
- act = MM_MODEM_ACCESS_TECHNOLOGY_EDGE;
- break;
- case '3':
- /* 3G R99 supported */
- act = MM_MODEM_ACCESS_TECHNOLOGY_UMTS;
- break;
- case '4':
- /* HSDPA supported */
- act = MM_MODEM_ACCESS_TECHNOLOGY_HSDPA;
- break;
- case '5':
- /* HSUPA supported */
- act = MM_MODEM_ACCESS_TECHNOLOGY_HSUPA;
- break;
- default:
- break;
- }
- }
-
- if (act == MM_MODEM_ACCESS_TECHNOLOGY_UNKNOWN) {
- g_set_error (error,
- MM_CORE_ERROR,
- MM_CORE_ERROR_FAILED,
- "Couldn't parse access technologies result: '%s'",
- response);
- return FALSE;
- }
-
- /* We are reporting ALL 3GPP access technologies here */
- *access_technologies = act;
- *mask = MM_IFACE_MODEM_3GPP_ALL_ACCESS_TECHNOLOGIES_MASK;
- return TRUE;
-}
-
-static void
-load_access_technologies (MMIfaceModem *self,
- GAsyncReadyCallback callback,
- gpointer user_data)
-{
- mm_base_modem_at_command (MM_BASE_MODEM (self),
- "+WGPRS=9,2",
- 3,
- FALSE,
- callback,
- user_data);
-}
-
-/*****************************************************************************/
-/* Register in network (3GPP interface) */
-
-static gboolean
-register_in_network_finish (MMIfaceModem3gpp *self,
- GAsyncResult *res,
- GError **error)
-{
- return g_task_propagate_boolean (G_TASK (res), error);
-}
-
-static void
-parent_registration_ready (MMIfaceModem3gpp *self,
- GAsyncResult *res,
- GTask *task)
-{
- GError *error = NULL;
-
- if (!iface_modem_3gpp_parent->register_in_network_finish (self, res, &error))
- g_task_return_error (task, error);
- else
- g_task_return_boolean (task, TRUE);
- g_object_unref (task);
-}
-
-static void
-run_parent_registration (GTask *task)
-{
- MMBroadbandModemWavecom *self;
- const gchar *operator_id;
-
- self = g_task_get_source_object (task);
- operator_id = g_task_get_task_data (task);
-
- iface_modem_3gpp_parent->register_in_network (
- MM_IFACE_MODEM_3GPP (self),
- operator_id,
- g_task_get_cancellable (task),
- (GAsyncReadyCallback)parent_registration_ready,
- task);
-}
-
-static gboolean
-parse_network_registration_mode (const gchar *reply,
- guint *mode)
-{
- g_autoptr(GRegex) r = NULL;
- g_autoptr(GMatchInfo) match_info = NULL;
-
- g_assert (mode != NULL);
-
- if (!reply)
- return FALSE;
-
- r = g_regex_new ("\\+COPS:\\s*(\\d)", G_REGEX_UNGREEDY, 0, NULL);
- g_assert (r != NULL);
-
- g_regex_match (r, reply, 0, &match_info);
-
- return (g_match_info_matches (match_info) && mm_get_uint_from_match_info (match_info, 1, mode));
-}
-
-static void
-cops_ready (MMBaseModem *self,
- GAsyncResult *res,
- GTask *task)
-{
- const gchar *response;
- GError *error = NULL;
- guint mode;
-
- response = mm_base_modem_at_command_finish (self, res, &error);
- if (!response) {
- g_task_return_error (task, error);
- g_object_unref (task);
- return;
- }
-
- if (!parse_network_registration_mode (response, &mode)) {
- g_task_return_new_error (task, MM_CORE_ERROR, MM_CORE_ERROR_FAILED,
- "Couldn't parse current network registration mode: '%s'",
- response);
- g_object_unref (task);
- return;
- }
-
- /* If the modem is not configured for automatic registration, run parent */
- if (mode != 0) {
- run_parent_registration (task);
- return;
- }
-
- mm_obj_dbg (self, "device is already in automatic registration mode, not requesting it again");
- g_task_return_boolean (task, TRUE);
- g_object_unref (task);
-}
-
-static void
-register_in_network (MMIfaceModem3gpp *self,
- const gchar *operator_id,
- GCancellable *cancellable,
- GAsyncReadyCallback callback,
- gpointer user_data)
-{
- GTask *task;
-
- task = g_task_new (self, cancellable, callback, user_data);
-
- /* Store operator id as task data */
- g_task_set_task_data (task, g_strdup (operator_id), g_free);
-
- /* If requesting automatic registration, we first need to query what the
- * current mode is. We must NOT send +COPS=0 if it already is in 0 mode,
- * or the device will get stuck. */
- if (operator_id == NULL || operator_id[0] == '\0') {
- /* Check which is the current operator selection status */
- mm_base_modem_at_command (MM_BASE_MODEM (self),
- "+COPS?",
- 3,
- FALSE,
- (GAsyncReadyCallback)cops_ready,
- task);
- return;
- }
-
- /* Otherwise, run parent's implementation right away */
- run_parent_registration (task);
-}
-
-/*****************************************************************************/
-/* After SIM unlock (Modem interface) */
-
-static gboolean
-modem_after_sim_unlock_finish (MMIfaceModem *self,
- GAsyncResult *res,
- GError **error)
-{
- return g_task_propagate_boolean (G_TASK (res), error);
-}
-
-static gboolean
-after_sim_unlock_wait_cb (GTask *task)
-{
- g_task_return_boolean (task, TRUE);
- g_object_unref (task);
- return G_SOURCE_REMOVE;
-}
-
-static void
-modem_after_sim_unlock (MMIfaceModem *self,
- GAsyncReadyCallback callback,
- gpointer user_data)
-{
- GTask *task;
-
- /* A short wait is necessary for SIM to become ready, otherwise reloading
- * facility lock states may fail with a +CME ERROR: 515 error.
- */
- task = g_task_new (self, NULL, callback, user_data);
- g_timeout_add_seconds (5, (GSourceFunc)after_sim_unlock_wait_cb, task);
-}
-
-/*****************************************************************************/
-/* Modem power up (Modem interface) */
-
-static gboolean
-modem_power_up_finish (MMIfaceModem *self,
- GAsyncResult *res,
- GError **error)
-{
- return !!mm_base_modem_at_command_finish (MM_BASE_MODEM (self), res, error);
-}
-
-static void
-modem_power_up (MMIfaceModem *self,
- GAsyncReadyCallback callback,
- gpointer user_data)
-{
- mm_obj_warn (self, "not in full functionality status, power-up command is needed");
- mm_obj_warn (self, "the device maybe rebooted");
-
- /* Try to go to full functionality mode without rebooting the system.
- * Works well if we previously switched off the power with CFUN=4
- */
- mm_base_modem_at_command (MM_BASE_MODEM (self),
- "+CFUN=1,0",
- 3,
- FALSE,
- callback,
- user_data);
-}
-
-/*****************************************************************************/
-/* Modem power down (Modem interface) */
-
-static gboolean
-modem_power_down_finish (MMIfaceModem *self,
- GAsyncResult *res,
- GError **error)
-{
- return !!mm_base_modem_at_command_finish (MM_BASE_MODEM (self), res, error);
-}
-
-static void
-modem_power_down (MMIfaceModem *self,
- GAsyncReadyCallback callback,
- gpointer user_data)
-{
- /* Use AT+CFUN=4 for power down. It will stop the RF (IMSI detach), and
- * keeps access to the SIM */
- mm_base_modem_at_command (MM_BASE_MODEM (self),
- "+CFUN=4",
- 3,
- FALSE,
- callback,
- user_data);
-}
-
-/*****************************************************************************/
-/* Modem power down (Modem interface) */
-
-static gboolean
-modem_power_off_finish (MMIfaceModem *self,
- GAsyncResult *res,
- GError **error)
-{
- return !!mm_base_modem_at_command_finish (MM_BASE_MODEM (self), res, error);
-}
-
-static void
-modem_power_off (MMIfaceModem *self,
- GAsyncReadyCallback callback,
- gpointer user_data)
-{
- mm_base_modem_at_command (MM_BASE_MODEM (self),
- "+CPOF=1",
- 3,
- FALSE,
- callback,
- user_data);
-}
-
-/*****************************************************************************/
-
-static void
-setup_ports (MMBroadbandModem *self)
-{
- gpointer parser;
- MMPortSerialAt *primary;
- g_autoptr(GRegex) regex = NULL;
-
- /* Call parent's setup ports first always */
- MM_BROADBAND_MODEM_CLASS (mm_broadband_modem_wavecom_parent_class)->setup_ports (self);
-
- /* Set 9600 baudrate by default in the AT port */
- mm_obj_dbg (self, "baudrate will be set to 9600 bps...");
- primary = mm_base_modem_peek_port_primary (MM_BASE_MODEM (self));
- if (!primary)
- return;
-
- /* AT+CPIN? replies will never have an OK appended */
- parser = mm_serial_parser_v1_new ();
- regex = g_regex_new ("\\r\\n\\+CPIN: .*\\r\\n",
- G_REGEX_RAW | G_REGEX_OPTIMIZE,
- 0, NULL);
- mm_serial_parser_v1_set_custom_regex (parser, regex, NULL);
-
- mm_port_serial_at_set_response_parser (MM_PORT_SERIAL_AT (primary),
- mm_serial_parser_v1_parse,
- parser,
- mm_serial_parser_v1_destroy);
-}
-
-/*****************************************************************************/
-
-MMBroadbandModemWavecom *
-mm_broadband_modem_wavecom_new (const gchar *device,
- const gchar **drivers,
- const gchar *plugin,
- guint16 vendor_id,
- guint16 product_id)
-{
- return g_object_new (MM_TYPE_BROADBAND_MODEM_WAVECOM,
- MM_BASE_MODEM_DEVICE, device,
- MM_BASE_MODEM_DRIVERS, drivers,
- MM_BASE_MODEM_PLUGIN, plugin,
- MM_BASE_MODEM_VENDOR_ID, vendor_id,
- MM_BASE_MODEM_PRODUCT_ID, product_id,
- /* Generic bearer supports TTY only */
- MM_BASE_MODEM_DATA_NET_SUPPORTED, FALSE,
- MM_BASE_MODEM_DATA_TTY_SUPPORTED, TRUE,
- NULL);
-}
-
-static void
-mm_broadband_modem_wavecom_init (MMBroadbandModemWavecom *self)
-{
-}
-
-static void
-iface_modem_init (MMIfaceModem *iface)
-{
- iface->load_supported_modes = load_supported_modes;
- iface->load_supported_modes_finish = load_supported_modes_finish;
- iface->load_current_modes = load_current_modes;
- iface->load_current_modes_finish = load_current_modes_finish;
- iface->set_current_modes = set_current_modes;
- iface->set_current_modes_finish = set_current_modes_finish;
- iface->load_supported_bands = load_supported_bands;
- iface->load_supported_bands_finish = load_supported_bands_finish;
- iface->load_current_bands = load_current_bands;
- iface->load_current_bands_finish = load_current_bands_finish;
- iface->set_current_bands = set_current_bands;
- iface->set_current_bands_finish = set_current_bands_finish;
- iface->load_access_technologies = load_access_technologies;
- iface->load_access_technologies_finish = load_access_technologies_finish;
- iface->modem_after_sim_unlock = modem_after_sim_unlock;
- iface->modem_after_sim_unlock_finish = modem_after_sim_unlock_finish;
- iface->modem_power_up = modem_power_up;
- iface->modem_power_up_finish = modem_power_up_finish;
- iface->modem_power_down = modem_power_down;
- iface->modem_power_down_finish = modem_power_down_finish;
- iface->modem_power_off = modem_power_off;
- iface->modem_power_off_finish = modem_power_off_finish;
-}
-
-static void
-iface_modem_3gpp_init (MMIfaceModem3gpp *iface)
-{
- iface_modem_3gpp_parent = g_type_interface_peek_parent (iface);
-
- iface->register_in_network = register_in_network;
- iface->register_in_network_finish = register_in_network_finish;
-}
-
-static void
-mm_broadband_modem_wavecom_class_init (MMBroadbandModemWavecomClass *klass)
-{
- MMBroadbandModemClass *broadband_modem_class = MM_BROADBAND_MODEM_CLASS (klass);
-
- broadband_modem_class->setup_ports = setup_ports;
-}
diff --git a/plugins/wavecom/mm-broadband-modem-wavecom.h b/plugins/wavecom/mm-broadband-modem-wavecom.h
deleted file mode 100644
index 89bdbde8..00000000
--- a/plugins/wavecom/mm-broadband-modem-wavecom.h
+++ /dev/null
@@ -1,50 +0,0 @@
-/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
-/*
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details:
- *
- * Copyright (C) 2011 Ammonit Measurement GmbH
- * Copyright (C) 2012 Aleksander Morgado <aleksander@gnu.org>
- *
- * Author: Aleksander Morgado <aleksander@lanedo.com>
- */
-
-#ifndef MM_BROADBAND_MODEM_WAVECOM_H
-#define MM_BROADBAND_MODEM_WAVECOM_H
-
-#include "mm-broadband-modem.h"
-
-#define MM_TYPE_BROADBAND_MODEM_WAVECOM (mm_broadband_modem_wavecom_get_type ())
-#define MM_BROADBAND_MODEM_WAVECOM(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), MM_TYPE_BROADBAND_MODEM_WAVECOM, MMBroadbandModemWavecom))
-#define MM_BROADBAND_MODEM_WAVECOM_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), MM_TYPE_BROADBAND_MODEM_WAVECOM, MMBroadbandModemWavecomClass))
-#define MM_IS_BROADBAND_MODEM_WAVECOM(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), MM_TYPE_BROADBAND_MODEM_WAVECOM))
-#define MM_IS_BROADBAND_MODEM_WAVECOM_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), MM_TYPE_BROADBAND_MODEM_WAVECOM))
-#define MM_BROADBAND_MODEM_WAVECOM_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), MM_TYPE_BROADBAND_MODEM_WAVECOM, MMBroadbandModemWavecomClass))
-
-typedef struct _MMBroadbandModemWavecom MMBroadbandModemWavecom;
-typedef struct _MMBroadbandModemWavecomClass MMBroadbandModemWavecomClass;
-
-struct _MMBroadbandModemWavecom {
- MMBroadbandModem parent;
-};
-
-struct _MMBroadbandModemWavecomClass{
- MMBroadbandModemClass parent;
-};
-
-GType mm_broadband_modem_wavecom_get_type (void);
-
-MMBroadbandModemWavecom *mm_broadband_modem_wavecom_new (const gchar *device,
- const gchar **drivers,
- const gchar *plugin,
- guint16 vendor_id,
- guint16 product_id);
-
-#endif /* MM_BROADBAND_MODEM_WAVECOM_H */
diff --git a/plugins/wavecom/mm-plugin-wavecom.c b/plugins/wavecom/mm-plugin-wavecom.c
deleted file mode 100644
index 8e3f9d2c..00000000
--- a/plugins/wavecom/mm-plugin-wavecom.c
+++ /dev/null
@@ -1,88 +0,0 @@
-/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
-
-/*
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU General Public License as
- * published by the Free Software Foundation; either version 2 of the
- * License, or (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * General Public License for more details.
- *
- * You should have received a copy of the GNU General Public
- * License along with this program; if not, write to the
- * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
- * Boston, MA 02111-1307, USA.
- *
- * Copyright (C) 2011 Ammonit Measurement GmbH
- * Copyright (C) 2012 Aleksander Morgado <aleksander@gnu.org>
- *
- * Author: Aleksander Morgado <aleksander@lanedo.com>
- */
-
-#include <string.h>
-#include <gmodule.h>
-
-#define _LIBMM_INSIDE_MM
-#include <libmm-glib.h>
-
-#include "mm-plugin-wavecom.h"
-#include "mm-broadband-modem-wavecom.h"
-
-G_DEFINE_TYPE (MMPluginWavecom, mm_plugin_wavecom, MM_TYPE_PLUGIN)
-
-MM_PLUGIN_DEFINE_MAJOR_VERSION
-MM_PLUGIN_DEFINE_MINOR_VERSION
-
-/*****************************************************************************/
-
-static MMBaseModem *
-create_modem (MMPlugin *self,
- const gchar *uid,
- const gchar **drivers,
- guint16 vendor,
- guint16 product,
- guint16 subsystem_vendor,
- GList *probes,
- GError **error)
-{
- return MM_BASE_MODEM (mm_broadband_modem_wavecom_new (uid,
- drivers,
- mm_plugin_get_name (self),
- vendor,
- product));
-}
-
-/*****************************************************************************/
-
-G_MODULE_EXPORT MMPlugin *
-mm_plugin_create (void)
-{
- static const gchar *subsystems[] = { "tty", NULL };
- static const guint16 vendor_ids[] = { 0x114f, 0 };
- static const gchar *forbidden_drivers[] = { "qcserial", NULL };
-
- return MM_PLUGIN (
- g_object_new (MM_TYPE_PLUGIN_WAVECOM,
- MM_PLUGIN_NAME, MM_MODULE_NAME,
- MM_PLUGIN_ALLOWED_SUBSYSTEMS, subsystems,
- MM_PLUGIN_ALLOWED_VENDOR_IDS, vendor_ids,
- MM_PLUGIN_FORBIDDEN_DRIVERS, forbidden_drivers,
- MM_PLUGIN_ALLOWED_AT, TRUE,
- NULL));
-}
-
-static void
-mm_plugin_wavecom_init (MMPluginWavecom *self)
-{
-}
-
-static void
-mm_plugin_wavecom_class_init (MMPluginWavecomClass *klass)
-{
- MMPluginClass *plugin_class = MM_PLUGIN_CLASS (klass);
-
- plugin_class->create_modem = create_modem;
-}
diff --git a/plugins/wavecom/mm-plugin-wavecom.h b/plugins/wavecom/mm-plugin-wavecom.h
deleted file mode 100644
index c1d76309..00000000
--- a/plugins/wavecom/mm-plugin-wavecom.h
+++ /dev/null
@@ -1,49 +0,0 @@
-/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
-
-/*
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU General Public License as
- * published by the Free Software Foundation; either version 2 of the
- * License, or (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * General Public License for more details.
- *
- * You should have received a copy of the GNU General Public
- * License along with this program; if not, write to the
- * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
- * Boston, MA 02111-1307, USA.
- *
- * Copyright (C) 2011 Ammonit Measurement GmbH
- * Copyright (C) 2012 Aleksander Morgado <aleksander@gnu.org>
- *
- * Author: Aleksander Morgado <aleksander@lanedo.com>
- */
-
-#ifndef MM_PLUGIN_WAVECOM_H
-#define MM_PLUGIN_WAVECOM_H
-
-#include "mm-plugin.h"
-
-#define MM_TYPE_PLUGIN_WAVECOM (mm_plugin_wavecom_get_type ())
-#define MM_PLUGIN_WAVECOM(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), MM_TYPE_PLUGIN_WAVECOM, MMPluginWavecom))
-#define MM_PLUGIN_WAVECOM_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), MM_TYPE_PLUGIN_WAVECOM, MMPluginWavecomClass))
-#define MM_IS_PLUGIN_WAVECOM(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), MM_TYPE_PLUGIN_WAVECOM))
-#define MM_IS_PLUGIN_WAVECOM_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), MM_TYPE_PLUGIN_WAVECOM))
-#define MM_PLUGIN_WAVECOM_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), MM_TYPE_PLUGIN_WAVECOM, MMPluginWavecomClass))
-
-typedef struct {
- MMPlugin parent;
-} MMPluginWavecom;
-
-typedef struct {
- MMPluginClass parent;
-} MMPluginWavecomClass;
-
-GType mm_plugin_wavecom_get_type (void);
-
-G_MODULE_EXPORT MMPlugin *mm_plugin_create (void);
-
-#endif /* MM_PLUGIN_WAVECOM_H */