summaryrefslogtreecommitdiffstats
path: root/fs/pstore/zone.c
diff options
context:
space:
mode:
authorKunwu Chan <chentao@kylinos.cn>2024-01-18 18:02:06 +0800
committerKees Cook <keescook@chromium.org>2024-02-22 10:37:22 -0800
commit98bc7e26e14fbb26a6abf97603d59532475e97f8 (patch)
tree62324bcb49adccdc5657f3e3d2f2a92a20f2ef0f /fs/pstore/zone.c
parenta28655c330ab294862cabe66deadb0f85cd4f191 (diff)
downloadlinux-98bc7e26e14fbb26a6abf97603d59532475e97f8.tar.gz
linux-98bc7e26e14fbb26a6abf97603d59532475e97f8.tar.bz2
linux-98bc7e26e14fbb26a6abf97603d59532475e97f8.zip
pstore/zone: Add a null pointer check to the psz_kmsg_read
kasprintf() returns a pointer to dynamically allocated memory which can be NULL upon failure. Ensure the allocation was successful by checking the pointer validity. Signed-off-by: Kunwu Chan <chentao@kylinos.cn> Link: https://lore.kernel.org/r/20240118100206.213928-1-chentao@kylinos.cn Signed-off-by: Kees Cook <keescook@chromium.org>
Diffstat (limited to 'fs/pstore/zone.c')
-rw-r--r--fs/pstore/zone.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/fs/pstore/zone.c b/fs/pstore/zone.c
index 2770746bb7aa..abca117725c8 100644
--- a/fs/pstore/zone.c
+++ b/fs/pstore/zone.c
@@ -973,6 +973,8 @@ static ssize_t psz_kmsg_read(struct pstore_zone *zone,
char *buf = kasprintf(GFP_KERNEL, "%s: Total %d times\n",
kmsg_dump_reason_str(record->reason),
record->count);
+ if (!buf)
+ return -ENOMEM;
hlen = strlen(buf);
record->buf = krealloc(buf, hlen + size, GFP_KERNEL);
if (!record->buf) {