udev: Add support for Sierra device detection

This commit is contained in:
Marcel Holtmann 2011-01-10 23:12:12 -08:00
parent c415ab9e69
commit 1cf3b640fe
2 changed files with 42 additions and 0 deletions

View File

@ -10,6 +10,9 @@ SUBSYSTEMS=="usb", ATTRS{bInterfaceNumber}=="?*", ATTRS{bInterfaceClass}=="ff",
# Qualcomm Gobi 2000 (Lenovo)
ATTRS{idVendor}=="05c6", ATTRS{idProduct}=="9205", ENV{OFONO_IFACE_NUM}=="02", ENV{OFONO_GOBI_TYPE}="modem"
# Sierra Wireless HSPA Modem
ATTRS{idVendor}=="1199", ATTRS{idProduct}=="6880", ENV{OFONO_IFACE_NUM}=="03", ENV{OFONO_SIERRA_TYPE}="modem"
ATTRS{idVendor}=="19d2", ATTRS{idProduct}=="0031", ENV{OFONO_IFACE_NUM}=="03", ENV{OFONO_ZTE_TYPE}="modem"
ATTRS{idVendor}=="19d2", ATTRS{idProduct}=="0031", ENV{OFONO_IFACE_NUM}=="01", ENV{OFONO_ZTE_TYPE}="aux"
@ -360,6 +363,11 @@ ENV{DEVTYPE}!="usb_device", GOTO="ofono_end"
# Novatel Wireless
ATTRS{idVendor}=="1410", ENV{OFONO_DRIVER}="novatel"
# Sierra Wireless
ATTRS{idVendor}=="1199", ENV{OFONO_DRIVER}="sierra"
ATTRS{idVendor}=="1199", ATTRS{serial}=="1234567890ABCDEF", ENV{ID_SERIAL_SHORT}=""
# HUAWEI Technology
ATTRS{idVendor}=="12d1", ENV{OFONO_DRIVER}="huawei"

View File

@ -359,6 +359,38 @@ static void add_huawei(struct ofono_modem *modem,
ofono_modem_register(modem);
}
static void add_sierra(struct ofono_modem *modem,
struct udev_device *udev_device)
{
struct udev_list_entry *entry;
const char *devnode;
gboolean found = FALSE;
DBG("modem %p", modem);
entry = udev_device_get_properties_list_entry(udev_device);
while (entry) {
const char *name = udev_list_entry_get_name(entry);
const char *value = udev_list_entry_get_value(entry);
if (g_str_equal(name, "OFONO_SIERRA_TYPE") == TRUE &&
g_str_equal(value, "modem") == TRUE) {
found = TRUE;
break;
}
entry = udev_list_entry_get_next(entry);
}
if (found == FALSE)
return;
devnode = udev_device_get_devnode(udev_device);
ofono_modem_set_string(modem, "Device", devnode);
ofono_modem_register(modem);
}
static void add_novatel(struct ofono_modem *modem,
struct udev_device *udev_device)
{
@ -583,6 +615,8 @@ done:
add_zte(modem, udev_device);
else if (g_strcmp0(driver, "huawei") == 0)
add_huawei(modem, udev_device);
else if (g_strcmp0(driver, "sierra") == 0)
add_sierra(modem, udev_device);
else if (g_strcmp0(driver, "novatel") == 0)
add_novatel(modem, udev_device);
else if (g_strcmp0(driver, "nokia") == 0)