2013/11/6 Steven Rostedt <[email protected]>: > 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 > > Ok Steve. Please, do the reword.
>> >> 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) > -- Regards, Geyslan G. Bem hackingbits.com -- 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/

