2005-12-11 15:16:03 +03:00
|
|
|
/* $NetBSD: if_tun.h,v 1.13 2005/12/11 12:24:51 christos Exp $ */
|
1994-06-29 10:29:24 +04:00
|
|
|
|
1993-11-14 23:07:20 +03:00
|
|
|
/*
|
1993-12-13 08:06:33 +03:00
|
|
|
* Copyright (c) 1988, Julian Onions <jpo@cs.nott.ac.uk>
|
|
|
|
* Nottingham University 1987.
|
1993-11-14 23:07:20 +03:00
|
|
|
*
|
|
|
|
* This source may be freely distributed, however I would be interested
|
|
|
|
* in any changes that are made.
|
|
|
|
*
|
1993-12-13 08:06:33 +03:00
|
|
|
* This driver takes packets off the IP i/f and hands them up to a
|
|
|
|
* user process to have it's wicked way with. This driver has it's
|
|
|
|
* roots in a similar driver written by Phil Cockcroft (formerly) at
|
|
|
|
* UCL. This driver is based much more on read/write/select mode of
|
|
|
|
* operation though.
|
2005-02-27 01:45:09 +03:00
|
|
|
*
|
1998-01-05 08:08:43 +03:00
|
|
|
* from: Header: if_tnreg.h,v 1.1.2.1 1992/07/16 22:39:16 friedl Exp
|
1993-11-14 23:07:20 +03:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _NET_IF_TUN_H_
|
|
|
|
#define _NET_IF_TUN_H_
|
|
|
|
|
1998-03-19 00:21:48 +03:00
|
|
|
#ifdef _KERNEL
|
1993-11-14 23:07:20 +03:00
|
|
|
struct tun_softc {
|
2001-10-31 23:08:17 +03:00
|
|
|
struct ifnet tun_if; /* the interface */
|
|
|
|
|
1993-11-14 23:07:20 +03:00
|
|
|
u_short tun_flags; /* misc flags */
|
|
|
|
#define TUN_OPEN 0x0001
|
|
|
|
#define TUN_INITED 0x0002
|
|
|
|
#define TUN_RCOLL 0x0004
|
|
|
|
#define TUN_IASET 0x0008
|
|
|
|
#define TUN_DSTADDR 0x0010
|
|
|
|
#define TUN_RWAIT 0x0040
|
|
|
|
#define TUN_ASYNC 0x0080
|
|
|
|
#define TUN_NBIO 0x0100
|
1996-06-26 02:15:13 +04:00
|
|
|
#define TUN_PREPADDR 0x0200
|
1994-05-04 03:02:07 +04:00
|
|
|
|
|
|
|
#define TUN_READY (TUN_OPEN | TUN_INITED | TUN_IASET)
|
|
|
|
|
2003-09-21 23:16:48 +04:00
|
|
|
pid_t tun_pgid; /* PID or process group ID */
|
1993-11-14 23:07:20 +03:00
|
|
|
struct selinfo tun_rsel; /* read select */
|
|
|
|
struct selinfo tun_wsel; /* write select (not used) */
|
2001-10-31 23:08:17 +03:00
|
|
|
int tun_unit; /* the tunnel unit number */
|
|
|
|
struct simplelock tun_lock; /* lock for this tunnel */
|
|
|
|
LIST_ENTRY(tun_softc) tun_list; /* list of all tuns */
|
1993-11-14 23:07:20 +03:00
|
|
|
};
|
1998-03-19 00:21:48 +03:00
|
|
|
#endif /* _KERNEL */
|
1993-11-14 23:07:20 +03:00
|
|
|
|
|
|
|
/* Maximum packet size */
|
1993-12-13 17:27:01 +03:00
|
|
|
#define TUNMTU 1500
|
1993-11-14 23:07:20 +03:00
|
|
|
|
|
|
|
/* ioctl's for get/set debug */
|
|
|
|
#define TUNSDEBUG _IOW('t', 90, int)
|
|
|
|
#define TUNGDEBUG _IOR('t', 89, int)
|
1996-06-26 02:15:13 +04:00
|
|
|
#define TUNSIFMODE _IOW('t', 88, int)
|
|
|
|
#define TUNSLMODE _IOW('t', 87, int)
|
1993-11-14 23:07:20 +03:00
|
|
|
|
|
|
|
#endif /* !_NET_IF_TUN_H_ */
|