* [PATCH 2/2] cgroups: fix cgroup_event_listener error handling [not found] ` <1357333518-28899-1-git-send-email-gthelen-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org> @ 2013-01-04 21:05 ` Greg Thelen 2013-01-07 17:42 ` [PATCH 1/2] cgroups: move cgroup_event_listener.c to tools/cgroup Tejun Heo 1 sibling, 0 replies; 6+ messages in thread From: Greg Thelen @ 2013-01-04 21:05 UTC (permalink / raw) To: Tejun Heo, Li Zefan Cc: cgroups-u79uwXL29TY76Z2rM5mHXA, containers-cunTk1MwBs9QetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA, linux-kernel-u79uwXL29TY76Z2rM5mHXA, linux-doc-u79uwXL29TY76Z2rM5mHXA If the <absolute-path-to-control-file> command line parameter cannot be opened, then cgroup_event_listener prints an error message and tries to return an error. However, due to an uninitialized variable the return value was undefined. With this patch such failures always return non-zero error. Compiler warning found this: $ gcc -Wall -O2 cgroup_event_listener.c cgroup_event_listener.c: In function ‘main’: cgroup_event_listener.c:109:2: warning: ‘ret’ may be used uninitialized in this function [-Wuninitialized] Signed-off-by: Greg Thelen <gthelen@google.com> --- tools/cgroup/cgroup_event_listener.c | 2 +- 1 files changed, 1 insertions(+), 1 deletions(-) diff --git a/tools/cgroup/cgroup_event_listener.c b/tools/cgroup/cgroup_event_listener.c index 3e082f9..a70f00c 100644 --- a/tools/cgroup/cgroup_event_listener.c +++ b/tools/cgroup/cgroup_event_listener.c @@ -35,7 +35,7 @@ int main(int argc, char **argv) if (cfd == -1) { fprintf(stderr, "Cannot open %s: %s\n", argv[1], strerror(errno)); - goto out; + return 1; } ret = snprintf(event_control_path, PATH_MAX, "%s/cgroup.event_control", -- 1.7.7.3 _______________________________________________ Containers mailing list Containers@lists.linux-foundation.org https://lists.linuxfoundation.org/mailman/listinfo/containers ^ permalink raw reply related [flat|nested] 6+ messages in thread
* Re: [PATCH 1/2] cgroups: move cgroup_event_listener.c to tools/cgroup [not found] ` <1357333518-28899-1-git-send-email-gthelen-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org> 2013-01-04 21:05 ` [PATCH 2/2] cgroups: fix cgroup_event_listener error handling Greg Thelen @ 2013-01-07 17:42 ` Tejun Heo 1 sibling, 0 replies; 6+ messages in thread From: Tejun Heo @ 2013-01-07 17:42 UTC (permalink / raw) To: Greg Thelen Cc: cgroups-u79uwXL29TY76Z2rM5mHXA, containers-cunTk1MwBs9QetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA, linux-kernel-u79uwXL29TY76Z2rM5mHXA, linux-doc-u79uwXL29TY76Z2rM5mHXA On Fri, Jan 04, 2013 at 01:05:17PM -0800, Greg Thelen wrote: > Move the cgroup_event_listener.c tool from Documentation into the new > tools/cgroup directory. > > This change involves wiring cgroup_event_listener.c into the tools/ > make system so that is can be built with: > $ make tools/cgroup > > Signed-off-by: Greg Thelen <gthelen-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org> Applied to cgroup/for-3.9. Thanks. -- tejun ^ permalink raw reply [flat|nested] 6+ messages in thread
[parent not found: <1357333518-28899-2-git-send-email-gthelen@google.com>]
[parent not found: <1357333518-28899-2-git-send-email-gthelen-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org>]
* Re: [PATCH 2/2] cgroups: fix cgroup_event_listener error handling [not found] ` <1357333518-28899-2-git-send-email-gthelen-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org> @ 2013-01-07 17:44 ` Tejun Heo 0 siblings, 0 replies; 6+ messages in thread From: Tejun Heo @ 2013-01-07 17:44 UTC (permalink / raw) To: Greg Thelen Cc: cgroups-u79uwXL29TY76Z2rM5mHXA, containers-cunTk1MwBs9QetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA, linux-kernel-u79uwXL29TY76Z2rM5mHXA, linux-doc-u79uwXL29TY76Z2rM5mHXA On Fri, Jan 04, 2013 at 01:05:18PM -0800, Greg Thelen wrote: > If the <absolute-path-to-control-file> command line parameter cannot > be opened, then cgroup_event_listener prints an error message and > tries to return an error. However, due to an uninitialized variable > the return value was undefined. > > With this patch such failures always return non-zero error. > > Compiler warning found this: > $ gcc -Wall -O2 cgroup_event_listener.c > cgroup_event_listener.c: In function ‘main’: > cgroup_event_listener.c:109:2: warning: ‘ret’ may be used uninitialized in this function [-Wuninitialized] > > Signed-off-by: Greg Thelen <gthelen@google.com> > --- > tools/cgroup/cgroup_event_listener.c | 2 +- > 1 files changed, 1 insertions(+), 1 deletions(-) > > diff --git a/tools/cgroup/cgroup_event_listener.c b/tools/cgroup/cgroup_event_listener.c > index 3e082f9..a70f00c 100644 > --- a/tools/cgroup/cgroup_event_listener.c > +++ b/tools/cgroup/cgroup_event_listener.c > @@ -35,7 +35,7 @@ int main(int argc, char **argv) > if (cfd == -1) { > fprintf(stderr, "Cannot open %s: %s\n", argv[1], > strerror(errno)); > - goto out; > + return 1; Hmm... so, event_control open failure path is broken the same way. Can you please fix it together? Please just remove the cleanup path. Thanks. -- tejun _______________________________________________ Containers mailing list Containers@lists.linux-foundation.org https://lists.linuxfoundation.org/mailman/listinfo/containers ^ permalink raw reply [flat|nested] 6+ messages in thread
[parent not found: <20130107174427.GM3926@htj.dyndns.org>]
[parent not found: <20130107174427.GM3926-Gd/HAXX7CRxy/B6EtB590w@public.gmane.org>]
* Re: [PATCH 2/2] cgroups: fix cgroup_event_listener error handling [not found] ` <20130107174427.GM3926-Gd/HAXX7CRxy/B6EtB590w@public.gmane.org> @ 2013-01-07 19:50 ` Greg Thelen [not found] ` <xr93a9sklqme.fsf-aSPv4SP+Du0KgorLzL7FmE7CuiCeIGUxQQ4Iyu8u01E@public.gmane.org> 0 siblings, 1 reply; 6+ messages in thread From: Greg Thelen @ 2013-01-07 19:50 UTC (permalink / raw) To: Tejun Heo Cc: cgroups-u79uwXL29TY76Z2rM5mHXA, containers-cunTk1MwBs9QetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA, linux-kernel-u79uwXL29TY76Z2rM5mHXA, linux-doc-u79uwXL29TY76Z2rM5mHXA On Mon, Jan 07 2013, Tejun Heo wrote: > On Fri, Jan 04, 2013 at 01:05:18PM -0800, Greg Thelen wrote: >> If the <absolute-path-to-control-file> command line parameter cannot >> be opened, then cgroup_event_listener prints an error message and >> tries to return an error. However, due to an uninitialized variable >> the return value was undefined. >> >> With this patch such failures always return non-zero error. >> >> Compiler warning found this: >> $ gcc -Wall -O2 cgroup_event_listener.c >> cgroup_event_listener.c: In function ‘main’: >> cgroup_event_listener.c:109:2: warning: ‘ret’ may be used uninitialized in this function [-Wuninitialized] >> >> Signed-off-by: Greg Thelen <gthelen@google.com> >> --- >> tools/cgroup/cgroup_event_listener.c | 2 +- >> 1 files changed, 1 insertions(+), 1 deletions(-) >> >> diff --git a/tools/cgroup/cgroup_event_listener.c b/tools/cgroup/cgroup_event_listener.c >> index 3e082f9..a70f00c 100644 >> --- a/tools/cgroup/cgroup_event_listener.c >> +++ b/tools/cgroup/cgroup_event_listener.c >> @@ -35,7 +35,7 @@ int main(int argc, char **argv) >> if (cfd == -1) { >> fprintf(stderr, "Cannot open %s: %s\n", argv[1], >> strerror(errno)); >> - goto out; >> + return 1; > > Hmm... so, event_control open failure path is broken the same way. > Can you please fix it together? Please just remove the cleanup path. Done. Patch below. ---8<--- cgroups: fix cgroup_event_listener error handling The error handling in cgroup_event_listener.c did not correctly deal with either an error opening either <control_file> or cgroup.event_control. Due to an uninitialized variable the program exit code was undefined if either of these opens failed. This patch simplifies and corrects cgroup_event_listener.c error handling by: 1. using err*() rather than printf(),exit() 2. depending on process exit to close open files With this patch failures always return non-zero error. Signed-off-by: Greg Thelen <gthelen@google.com> --- tools/cgroup/cgroup_event_listener.c | 72 ++++++++++----------------------- 1 files changed, 22 insertions(+), 50 deletions(-) diff --git a/tools/cgroup/cgroup_event_listener.c b/tools/cgroup/cgroup_event_listener.c index 3e082f9..4eb5507 100644 --- a/tools/cgroup/cgroup_event_listener.c +++ b/tools/cgroup/cgroup_event_listener.c @@ -5,6 +5,7 @@ */ #include <assert.h> +#include <err.h> #include <errno.h> #include <fcntl.h> #include <libgen.h> @@ -15,7 +16,7 @@ #include <sys/eventfd.h> -#define USAGE_STR "Usage: cgroup_event_listener <path-to-control-file> <args>\n" +#define USAGE_STR "Usage: cgroup_event_listener <path-to-control-file> <args>" int main(int argc, char **argv) { @@ -26,49 +27,33 @@ int main(int argc, char **argv) char line[LINE_MAX]; int ret; - if (argc != 3) { - fputs(USAGE_STR, stderr); - return 1; - } + if (argc != 3) + errx(1, "%s", USAGE_STR); cfd = open(argv[1], O_RDONLY); - if (cfd == -1) { - fprintf(stderr, "Cannot open %s: %s\n", argv[1], - strerror(errno)); - goto out; - } + if (cfd == -1) + err(1, "Cannot open %s", argv[1]); ret = snprintf(event_control_path, PATH_MAX, "%s/cgroup.event_control", dirname(argv[1])); - if (ret >= PATH_MAX) { - fputs("Path to cgroup.event_control is too long\n", stderr); - goto out; - } + if (ret >= PATH_MAX) + errx(1, "Path to cgroup.event_control is too long"); event_control = open(event_control_path, O_WRONLY); - if (event_control == -1) { - fprintf(stderr, "Cannot open %s: %s\n", event_control_path, - strerror(errno)); - goto out; - } + if (event_control == -1) + err(1, "Cannot open %s", event_control_path); efd = eventfd(0, 0); - if (efd == -1) { - perror("eventfd() failed"); - goto out; - } + if (efd == -1) + err(1, "eventfd() failed"); ret = snprintf(line, LINE_MAX, "%d %d %s", efd, cfd, argv[2]); - if (ret >= LINE_MAX) { - fputs("Arguments string is too long\n", stderr); - goto out; - } + if (ret >= LINE_MAX) + errx(1, "Arguments string is too long"); ret = write(event_control, line, strlen(line) + 1); - if (ret == -1) { - perror("Cannot write to cgroup.event_control"); - goto out; - } + if (ret == -1) + err(1, "Cannot write to cgroup.event_control"); while (1) { uint64_t result; @@ -77,34 +62,21 @@ int main(int argc, char **argv) if (ret == -1) { if (errno == EINTR) continue; - perror("Cannot read from eventfd"); - break; + err(1, "Cannot read from eventfd"); } assert(ret == sizeof(result)); ret = access(event_control_path, W_OK); if ((ret == -1) && (errno == ENOENT)) { - puts("The cgroup seems to have removed."); - ret = 0; - break; - } - - if (ret == -1) { - perror("cgroup.event_control " - "is not accessible any more"); + puts("The cgroup seems to have removed."); break; } + if (ret == -1) + err(1, "cgroup.event_control is not accessible any more"); + printf("%s %s: crossed\n", argv[1], argv[2]); } -out: - if (efd >= 0) - close(efd); - if (event_control >= 0) - close(event_control); - if (cfd >= 0) - close(cfd); - - return (ret != 0); + return 0; } -- 1.7.7.3 _______________________________________________ Containers mailing list Containers@lists.linux-foundation.org https://lists.linuxfoundation.org/mailman/listinfo/containers ^ permalink raw reply related [flat|nested] 6+ messages in thread
[parent not found: <xr93a9sklqme.fsf-aSPv4SP+Du0KgorLzL7FmE7CuiCeIGUxQQ4Iyu8u01E@public.gmane.org>]
* Re: [PATCH 2/2] cgroups: fix cgroup_event_listener error handling [not found] ` <xr93a9sklqme.fsf-aSPv4SP+Du0KgorLzL7FmE7CuiCeIGUxQQ4Iyu8u01E@public.gmane.org> @ 2013-01-08 6:28 ` Li Zefan [not found] ` <50EBBC9C.7060909-hv44wF8Li93QT0dZR+AlfA@public.gmane.org> 0 siblings, 1 reply; 6+ messages in thread From: Li Zefan @ 2013-01-08 6:28 UTC (permalink / raw) To: Greg Thelen Cc: Tejun Heo, cgroups-u79uwXL29TY76Z2rM5mHXA, containers-cunTk1MwBs9QetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA, linux-kernel-u79uwXL29TY76Z2rM5mHXA, linux-doc-u79uwXL29TY76Z2rM5mHXA > cgroups: fix cgroup_event_listener error handling > > The error handling in cgroup_event_listener.c did not correctly deal > with either an error opening either <control_file> or > cgroup.event_control. Due to an uninitialized variable the program > exit code was undefined if either of these opens failed. > > This patch simplifies and corrects cgroup_event_listener.c error > handling by: > 1. using err*() rather than printf(),exit() > 2. depending on process exit to close open files > > With this patch failures always return non-zero error. > > Signed-off-by: Greg Thelen <gthelen-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org> Acked-by: Li Zefan <lizefan-hv44wF8Li93QT0dZR+AlfA@public.gmane.org> > --- > tools/cgroup/cgroup_event_listener.c | 72 ++++++++++----------------------- > 1 files changed, 22 insertions(+), 50 deletions(-) ^ permalink raw reply [flat|nested] 6+ messages in thread
[parent not found: <50EBBC9C.7060909-hv44wF8Li93QT0dZR+AlfA@public.gmane.org>]
* Re: [PATCH 2/2] cgroups: fix cgroup_event_listener error handling [not found] ` <50EBBC9C.7060909-hv44wF8Li93QT0dZR+AlfA@public.gmane.org> @ 2013-01-08 18:08 ` Tejun Heo 0 siblings, 0 replies; 6+ messages in thread From: Tejun Heo @ 2013-01-08 18:08 UTC (permalink / raw) To: Li Zefan Cc: containers-cunTk1MwBs9QetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA, linux-doc-u79uwXL29TY76Z2rM5mHXA, linux-kernel-u79uwXL29TY76Z2rM5mHXA, cgroups-u79uwXL29TY76Z2rM5mHXA On Tue, Jan 08, 2013 at 02:28:44PM +0800, Li Zefan wrote: > > cgroups: fix cgroup_event_listener error handling > > > > The error handling in cgroup_event_listener.c did not correctly deal > > with either an error opening either <control_file> or > > cgroup.event_control. Due to an uninitialized variable the program > > exit code was undefined if either of these opens failed. > > > > This patch simplifies and corrects cgroup_event_listener.c error > > handling by: > > 1. using err*() rather than printf(),exit() > > 2. depending on process exit to close open files > > > > With this patch failures always return non-zero error. > > > > Signed-off-by: Greg Thelen <gthelen-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org> > > Acked-by: Li Zefan <lizefan-hv44wF8Li93QT0dZR+AlfA@public.gmane.org> Applied to cgroup/for-3.9. Thanks. -- tejun ^ permalink raw reply [flat|nested] 6+ messages in thread
end of thread, other threads:[~2013-01-08 18:08 UTC | newest]
Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
[not found] <1357333518-28899-1-git-send-email-gthelen@google.com>
[not found] ` <1357333518-28899-1-git-send-email-gthelen-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org>
2013-01-04 21:05 ` [PATCH 2/2] cgroups: fix cgroup_event_listener error handling Greg Thelen
2013-01-07 17:42 ` [PATCH 1/2] cgroups: move cgroup_event_listener.c to tools/cgroup Tejun Heo
[not found] ` <1357333518-28899-2-git-send-email-gthelen@google.com>
[not found] ` <1357333518-28899-2-git-send-email-gthelen-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org>
2013-01-07 17:44 ` [PATCH 2/2] cgroups: fix cgroup_event_listener error handling Tejun Heo
[not found] ` <20130107174427.GM3926@htj.dyndns.org>
[not found] ` <20130107174427.GM3926-Gd/HAXX7CRxy/B6EtB590w@public.gmane.org>
2013-01-07 19:50 ` Greg Thelen
[not found] ` <xr93a9sklqme.fsf-aSPv4SP+Du0KgorLzL7FmE7CuiCeIGUxQQ4Iyu8u01E@public.gmane.org>
2013-01-08 6:28 ` Li Zefan
[not found] ` <50EBBC9C.7060909-hv44wF8Li93QT0dZR+AlfA@public.gmane.org>
2013-01-08 18:08 ` Tejun Heo
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox