[PATCH] simtech: support QMI devices
Yegor Yefremov
yegorslists at googlemail.com
Tue May 31 13:50:18 UTC 2016
On Tue, May 31, 2016 at 11:24 AM, Aleksander Morgado
<aleksander at aleksander.es> wrote:
> ---
>
> Hey Yegor,
>
> Sorry, completely forgot about it.
>
> Could you try this patch and see if it works?
It works. Thanks.
Tested-by: Yegor Yefremov <yegorslists at googlemail.com>
Yegor
> ---
> plugins/simtech/mm-plugin-simtech.c | 79 ++++++++++++++++++++-----------------
> 1 file changed, 43 insertions(+), 36 deletions(-)
>
> diff --git a/plugins/simtech/mm-plugin-simtech.c b/plugins/simtech/mm-plugin-simtech.c
> index fcaa250..b736185 100644
> --- a/plugins/simtech/mm-plugin-simtech.c
> +++ b/plugins/simtech/mm-plugin-simtech.c
> @@ -25,6 +25,10 @@
> #include "mm-plugin-simtech.h"
> #include "mm-broadband-modem-simtech.h"
>
> +#if defined WITH_QMI
> +#include "mm-broadband-modem-qmi.h"
> +#endif
> +
> G_DEFINE_TYPE (MMPluginSimtech, mm_plugin_simtech, MM_TYPE_PLUGIN)
>
> MM_PLUGIN_DEFINE_MAJOR_VERSION
> @@ -41,6 +45,17 @@ create_modem (MMPlugin *self,
> GList *probes,
> GError **error)
> {
> +#if defined WITH_QMI
> + if (mm_port_probe_list_has_qmi_port (probes)) {
> + mm_dbg ("QMI-powered SimTech modem found...");
> + return MM_BASE_MODEM (mm_broadband_modem_qmi_new (sysfs_path,
> + drivers,
> + mm_plugin_get_name (self),
> + vendor,
> + product));
> + }
> +#endif
> +
> return MM_BASE_MODEM (mm_broadband_modem_simtech_new (sysfs_path,
> drivers,
> mm_plugin_get_name (self),
> @@ -58,44 +73,35 @@ grab_port (MMPlugin *self,
> MMPortType ptype;
> MMPortSerialAtFlag pflags = MM_PORT_SERIAL_AT_FLAG_NONE;
>
> - /* The Simtech plugin cannot do anything with non-AT non-QCDM ports */
> - if (!mm_port_probe_is_at (probe) &&
> - !mm_port_probe_is_qcdm (probe)) {
> - g_set_error_literal (error,
> - MM_CORE_ERROR,
> - MM_CORE_ERROR_UNSUPPORTED,
> - "Ignoring non-AT non-QCDM port");
> - return FALSE;
> - }
> -
> port = mm_port_probe_peek_port (probe);
> -
> - /* 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
> - * what the Windows .INF files say the port layout should be.
> - */
> - if (g_udev_device_get_property_as_boolean (port, "ID_MM_SIMTECH_PORT_TYPE_MODEM")) {
> - mm_dbg ("Simtech: AT port '%s/%s' flagged as primary",
> - mm_port_probe_get_port_subsys (probe),
> - mm_port_probe_get_port_name (probe));
> - pflags = MM_PORT_SERIAL_AT_FLAG_PRIMARY;
> - } else if (g_udev_device_get_property_as_boolean (port, "ID_MM_SIMTECH_PORT_TYPE_AUX")) {
> - mm_dbg ("Simtech: AT port '%s/%s' flagged as secondary",
> - mm_port_probe_get_port_subsys (probe),
> - mm_port_probe_get_port_name (probe));
> - pflags = MM_PORT_SERIAL_AT_FLAG_SECONDARY;
> + ptype = mm_port_probe_get_port_type (probe);
> +
> + if (mm_port_probe_is_at (probe)) {
> + /* 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
> + * what the Windows .INF files say the port layout should be.
> + */
> + if (g_udev_device_get_property_as_boolean (port, "ID_MM_SIMTECH_PORT_TYPE_MODEM")) {
> + mm_dbg ("Simtech: AT port '%s/%s' flagged as primary",
> + mm_port_probe_get_port_subsys (probe),
> + mm_port_probe_get_port_name (probe));
> + pflags = MM_PORT_SERIAL_AT_FLAG_PRIMARY;
> + } else if (g_udev_device_get_property_as_boolean (port, "ID_MM_SIMTECH_PORT_TYPE_AUX")) {
> + mm_dbg ("Simtech: AT port '%s/%s' flagged as secondary",
> + mm_port_probe_get_port_subsys (probe),
> + mm_port_probe_get_port_name (probe));
> + pflags = MM_PORT_SERIAL_AT_FLAG_SECONDARY;
> + }
> +
> + /* If the port was tagged by the udev rules but isn't a primary or secondary,
> + * then ignore it to guard against race conditions if a device just happens
> + * to show up with more than two AT-capable ports.
> + */
> + if (pflags == MM_PORT_SERIAL_AT_FLAG_NONE &&
> + g_udev_device_get_property_as_boolean (port, "ID_MM_SIMTECH_TAGGED"))
> + ptype = MM_PORT_TYPE_IGNORED;
> }
>
> - /* If the port was tagged by the udev rules but isn't a primary or secondary,
> - * then ignore it to guard against race conditions if a device just happens
> - * to show up with more than two AT-capable ports.
> - */
> - if (pflags == MM_PORT_SERIAL_AT_FLAG_NONE &&
> - g_udev_device_get_property_as_boolean (port, "ID_MM_SIMTECH_TAGGED"))
> - ptype = MM_PORT_TYPE_IGNORED;
> - else
> - ptype = mm_port_probe_get_port_type (probe);
> -
> return mm_base_modem_grab_port (modem,
> mm_port_probe_get_port_subsys (probe),
> mm_port_probe_get_port_name (probe),
> @@ -110,7 +116,7 @@ grab_port (MMPlugin *self,
> G_MODULE_EXPORT MMPlugin *
> mm_plugin_create (void)
> {
> - static const gchar *subsystems[] = { "tty", NULL };
> + static const gchar *subsystems[] = { "tty", "net", "usb", NULL };
> static const guint16 vendor_ids[] = { 0x1e0e, /* A-Link (for now) */
> 0 };
>
> @@ -121,6 +127,7 @@ mm_plugin_create (void)
> MM_PLUGIN_ALLOWED_VENDOR_IDS, vendor_ids,
> MM_PLUGIN_ALLOWED_AT, TRUE,
> MM_PLUGIN_ALLOWED_QCDM, TRUE,
> + MM_PLUGIN_ALLOWED_QMI, TRUE,
> NULL));
> }
>
> --
> 2.8.2
More information about the ModemManager-devel
mailing list