| /* -*- 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) 2008 - 2009 Novell, Inc. |
| * Copyright (C) 2009 - 2011 Red Hat, Inc. |
| * Copyright (C) 2015 - Marco Bascetta <marco.bascetta@sadel.it> |
| * Copyright (C) 2011 - 2022 Google, Inc. |
| */ |
| |
| #ifndef MM_BROADBAND_MODEM_H |
| #define MM_BROADBAND_MODEM_H |
| |
| #include <glib.h> |
| #include <glib-object.h> |
| |
| #include <ModemManager.h> |
| |
| #include "mm-modem-helpers.h" |
| #include "mm-charsets.h" |
| #include "mm-base-modem.h" |
| #include "mm-base-sms.h" |
| |
| #define MM_TYPE_BROADBAND_MODEM (mm_broadband_modem_get_type ()) |
| #define MM_BROADBAND_MODEM(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), MM_TYPE_BROADBAND_MODEM, MMBroadbandModem)) |
| #define MM_BROADBAND_MODEM_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), MM_TYPE_BROADBAND_MODEM, MMBroadbandModemClass)) |
| #define MM_IS_BROADBAND_MODEM(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), MM_TYPE_BROADBAND_MODEM)) |
| #define MM_IS_BROADBAND_MODEM_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), MM_TYPE_BROADBAND_MODEM)) |
| #define MM_BROADBAND_MODEM_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), MM_TYPE_BROADBAND_MODEM, MMBroadbandModemClass)) |
| |
| typedef struct _MMBroadbandModem MMBroadbandModem; |
| typedef struct _MMBroadbandModemClass MMBroadbandModemClass; |
| typedef struct _MMBroadbandModemPrivate MMBroadbandModemPrivate; |
| |
| #define MM_BROADBAND_MODEM_FLOW_CONTROL "broadband-modem-flow-control" |
| #define MM_BROADBAND_MODEM_INDICATORS_DISABLED "broadband-modem-indicators-disabled" |
| |
| #if defined WITH_SUSPEND_RESUME |
| # define MM_BROADBAND_MODEM_SIGNAL_SYNC_NEEDED "broadband-modem-sync-needed" |
| #endif |
| |
| struct _MMBroadbandModem { |
| MMBaseModem parent; |
| MMBroadbandModemPrivate *priv; |
| }; |
| |
| struct _MMBroadbandModemClass { |
| MMBaseModemClass parent; |
| |
| /* Setup ports, e.g. to setup unsolicited response handlers. |
| * Plugins which need specific setups should chain up parent's port setup |
| * as well. */ |
| void (* setup_ports) (MMBroadbandModem *self); |
| |
| /* First and last initialization steps. |
| * Actually, this is not really the first step, setup_ports() is */ |
| void (* initialization_started) (MMBroadbandModem *self, |
| GAsyncReadyCallback callback, |
| gpointer user_data); |
| gpointer (* initialization_started_finish) (MMBroadbandModem *self, |
| GAsyncResult *res, |
| GError **error); |
| gboolean (* initialization_stopped) (MMBroadbandModem *self, |
| gpointer started_context, |
| GError **error); |
| |
| /* First enabling step */ |
| void (* enabling_started) (MMBroadbandModem *self, |
| GAsyncReadyCallback callback, |
| gpointer user_data); |
| gboolean (* enabling_started_finish) (MMBroadbandModem *self, |
| GAsyncResult *res, |
| GError **error); |
| |
| /* Modem initialization. During the 'enabling' step, this setup will be |
| * called in order to initialize the modem, only if it wasn't hotplugged, |
| * as we assume that a hotplugged modem is already initialized. */ |
| void (* enabling_modem_init) (MMBroadbandModem *self, |
| GAsyncReadyCallback callback, |
| gpointer user_data); |
| gboolean (* enabling_modem_init_finish) (MMBroadbandModem *self, |
| GAsyncResult *res, |
| GError **error); |
| |
| /* Last disabling step */ |
| gboolean (* disabling_stopped) (MMBroadbandModem *self, |
| GError **error); |
| |
| #if defined WITH_SUSPEND_RESUME |
| /* signals */ |
| void (* sync_needed) (MMBroadbandModem *self); |
| #endif |
| |
| /* initial EPS bearer profile id selection */ |
| void (* load_initial_eps_bearer_cid) (MMBroadbandModem *self, |
| GAsyncReadyCallback callback, |
| gpointer user_data); |
| gint (* load_initial_eps_bearer_cid_finish) (MMBroadbandModem *self, |
| GAsyncResult *res, |
| GError **error); |
| |
| /* Create SMS objects */ |
| MMBaseSms * (* create_sms) (MMBroadbandModem *self); |
| }; |
| |
| GType mm_broadband_modem_get_type (void); |
| G_DEFINE_AUTOPTR_CLEANUP_FUNC (MMBroadbandModem, g_object_unref) |
| |
| MMBroadbandModem *mm_broadband_modem_new (const gchar *device, |
| const gchar *physdev, |
| const gchar **drivers, |
| const gchar *plugin, |
| guint16 vendor_id, |
| guint16 product_id); |
| |
| MMModemCharset mm_broadband_modem_get_current_charset (MMBroadbandModem *self); |
| |
| /* Create a unique device identifier string using the ATI and ATI1 replies and some |
| * additional internal info */ |
| gchar *mm_broadband_modem_create_device_identifier (MMBroadbandModem *self, |
| const gchar *ati, |
| const gchar *ati1, |
| GError **error); |
| |
| /* Helper to update SIM hot swap */ |
| gboolean mm_broadband_modem_sim_hot_swap_ports_context_init (MMBroadbandModem *self, |
| GError **error); |
| void mm_broadband_modem_sim_hot_swap_ports_context_reset (MMBroadbandModem *self); |
| |
| /* Helper to manage multiplexed bearers */ |
| gboolean mm_broadband_modem_get_active_multiplexed_bearers (MMBroadbandModem *self, |
| guint *out_current, |
| guint *out_max, |
| GError **error); |
| |
| /* Helper to manage initial EPS bearer */ |
| gint mm_broadband_modem_get_initial_eps_bearer_cid (MMBroadbandModem *self); |
| |
| /* Helper to create a new modem-specific SMS object */ |
| MMBaseSms *mm_broadband_modem_create_sms (MMBroadbandModem *self); |
| |
| #endif /* MM_BROADBAND_MODEM_H */ |