diff options
| author | Erik Andersen <andersen@codepoet.org> | 2000-05-14 04:16:35 +0000 | 
|---|---|---|
| committer | Erik Andersen <andersen@codepoet.org> | 2000-05-14 04:16:35 +0000 | 
| commit | 64bc6412188b141c010ac3b8e813b837dd991e80 (patch) | |
| tree | ffa12b79ea4b13191754f54b872eb1a4f9e3a04b /include/arpa | |
Initial revision
Diffstat (limited to 'include/arpa')
| -rw-r--r-- | include/arpa/inet.h | 12 | ||||
| -rw-r--r-- | include/arpa/nameser.h | 392 | ||||
| -rw-r--r-- | include/arpa/telnet.h | 319 | ||||
| -rw-r--r-- | include/arpa/tftp.h | 80 | 
4 files changed, 803 insertions, 0 deletions
| diff --git a/include/arpa/inet.h b/include/arpa/inet.h new file mode 100644 index 000000000..cf4cd3275 --- /dev/null +++ b/include/arpa/inet.h @@ -0,0 +1,12 @@ +#ifndef __ARPA_INET_H +#define __ARPA_INET_H + +#include <netinet/in.h> + +int inet_aton(const char *cp, struct in_addr *inp); +       +unsigned long int inet_addr(const char *cp); + +char *inet_ntoa(struct in_addr in); +        +#endif diff --git a/include/arpa/nameser.h b/include/arpa/nameser.h new file mode 100644 index 000000000..ba6014216 --- /dev/null +++ b/include/arpa/nameser.h @@ -0,0 +1,392 @@ +/* + * ++Copyright++ 1983, 1989, 1993 + * - + * Copyright (c) 1983, 1989, 1993 + *    The Regents of the University of California.  All rights reserved. + * + * 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. + * - + * Portions Copyright (c) 1993 by Digital Equipment Corporation. + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies, and that + * the name of Digital Equipment Corporation not be used in advertising or + * publicity pertaining to distribution of the document or software without + * specific, written prior permission. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND DIGITAL EQUIPMENT CORP. DISCLAIMS ALL + * WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES + * OF MERCHANTABILITY AND FITNESS.   IN NO EVENT SHALL DIGITAL EQUIPMENT + * CORPORATION BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL + * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR + * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS + * ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS + * SOFTWARE. + * - + * Portions Copyright (c) 1995 by International Business Machines, Inc. + * + * International Business Machines, Inc. (hereinafter called IBM) grants + * permission under its copyrights to use, copy, modify, and distribute this + * Software with or without fee, provided that the above copyright notice and + * all paragraphs of this notice appear in all copies, and that the name of IBM + * not be used in connection with the marketing of any product incorporating + * the Software or modifications thereof, without specific, written prior + * permission. + * + * To the extent it has a right to do so, IBM grants an immunity from suit + * under its patents, if any, for the use, sale or manufacture of products to + * the extent that such products are used for performing Domain Name System + * dynamic updates in TCP/IP networks by means of the Software.  No immunity is + * granted for any product per se or for any other function of any product. + * + * THE SOFTWARE IS PROVIDED "AS IS", AND IBM DISCLAIMS ALL WARRANTIES, + * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A + * PARTICULAR PURPOSE.  IN NO EVENT SHALL IBM BE LIABLE FOR ANY SPECIAL, + * DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER ARISING + * OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE, EVEN + * IF IBM IS APPRISED OF THE POSSIBILITY OF SUCH DAMAGES. + * --Copyright-- + */ + +/* + *      @(#)nameser.h	8.1 (Berkeley) 6/2/93 + *	$Id: nameser.h,v 1.1 2000/05/14 04:16:36 erik Exp $ + */ + +#ifndef _NAMESER_H_ +#define	_NAMESER_H_ + +#include <sys/param.h> +#if (!defined(BSD)) || (BSD < 199306) +# include <sys/bitypes.h> +#else +# include <sys/types.h> +#endif +#include <sys/cdefs.h> + +#ifdef _AUX_SOURCE +# include <sys/types.h> +#endif + +/* + * revision information.  this is the release date in YYYYMMDD format. + * it can change every day so the right thing to do with it is use it + * in preprocessor commands such as "#if (__BIND > 19931104)".  do not + * compare for equality; rather, use it to determine whether your resolver + * is new enough to contain a certain feature. + */ + +#define __BIND		19960801	/* interface version stamp */ + +/* + * Define constants based on rfc883 + */ +#define PACKETSZ	512		/* maximum packet size */ +#define MAXDNAME	1025		/* maximum domain name */ +#define MAXCDNAME	255		/* maximum compressed domain name */ +#define MAXLABEL	63		/* maximum length of domain label */ +#define HFIXEDSZ	12		/* #/bytes of fixed data in header */ +#define QFIXEDSZ	4		/* #/bytes of fixed data in query */ +#define RRFIXEDSZ	10		/* #/bytes of fixed data in r record */ +#define INT32SZ		4		/* for systems without 32-bit ints */ +#define INT16SZ		2		/* for systems without 16-bit ints */ +#define INADDRSZ	4		/* IPv4 T_A */ +#define IN6ADDRSZ	16		/* IPv6 T_AAAA */ + +/* + * Internet nameserver port number + */ +#define NAMESERVER_PORT	53 + +/* + * Currently defined opcodes + */ +#define QUERY		0x0		/* standard query */ +#define IQUERY		0x1		/* inverse query */ +#define STATUS		0x2		/* nameserver status query */ +/*#define xxx		0x3*/		/* 0x3 reserved */ +#define NS_NOTIFY_OP	0x4		/* notify secondary of SOA change */ +/* + * Currently defined response codes + */ +#define NOERROR		0		/* no error */ +#define FORMERR		1		/* format error */ +#define SERVFAIL	2		/* server failure */ +#define NXDOMAIN	3		/* non existent domain */ +#define NOTIMP		4		/* not implemented */ +#define REFUSED		5		/* query refused */ + +/* + * Type values for resources and queries + */ +#define T_A		1		/* host address */ +#define T_NS		2		/* authoritative server */ +#define T_MD		3		/* mail destination */ +#define T_MF		4		/* mail forwarder */ +#define T_CNAME		5		/* canonical name */ +#define T_SOA		6		/* start of authority zone */ +#define T_MB		7		/* mailbox domain name */ +#define T_MG		8		/* mail group member */ +#define T_MR		9		/* mail rename name */ +#define T_NULL		10		/* null resource record */ +#define T_WKS		11		/* well known service */ +#define T_PTR		12		/* domain name pointer */ +#define T_HINFO		13		/* host information */ +#define T_MINFO		14		/* mailbox information */ +#define T_MX		15		/* mail routing information */ +#define T_TXT		16		/* text strings */ +#define T_RP		17		/* responsible person */ +#define T_AFSDB		18		/* AFS cell database */ +#define T_X25		19		/* X_25 calling address */ +#define T_ISDN		20		/* ISDN calling address */ +#define T_RT		21		/* router */ +#define T_NSAP		22		/* NSAP address */ +#define T_NSAP_PTR	23		/* reverse NSAP lookup (deprecated) */ +#define T_SIG		24		/* security signature */ +#define T_KEY		25		/* security key */ +#define T_PX		26		/* X.400 mail mapping */ +#define T_GPOS		27		/* geographical position (withdrawn) */ +#define T_AAAA		28		/* IP6 Address */ +#define T_LOC		29		/* Location Information */ +#define T_NXT		30		/* Next Valid Name in Zone */ +#define T_EID		31		/* Endpoint identifier */ +#define T_NIMLOC	32		/* Nimrod locator */ +#define T_SRV		33		/* Server selection */ +#define T_ATMA		34		/* ATM Address */ +#define T_NAPTR		35		/* Naming Authority PoinTeR */ +	/* non standard */ +#define T_UINFO		100		/* user (finger) information */ +#define T_UID		101		/* user ID */ +#define T_GID		102		/* group ID */ +#define T_UNSPEC	103		/* Unspecified format (binary data) */ +	/* Query type values which do not appear in resource records */ +#define	T_IXFR		251		/* incremental zone transfer */ +#define T_AXFR		252		/* transfer zone of authority */ +#define T_MAILB		253		/* transfer mailbox records */ +#define T_MAILA		254		/* transfer mail agent records */ +#define T_ANY		255		/* wildcard match */ + +/* + * Values for class field + */ + +#define C_IN		1		/* the arpa internet */ +#define C_CHAOS		3		/* for chaos net (MIT) */ +#define C_HS		4		/* for Hesiod name server (MIT) (XXX) */ +	/* Query class values which do not appear in resource records */ +#define C_ANY		255		/* wildcard match */ + +/* + * Flags field of the KEY RR rdata + */ +#define	KEYFLAG_TYPEMASK	0xC000	/* Mask for "type" bits */ +#define	KEYFLAG_TYPE_AUTH_CONF	0x0000	/* Key usable for both */ +#define	KEYFLAG_TYPE_CONF_ONLY	0x8000	/* Key usable for confidentiality */ +#define	KEYFLAG_TYPE_AUTH_ONLY	0x4000	/* Key usable for authentication */ +#define	KEYFLAG_TYPE_NO_KEY	0xC000	/* No key usable for either; no key */ +/* The type bits can also be interpreted independently, as single bits: */ +#define	KEYFLAG_NO_AUTH		0x8000	/* Key not usable for authentication */ +#define	KEYFLAG_NO_CONF		0x4000	/* Key not usable for confidentiality */ + +#define	KEYFLAG_EXPERIMENTAL	0x2000	/* Security is *mandatory* if bit=0 */ +#define	KEYFLAG_RESERVED3	0x1000  /* reserved - must be zero */ +#define	KEYFLAG_RESERVED4	0x0800  /* reserved - must be zero */ +#define	KEYFLAG_USERACCOUNT	0x0400	/* key is assoc. with a user acct */ +#define	KEYFLAG_ENTITY		0x0200	/* key is assoc. with entity eg host */ +#define	KEYFLAG_ZONEKEY		0x0100	/* key is zone key for the zone named */ +#define	KEYFLAG_IPSEC		0x0080  /* key is for IPSEC use (host or user)*/ +#define	KEYFLAG_EMAIL		0x0040  /* key is for email (MIME security) */ +#define	KEYFLAG_RESERVED10	0x0020  /* reserved - must be zero */ +#define	KEYFLAG_RESERVED11	0x0010  /* reserved - must be zero */ +#define	KEYFLAG_SIGNATORYMASK	0x000F	/* key can sign DNS RR's of same name */ + +#define  KEYFLAG_RESERVED_BITMASK ( KEYFLAG_RESERVED3 | \ +				    KEYFLAG_RESERVED4 | \ +				    KEYFLAG_RESERVED10| KEYFLAG_RESERVED11) + +/* The Algorithm field of the KEY and SIG RR's is an integer, {1..254} */ +#define	ALGORITHM_MD5RSA	1	/* MD5 with RSA */ +#define	ALGORITHM_EXPIRE_ONLY	253	/* No alg, no security */ +#define	ALGORITHM_PRIVATE_OID	254	/* Key begins with OID indicating alg */ + +/* Signatures */ +					/* Size of a mod or exp in bits */ +#define	MIN_MD5RSA_KEY_PART_BITS	 512 +#define	MAX_MD5RSA_KEY_PART_BITS	2552 +					/* Total of binary mod and exp, bytes */ +#define	MAX_MD5RSA_KEY_BYTES		((MAX_MD5RSA_KEY_PART_BITS+7/8)*2+3) +					/* Max length of text sig block */ +#define	MAX_KEY_BASE64			(((MAX_MD5RSA_KEY_BYTES+2)/3)*4) + +/* + * Status return codes for T_UNSPEC conversion routines + */ +#define CONV_SUCCESS	0 +#define CONV_OVERFLOW	(-1) +#define CONV_BADFMT	(-2) +#define CONV_BADCKSUM	(-3) +#define CONV_BADBUFLEN	(-4) + +#ifndef BYTE_ORDER +#if (BSD >= 199103) +# include <machine/endian.h> +#else +#ifdef linux +# include <endian.h> +#else +#define LITTLE_ENDIAN	1234	/* least-significant byte first (vax, pc) */ +#define BIG_ENDIAN	4321	/* most-significant byte first (IBM, net) */ +#define PDP_ENDIAN	3412	/* LSB first in word, MSW first in long (pdp)*/ + +#if defined(vax) || defined(ns32000) || defined(sun386) || defined(i386) || \ +    defined(MIPSEL) || defined(_MIPSEL) || defined(BIT_ZERO_ON_RIGHT) || \ +    defined(__alpha__) || defined(__alpha) +#define BYTE_ORDER	LITTLE_ENDIAN +#endif + +#if defined(sel) || defined(pyr) || defined(mc68000) || defined(sparc) || \ +    defined(is68k) || defined(tahoe) || defined(ibm032) || defined(ibm370) || \ +    defined(MIPSEB) || defined(_MIPSEB) || defined(_IBMR2) || defined(DGUX) ||\ +    defined(apollo) || defined(__convex__) || defined(_CRAY) || \ +    defined(__hppa) || defined(__hp9000) || \ +    defined(__hp9000s300) || defined(__hp9000s700) || \ +    defined (BIT_ZERO_ON_LEFT) || defined(m68k) +#define BYTE_ORDER	BIG_ENDIAN +#endif +#endif /* linux */ +#endif /* BSD */ +#endif /* BYTE_ORDER */ + +#if !defined(BYTE_ORDER) || \ +    (BYTE_ORDER != BIG_ENDIAN && BYTE_ORDER != LITTLE_ENDIAN && \ +    BYTE_ORDER != PDP_ENDIAN) +	/* you must determine what the correct bit order is for +	 * your compiler - the next line is an intentional error +	 * which will force your compiles to bomb until you fix +	 * the above macros. +	 */ +  error "Undefined or invalid BYTE_ORDER"; +#endif + +/* + * Structure for query header.  The order of the fields is machine- and + * compiler-dependent, depending on the byte/bit order and the layout + * of bit fields.  We use bit fields only in int variables, as this + * is all ANSI requires.  This requires a somewhat confusing rearrangement. + */ + +typedef struct { +	unsigned	id :16;		/* query identification number */ +#if BYTE_ORDER == BIG_ENDIAN +			/* fields in third byte */ +	unsigned	qr: 1;		/* response flag */ +	unsigned	opcode: 4;	/* purpose of message */ +	unsigned	aa: 1;		/* authoritative answer */ +	unsigned	tc: 1;		/* truncated message */ +	unsigned	rd: 1;		/* recursion desired */ +			/* fields in fourth byte */ +	unsigned	ra: 1;		/* recursion available */ +	unsigned	unused :1;	/* unused bits (MBZ as of 4.9.3a3) */ +	unsigned	ad: 1;		/* authentic data from named */ +	unsigned	cd: 1;		/* checking disabled by resolver */ +	unsigned	rcode :4;	/* response code */ +#endif +#if BYTE_ORDER == LITTLE_ENDIAN || BYTE_ORDER == PDP_ENDIAN +			/* fields in third byte */ +	unsigned	rd :1;		/* recursion desired */ +	unsigned	tc :1;		/* truncated message */ +	unsigned	aa :1;		/* authoritative answer */ +	unsigned	opcode :4;	/* purpose of message */ +	unsigned	qr :1;		/* response flag */ +			/* fields in fourth byte */ +	unsigned	rcode :4;	/* response code */ +	unsigned	cd: 1;		/* checking disabled by resolver */ +	unsigned	ad: 1;		/* authentic data from named */ +	unsigned	unused :1;	/* unused bits (MBZ as of 4.9.3a3) */ +	unsigned	ra :1;		/* recursion available */ +#endif +			/* remaining bytes */ +	unsigned	qdcount :16;	/* number of question entries */ +	unsigned	ancount :16;	/* number of answer entries */ +	unsigned	nscount :16;	/* number of authority entries */ +	unsigned	arcount :16;	/* number of resource entries */ +} HEADER; + +/* + * Defines for handling compressed domain names + */ +#define INDIR_MASK	0xc0 + +extern	u_int16_t	_getshort __P((const u_char *)); +extern	u_int32_t	_getlong __P((const u_char *)); + +/* + * Inline versions of get/put short/long.  Pointer is advanced. + * + * These macros demonstrate the property of C whereby it can be + * portable or it can be elegant but rarely both. + */ +#define GETSHORT(s, cp) { \ +	register u_char *t_cp = (u_char *)(cp); \ +	(s) = ((u_int16_t)t_cp[0] << 8) \ +	    | ((u_int16_t)t_cp[1]) \ +	    ; \ +	(cp) += INT16SZ; \ +} + +#define GETLONG(l, cp) { \ +	register u_char *t_cp = (u_char *)(cp); \ +	(l) = ((u_int32_t)t_cp[0] << 24) \ +	    | ((u_int32_t)t_cp[1] << 16) \ +	    | ((u_int32_t)t_cp[2] << 8) \ +	    | ((u_int32_t)t_cp[3]) \ +	    ; \ +	(cp) += INT32SZ; \ +} + +#define PUTSHORT(s, cp) { \ +	register u_int16_t t_s = (u_int16_t)(s); \ +	register u_char *t_cp = (u_char *)(cp); \ +	*t_cp++ = t_s >> 8; \ +	*t_cp   = t_s; \ +	(cp) += INT16SZ; \ +} + +#define PUTLONG(l, cp) { \ +	register u_int32_t t_l = (u_int32_t)(l); \ +	register u_char *t_cp = (u_char *)(cp); \ +	*t_cp++ = t_l >> 24; \ +	*t_cp++ = t_l >> 16; \ +	*t_cp++ = t_l >> 8; \ +	*t_cp   = t_l; \ +	(cp) += INT32SZ; \ +} + +#endif /* !_NAMESER_H_ */ diff --git a/include/arpa/telnet.h b/include/arpa/telnet.h new file mode 100644 index 000000000..25085b89a --- /dev/null +++ b/include/arpa/telnet.h @@ -0,0 +1,319 @@ +/* + * Copyright (c) 1983, 1993 + *	The Regents of the University of California.  All rights reserved. + * + * 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. + * + *	@(#)telnet.h	8.2 (Berkeley) 12/15/93 + */ + +#ifndef _ARPA_TELNET_H +#define _ARPA_TELNET_H + +/* + * Definitions for the TELNET protocol. + */ +#define	IAC	255		/* interpret as command: */ +#define	DONT	254		/* you are not to use option */ +#define	DO	253		/* please, you use option */ +#define	WONT	252		/* I won't use option */ +#define	WILL	251		/* I will use option */ +#define	SB	250		/* interpret as subnegotiation */ +#define	GA	249		/* you may reverse the line */ +#define	EL	248		/* erase the current line */ +#define	EC	247		/* erase the current character */ +#define	AYT	246		/* are you there */ +#define	AO	245		/* abort output--but let prog finish */ +#define	IP	244		/* interrupt process--permanently */ +#define	BREAK	243		/* break */ +#define	DM	242		/* data mark--for connect. cleaning */ +#define	NOP	241		/* nop */ +#define	SE	240		/* end sub negotiation */ +#define EOR     239             /* end of record (transparent mode) */ +#define	ABORT	238		/* Abort process */ +#define	SUSP	237		/* Suspend process */ +#define	xEOF	236		/* End of file: EOF is already used... */ + +#define SYNCH	242		/* for telfunc calls */ + +#ifdef TELCMDS +char *telcmds[] = { +	"EOF", "SUSP", "ABORT", "EOR", +	"SE", "NOP", "DMARK", "BRK", "IP", "AO", "AYT", "EC", +	"EL", "GA", "SB", "WILL", "WONT", "DO", "DONT", "IAC", 0, +}; +#else +extern char *telcmds[]; +#endif + +#define	TELCMD_FIRST	xEOF +#define	TELCMD_LAST	IAC +#define	TELCMD_OK(x)	((unsigned int)(x) <= TELCMD_LAST && \ +			 (unsigned int)(x) >= TELCMD_FIRST) +#define	TELCMD(x)	telcmds[(x)-TELCMD_FIRST] + +/* telnet options */ +#define TELOPT_BINARY	0	/* 8-bit data path */ +#define TELOPT_ECHO	1	/* echo */ +#define	TELOPT_RCP	2	/* prepare to reconnect */ +#define	TELOPT_SGA	3	/* suppress go ahead */ +#define	TELOPT_NAMS	4	/* approximate message size */ +#define	TELOPT_STATUS	5	/* give status */ +#define	TELOPT_TM	6	/* timing mark */ +#define	TELOPT_RCTE	7	/* remote controlled transmission and echo */ +#define TELOPT_NAOL 	8	/* negotiate about output line width */ +#define TELOPT_NAOP 	9	/* negotiate about output page size */ +#define TELOPT_NAOCRD	10	/* negotiate about CR disposition */ +#define TELOPT_NAOHTS	11	/* negotiate about horizontal tabstops */ +#define TELOPT_NAOHTD	12	/* negotiate about horizontal tab disposition */ +#define TELOPT_NAOFFD	13	/* negotiate about formfeed disposition */ +#define TELOPT_NAOVTS	14	/* negotiate about vertical tab stops */ +#define TELOPT_NAOVTD	15	/* negotiate about vertical tab disposition */ +#define TELOPT_NAOLFD	16	/* negotiate about output LF disposition */ +#define TELOPT_XASCII	17	/* extended ascic character set */ +#define	TELOPT_LOGOUT	18	/* force logout */ +#define	TELOPT_BM	19	/* byte macro */ +#define	TELOPT_DET	20	/* data entry terminal */ +#define	TELOPT_SUPDUP	21	/* supdup protocol */ +#define	TELOPT_SUPDUPOUTPUT 22	/* supdup output */ +#define	TELOPT_SNDLOC	23	/* send location */ +#define	TELOPT_TTYPE	24	/* terminal type */ +#define	TELOPT_EOR	25	/* end or record */ +#define	TELOPT_TUID	26	/* TACACS user identification */ +#define	TELOPT_OUTMRK	27	/* output marking */ +#define	TELOPT_TTYLOC	28	/* terminal location number */ +#define	TELOPT_3270REGIME 29	/* 3270 regime */ +#define	TELOPT_X3PAD	30	/* X.3 PAD */ +#define	TELOPT_NAWS	31	/* window size */ +#define	TELOPT_TSPEED	32	/* terminal speed */ +#define	TELOPT_LFLOW	33	/* remote flow control */ +#define TELOPT_LINEMODE	34	/* Linemode option */ +#define TELOPT_XDISPLOC	35	/* X Display Location */ +#define TELOPT_OLD_ENVIRON 36	/* Old - Environment variables */ +#define	TELOPT_AUTHENTICATION 37/* Authenticate */ +#define	TELOPT_ENCRYPT	38	/* Encryption option */ +#define TELOPT_NEW_ENVIRON 39	/* New - Environment variables */ +#define	TELOPT_EXOPL	255	/* extended-options-list */ + + +#define	NTELOPTS	(1+TELOPT_NEW_ENVIRON) +#ifdef TELOPTS +char *telopts[NTELOPTS+1] = { +	"BINARY", "ECHO", "RCP", "SUPPRESS GO AHEAD", "NAME", +	"STATUS", "TIMING MARK", "RCTE", "NAOL", "NAOP", +	"NAOCRD", "NAOHTS", "NAOHTD", "NAOFFD", "NAOVTS", +	"NAOVTD", "NAOLFD", "EXTEND ASCII", "LOGOUT", "BYTE MACRO", +	"DATA ENTRY TERMINAL", "SUPDUP", "SUPDUP OUTPUT", +	"SEND LOCATION", "TERMINAL TYPE", "END OF RECORD", +	"TACACS UID", "OUTPUT MARKING", "TTYLOC", +	"3270 REGIME", "X.3 PAD", "NAWS", "TSPEED", "LFLOW", +	"LINEMODE", "XDISPLOC", "OLD-ENVIRON", "AUTHENTICATION", +	"ENCRYPT", "NEW-ENVIRON", +	0, +}; +#define	TELOPT_FIRST	TELOPT_BINARY +#define	TELOPT_LAST	TELOPT_NEW_ENVIRON +#define	TELOPT_OK(x)	((unsigned int)(x) <= TELOPT_LAST) +#define	TELOPT(x)	telopts[(x)-TELOPT_FIRST] +#endif + +/* sub-option qualifiers */ +#define	TELQUAL_IS	0	/* option is... */ +#define	TELQUAL_SEND	1	/* send option */ +#define	TELQUAL_INFO	2	/* ENVIRON: informational version of IS */ +#define	TELQUAL_REPLY	2	/* AUTHENTICATION: client version of IS */ +#define	TELQUAL_NAME	3	/* AUTHENTICATION: client version of IS */ + +#define	LFLOW_OFF		0	/* Disable remote flow control */ +#define	LFLOW_ON		1	/* Enable remote flow control */ +#define	LFLOW_RESTART_ANY	2	/* Restart output on any char */ +#define	LFLOW_RESTART_XON	3	/* Restart output only on XON */ + +/* + * LINEMODE suboptions + */ + +#define	LM_MODE		1 +#define	LM_FORWARDMASK	2 +#define	LM_SLC		3 + +#define	MODE_EDIT	0x01 +#define	MODE_TRAPSIG	0x02 +#define	MODE_ACK	0x04 +#define MODE_SOFT_TAB	0x08 +#define MODE_LIT_ECHO	0x10 + +#define	MODE_MASK	0x1f + +/* Not part of protocol, but needed to simplify things... */ +#define MODE_FLOW		0x0100 +#define MODE_ECHO		0x0200 +#define MODE_INBIN		0x0400 +#define MODE_OUTBIN		0x0800 +#define MODE_FORCE		0x1000 + +#define	SLC_SYNCH	1 +#define	SLC_BRK		2 +#define	SLC_IP		3 +#define	SLC_AO		4 +#define	SLC_AYT		5 +#define	SLC_EOR		6 +#define	SLC_ABORT	7 +#define	SLC_EOF		8 +#define	SLC_SUSP	9 +#define	SLC_EC		10 +#define	SLC_EL		11 +#define	SLC_EW		12 +#define	SLC_RP		13 +#define	SLC_LNEXT	14 +#define	SLC_XON		15 +#define	SLC_XOFF	16 +#define	SLC_FORW1	17 +#define	SLC_FORW2	18 + +#define	NSLC		18 + +/* + * For backwards compatability, we define SLC_NAMES to be the + * list of names if SLC_NAMES is not defined. + */ +#define	SLC_NAMELIST	"0", "SYNCH", "BRK", "IP", "AO", "AYT", "EOR", \ +			"ABORT", "EOF", "SUSP", "EC", "EL", "EW", "RP", \ +			"LNEXT", "XON", "XOFF", "FORW1", "FORW2", 0, +#ifdef	SLC_NAMES +char *slc_names[] = { +	SLC_NAMELIST +}; +#else +extern char *slc_names[]; +#define	SLC_NAMES SLC_NAMELIST +#endif + +#define	SLC_NAME_OK(x)	((unsigned int)(x) <= NSLC) +#define SLC_NAME(x)	slc_names[x] + +#define	SLC_NOSUPPORT	0 +#define	SLC_CANTCHANGE	1 +#define	SLC_VARIABLE	2 +#define	SLC_DEFAULT	3 +#define	SLC_LEVELBITS	0x03 + +#define	SLC_FUNC	0 +#define	SLC_FLAGS	1 +#define	SLC_VALUE	2 + +#define	SLC_ACK		0x80 +#define	SLC_FLUSHIN	0x40 +#define	SLC_FLUSHOUT	0x20 + +#define	OLD_ENV_VAR	1 +#define	OLD_ENV_VALUE	0 +#define	NEW_ENV_VAR	0 +#define	NEW_ENV_VALUE	1 +#define	ENV_ESC		2 +#define	ENV_USERVAR	3 + +/* + * AUTHENTICATION suboptions + */ + +/* + * Who is authenticating who ... + */ +#define	AUTH_WHO_CLIENT		0	/* Client authenticating server */ +#define	AUTH_WHO_SERVER		1	/* Server authenticating client */ +#define	AUTH_WHO_MASK		1 + +/* + * amount of authentication done + */ +#define	AUTH_HOW_ONE_WAY	0 +#define	AUTH_HOW_MUTUAL		2 +#define	AUTH_HOW_MASK		2 + +#define	AUTHTYPE_NULL		0 +#define	AUTHTYPE_KERBEROS_V4	1 +#define	AUTHTYPE_KERBEROS_V5	2 +#define	AUTHTYPE_SPX		3 +#define	AUTHTYPE_MINK		4 +#define	AUTHTYPE_CNT		5 + +#define	AUTHTYPE_TEST		99 + +#ifdef	AUTH_NAMES +char *authtype_names[] = { +	"NULL", "KERBEROS_V4", "KERBEROS_V5", "SPX", "MINK", 0, +}; +#else +extern char *authtype_names[]; +#endif + +#define	AUTHTYPE_NAME_OK(x)	((unsigned int)(x) < AUTHTYPE_CNT) +#define	AUTHTYPE_NAME(x)	authtype_names[x] + +/* + * ENCRYPTion suboptions + */ +#define	ENCRYPT_IS		0	/* I pick encryption type ... */ +#define	ENCRYPT_SUPPORT		1	/* I support encryption types ... */ +#define	ENCRYPT_REPLY		2	/* Initial setup response */ +#define	ENCRYPT_START		3	/* Am starting to send encrypted */ +#define	ENCRYPT_END		4	/* Am ending encrypted */ +#define	ENCRYPT_REQSTART	5	/* Request you start encrypting */ +#define	ENCRYPT_REQEND		6	/* Request you send encrypting */ +#define	ENCRYPT_ENC_KEYID	7 +#define	ENCRYPT_DEC_KEYID	8 +#define	ENCRYPT_CNT		9 + +#define	ENCTYPE_ANY		0 +#define	ENCTYPE_DES_CFB64	1 +#define	ENCTYPE_DES_OFB64	2 +#define	ENCTYPE_CNT		3 + +#ifdef	ENCRYPT_NAMES +char *encrypt_names[] = { +	"IS", "SUPPORT", "REPLY", "START", "END", +	"REQUEST-START", "REQUEST-END", "ENC-KEYID", "DEC-KEYID", +	0, +}; +char *enctype_names[] = { +	"ANY", "DES_CFB64",  "DES_OFB64",  0, +}; +#else +extern char *encrypt_names[]; +extern char *enctype_names[]; +#endif + + +#define	ENCRYPT_NAME_OK(x)	((unsigned int)(x) < ENCRYPT_CNT) +#define	ENCRYPT_NAME(x)		encrypt_names[x] + +#define	ENCTYPE_NAME_OK(x)	((unsigned int)(x) < ENCTYPE_CNT) +#define	ENCTYPE_NAME(x)		enctype_names[x] +#endif /* _ARPA_TELNET_H */ diff --git a/include/arpa/tftp.h b/include/arpa/tftp.h new file mode 100644 index 000000000..0904407c7 --- /dev/null +++ b/include/arpa/tftp.h @@ -0,0 +1,80 @@ +/* + * Copyright (c) 1983, 1993 + *	The Regents of the University of California.  All rights reserved. + * + * 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. + * + *	@(#)tftp.h	8.1 (Berkeley) 6/2/93 + */ + +#ifndef _ARPA_TFTP_H +#define	_ARPA_TFTP_H 1 + +/* + * Trivial File Transfer Protocol (IEN-133) + */ +#define	SEGSIZE		512		/* data segment size */ + +/* + * Packet types. + */ +#define	RRQ	01				/* read request */ +#define	WRQ	02				/* write request */ +#define	DATA	03				/* data packet */ +#define	ACK	04				/* acknowledgement */ +#define	ERROR	05				/* error code */ + +struct	tftphdr { +	short	th_opcode;			/* packet type */ +	union { +		unsigned short	tu_block;	/* block # */ +		short	tu_code;		/* error code */ +		char	tu_stuff[1];		/* request packet stuff */ +	} th_u; +	char	th_data[1];			/* data or error string */ +}; + +#define	th_block	th_u.tu_block +#define	th_code		th_u.tu_code +#define	th_stuff	th_u.tu_stuff +#define	th_msg		th_data + +/* + * Error codes. + */ +#define	EUNDEF		0		/* not defined */ +#define	ENOTFOUND	1		/* file not found */ +#define	EACCESS		2		/* access violation */ +#define	ENOSPACE	3		/* disk full or allocation exceeded */ +#define	EBADOP		4		/* illegal TFTP operation */ +#define	EBADID		5		/* unknown transfer ID */ +#define	EEXISTS		6		/* file already exists */ +#define	ENOUSER		7		/* no such user */ + +#endif /* arpa/tftp.h */ | 
