Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Openssl
提交
370bf1d7
T
Third Party Openssl
项目概览
OpenHarmony
/
Third Party Openssl
1 年多 前同步成功
通知
10
Star
18
Fork
1
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
Third Party Openssl
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
370bf1d7
编写于
6月 29, 2014
作者:
Z
ZNV
提交者:
Dr. Stephen Henson
6月 29, 2014
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Make EVP_CIPHER_CTX_copy work in GCM mode.
PR#3272
上级
7e6a01bd
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
18 addition
and
1 deletion
+18
-1
crypto/evp/e_aes.c
crypto/evp/e_aes.c
+18
-1
未找到文件。
crypto/evp/e_aes.c
浏览文件 @
370bf1d7
...
...
@@ -1298,6 +1298,22 @@ static int aes_gcm_ctrl(EVP_CIPHER_CTX *c, int type, int arg, void *ptr)
/* Extra padding: tag appended to record */
return
EVP_GCM_TLS_TAG_LEN
;
case
EVP_CTRL_COPY
:
{
EVP_CIPHER_CTX
*
out
=
ptr
;
EVP_AES_GCM_CTX
*
gctx_out
=
out
->
cipher_data
;
if
(
gctx
->
iv
==
c
->
iv
)
gctx_out
->
iv
=
out
->
iv
;
else
{
gctx_out
->
iv
=
OPENSSL_malloc
(
gctx
->
ivlen
);
if
(
!
gctx_out
->
iv
)
return
0
;
memcpy
(
gctx_out
->
iv
,
gctx
->
iv
,
gctx
->
ivlen
);
}
return
1
;
}
default:
return
-
1
;
...
...
@@ -1687,7 +1703,8 @@ static int aes_gcm_cipher(EVP_CIPHER_CTX *ctx, unsigned char *out,
#define CUSTOM_FLAGS (EVP_CIPH_FLAG_DEFAULT_ASN1 \
| EVP_CIPH_CUSTOM_IV | EVP_CIPH_FLAG_CUSTOM_CIPHER \
| EVP_CIPH_ALWAYS_CALL_INIT | EVP_CIPH_CTRL_INIT)
| EVP_CIPH_ALWAYS_CALL_INIT | EVP_CIPH_CTRL_INIT \
| EVP_CIPH_CUSTOM_COPY)
BLOCK_CIPHER_custom
(
NID_aes
,
128
,
1
,
12
,
gcm
,
GCM
,
EVP_CIPH_FLAG_FIPS
|
EVP_CIPH_FLAG_AEAD_CIPHER
|
CUSTOM_FLAGS
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录