| 
									
										
											  
											
												[INET_DIAG]: Move the tcp_diag interface to the proper place
With this the previous setup is back, i.e. tcp_diag can be built as a module,
as dccp_diag and both share the infrastructure available in inet_diag.
If one selects CONFIG_INET_DIAG as module CONFIG_INET_TCP_DIAG will also be
built as a module, as will CONFIG_INET_DCCP_DIAG, if CONFIG_IP_DCCP was
selected static or as a module, if CONFIG_INET_DIAG is y, being statically
linked CONFIG_INET_TCP_DIAG will follow suit and CONFIG_INET_DCCP_DIAG will be
built in the same manner as CONFIG_IP_DCCP.
Now to aim at UDP, converting it to use inet_hashinfo, so that we can use
iproute2 for UDP sockets as well.
Ah, just to show an example of this new infrastructure working for DCCP :-)
[root@qemu ~]# ./ss -dane
State      Recv-Q Send-Q Local Address:Port  Peer Address:Port
LISTEN     0      0                  *:5001             *:*     ino:942 sk:cfd503a0
ESTAB      0      0          127.0.0.1:5001     127.0.0.1:32770 ino:943 sk:cfd50a60
ESTAB      0      0          127.0.0.1:32770    127.0.0.1:5001  ino:947 sk:cfd50700
TIME-WAIT  0      0          127.0.0.1:32769    127.0.0.1:5001  timer:(timewait,3.430ms,0) ino:0 sk:cf209620
Signed-off-by: Arnaldo Carvalho de Melo <acme@mandriva.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
											
										 
											2005-08-12 12:59:17 -03:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * tcp_diag.c	Module for monitoring TCP transport protocols sockets. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Authors:	Alexey Kuznetsov, <kuznet@ms2.inr.ac.ru> | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *	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; either version | 
					
						
							|  |  |  |  *      2 of the License, or (at your option) any later version. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <linux/module.h>
 | 
					
						
							|  |  |  | #include <linux/inet_diag.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <linux/tcp.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <net/tcp.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void tcp_diag_get_info(struct sock *sk, struct inet_diag_msg *r, | 
					
						
							|  |  |  | 			      void *_info) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	const struct tcp_sock *tp = tcp_sk(sk); | 
					
						
							|  |  |  | 	struct tcp_info *info = _info; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-09-18 13:26:31 -07:00
										 |  |  | 	if (sk->sk_state == TCP_LISTEN) { | 
					
						
							| 
									
										
										
										
											2006-06-27 13:29:00 -07:00
										 |  |  | 		r->idiag_rqueue = sk->sk_ack_backlog; | 
					
						
							| 
									
										
										
										
											2007-09-18 13:26:31 -07:00
										 |  |  | 		r->idiag_wqueue = sk->sk_max_ack_backlog; | 
					
						
							|  |  |  | 	} else { | 
					
						
							| 
									
										
										
										
											2009-12-03 16:06:13 -08:00
										 |  |  | 		r->idiag_rqueue = max_t(int, tp->rcv_nxt - tp->copied_seq, 0); | 
					
						
							| 
									
										
										
										
											2007-09-18 13:26:31 -07:00
										 |  |  | 		r->idiag_wqueue = tp->write_seq - tp->snd_una; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
											  
											
												[INET_DIAG]: Move the tcp_diag interface to the proper place
With this the previous setup is back, i.e. tcp_diag can be built as a module,
as dccp_diag and both share the infrastructure available in inet_diag.
If one selects CONFIG_INET_DIAG as module CONFIG_INET_TCP_DIAG will also be
built as a module, as will CONFIG_INET_DCCP_DIAG, if CONFIG_IP_DCCP was
selected static or as a module, if CONFIG_INET_DIAG is y, being statically
linked CONFIG_INET_TCP_DIAG will follow suit and CONFIG_INET_DCCP_DIAG will be
built in the same manner as CONFIG_IP_DCCP.
Now to aim at UDP, converting it to use inet_hashinfo, so that we can use
iproute2 for UDP sockets as well.
Ah, just to show an example of this new infrastructure working for DCCP :-)
[root@qemu ~]# ./ss -dane
State      Recv-Q Send-Q Local Address:Port  Peer Address:Port
LISTEN     0      0                  *:5001             *:*     ino:942 sk:cfd503a0
ESTAB      0      0          127.0.0.1:5001     127.0.0.1:32770 ino:943 sk:cfd50a60
ESTAB      0      0          127.0.0.1:32770    127.0.0.1:5001  ino:947 sk:cfd50700
TIME-WAIT  0      0          127.0.0.1:32769    127.0.0.1:5001  timer:(timewait,3.430ms,0) ino:0 sk:cf209620
Signed-off-by: Arnaldo Carvalho de Melo <acme@mandriva.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
											
										 
											2005-08-12 12:59:17 -03:00
										 |  |  | 	if (info != NULL) | 
					
						
							|  |  |  | 		tcp_get_info(sk, info); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-09 06:23:18 +00:00
										 |  |  | static void tcp_diag_dump(struct sk_buff *skb, struct netlink_callback *cb, | 
					
						
							| 
									
										
										
										
											2014-08-29 23:32:05 -07:00
										 |  |  | 			  struct inet_diag_req_v2 *r, struct nlattr *bc) | 
					
						
							| 
									
										
										
										
											2011-12-09 06:23:18 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	inet_diag_dump_icsk(&tcp_hashinfo, skb, cb, r, bc); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int tcp_diag_dump_one(struct sk_buff *in_skb, const struct nlmsghdr *nlh, | 
					
						
							| 
									
										
										
										
											2014-08-29 23:32:05 -07:00
										 |  |  | 			     struct inet_diag_req_v2 *req) | 
					
						
							| 
									
										
										
										
											2011-12-09 06:23:18 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	return inet_diag_dump_one_icsk(&tcp_hashinfo, in_skb, nlh, req); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-19 15:43:27 -08:00
										 |  |  | static const struct inet_diag_handler tcp_diag_handler = { | 
					
						
							| 
									
										
										
										
											2011-12-09 06:23:18 +00:00
										 |  |  | 	.dump		 = tcp_diag_dump, | 
					
						
							|  |  |  | 	.dump_one	 = tcp_diag_dump_one, | 
					
						
							| 
									
										
											  
											
												[INET_DIAG]: Move the tcp_diag interface to the proper place
With this the previous setup is back, i.e. tcp_diag can be built as a module,
as dccp_diag and both share the infrastructure available in inet_diag.
If one selects CONFIG_INET_DIAG as module CONFIG_INET_TCP_DIAG will also be
built as a module, as will CONFIG_INET_DCCP_DIAG, if CONFIG_IP_DCCP was
selected static or as a module, if CONFIG_INET_DIAG is y, being statically
linked CONFIG_INET_TCP_DIAG will follow suit and CONFIG_INET_DCCP_DIAG will be
built in the same manner as CONFIG_IP_DCCP.
Now to aim at UDP, converting it to use inet_hashinfo, so that we can use
iproute2 for UDP sockets as well.
Ah, just to show an example of this new infrastructure working for DCCP :-)
[root@qemu ~]# ./ss -dane
State      Recv-Q Send-Q Local Address:Port  Peer Address:Port
LISTEN     0      0                  *:5001             *:*     ino:942 sk:cfd503a0
ESTAB      0      0          127.0.0.1:5001     127.0.0.1:32770 ino:943 sk:cfd50a60
ESTAB      0      0          127.0.0.1:32770    127.0.0.1:5001  ino:947 sk:cfd50700
TIME-WAIT  0      0          127.0.0.1:32769    127.0.0.1:5001  timer:(timewait,3.430ms,0) ino:0 sk:cf209620
Signed-off-by: Arnaldo Carvalho de Melo <acme@mandriva.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
											
										 
											2005-08-12 12:59:17 -03:00
										 |  |  | 	.idiag_get_info	 = tcp_diag_get_info, | 
					
						
							| 
									
										
										
										
											2011-12-06 08:05:24 +00:00
										 |  |  | 	.idiag_type	 = IPPROTO_TCP, | 
					
						
							| 
									
										
											  
											
												[INET_DIAG]: Move the tcp_diag interface to the proper place
