xref: /illumos-gate/usr/src/cmd/ipf/lib/printactivenat.c (revision f3ac678143127d4c6c1793fadabb5ded04e127b6)
1*f3ac6781SToomas Soome /*
2*f3ac6781SToomas Soome  * Copyright (C) 2002-2004 by Darren Reed.
3*f3ac6781SToomas Soome  *
4*f3ac6781SToomas Soome  * See the IPFILTER.LICENCE file for details on licencing.
5*f3ac6781SToomas Soome  */
6*f3ac6781SToomas Soome 
7*f3ac6781SToomas Soome #include "ipf.h"
8*f3ac6781SToomas Soome 
9*f3ac6781SToomas Soome 
10*f3ac6781SToomas Soome #if !defined(lint)
11*f3ac6781SToomas Soome static const char rcsid[] = "@(#)$Id: printactivenat.c,v 1.3.2.4 2004/05/11 16:07:32 darrenr Exp $";
12*f3ac6781SToomas Soome #endif
13*f3ac6781SToomas Soome 
14*f3ac6781SToomas Soome 
printactivenat(nat,opts,alive)15*f3ac6781SToomas Soome void printactivenat(nat, opts, alive)
16*f3ac6781SToomas Soome nat_t *nat;
17*f3ac6781SToomas Soome int opts, alive;
18*f3ac6781SToomas Soome {
19*f3ac6781SToomas Soome 
20*f3ac6781SToomas Soome 	printf("%s", getnattype(nat, alive));
21*f3ac6781SToomas Soome 
22*f3ac6781SToomas Soome 	if (nat->nat_flags & SI_CLONE)
23*f3ac6781SToomas Soome 		printf(" CLONE");
24*f3ac6781SToomas Soome 
25*f3ac6781SToomas Soome 	printactiveaddress(nat->nat_v, " %-15s", &nat->nat_inip6,
26*f3ac6781SToomas Soome 			   nat->nat_ifnames[0]);
27*f3ac6781SToomas Soome 
28*f3ac6781SToomas Soome 	if ((nat->nat_flags & IPN_TCPUDP) != 0)
29*f3ac6781SToomas Soome 		printf(" %-5hu", ntohs(nat->nat_inport));
30*f3ac6781SToomas Soome 
31*f3ac6781SToomas Soome 	printf(" <- -> ");
32*f3ac6781SToomas Soome 	printactiveaddress(nat->nat_v, "%-15s", &nat->nat_outip6,
33*f3ac6781SToomas Soome 			   nat->nat_ifnames[0]);
34*f3ac6781SToomas Soome 
35*f3ac6781SToomas Soome 	if ((nat->nat_flags & IPN_TCPUDP) != 0)
36*f3ac6781SToomas Soome 		printf(" %-5hu", ntohs(nat->nat_outport));
37*f3ac6781SToomas Soome 
38*f3ac6781SToomas Soome 	printf(" [");
39*f3ac6781SToomas Soome 	printactiveaddress(nat->nat_v, "%s", &nat->nat_oip6,
40*f3ac6781SToomas Soome 			   nat->nat_ifnames[0]);
41*f3ac6781SToomas Soome 
42*f3ac6781SToomas Soome 	if ((nat->nat_flags & IPN_TCPUDP) != 0)
43*f3ac6781SToomas Soome 		printf(" %hu", ntohs(nat->nat_oport));
44*f3ac6781SToomas Soome 	printf("]");
45*f3ac6781SToomas Soome 
46*f3ac6781SToomas Soome 	if (opts & OPT_VERBOSE) {
47*f3ac6781SToomas Soome 		printf("\n\tage %lu use %hu sumd %s/",
48*f3ac6781SToomas Soome 			nat->nat_age, nat->nat_use, getsumd(nat->nat_sumd[0]));
49*f3ac6781SToomas Soome 		printf("%s pr %u bkt %d/%d flags %x\n",
50*f3ac6781SToomas Soome 			getsumd(nat->nat_sumd[1]), nat->nat_p,
51*f3ac6781SToomas Soome 			nat->nat_hv[0], nat->nat_hv[1], nat->nat_flags);
52*f3ac6781SToomas Soome 		printf("\tifp %s", getifname(nat->nat_ifps[0]));
53*f3ac6781SToomas Soome 		printf(",%s ", getifname(nat->nat_ifps[1]));
54*f3ac6781SToomas Soome #ifdef	USE_QUAD_T
55*f3ac6781SToomas Soome 		printf("bytes %qu/%qu pkts %qu/%qu",
56*f3ac6781SToomas Soome 			(unsigned long long)nat->nat_bytes[0],
57*f3ac6781SToomas Soome 			(unsigned long long)nat->nat_bytes[1],
58*f3ac6781SToomas Soome 			(unsigned long long)nat->nat_pkts[0],
59*f3ac6781SToomas Soome 			(unsigned long long)nat->nat_pkts[1]);
60*f3ac6781SToomas Soome #else
61*f3ac6781SToomas Soome 		printf("bytes %lu/%lu pkts %lu/%lu", nat->nat_bytes[0],
62*f3ac6781SToomas Soome 			nat->nat_bytes[1], nat->nat_pkts[0], nat->nat_pkts[1]);
63*f3ac6781SToomas Soome #endif
64*f3ac6781SToomas Soome 		printf(" ipsumd %x", nat->nat_ipsumd);
65*f3ac6781SToomas Soome 	}
66*f3ac6781SToomas Soome 
67*f3ac6781SToomas Soome 	if (opts & OPT_DEBUG) {
68*f3ac6781SToomas Soome 		printf("\n\tnat_next %p _pnext %p _hm %p\n",
69*f3ac6781SToomas Soome 			nat->nat_next, nat->nat_pnext, nat->nat_hm);
70*f3ac6781SToomas Soome 		printf("\t_hnext %p/%p _phnext %p/%p\n",
71*f3ac6781SToomas Soome 			nat->nat_hnext[0], nat->nat_hnext[1],
72*f3ac6781SToomas Soome 			nat->nat_phnext[0], nat->nat_phnext[1]);
73*f3ac6781SToomas Soome 		printf("\t_data %p _me %p _state %p _aps %p\n",
74*f3ac6781SToomas Soome 			nat->nat_data, nat->nat_me, nat->nat_state, nat->nat_aps);
75*f3ac6781SToomas Soome 		printf("\tfr %p ptr %p ifps %p/%p sync %p\n",
76*f3ac6781SToomas Soome 			nat->nat_fr, nat->nat_ptr, nat->nat_ifps[0],
77*f3ac6781SToomas Soome 			nat->nat_ifps[1], nat->nat_sync);
78*f3ac6781SToomas Soome 		printf("\ttqe:pnext %p next %p ifq %p parent %p/%p\n",
79*f3ac6781SToomas Soome 			nat->nat_tqe.tqe_pnext, nat->nat_tqe.tqe_next,
80*f3ac6781SToomas Soome 			nat->nat_tqe.tqe_ifq, nat->nat_tqe.tqe_parent, nat);
81*f3ac6781SToomas Soome 		printf("\ttqe:die %ld touched %ld flags %x state %d/%d\n",
82*f3ac6781SToomas Soome 			nat->nat_tqe.tqe_die, nat->nat_tqe.tqe_touched,
83*f3ac6781SToomas Soome 			nat->nat_tqe.tqe_flags, nat->nat_tqe.tqe_state[0],
84*f3ac6781SToomas Soome 			nat->nat_tqe.tqe_state[1]);
85*f3ac6781SToomas Soome 	}
86*f3ac6781SToomas Soome 	putchar('\n');
87*f3ac6781SToomas Soome }
88