BSD 4_3_Net_2 release
[unix-history] / usr / src / usr.bin / netstat / ns.c
index 1eef2d3..8bdc89c 100644 (file)
@@ -1,24 +1,41 @@
 /*
 /*
- * Copyright (c) 1985,1988 Regents of the University of California.
+ * Copyright (c) 1985, 1988 Regents of the University of California.
  * All rights reserved.
  *
  * All rights reserved.
  *
- * Redistribution and use in source and binary forms are permitted
- * provided that this notice is preserved and that due credit is given
- * to the University of California at Berkeley. The name of the University
- * may not be used to endorse or promote products derived from this
- * software without specific prior written permission. This software
- * is provided ``as is'' without express or implied warranty.
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ * 3. All advertising materials mentioning features or use of this software
+ *    must display the following acknowledgement:
+ *     This product includes software developed by the University of
+ *     California, Berkeley and its contributors.
+ * 4. Neither the name of the University nor the names of its contributors
+ *    may be used to endorse or promote products derived from this software
+ *    without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
  */
 
 #ifndef lint
  */
 
 #ifndef lint
-static char sccsid[] = "@(#)ns.c       5.6 (Berkeley) %G%";
-#endif not lint
-
-#include <stdio.h>
-#include <errno.h>
-#include <nlist.h>
+static char sccsid[] = "@(#)ns.c       5.13 (Berkeley) 3/1/91";
+#endif /* not lint */
 
 
-#include <sys/types.h>
+#include <sys/param.h>
 #include <sys/socket.h>
 #include <sys/socketvar.h>
 #include <sys/mbuf.h>
 #include <sys/socket.h>
 #include <sys/socketvar.h>
 #include <sys/mbuf.h>
@@ -28,7 +45,6 @@ static char sccsid[] = "@(#)ns.c      5.6 (Berkeley) %G%";
 #include <net/if.h>
 
 #include <netinet/tcp_fsm.h>
 #include <net/if.h>
 
 #include <netinet/tcp_fsm.h>
-#include <netinet/tcp_timer.h>
 
 #include <netns/ns.h>
 #include <netns/ns_pcb.h>
 
 #include <netns/ns.h>
 #include <netns/ns_pcb.h>
@@ -37,15 +53,19 @@ static char sccsid[] = "@(#)ns.c    5.6 (Berkeley) %G%";
 #include <netns/ns_error.h>
 #include <netns/sp.h>
 #include <netns/spidp.h>
 #include <netns/ns_error.h>
 #include <netns/sp.h>
 #include <netns/spidp.h>
+#include <netns/spp_timer.h>
 #include <netns/spp_var.h>
 #define SANAMES
 #include <netns/spp_debug.h>
 
 #include <netns/spp_var.h>
 #define SANAMES
 #include <netns/spp_debug.h>
 
+#include <nlist.h>
+#include <errno.h>
+#include <stdio.h>
+#include <string.h>
 
 struct nspcb nspcb;
 struct sppcb sppcb;
 struct socket sockb;
 
 struct nspcb nspcb;
 struct sppcb sppcb;
 struct socket sockb;
-extern int kmem;
 extern int Aflag;
 extern int aflag;
 extern int nflag;
 extern int Aflag;
 extern int aflag;
 extern int nflag;
@@ -72,8 +92,7 @@ nsprotopr(off, name)
        if (off == 0)
                return;
        isspp = strcmp(name, "spp") == 0;
        if (off == 0)
                return;
        isspp = strcmp(name, "spp") == 0;
-       klseek(kmem, off, 0);
-       read(kmem, (char *)&cb, sizeof (struct nspcb));
+       kvm_read(off, (char *)&cb, sizeof (struct nspcb));
        nspcb = cb;
        prev = (struct nspcb *)off;
        if (nspcb.nsp_next == (struct nspcb *)off)
        nspcb = cb;
        prev = (struct nspcb *)off;
        if (nspcb.nsp_next == (struct nspcb *)off)
@@ -82,8 +101,7 @@ nsprotopr(off, name)
                off_t ppcb;
 
                next = nspcb.nsp_next;
                off_t ppcb;
 
                next = nspcb.nsp_next;
