[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-Id: <1614152666-30137-2-git-send-email-mojha@qti.qualcomm.com>
Date: Wed, 24 Feb 2021 13:14:26 +0530
From: Mukesh Ojha <mojha@....qualcomm.com>
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: [PATCH 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