With this the previous setup is back, i.e. tcp_diag can be built as a module,
as dccp_diag and both share the infrastructure available in inet_diag.
If one selects CONFIG_INET_DIAG as module CONFIG_INET_TCP_DIAG will also be
built as a module, as will CONFIG_INET_DCCP_DIAG, if CONFIG_IP_DCCP was
selected static or as a module, if CONFIG_INET_DIAG is y, being statically
linked CONFIG_INET_TCP_DIAG will follow suit and CONFIG_INET_DCCP_DIAG will be
built in the same manner as CONFIG_IP_DCCP.
Now to aim at UDP, converting it to use inet_hashinfo, so that we can use
iproute2 for UDP sockets as well.
Ah, just to show an example of this new infrastructure working for DCCP :-)
[root@qemu ~]# ./ss -dane
State      Recv-Q Send-Q Local Address:Port  Peer Address:Port
LISTEN     0      0                  *:5001             *:*     ino:942 sk:cfd503a0
ESTAB      0      0          127.0.0.1:5001     127.0.0.1:32770 ino:943 sk:cfd50a60
ESTAB      0      0          127.0.0.1:32770    127.0.0.1:5001  ino:947 sk:cfd50700
TIME-WAIT  0      0          127.0.0.1:32769    127.0.0.1:5001  timer:(timewait,3.430ms,0) ino:0 sk:cf209620
Signed-off-by: Arnaldo Carvalho de Melo <acme@mandriva.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
											
										 
											2005-08-12 12:59:17 -03:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int __init tcp_diag_init(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return inet_diag_register(&tcp_diag_handler); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void __exit tcp_diag_exit(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	inet_diag_unregister(&tcp_diag_handler); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | module_init(tcp_diag_init); | 
					
						
							|  |  |  | module_exit(tcp_diag_exit); | 
					
						
							|  |  |  | MODULE_LICENSE("GPL"); | 
					
						
							| 
									
										
										
										
											2011-12-15 02:43:27 +00:00
										 |  |  | MODULE_ALIAS_NET_PF_PROTO_TYPE(PF_NETLINK, NETLINK_SOCK_DIAG, 2-6 /* AF_INET - IPPROTO_TCP */); |