11 Star 11 Fork 42

src-openEuler/secGear

Create your Gitee Account
Explore and code with more than 13.5 million developers,Free private repositories !:)
Sign up
文件
This repository doesn't specify license. Please pay attention to the specific project description and its upstream code dependency when using it.
Clone or Download
0073-memset-no-optimize.patch 1.90 KB
Copy Edit Raw Blame History
houmingyong authored 12 months ago . synchoronous features
From c15207d44281663b32ad4a8ede998dd4c7bda6fd Mon Sep 17 00:00:00 2001
From: zhengxiaoxiao <zhengxiaoxiao2@huawei.com>
Date: Thu, 14 Mar 2024 20:20:34 +0800
Subject: [PATCH] memset no optimize
Reference:https://gitee.com/openeuler/secGear/commit/c0997efc6a69d465b286347285cb1508a9d9c24b
Conflict:NA
---
src/enclave_src/gp/itrustee/itrustee_seal_data.c | 15 +++++++++++----
1 file changed, 11 insertions(+), 4 deletions(-)
diff --git a/src/enclave_src/gp/itrustee/itrustee_seal_data.c b/src/enclave_src/gp/itrustee/itrustee_seal_data.c
index b074d6f..e23cb1e 100644
--- a/src/enclave_src/gp/itrustee/itrustee_seal_data.c
+++ b/src/enclave_src/gp/itrustee/itrustee_seal_data.c
@@ -15,6 +15,13 @@
#include "tee_crypto_api.h"
#include "dataseal_internal.h"
#include "tee_trusted_storage.h"
+
+#define CC_OPTIMIZE_OFF __attribute__((optimize("O0")))
+CC_OPTIMIZE_OFF static void *memset_no_optimize(void *ptr, int value, size_t num)
+{
+ memset(ptr, 0, num);
+}
+
uint32_t get_sealed_data_size_ex(uint32_t seal_data_len, uint32_t aad_len)
{
if (UINT32_MAX - aad_len <= seal_data_len) {
@@ -139,13 +146,13 @@ TEE_Result itrustee_seal_data(uint8_t *seal_data, uint32_t seal_data_len, void *
result = data_copy(tmp_sealed_data, salt, nonce, mac_data, mac_data_len);
error0:
- memset(nonce, 0, SEAL_DATA_NONCE_LEN);
+ memset_no_optimize(nonce, 0, SEAL_DATA_NONCE_LEN);
TEE_Free(nonce);
error1:
- memset(salt, 0, SEAL_KEY_SALT_LEN);
+ memset_no_optimize(salt, 0, SEAL_KEY_SALT_LEN);
TEE_Free(salt);
error2:
- memset(key_buf, 0, SEAL_KEY_LEN);
+ memset_no_optimize(key_buf, 0, SEAL_KEY_LEN);
TEE_Free(key_buf);
return result;
}
@@ -249,7 +256,7 @@ TEE_Result itrustee_unseal_data(void *sealed_data, uint8_t *decrypted_data, uint
}
done:
- memset(key_buf, 0, SEAL_KEY_LEN);
+ memset_no_optimize(key_buf, 0, SEAL_KEY_LEN);
TEE_Free(key_buf);
return result;
}
--
2.33.0
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/src-openeuler/secGear.git
git@gitee.com:src-openeuler/secGear.git
src-openeuler
secGear
secGear
master

Search