diff options
author | Marcel Holtmann <marcel@holtmann.org> | 2010-08-20 02:20:37 +0200 |
---|---|---|
committer | Marcel Holtmann <marcel@holtmann.org> | 2010-08-20 02:20:37 +0200 |
commit | d05ea32ac244e8d0185eea7c12b98da0c46e84b2 (patch) | |
tree | daef764de13c90c4d74d97848d0487fc3b80efca | |
parent | 7be74dabe28c3c3111be2b8cd4f08685d165800f (diff) | |
download | ofono-d05ea32ac244e8d0185eea7c12b98da0c46e84b2.tar.bz2 |
udev: Add detection for Nokia data cards
-rw-r--r-- | plugins/ofono.rules | 3 | ||||
-rw-r--r-- | plugins/udev.c | 37 |
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) |