-               klseek(kmem, (off_t)next, 0);
-               read(kmem, (char *)&nspcb, sizeof (nspcb));
+               kvm_read((off_t)next, (char *)&nspcb, sizeof (nspcb));
                if (nspcb.nsp_prev != prev) {
                        printf("???\n");
                        break;
                if (nspcb.nsp_prev != prev) {
                        printf("???\n");
                        break;
@@ -91,13 +109,12 @@ nsprotopr(off, name)
                if (!aflag && ns_nullhost(nspcb.nsp_faddr) ) {
                        continue;
                }
                if (!aflag && ns_nullhost(nspcb.nsp_faddr) ) {
                        continue;
                }
-               klseek(kmem, (off_t)nspcb.nsp_socket, 0);
-               read(kmem, (char *)&sockb, sizeof (sockb));
+               kvm_read((off_t)nspcb.nsp_socket,
+                               (char *)&sockb, sizeof (sockb));
                ppcb = (off_t) nspcb.nsp_pcb;
                if (ppcb) {
                        if (isspp) {
                ppcb = (off_t) nspcb.nsp_pcb;
                if (ppcb) {
                        if (isspp) {
-                               klseek(kmem, ppcb, 0);
-                               read(kmem, (char *)&sppcb, sizeof (sppcb));
+                               kvm_read(ppcb, (char *)&sppcb, sizeof (sppcb));
                        } else continue;
                } else
                        if (isspp) continue;
                        } else continue;
                } else
                        if (isspp) continue;
@@ -132,7 +149,8 @@ nsprotopr(off, name)
                prev = next;
        }
 }
                prev = next;
        }
 }
