linux-bluetooth.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH BlueZ] core: Catch SIGPIPE
@ 2018-11-17  6:00 Gal Ben-Haim
  2018-11-17 20:41 ` Gal Ben Haim
  0 siblings, 1 reply; 7+ messages in thread
From: Gal Ben-Haim @ 2018-11-17  6:00 UTC (permalink / raw)
  To: linux-bluetooth; +Cc: Gal Ben-Haim

bluetoothd receives a SIGPIPE and terminates if writing to a pipe that
was acquired by AcquireNotify and there are no readers. it can be
reproduced by terminating the reader process without closing the reader
end of the pipe.

Catching SIGPIPE will cause the write call to return an EPIPE error
which will be logged as "io_send: Broken pipe".
---
 src/main.c | 3 +++
 1 file changed, 3 insertions(+)

diff --git a/src/main.c b/src/main.c
index 4716f5388..54cdb8d3f 100644
--- a/src/main.c
+++ b/src/main.c
@@ -533,6 +533,8 @@ static gboolean signal_handler(GIOChannel *channel, GIOCondition cond,
 	case SIGUSR2:
 		__btd_toggle_debug();
 		break;
+	case SIGPIPE:
+		break;
 	}
 
 	return TRUE;
@@ -549,6 +551,7 @@ static guint setup_signalfd(void)
 	sigaddset(&mask, SIGINT);
 	sigaddset(&mask, SIGTERM);
 	sigaddset(&mask, SIGUSR2);
+	sigaddset(&mask, SIGPIPE);
 
 	if (sigprocmask(SIG_BLOCK, &mask, NULL) < 0) {
 		perror("Failed to set signal mask");
-- 
2.19.1


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

end of thread, other threads:[~2018-11-19 13:27 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2018-11-17  6:00 [PATCH BlueZ] core: Catch SIGPIPE Gal Ben-Haim
2018-11-17 20:41 ` Gal Ben Haim
2018-11-17 20:47   ` Gal Ben Haim
2018-11-19  9:22     ` Luiz Augusto von Dentz
2018-11-19  9:47       ` Gal Ben Haim
2018-11-19 10:59         ` Luiz Augusto von Dentz
2018-11-19 13:27       ` Marcel Holtmann

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).