diff options
author | Aleksander Morgado <aleksander@aleksander.es> | 2020-05-10 10:36:47 +0200 |
---|---|---|
committer | Aleksander Morgado <aleksander@aleksander.es> | 2020-05-10 10:51:45 +0200 |
commit | 26b589cc021f744d1af5d3680907a3e1f0689823 (patch) | |
tree | dadf6f66a8560e09d9baddabc48a7bea3f166ee7 | |
parent | 0ddadbdc37c80397367dcd75f0752cc45b2285b6 (diff) |
broadmobi: new plugin
Right now, just with port type hints for the BM818.
-rw-r--r-- | .gitlab-ci.yml | 6 | ||||
-rw-r--r-- | configure.ac | 2 | ||||
-rw-r--r-- | plugins/Makefile.am | 23 | ||||
-rw-r--r-- | plugins/broadmobi/77-mm-broadmobi-port-types.rules | 16 | ||||
-rw-r--r-- | plugins/broadmobi/mm-plugin-broadmobi.c | 95 | ||||
-rw-r--r-- | plugins/broadmobi/mm-plugin-broadmobi.h | 40 |
6 files changed, 179 insertions, 3 deletions
diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 24b9009e..cd534bb0 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -83,9 +83,9 @@ build-single-plugins: - make install - popd - NOCONFIGURE=1 ./autogen.sh - - for plugin in generic altair-lte anydata cinterion dell dlink - fibocom foxconn haier huawei iridium linktop - longcheer mbm motorola mtk nokia nokia-icera + - for plugin in generic altair-lte anydata broadmobi cinterion + dell dlink fibocom foxconn haier huawei iridium + linktop longcheer mbm motorola mtk nokia nokia-icera novatel novatel-lte option option-hso pantech quectel samsung sierra-legacy sierra simtech telit thuraya tplink ublox via wavecom x22x zte; do diff --git a/configure.ac b/configure.ac index e9883ad4..47cb6f0d 100644 --- a/configure.ac +++ b/configure.ac @@ -448,6 +448,7 @@ MM_ENABLE_ALL_PLUGINS MM_ENABLE_PLUGIN([generic]) MM_ENABLE_PLUGIN([altair-lte]) MM_ENABLE_PLUGIN([anydata]) +MM_ENABLE_PLUGIN([broadmobi]) MM_ENABLE_PLUGIN([cinterion]) MM_ENABLE_PLUGIN([dell], [with_shared_sierra, @@ -592,6 +593,7 @@ echo " generic: ${enable_plugin_generic} altair lte: ${enable_plugin_altair_lte} anydata: ${enable_plugin_anydata} + broadmobi: ${enable_plugin_broadmobi} cinterion: ${enable_plugin_cinterion} dell: ${enable_plugin_dell} dlink: ${enable_plugin_dlink} diff --git a/plugins/Makefile.am b/plugins/Makefile.am index 15ba237d..6f83ad61 100644 --- a/plugins/Makefile.am +++ b/plugins/Makefile.am @@ -537,6 +537,29 @@ libmm_plugin_anydata_la_LDFLAGS = $(PLUGIN_COMMON_LINKER_FLAGS) endif ################################################################################ +# plugin: broadmobi +################################################################################ + +if ENABLE_PLUGIN_BROADMOBI + +pkglib_LTLIBRARIES += libmm-plugin-broadmobi.la +libmm_plugin_broadmobi_la_SOURCES = \ + broadmobi/mm-plugin-broadmobi.c \ + broadmobi/mm-plugin-broadmobi.h \ + $(NULL) +libmm_plugin_broadmobi_la_CPPFLAGS = \ + $(PLUGIN_COMMON_COMPILER_FLAGS) \ + -DMM_MODULE_NAME=\"broadmobi\" \ + $(NULL) +libmm_plugin_broadmobi_la_LDFLAGS = $(PLUGIN_COMMON_LINKER_FLAGS) + +dist_udevrules_DATA += broadmobi/77-mm-broadmobi-port-types.rules + +AM_CFLAGS += -DTESTUDEVRULESDIR_BROADMOBI=\"${srcdir}/broadmobi\" + +endif + +################################################################################ # plugin: cinterion (previously siemens) ################################################################################ diff --git a/plugins/broadmobi/77-mm-broadmobi-port-types.rules b/plugins/broadmobi/77-mm-broadmobi-port-types.rules new file mode 100644 index 00000000..863cb74c --- /dev/null +++ b/plugins/broadmobi/77-mm-broadmobi-port-types.rules @@ -0,0 +1,16 @@ +# do not edit this file, it will be overwritten on update + +ACTION!="add|change|move|bind", GOTO="mm_broadmobi_port_types_end" +SUBSYSTEMS=="usb", ATTRS{idVendor}=="2020", GOTO="mm_broadmobi_port_types" +GOTO="mm_broadmobi_port_types_end" + +LABEL="mm_broadmobi_port_types" +SUBSYSTEMS=="usb", ATTRS{bInterfaceNumber}=="?*", ENV{.MM_USBIFNUM}="$attr{bInterfaceNumber}" + +# BroadMobi BM818 +ATTRS{idVendor}=="2020", ATTRS{idProduct}=="2060", ENV{.MM_USBIFNUM}=="00", ENV{ID_MM_PORT_TYPE_QCDM}="1" +ATTRS{idVendor}=="2020", ATTRS{idProduct}=="2060", ENV{.MM_USBIFNUM}=="01", ENV{ID_MM_PORT_TYPE_AT_PRIMARY}="1" +ATTRS{idVendor}=="2020", ATTRS{idProduct}=="2060", ENV{.MM_USBIFNUM}=="02", ENV{ID_MM_PORT_TYPE_AT_SECONDARY}="1" +ATTRS{idVendor}=="2020", ATTRS{idProduct}=="2060", ENV{.MM_USBIFNUM}=="03", ENV{ID_MM_PORT_TYPE_AT_SECONDARY}="1" + +LABEL="mm_broadmobi_port_types_end"
\ No newline at end of file diff --git a/plugins/broadmobi/mm-plugin-broadmobi.c b/plugins/broadmobi/mm-plugin-broadmobi.c new file mode 100644 index 00000000..c6a5782c --- /dev/null +++ b/plugins/broadmobi/mm-plugin-broadmobi.c @@ -0,0 +1,95 @@ +/* -*- 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) 2020 Aleksander Morgado <aleksander@aleksander.es> + */ + +#include <string.h> +#include <gmodule.h> + +#define _LIBMM_INSIDE_MM +#include <libmm-glib.h> + +#include "mm-port-enums-types.h" +#include "mm-log-object.h" +#include "mm-plugin-broadmobi.h" +#include "mm-broadband-modem.h" + +#if defined WITH_QMI +# include "mm-broadband-modem-qmi.h" +#endif + +G_DEFINE_TYPE (MMPluginBroadmobi, mm_plugin_broadmobi, 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, + GList *probes, + GError **error) +{ +#if defined WITH_QMI + if (mm_port_probe_list_has_qmi_port (probes)) { + mm_obj_dbg (self, "QMI-powered BroadMobi modem found..."); + return MM_BASE_MODEM (mm_broadband_modem_qmi_new (uid, + drivers, + mm_plugin_get_name (self), + vendor, + product)); + } +#endif + + return MM_BASE_MODEM (mm_broadband_modem_new (uid, + drivers, + mm_plugin_get_name (self), + vendor, + product)); +} + +/*****************************************************************************/ + +G_MODULE_EXPORT MMPlugin * +mm_plugin_create (void) +{ + static const gchar *subsystems[] = { "tty", "net", "usb", NULL }; + static const guint16 vendor_ids[] = { 0x2020, 0 }; + + return MM_PLUGIN ( + g_object_new (MM_TYPE_PLUGIN_BROADMOBI, + MM_PLUGIN_NAME, MM_MODULE_NAME, + MM_PLUGIN_ALLOWED_SUBSYSTEMS, subsystems, + MM_PLUGIN_ALLOWED_VENDOR_IDS, vendor_ids, + MM_PLUGIN_ALLOWED_AT, TRUE, + MM_PLUGIN_ALLOWED_QCDM, TRUE, + MM_PLUGIN_ALLOWED_QMI, TRUE, + NULL)); +} + +static void +mm_plugin_broadmobi_init (MMPluginBroadmobi *self) +{ +} + +static void +mm_plugin_broadmobi_class_init (MMPluginBroadmobiClass *klass) +{ + MMPluginClass *plugin_class = MM_PLUGIN_CLASS (klass); + + plugin_class->create_modem = create_modem; +} diff --git a/plugins/broadmobi/mm-plugin-broadmobi.h b/plugins/broadmobi/mm-plugin-broadmobi.h new file mode 100644 index 00000000..1f46cfce --- /dev/null +++ b/plugins/broadmobi/mm-plugin-broadmobi.h @@ -0,0 +1,40 @@ +/* -*- 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) 2020 Aleksander Morgado <aleksander@aleksander.es> + */ + +#ifndef MM_PLUGIN_BROADMOBI_H +#define MM_PLUGIN_BROADMOBI_H + +#include "mm-plugin.h" + +#define MM_TYPE_PLUGIN_BROADMOBI (mm_plugin_broadmobi_get_type ()) +#define MM_PLUGIN_BROADMOBI(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), MM_TYPE_PLUGIN_BROADMOBI, MMPluginBroadmobi)) +#define MM_PLUGIN_BROADMOBI_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), MM_TYPE_PLUGIN_BROADMOBI, MMPluginBroadmobiClass)) +#define MM_IS_PLUGIN_BROADMOBI(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), MM_TYPE_PLUGIN_BROADMOBI)) +#define MM_IS_PLUGIN_BROADMOBI_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), MM_TYPE_PLUGIN_BROADMOBI)) +#define MM_PLUGIN_BROADMOBI_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), MM_TYPE_PLUGIN_BROADMOBI, MMPluginBroadmobiClass)) + +typedef struct { + MMPlugin parent; +} MMPluginBroadmobi; + +typedef struct { + MMPluginClass parent; +} MMPluginBroadmobiClass; + +GType mm_plugin_broadmobi_get_type (void); + +G_MODULE_EXPORT MMPlugin *mm_plugin_create (void); + +#endif /* MM_PLUGIN_BROADMOBI_H */ |