diff options
author | Bob Ham <bob.ham@puri.sm> | 2018-04-30 13:56:06 +0000 |
---|---|---|
committer | Denis Kenzior <denkenz@gmail.com> | 2018-04-30 11:17:47 -0500 |
commit | 1d63b1d35f8e650ab050b5ea29d9b9dca42bb178 (patch) | |
tree | edaff525252411675bdb450fe14c25bf7ab198b4 /plugins/udevng.c | |
parent | 3cb55b65cb6c1f44228cf0f0a040d10c99ba1054 (diff) | |
download | ofono-1d63b1d35f8e650ab050b5ea29d9b9dca42bb178.tar.gz |
plugins: Add support for SIM7100E by SIMCom
Add support for the SIM7100E modem. We add a new "sim7100" plugin
because there's no other AT-based modem that has support for both GPRS
and voice calls.
Diffstat (limited to 'plugins/udevng.c')
-rw-r--r-- | plugins/udevng.c | 56 |
1 files changed, 53 insertions, 3 deletions
diff --git a/plugins/udevng.c b/plugins/udevng.c index ff5d41af..cd56fd56 100644 --- a/plugins/udevng.c +++ b/plugins/udevng.c @@ -710,7 +710,7 @@ static gboolean setup_telitqmi(struct modem_info *modem) return TRUE; } -static gboolean setup_simcom(struct modem_info *modem) +static gboolean setup_sim900(struct modem_info *modem) { const char *mdm = NULL, *aux = NULL, *gps = NULL, *diag = NULL; GSList *list; @@ -1213,6 +1213,54 @@ static gboolean setup_xmm7xxx(struct modem_info *modem) return TRUE; } +static gboolean setup_sim7100(struct modem_info *modem) +{ + const char *at = NULL, *ppp = NULL, *gps = NULL, *diag = NULL, *audio = NULL; + GSList *list; + + DBG("%s", modem->syspath); + + for (list = modem->devices; list; list = list->next) { + struct device_info *info = list->data; + + DBG("%s %s", info->devnode, info->number); + + /* + * Serial port layout: + * 0: QCDM/DIAG + * 1: NMEA + * 2: AT + * 3: AT/PPP + * 4: audio + * + * -- https://www.spinics.net/lists/linux-usb/msg135728.html + */ + if (g_strcmp0(info->number, "00") == 0) + diag = info->devnode; + else if (g_strcmp0(info->number, "01") == 0) + gps = info->devnode; + else if (g_strcmp0(info->number, "02") == 0) + at = info->devnode; + else if (g_strcmp0(info->number, "03") == 0) + ppp = info->devnode; + else if (g_strcmp0(info->number, "04") == 0) + audio = info->devnode; + } + + if (at == NULL) + return FALSE; + + DBG("at=%s ppp=%s gps=%s diag=%s, audio=%s", at, ppp, gps, diag, audio); + + ofono_modem_set_string(modem->modem, "AT", at); + ofono_modem_set_string(modem->modem, "PPP", ppp); + ofono_modem_set_string(modem->modem, "GPS", gps); + ofono_modem_set_string(modem->modem, "Diag", diag); + ofono_modem_set_string(modem->modem, "Audio", audio); + + return TRUE; +} + static struct { const char *name; gboolean (*setup)(struct modem_info *modem); @@ -1232,7 +1280,8 @@ static struct { { "nokia", setup_nokia }, { "telit", setup_telit, "device/interface" }, { "telitqmi", setup_telitqmi }, - { "simcom", setup_simcom }, + { "sim900", setup_sim900 }, + { "sim7100", setup_sim7100 }, { "zte", setup_zte }, { "icera", setup_icera }, { "samsung", setup_samsung }, @@ -1596,7 +1645,8 @@ static struct { { "alcatel", "option", "1bbb", "0017" }, { "novatel", "option", "1410" }, { "zte", "option", "19d2" }, - { "simcom", "option", "05c6", "9000" }, + { "sim900", "option", "05c6", "9000" }, + { "sim7100", "option", "1e0e", "9001" }, { "telit", "usbserial", "1bc7" }, { "telit", "option", "1bc7" }, { "telit", "cdc_acm", "1bc7", "0021" }, |