From 3e16ebf1750bdef54975919ec6bf087b01e1351e Mon Sep 17 00:00:00 2001 From: Denis Kenzior Date: Wed, 15 Jul 2009 11:45:17 -0500 Subject: [PATCH] Fix modem wakeup handling --- gatchat/gatchat.c | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/gatchat/gatchat.c b/gatchat/gatchat.c index 32f0b59..dfd60d5 100644 --- a/gatchat/gatchat.c +++ b/gatchat/gatchat.c @@ -765,6 +765,14 @@ static gboolean received_data(GIOChannel *channel, GIOCondition cond, static gboolean wakeup_no_response(gpointer user) { GAtChat *chat = user; + struct at_command *cmd = g_queue_peek_head(chat->command_queue); + + /* Sometimes during startup the modem is still in the ready state + * and might acknowledge our 'wakeup' command. In that case don't + * timeout the wrong command + */ + if (cmd == NULL || cmd->id != 0) + return FALSE; g_at_chat_finish_command(chat, FALSE, NULL); -- 2.7.4