Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
4b97ad0a
Commit
4b97ad0a
authored
Oct 20, 2002
by
Arnaldo Carvalho de Melo
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
o ipv4: move /proc/net/arp seq_file support back to arp.c
This also buries ip_proc.c.
parent
414ae5bb
Changes
7
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
367 additions
and
351 deletions
+367
-351
include/linux/udp.h
include/linux/udp.h
+3
-0
include/net/arp.h
include/net/arp.h
+0
-1
net/ipv4/Makefile
net/ipv4/Makefile
+1
-1
net/ipv4/af_inet.c
net/ipv4/af_inet.c
+67
-2
net/ipv4/arp.c
net/ipv4/arp.c
+284
-3
net/ipv4/ip_proc.c
net/ipv4/ip_proc.c
+0
-344
net/ipv4/udp.c
net/ipv4/udp.c
+12
-0
No files found.
include/linux/udp.h
View file @
4b97ad0a
...
@@ -57,4 +57,7 @@ struct udp_sock {
...
@@ -57,4 +57,7 @@ struct udp_sock {
#define udp_sk(__sk) (&((struct udp_sock *)__sk)->udp)
#define udp_sk(__sk) (&((struct udp_sock *)__sk)->udp)
extern
int
udp_proc_init
(
void
);
extern
void
udp_proc_exit
(
void
);
#endif
/* _LINUX_UDP_H */
#endif
/* _LINUX_UDP_H */
include/net/arp.h
View file @
4b97ad0a
...
@@ -18,7 +18,6 @@ extern void arp_send(int type, int ptype, u32 dest_ip,
...
@@ -18,7 +18,6 @@ extern void arp_send(int type, int ptype, u32 dest_ip,
extern
int
arp_bind_neighbour
(
struct
dst_entry
*
dst
);
extern
int
arp_bind_neighbour
(
struct
dst_entry
*
dst
);
extern
int
arp_mc_map
(
u32
addr
,
u8
*
haddr
,
struct
net_device
*
dev
,
int
dir
);
extern
int
arp_mc_map
(
u32
addr
,
u8
*
haddr
,
struct
net_device
*
dev
,
int
dir
);
extern
void
arp_ifdown
(
struct
net_device
*
dev
);
extern
void
arp_ifdown
(
struct
net_device
*
dev
);
extern
unsigned
arp_state_to_flags
(
struct
neighbour
*
neigh
);
extern
struct
neigh_ops
arp_broken_ops
;
extern
struct
neigh_ops
arp_broken_ops
;
...
...
net/ipv4/Makefile
View file @
4b97ad0a
...
@@ -4,7 +4,7 @@
...
@@ -4,7 +4,7 @@
obj-y
:=
utils.o route.o inetpeer.o proc.o protocol.o
\
obj-y
:=
utils.o route.o inetpeer.o proc.o protocol.o
\
ip_input.o ip_fragment.o ip_forward.o ip_options.o
\
ip_input.o ip_fragment.o ip_forward.o ip_options.o
\
ip_output.o ip_sockglue.o
ip_proc.o
\
ip_output.o ip_sockglue.o
\
tcp.o tcp_input.o tcp_output.o tcp_timer.o tcp_ipv4.o tcp_minisocks.o
\
tcp.o tcp_input.o tcp_output.o tcp_timer.o tcp_ipv4.o tcp_minisocks.o
\
tcp_diag.o raw.o udp.o arp.o icmp.o devinet.o af_inet.o igmp.o
\
tcp_diag.o raw.o udp.o arp.o icmp.o devinet.o af_inet.o igmp.o
\
sysctl_net_ipv4.o fib_frontend.o fib_semantics.o fib_hash.o
sysctl_net_ipv4.o fib_frontend.o fib_semantics.o fib_hash.o
...
...
net/ipv4/af_inet.c
View file @
4b97ad0a
...
@@ -102,6 +102,8 @@
...
@@ -102,6 +102,8 @@
#include <net/tcp.h>
#include <net/tcp.h>
#include <net/udp.h>
#include <net/udp.h>
#include <linux/skbuff.h>
#include <linux/skbuff.h>
#include <linux/proc_fs.h>
#include <linux/seq_file.h>
#include <net/sock.h>
#include <net/sock.h>
#include <net/raw.h>
#include <net/raw.h>
#include <net/icmp.h>
#include <net/icmp.h>
...
@@ -1123,6 +1125,8 @@ static struct inet_protocol icmp_protocol = {
...
@@ -1123,6 +1125,8 @@ static struct inet_protocol icmp_protocol = {
.
handler
=
icmp_rcv
,
.
handler
=
icmp_rcv
,
};
};
int
ipv4_proc_init
(
void
);
static
int
__init
inet_init
(
void
)
static
int
__init
inet_init
(
void
)
{
{
struct
sk_buff
*
dummy_skb
;
struct
sk_buff
*
dummy_skb
;
...
@@ -1218,9 +1222,70 @@ static int __init inet_init(void)
...
@@ -1218,9 +1222,70 @@ static int __init inet_init(void)
#endif
#endif
ipv4_proc_init
();
ipv4_proc_init
();
udp_proc_init
();
fib_proc_init
();
return
0
;
return
0
;
}
}
module_init
(
inet_init
);
module_init
(
inet_init
);
/* ------------------------------------------------------------------------ */
#ifdef CONFIG_PROC_FS
extern
int
raw_get_info
(
char
*
,
char
**
,
off_t
,
int
);
extern
int
snmp_get_info
(
char
*
,
char
**
,
off_t
,
int
);
extern
int
netstat_get_info
(
char
*
,
char
**
,
off_t
,
int
);
extern
int
afinet_get_info
(
char
*
,
char
**
,
off_t
,
int
);
extern
int
tcp_get_info
(
char
*
,
char
**
,
off_t
,
int
);
extern
int
udp_get_info
(
char
*
,
char
**
,
off_t
,
int
);
int
__init
ipv4_proc_init
(
void
)
{
int
rc
=
0
;
if
(
!
proc_net_create
(
"raw"
,
0
,
raw_get_info
))
goto
out_raw
;
if
(
!
proc_net_create
(
"netstat"
,
0
,
netstat_get_info
))
goto
out_netstat
;
if
(
!
proc_net_create
(
"snmp"
,
0
,
snmp_get_info
))
goto
out_snmp
;
if
(
!
proc_net_create
(
"sockstat"
,
0
,
afinet_get_info
))
goto
out_sockstat
;
if
(
!
proc_net_create
(
"tcp"
,
0
,
tcp_get_info
))
goto
out_tcp
;
if
(
udp_proc_init
())
goto
out_udp
;
if
(
fib_proc_init
())
goto
out_fib
;
out:
return
rc
;
out_fib:
udp_proc_exit
();
out_udp:
proc_net_remove
(
"tcp"
);
out_tcp:
proc_net_remove
(
"sockstat"
);
out_sockstat:
proc_net_remove
(
"snmp"
);
out_snmp:
proc_net_remove
(
"netstat"
);
out_netstat:
proc_net_remove
(
"raw"
);
out_raw:
rc
=
-
ENOMEM
;
goto
out
;
}
int
ip_seq_release
(
struct
inode
*
inode
,
struct
file
*
file
)
{
struct
seq_file
*
seq
=
(
struct
seq_file
*
)
file
->
private_data
;
kfree
(
seq
->
private
);
seq
->
private
=
NULL
;
return
seq_release
(
inode
,
file
);
}
#else
/* CONFIG_PROC_FS */
int
__init
ipv4_proc_init
(
void
)
{
return
0
;
}
#endif
/* CONFIG_PROC_FS */
net/ipv4/arp.c
View file @
4b97ad0a
...
@@ -66,8 +66,7 @@
...
@@ -66,8 +66,7 @@
* Alexey Kuznetsov: new arp state machine;
* Alexey Kuznetsov: new arp state machine;
* now it is in net/core/neighbour.c.
* now it is in net/core/neighbour.c.
* Krzysztof Halasa: Added Frame Relay ARP support.
* Krzysztof Halasa: Added Frame Relay ARP support.
* Arnaldo C. Melo : move proc stuff to seq_file and
* Arnaldo C. Melo : convert /proc/net/arp to seq_file
* net/ipv4/ip_proc.c
*/
*/
#include <linux/types.h>
#include <linux/types.h>
...
@@ -87,6 +86,8 @@
...
@@ -87,6 +86,8 @@
#include <linux/if_arp.h>
#include <linux/if_arp.h>
#include <linux/trdevice.h>
#include <linux/trdevice.h>
#include <linux/skbuff.h>
#include <linux/skbuff.h>
#include <linux/proc_fs.h>
#include <linux/seq_file.h>
#include <linux/stat.h>
#include <linux/stat.h>
#include <linux/init.h>
#include <linux/init.h>
#ifdef CONFIG_SYSCTL
#ifdef CONFIG_SYSCTL
...
@@ -919,7 +920,7 @@ int arp_req_set(struct arpreq *r, struct net_device * dev)
...
@@ -919,7 +920,7 @@ int arp_req_set(struct arpreq *r, struct net_device * dev)
return
err
;
return
err
;
}
}
unsigned
arp_state_to_flags
(
struct
neighbour
*
neigh
)
static
unsigned
arp_state_to_flags
(
struct
neighbour
*
neigh
)
{
{
unsigned
flags
=
0
;
unsigned
flags
=
0
;
if
(
neigh
->
nud_state
&
NUD_PERMANENT
)
if
(
neigh
->
nud_state
&
NUD_PERMANENT
)
...
@@ -1087,13 +1088,293 @@ static struct packet_type arp_packet_type = {
...
@@ -1087,13 +1088,293 @@ static struct packet_type arp_packet_type = {
.
data
=
(
void
*
)
1
,
/* understand shared skbs */
.
data
=
(
void
*
)
1
,
/* understand shared skbs */
};
};
static
int
arp_proc_init
(
void
);
void
__init
arp_init
(
void
)
void
__init
arp_init
(
void
)
{
{
neigh_table_init
(
&
arp_tbl
);
neigh_table_init
(
&
arp_tbl
);
dev_add_pack
(
&
arp_packet_type
);
dev_add_pack
(
&
arp_packet_type
);
arp_proc_init
();
#ifdef CONFIG_SYSCTL
#ifdef CONFIG_SYSCTL
neigh_sysctl_register
(
NULL
,
&
arp_tbl
.
parms
,
NET_IPV4
,
neigh_sysctl_register
(
NULL
,
&
arp_tbl
.
parms
,
NET_IPV4
,
NET_IPV4_NEIGH
,
"ipv4"
);
NET_IPV4_NEIGH
,
"ipv4"
);
#endif
#endif
}
}
#ifdef CONFIG_PROC_FS
#if defined(CONFIG_AX25) || defined(CONFIG_AX25_MODULE)
/* ------------------------------------------------------------------------ */
/*
* ax25 -> ASCII conversion
*/
static
char
*
ax2asc2
(
ax25_address
*
a
,
char
*
buf
)
{
char
c
,
*
s
;
int
n
;
for
(
n
=
0
,
s
=
buf
;
n
<
6
;
n
++
)
{
c
=
(
a
->
ax25_call
[
n
]
>>
1
)
&
0x7F
;
if
(
c
!=
' '
)
*
s
++
=
c
;
}
*
s
++
=
'-'
;
if
((
n
=
((
a
->
ax25_call
[
6
]
>>
1
)
&
0x0F
))
>
9
)
{
*
s
++
=
'1'
;
n
-=
10
;
}
*
s
++
=
n
+
'0'
;
*
s
++
=
'\0'
;
if
(
*
buf
==
'\0'
||
*
buf
==
'-'
)
return
"*"
;
return
buf
;
}
#endif
/* CONFIG_AX25 */
struct
arp_iter_state
{
int
is_pneigh
,
bucket
;
};
static
__inline__
struct
neighbour
*
neigh_get_bucket
(
struct
seq_file
*
seq
,
loff_t
*
pos
)
{
struct
neighbour
*
n
=
NULL
;
struct
arp_iter_state
*
state
=
seq
->
private
;
loff_t
l
=
*
pos
;
int
i
;
for
(;
state
->
bucket
<=
NEIGH_HASHMASK
;
++
state
->
bucket
)
for
(
i
=
0
,
n
=
arp_tbl
.
hash_buckets
[
state
->
bucket
];
n
;
++
i
,
n
=
n
->
next
)
/* Do not confuse users "arp -a" with magic entries */
if
((
n
->
nud_state
&
~
NUD_NOARP
)
&&
!
l
--
)
{
*
pos
=
i
;
goto
out
;
}
out:
return
n
;
}
static
__inline__
struct
pneigh_entry
*
pneigh_get_bucket
(
struct
seq_file
*
seq
,
loff_t
*
pos
)
{
struct
pneigh_entry
*
n
=
NULL
;
struct
arp_iter_state
*
state
=
seq
->
private
;
loff_t
l
=
*
pos
;
int
i
;
for
(;
state
->
bucket
<=
PNEIGH_HASHMASK
;
++
state
->
bucket
)
for
(
i
=
0
,
n
=
arp_tbl
.
phash_buckets
[
state
->
bucket
];
n
;
++
i
,
n
=
n
->
next
)
if
(
!
l
--
)
{
*
pos
=
i
;
goto
out
;
}
out:
return
n
;
}
static
__inline__
void
*
arp_get_bucket
(
struct
seq_file
*
seq
,
loff_t
*
pos
)
{
void
*
rc
=
neigh_get_bucket
(
seq
,
pos
);
if
(
!
rc
)
{
struct
arp_iter_state
*
state
=
seq
->
private
;
read_unlock_bh
(
&
arp_tbl
.
lock
);
state
->
is_pneigh
=
1
;
state
->
bucket
=
0
;
*
pos
=
0
;
rc
=
pneigh_get_bucket
(
seq
,
pos
);
}
return
rc
;
}
static
void
*
arp_seq_start
(
struct
seq_file
*
seq
,
loff_t
*
pos
)
{
read_lock_bh
(
&
arp_tbl
.
lock
);
return
*
pos
?
arp_get_bucket
(
seq
,
pos
)
:
(
void
*
)
1
;
}
static
void
*
arp_seq_next
(
struct
seq_file
*
seq
,
void
*
v
,
loff_t
*
pos
)
{
void
*
rc
;
struct
arp_iter_state
*
state
;
if
(
v
==
(
void
*
)
1
)
{
rc
=
arp_get_bucket
(
seq
,
pos
);
goto
out
;
}
state
=
seq
->
private
;
if
(
!
state
->
is_pneigh
)
{
struct
neighbour
*
n
=
v
;
rc
=
n
=
n
->
next
;
if
(
n
)
goto
out
;
*
pos
=
0
;
++
state
->
bucket
;
rc
=
neigh_get_bucket
(
seq
,
pos
);
if
(
rc
)
goto
out
;
read_unlock_bh
(
&
arp_tbl
.
lock
);
state
->
is_pneigh
=
1
;
state
->
bucket
=
0
;
*
pos
=
0
;
rc
=
pneigh_get_bucket
(
seq
,
pos
);
}
else
{
struct
pneigh_entry
*
pn
=
v
;
pn
=
pn
->
next
;
if
(
!
pn
)
{
++
state
->
bucket
;
*
pos
=
0
;
pn
=
pneigh_get_bucket
(
seq
,
pos
);
}
rc
=
pn
;
}
out:
++*
pos
;
return
rc
;
}
static
void
arp_seq_stop
(
struct
seq_file
*
seq
,
void
*
v
)
{
struct
arp_iter_state
*
state
=
seq
->
private
;
if
(
!
state
->
is_pneigh
)
read_unlock_bh
(
&
arp_tbl
.
lock
);
}
#define HBUFFERLEN 30
static
__inline__
void
arp_format_neigh_entry
(
struct
seq_file
*
seq
,
struct
neighbour
*
n
)
{
char
hbuffer
[
HBUFFERLEN
];
const
char
hexbuf
[]
=
"0123456789ABCDEF"
;
int
k
,
j
;
char
tbuf
[
16
];
struct
net_device
*
dev
=
n
->
dev
;
int
hatype
=
dev
->
type
;
read_lock
(
&
n
->
lock
);
/* Convert hardware address to XX:XX:XX:XX ... form. */
#if defined(CONFIG_AX25) || defined(CONFIG_AX25_MODULE)
if
(
hatype
==
ARPHRD_AX25
||
hatype
==
ARPHRD_NETROM
)
ax2asc2
((
ax25_address
*
)
n
->
ha
,
hbuffer
);
else
{
#endif
for
(
k
=
0
,
j
=
0
;
k
<
HBUFFERLEN
-
3
&&
j
<
dev
->
addr_len
;
j
++
)
{
hbuffer
[
k
++
]
=
hexbuf
[(
n
->
ha
[
j
]
>>
4
)
&
15
];
hbuffer
[
k
++
]
=
hexbuf
[
n
->
ha
[
j
]
&
15
];
hbuffer
[
k
++
]
=
':'
;
}
hbuffer
[
--
k
]
=
0
;
#if defined(CONFIG_AX25) || defined(CONFIG_AX25_MODULE)
}
#endif
sprintf
(
tbuf
,
"%u.%u.%u.%u"
,
NIPQUAD
(
*
(
u32
*
)
n
->
primary_key
));
seq_printf
(
seq
,
"%-16s 0x%-10x0x%-10x%s * %s
\n
"
,
tbuf
,
hatype
,
arp_state_to_flags
(
n
),
hbuffer
,
dev
->
name
);
read_unlock
(
&
n
->
lock
);
}
static
__inline__
void
arp_format_pneigh_entry
(
struct
seq_file
*
seq
,
struct
pneigh_entry
*
n
)
{
struct
net_device
*
dev
=
n
->
dev
;
int
hatype
=
dev
?
dev
->
type
:
0
;
char
tbuf
[
16
];
sprintf
(
tbuf
,
"%u.%u.%u.%u"
,
NIPQUAD
(
*
(
u32
*
)
n
->
key
));
seq_printf
(
seq
,
"%-16s 0x%-10x0x%-10x%s * %s
\n
"
,
tbuf
,
hatype
,
ATF_PUBL
|
ATF_PERM
,
"00:00:00:00:00:00"
,
dev
?
dev
->
name
:
"*"
);
}
static
int
arp_seq_show
(
struct
seq_file
*
seq
,
void
*
v
)
{
if
(
v
==
(
void
*
)
1
)
seq_puts
(
seq
,
"IP address HW type Flags "
"HW address Mask Device
\n
"
);
else
{
struct
arp_iter_state
*
state
=
seq
->
private
;
if
(
state
->
is_pneigh
)
arp_format_pneigh_entry
(
seq
,
v
);
else
arp_format_neigh_entry
(
seq
,
v
);
}
return
0
;
}
/* ------------------------------------------------------------------------ */
static
struct
seq_operations
arp_seq_ops
=
{
.
start
=
arp_seq_start
,
.
next
=
arp_seq_next
,
.
stop
=
arp_seq_stop
,
.
show
=
arp_seq_show
,
};
static
int
arp_seq_open
(
struct
inode
*
inode
,
struct
file
*
file
)
{
struct
seq_file
*
seq
;
int
rc
=
-
ENOMEM
;
struct
arp_iter_state
*
s
=
kmalloc
(
sizeof
(
*
s
),
GFP_KERNEL
);
if
(
!
s
)
goto
out
;
rc
=
seq_open
(
file
,
&
arp_seq_ops
);
if
(
rc
)
goto
out_kfree
;
seq
=
file
->
private_data
;
seq
->
private
=
s
;
memset
(
s
,
0
,
sizeof
(
*
s
));
out:
return
rc
;
out_kfree:
kfree
(
s
);
goto
out
;
}
static
struct
file_operations
arp_seq_fops
=
{
.
open
=
arp_seq_open
,
.
read
=
seq_read
,
.
llseek
=
seq_lseek
,
.
release
=
ip_seq_release
,
};
static
int
__init
arp_proc_init
(
void
)
{
int
rc
=
0
;
struct
proc_dir_entry
*
p
=
create_proc_entry
(
"arp"
,
S_IRUGO
,
proc_net
);
if
(
p
)
p
->
proc_fops
=
&
arp_seq_fops
;
else
rc
=
-
ENOMEM
;
return
rc
;
}
#else
/* CONFIG_PROC_FS */
static
int
__init
arp_proc_init
(
void
)
{
return
0
;
}
#endif
/* CONFIG_PROC_FS */
net/ipv4/ip_proc.c
deleted
100644 → 0
View file @
414ae5bb
/*
* INET An implementation of the TCP/IP protocol suite for the LINUX
* operating system. INET is implemented using the BSD Socket
* interface as the means of communication with the user level.
*
* ipv4 proc support
*
* Arnaldo Carvalho de Melo <acme@conectiva.com.br>, 2002/10/10
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; version 2 of the
* License
*/
#include <linux/config.h>
#include <linux/init.h>
#include <linux/netdevice.h>
#include <net/neighbour.h>
#include <net/arp.h>
#include <linux/seq_file.h>
#include <linux/proc_fs.h>
extern
int
raw_get_info
(
char
*
,
char
**
,
off_t
,
int
);
extern
int
snmp_get_info
(
char
*
,
char
**
,
off_t
,
int
);
extern
int
netstat_get_info
(
char
*
,
char
**
,
off_t
,
int
);
extern
int
afinet_get_info
(
char
*
,
char
**
,
off_t
,
int
);
extern
int
tcp_get_info
(
char
*
,
char
**
,
off_t
,
int
);
#ifdef CONFIG_PROC_FS
#ifdef CONFIG_AX25
/* ------------------------------------------------------------------------ */
/*
* ax25 -> ASCII conversion
*/
static
char
*
ax2asc2
(
ax25_address
*
a
,
char
*
buf
)
{
char
c
,
*
s
;
int
n
;
for
(
n
=
0
,
s
=
buf
;
n
<
6
;
n
++
)
{
c
=
(
a
->
ax25_call
[
n
]
>>
1
)
&
0x7F
;
if
(
c
!=
' '
)
*
s
++
=
c
;
}
*
s
++
=
'-'
;
if
((
n
=
((
a
->
ax25_call
[
6
]
>>
1
)
&
0x0F
))
>
9
)
{
*
s
++
=
'1'
;
n
-=
10
;
}
*
s
++
=
n
+
'0'
;
*
s
++
=
'\0'
;
if
(
*
buf
==
'\0'
||
*
buf
==
'-'
)
return
"*"
;
return
buf
;
}
#endif
/* CONFIG_AX25 */
struct
arp_iter_state
{
int
is_pneigh
,
bucket
;
};
static
__inline__
struct
neighbour
*
neigh_get_bucket
(
struct
seq_file
*
seq
,
loff_t
*
pos
)
{
struct
neighbour
*
n
=
NULL
;
struct
arp_iter_state
*
state
=
seq
->
private
;
loff_t
l
=
*
pos
;
int
i
;
for
(;
state
->
bucket
<=
NEIGH_HASHMASK
;
++
state
->
bucket
)
for
(
i
=
0
,
n
=
arp_tbl
.
hash_buckets
[
state
->
bucket
];
n
;
++
i
,
n
=
n
->
next
)
/* Do not confuse users "arp -a" with magic entries */
if
((
n
->
nud_state
&
~
NUD_NOARP
)
&&
!
l
--
)
{
*
pos
=
i
;
goto
out
;
}
out:
return
n
;
}
static
__inline__
struct
pneigh_entry
*
pneigh_get_bucket
(
struct
seq_file
*
seq
,
loff_t
*
pos
)
{
struct
pneigh_entry
*
n
=
NULL
;
struct
arp_iter_state
*
state
=
seq
->
private
;
loff_t
l
=
*
pos
;
int
i
;
for
(;
state
->
bucket
<=
PNEIGH_HASHMASK
;
++
state
->
bucket
)
for
(
i
=
0
,
n
=
arp_tbl
.
phash_buckets
[
state
->
bucket
];
n
;
++
i
,
n
=
n
->
next
)
if
(
!
l
--
)
{
*
pos
=
i
;
goto
out
;
}
out:
return
n
;
}
static
__inline__
void
*
arp_get_bucket
(
struct
seq_file
*
seq
,
loff_t
*
pos
)
{
void
*
rc
=
neigh_get_bucket
(
seq
,
pos
);
if
(
!
rc
)
{
struct
arp_iter_state
*
state
=
seq
->
private
;
read_unlock_bh
(
&
arp_tbl
.
lock
);
state
->
is_pneigh
=
1
;
state
->
bucket
=
0
;
*
pos
=
0
;
rc
=
pneigh_get_bucket
(
seq
,
pos
);
}
return
rc
;
}
static
void
*
arp_seq_start
(
struct
seq_file
*
seq
,
loff_t
*
pos
)
{
read_lock_bh
(
&
arp_tbl
.
lock
);
return
*
pos
?
arp_get_bucket
(
seq
,
pos
)
:
(
void
*
)
1
;
}
static
void
*
arp_seq_next
(
struct
seq_file
*
seq
,
void
*
v
,
loff_t
*
pos
)
{
void
*
rc
;
struct
arp_iter_state
*
state
;
if
(
v
==
(
void
*
)
1
)
{
rc
=
arp_get_bucket
(
seq
,
pos
);
goto
out
;
}
state
=
seq
->
private
;
if
(
!
state
->
is_pneigh
)
{
struct
neighbour
*
n
=
v
;
rc
=
n
=
n
->
next
;
if
(
n
)
goto
out
;
*
pos
=
0
;
++
state
->
bucket
;
rc
=
neigh_get_bucket
(
seq
,
pos
);
if
(
rc
)
goto
out
;
read_unlock_bh
(
&
arp_tbl
.
lock
);
state
->
is_pneigh
=
1
;
state
->
bucket
=
0
;
*
pos
=
0
;
rc
=
pneigh_get_bucket
(
seq
,
pos
);
}
else
{
struct
pneigh_entry
*
pn
=
v
;
pn
=
pn
->
next
;
if
(
!
pn
)
{
++
state
->
bucket
;
*
pos
=
0
;
pn
=
pneigh_get_bucket
(
seq
,
pos
);
}
rc
=
pn
;
}
out:
++*
pos
;
return
rc
;
}
static
void
arp_seq_stop
(
struct
seq_file
*
seq
,
void
*
v
)
{
struct
arp_iter_state
*
state
=
seq
->
private
;
if
(
!
state
->
is_pneigh
)
read_unlock_bh
(
&
arp_tbl
.
lock
);
}
#define HBUFFERLEN 30
static
__inline__
void
arp_format_neigh_entry
(
struct
seq_file
*
seq
,
struct
neighbour
*
n
)
{
char
hbuffer
[
HBUFFERLEN
];
const
char
hexbuf
[]
=
"0123456789ABCDEF"
;
int
k
,
j
;
char
tbuf
[
16
];
struct
net_device
*
dev
=
n
->
dev
;
int
hatype
=
dev
->
type
;
read_lock
(
&
n
->
lock
);
/* Convert hardware address to XX:XX:XX:XX ... form. */
#ifdef CONFIG_AX25
if
(
hatype
==
ARPHRD_AX25
||
hatype
==
ARPHRD_NETROM
)
ax2asc2
((
ax25_address
*
)
n
->
ha
,
hbuffer
);
else
{
#endif
for
(
k
=
0
,
j
=
0
;
k
<
HBUFFERLEN
-
3
&&
j
<
dev
->
addr_len
;
j
++
)
{
hbuffer
[
k
++
]
=
hexbuf
[(
n
->
ha
[
j
]
>>
4
)
&
15
];
hbuffer
[
k
++
]
=
hexbuf
[
n
->
ha
[
j
]
&
15
];
hbuffer
[
k
++
]
=
':'
;
}
hbuffer
[
--
k
]
=
0
;
#ifdef CONFIG_AX25
}
#endif
sprintf
(
tbuf
,
"%u.%u.%u.%u"
,
NIPQUAD
(
*
(
u32
*
)
n
->
primary_key
));
seq_printf
(
seq
,
"%-16s 0x%-10x0x%-10x%s * %s
\n
"
,
tbuf
,
hatype
,
arp_state_to_flags
(
n
),
hbuffer
,
dev
->
name
);
read_unlock
(
&
n
->
lock
);
}
static
__inline__
void
arp_format_pneigh_entry
(
struct
seq_file
*
seq
,
struct
pneigh_entry
*
n
)
{
struct
net_device
*
dev
=
n
->
dev
;
int
hatype
=
dev
?
dev
->
type
:
0
;
char
tbuf
[
16
];
sprintf
(
tbuf
,
"%u.%u.%u.%u"
,
NIPQUAD
(
*
(
u32
*
)
n
->
key
));
seq_printf
(
seq
,
"%-16s 0x%-10x0x%-10x%s * %s
\n
"
,
tbuf
,
hatype
,
ATF_PUBL
|
ATF_PERM
,
"00:00:00:00:00:00"
,
dev
?
dev
->
name
:
"*"
);
}
static
int
arp_seq_show
(
struct
seq_file
*
seq
,
void
*
v
)
{
if
(
v
==
(
void
*
)
1
)
seq_puts
(
seq
,
"IP address HW type Flags "
"HW address Mask Device
\n
"
);
else
{
struct
arp_iter_state
*
state
=
seq
->
private
;
if
(
state
->
is_pneigh
)
arp_format_pneigh_entry
(
seq
,
v
);
else
arp_format_neigh_entry
(
seq
,
v
);
}
return
0
;
}
/* ------------------------------------------------------------------------ */
static
struct
seq_operations
arp_seq_ops
=
{
.
start
=
arp_seq_start
,
.
next
=
arp_seq_next
,
.
stop
=
arp_seq_stop
,
.
show
=
arp_seq_show
,
};
static
int
arp_seq_open
(
struct
inode
*
inode
,
struct
file
*
file
)
{
struct
seq_file
*
seq
;
int
rc
=
-
ENOMEM
;
struct
arp_iter_state
*
s
=
kmalloc
(
sizeof
(
*
s
),
GFP_KERNEL
);
if
(
!
s
)
goto
out
;
rc
=
seq_open
(
file
,
&
arp_seq_ops
);
if
(
rc
)
goto
out_kfree
;
seq
=
file
->
private_data
;
seq
->
private
=
s
;
memset
(
s
,
0
,
sizeof
(
*
s
));
out:
return
rc
;
out_kfree:
kfree
(
s
);
goto
out
;
}
int
ip_seq_release
(
struct
inode
*
inode
,
struct
file
*
file
)
{
struct
seq_file
*
seq
=
(
struct
seq_file
*
)
file
->
private_data
;
kfree
(
seq
->
private
);
seq
->
private
=
NULL
;
return
seq_release
(
inode
,
file
);
}
static
struct
file_operations
arp_seq_fops
=
{
.
open
=
arp_seq_open
,
.
read
=
seq_read
,
.
llseek
=
seq_lseek
,
.
release
=
ip_seq_release
,
};
/* ------------------------------------------------------------------------ */
int
__init
ipv4_proc_init
(
void
)
{
struct
proc_dir_entry
*
p
;
int
rc
=
0
;
if
(
!
proc_net_create
(
"raw"
,
0
,
raw_get_info
))
goto
out_raw
;
if
(
!
proc_net_create
(
"netstat"
,
0
,
netstat_get_info
))
goto
out_netstat
;
if
(
!
proc_net_create
(
"snmp"
,
0
,
snmp_get_info
))
goto
out_snmp
;
if
(
!
proc_net_create
(
"sockstat"
,
0
,
afinet_get_info
))
goto
out_sockstat
;
if
(
!
proc_net_create
(
"tcp"
,
0
,
tcp_get_info
))
goto
out_tcp
;
p
=
create_proc_entry
(
"arp"
,
S_IRUGO
,
proc_net
);
if
(
!
p
)
goto
out_arp
;
p
->
proc_fops
=
&
arp_seq_fops
;
out:
return
rc
;
out_arp:
proc_net_remove
(
"tcp"
);
out_tcp:
proc_net_remove
(
"sockstat"
);
out_sockstat:
proc_net_remove
(
"snmp"
);
out_snmp:
proc_net_remove
(
"netstat"
);
out_netstat:
proc_net_remove
(
"raw"
);
out_raw:
rc
=
-
ENOMEM
;
goto
out
;
}
#else
/* CONFIG_PROC_FS */
int
__init
ipv4_proc_init
(
void
)
{
return
0
;
}
#endif
/* CONFIG_PROC_FS */
net/ipv4/udp.c
View file @
4b97ad0a
...
@@ -1360,9 +1360,21 @@ int __init udp_proc_init(void)
...
@@ -1360,9 +1360,21 @@ int __init udp_proc_init(void)
rc
=
-
ENOMEM
;
rc
=
-
ENOMEM
;
return
rc
;
return
rc
;
}
}
void
__init
udp_proc_exit
(
void
)
{
remove_proc_entry
(
"udp"
,
proc_net
);
}
#else
/* CONFIG_PROC_FS */
#else
/* CONFIG_PROC_FS */
int
__init
udp_proc_init
(
void
)
int
__init
udp_proc_init
(
void
)
{
{
return
0
;
return
0
;
}
}
void
__init
udp_proc_exit
(
void
)
{
return
0
;
}
#endif
/* CONFIG_PROC_FS */
#endif
/* CONFIG_PROC_FS */
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment