parse_synth_field() builds a "__data_loc ..." type string before
assigning it to field->type. If the seq_buf check fails, the common
cleanup cannot free the temporary string. Free it before leaving.

Signed-off-by: Yu Peng <[email protected]>
---
 kernel/trace/trace_events_synth.c | 4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)

diff --git a/kernel/trace/trace_events_synth.c 
b/kernel/trace/trace_events_synth.c
index cdd5b93328358..dc15658a887cb 100644
--- a/kernel/trace/trace_events_synth.c
+++ b/kernel/trace/trace_events_synth.c
@@ -839,8 +839,10 @@ static struct synth_field *parse_synth_field(int argc, 
char **argv,
                        seq_buf_puts(&s, "__data_loc ");
                        seq_buf_puts(&s, field->type);
 
-                       if (WARN_ON_ONCE(!seq_buf_buffer_left(&s)))
+                       if (WARN_ON_ONCE(!seq_buf_buffer_left(&s))) {
+                               kfree(type);
                                goto free;
+                       }
                        s.buffer[s.len] = '\0';
 
                        kfree(field->type);
-- 
2.43.0


Reply via email to