aboutsummaryrefslogtreecommitdiffstats
path: root/tools/perf/util/parse-options.c
diff options
context:
space:
mode:
authorJiri Olsa <jolsa@redhat.com>2011-03-07 15:13:40 -0500
committerArnaldo Carvalho de Melo <acme@redhat.com>2011-03-10 08:54:13 -0500
commitb9a46bba88001504235459c8410f17e6a7e38008 (patch)
tree35687cc87135475ce5be257c878cee6eeaf40f37 /tools/perf/util/parse-options.c
parent2a8247a2600c3e087a568fc68a6ec4eedac27ef1 (diff)
perf top: Fix events overflow in top command
The snprintf function returns number of printed characters even if it cross the size parameter. So passing enough events via '-e' parameter will cause segmentation fault. It's reproduced by following command: perf top -e `perf list | grep Tracepoint | awk -F'[' '\ {gsub(/[[:space:]]+/,"",$1);array[FNR]=$1}END{outputs=array[1];\ for (i=2;i<=FNR;i++){ outputs=outputs "," array[i];};print outputs}'` Attached patch is adding SNPRINTF macro that provides the overflow check and returns actuall number of printed characters. Reported-by: Han Pingtian <phan@redhat.com> Cc: Han Pingtian <phan@redhat.com> Cc: Ingo Molnar <mingo@elte.hu> Cc: Paul Mackerras <paulus@samba.org> Cc: Peter Zijlstra <a.p.zijlstra@chello.nl> LKML-Reference: <1299528821-17521-2-git-send-email-jolsa@redhat.com> Signed-off-by: Jiri Olsa <jolsa@redhat.com> Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools/perf/util/parse-options.c')
0 files changed, 0 insertions, 0 deletions