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
Kirill Smelkov
linux
Commits
26a2fcbd
Commit
26a2fcbd
authored
May 25, 2003
by
Hideaki Yoshifuji
Committed by
David S. Miller
May 25, 2003
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[IPV6]: Convert /proc/net/udp6 to seq_file.
parent
2170b688
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
57 additions
and
61 deletions
+57
-61
net/ipv6/af_inet6.c
net/ipv6/af_inet6.c
+5
-3
net/ipv6/udp.c
net/ipv6/udp.c
+52
-58
No files found.
net/ipv6/af_inet6.c
View file @
26a2fcbd
...
@@ -78,7 +78,9 @@ extern int raw6_proc_init(void);
...
@@ -78,7 +78,9 @@ extern int raw6_proc_init(void);
extern
int
raw6_proc_exit
(
void
);
extern
int
raw6_proc_exit
(
void
);
extern
int
tcp6_get_info
(
char
*
,
char
**
,
off_t
,
int
);
extern
int
tcp6_get_info
(
char
*
,
char
**
,
off_t
,
int
);
extern
int
udp6_get_info
(
char
*
,
char
**
,
off_t
,
int
);
extern
int
udp6_proc_init
(
void
);
extern
void
udp6_proc_exit
(
void
);
extern
int
ipv6_misc_proc_init
(
void
);
extern
int
ipv6_misc_proc_init
(
void
);
extern
int
ipv6_misc_proc_exit
(
void
);
extern
int
ipv6_misc_proc_exit
(
void
);
...
@@ -789,7 +791,7 @@ static int __init inet6_init(void)
...
@@ -789,7 +791,7 @@ static int __init inet6_init(void)
goto
proc_raw6_fail
;
goto
proc_raw6_fail
;
if
(
!
proc_net_create
(
"tcp6"
,
0
,
tcp6_get_info
))
if
(
!
proc_net_create
(
"tcp6"
,
0
,
tcp6_get_info
))
goto
proc_tcp6_fail
;
goto
proc_tcp6_fail
;
if
(
!
proc_net_create
(
"udp6"
,
0
,
udp6_get_info
))
if
(
udp6_proc_init
(
))
goto
proc_udp6_fail
;
goto
proc_udp6_fail
;
if
(
ipv6_misc_proc_init
())
if
(
ipv6_misc_proc_init
())
goto
proc_misc6_fail
;
goto
proc_misc6_fail
;
...
@@ -820,7 +822,7 @@ static int __init inet6_init(void)
...
@@ -820,7 +822,7 @@ static int __init inet6_init(void)
proc_anycast6_fail:
proc_anycast6_fail:
ipv6_misc_proc_exit
();
ipv6_misc_proc_exit
();
proc_misc6_fail:
proc_misc6_fail:
proc_net_remove
(
"udp6"
);
udp6_proc_exit
(
);
proc_udp6_fail:
proc_udp6_fail:
proc_net_remove
(
"tcp6"
);
proc_net_remove
(
"tcp6"
);
proc_tcp6_fail:
proc_tcp6_fail:
...
...
net/ipv6/udp.c
View file @
26a2fcbd
...
@@ -15,6 +15,7 @@
...
@@ -15,6 +15,7 @@
* Alexey Kuznetsov allow both IPv4 and IPv6 sockets to bind
* Alexey Kuznetsov allow both IPv4 and IPv6 sockets to bind
* a single port at the same time.
* a single port at the same time.
* Kazunori MIYAZAWA @USAGI: change process style to use ip6_append_data
* Kazunori MIYAZAWA @USAGI: change process style to use ip6_append_data
* YOSHIFUJI Hideaki @USAGI: convert /proc/net/udp6 to seq_file.
*
*
* This program is free software; you can redistribute it and/or
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* modify it under the terms of the GNU General Public License
...
@@ -53,6 +54,9 @@
...
@@ -53,6 +54,9 @@
#include <net/checksum.h>
#include <net/checksum.h>
#include <net/xfrm.h>
#include <net/xfrm.h>
#include <linux/proc_fs.h>
#include <linux/seq_file.h>
DEFINE_SNMP_STAT
(
struct
udp_mib
,
udp_stats_in6
);
DEFINE_SNMP_STAT
(
struct
udp_mib
,
udp_stats_in6
);
/* XXX This is identical to tcp_ipv6.c:ipv6_rcv_saddr_equal, put
/* XXX This is identical to tcp_ipv6.c:ipv6_rcv_saddr_equal, put
...
@@ -1116,10 +1120,10 @@ static struct inet6_protocol udpv6_protocol = {
...
@@ -1116,10 +1120,10 @@ static struct inet6_protocol udpv6_protocol = {
.
flags
=
INET6_PROTO_NOPOLICY
|
INET6_PROTO_FINAL
,
.
flags
=
INET6_PROTO_NOPOLICY
|
INET6_PROTO_FINAL
,
};
};
#define LINE_LEN 190
/* ------------------------------------------------------------------------ */
#
define LINE_FMT "%-190s\n"
#
ifdef CONFIG_PROC_FS
static
void
get_udp6_sock
(
struct
sock
*
sp
,
char
*
tmpbuf
,
int
i
)
static
void
udp6_sock_seq_show
(
struct
seq_file
*
seq
,
struct
sock
*
sp
,
int
bucket
)
{
{
struct
inet_opt
*
inet
=
inet_sk
(
sp
);
struct
inet_opt
*
inet
=
inet_sk
(
sp
);
struct
ipv6_pinfo
*
np
=
inet6_sk
(
sp
);
struct
ipv6_pinfo
*
np
=
inet6_sk
(
sp
);
...
@@ -1130,66 +1134,56 @@ static void get_udp6_sock(struct sock *sp, char *tmpbuf, int i)
...
@@ -1130,66 +1134,56 @@ static void get_udp6_sock(struct sock *sp, char *tmpbuf, int i)
src
=
&
np
->
rcv_saddr
;
src
=
&
np
->
rcv_saddr
;
destp
=
ntohs
(
inet
->
dport
);
destp
=
ntohs
(
inet
->
dport
);
srcp
=
ntohs
(
inet
->
sport
);
srcp
=
ntohs
(
inet
->
sport
);
s
printf
(
tmpbuf
,
s
eq_printf
(
seq
,
"%4d: %08X%08X%08X%08X:%04X %08X%08X%08X%08X:%04X "
"%4d: %08X%08X%08X%08X:%04X %08X%08X%08X%08X:%04X "
"%02X %08X:%08X %02X:%08lX %08X %5d %8d %lu %d %p
"
,
"%02X %08X:%08X %02X:%08lX %08X %5d %8d %lu %d %p
\n
"
,
i
,
bucket
,
src
->
s6_addr32
[
0
],
src
->
s6_addr32
[
1
],
src
->
s6_addr32
[
0
],
src
->
s6_addr32
[
1
],
src
->
s6_addr32
[
2
],
src
->
s6_addr32
[
3
],
srcp
,
src
->
s6_addr32
[
2
],
src
->
s6_addr32
[
3
],
srcp
,
dest
->
s6_addr32
[
0
],
dest
->
s6_addr32
[
1
],
dest
->
s6_addr32
[
0
],
dest
->
s6_addr32
[
1
],
dest
->
s6_addr32
[
2
],
dest
->
s6_addr32
[
3
],
destp
,
dest
->
s6_addr32
[
2
],
dest
->
s6_addr32
[
3
],
destp
,
sp
->
state
,
sp
->
state
,
atomic_read
(
&
sp
->
wmem_alloc
),
atomic_read
(
&
sp
->
rmem_alloc
),
atomic_read
(
&
sp
->
wmem_alloc
),
atomic_read
(
&
sp
->
rmem_alloc
),
0
,
0L
,
0
,
0
,
0L
,
0
,
sock_i_uid
(
sp
),
0
,
sock_i_uid
(
sp
),
0
,
sock_i_ino
(
sp
),
sock_i_ino
(
sp
),
atomic_read
(
&
sp
->
refcnt
),
sp
);
atomic_read
(
&
sp
->
refcnt
),
sp
);
}
}
int
udp6_get_info
(
char
*
buffer
,
char
**
start
,
off_t
offset
,
int
length
)
static
int
udp6_seq_show
(
struct
seq_file
*
seq
,
void
*
v
)
{
{
int
len
=
0
,
num
=
0
,
i
;
if
(
v
==
(
void
*
)
1
)
off_t
pos
=
0
;
seq_printf
(
seq
,
off_t
begin
;
" sl "
char
tmpbuf
[
LINE_LEN
+
2
];
"local_address "
"remote_address "
if
(
offset
<
LINE_LEN
+
1
)
"st tx_queue rx_queue tr tm->when retrnsmt"
len
+=
sprintf
(
buffer
,
LINE_FMT
,
" uid timeout inode
\n
"
);
" sl "
/* 6 */
else
"local_address "
/* 38 */
udp6_sock_seq_show
(
seq
,
v
,
((
struct
udp_iter_state
*
)
seq
->
private
)
->
bucket
);
"remote_address "
/* 38 */
return
0
;
"st tx_queue rx_queue tr tm->when retrnsmt"
/* 41 */
}
" uid timeout inode"
);
/* 21 */
/*----*/
/*144 */
pos
=
LINE_LEN
+
1
;
read_lock
(
&
udp_hash_lock
);
for
(
i
=
0
;
i
<
UDP_HTABLE_SIZE
;
i
++
)
{
struct
sock
*
sk
;
for
(
sk
=
udp_hash
[
i
];
sk
;
sk
=
sk
->
next
,
num
++
)
{
static
struct
file_operations
udp6_seq_fops
;
if
(
sk
->
family
!=
PF_INET6
)
static
struct
udp_seq_afinfo
udp6_seq_afinfo
=
{
continue
;
.
owner
=
THIS_MODULE
,
pos
+=
LINE_LEN
+
1
;
.
name
=
"udp6"
,
if
(
pos
<=
offset
)
.
family
=
AF_INET6
,
continue
;
.
seq_show
=
udp6_seq_show
,
get_udp6_sock
(
sk
,
tmpbuf
,
i
);
.
seq_fops
=
&
udp6_seq_fops
,
len
+=
sprintf
(
buffer
+
len
,
LINE_FMT
,
tmpbuf
);
};
if
(
len
>=
length
)
goto
out
;
int
__init
udp6_proc_init
(
void
)
}
{
}
return
udp_proc_register
(
&
udp6_seq_afinfo
);
out:
}
read_unlock
(
&
udp_hash_lock
);
begin
=
len
-
(
pos
-
offset
);
void
udp6_proc_exit
(
void
)
{
*
start
=
buffer
+
begin
;
udp_proc_unregister
(
&
udp6_seq_afinfo
);
len
-=
begin
;
if
(
len
>
length
)
len
=
length
;
if
(
len
<
0
)
len
=
0
;
return
len
;
}
}
#endif
/* CONFIG_PROC_FS */
/* ------------------------------------------------------------------------ */
struct
proto
udpv6_prot
=
{
struct
proto
udpv6_prot
=
{
.
name
=
"UDP"
,
.
name
=
"UDP"
,
...
...
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