Commit 26a2fcbd authored by Hideaki Yoshifuji's avatar Hideaki Yoshifuji Committed by David S. Miller

[IPV6]: Convert /proc/net/udp6 to seq_file.

parent 2170b688
...@@ -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:
......
...@@ -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);
sprintf(tmpbuf, seq_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",
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment