summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMarcel Holtmann <marcel@holtmann.org>2010-08-20 02:20:37 +0200
committerMarcel Holtmann <marcel@holtmann.org>2010-08-20 02:20:37 +0200
commitd05ea32ac244e8d0185eea7c12b98da0c46e84b2 (patch)
treedaef764de13c90c4d74d97848d0487fc3b80efca
parent7be74dabe28c3c3111be2b8cd4f08685d165800f (diff)
downloadofono-d05ea32ac244e8d0185eea7c12b98da0c46e84b2.tar.bz2
udev: Add detection for Nokia data cards
-rw-r--r--plugins/ofono.rules3
-rw-r--r--plugins/udev.c37
2 files changed, 40 insertions, 0 deletions
diff --git a/plugins/ofono.rules b/plugins/ofono.rules
index cb821dd8..2dd66521 100644
--- a/plugins/ofono.rules
+++ b/plugins/ofono.rules
@@ -388,4 +388,7 @@ ATTRS{idVendor}=="0930", ATTRS{idProduct}=="130b", ENV{OFONO_DRIVER}="mbm"
ATTRS{idVendor}=="0930", ATTRS{idProduct}=="130c", ENV{OFONO_DRIVER}="mbm"
ATTRS{idVendor}=="0930", ATTRS{idProduct}=="1311", ENV{OFONO_DRIVER}="mbm"
+# Nokia Internet Stick CS-10
+ATTRS{idVendor}=="0421", ATTRS{idProduct}=="060e", ENV{OFONO_DRIVER}="nokia"
+
LABEL="ofono_end"
diff --git a/plugins/udev.c b/plugins/udev.c
index 1ddfbea4..84399ded 100644
--- a/plugins/udev.c
+++ b/plugins/udev.c
@@ -86,6 +86,9 @@ static const char *get_serial(struct udev_device *udev_device)
entry = udev_list_entry_get_next(entry);
}
+ if (strpbrk(serial, ".-_?*") != NULL)
+ return NULL;
+
return serial;
}
@@ -339,6 +342,8 @@ static void add_novatel(struct ofono_modem *modem,
parent = udev_device_get_parent(parent);
intfnum = udev_device_get_sysattr_value(parent, "bInterfaceNumber");
+ DBG("intfnum %s", intfnum);
+
if (g_strcmp0(intfnum, "00") == 0) {
devnode = udev_device_get_devnode(udev_device);
ofono_modem_set_string(modem, "PrimaryDevice", devnode);
@@ -351,6 +356,36 @@ static void add_novatel(struct ofono_modem *modem,
}
}
+static void add_nokia(struct ofono_modem *modem,
+ struct udev_device *udev_device)
+{
+ const char *devnode, *intfnum;
+ struct udev_device *parent;
+ int registered;
+
+ DBG("modem %p", modem);
+
+ registered = ofono_modem_get_integer(modem, "Registered");
+ if (registered != 0)
+ return;
+
+ parent = udev_device_get_parent(udev_device);
+ intfnum = udev_device_get_sysattr_value(parent, "bInterfaceNumber");
+
+ DBG("intfnum %s", intfnum);
+
+ if (g_strcmp0(intfnum, "01") == 0) {
+ devnode = udev_device_get_devnode(udev_device);
+ ofono_modem_set_string(modem, "Modem", devnode);
+ } else if (g_strcmp0(intfnum, "03") == 0) {
+ devnode = udev_device_get_devnode(udev_device);
+ ofono_modem_set_string(modem, "Control", devnode);
+
+ ofono_modem_set_integer(modem, "Registered", 1);
+ ofono_modem_register(modem);
+ }
+}
+
static void add_modem(struct udev_device *udev_device)
{
struct ofono_modem *modem;
@@ -409,6 +444,8 @@ static void add_modem(struct udev_device *udev_device)
add_huawei(modem, udev_device);
else if (g_strcmp0(driver, "novatel") == 0)
add_novatel(modem, udev_device);
+ else if (g_strcmp0(driver, "nokia") == 0)
+ add_nokia(modem, udev_device);
}
static gboolean devpath_remove(gpointer key, gpointer value, gpointer user_data)