Home | History | Annotate | Line # | Download | only in systat
ip.c revision 1.9
      1  1.9   simonb /*	$NetBSD: ip.c,v 1.9 2000/12/01 02:19:43 simonb Exp $	*/
      2  1.1       ad 
      3  1.1       ad /*
      4  1.8       ad  * Copyright (c) 1999, 2000 Andrew Doran <ad (at) NetBSD.org>
      5  1.1       ad  * All rights reserved.
      6  1.1       ad  *
      7  1.1       ad  * Redistribution and use in source and binary forms, with or without
      8  1.1       ad  * modification, are permitted provided that the following conditions
      9  1.1       ad  * are met:
     10  1.1       ad  * 1. Redistributions of source code must retain the above copyright
     11  1.1       ad  *    notice, this list of conditions and the following disclaimer.
     12  1.1       ad  * 2. Redistributions in binary form must reproduce the above copyright
     13  1.1       ad  *    notice, this list of conditions and the following disclaimer in the
     14  1.1       ad  *    documentation and/or other materials provided with the distribution.
     15  1.1       ad  *
     16  1.1       ad  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
     17  1.1       ad  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     18  1.1       ad  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     19  1.1       ad  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
     20  1.1       ad  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     21  1.1       ad  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     22  1.1       ad  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     23  1.1       ad  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     24  1.1       ad  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     25  1.1       ad  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     26  1.1       ad  * SUCH DAMAGE.
     27  1.1       ad  *
     28  1.1       ad  */
     29  1.1       ad 
     30  1.1       ad #include <sys/cdefs.h>
     31  1.1       ad #ifndef lint
     32  1.9   simonb __RCSID("$NetBSD: ip.c,v 1.9 2000/12/01 02:19:43 simonb Exp $");
     33  1.1       ad #endif /* not lint */
     34  1.1       ad 
     35  1.1       ad #include <sys/param.h>
     36  1.1       ad #include <sys/sysctl.h>
     37  1.1       ad 
     38  1.1       ad #include <netinet/in.h>
     39  1.1       ad #include <netinet/in_systm.h>
     40  1.1       ad #include <netinet/ip.h>
     41  1.1       ad #include <netinet/ip_var.h>
     42  1.1       ad #include <netinet/udp.h>
     43  1.1       ad #include <netinet/udp_var.h>
     44  1.1       ad 
     45  1.9   simonb #include <kvm.h>
     46  1.1       ad #include <string.h>
     47  1.5       ad 
     48  1.1       ad #include "systat.h"
     49  1.1       ad #include "extern.h"
     50  1.1       ad 
     51  1.1       ad #define LHD(row, str)		mvwprintw(wnd, row, 10, str)
     52  1.1       ad #define RHD(row, str)		mvwprintw(wnd, row, 45, str);
     53  1.4   itojun #define SHOW(stat, row, col) \
     54  1.4   itojun     mvwprintw(wnd, row, col, "%9llu", (unsigned long long)curstat.stat)
     55  1.1       ad 
     56  1.1       ad struct mystat {
     57  1.1       ad 	struct ipstat i;
     58  1.1       ad 	struct udpstat u;
     59  1.1       ad };
     60  1.1       ad 
     61  1.8       ad enum update {
     62  1.8       ad 	UPDATE_TIME,
     63  1.8       ad 	UPDATE_BOOT,
     64  1.8       ad 	UPDATE_RUN,
     65  1.8       ad };
     66  1.8       ad 
     67  1.8       ad static enum update update = UPDATE_TIME;
     68  1.1       ad static struct mystat curstat;
     69  1.8       ad static struct mystat oldstat;
     70  1.8       ad static struct mystat newstat;
     71  1.1       ad 
     72  1.1       ad static struct nlist namelist[] = {
     73  1.1       ad 	{ "_ipstat" },
     74  1.1       ad 	{ "_udpstat" },
     75  1.1       ad 	{ "" }
     76  1.1       ad };
     77  1.1       ad 
     78  1.1       ad WINDOW *
     79  1.1       ad openip(void)
     80  1.1       ad {
     81  1.1       ad 
     82  1.1       ad 	return (subwin(stdscr, LINES-5-1, 0, 5, 0));
     83  1.1       ad }
     84  1.1       ad 
     85  1.1       ad void
     86  1.8       ad closeip(WINDOW *w)
     87  1.1       ad {
     88  1.1       ad 
     89  1.1       ad 	if (w != NULL) {
     90  1.1       ad 		wclear(w);
     91  1.1       ad 		wrefresh(w);
     92  1.1       ad 		delwin(w);
     93  1.1       ad 	}
     94  1.1       ad }
     95  1.1       ad 
     96  1.1       ad void
     97  1.1       ad labelip(void)
     98  1.1       ad {
     99  1.2       ad 
    100  1.1       ad 	wmove(wnd, 0, 0); wclrtoeol(wnd);
    101  1.1       ad 
    102  1.1       ad 	LHD(0,  "total packets received");
    103  1.1       ad 	LHD(1,  "  passed to upper layers");
    104  1.1       ad 	LHD(2,  "  with bad checksums");
    105  1.1       ad 	LHD(3,  "  too short for header");
    106  1.1       ad 	LHD(4,  "  too short for data");
    107  1.1       ad 	LHD(5,  "  with invalid hlen");
    108  1.1       ad 	LHD(6,  "  with invalid length");
    109  1.1       ad 	LHD(7,  "  with invalid version");
    110  1.1       ad 	LHD(8,  "  too large");
    111  1.1       ad 	LHD(9,  "  option errors");
    112  1.1       ad 	LHD(10, "  fragments received");
    113  1.1       ad 	LHD(11, "  fragments dropped");
    114  1.1       ad 	LHD(12, "  fragments timed out");
    115  1.1       ad 	LHD(13, "  packets reassembled ok");
    116  1.1       ad 
    117  1.1       ad 	LHD(15, "packets forwarded");
    118  1.1       ad 	LHD(16, "  fast forwarded");
    119  1.1       ad 	LHD(17, "  unreachable dests");
    120  1.1       ad 	LHD(18, "  redirects generated");
    121  1.1       ad 
    122  1.1       ad 	RHD(0,  "total packets sent");
    123  1.1       ad 	RHD(1,  "  generated locally");
    124  1.1       ad 	RHD(2,  "  output drops");
    125  1.1       ad 	RHD(3,  "  output fragments generated");
    126  1.1       ad 	RHD(4,  "  fragmentation failed");
    127  1.1       ad 	RHD(5,  "  destinations unreachable");
    128  1.1       ad 	RHD(6,  "  packets output via raw IP");
    129  1.1       ad 	RHD(7,  "  total UDP packets sent");
    130  1.1       ad 
    131  1.1       ad 	RHD(9, "total UDP packets recieved");
    132  1.1       ad 	RHD(10, "  too short for header");
    133  1.1       ad 	RHD(11, "  invalid checksum");
    134  1.1       ad 	RHD(12, "  invalid length");
    135  1.1       ad 	RHD(13, "  no socket for dest port");
    136  1.1       ad 	RHD(14, "  no socket for broadcast");
    137  1.1       ad 	RHD(15, "  socket buffer full");
    138  1.1       ad }
    139  1.1       ad 
    140  1.1       ad void
    141  1.1       ad showip(void)
    142  1.1       ad {
    143  1.3  msaitoh 	u_quad_t totalout;
    144  1.1       ad 
    145  1.1       ad 	totalout = curstat.i.ips_forward + curstat.i.ips_localout;
    146  1.1       ad 
    147  1.1       ad 	SHOW(i.ips_total, 0, 0);
    148  1.6  thorpej 	mvwprintw(wnd, 0, 35, "%9llu", (unsigned long long)totalout);
    149  1.1       ad 	SHOW(i.ips_delivered, 1, 0);
    150  1.1       ad 	SHOW(i.ips_badsum, 2, 0);
    151  1.1       ad 	SHOW(i.ips_tooshort, 3, 0);
    152  1.1       ad 	SHOW(i.ips_toosmall, 4, 0);
    153  1.1       ad 	SHOW(i.ips_badhlen, 5, 0);
    154  1.1       ad 	SHOW(i.ips_badlen, 6, 0);
    155  1.1       ad 	SHOW(i.ips_badvers, 7, 0);
    156  1.1       ad 	SHOW(i.ips_toolong, 8, 0);
    157  1.1       ad 	SHOW(i.ips_badoptions, 9, 0);
    158  1.1       ad 
    159  1.1       ad 	SHOW(i.ips_localout, 1, 35);
    160  1.1       ad 	SHOW(i.ips_odropped, 2, 35);
    161  1.1       ad 	SHOW(i.ips_ofragments, 3, 35);
    162  1.1       ad 	SHOW(i.ips_cantfrag, 4, 35);
    163  1.1       ad 	SHOW(i.ips_noroute, 5, 35);
    164  1.1       ad 	SHOW(i.ips_rawout, 6, 35);
    165  1.1       ad 	SHOW(u.udps_opackets, 7, 35);
    166  1.1       ad 
    167  1.1       ad 	SHOW(i.ips_fragments, 10, 0);
    168  1.1       ad 	SHOW(i.ips_fragdropped, 11, 0);
    169  1.1       ad 	SHOW(i.ips_fragtimeout, 12, 0);
    170  1.1       ad 	SHOW(i.ips_reassembled, 13, 0);
    171  1.1       ad 
    172  1.1       ad 	SHOW(i.ips_forward, 15, 0);
    173  1.1       ad 	SHOW(i.ips_fastforward, 16, 0);
    174  1.1       ad 	SHOW(i.ips_cantforward, 17, 0);
    175  1.1       ad 	SHOW(i.ips_redirectsent, 18, 0);
    176  1.1       ad 
    177  1.1       ad 	SHOW(u.udps_ipackets, 9, 35);
    178  1.1       ad 	SHOW(u.udps_hdrops, 10, 35);
    179  1.1       ad 	SHOW(u.udps_badsum, 11, 35);
    180  1.1       ad 	SHOW(u.udps_badlen, 12, 35);
    181  1.1       ad 	SHOW(u.udps_noport, 13, 35);
    182  1.1       ad 	SHOW(u.udps_noportbcast, 14, 35);
    183  1.1       ad 	SHOW(u.udps_fullsock, 15, 35);
    184  1.1       ad }
    185  1.1       ad 
    186  1.1       ad int
    187  1.1       ad initip(void)
    188  1.1       ad {
    189  1.2       ad 
    190  1.1       ad 	if (namelist[0].n_type == 0) {
    191  1.1       ad 		if (kvm_nlist(kd, namelist)) {
    192  1.1       ad 			nlisterr(namelist);
    193  1.1       ad 			return(0);
    194  1.1       ad 		}
    195  1.1       ad 		if ((namelist[0].n_type | namelist[1].n_type) == 0) {
    196  1.1       ad 			error("No namelist");
    197  1.1       ad 			return(0);
    198  1.1       ad 		}
    199  1.1       ad 	}
    200  1.1       ad 	return 1;
    201  1.1       ad }
    202  1.1       ad 
    203  1.1       ad void
    204  1.1       ad fetchip(void)
    205  1.1       ad {
    206  1.2       ad 
    207  1.8       ad 	KREAD((void *)namelist[0].n_value, &newstat.i,
    208  1.8       ad 	    sizeof(newstat.i));
    209  1.8       ad 	KREAD((void *)namelist[1].n_value, &newstat.u,
    210  1.8       ad 	    sizeof(newstat.u));
    211  1.8       ad 
    212  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, i.ips_total);
    213  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, i.ips_delivered);
    214  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, i.ips_badsum);
    215  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, i.ips_tooshort);
    216  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, i.ips_toosmall);
    217  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, i.ips_badhlen);
    218  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, i.ips_badlen);
    219  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, i.ips_badvers);
    220  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, i.ips_toolong);
    221  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, i.ips_badoptions);
    222  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, i.ips_localout);
    223  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, i.ips_odropped);
    224  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, i.ips_ofragments);
    225  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, i.ips_cantfrag);
    226  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, i.ips_noroute);
    227  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, i.ips_rawout);
    228  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, i.ips_fragments);
    229  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, i.ips_fragdropped);
    230  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, i.ips_fragtimeout);
    231  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, i.ips_reassembled);
    232  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, i.ips_forward);
    233  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, i.ips_fastforward);
    234  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, i.ips_cantforward);
    235  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, i.ips_redirectsent);
    236  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, u.udps_opackets);
    237  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, u.udps_ipackets);
    238  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, u.udps_hdrops);
    239  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, u.udps_badsum);
    240  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, u.udps_badlen);
    241  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, u.udps_noport);
    242  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, u.udps_noportbcast);
    243  1.8       ad 	ADJINETCTR(curstat, oldstat, newstat, u.udps_fullsock);
    244  1.8       ad 
    245  1.8       ad 	if (update == UPDATE_TIME)
    246  1.8       ad 		memcpy(&oldstat, &newstat, sizeof(oldstat));
    247  1.8       ad }
    248  1.8       ad 
    249  1.8       ad void
    250  1.8       ad ip_boot(char *args)
    251  1.8       ad {
    252  1.8       ad 
    253  1.8       ad 	memset(&oldstat, 0, sizeof(oldstat));
    254  1.8       ad 	update = UPDATE_BOOT;
    255  1.8       ad }
    256  1.8       ad 
    257  1.8       ad void
    258  1.8       ad ip_run(char *args)
    259  1.8       ad {
    260  1.8       ad 
    261  1.8       ad 	if (update != UPDATE_RUN) {
    262  1.8       ad 		memcpy(&oldstat, &newstat, sizeof(oldstat));
    263  1.8       ad 		update = UPDATE_RUN;
    264  1.8       ad 	}
    265  1.8       ad }
    266  1.8       ad 
    267  1.8       ad void
    268  1.8       ad ip_time(char *args)
    269  1.8       ad {
    270  1.8       ad 
    271  1.8       ad 	if (update != UPDATE_TIME) {
    272  1.8       ad 		memcpy(&oldstat, &newstat, sizeof(oldstat));
    273  1.8       ad 		update = UPDATE_TIME;
    274  1.8       ad 	}
    275  1.8       ad }
    276  1.8       ad 
    277  1.8       ad void
    278  1.8       ad ip_zero(char *args)
    279  1.8       ad {
    280  1.8       ad 
    281  1.8       ad 	if (update == UPDATE_RUN)
    282  1.8       ad 		memcpy(&oldstat, &newstat, sizeof(oldstat));
    283  1.1       ad }
    284