8 Star 1 Fork 8

src-anolis-os/rasdaemon

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
1046-ras-events-quit-loop-in-read_ras_event-when-kbuf-dat.patch 1.25 KB
一键复制 编辑 原始数据 按行查看 历史
winterddd 提交于 2024-12-25 17:32 +08:00 . [Feature]anolis: rasdaemon: rasdaemon 0.6.7-16
From 838234ed7e9cf87b740556c5e15e3e236b723fa4 Mon Sep 17 00:00:00 2001
From: hubin <hubin73@huawei.com>
Date: Thu, 18 May 2023 16:14:41 +0800
Subject: [PATCH 46/85] ras-events: quit loop in read_ras_event when kbuf data
is broken
when kbuf data is broken, kbuffer_next_event() may move kbuf->index back to
the current kbuf->index position, causing dead loop.
In this situation, rasdaemon will repeatedly parse an invalid event, and
print warning like "ug! negative record size -8!", pushing cpu utilization
rate to 100%.
when kbuf data is broken, discard current page and continue reading next page
kbuf.
Signed-off-by: hubin <hubin73@huawei.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@kernel.org>
---
ras-events.c | 5 +++++
1 file changed, 5 insertions(+)
diff --git a/ras-events.c b/ras-events.c
index e1326f3..2cc54b3 100644
--- a/ras-events.c
+++ b/ras-events.c
@@ -546,6 +546,11 @@ static int read_ras_event_all_cpus(struct pthread_data *pdata,
kbuffer_load_subbuffer(kbuf, page);
while ((data = kbuffer_read_event(kbuf, &time_stamp))) {
+ if (kbuffer_curr_size(kbuf) < 0) {
+ log(TERM, LOG_ERR, "invalid kbuf data, discard\n");
+ break;
+ }
+
parse_ras_data(&pdata[i],
kbuf, data, time_stamp);
--
2.33.1
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/src-anolis-os/rasdaemon.git
git@gitee.com:src-anolis-os/rasdaemon.git
src-anolis-os
rasdaemon
rasdaemon
a8

搜索帮助

371d5123 14472233 46e8bd33 14472233