From: Mark Wielaard Date: Fri, 24 Jan 2020 21:55:48 +0000 (+0100) Subject: libdwfl: Fix some GCC10 -Wnull-dereference issues. X-Git-Tag: elfutils-0.179~43 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=268e805de045c5ec28be952c7c6b05bb997f217e;p=thirdparty%2Felfutils.git libdwfl: Fix some GCC10 -Wnull-dereference issues. GCC10 on some arches will warn about possible NULL derefences. In the libdwfl linux-kernel-modules.c cases it might be caught already by earlier calls to get_release (). But it is hard to see that will really always happen. So do an explicit NULL check just in case. Signed-off-by: Mark Wielaard --- diff --git a/libdwfl/ChangeLog b/libdwfl/ChangeLog index b36a7ca6d..0b95490aa 100644 --- a/libdwfl/ChangeLog +++ b/libdwfl/ChangeLog @@ -1,3 +1,9 @@ +2020-01-24 Mark Wielaard + + * linux-kernel-modules.c (find_kernel_elf): Check release isn't NULL. + (report_kernel): Check release and *release aren't NULL. + (report_kernel_archive): Likewise. + 2019-12-11 Omar Sandoval * libdwflP.h (Dwfl_Module): Remove coalescing state. diff --git a/libdwfl/linux-kernel-modules.c b/libdwfl/linux-kernel-modules.c index 48fb1ff0a..0434f1e57 100644 --- a/libdwfl/linux-kernel-modules.c +++ b/libdwfl/linux-kernel-modules.c @@ -176,9 +176,10 @@ find_kernel_elf (Dwfl *dwfl, const char *release, char **fname) { /* First try to find an uncompressed vmlinux image. Possibly including debuginfo. */ - if ((release[0] == '/' - ? asprintf (fname, "%s/vmlinux", release) - : asprintf (fname, "/boot/vmlinux-%s", release)) < 0) + if (release == NULL + || ((release[0] == '/' + ? asprintf (fname, "%s/vmlinux", release) + : asprintf (fname, "/boot/vmlinux-%s", release)) < 0)) return -1; int fd = try_kernel_name (dwfl, fname, true); @@ -241,6 +242,9 @@ report_kernel (Dwfl *dwfl, const char **release, if (unlikely (result != 0)) return result; + if (release == NULL || *release == NULL) + return EINVAL; + char *fname; int fd = find_kernel_elf (dwfl, *release, &fname); @@ -296,6 +300,9 @@ report_kernel_archive (Dwfl *dwfl, const char **release, if (unlikely (result != 0)) return result; + if (release == NULL || *release == NULL) + return EINVAL; + char *archive; int res = (((*release)[0] == '/') ? asprintf (&archive, "%s/debug.a", *release)