Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit e636f65b authored by Heiko Carstens's avatar Heiko Carstens Committed by Greg Kroah-Hartman
Browse files

s390/kexec: fix return code handling



[ Upstream commit 20c76e242e7025bd355619ba67beb243ba1a1e95 ]

kexec_file_add_ipl_report ignores that ipl_report_finish may fail and
can return an error pointer instead of a valid pointer.
Fix this and simplify by returning NULL in case of an error and let
the only caller handle this case.

Fixes: 99feaa71 ("s390/kexec_file: Create ipl report and pass to next kernel")
Signed-off-by: default avatarHeiko Carstens <hca@linux.ibm.com>
Signed-off-by: default avatarSasha Levin <sashal@kernel.org>
parent cc093e5a
Loading
Loading
Loading
Loading
+2 −1
Original line number Diff line number Diff line
@@ -1783,7 +1783,7 @@ void *ipl_report_finish(struct ipl_report *report)

	buf = vzalloc(report->size);
	if (!buf)
		return ERR_PTR(-ENOMEM);
		goto out;
	ptr = buf;

	memcpy(ptr, report->ipib, report->ipib->hdr.len);
@@ -1822,6 +1822,7 @@ void *ipl_report_finish(struct ipl_report *report)
	}

	BUG_ON(ptr > buf + report->size);
out:
	return buf;
}

+7 −1
Original line number Diff line number Diff line
@@ -170,6 +170,7 @@ static int kexec_file_add_ipl_report(struct kimage *image,
	struct kexec_buf buf;
	unsigned long addr;
	void *ptr, *end;
	int ret;

	buf.image = image;

@@ -199,7 +200,10 @@ static int kexec_file_add_ipl_report(struct kimage *image,
		ptr += len;
	}

	ret = -ENOMEM;
	buf.buffer = ipl_report_finish(data->report);
	if (!buf.buffer)
		goto out;
	buf.bufsz = data->report->size;
	buf.memsz = buf.bufsz;

@@ -209,7 +213,9 @@ static int kexec_file_add_ipl_report(struct kimage *image,
		data->kernel_buf + offsetof(struct lowcore, ipl_parmblock_ptr);
	*lc_ipl_parmblock_ptr = (__u32)buf.mem;

	return kexec_add_buffer(&buf);
	ret = kexec_add_buffer(&buf);
out:
	return ret;
}

void *kexec_file_add_components(struct kimage *image,