diff options
author | Aleksander Morgado <aleksander@lanedo.com> | 2012-07-20 13:10:29 +0200 |
---|---|---|
committer | Aleksander Morgado <aleksander@lanedo.com> | 2012-08-06 20:07:49 +0200 |
commit | bbb4ed2b0a7e171e9a045a1e37580697b9cbc783 (patch) | |
tree | e61d6263f1333b21363d7a46de943b58fcb08e19 | |
parent | bdcc4becab4a10ae100117678e8249021d4bfd69 (diff) |
zte: start porting the ZTE plugin
-rw-r--r-- | plugins/Makefile.am | 19 | ||||
-rw-r--r-- | plugins/zte/77-mm-zte-port-types.rules (renamed from plugins/77-mm-zte-port-types.rules) | 0 | ||||
-rw-r--r-- | plugins/zte/mm-plugin-zte.c | 126 | ||||
-rw-r--r-- | plugins/zte/mm-plugin-zte.h | 42 |
4 files changed, 177 insertions, 10 deletions
diff --git a/plugins/Makefile.am b/plugins/Makefile.am index cb186d2f..1c58cb0e 100644 --- a/plugins/Makefile.am +++ b/plugins/Makefile.am @@ -56,7 +56,8 @@ pkglib_LTLIBRARIES = \ libmm-plugin-huawei.la \ libmm-plugin-longcheer.la \ libmm-plugin-x22x.la \ - libmm-plugin-pantech.la + libmm-plugin-pantech.la \ + libmm-plugin-zte.la #pkglib_LTLIBRARIES = \ # libmm-plugin-generic.la \ @@ -194,15 +195,13 @@ libmm_plugin_nokia_icera_la_LDFLAGS = $(PLUGIN_COMMON_LINKER_FLAGS) libmm_plugin_nokia_icera_la_LIBADD = $(ICERA_COMMON_LIBADD_FLAGS) udevrules_DATA += nokia/77-mm-nokia-port-types.rules -## Zte -#libmm_plugin_zte_la_SOURCES = \ -# mm-plugin-zte.c \ -# mm-plugin-zte.h \ -# mm-modem-zte.c \ -# mm-modem-zte.h -#libmm_plugin_zte_la_CPPFLAGS = $(PLUGIN_COMMON_COMPILER_FLAGS) -#libmm_plugin_zte_la_LDFLAGS = $(PLUGIN_COMMON_LINKER_FLAGS) -#libmm_plugin_zte_la_LIBADD = $(builddir)/libicera-utils.la +# Zte +libmm_plugin_zte_la_SOURCES = \ + zte/mm-plugin-zte.c \ + zte/mm-plugin-zte.h +libmm_plugin_zte_la_CPPFLAGS = $(PLUGIN_COMMON_COMPILER_FLAGS) +libmm_plugin_zte_la_LDFLAGS = $(PLUGIN_COMMON_LINKER_FLAGS) +udevrules_DATA += zte/77-mm-zte-port-types.rules # Longcheer (and rebranded dongles) libmm_plugin_longcheer_la_SOURCES = \ diff --git a/plugins/77-mm-zte-port-types.rules b/plugins/zte/77-mm-zte-port-types.rules index ac008dd7..ac008dd7 100644 --- a/plugins/77-mm-zte-port-types.rules +++ b/plugins/zte/77-mm-zte-port-types.rules diff --git a/plugins/zte/mm-plugin-zte.c b/plugins/zte/mm-plugin-zte.c new file mode 100644 index 00000000..c08dc0ee --- /dev/null +++ b/plugins/zte/mm-plugin-zte.c @@ -0,0 +1,126 @@ +/* -*- 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 - 2012 Red Hat, Inc. + * Copyright (C) 2012 Aleksander Morgado <aleksander@gnu.org> + */ + +#include <string.h> +#include <gmodule.h> + +#include <libmm-common.h> + +#include "mm-log.h" +#include "mm-plugin-zte.h" +#include "mm-broadband-modem.h" + +G_DEFINE_TYPE (MMPluginZte, mm_plugin_zte, MM_TYPE_PLUGIN) + +int mm_plugin_major_version = MM_PLUGIN_MAJOR_VERSION; +int mm_plugin_minor_version = MM_PLUGIN_MINOR_VERSION; + +/*****************************************************************************/ +/* Custom commands for AT probing */ + +/* Many ZTE devices will flood the port with "Message waiting" indications + * and eventually fill up the serial buffer and crash. We need to turn off + * that indicator. See NetworkManager commits + * 1235f71b20c92cded4abd976ccc5010649aae1a0 and + * f38ad328acfdc6ce29dd1380602c546b064161ae for more details. + * + * We use this command also for checking AT support in the port. + */ +static const MMPortProbeAtCommand custom_at_probe[] = { + { "ATE0+CPMS?", 3, mm_port_probe_response_processor_is_at }, + { "ATE0+CPMS?", 3, mm_port_probe_response_processor_is_at }, + { "ATE0+CPMS?", 3, mm_port_probe_response_processor_is_at }, + { NULL } +}; + +/*****************************************************************************/ + +static MMBaseModem * +create_modem (MMPlugin *self, + const gchar *sysfs_path, + const gchar *driver, + guint16 vendor, + guint16 product, + GList *probes, + GError **error) +{ + return MM_BASE_MODEM (mm_broadband_modem_new (sysfs_path, + driver, + mm_plugin_get_name (self), + vendor, + product)); +} + +static gboolean +grab_port (MMPlugin *self, + MMBaseModem *modem, + MMPortProbe *probe, + GError **error) +{ + GUdevDevice *port; + MMAtPortFlag pflags = MM_AT_PORT_FLAG_NONE; + + port = mm_port_probe_peek_port (probe); + + if (mm_port_probe_is_at (probe)) { + /* Look for port type hints */ + if (g_udev_device_get_property_as_boolean (port, "ID_MM_ZTE_PORT_TYPE_MODEM")) + pflags = MM_AT_PORT_FLAG_PRIMARY; + else if (g_udev_device_get_property_as_boolean (port, "ID_MM_ZTE_PORT_TYPE_AUX")) + pflags = MM_AT_PORT_FLAG_SECONDARY; + } + + return mm_base_modem_grab_port (modem, + mm_port_probe_get_port_subsys (probe), + mm_port_probe_get_port_name (probe), + mm_port_probe_get_port_type (probe), + pflags, + error); +} + +/*****************************************************************************/ + +G_MODULE_EXPORT MMPlugin * +mm_plugin_create (void) +{ + static const gchar *subsystems[] = { "tty", "net", NULL }; + static const guint16 vendor_ids[] = { 0x19d2, 0 }; + + return MM_PLUGIN ( + g_object_new (MM_TYPE_PLUGIN_ZTE, + MM_PLUGIN_NAME, "ZTE", + MM_PLUGIN_ALLOWED_SUBSYSTEMS, subsystems, + MM_PLUGIN_ALLOWED_VENDOR_IDS, vendor_ids, + MM_PLUGIN_CUSTOM_AT_PROBE, custom_at_probe, + MM_PLUGIN_ALLOWED_AT, TRUE, + MM_PLUGIN_ALLOWED_QCDM, TRUE, + NULL)); +} + +static void +mm_plugin_zte_init (MMPluginZte *self) +{ +} + +static void +mm_plugin_zte_class_init (MMPluginZteClass *klass) +{ + MMPluginClass *plugin_class = MM_PLUGIN_CLASS (klass); + + plugin_class->create_modem = create_modem; + plugin_class->grab_port = grab_port; +} diff --git a/plugins/zte/mm-plugin-zte.h b/plugins/zte/mm-plugin-zte.h new file mode 100644 index 00000000..353ce86e --- /dev/null +++ b/plugins/zte/mm-plugin-zte.h @@ -0,0 +1,42 @@ +/* -*- 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 - 2012 Red Hat, Inc. + * Copyright (C) 2012 Aleksander Morgado <aleksander@gnu.org> + */ + +#ifndef MM_PLUGIN_ZTE_H +#define MM_PLUGIN_ZTE_H + +#include "mm-plugin.h" + +#define MM_TYPE_PLUGIN_ZTE (mm_plugin_zte_get_type ()) +#define MM_PLUGIN_ZTE(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), MM_TYPE_PLUGIN_ZTE, MMPluginZte)) +#define MM_PLUGIN_ZTE_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), MM_TYPE_PLUGIN_ZTE, MMPluginZteClass)) +#define MM_IS_PLUGIN_ZTE(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), MM_TYPE_PLUGIN_ZTE)) +#define MM_IS_PLUGIN_ZTE_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), MM_TYPE_PLUGIN_ZTE)) +#define MM_PLUGIN_ZTE_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), MM_TYPE_PLUGIN_ZTE, MMPluginZteClass)) + +typedef struct { + MMPlugin parent; +} MMPluginZte; + +typedef struct { + MMPluginClass parent; +} MMPluginZteClass; + +GType mm_plugin_zte_get_type (void); + +G_MODULE_EXPORT MMPlugin *mm_plugin_create (void); + +#endif /* MM_PLUGIN_ZTE_H */ |