Ai
7 Star 1 Fork 19

src-openEuler/ima-evm-utils
关闭

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
0002-fix-caps-parameter-cannot-be-parsed.patch 1.26 KB
一键复制 编辑 原始数据 按行查看 历史
Linux_zhang 提交于 2025-12-09 14:20 +08:00 . fix the stack overflow vulnerability
From 24c9623f563646695f6d219b2414b23f36378b42 Mon Sep 17 00:00:00 2001
From: shenxiangwei <shenxiangwei1@huawei.com>
Date: Fri, 19 Aug 2022 12:05:11 +0800
Subject: [PATCH] fix caps parameter cannot be parsed
Signed-off-by: shenxiangwei <shenxiangwei1@huawei.com>
Signed-off-by: zhoushuiqing <zhoushuiqing2@huawei.com>
Signed-off-by: xuce <xuce10@h-parnters.com>
---
src/evmctl.c | 9 ++++++---
1 file changed, 6 insertions(+), 3 deletions(-)
diff --git a/src/evmctl.c b/src/evmctl.c
index 3748c31..6c99685 100644
--- a/src/evmctl.c
+++ b/src/evmctl.c
@@ -472,14 +472,17 @@ static int calc_evm_hash(const char *file, unsigned char *hash)
} else if (!strcmp(*xattrname, XATTR_NAME_CAPS) && (hmac_flags & HMAC_FLAG_CAPS_SET)) {
if (!caps_str)
continue;
- err = strlen(caps_str);
+ err = strlen(caps_str) >> 1;
if (err >= sizeof(xattr_value)) {
log_err("caps[%u] value is too long to fit into xattr[%zu]\n",
- err + 1, sizeof(xattr_value));
+ err, sizeof(xattr_value));
+ err = -1;
+ goto out;
+ }
+ if (hex2bin(xattr_value, caps_str, strlen(caps_str) >> 1)) {
err = -1;
goto out;
}
- strcpy(xattr_value, caps_str);
} else {
err = lgetxattr(file, *xattrname, xattr_value, sizeof(xattr_value));
if (err < 0) {
--
2.43.0
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/src-openeuler/ima-evm-utils.git
git@gitee.com:src-openeuler/ima-evm-utils.git
src-openeuler
ima-evm-utils
ima-evm-utils
master

搜索帮助