[lttng-dev] [PATCH lttng-tools] Fix: ignore SIGPIPE

Jérémie Galarneau jeremie.galarneau at efficios.com
Fri Oct 7 21:19:29 UTC 2016


Merged, thanks!

Jérémie

On 6 October 2016 at 12:57, Mathieu Desnoyers
<mathieu.desnoyers at efficios.com> wrote:
> Issuing fprintf() to stderr (thus write() to the standard error file
> descriptor) within the SIGPIPE signal handler is bad: it can trigger
> SIGPIPE repeatedly if the listening end has closed its end of the pipe.
>
> Set the SIGPIPE action to SIG_IGN in relayd, sessiond, and consumerd.
>
> This was affecting sessiond and relayd. The consumerd did not print
> anything to stderr.
>
> Signed-off-by: Mathieu Desnoyers <mathieu.desnoyers at efficios.com>
> ---
>  src/bin/lttng-consumerd/lttng-consumerd.c | 12 +++---------
>  src/bin/lttng-relayd/main.c               | 11 +++++------
>  src/bin/lttng-sessiond/main.c             | 11 +++++------
>  3 files changed, 13 insertions(+), 21 deletions(-)
>
> diff --git a/src/bin/lttng-consumerd/lttng-consumerd.c b/src/bin/lttng-consumerd/lttng-consumerd.c
> index 1636b9c..1373a74 100644
> --- a/src/bin/lttng-consumerd/lttng-consumerd.c
> +++ b/src/bin/lttng-consumerd/lttng-consumerd.c
> @@ -99,14 +99,6 @@ static void sighandler(int sig)
>                 return;
>         }
>
> -       /*
> -        * Ignore SIGPIPE because it should not stop the consumer whenever a
> -        * SIGPIPE is caught through a FD operation.
> -        */
> -       if (sig == SIGPIPE) {
> -               return;
> -       }
> -
>         if (ctx) {
>                 lttng_consumer_should_exit(ctx);
>         }
> @@ -127,9 +119,10 @@ static int set_signal_handler(void)
>                 return ret;
>         }
>
> -       sa.sa_handler = sighandler;
>         sa.sa_mask = sigset;
>         sa.sa_flags = 0;
> +
> +       sa.sa_handler = sighandler;
>         if ((ret = sigaction(SIGTERM, &sa, NULL)) < 0) {
>                 PERROR("sigaction");
>                 return ret;
> @@ -140,6 +133,7 @@ static int set_signal_handler(void)
>                 return ret;
>         }
>
> +       sa.sa_handler = SIG_IGN;
>         if ((ret = sigaction(SIGPIPE, &sa, NULL)) < 0) {
>                 PERROR("sigaction");
>                 return ret;
> diff --git a/src/bin/lttng-relayd/main.c b/src/bin/lttng-relayd/main.c
> index e8f3087..ea46ec7 100644
> --- a/src/bin/lttng-relayd/main.c
> +++ b/src/bin/lttng-relayd/main.c
> @@ -582,9 +582,6 @@ int lttng_relay_stop_threads(void)
>  static void sighandler(int sig)
>  {
>         switch (sig) {
> -       case SIGPIPE:
> -               DBG("SIGPIPE caught");
> -               return;
>         case SIGINT:
>                 DBG("SIGINT caught");
>                 if (lttng_relay_stop_threads()) {
> @@ -620,9 +617,10 @@ static int set_signal_handler(void)
>                 return ret;
>         }
>
> -       sa.sa_handler = sighandler;
>         sa.sa_mask = sigset;
>         sa.sa_flags = 0;
> +
> +       sa.sa_handler = sighandler;
>         if ((ret = sigaction(SIGTERM, &sa, NULL)) < 0) {
>                 PERROR("sigaction");
>                 return ret;
> @@ -633,12 +631,13 @@ static int set_signal_handler(void)
>                 return ret;
>         }
>
> -       if ((ret = sigaction(SIGPIPE, &sa, NULL)) < 0) {
> +       if ((ret = sigaction(SIGUSR1, &sa, NULL)) < 0) {
>                 PERROR("sigaction");
>                 return ret;
>         }
>
> -       if ((ret = sigaction(SIGUSR1, &sa, NULL)) < 0) {
> +       sa.sa_handler = SIG_IGN;
> +       if ((ret = sigaction(SIGPIPE, &sa, NULL)) < 0) {
>                 PERROR("sigaction");
>                 return ret;
>         }
> diff --git a/src/bin/lttng-sessiond/main.c b/src/bin/lttng-sessiond/main.c
> index 1964fe0..a2afb8f 100644
> --- a/src/bin/lttng-sessiond/main.c
> +++ b/src/bin/lttng-sessiond/main.c
> @@ -5370,9 +5370,6 @@ error:
>  static void sighandler(int sig)
>  {
>         switch (sig) {
> -       case SIGPIPE:
> -               DBG("SIGPIPE caught");
> -               return;
>         case SIGINT:
>                 DBG("SIGINT caught");
>                 stop_threads();
> @@ -5404,9 +5401,10 @@ static int set_signal_handler(void)
>                 return ret;
>         }
>
> -       sa.sa_handler = sighandler;
>         sa.sa_mask = sigset;
>         sa.sa_flags = 0;
> +
> +       sa.sa_handler = sighandler;
>         if ((ret = sigaction(SIGTERM, &sa, NULL)) < 0) {
>                 PERROR("sigaction");
>                 return ret;
> @@ -5417,12 +5415,13 @@ static int set_signal_handler(void)
>                 return ret;
>         }
>
> -       if ((ret = sigaction(SIGPIPE, &sa, NULL)) < 0) {
> +       if ((ret = sigaction(SIGUSR1, &sa, NULL)) < 0) {
>                 PERROR("sigaction");
>                 return ret;
>         }
>
> -       if ((ret = sigaction(SIGUSR1, &sa, NULL)) < 0) {
> +       sa.sa_handler = SIG_IGN;
> +       if ((ret = sigaction(SIGPIPE, &sa, NULL)) < 0) {
>                 PERROR("sigaction");
>                 return ret;
>         }
> --
> 2.1.4
>



-- 
Jérémie Galarneau
EfficiOS Inc.
http://www.efficios.com


More information about the lttng-dev mailing list