summaryrefslogtreecommitdiffstats
path: root/plugins/mbm.c
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/mbm.c')
-rw-r--r--plugins/mbm.c49
1 files changed, 29 insertions, 20 deletions
diff --git a/plugins/mbm.c b/plugins/mbm.c
index 09176a69..5fbb3a42 100644
--- a/plugins/mbm.c
+++ b/plugins/mbm.c
@@ -38,8 +38,6 @@
#include <ofono/sms.h>
#include <ofono/log.h>
-#include "chat.h"
-
struct mbm_data {
GAtChat *chat;
};
@@ -75,37 +73,47 @@ static void mbm_debug(const char *str, void *user_data)
ofono_info("%s", str);
}
-static void connect_callback(GAtChat *chat, gpointer user_data)
+static void cfun_enable(gboolean ok, GAtResult *result, gpointer user_data)
{
struct ofono_modem *modem = user_data;
+
+ DBG("");
+
+ if (ok)
+ ofono_modem_set_powered(modem, TRUE);
+}
+
+static int mbm_enable(struct ofono_modem *modem)
+{
struct mbm_data *data = ofono_modem_get_data(modem);
+ GAtSyntax *syntax;
- if (!chat) {
- ofono_modem_set_powered(modem, FALSE);
- return;
- }
+ DBG("%p", modem);
- data->chat = g_at_chat_ref(chat);
+ syntax = g_at_syntax_new_gsmv1();
+ data->chat = g_at_chat_new_from_tty("/dev/ttyACM0", syntax);
+ g_at_syntax_unref(syntax);
+
+ if (!data->chat)
+ return -EIO;
if (getenv("OFONO_AT_DEBUG"))
g_at_chat_set_debug(data->chat, mbm_debug, NULL);
- ofono_modem_set_powered(modem, TRUE);
+ g_at_chat_send(data->chat, "AT+CFUN=1", NULL,
+ cfun_enable, modem, NULL);
- g_at_chat_send(data->chat, "AT+CFUN=1", NULL, NULL, NULL, NULL);
+ return 0;
}
-static int mbm_enable(struct ofono_modem *modem)
+static void cfun_disable(gboolean ok, GAtResult *result, gpointer user_data)
{
- int err;
-
- DBG("%p", modem);
+ struct ofono_modem *modem = user_data;
- err = chat_connect("/dev/ttyACM0", connect_callback, modem);
- if (err < 0)
- return err;
+ DBG("");
- return -EINPROGRESS;
+ if (ok)
+ ofono_modem_set_powered(modem, FALSE);
}
static int mbm_disable(struct ofono_modem *modem)
@@ -117,9 +125,10 @@ static int mbm_disable(struct ofono_modem *modem)
if (!data->chat)
return 0;
- g_at_chat_shutdown(data->chat);
+ g_at_chat_send(data->chat, "AT+CFUN=0", NULL,
+ cfun_disable, modem, NULL);
- chat_disconnect(data->chat);
+ g_at_chat_shutdown(data->chat);
g_at_chat_unref(data->chat);
data->chat = NULL;