On Wed,  6 Nov 2013 16:02:51 -0300
"Geyslan G. Bem" <[email protected]> wrote:

> In 'system_tr_open()':
> Fix possible 'dir' assignment after freeing it.

I'll take this patch, but I'm going to reword the subject and the
change log. The assignment of dir to filp->private_data after dir is
freed is not as bad as it sounds. As we are returning an error,
filp->private_data is never used.

-- Steve


> 
> In both functions:
> Restructures logic conditions testing 'tracing_is_disabled()'
> return before the others tests.
> 
> Signed-off-by: Geyslan G. Bem <[email protected]>
> ---
>  kernel/trace/trace_events.c | 9 ++++++++-
>  1 file changed, 8 insertions(+), 1 deletion(-)
> 
> diff --git a/kernel/trace/trace_events.c b/kernel/trace/trace_events.c
> index 368a4d5..b44a7ea 100644
> --- a/kernel/trace/trace_events.c
> +++ b/kernel/trace/trace_events.c
> @@ -1062,6 +1062,9 @@ static int subsystem_open(struct inode *inode, struct 
> file *filp)
>       struct trace_array *tr;
>       int ret;
>  
> +     if (tracing_is_disabled())
> +             return -ENODEV;
> +
>       /* Make sure the system still exists */
>       mutex_lock(&trace_types_lock);
>       mutex_lock(&event_mutex);
> @@ -1108,6 +1111,9 @@ static int system_tr_open(struct inode *inode, struct 
> file *filp)
>       struct trace_array *tr = inode->i_private;
>       int ret;
>  
> +     if (tracing_is_disabled())
> +             return -ENODEV;
> +
>       if (trace_array_get(tr) < 0)
>               return -ENODEV;
>  
> @@ -1124,11 +1130,12 @@ static int system_tr_open(struct inode *inode, struct 
> file *filp)
>       if (ret < 0) {
>               trace_array_put(tr);
>               kfree(dir);
> +             return ret;
>       }
>  
>       filp->private_data = dir;
>  
> -     return ret;
> +     return 0;
>  }
>  
>  static int subsystem_release(struct inode *inode, struct file *file)

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to