1118318Sdwmalone/*- 2118318Sdwmalone * Copyright (c) 1980, 1992, 1993 3118318Sdwmalone * The Regents of the University of California. All rights reserved. 4118318Sdwmalone * 5118318Sdwmalone * Redistribution and use in source and binary forms, with or without 6118318Sdwmalone * modification, are permitted provided that the following conditions 7118318Sdwmalone * are met: 8118318Sdwmalone * 1. Redistributions of source code must retain the above copyright 9118318Sdwmalone * notice, this list of conditions and the following disclaimer. 10118318Sdwmalone * 2. Redistributions in binary form must reproduce the above copyright 11118318Sdwmalone * notice, this list of conditions and the following disclaimer in the 12118318Sdwmalone * documentation and/or other materials provided with the distribution. 13118318Sdwmalone * 4. Neither the name of the University nor the names of its contributors 14118318Sdwmalone * may be used to endorse or promote products derived from this software 15118318Sdwmalone * without specific prior written permission. 16118318Sdwmalone * 17118318Sdwmalone * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 18118318Sdwmalone * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 19118318Sdwmalone * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 20118318Sdwmalone * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 21118318Sdwmalone * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 22118318Sdwmalone * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 23118318Sdwmalone * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 24118318Sdwmalone * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 25118318Sdwmalone * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 26118318Sdwmalone * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 27118318Sdwmalone * SUCH DAMAGE. 28118318Sdwmalone */ 29118318Sdwmalone 30118318Sdwmalone#include <sys/cdefs.h> 31118318Sdwmalone 32118318Sdwmalone__FBSDID("$FreeBSD$"); 33118318Sdwmalone 34118318Sdwmalone#ifdef lint 35118318Sdwmalonestatic const char sccsid[] = "@(#)mbufs.c 8.1 (Berkeley) 6/6/93"; 36118318Sdwmalone#endif 37118318Sdwmalone 38118318Sdwmalone/* From: 39118318Sdwmalone "Id: mbufs.c,v 1.5 1997/02/24 20:59:03 wollman Exp" 40118318Sdwmalone*/ 41118318Sdwmalone 42118318Sdwmalone#ifdef INET6 43118318Sdwmalone#include <sys/param.h> 44118318Sdwmalone#include <sys/types.h> 45118318Sdwmalone#include <sys/socket.h> 46118318Sdwmalone#include <sys/sysctl.h> 47118318Sdwmalone 48118318Sdwmalone#include <netinet/in.h> 49118318Sdwmalone#include <netinet/in_systm.h> 50118318Sdwmalone#include <netinet/ip.h> 51118318Sdwmalone#include <netinet6/ip6_var.h> 52118318Sdwmalone 53118318Sdwmalone#include <stdlib.h> 54118318Sdwmalone#include <string.h> 55118318Sdwmalone#include <paths.h> 56118318Sdwmalone 57118318Sdwmalone#include "systat.h" 58118318Sdwmalone#include "extern.h" 59118318Sdwmalone#include "mode.h" 60118318Sdwmalone 61118318Sdwmalonestatic struct ip6stat curstat, initstat, oldstat; 62118318Sdwmalone 63118318Sdwmalone/*- 64118318Sdwmalone--0 1 2 3 4 5 6 7 65118318Sdwmalone--0123456789012345678901234567890123456789012345678901234567890123456789012345 66158160Sbde00 IPv6 Input IPv6 Output 67158160Sbde019999999 total packets received 999999999 total packets sent 68158160Sbde029999999 - too short for header 999999999 - generated locally 69158160Sbde039999999 - too short for data 999999999 - output drops 70158160Sbde049999999 - with invalid version 999999999 output fragments generated 71158160Sbde059999999 total fragments received 999999999 - fragmentation failed 72158160Sbde069999999 - fragments dropped 999999999 destinations unreachable 73158160Sbde079999999 - fragments timed out 999999999 packets output via raw IP 74158161Sbde089999999 - fragments overflown 75158160Sbde099999999 - packets reassembled ok Input next-header histogram 76158160Sbde109999999 packets forwarded 999999999 - destination options 77158160Sbde119999999 - unreachable dests 999999999 - hop-by-hop options 78158160Sbde129999999 - redirects generated 999999999 - IPv4 79158160Sbde139999999 option errors 999999999 - TCP 80158160Sbde149999999 unwanted multicasts 999999999 - UDP 81158160Sbde159999999 delivered to upper layer 999999999 - IPv6 82158160Sbde169999999 bad scope packets 999999999 - routing header 83158160Sbde179999999 address selection failed 999999999 - fragmentation header 84158160Sbde18 999999999 - ICMP6 85158161Sbde19 999999999 - none 86118318Sdwmalone--0123456789012345678901234567890123456789012345678901234567890123456789012345 87118318Sdwmalone--0 1 2 3 4 5 6 7 88118318Sdwmalone*/ 89118318Sdwmalone 90118318SdwmaloneWINDOW * 91118318Sdwmaloneopenip6(void) 92118318Sdwmalone{ 93158160Sbde return (subwin(stdscr, LINES-3-1, 0, MAINWIN_ROW, 0)); 94118318Sdwmalone} 95118318Sdwmalone 96118318Sdwmalonevoid 97175387Sdelphijcloseip6(WINDOW *w) 98118318Sdwmalone{ 99118318Sdwmalone if (w == NULL) 100118318Sdwmalone return; 101118318Sdwmalone wclear(w); 102118318Sdwmalone wrefresh(w); 103118318Sdwmalone delwin(w); 104118318Sdwmalone} 105118318Sdwmalone 106118318Sdwmalonevoid 107118318Sdwmalonelabelip6(void) 108118318Sdwmalone{ 109118318Sdwmalone wmove(wnd, 0, 0); wclrtoeol(wnd); 110118318Sdwmalone#define L(row, str) mvwprintw(wnd, row, 10, str) 111118318Sdwmalone#define R(row, str) mvwprintw(wnd, row, 45, str); 112158160Sbde L(0, "IPv6 Input"); R(0, "IPv6 Output"); 113158160Sbde L(1, "total packets received"); R(1, "total packets sent"); 114158160Sbde L(2, "- too short for header"); R(2, "- generated locally"); 115158160Sbde L(3, "- too short for data"); R(3, "- output drops"); 116158160Sbde L(4, "- with invalid version"); R(4, "output fragments generated"); 117158160Sbde L(5, "total fragments received"); R(5, "- fragmentation failed"); 118158160Sbde L(6, "- fragments dropped"); R(6, "destinations unreachable"); 119158160Sbde L(7, "- fragments timed out"); R(7, "packets output via raw IP"); 120158160Sbde L(8, "- fragments overflown"); 121158160Sbde L(9, "- packets reassembled ok"); R(9, "Input next-header histogram"); 122158160Sbde L(10, "packets forwarded"); R(10, " - destination options"); 123158160Sbde L(11, "- unreachable dests"); R(11, " - hop-by-hop options"); 124158160Sbde L(12, "- redirects generated"); R(12, " - IPv4"); 125158160Sbde L(13, "option errors"); R(13, " - TCP"); 126158160Sbde L(14, "unwanted multicasts"); R(14, " - UDP"); 127158160Sbde L(15, "delivered to upper layer"); R(15, " - IPv6"); 128158160Sbde L(16, "bad scope packets"); R(16, " - routing header"); 129158160Sbde L(17, "address selection failed"); R(17, " - fragmentation header"); 130158160Sbde R(18, " - ICMP6"); 131158160Sbde R(19, " - none"); 132118318Sdwmalone#undef L 133118318Sdwmalone#undef R 134118318Sdwmalone} 135118318Sdwmalone 136118318Sdwmalonestatic void 137118318Sdwmalonedomode(struct ip6stat *ret) 138118318Sdwmalone{ 139118318Sdwmalone const struct ip6stat *sub; 140118318Sdwmalone int divisor = 1, i; 141118318Sdwmalone 142118318Sdwmalone switch(currentmode) { 143118318Sdwmalone case display_RATE: 144118318Sdwmalone sub = &oldstat; 145240605Smelifaro divisor = (delay > 1000000) ? delay / 1000000 : 1; 146118318Sdwmalone break; 147118318Sdwmalone case display_DELTA: 148118318Sdwmalone sub = &oldstat; 149118318Sdwmalone break; 150118318Sdwmalone case display_SINCE: 151118318Sdwmalone sub = &initstat; 152118318Sdwmalone break; 153118318Sdwmalone default: 154118318Sdwmalone *ret = curstat; 155118318Sdwmalone return; 156118318Sdwmalone } 157118318Sdwmalone#define DO(stat) ret->stat = (curstat.stat - sub->stat) / divisor 158118318Sdwmalone DO(ip6s_total); 159118318Sdwmalone DO(ip6s_tooshort); 160118318Sdwmalone DO(ip6s_toosmall); 161118318Sdwmalone DO(ip6s_fragments); 162118318Sdwmalone DO(ip6s_fragdropped); 163118318Sdwmalone DO(ip6s_fragtimeout); 164118318Sdwmalone DO(ip6s_fragoverflow); 165118318Sdwmalone DO(ip6s_forward); 166118318Sdwmalone DO(ip6s_cantforward); 167118318Sdwmalone DO(ip6s_redirectsent); 168118318Sdwmalone DO(ip6s_delivered); 169118318Sdwmalone DO(ip6s_localout); 170118318Sdwmalone DO(ip6s_odropped); 171118318Sdwmalone DO(ip6s_reassembled); 172118318Sdwmalone DO(ip6s_fragmented); 173118318Sdwmalone DO(ip6s_ofragments); 174118318Sdwmalone DO(ip6s_cantfrag); 175118318Sdwmalone DO(ip6s_badoptions); 176118318Sdwmalone DO(ip6s_noroute); 177118318Sdwmalone DO(ip6s_badvers); 178118318Sdwmalone DO(ip6s_rawout); 179118318Sdwmalone DO(ip6s_notmember); 180118318Sdwmalone for (i = 0; i < 256; i++) 181118318Sdwmalone DO(ip6s_nxthist[i]); 182118318Sdwmalone DO(ip6s_badscope); 183118318Sdwmalone DO(ip6s_sources_none); 184118318Sdwmalone#undef DO 185118318Sdwmalone} 186158161Sbde 187118318Sdwmalonevoid 188118318Sdwmaloneshowip6(void) 189118318Sdwmalone{ 190118318Sdwmalone struct ip6stat stats; 191118318Sdwmalone u_long totalout; 192118318Sdwmalone 193118318Sdwmalone domode(&stats); 194118318Sdwmalone totalout = stats.ip6s_forward + stats.ip6s_localout; 195118318Sdwmalone 196118318Sdwmalone#define DO(stat, row, col) \ 197118318Sdwmalone mvwprintw(wnd, row, col, "%9lu", stats.stat) 198118318Sdwmalone 199158160Sbde DO(ip6s_total, 1, 0); 200158160Sbde mvwprintw(wnd, 1, 35, "%9lu", totalout); 201158160Sbde DO(ip6s_tooshort, 2, 0); 202158160Sbde DO(ip6s_localout, 2, 35); 203158160Sbde DO(ip6s_toosmall, 3, 0); 204158160Sbde DO(ip6s_odropped, 3, 35); 205158160Sbde DO(ip6s_badvers, 4, 0); 206158160Sbde DO(ip6s_ofragments, 4, 35); 207158160Sbde DO(ip6s_fragments, 5, 0); 208158160Sbde DO(ip6s_cantfrag, 5, 35); 209158160Sbde DO(ip6s_fragdropped, 6, 0); 210158160Sbde DO(ip6s_noroute, 6, 35); 211158160Sbde DO(ip6s_fragtimeout, 7, 0); 212158160Sbde DO(ip6s_rawout, 7, 35); 213158160Sbde DO(ip6s_fragoverflow, 8, 0); 214158160Sbde DO(ip6s_reassembled, 9, 0); 215158160Sbde DO(ip6s_forward, 10, 0); 216118318Sdwmalone DO(ip6s_nxthist[IPPROTO_DSTOPTS], 10, 35); 217158160Sbde DO(ip6s_cantforward, 11, 0); 218118318Sdwmalone DO(ip6s_nxthist[IPPROTO_HOPOPTS], 11, 35); 219158160Sbde DO(ip6s_redirectsent, 12, 0); 220118318Sdwmalone DO(ip6s_nxthist[IPPROTO_IPV4], 12, 35); 221158160Sbde DO(ip6s_badoptions, 13, 0); 222118318Sdwmalone DO(ip6s_nxthist[IPPROTO_TCP], 13, 35); 223158160Sbde DO(ip6s_notmember, 14, 0); 224118318Sdwmalone DO(ip6s_nxthist[IPPROTO_UDP], 14, 35); 225158160Sbde DO(ip6s_delivered, 15, 0); 226118318Sdwmalone DO(ip6s_nxthist[IPPROTO_IPV6], 15, 35); 227158160Sbde DO(ip6s_badscope, 16, 0); 228118318Sdwmalone DO(ip6s_nxthist[IPPROTO_ROUTING], 16, 35); 229158160Sbde DO(ip6s_sources_none, 17, 0); 230118318Sdwmalone DO(ip6s_nxthist[IPPROTO_FRAGMENT], 17, 35); 231118318Sdwmalone DO(ip6s_nxthist[IPPROTO_ICMPV6], 18, 35); 232118318Sdwmalone DO(ip6s_nxthist[IPPROTO_NONE], 19, 35); 233118318Sdwmalone#undef DO 234118318Sdwmalone} 235118318Sdwmalone 236118318Sdwmaloneint 237118318Sdwmaloneinitip6(void) 238118318Sdwmalone{ 239118318Sdwmalone size_t len; 240118318Sdwmalone int name[4]; 241118318Sdwmalone 242118318Sdwmalone name[0] = CTL_NET; 243118318Sdwmalone name[1] = PF_INET6; 244118318Sdwmalone name[2] = IPPROTO_IPV6; 245118318Sdwmalone name[3] = IPV6CTL_STATS; 246118318Sdwmalone 247118318Sdwmalone len = 0; 248118318Sdwmalone if (sysctl(name, 4, 0, &len, 0, 0) < 0) { 249118318Sdwmalone error("sysctl getting ip6stat size failed"); 250118318Sdwmalone return 0; 251118318Sdwmalone } 252118318Sdwmalone if (len > sizeof curstat) { 253118318Sdwmalone error("ip6stat structure has grown--recompile systat!"); 254118318Sdwmalone return 0; 255118318Sdwmalone } 256118318Sdwmalone if (sysctl(name, 4, &initstat, &len, 0, 0) < 0) { 257118318Sdwmalone error("sysctl getting ip6stat failed"); 258118318Sdwmalone return 0; 259118318Sdwmalone } 260118318Sdwmalone oldstat = initstat; 261118318Sdwmalone return 1; 262118318Sdwmalone} 263118318Sdwmalone 264118318Sdwmalonevoid 265118318Sdwmaloneresetip6(void) 266118318Sdwmalone{ 267118318Sdwmalone size_t len; 268118318Sdwmalone int name[4]; 269118318Sdwmalone 270118318Sdwmalone name[0] = CTL_NET; 271118318Sdwmalone name[1] = PF_INET6; 272118318Sdwmalone name[2] = IPPROTO_IPV6; 273118318Sdwmalone name[3] = IPV6CTL_STATS; 274118318Sdwmalone 275118318Sdwmalone len = sizeof initstat; 276118318Sdwmalone if (sysctl(name, 4, &initstat, &len, 0, 0) < 0) { 277118318Sdwmalone error("sysctl getting ipstat failed"); 278118318Sdwmalone } 279118318Sdwmalone 280118318Sdwmalone oldstat = initstat; 281118318Sdwmalone} 282118318Sdwmalone 283118318Sdwmalonevoid 284118318Sdwmalonefetchip6(void) 285118318Sdwmalone{ 286118318Sdwmalone int name[4]; 287118318Sdwmalone size_t len; 288118318Sdwmalone 289118318Sdwmalone oldstat = curstat; 290118318Sdwmalone name[0] = CTL_NET; 291118318Sdwmalone name[1] = PF_INET6; 292118318Sdwmalone name[2] = IPPROTO_IPV6; 293118318Sdwmalone name[3] = IPV6CTL_STATS; 294118318Sdwmalone len = sizeof curstat; 295118318Sdwmalone 296118318Sdwmalone if (sysctl(name, 4, &curstat, &len, 0, 0) < 0) 297118318Sdwmalone return; 298118318Sdwmalone} 299118318Sdwmalone 300118318Sdwmalone#endif 301