summaryrefslogtreecommitdiffstats
path: root/plugins/udev.c
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/udev.c')
-rw-r--r--plugins/udev.c38
1 files changed, 33 insertions, 5 deletions
diff --git a/plugins/udev.c b/plugins/udev.c
index ca7a25ce..82421cca 100644
--- a/plugins/udev.c
+++ b/plugins/udev.c
@@ -91,7 +91,8 @@ static const char *get_driver(struct udev_device *udev_device)
#define MBM_GPS_DEVICE "GPSDevice"
#define MBM_NETWORK_INTERFACE "NetworkInterface"
-static void add_mbm(struct ofono_modem *modem, struct udev_device *udev_device)
+static void add_mbm(struct ofono_modem *modem,
+ struct udev_device *udev_device)
{
const char *description, *devnode;
const char *device, *network;
@@ -134,6 +135,23 @@ static void add_mbm(struct ofono_modem *modem, struct udev_device *udev_device)
}
}
+static void add_huawei(struct ofono_modem *modem,
+ struct udev_device *udev_device)
+{
+ const char *devnode;
+ int registered;
+
+ registered = ofono_modem_get_integer(modem, "Registered");
+ if (registered != 0)
+ return;
+
+ devnode = udev_device_get_devnode(udev_device);
+ ofono_modem_set_string(modem, "Device", 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;
@@ -148,8 +166,12 @@ static void add_modem(struct udev_device *udev_device)
if (driver == NULL) {
parent = udev_device_get_parent(parent);
driver = get_driver(parent);
- if (driver == NULL)
- return;
+ if (driver == NULL) {
+ parent = udev_device_get_parent(parent);
+ driver = get_driver(parent);
+ if (driver == NULL)
+ return;
+ }
}
devpath = udev_device_get_devpath(parent);
@@ -170,6 +192,8 @@ static void add_modem(struct udev_device *udev_device)
if (g_strcmp0(driver, "mbm") == 0)
add_mbm(modem, udev_device);
+ else if (g_strcmp0(driver, "huawei") == 0)
+ add_huawei(modem, udev_device);
}
static void remove_modem(struct udev_device *udev_device)
@@ -186,8 +210,12 @@ static void remove_modem(struct udev_device *udev_device)
if (driver == NULL) {
parent = udev_device_get_parent(parent);
driver = get_driver(parent);
- if (driver == NULL)
- return;
+ if (driver == NULL) {
+ parent = udev_device_get_parent(parent);
+ driver = get_driver(parent);
+ if (driver == NULL)
+ return;
+ }
}
devpath = udev_device_get_devpath(parent);