提交 465c9615 编写于 作者: K Kai Ye 提交者: Zheng Zengkai

crypto: hisilicon/sec - fix the max length of AAD for the CCM mode

driver inclusion
category: bugfix
bugzilla: https://gitee.com/openeuler/kernel/issues/I4750I?from=project-issue

----------------------------------------------------------------------

Fix the maximum length of AAD for the CCM mode due to the hardware limited.
Signed-off-by: NKai Ye <yekai13@huawei.com>
Reviewed-by: NHao Fang <fanghao11@huawei.com>
Reviewed-by: NMingqiang Ling <lingmingqiang@huawei.com>
Signed-off-by: NZheng Zengkai <zhengzengkai@huawei.com>
上级 05aca98f
...@@ -63,6 +63,7 @@ ...@@ -63,6 +63,7 @@
#define SEC_AUTH_CIPHER 0x1 #define SEC_AUTH_CIPHER 0x1
#define SEC_MAX_MAC_LEN 64 #define SEC_MAX_MAC_LEN 64
#define SEC_MAX_AAD_LEN 65535 #define SEC_MAX_AAD_LEN 65535
#define SEC_MAX_CCM_AAD_LEN 65279
#define SEC_TOTAL_MAC_SZ (SEC_MAX_MAC_LEN * QM_Q_DEPTH) #define SEC_TOTAL_MAC_SZ (SEC_MAX_MAC_LEN * QM_Q_DEPTH)
#define SEC_PBUF_SZ 512 #define SEC_PBUF_SZ 512
...@@ -2219,6 +2220,10 @@ static int sec_aead_spec_check(struct sec_ctx *ctx, struct sec_req *sreq) ...@@ -2219,6 +2220,10 @@ static int sec_aead_spec_check(struct sec_ctx *ctx, struct sec_req *sreq)
} }
if (c_mode == SEC_CMODE_CCM) { if (c_mode == SEC_CMODE_CCM) {
if (unlikely(req->assoclen > SEC_MAX_CCM_AAD_LEN)) {
dev_err_ratelimited(dev, "CCM input aad parameter is too long!\n");
return -EINVAL;
}
ret = aead_iv_demension_check(req); ret = aead_iv_demension_check(req);
if (ret) { if (ret) {
dev_err(dev, "aead input iv param error!\n"); dev_err(dev, "aead input iv param error!\n");
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册