[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <1614268817-7596-2-git-send-email-mojha@codeaurora.org>
Date: Thu, 25 Feb 2021 21:30:17 +0530
From: Mukesh Ojha <mojha@...eaurora.org>
To: linux-kernel@...r.kernel.org
Cc: keescook@...omium.org, anton@...msg.org, ccross@...roid.com,
tony.luck@...el.com, Huang Yiwei <hyiwei@...eaurora.org>,
Mukesh Ojha <mojha@...eaurora.org>
Subject: [RESEND PATCH v2 2/2] pstore: Add buffer start check during init
From: Huang Yiwei <hyiwei@...eaurora.org>
In a scenario of panic, when we use DRAM to store log instead
of persistant storage and during warm reset when we copy these
data outside of ram. Missing check on prz->start(write position)
can cause crash because it can be any value and can point outside
the mapped region. So add the start check to avoid.
Signed-off-by: Huang Yiwei <hyiwei@...eaurora.org>
Signed-off-by: Mukesh Ojha <mojha@...eaurora.org>
---
change in v2:
- this is on top of first patchset.
fs/pstore/ram_core.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/fs/pstore/ram_core.c b/fs/pstore/ram_core.c
index 0da012f..a15748a 100644
--- a/fs/pstore/ram_core.c
+++ b/fs/pstore/ram_core.c
@@ -514,7 +514,7 @@ static int persistent_ram_post_init(struct persistent_ram_zone *prz, u32 sig,
sig ^= PERSISTENT_RAM_SIG;
if (prz->buffer->sig == sig) {
- if (buffer_size(prz) == 0) {
+ if (buffer_size(prz) == 0 && buffer_start(prz) == 0) {
pr_debug("found existing empty buffer\n");
return 0;
}
--
Qualcomm India Private Limited, on behalf of Qualcomm Innovation Center,
Inc. is a member of the Code Aurora Forum, a Linux Foundation Collaborative Project
Powered by blists - more mailing lists