Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Openssl
提交
447e1319
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,发现更多精彩内容 >>
提交
447e1319
编写于
6月 11, 2012
作者:
A
Andy Polyakov
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
bss_dgram.c: add BIO_CTRL_DGRAM_SET_DONT_FRAG.
PR: 2830 Submitted by: Robin Seggelmann
上级
e77ec2ba
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
46 addition
and
1 deletion
+46
-1
crypto/bio/bio.h
crypto/bio/bio.h
+1
-0
crypto/bio/bss_dgram.c
crypto/bio/bss_dgram.c
+45
-1
未找到文件。
crypto/bio/bio.h
浏览文件 @
447e1319
...
@@ -174,6 +174,7 @@ extern "C" {
...
@@ -174,6 +174,7 @@ extern "C" {
#define BIO_CTRL_DGRAM_SET_NEXT_TIMEOUT 45
/* Next DTLS handshake timeout to
#define BIO_CTRL_DGRAM_SET_NEXT_TIMEOUT 45
/* Next DTLS handshake timeout to
* adjust socket timeouts */
* adjust socket timeouts */
#define BIO_CTRL_DGRAM_SET_DONT_FRAG 48
#ifndef OPENSSL_NO_SCTP
#ifndef OPENSSL_NO_SCTP
/* SCTP stuff */
/* SCTP stuff */
...
...
crypto/bio/bss_dgram.c
浏览文件 @
447e1319
...
@@ -460,8 +460,8 @@ static long dgram_ctrl(BIO *b, int cmd, long num, void *ptr)
...
@@ -460,8 +460,8 @@ static long dgram_ctrl(BIO *b, int cmd, long num, void *ptr)
int
*
ip
;
int
*
ip
;
struct
sockaddr
*
to
=
NULL
;
struct
sockaddr
*
to
=
NULL
;
bio_dgram_data
*
data
=
NULL
;
bio_dgram_data
*
data
=
NULL
;
#if defined(OPENSSL_SYS_LINUX) && (defined(IP_MTU_DISCOVER) || defined(IP_MTU))
int
sockopt_val
=
0
;
int
sockopt_val
=
0
;
#if defined(OPENSSL_SYS_LINUX) && (defined(IP_MTU_DISCOVER) || defined(IP_MTU))
socklen_t
sockopt_len
;
/* assume that system supporting IP_MTU is
socklen_t
sockopt_len
;
/* assume that system supporting IP_MTU is
* modern enough to define socklen_t */
* modern enough to define socklen_t */
socklen_t
addr_len
;
socklen_t
addr_len
;
...
@@ -848,6 +848,50 @@ static long dgram_ctrl(BIO *b, int cmd, long num, void *ptr)
...
@@ -848,6 +848,50 @@ static long dgram_ctrl(BIO *b, int cmd, long num, void *ptr)
ret
=
0
;
ret
=
0
;
break
;
break
;
#endif
#endif
case
BIO_CTRL_DGRAM_SET_DONT_FRAG
:
sockopt_val
=
num
?
1
:
0
;
switch
(
data
->
peer
.
sa
.
sa_family
)
{
case
AF_INET
:
#if defined(IP_DONTFRAG)
if
((
ret
=
setsockopt
(
b
->
num
,
IPPROTO_IP
,
IP_DONTFRAG
,
&
sockopt_val
,
sizeof
(
sockopt_val
)))
<
0
)
{
perror
(
"setsockopt"
);
ret
=
-
1
;
}
#elif defined(OPENSSL_SYS_LINUX) && defined(IP_MTUDISCOVER)
if
((
sockopt_val
=
num
?
IP_PMTUDISC_PROBE
:
IP_PMTUDISC_DONT
),
(
ret
=
setsockopt
(
b
->
num
,
IPPROTO_IP
,
IP_MTU_DISCOVER
,
&
sockopt_val
,
sizeof
(
sockopt_val
)))
<
0
)
{
perror
(
"setsockopt"
);
ret
=
-
1
;
}
#elif defined(OPENSSL_SYS_WINDOWS) && defined(IP_DONTFRAGMENT)
if
((
ret
=
setsockopt
(
b
->
num
,
IPPROTO_IP
,
IP_DONTFRAGMENT
,
(
const
char
*
)
&
sockopt_val
,
sizeof
(
sockopt_val
)))
<
0
)
{
perror
(
"setsockopt"
);
ret
=
-
1
;
}
#else
ret
=
-
1
;
#endif
break
;
#if OPENSSL_USE_IPV6
case
AF_INET6
:
#if defined(IPV6_DONTFRAG)
if
((
ret
=
setsockopt
(
b
->
num
,
IPPROTO_IPV6
,
IPV6_DONTFRAG
,
&
sockopt_val
,
sizeof
(
sockopt_val
)))
<
0
)
{
perror
(
"setsockopt"
);
ret
=
-
1
;
}
#elif defined(OPENSSL_SYS_LINUX) && defined(IPV6_MTUDISCOVER)
if
((
sockopt_val
=
num
?
IP_PMTUDISC_PROBE
:
IP_PMTUDISC_DONT
),
(
ret
=
setsockopt
(
b
->
num
,
IPPROTO_IPV6
,
IPV6_MTU_DISCOVER
,
&
sockopt_val
,
sizeof
(
sockopt_val
)))
<
0
)
{
perror
(
"setsockopt"
);
ret
=
-
1
;
}
#else
ret
=
-
1
;
#endif
break
;
#endif
default:
ret
=
-
1
;
break
;
}
break
;
default:
default:
ret
=
0
;
ret
=
0
;
break
;
break
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录