---
 plugins/udevng.c | 92 +++++++++++++++++++++++++++++++++++++++++---------------
 1 file changed, 68 insertions(+), 24 deletions(-)

diff --git a/plugins/udevng.c b/plugins/udevng.c
index ff6e1fc..ee6f9e8 100644
--- a/plugins/udevng.c
+++ b/plugins/udevng.c
@@ -711,8 +711,56 @@ static gboolean setup_telitqmi(struct modem_info *modem)
        return TRUE;
 }
 
-/* TODO: Not used as we have no simcom driver */
-static gboolean setup_simcom(struct modem_info *modem)
+
+static gboolean setup_sim800(struct modem_info *modem)
+{
+       const char *mdm = NULL, *aux = NULL, *gps = NULL, *diag = NULL;
+       GSList *list;
+
+       DBG("%s", modem->syspath);
+
+       for (list = modem->devices; list; list = list->next) {
+               struct device_info *info = list->data;
+
+               DBG("%s %s %s %s", info->devnode, info->interface,
+                                               info->number, info->label);
+
+               if (g_strcmp0(info->label, "aux") == 0) {
+                       DBG("setting aux as info->devnode");
+                       aux = info->devnode;
+                       if (mdm != NULL)
+                               break;
+               } else if (g_strcmp0(info->label, "modem") == 0) {
+                       mdm = info->devnode;
+                       if (aux != NULL)
+                               break;
+               } else if (g_strcmp0(info->interface, "255/0/0") == 0) {
+                       if (g_strcmp0(info->number, "00") == 0)
+                               mdm = info->devnode;
+                       else if (g_strcmp0(info->number, "01") == 0)
+                               gps = info->devnode;
+                       else if (g_strcmp0(info->number, "02") == 0)
+                               aux = info->devnode;
+                       else if (g_strcmp0(info->number, "03") == 0)
+                               mdm = info->devnode;
+               }
+       }
+       DBG("modem=%s aux=%s gps=%s diag=%s", mdm, aux, gps, diag);
+
+       if (mdm == NULL) {
+               DBG("modem did not set up");
+               return FALSE;
+       }
+
+       ofono_modem_set_string(modem->modem, "Device", mdm);
+       ofono_modem_set_string(modem->modem, "Modem", mdm);
+
+       return TRUE;
+}
+
+
+
+static gboolean setup_sim900(struct modem_info *modem)
 {
        const char *mdm = NULL, *aux = NULL, *gps = NULL, *diag = NULL;
        GSList *list;
@@ -962,6 +1010,8 @@ static gboolean setup_mbim(struct modem_info *modem)
        ofono_modem_set_string(modem->modem, "Device", ctl);
        ofono_modem_set_string(modem->modem, "NetworkInterface", net);
        ofono_modem_set_string(modem->modem, "DescriptorFile", descriptors);
+       ofono_modem_set_string(modem->modem, "Vendor", modem->vendor);
+       ofono_modem_set_string(modem->modem, "Model", modem->model);
 
        return TRUE;
 }
@@ -1193,22 +1243,12 @@ static gboolean setup_xmm7xxx(struct modem_info *modem)
                                info->interface, info->number, info->label,
                                info->sysattr, info->subsystem);
 
-               if (g_strcmp0(modem->model,"095a") == 0) {
-                       if (g_strcmp0(info->subsystem, "tty") == 0) {
-                               if (g_strcmp0(info->number, "00") == 0)
-                                       mdm = info->devnode;
-                       } else if (g_strcmp0(info->subsystem, "net") == 0) {
-                               if (g_strcmp0(info->number, "06") == 0)
-                                       net = info->devnode;
-                       }
-               } else {
-                       if (g_strcmp0(info->subsystem, "tty") == 0) {
-                               if (g_strcmp0(info->number, "02") == 0)
-                                       mdm = info->devnode;
-                       } else if (g_strcmp0(info->subsystem, "net") == 0) {
-                               if (g_strcmp0(info->number, "00") == 0)
-                                       net = info->devnode;
-                       }
+               if (g_strcmp0(info->subsystem, "tty") == 0) {
+                       if (g_strcmp0(info->number, "02") == 0)
+                               mdm = info->devnode;
+               } else if (g_strcmp0(info->subsystem, "net") == 0) {
+                       if (g_strcmp0(info->number, "00") == 0)
+                               net = info->devnode;
                }
        }
 
@@ -1290,7 +1330,8 @@ static struct {
        { "nokia",      setup_nokia     },
        { "telit",      setup_telit,    "device/interface"      },
        { "telitqmi",   setup_telitqmi  },
-       { "simcom",     setup_simcom    },
+       { "sim800",     setup_sim800    },
+       { "sim900",     setup_sim900    },
        { "sim7100",    setup_sim7100   },
        { "zte",        setup_zte       },
        { "icera",      setup_icera     },
@@ -1308,7 +1349,9 @@ static struct {
        { "calypso",    setup_serial_modem      },
        { "cinterion",  setup_serial_modem      },
        { "nokiacdma",  setup_serial_modem      },
+       { "sim800",     setup_serial_modem      },
        { "sim900",     setup_serial_modem      },
+       { "sim800",     setup_serial_modem      },
        { "wavecom",    setup_wavecom           },
        { "tc65",       setup_tc65              },
        { "ehs6",       setup_ehs6              },
@@ -1471,7 +1514,7 @@ static void add_serial_device(struct udev_device *dev)
        const char *subsystem;
        struct udev_device* mdev;
        const char* driver;
-
+       DBG("adding %s interface", udev_device_get_devpath(dev));
        mdev = get_serial_modem_device(dev);
        if (!mdev) {
                DBG("Device is missing required OFONO_DRIVER property");
@@ -1663,7 +1706,8 @@ static struct {
        { "alcatel",    "option",       "1bbb", "0017"  },
        { "novatel",    "option",       "1410"          },
        { "zte",        "option",       "19d2"          },
-       { "simcom",     "option",       "05c6", "9000"  },
+       { "sim800",     "option",       "05c6", "9000"  },
+       { "sim900",     "option",       "05c6", "9000"  },
        { "sim7100",    "option",       "1e0e", "9001"  },
        { "telit",      "usbserial",    "1bc7"          },
        { "telit",      "option",       "1bc7"          },
@@ -1693,7 +1737,6 @@ static struct {
        { "xmm7xxx",    "cdc_ncm",      "8087"          },
        { }
 };
-
 static void check_usb_device(struct udev_device *device)
 {
        struct udev_device *usb_device;
@@ -1722,9 +1765,10 @@ static void check_usb_device(struct udev_device *device)
                        udev_device_get_parent_with_subsystem_devtype(
                                device, "usb", "usb_interface");
 
-               if (usb_interface)
+               if (usb_interface) {
                        driver = udev_device_get_property_value(
                                        usb_interface, "OFONO_DRIVER");
+               }
        }
 
        if (driver == NULL) {
@@ -1801,7 +1845,7 @@ static gboolean create_modem(gpointer key, gpointer 
value, gpointer user_data)
        struct modem_info *modem = value;
        const char *syspath = key;
        unsigned int i;
-
+       DBG("");
        if (modem->modem != NULL)
                return FALSE;
 
-- 
2.7.4

_______________________________________________
ofono mailing list
[email protected]
https://lists.ofono.org/mailman/listinfo/ofono

Reply via email to