Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Openssl
提交
07981709
T
Third Party Openssl
项目概览
OpenHarmony
/
Third Party Openssl
大约 1 年 前同步成功
通知
9
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看板
体验新版 GitCode,发现更多精彩内容 >>
提交
07981709
编写于
12月 01, 2011
作者:
D
Dr. Stephen Henson
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Update DH_check() to peform sensible checks when q parameter is present.
上级
28ff1477
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
42 addition
and
9 deletion
+42
-9
crypto/dh/dh.h
crypto/dh/dh.h
+3
-0
crypto/dh/dh_check.c
crypto/dh/dh_check.c
+39
-9
未找到文件。
crypto/dh/dh.h
浏览文件 @
07981709
...
...
@@ -165,6 +165,9 @@ struct dh_st
#define DH_CHECK_P_NOT_SAFE_PRIME 0x02
#define DH_UNABLE_TO_CHECK_GENERATOR 0x04
#define DH_NOT_SUITABLE_GENERATOR 0x08
#define DH_CHECK_Q_NOT_PRIME 0x10
#define DH_CHECK_INVALID_Q_VALUE 0x20
#define DH_CHECK_INVALID_J_VALUE 0x40
/* DH_check_pub_key error codes */
#define DH_CHECK_PUBKEY_TOO_SMALL 0x01
...
...
crypto/dh/dh_check.c
浏览文件 @
07981709
...
...
@@ -75,15 +75,42 @@ int DH_check(const DH *dh, int *ret)
int
ok
=
0
;
BN_CTX
*
ctx
=
NULL
;
BN_ULONG
l
;
BIGNUM
*
q
=
NULL
;
BIGNUM
*
t1
=
NULL
,
*
t2
=
NULL
;
*
ret
=
0
;
ctx
=
BN_CTX_new
();
if
(
ctx
==
NULL
)
goto
err
;
q
=
BN_new
();
if
(
q
==
NULL
)
goto
err
;
BN_CTX_start
(
ctx
);
t1
=
BN_CTX_get
(
ctx
);
t2
=
BN_CTX_get
(
ctx
);
if
(
t2
==
NULL
)
goto
err
;
if
(
BN_is_word
(
dh
->
g
,
DH_GENERATOR_2
))
if
(
dh
->
q
)
{
if
(
BN_cmp
(
dh
->
g
,
BN_value_one
())
<=
0
)
*
ret
|=
DH_NOT_SUITABLE_GENERATOR
;
else
if
(
BN_cmp
(
dh
->
g
,
dh
->
p
)
>=
0
)
*
ret
|=
DH_NOT_SUITABLE_GENERATOR
;
else
{
/* Check g^q == 1 mod p */
if
(
!
BN_mod_exp
(
t1
,
dh
->
g
,
dh
->
q
,
dh
->
p
,
ctx
))
goto
err
;
if
(
!
BN_is_one
(
t1
))
*
ret
|=
DH_NOT_SUITABLE_GENERATOR
;
}
if
(
!
BN_is_prime_ex
(
dh
->
q
,
BN_prime_checks
,
ctx
,
NULL
))
*
ret
|=
DH_CHECK_Q_NOT_PRIME
;
/* Check p == 1 mod q i.e. q divides p - 1 */
if
(
!
BN_div
(
t1
,
t2
,
dh
->
p
,
dh
->
q
,
ctx
))
goto
err
;
if
(
!
BN_is_one
(
t2
))
*
ret
|=
DH_CHECK_INVALID_Q_VALUE
;
if
(
dh
->
j
&&
BN_cmp
(
dh
->
j
,
t1
))
*
ret
|=
DH_CHECK_INVALID_J_VALUE
;
}
else
if
(
BN_is_word
(
dh
->
g
,
DH_GENERATOR_2
))
{
l
=
BN_mod_word
(
dh
->
p
,
24
);
if
(
l
!=
11
)
*
ret
|=
DH_NOT_SUITABLE_GENERATOR
;
...
...
@@ -106,16 +133,19 @@ int DH_check(const DH *dh, int *ret)
if
(
!
BN_is_prime_ex
(
dh
->
p
,
BN_prime_checks
,
ctx
,
NULL
))
*
ret
|=
DH_CHECK_P_NOT_PRIME
;
else
else
if
(
!
dh
->
q
)
{
if
(
!
BN_rshift1
(
q
,
dh
->
p
))
goto
err
;
if
(
!
BN_is_prime_ex
(
q
,
BN_prime_checks
,
ctx
,
NULL
))
if
(
!
BN_rshift1
(
t1
,
dh
->
p
))
goto
err
;
if
(
!
BN_is_prime_ex
(
t1
,
BN_prime_checks
,
ctx
,
NULL
))
*
ret
|=
DH_CHECK_P_NOT_SAFE_PRIME
;
}
ok
=
1
;
err:
if
(
ctx
!=
NULL
)
BN_CTX_free
(
ctx
);
if
(
q
!=
NULL
)
BN_free
(
q
);
if
(
ctx
!=
NULL
)
{
BN_CTX_end
(
ctx
);
BN_CTX_free
(
ctx
);
}
return
(
ok
);
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录