All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] gatmux: fix channel remove on error.
@ 2016-10-04  7:42 Antoine Aubert
  2016-10-05  3:16 ` Denis Kenzior
  0 siblings, 1 reply; 4+ messages in thread
From: Antoine Aubert @ 2016-10-04  7:42 UTC (permalink / raw)
  To: ofono

[-- Attachment #1: Type: text/plain, Size: 1232 bytes --]

In case of invalid IO, read_watch is not reset. Fix crash on destroy
gatmux.

Signed-off-by: Antoine Aubert <a.aubert@overkiz.com>
---
 gatchat/gatmux.c | 16 ++++++++++++----
 1 file changed, 12 insertions(+), 4 deletions(-)

diff --git a/gatchat/gatmux.c b/gatchat/gatmux.c
index 9beeece..896ddff 100644
--- a/gatchat/gatmux.c
+++ b/gatchat/gatmux.c
@@ -186,8 +186,10 @@ static gboolean received_data(GIOChannel *channel, GIOCondition cond,
 	GIOStatus status;
 	gsize bytes_read;
 
-	if (cond & G_IO_NVAL)
+	if (cond & G_IO_NVAL) {
+		mux->read_watch = 0;
 		return FALSE;
+	}
 
 	debug(mux, "received data");
 
@@ -223,14 +225,20 @@ static gboolean received_data(GIOChannel *channel, GIOCondition cond,
 		}
 	}
 
-	if (cond & (G_IO_HUP | G_IO_ERR))
+	if (cond & (G_IO_HUP | G_IO_ERR)) {
+		mux->read_watch = 0;
 		return FALSE;
+	}
 
-	if (status != G_IO_STATUS_NORMAL && status != G_IO_STATUS_AGAIN)
+	if (status != G_IO_STATUS_NORMAL && status != G_IO_STATUS_AGAIN) {
+		mux->read_watch = 0;
 		return FALSE;
+	}
 
-	if (mux->buf_used == sizeof(mux->buf))
+	if (mux->buf_used == sizeof(mux->buf)) {
+		mux->read_watch = 0;
 		return FALSE;
+	}
 
 	return TRUE;
 }
-- 
2.7.4


[-- Attachment #2: attachment.html --]
[-- Type: text/html, Size: 1489 bytes --]

^ permalink raw reply related	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2016-10-05 18:04 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2016-10-04  7:42 [PATCH] gatmux: fix channel remove on error Antoine Aubert
2016-10-05  3:16 ` Denis Kenzior
2016-10-05  6:42   ` [PATCH] gatmux: fix read " Antoine Aubert
2016-10-05 18:04     ` Denis Kenzior

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.