Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
kernel_linux
提交
76abf3e7
K
kernel_linux
项目概览
OpenHarmony
/
kernel_linux
上一次同步 3 年多
通知
13
Star
8
Fork
2
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
kernel_linux
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
76abf3e7
编写于
9月 21, 2005
作者:
L
Linus Torvalds
浏览文件
操作
浏览文件
下载
差异文件
Merge master.kernel.org:/pub/scm/linux/kernel/git/davem/net-2.6
上级
d90d4392
7957aed7
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
52 addition
and
30 deletion
+52
-30
net/ipv4/fib_trie.c
net/ipv4/fib_trie.c
+3
-12
net/ipv4/tcp_minisocks.c
net/ipv4/tcp_minisocks.c
+1
-1
net/packet/af_packet.c
net/packet/af_packet.c
+48
-17
未找到文件。
net/ipv4/fib_trie.c
浏览文件 @
76abf3e7
...
...
@@ -1086,7 +1086,7 @@ fib_insert_node(struct trie *t, int *err, u32 key, int plen)
}
if
(
tp
&&
tp
->
pos
+
tp
->
bits
>
32
)
printk
(
"ERROR
tp=%p pos=%d, bits=%d, key=%0x plen=%d
\n
"
,
printk
(
KERN_WARNING
"fib_trie
tp=%p pos=%d, bits=%d, key=%0x plen=%d
\n
"
,
tp
,
tp
->
pos
,
tp
->
bits
,
key
,
plen
);
/* Rebalance the trie */
...
...
@@ -1832,16 +1832,7 @@ static int fn_trie_dump_fa(t_key key, int plen, struct list_head *fah, struct fi
i
++
;
continue
;
}
if
(
fa
->
fa_info
->
fib_nh
==
NULL
)
{
printk
(
"Trie error _fib_nh=NULL in fa[%d] k=%08x plen=%d
\n
"
,
i
,
key
,
plen
);
i
++
;
continue
;
}
if
(
fa
->
fa_info
==
NULL
)
{
printk
(
"Trie error fa_info=NULL in fa[%d] k=%08x plen=%d
\n
"
,
i
,
key
,
plen
);
i
++
;
continue
;
}
BUG_ON
(
!
fa
->
fa_info
);
if
(
fib_dump_info
(
skb
,
NETLINK_CB
(
cb
->
skb
).
pid
,
cb
->
nlh
->
nlmsg_seq
,
...
...
@@ -1964,7 +1955,7 @@ struct fib_table * __init fib_hash_init(int id)
trie_main
=
t
;
if
(
id
==
RT_TABLE_LOCAL
)
printk
(
"IPv4 FIB: Using LC-trie version %s
\n
"
,
VERSION
);
printk
(
KERN_INFO
"IPv4 FIB: Using LC-trie version %s
\n
"
,
VERSION
);
return
tb
;
}
...
...
net/ipv4/tcp_minisocks.c
浏览文件 @
76abf3e7
...
...
@@ -384,7 +384,7 @@ struct sock *tcp_create_openreq_child(struct sock *sk, struct request_sock *req,
newtp
->
frto_counter
=
0
;
newtp
->
frto_highmark
=
0
;
newicsk
->
icsk_ca_ops
=
&
tcp_
reno
;
newicsk
->
icsk_ca_ops
=
&
tcp_
init_congestion_ops
;
tcp_set_ca_state
(
newsk
,
TCP_CA_Open
);
tcp_init_xmit_timers
(
newsk
);
...
...
net/packet/af_packet.c
浏览文件 @
76abf3e7
...
...
@@ -36,6 +36,11 @@
* Michal Ostrowski : Module initialization cleanup.
* Ulises Alonso : Frame number limit removal and
* packet_set_ring memory leak.
* Eric Biederman : Allow for > 8 byte hardware addresses.
* The convention is that longer addresses
* will simply extend the hardware address
* byte arrays at the end of sockaddr_ll
* and packet_mreq.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
...
...
@@ -161,7 +166,17 @@ struct packet_mclist
int
count
;
unsigned
short
type
;
unsigned
short
alen
;
unsigned
char
addr
[
8
];
unsigned
char
addr
[
MAX_ADDR_LEN
];
};
/* identical to struct packet_mreq except it has
* a longer address field.
*/
struct
packet_mreq_max
{
int
mr_ifindex
;
unsigned
short
mr_type
;
unsigned
short
mr_alen
;
unsigned
char
mr_address
[
MAX_ADDR_LEN
];
};
#endif
#ifdef CONFIG_PACKET_MMAP
...
...
@@ -716,6 +731,8 @@ static int packet_sendmsg(struct kiocb *iocb, struct socket *sock,
err
=
-
EINVAL
;
if
(
msg
->
msg_namelen
<
sizeof
(
struct
sockaddr_ll
))
goto
out
;
if
(
msg
->
msg_namelen
<
(
saddr
->
sll_halen
+
offsetof
(
struct
sockaddr_ll
,
sll_addr
)))
goto
out
;
ifindex
=
saddr
->
sll_ifindex
;
proto
=
saddr
->
sll_protocol
;
addr
=
saddr
->
sll_addr
;
...
...
@@ -744,6 +761,12 @@ static int packet_sendmsg(struct kiocb *iocb, struct socket *sock,
if
(
dev
->
hard_header
)
{
int
res
;
err
=
-
EINVAL
;
if
(
saddr
)
{
if
(
saddr
->
sll_halen
!=
dev
->
addr_len
)
goto
out_free
;
if
(
saddr
->
sll_hatype
!=
dev
->
type
)
goto
out_free
;
}
res
=
dev
->
hard_header
(
skb
,
dev
,
ntohs
(
proto
),
addr
,
NULL
,
len
);
if
(
sock
->
type
!=
SOCK_DGRAM
)
{
skb
->
tail
=
skb
->
data
;
...
...
@@ -1045,6 +1068,7 @@ static int packet_recvmsg(struct kiocb *iocb, struct socket *sock,
struct
sock
*
sk
=
sock
->
sk
;
struct
sk_buff
*
skb
;
int
copied
,
err
;
struct
sockaddr_ll
*
sll
;
err
=
-
EINVAL
;
if
(
flags
&
~
(
MSG_PEEK
|
MSG_DONTWAIT
|
MSG_TRUNC
|
MSG_CMSG_COMPAT
))
...
...
@@ -1056,16 +1080,6 @@ static int packet_recvmsg(struct kiocb *iocb, struct socket *sock,
return -ENODEV;
#endif
/*
* If the address length field is there to be filled in, we fill
* it in now.
*/
if
(
sock
->
type
==
SOCK_PACKET
)
msg
->
msg_namelen
=
sizeof
(
struct
sockaddr_pkt
);
else
msg
->
msg_namelen
=
sizeof
(
struct
sockaddr_ll
);
/*
* Call the generic datagram receiver. This handles all sorts
* of horrible races and re-entrancy so we can forget about it
...
...
@@ -1086,6 +1100,17 @@ static int packet_recvmsg(struct kiocb *iocb, struct socket *sock,
if
(
skb
==
NULL
)
goto
out
;
/*
* If the address length field is there to be filled in, we fill
* it in now.
*/
sll
=
(
struct
sockaddr_ll
*
)
skb
->
cb
;
if
(
sock
->
type
==
SOCK_PACKET
)
msg
->
msg_namelen
=
sizeof
(
struct
sockaddr_pkt
);
else
msg
->
msg_namelen
=
sll
->
sll_halen
+
offsetof
(
struct
sockaddr_ll
,
sll_addr
);
/*
* You lose any data beyond the buffer you gave. If it worries a
* user program they can ask the device for its MTU anyway.
...
...
@@ -1166,7 +1191,7 @@ static int packet_getname(struct socket *sock, struct sockaddr *uaddr,
sll
->
sll_hatype
=
0
;
/* Bad: we have no ARPHRD_UNSPEC */
sll
->
sll_halen
=
0
;
}
*
uaddr_len
=
sizeof
(
*
sll
)
;
*
uaddr_len
=
offsetof
(
struct
sockaddr_ll
,
sll_addr
)
+
sll
->
sll_halen
;
return
0
;
}
...
...
@@ -1199,7 +1224,7 @@ static void packet_dev_mclist(struct net_device *dev, struct packet_mclist *i, i
}
}
static
int
packet_mc_add
(
struct
sock
*
sk
,
struct
packet_mreq
*
mreq
)
static
int
packet_mc_add
(
struct
sock
*
sk
,
struct
packet_mreq
_max
*
mreq
)
{
struct
packet_sock
*
po
=
pkt_sk
(
sk
);
struct
packet_mclist
*
ml
,
*
i
;
...
...
@@ -1249,7 +1274,7 @@ static int packet_mc_add(struct sock *sk, struct packet_mreq *mreq)
return
err
;
}
static
int
packet_mc_drop
(
struct
sock
*
sk
,
struct
packet_mreq
*
mreq
)
static
int
packet_mc_drop
(
struct
sock
*
sk
,
struct
packet_mreq
_max
*
mreq
)
{
struct
packet_mclist
*
ml
,
**
mlp
;
...
...
@@ -1315,11 +1340,17 @@ packet_setsockopt(struct socket *sock, int level, int optname, char __user *optv
case
PACKET_ADD_MEMBERSHIP
:
case
PACKET_DROP_MEMBERSHIP
:
{
struct
packet_mreq
mreq
;
if
(
optlen
<
sizeof
(
mreq
))
struct
packet_mreq_max
mreq
;
int
len
=
optlen
;
memset
(
&
mreq
,
0
,
sizeof
(
mreq
));
if
(
len
<
sizeof
(
struct
packet_mreq
))
return
-
EINVAL
;
if
(
copy_from_user
(
&
mreq
,
optval
,
sizeof
(
mreq
)))
if
(
len
>
sizeof
(
mreq
))
len
=
sizeof
(
mreq
);
if
(
copy_from_user
(
&
mreq
,
optval
,
len
))
return
-
EFAULT
;
if
(
len
<
(
mreq
.
mr_alen
+
offsetof
(
struct
packet_mreq
,
mr_address
)))
return
-
EINVAL
;
if
(
optname
==
PACKET_ADD_MEMBERSHIP
)
ret
=
packet_mc_add
(
sk
,
&
mreq
);
else
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录