From: Masahiro Yamada Date: Mon, 10 Feb 2020 16:18:52 +0000 (+0900) Subject: scripts/kallsyms: fix memory corruption caused by write over-run X-Git-Url: http://git.maquefel.me/?a=commitdiff_plain;h=9d1b38958b077f6c8d4bd196a115b643d7bd6717;p=linux.git scripts/kallsyms: fix memory corruption caused by write over-run memcpy() writes one more byte than allocated. Fixes: 8d60526999aa ("scripts/kallsyms: change table to store (strcut sym_entry *)") Reported-by: youling257 Reported-by: Pavel Machek Signed-off-by: Masahiro Yamada Tested-by: Pavel Machek --- diff --git a/scripts/kallsyms.c b/scripts/kallsyms.c index a566d8201b56c..0133dfaaf3529 100644 --- a/scripts/kallsyms.c +++ b/scripts/kallsyms.c @@ -210,7 +210,7 @@ static struct sym_entry *read_symbol(FILE *in) len = strlen(name) + 1; - sym = malloc(sizeof(*sym) + len); + sym = malloc(sizeof(*sym) + len + 1); if (!sym) { fprintf(stderr, "kallsyms failure: " "unable to allocate required amount of memory\n"); @@ -219,7 +219,7 @@ static struct sym_entry *read_symbol(FILE *in) sym->addr = addr; sym->len = len; sym->sym[0] = type; - memcpy(sym_name(sym), name, len); + strcpy(sym_name(sym), name); sym->percpu_absolute = 0; return sym;