Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
36bdbcae
K
Kernel
项目概览
openeuler
/
Kernel
接近 2 年 前同步成功
通知
8
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
36bdbcae
编写于
7月 02, 2012
作者:
D
David S. Miller
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
net: Kill dst->_neighbour, accessors, and final uses.
No longer used. Signed-off-by:
N
David S. Miller
<
davem@davemloft.net
>
上级
d1e31fb0
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
1 addition
and
34 deletion
+1
-34
include/net/dst.h
include/net/dst.h
+1
-16
net/core/dst.c
net/core/dst.c
+0
-18
未找到文件。
include/net/dst.h
浏览文件 @
36bdbcae
...
...
@@ -42,7 +42,7 @@ struct dst_entry {
struct
dst_entry
*
from
;
};
struct
dst_entry
*
path
;
struct
neighbour
__rcu
*
_neighbour
;
void
*
__pad0
;
#ifdef CONFIG_XFRM
struct
xfrm_state
*
xfrm
;
#else
...
...
@@ -96,21 +96,6 @@ struct dst_entry {
};
};
static
inline
struct
neighbour
*
dst_get_neighbour_noref
(
struct
dst_entry
*
dst
)
{
return
rcu_dereference
(
dst
->
_neighbour
);
}
static
inline
struct
neighbour
*
dst_get_neighbour_noref_raw
(
struct
dst_entry
*
dst
)
{
return
rcu_dereference_raw
(
dst
->
_neighbour
);
}
static
inline
void
dst_set_neighbour
(
struct
dst_entry
*
dst
,
struct
neighbour
*
neigh
)
{
rcu_assign_pointer
(
dst
->
_neighbour
,
neigh
);
}
extern
u32
*
dst_cow_metrics_generic
(
struct
dst_entry
*
dst
,
unsigned
long
old
);
extern
const
u32
dst_default_metrics
[
RTAX_MAX
];
...
...
net/core/dst.c
浏览文件 @
36bdbcae
...
...
@@ -171,7 +171,6 @@ void *dst_alloc(struct dst_ops *ops, struct net_device *dev,
dst_init_metrics
(
dst
,
dst_default_metrics
,
true
);
dst
->
expires
=
0UL
;
dst
->
path
=
dst
;
RCU_INIT_POINTER
(
dst
->
_neighbour
,
NULL
);
#ifdef CONFIG_XFRM
dst
->
xfrm
=
NULL
;
#endif
...
...
@@ -225,19 +224,12 @@ EXPORT_SYMBOL(__dst_free);
struct
dst_entry
*
dst_destroy
(
struct
dst_entry
*
dst
)
{
struct
dst_entry
*
child
;
struct
neighbour
*
neigh
;
smp_rmb
();
again:
neigh
=
rcu_dereference_protected
(
dst
->
_neighbour
,
1
);
child
=
dst
->
child
;
if
(
neigh
)
{
RCU_INIT_POINTER
(
dst
->
_neighbour
,
NULL
);
neigh_release
(
neigh
);
}
if
(
!
(
dst
->
flags
&
DST_NOCOUNT
))
dst_entries_add
(
dst
->
ops
,
-
1
);
...
...
@@ -361,19 +353,9 @@ static void dst_ifdown(struct dst_entry *dst, struct net_device *dev,
if
(
!
unregister
)
{
dst
->
input
=
dst
->
output
=
dst_discard
;
}
else
{
struct
neighbour
*
neigh
;
dst
->
dev
=
dev_net
(
dst
->
dev
)
->
loopback_dev
;
dev_hold
(
dst
->
dev
);
dev_put
(
dev
);
rcu_read_lock
();
neigh
=
dst_get_neighbour_noref
(
dst
);
if
(
neigh
&&
neigh
->
dev
==
dev
)
{
neigh
->
dev
=
dst
->
dev
;
dev_hold
(
dst
->
dev
);
dev_put
(
dev
);
}
rcu_read_unlock
();
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录