aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAleksander Morgado <aleksander@lanedo.com>2011-03-30 18:52:23 +0200
committerAleksander Morgado <aleksander@lanedo.com>2011-04-11 10:04:27 +0200
commit262edb96d50138a724173840fc63ca93ede322c2 (patch)
tree921b65eace9c4d3f77de1fe41bbdb4885b3f8685
parentf91ee7af7d6a38eda226afb429b26ffe1408e08f (diff)
wavecom: handle READY without OK in CPIN? reply
-rw-r--r--plugins/mm-modem-wavecom-gsm.c51
-rw-r--r--src/mm-serial-parsers.c3
2 files changed, 48 insertions, 6 deletions
diff --git a/plugins/mm-modem-wavecom-gsm.c b/plugins/mm-modem-wavecom-gsm.c
index b28df078..3e39ffff 100644
--- a/plugins/mm-modem-wavecom-gsm.c
+++ b/plugins/mm-modem-wavecom-gsm.c
@@ -21,11 +21,7 @@
#include <unistd.h>
#include "mm-modem-wavecom-gsm.h"
-#include "mm-errors.h"
-#include "mm-modem-simple.h"
-#include "mm-callback-info.h"
-#include "mm-modem-helpers.h"
-#include "mm-at-serial-port.h"
+#include "mm-serial-parsers.h"
static void modem_init (MMModem *modem_class);
@@ -55,11 +51,56 @@ mm_modem_wavecom_gsm_new (const char *device,
NULL));
}
+
+static gboolean
+grab_port (MMModem *modem,
+ const char *subsys,
+ const char *name,
+ MMPortType suggested_type,
+ gpointer user_data,
+ GError **error)
+{
+ MMGenericGsm *gsm = MM_GENERIC_GSM (modem);
+ MMPortType ptype = MM_PORT_TYPE_IGNORED;
+ MMPort *port = NULL;
+
+ if (suggested_type == MM_PORT_TYPE_UNKNOWN) {
+ if (!mm_generic_gsm_get_at_port (gsm, MM_PORT_TYPE_PRIMARY))
+ ptype = MM_PORT_TYPE_PRIMARY;
+ else if (!mm_generic_gsm_get_at_port (gsm, MM_PORT_TYPE_SECONDARY))
+ ptype = MM_PORT_TYPE_SECONDARY;
+ } else
+ ptype = suggested_type;
+
+ port = mm_generic_gsm_grab_port (gsm, subsys, name, ptype, error);
+ if (port && MM_IS_AT_SERIAL_PORT (port)) {
+ gpointer parser;
+ GRegex *regex;
+
+ parser = mm_serial_parser_v1_new ();
+
+ /* AT+CPIN? replies will never have an OK appended */
+ regex = g_regex_new ("\\r\\n\\+CPIN: .*\\r\\n",
+ G_REGEX_RAW | G_REGEX_OPTIMIZE,
+ 0, NULL);
+ mm_serial_parser_v1_set_custom_regex (parser, regex, NULL);
+ g_regex_unref (regex);
+
+ mm_at_serial_port_set_response_parser (MM_AT_SERIAL_PORT (port),
+ mm_serial_parser_v1_parse,
+ parser,
+ mm_serial_parser_v1_destroy);
+ }
+
+ return !!port;
+}
+
/*****************************************************************************/
static void
modem_init (MMModem *modem_class)
{
+ modem_class->grab_port = grab_port;
}
static void
diff --git a/src/mm-serial-parsers.c b/src/mm-serial-parsers.c
index f6798314..c1d010aa 100644
--- a/src/mm-serial-parsers.c
+++ b/src/mm-serial-parsers.c
@@ -270,10 +270,11 @@ mm_serial_parser_v1_parse (gpointer data,
/* First, check for successful responses */
/* Custom successful replies first, if any */
- if (parser->regex_custom_successful)
+ if (parser->regex_custom_successful) {
found = g_regex_match_full (parser->regex_custom_successful,
response->str, response->len,
0, 0, NULL, NULL);
+ }
if (!found) {
found = g_regex_match_full (parser->regex_ok,