| /* | 
 |  * Copyright (c) 1992, 1993, 1994, 1995, 1996 | 
 |  *	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: (1) source code distributions | 
 |  * retain the above copyright notice and this paragraph in its entirety, (2) | 
 |  * distributions including binary code include the above copyright notice and | 
 |  * this paragraph in its entirety in the documentation or other materials | 
 |  * provided with the distribution, and (3) all advertising materials mentioning | 
 |  * features or use of this software display the following acknowledgement: | 
 |  * ``This product includes software developed by the University of California, | 
 |  * Lawrence Berkeley Laboratory and its contributors.'' 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 ``AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED | 
 |  * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF | 
 |  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 
 |  * | 
 |  * @(#) $Header: /tcpdump/master/tcpdump/fddi.h,v 1.11 2002-12-11 07:13:51 guy Exp $ (LBL) | 
 |  */ | 
 |  | 
 | /* | 
 |  * Based on Ultrix if_fddi.h | 
 |  */ | 
 |  | 
 | /* | 
 |  * This stuff should come from a system header file, but there's no | 
 |  * obviously portable way to do that and it's not really going | 
 |  * to change from system to system (except for the padding business). | 
 |  */ | 
 |  | 
 | struct fddi_header { | 
 | 	u_char  fddi_fc;		/* frame control */ | 
 | 	u_char  fddi_dhost[6]; | 
 | 	u_char  fddi_shost[6]; | 
 | }; | 
 |  | 
 | /* | 
 |  * Length of an FDDI header; note that some compilers may pad | 
 |  * "struct fddi_header" to a multiple of 4 bytes, for example, so | 
 |  * "sizeof (struct fddi_header)" may not give the right | 
 |  * answer. | 
 |  */ | 
 | #define FDDI_HDRLEN 13 | 
 |  | 
 | /* Useful values for fddi_fc (frame control) field */ | 
 |  | 
 | /* | 
 |  * FDDI Frame Control bits | 
 |  */ | 
 | #define	FDDIFC_C		0x80		/* Class bit */ | 
 | #define	FDDIFC_L		0x40		/* Address length bit */ | 
 | #define	FDDIFC_F		0x30		/* Frame format bits */ | 
 | #define	FDDIFC_Z		0x0f		/* Control bits */ | 
 |  | 
 | /* | 
 |  * FDDI Frame Control values. (48-bit addressing only). | 
 |  */ | 
 | #define	FDDIFC_VOID		0x40		/* Void frame */ | 
 | #define	FDDIFC_NRT		0x80		/* Nonrestricted token */ | 
 | #define	FDDIFC_RT		0xc0		/* Restricted token */ | 
 | #define	FDDIFC_SMT_INFO		0x41		/* SMT Info */ | 
 | #define	FDDIFC_SMT_NSA		0x4F		/* SMT Next station adrs */ | 
 | #define	FDDIFC_MAC_BEACON	0xc2		/* MAC Beacon frame */ | 
 | #define	FDDIFC_MAC_CLAIM	0xc3		/* MAC Claim frame */ | 
 | #define	FDDIFC_LLC_ASYNC	0x50		/* Async. LLC frame */ | 
 | #define	FDDIFC_LLC_SYNC		0xd0		/* Sync. LLC frame */ | 
 | #define	FDDIFC_IMP_ASYNC	0x60		/* Implementor Async. */ | 
 | #define	FDDIFC_IMP_SYNC		0xe0		/* Implementor Synch. */ | 
 | #define FDDIFC_SMT		0x40		/* SMT frame */ | 
 | #define FDDIFC_MAC		0xc0		/* MAC frame */ | 
 |  | 
 | #define	FDDIFC_CLFF		0xF0		/* Class/Length/Format bits */ | 
 | #define	FDDIFC_ZZZZ		0x0F		/* Control bits */ |