1 1.18 joerg /* $NetBSD: ip.c,v 1.18 2014/06/03 22:22:41 joerg 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.18 joerg __RCSID("$NetBSD: ip.c,v 1.18 2014/06/03 22:22:41 joerg 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.1 ad #include <string.h> 46 1.5 ad 47 1.1 ad #include "systat.h" 48 1.1 ad #include "extern.h" 49 1.1 ad 50 1.1 ad #define LHD(row, str) mvwprintw(wnd, row, 10, str) 51 1.1 ad #define RHD(row, str) mvwprintw(wnd, row, 45, str); 52 1.4 itojun #define SHOW(stat, row, col) \ 53 1.4 itojun mvwprintw(wnd, row, col, "%9llu", (unsigned long long)curstat.stat) 54 1.1 ad 55 1.1 ad struct mystat { 56 1.15 thorpej uint64_t i[IP_NSTATS]; 57 1.14 thorpej uint64_t u[UDP_NSTATS]; 58 1.1 ad }; 59 1.1 ad 60 1.8 ad enum update { 61 1.8 ad UPDATE_TIME, 62 1.8 ad UPDATE_BOOT, 63 1.8 ad UPDATE_RUN, 64 1.8 ad }; 65 1.8 ad 66 1.8 ad static enum update update = UPDATE_TIME; 67 1.1 ad static struct mystat curstat; 68 1.8 ad static struct mystat oldstat; 69 1.8 ad static struct mystat newstat; 70 1.1 ad 71 1.1 ad WINDOW * 72 1.1 ad openip(void) 73 1.1 ad { 74 1.1 ad 75 1.11 dsl return (subwin(stdscr, -1, 0, 5, 0)); 76 1.1 ad } 77 1.1 ad 78 1.1 ad void 79 1.8 ad closeip(WINDOW *w) 80 1.1 ad { 81 1.1 ad 82 1.1 ad if (w != NULL) { 83 1.1 ad wclear(w); 84 1.1 ad wrefresh(w); 85 1.1 ad delwin(w); 86 1.1 ad } 87 1.1 ad } 88 1.1 ad 89 1.1 ad void 90 1.1 ad labelip(void) 91 1.1 ad { 92 1.2 ad 93 1.1 ad wmove(wnd, 0, 0); wclrtoeol(wnd); 94 1.1 ad 95 1.1 ad LHD(0, "total packets received"); 96 1.1 ad LHD(1, " passed to upper layers"); 97 1.1 ad LHD(2, " with bad checksums"); 98 1.1 ad LHD(3, " too short for header"); 99 1.1 ad LHD(4, " too short for data"); 100 1.1 ad LHD(5, " with invalid hlen"); 101 1.1 ad LHD(6, " with invalid length"); 102 1.1 ad LHD(7, " with invalid version"); 103 1.1 ad LHD(8, " too large"); 104 1.1 ad LHD(9, " option errors"); 105 1.1 ad LHD(10, " fragments received"); 106 1.1 ad LHD(11, " fragments dropped"); 107 1.1 ad LHD(12, " fragments timed out"); 108 1.1 ad LHD(13, " packets reassembled ok"); 109 1.1 ad 110 1.1 ad LHD(15, "packets forwarded"); 111 1.1 ad LHD(16, " fast forwarded"); 112 1.1 ad LHD(17, " unreachable dests"); 113 1.1 ad LHD(18, " redirects generated"); 114 1.1 ad 115 1.1 ad RHD(0, "total packets sent"); 116 1.1 ad RHD(1, " generated locally"); 117 1.1 ad RHD(2, " output drops"); 118 1.1 ad RHD(3, " output fragments generated"); 119 1.1 ad RHD(4, " fragmentation failed"); 120 1.1 ad RHD(5, " destinations unreachable"); 121 1.1 ad RHD(6, " packets output via raw IP"); 122 1.1 ad RHD(7, " total UDP packets sent"); 123 1.1 ad 124 1.10 wiz RHD(9, "total UDP packets received"); 125 1.1 ad RHD(10, " too short for header"); 126 1.1 ad RHD(11, " invalid checksum"); 127 1.1 ad RHD(12, " invalid length"); 128 1.1 ad RHD(13, " no socket for dest port"); 129 1.1 ad RHD(14, " no socket for broadcast"); 130 1.1 ad RHD(15, " socket buffer full"); 131 1.1 ad } 132 1.1 ad 133 1.1 ad void 134 1.1 ad showip(void) 135 1.1 ad { 136 1.3 msaitoh u_quad_t totalout; 137 1.1 ad 138 1.15 thorpej totalout = curstat.i[IP_STAT_FORWARD] + curstat.i[IP_STAT_LOCALOUT]; 139 1.1 ad 140 1.15 thorpej SHOW(i[IP_STAT_TOTAL], 0, 0); 141 1.6 thorpej mvwprintw(wnd, 0, 35, "%9llu", (unsigned long long)totalout); 142 1.15 thorpej SHOW(i[IP_STAT_DELIVERED], 1, 0); 143 1.15 thorpej SHOW(i[IP_STAT_BADSUM], 2, 0); 144 1.15 thorpej SHOW(i[IP_STAT_TOOSHORT], 3, 0); 145 1.15 thorpej SHOW(i[IP_STAT_TOOSMALL], 4, 0); 146 1.15 thorpej SHOW(i[IP_STAT_BADHLEN], 5, 0); 147 1.15 thorpej SHOW(i[IP_STAT_BADLEN], 6, 0); 148 1.15 thorpej SHOW(i[IP_STAT_BADVERS], 7, 0); 149 1.15 thorpej SHOW(i[IP_STAT_TOOLONG], 8, 0); 150 1.15 thorpej SHOW(i[IP_STAT_BADOPTIONS], 9, 0); 151 1.15 thorpej 152 1.15 thorpej SHOW(i[IP_STAT_LOCALOUT], 1, 35); 153 1.15 thorpej SHOW(i[IP_STAT_ODROPPED], 2, 35); 154 1.15 thorpej SHOW(i[IP_STAT_OFRAGMENTS], 3, 35); 155 1.15 thorpej SHOW(i[IP_STAT_CANTFRAG], 4, 35); 156 1.15 thorpej SHOW(i[IP_STAT_NOROUTE], 5, 35); 157 1.15 thorpej SHOW(i[IP_STAT_RAWOUT], 6, 35); 158 1.14 thorpej SHOW(u[UDP_STAT_OPACKETS], 7, 35); 159 1.1 ad 160 1.15 thorpej SHOW(i[IP_STAT_FRAGMENTS], 10, 0); 161 1.15 thorpej SHOW(i[IP_STAT_FRAGDROPPED], 11, 0); 162 1.15 thorpej SHOW(i[IP_STAT_FRAGTIMEOUT], 12, 0); 163 1.15 thorpej SHOW(i[IP_STAT_REASSEMBLED], 13, 0); 164 1.15 thorpej 165 1.15 thorpej SHOW(i[IP_STAT_FORWARD], 15, 0); 166 1.15 thorpej SHOW(i[IP_STAT_FASTFORWARD], 16, 0); 167 1.15 thorpej SHOW(i[IP_STAT_CANTFORWARD], 17, 0); 168 1.15 thorpej SHOW(i[IP_STAT_REDIRECTSENT], 18, 0); 169 1.1 ad 170 1.14 thorpej SHOW(u[UDP_STAT_IPACKETS], 9, 35); 171 1.14 thorpej SHOW(u[UDP_STAT_HDROPS], 10, 35); 172 1.14 thorpej SHOW(u[UDP_STAT_BADSUM], 11, 35); 173 1.14 thorpej SHOW(u[UDP_STAT_BADLEN], 12, 35); 174 1.14 thorpej SHOW(u[UDP_STAT_NOPORT], 13, 35); 175 1.14 thorpej SHOW(u[UDP_STAT_NOPORTBCAST], 14, 35); 176 1.14 thorpej SHOW(u[UDP_STAT_FULLSOCK], 15, 35); 177 1.1 ad } 178 1.1 ad 179 1.1 ad int 180 1.1 ad initip(void) 181 1.1 ad { 182 1.2 ad 183 1.1 ad return 1; 184 1.1 ad } 185 1.1 ad 186 1.1 ad void 187 1.1 ad fetchip(void) 188 1.1 ad { 189 1.18 joerg size_t size; 190 1.2 ad 191 1.18 joerg size = sizeof(newstat.i); 192 1.18 joerg if (sysctlbyname("net.inet.ip.stats", newstat.i, &size, NULL, 0) == -1) 193 1.18 joerg return; 194 1.18 joerg size = sizeof(newstat.u); 195 1.18 joerg if (sysctlbyname("net.inet.udp.stats", newstat.u, &size, NULL, 0) == -1) 196 1.18 joerg return; 197 1.8 ad 198 1.15 thorpej ADJINETCTR(curstat, oldstat, newstat, i[IP_STAT_TOTAL]); 199 1.15 thorpej ADJINETCTR(curstat, oldstat, newstat, i[IP_STAT_DELIVERED]); 200 1.15 thorpej ADJINETCTR(curstat, oldstat, newstat, i[IP_STAT_BADSUM]); 201 1.15 thorpej ADJINETCTR(curstat, oldstat, newstat, i[IP_STAT_TOOSHORT]); 202 1.15 thorpej ADJINETCTR(curstat, oldstat, newstat, i[IP_STAT_TOOSMALL]); 203 1.15 thorpej ADJINETCTR(curstat, oldstat, newstat, i[IP_STAT_BADHLEN]); 204 1.15 thorpej ADJINETCTR(curstat, oldstat, newstat, i[IP_STAT_BADLEN]); 205 1.15 thorpej ADJINETCTR(curstat, oldstat, newstat, i[IP_STAT_BADVERS]); 206 1.15 thorpej ADJINETCTR(curstat, oldstat, newstat, i[IP_STAT_TOOLONG]); 207 1.15 thorpej ADJINETCTR(curstat, oldstat, newstat, i[IP_STAT_BADOPTIONS]); 208 1.15 thorpej ADJINETCTR(curstat, oldstat, newstat, i[IP_STAT_LOCALOUT]); 209 1.15 thorpej ADJINETCTR(curstat, oldstat, newstat, i[IP_STAT_ODROPPED]); 210 1.15 thorpej ADJINETCTR(curstat, oldstat, newstat, i[IP_STAT_OFRAGMENTS]); 211 1.15 thorpej ADJINETCTR(curstat, oldstat, newstat, i[IP_STAT_CANTFRAG]); 212 1.15 thorpej ADJINETCTR(curstat, oldstat, newstat, i[IP_STAT_NOROUTE]); 213 1.15 thorpej ADJINETCTR(curstat, oldstat, newstat, i[IP_STAT_RAWOUT]); 214 1.15 thorpej ADJINETCTR(curstat, oldstat, newstat, i[IP_STAT_FRAGMENTS]); 215 1.15 thorpej ADJINETCTR(curstat, oldstat, newstat, i[IP_STAT_FRAGDROPPED]); 216 1.15 thorpej ADJINETCTR(curstat, oldstat, newstat, i[IP_STAT_FRAGTIMEOUT]); 217 1.15 thorpej ADJINETCTR(curstat, oldstat, newstat, i[IP_STAT_REASSEMBLED]); 218 1.15 thorpej ADJINETCTR(curstat, oldstat, newstat, i[IP_STAT_FORWARD]); 219 1.15 thorpej ADJINETCTR(curstat, oldstat, newstat, i[IP_STAT_FASTFORWARD]); 220 1.15 thorpej ADJINETCTR(curstat, oldstat, newstat, i[IP_STAT_CANTFORWARD]); 221 1.15 thorpej ADJINETCTR(curstat, oldstat, newstat, i[IP_STAT_REDIRECTSENT]); 222 1.14 thorpej ADJINETCTR(curstat, oldstat, newstat, u[UDP_STAT_OPACKETS]); 223 1.14 thorpej ADJINETCTR(curstat, oldstat, newstat, u[UDP_STAT_IPACKETS]); 224 1.14 thorpej ADJINETCTR(curstat, oldstat, newstat, u[UDP_STAT_HDROPS]); 225 1.14 thorpej ADJINETCTR(curstat, oldstat, newstat, u[UDP_STAT_BADSUM]); 226 1.14 thorpej ADJINETCTR(curstat, oldstat, newstat, u[UDP_STAT_BADLEN]); 227 1.14 thorpej ADJINETCTR(curstat, oldstat, newstat, u[UDP_STAT_NOPORT]); 228 1.14 thorpej ADJINETCTR(curstat, oldstat, newstat, u[UDP_STAT_NOPORTBCAST]); 229 1.14 thorpej ADJINETCTR(curstat, oldstat, newstat, u[UDP_STAT_FULLSOCK]); 230 1.8 ad 231 1.8 ad if (update == UPDATE_TIME) 232 1.8 ad memcpy(&oldstat, &newstat, sizeof(oldstat)); 233 1.8 ad } 234 1.8 ad 235 1.8 ad void 236 1.8 ad ip_boot(char *args) 237 1.8 ad { 238 1.8 ad 239 1.8 ad memset(&oldstat, 0, sizeof(oldstat)); 240 1.8 ad update = UPDATE_BOOT; 241 1.8 ad } 242 1.8 ad 243 1.8 ad void 244 1.8 ad ip_run(char *args) 245 1.8 ad { 246 1.8 ad 247 1.8 ad if (update != UPDATE_RUN) { 248 1.8 ad memcpy(&oldstat, &newstat, sizeof(oldstat)); 249 1.8 ad update = UPDATE_RUN; 250 1.8 ad } 251 1.8 ad } 252 1.8 ad 253 1.8 ad void 254 1.8 ad ip_time(char *args) 255 1.8 ad { 256 1.8 ad 257 1.8 ad if (update != UPDATE_TIME) { 258 1.8 ad memcpy(&oldstat, &newstat, sizeof(oldstat)); 259 1.8 ad update = UPDATE_TIME; 260 1.8 ad } 261 1.8 ad } 262 1.8 ad 263 1.8 ad void 264 1.8 ad ip_zero(char *args) 265 1.8 ad { 266 1.8 ad 267 1.8 ad if (update == UPDATE_RUN) 268 1.8 ad memcpy(&oldstat, &newstat, sizeof(oldstat)); 269 1.1 ad } 270