telit: support QMI and MBIM modems

Vendor specific plugins that support QMI or MBIM based devices need to
handle the creation of these modems themselves.

https://bugs.freedesktop.org/show_bug.cgi?id=100372

Original patch by Aleksander Morgado.
This commit is contained in:
Daniele Palmas
2017-03-27 15:54:46 +02:00
committed by Aleksander Morgado
parent eee6896648
commit 6de2d84af1
3 changed files with 41 additions and 4 deletions

View File

@@ -42,7 +42,4 @@ ATTRS{idVendor}=="1bc7", ATTRS{idProduct}=="0022", ENV{ID_MM_TELIT_PORTS_TAGGED}
# LE910 V2 # LE910 V2
ATTRS{idVendor}=="1bc7", ATTRS{idProduct}=="0036", ENV{ID_MM_TELIT_PORTS_TAGGED}="1" ATTRS{idVendor}=="1bc7", ATTRS{idProduct}=="0036", ENV{ID_MM_TELIT_PORTS_TAGGED}="1"
# NOTE: Qualcomm Gobi-based devices like the LE920 should not be handled
# by this plugin, but by the Gobi plugin.
LABEL="mm_telit_port_types_end" LABEL="mm_telit_port_types_end"

View File

@@ -38,10 +38,16 @@ telit_grab_port (MMPlugin *self,
MMDevice *device; MMDevice *device;
MMPortType ptype; MMPortType ptype;
MMPortSerialAtFlag pflags = MM_PORT_SERIAL_AT_FLAG_NONE; MMPortSerialAtFlag pflags = MM_PORT_SERIAL_AT_FLAG_NONE;
const gchar *subsys;
port = mm_port_probe_peek_port (probe); port = mm_port_probe_peek_port (probe);
ptype = mm_port_probe_get_port_type (probe); ptype = mm_port_probe_get_port_type (probe);
device = mm_port_probe_peek_device (probe); device = mm_port_probe_peek_device (probe);
subsys = mm_port_probe_get_port_subsys (probe);
/* Just skip custom port identification for subsys different than tty */
if (!g_str_equal (subsys, "tty"))
goto out;
/* Look for port type hints; just probing can't distinguish which port should /* Look for port type hints; just probing can't distinguish which port should
* be the data/primary port on these devices. We have to tag them based on * be the data/primary port on these devices. We have to tag them based on
@@ -102,6 +108,7 @@ telit_grab_port (MMPlugin *self,
ptype = MM_PORT_TYPE_IGNORED; ptype = MM_PORT_TYPE_IGNORED;
} }
out:
return mm_base_modem_grab_port (modem, return mm_base_modem_grab_port (modem,
port, port,
ptype, ptype,

View File

@@ -28,6 +28,15 @@
#include "mm-common-telit.h" #include "mm-common-telit.h"
#include "mm-broadband-modem-telit.h" #include "mm-broadband-modem-telit.h"
#if defined WITH_QMI
# include "mm-broadband-modem-qmi.h"
#endif
#if defined WITH_MBIM
# include "mm-broadband-modem-mbim.h"
#endif
G_DEFINE_TYPE (MMPluginTelit, mm_plugin_telit, MM_TYPE_PLUGIN) G_DEFINE_TYPE (MMPluginTelit, mm_plugin_telit, MM_TYPE_PLUGIN)
MM_PLUGIN_DEFINE_MAJOR_VERSION MM_PLUGIN_DEFINE_MAJOR_VERSION
@@ -44,6 +53,28 @@ create_modem (MMPlugin *self,
GList *probes, GList *probes,
GError **error) GError **error)
{ {
#if defined WITH_QMI
if (mm_port_probe_list_has_qmi_port (probes)) {
mm_dbg ("QMI-powered Telit modem found...");
return MM_BASE_MODEM (mm_broadband_modem_qmi_new (uid,
drivers,
mm_plugin_get_name (self),
vendor,
product));
}
#endif
#if defined WITH_MBIM
if (mm_port_probe_list_has_mbim_port (probes)) {
mm_dbg ("MBIM-powered Telit modem found...");
return MM_BASE_MODEM (mm_broadband_modem_mbim_new (uid,
drivers,
mm_plugin_get_name (self),
vendor,
product));
}
#endif
return MM_BASE_MODEM (mm_broadband_modem_telit_new (uid, return MM_BASE_MODEM (mm_broadband_modem_telit_new (uid,
drivers, drivers,
mm_plugin_get_name (self), mm_plugin_get_name (self),
@@ -56,7 +87,7 @@ create_modem (MMPlugin *self,
G_MODULE_EXPORT MMPlugin * G_MODULE_EXPORT MMPlugin *
mm_plugin_create (void) mm_plugin_create (void)
{ {
static const gchar *subsystems[] = { "tty", NULL }; static const gchar *subsystems[] = { "tty", "net", "usb", NULL };
/* Vendors: Telit */ /* Vendors: Telit */
static const guint16 vendor_ids[] = { 0x1bc7, 0 }; static const guint16 vendor_ids[] = { 0x1bc7, 0 };
static const gchar *vendor_strings[] = { "telit", NULL }; static const gchar *vendor_strings[] = { "telit", NULL };
@@ -73,6 +104,8 @@ mm_plugin_create (void)
MM_PLUGIN_ALLOWED_VENDOR_IDS, vendor_ids, MM_PLUGIN_ALLOWED_VENDOR_IDS, vendor_ids,
MM_PLUGIN_ALLOWED_VENDOR_STRINGS, vendor_strings, MM_PLUGIN_ALLOWED_VENDOR_STRINGS, vendor_strings,
MM_PLUGIN_ALLOWED_AT, TRUE, MM_PLUGIN_ALLOWED_AT, TRUE,
MM_PLUGIN_ALLOWED_QMI, TRUE,
MM_PLUGIN_ALLOWED_MBIM, TRUE,
MM_PLUGIN_CUSTOM_INIT, &custom_init, MM_PLUGIN_CUSTOM_INIT, &custom_init,
NULL)); NULL));
} }