Em Fri, Aug 02, 2019 at 04:29:52PM +0800, zhe...@windriver.com escreveu: > From: He Zhe <zhe...@windriver.com> > > cpu_map__snprint_mask would write to illegal memory pointed by zalloc(0) > when there is only one cpu. > > This patch fixes the calculation and adds sanity check against the input > parameters.
Thanks, applied, and added the missing: Fixes: 4400ac8a9a90 ("perf cpumap: Introduce cpu_map__snprint_mask()") - Arnaldo > Signed-off-by: He Zhe <zhe...@windriver.com> > --- > tools/perf/util/cpumap.c | 5 ++++- > 1 file changed, 4 insertions(+), 1 deletion(-) > > diff --git a/tools/perf/util/cpumap.c b/tools/perf/util/cpumap.c > index 3acfbe3..39cce66 100644 > --- a/tools/perf/util/cpumap.c > +++ b/tools/perf/util/cpumap.c > @@ -751,7 +751,10 @@ size_t cpu_map__snprint_mask(struct cpu_map *map, char > *buf, size_t size) > unsigned char *bitmap; > int last_cpu = cpu_map__cpu(map, map->nr - 1); > > - bitmap = zalloc((last_cpu + 7) / 8); > + if (buf == NULL) > + return 0; > + > + bitmap = zalloc(last_cpu / 8 + 1); > if (bitmap == NULL) { > buf[0] = '\0'; > return 0; > -- > 2.7.4 -- - Arnaldo