Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
ab92bb2f
cloud-kernel
项目概览
openanolis
/
cloud-kernel
1 年多 前同步成功
通知
161
Star
36
Fork
7
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
10
列表
看板
标记
里程碑
合并请求
2
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
cloud-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
10
Issue
10
列表
看板
标记
里程碑
合并请求
2
合并请求
2
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
ab92bb2f
编写于
7月 09, 2012
作者:
D
David S. Miller
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
tcp: Abstract back handling peer aliveness test into helper function.
Signed-off-by:
N
David S. Miller
<
davem@davemloft.net
>
上级
4aabd8ef
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
13 addition
and
2 deletion
+13
-2
include/net/tcp.h
include/net/tcp.h
+1
-0
net/ipv4/tcp_ipv4.c
net/ipv4/tcp_ipv4.c
+1
-1
net/ipv4/tcp_metrics.c
net/ipv4/tcp_metrics.c
+10
-0
net/ipv6/tcp_ipv6.c
net/ipv6/tcp_ipv6.c
+1
-1
未找到文件。
include/net/tcp.h
浏览文件 @
ab92bb2f
...
...
@@ -389,6 +389,7 @@ extern void tcp_enter_loss(struct sock *sk, int how);
extern
void
tcp_clear_retrans
(
struct
tcp_sock
*
tp
);
extern
void
tcp_update_metrics
(
struct
sock
*
sk
);
extern
void
tcp_init_metrics
(
struct
sock
*
sk
);
extern
bool
tcp_peer_is_proven
(
struct
request_sock
*
req
,
struct
dst_entry
*
dst
);
extern
void
tcp_disable_fack
(
struct
tcp_sock
*
tp
);
extern
void
tcp_close
(
struct
sock
*
sk
,
long
timeout
);
extern
void
tcp_init_sock
(
struct
sock
*
sk
);
...
...
net/ipv4/tcp_ipv4.c
浏览文件 @
ab92bb2f
...
...
@@ -1405,7 +1405,7 @@ int tcp_v4_conn_request(struct sock *sk, struct sk_buff *skb)
(
sysctl_max_syn_backlog
-
inet_csk_reqsk_queue_len
(
sk
)
<
(
sysctl_max_syn_backlog
>>
2
))
&&
(
!
peer
||
!
peer
->
tcp_ts_stamp
)
&&
(
!
dst
||
!
dst_metric
(
dst
,
RTAX_RTT
)
))
{
!
tcp_peer_is_proven
(
req
,
dst
))
{
/* Without syncookies last quarter of
* backlog is filled with destinations,
* proven to be alive.
...
...
net/ipv4/tcp_metrics.c
浏览文件 @
ab92bb2f
#include <linux/module.h>
#include <linux/cache.h>
#include <linux/tcp.h>
#include <net/inet_connection_sock.h>
#include <net/request_sock.h>
#include <net/sock.h>
#include <net/dst.h>
#include <net/tcp.h>
...
...
@@ -190,3 +192,11 @@ void tcp_init_metrics(struct sock *sk)
tp
->
snd_cwnd
=
tcp_init_cwnd
(
tp
,
dst
);
tp
->
snd_cwnd_stamp
=
tcp_time_stamp
;
}
bool
tcp_peer_is_proven
(
struct
request_sock
*
req
,
struct
dst_entry
*
dst
)
{
if
(
!
dst
)
return
false
;
return
dst_metric
(
dst
,
RTAX_RTT
)
?
true
:
false
;
}
EXPORT_SYMBOL_GPL
(
tcp_peer_is_proven
);
net/ipv6/tcp_ipv6.c
浏览文件 @
ab92bb2f
...
...
@@ -1177,7 +1177,7 @@ static int tcp_v6_conn_request(struct sock *sk, struct sk_buff *skb)
(
sysctl_max_syn_backlog
-
inet_csk_reqsk_queue_len
(
sk
)
<
(
sysctl_max_syn_backlog
>>
2
))
&&
(
!
peer
||
!
peer
->
tcp_ts_stamp
)
&&
(
!
dst
||
!
dst_metric
(
dst
,
RTAX_RTT
)
))
{
!
tcp_peer_is_proven
(
req
,
dst
))
{
/* Without syncookies last quarter of
* backlog is filled with destinations,
* proven to be alive.
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录