1 1.22 riastrad /* $NetBSD: if_tun.h,v 1.22 2022/03/13 21:32:43 riastradh Exp $ */ 2 1.5 cgd 3 1.1 deraadt /* 4 1.2 deraadt * Copyright (c) 1988, Julian Onions <jpo (at) cs.nott.ac.uk> 5 1.2 deraadt * Nottingham University 1987. 6 1.1 deraadt * 7 1.1 deraadt * This source may be freely distributed, however I would be interested 8 1.1 deraadt * in any changes that are made. 9 1.1 deraadt * 10 1.2 deraadt * This driver takes packets off the IP i/f and hands them up to a 11 1.18 snj * user process to have its wicked way with. This driver has its 12 1.2 deraadt * roots in a similar driver written by Phil Cockcroft (formerly) at 13 1.2 deraadt * UCL. This driver is based much more on read/write/select mode of 14 1.2 deraadt * operation though. 15 1.12 perry * 16 1.7 perry * from: Header: if_tnreg.h,v 1.1.2.1 1992/07/16 22:39:16 friedl Exp 17 1.1 deraadt */ 18 1.1 deraadt 19 1.1 deraadt #ifndef _NET_IF_TUN_H_ 20 1.1 deraadt #define _NET_IF_TUN_H_ 21 1.1 deraadt 22 1.19 dholland #include <sys/ioccom.h> 23 1.19 dholland 24 1.8 tv #ifdef _KERNEL 25 1.21 riastrad 26 1.21 riastrad #include <sys/types.h> 27 1.21 riastrad 28 1.21 riastrad #include <sys/condvar.h> 29 1.21 riastrad #include <sys/mutex.h> 30 1.21 riastrad #include <sys/queue.h> 31 1.21 riastrad #include <sys/select.h> 32 1.21 riastrad 33 1.21 riastrad #include <net/if.h> 34 1.21 riastrad 35 1.1 deraadt struct tun_softc { 36 1.10 atatat struct ifnet tun_if; /* the interface */ 37 1.10 atatat 38 1.1 deraadt u_short tun_flags; /* misc flags */ 39 1.1 deraadt #define TUN_OPEN 0x0001 40 1.1 deraadt #define TUN_INITED 0x0002 41 1.1 deraadt #define TUN_RCOLL 0x0004 42 1.1 deraadt #define TUN_IASET 0x0008 43 1.1 deraadt #define TUN_DSTADDR 0x0010 44 1.22 riastrad #define TUN_UNUSED0 0x0040 /* was TUN_RWAIT */ 45 1.1 deraadt #define TUN_ASYNC 0x0080 46 1.1 deraadt #define TUN_NBIO 0x0100 47 1.6 pk #define TUN_PREPADDR 0x0200 48 1.14 rpaulo #define TUN_IFHEAD 0x0400 49 1.4 deraadt 50 1.4 deraadt #define TUN_READY (TUN_OPEN | TUN_INITED | TUN_IASET) 51 1.4 deraadt 52 1.11 jdolecek pid_t tun_pgid; /* PID or process group ID */ 53 1.1 deraadt struct selinfo tun_rsel; /* read select */ 54 1.1 deraadt struct selinfo tun_wsel; /* write select (not used) */ 55 1.10 atatat int tun_unit; /* the tunnel unit number */ 56 1.17 rmind kmutex_t tun_lock; /* lock for this tunnel */ 57 1.20 skrll kcondvar_t tun_cv; /* condition variable for tunnel */ 58 1.10 atatat LIST_ENTRY(tun_softc) tun_list; /* list of all tuns */ 59 1.16 ad void *tun_osih; /* soft interrupt handle */ 60 1.16 ad void *tun_isih; /* soft interrupt handle */ 61 1.1 deraadt }; 62 1.8 tv #endif /* _KERNEL */ 63 1.1 deraadt 64 1.1 deraadt /* Maximum packet size */ 65 1.3 deraadt #define TUNMTU 1500 66 1.1 deraadt 67 1.1 deraadt /* ioctl's for get/set debug */ 68 1.1 deraadt #define TUNSDEBUG _IOW('t', 90, int) 69 1.1 deraadt #define TUNGDEBUG _IOR('t', 89, int) 70 1.6 pk #define TUNSIFMODE _IOW('t', 88, int) 71 1.6 pk #define TUNSLMODE _IOW('t', 87, int) 72 1.15 rpaulo #define TUNSIFHEAD _IOW('t', 66, int) 73 1.15 rpaulo #define TUNGIFHEAD _IOR('t', 65, int) 74 1.1 deraadt 75 1.1 deraadt #endif /* !_NET_IF_TUN_H_ */ 76