-#define ANY(x,y,z)  ((x) ? printf("\t%u %s%s%s\n",x,y,plural(x),z) : 0)
+#define ANY(x,y,z) \
+       ((x) ? printf("\t%d %s%s%s -- %s\n",x,y,plural(x),z,"x") : 0)
 
 /*
  * Dump SPP statistics structure.
 
 /*
  * Dump SPP statistics structure.
@@ -142,22 +160,74 @@ spp_stats(off, name)
        char *name;
 {
        struct spp_istat spp_istat;
        char *name;
 {
        struct spp_istat spp_istat;
+#define sppstat spp_istat.newstats
 
        if (off == 0)
                return;
 
        if (off == 0)
                return;
-       klseek(kmem, off, 0);
-       read(kmem, (char *)&spp_istat, sizeof (spp_istat));
+       kvm_read(off, (char *)&spp_istat, sizeof (spp_istat));
        printf("%s:\n", name);
        ANY(spp_istat.nonucn, "connection", " dropped due to no new sockets ");
        ANY(spp_istat.gonawy, "connection", " terminated due to our end dying");
        printf("%s:\n", name);
        ANY(spp_istat.nonucn, "connection", " dropped due to no new sockets ");
        ANY(spp_istat.gonawy, "connection", " terminated due to our end dying");
-       ANY(spp_istat.nonucn, "connection", " dropped due to inability to connect");
-       ANY(spp_istat.noconn, "connection", " dropped due to inability to connect");
-       ANY(spp_istat.notme, "connection", " incompleted due to mismatched id's");
+       ANY(spp_istat.nonucn, "connection",
+           " dropped due to inability to connect");
+       ANY(spp_istat.noconn, "connection",
+           " dropped due to inability to connect");
+       ANY(spp_istat.notme, "connection",
+           " incompleted due to mismatched id's");
        ANY(spp_istat.wrncon, "connection", " dropped due to mismatched id's");
        ANY(spp_istat.bdreas, "packet", " dropped out of sequence");
        ANY(spp_istat.lstdup, "packet", " duplicating the highest packet");
        ANY(spp_istat.notyet, "packet", " refused as exceeding allocation");
        ANY(spp_istat.wrncon, "connection", " dropped due to mismatched id's");
        ANY(spp_istat.bdreas, "packet", " dropped out of sequence");
        ANY(spp_istat.lstdup, "packet", " duplicating the highest packet");
        ANY(spp_istat.notyet, "packet", " refused as exceeding allocation");
+       ANY(sppstat.spps_connattempt, "connection", " initiated");
+       ANY(sppstat.spps_accepts, "connection", " accepted");
+       ANY(sppstat.spps_connects, "connection", " established");
+       ANY(sppstat.spps_drops, "connection", " dropped");
+       ANY(sppstat.spps_conndrops, "embryonic connection", " dropped");
+       ANY(sppstat.spps_closed, "connection", " closed (includes drops)");
+       ANY(sppstat.spps_segstimed, "packet", " where we tried to get rtt");
+       ANY(sppstat.spps_rttupdated, "time", " we got rtt");
+       ANY(sppstat.spps_delack, "delayed ack", " sent");
+       ANY(sppstat.spps_timeoutdrop, "connection", " dropped in rxmt timeout");
+       ANY(sppstat.spps_rexmttimeo, "retransmit timeout", "");
+       ANY(sppstat.spps_persisttimeo, "persist timeout", "");
+       ANY(sppstat.spps_keeptimeo, "keepalive timeout", "");
+       ANY(sppstat.spps_keepprobe, "keepalive probe", " sent");
+       ANY(sppstat.spps_keepdrops, "connection", " dropped in keepalive");
+       ANY(sppstat.spps_sndtotal, "total packet", " sent");
+       ANY(sppstat.spps_sndpack, "data packet", " sent");
+       ANY(sppstat.spps_sndbyte, "data byte", " sent");
+       ANY(sppstat.spps_sndrexmitpack, "data packet", " retransmitted");
+       ANY(sppstat.spps_sndrexmitbyte, "data byte", " retransmitted");
+       ANY(sppstat.spps_sndacks, "ack-only packet", " sent");
+       ANY(sppstat.spps_sndprobe, "window probe", " sent");
+       ANY(sppstat.spps_sndurg, "packet", " sent with URG only");
+       ANY(sppstat.spps_sndwinup, "window update-only packet", " sent");
+       ANY(sppstat.spps_sndctrl, "control (SYN|FIN|RST) packet", " sent");
+       ANY(sppstat.spps_sndvoid, "request", " to send a non-existant packet");
+       ANY(sppstat.spps_rcvtotal, "total packet", " received");
+       ANY(sppstat.spps_rcvpack, "packet", " received in sequence");
+       ANY(sppstat.spps_rcvbyte, "byte", " received in sequence");
+       ANY(sppstat.spps_rcvbadsum, "packet", " received with ccksum errs");
+       ANY(sppstat.spps_rcvbadoff, "packet", " received with bad offset");
+       ANY(sppstat.spps_rcvshort, "packet", " received too short");
+       ANY(sppstat.spps_rcvduppack, "duplicate-only packet", " received");
+       ANY(sppstat.spps_rcvdupbyte, "duplicate-only byte", " received");
+       ANY(sppstat.spps_rcvpartduppack, "packet", " with some duplicate data");
+       ANY(sppstat.spps_rcvpartdupbyte, "dup. byte", " in part-dup. packet");
+       ANY(sppstat.spps_rcvoopack, "out-of-order packet", " received");
+       ANY(sppstat.spps_rcvoobyte, "out-of-order byte", " received");
+       ANY(sppstat.spps_rcvpackafterwin, "packet", " with data after window");
+       ANY(sppstat.spps_rcvbyteafterwin, "byte", " rcvd after window");
+       ANY(sppstat.spps_rcvafterclose, "packet", " rcvd after 'close'");
+       ANY(sppstat.spps_rcvwinprobe, "rcvd window probe packet", "");
+       ANY(sppstat.spps_rcvdupack, "rcvd duplicate ack", "");
+       ANY(sppstat.spps_rcvacktoomuch, "rcvd ack", " for unsent data");
+       ANY(sppstat.spps_rcvackpack, "rcvd ack packet", "");
+       ANY(sppstat.spps_rcvackbyte, "byte", " acked by rcvd acks");
+       ANY(sppstat.spps_rcvwinupd, "rcvd window update packet", "");
 }
 }
+#undef ANY
+#define ANY(x,y,z)  ((x) ? printf("\t%d %s%s%s\n",x,y,plural(x),z) : 0)
 
 /*
  * Dump IDP statistics structure.
 
 /*
  * Dump IDP statistics structure.
@@ -170,23 +240,27 @@ idp_stats(off, name)
 
        if (off == 0)
                return;
 
        if (off == 0)
                return;
-       klseek(kmem, off, 0);
-       read(kmem, (char *)&idpstat, sizeof (idpstat));
+       kvm_read(off, (char *)&idpstat, sizeof (idpstat));
        printf("%s:\n", name);
        ANY(idpstat.idps_toosmall, "packet", " smaller than a header");
        ANY(idpstat.idps_tooshort, "packet", " smaller than advertised");
        ANY(idpstat.idps_badsum, "packet", " with bad checksums");
 }
 
        printf("%s:\n", name);
        ANY(idpstat.idps_toosmall, "packet", " smaller than a header");
        ANY(idpstat.idps_tooshort, "packet", " smaller than advertised");
        ANY(idpstat.idps_badsum, "packet", " with bad checksums");
 }
 
-static char *((ns_errnames[])[2]) = {
-       {"Unspecified Error", " at Destination"},
-       {"Bad Checksum", " at Destination"},
-       {"No Listener", " at Socket"},
-       {"Packet", " Refused due to lack of space at Destination"},
-       {"Unspecified Error", " while gatewayed"},
-       {"Bad Checksum", " while gatewayed"},
-       {"Packet", " forwarded too many times"},
-       {"Packet", " too large to be forwarded"},
+static struct {
+       u_short code;
+       char *name;
+       char *where;
+} ns_errnames[] = {
+       {0, "Unspecified Error", " at Destination"},
+       {1, "Bad Checksum", " at Destination"},
+       {2, "No Listener", " at Socket"},
+       {3, "Packet", " Refused due to lack of space at Destination"},
+       {01000, "Unspecified Error", " while gatewayed"},
+       {01001, "Bad Checksum", " while gatewayed"},
+       {01002, "Packet", " forwarded too many times"},
+       {01003, "Packet", " too large to be forwarded"},
+       {-1, 0, 0},
 };
 
 /*
 };
 
 /*
@@ -204,8 +278,7 @@ nserr_stats(off, name)
 
        if (off == 0)
                return;
 
        if (off == 0)
                return;
-       klseek(kmem, off, 0);
-       read(kmem, (char *)&ns_errstat, sizeof (ns_errstat));
+       kvm_read(off, (char *)&ns_errstat, sizeof (ns_errstat));
        printf("NS error statistics:\n");
        ANY(ns_errstat.ns_es_error, "call", " to ns_error");
        ANY(ns_errstat.ns_es_oldshort, "error",
        printf("NS error statistics:\n");
        ANY(ns_errstat.ns_es_error, "call", " to ns_error");
        ANY(ns_errstat.ns_es_oldshort, "error",
@@ -222,7 +295,8 @@ nserr_stats(off, name)
                        printf("Output Error Histogram:\n");
                        histoprint = 0;
                }
                        printf("Output Error Histogram:\n");
                        histoprint = 0;
                }
-               ANY(z, ns_errnames[j][0], ns_errnames[j][1]);
+               ns_erputil(z, ns_errstat.ns_es_codes[j]);
+
        }
        histoprint = 1;
        for(j = 0; j < NS_ERR_MAX; j ++) {
        }
        histoprint = 1;
        for(j = 0; j < NS_ERR_MAX; j ++) {
@@ -231,16 +305,42 @@ nserr_stats(off, name)
                        printf("Input Error Histogram:\n");
                        histoprint = 0;
                }
                        printf("Input Error Histogram:\n");
                        histoprint = 0;
                }
-               ANY(z, ns_errnames[j][0], ns_errnames[j][1]);
+               ns_erputil(z, ns_errstat.ns_es_codes[j]);
        }
 }
        }
 }
+
+ns_erputil(z, c)
+{
+       int j;
+       char codebuf[30];
+       char *name, *where;
+
+       for(j = 0;; j ++) {
+               if ((name = ns_errnames[j].name) == 0)
+                       break;
+               if (ns_errnames[j].code == c)
+                       break;
+       }
+       if (name == 0)  {
+               if (c > 01000)
+                       where = "in transit";
+               else
+                       where = "at destination";
+               sprintf(codebuf, "Unknown XNS error code 0%o", c);
+               name = codebuf;
+       } else 
+               where =  ns_errnames[j].where;
+       ANY(z, name, where);
+}
+
 static struct sockaddr_ns ssns = {AF_NS};
 
 char *ns_prpr(x)
 static struct sockaddr_ns ssns = {AF_NS};
 
 char *ns_prpr(x)
-struct ns_addr *x;
+       struct ns_addr *x;
 {
 {
-       extern char *ns_print();
        struct sockaddr_ns *sns = &ssns;
        struct sockaddr_ns *sns = &ssns;
+       extern char *ns_print();
+
        sns->sns_addr = *x;
        return(ns_print(sns));
 }
        sns->sns_addr = *x;
        return(ns_print(sns));
 }