Re: [tip:tracing/core] tracing: trace_output.c, fix false positivecompiler warning

From: Steven Rostedt
Date: Wed May 06 2009 - 10:24:54 EST



On Wed, 6 May 2009, tip-bot for Jaswinder Singh Rajput wrote:

> Commit-ID: 48dd0fed90e2b1f1ba87401439b85942181c6df3
> Gitweb: http://git.kernel.org/tip/48dd0fed90e2b1f1ba87401439b85942181c6df3
> Author: Jaswinder Singh Rajput <jaswinder@xxxxxxxxxx>
> AuthorDate: Wed, 6 May 2009 15:45:45 +0530
> Committer: Ingo Molnar <mingo@xxxxxxx>
> CommitDate: Wed, 6 May 2009 14:19:16 +0200
>
> tracing: trace_output.c, fix false positive compiler warning
>
> This compiler warning:
>
> CC kernel/trace/trace_output.o
> kernel/trace/trace_output.c: In function ?register_ftrace_event?:
> kernel/trace/trace_output.c:544: warning: ?list? may be used uninitialized in this function
>
> Is wrong as 'list' is always initialized - but GCC (4.3.2) does not
> recognize this relationship properly.
>
> Work around the warning by initializing the variable to NULL.
>
> [ Impact: fix false positive compiler warning ]
>
> Signed-off-by: Jaswinder Singh Rajput <jaswinderrajput@xxxxxxxxx>
> Acked-by: Steven Rostedt <rostedt@xxxxxxxxxxx>
> LKML-Reference: <new-submission>
> Signed-off-by: Ingo Molnar <mingo@xxxxxxx>
>
>
> ---
> kernel/trace/trace_output.c | 2 +-
> 1 files changed, 1 insertions(+), 1 deletions(-)
>
> diff --git a/kernel/trace/trace_output.c b/kernel/trace/trace_output.c
> index 5fc51f0..8bd9a2c 100644
> --- a/kernel/trace/trace_output.c
> +++ b/kernel/trace/trace_output.c
> @@ -541,7 +541,7 @@ int register_ftrace_event(struct trace_event *event)
> INIT_LIST_HEAD(&event->list);
>
> if (!event->type) {
> - struct list_head *list;
> + struct list_head *list = NULL;

Actually this is the wrong place to initialize. The correct place is in
the function that is expected to.

>
> if (next_event_type > FTRACE_MAX_EVENT) {
>

Could you test this patch instead:

tracing: quiet gcc compile warning

Some versions of gcc can not catch the fact that the list variable in
register_ftrace_event is initialized. There's one place in the logic that
is a bit complex. The trace_search_list function that initializes the list
will not initialize it on error. But that's OK, because the caller checks
for error and will not use the list variable if there is one. Some
versions of gcc miss this.

[ Impact: quiet gcc from complaining about an unused variable ]

Signed-off-by: Steven Rostedt <rostedt@xxxxxxxxxxx>

diff --git a/kernel/trace/trace_output.c b/kernel/trace/trace_output.c
index 5fc51f0..e949cf6 100644
--- a/kernel/trace/trace_output.c
+++ b/kernel/trace/trace_output.c
@@ -506,8 +506,10 @@ static int trace_search_list(struct list_head **list)
}

/* Did we used up all 65 thousand events??? */
- if ((last + 1) > FTRACE_MAX_EVENT)
+ if ((last + 1) > FTRACE_MAX_EVENT) {
+ *list = NULL;
return 0;
+ }

*list = &e->list;
return last + 1;
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/