xref: /utopia/UTPA2-700.0.x/projects/tools/lint/mips-linux-gnu_include/linux/sonet.h (revision 53ee8cc121a030b8d368113ac3e966b4705770ef)
1*53ee8cc1Swenshuai.xi /* sonet.h - SONET/SHD physical layer control */
2*53ee8cc1Swenshuai.xi 
3*53ee8cc1Swenshuai.xi /* Written 1995-2000 by Werner Almesberger, EPFL LRC/ICA */
4*53ee8cc1Swenshuai.xi 
5*53ee8cc1Swenshuai.xi 
6*53ee8cc1Swenshuai.xi #ifndef LINUX_SONET_H
7*53ee8cc1Swenshuai.xi #define LINUX_SONET_H
8*53ee8cc1Swenshuai.xi 
9*53ee8cc1Swenshuai.xi #define __SONET_ITEMS \
10*53ee8cc1Swenshuai.xi     __HANDLE_ITEM(section_bip); 	/* section parity errors (B1) */ \
11*53ee8cc1Swenshuai.xi     __HANDLE_ITEM(line_bip);		/* line parity errors (B2) */ \
12*53ee8cc1Swenshuai.xi     __HANDLE_ITEM(path_bip);		/* path parity errors (B3) */ \
13*53ee8cc1Swenshuai.xi     __HANDLE_ITEM(line_febe);		/* line parity errors at remote */ \
14*53ee8cc1Swenshuai.xi     __HANDLE_ITEM(path_febe);		/* path parity errors at remote */ \
15*53ee8cc1Swenshuai.xi     __HANDLE_ITEM(corr_hcs);		/* correctable header errors */ \
16*53ee8cc1Swenshuai.xi     __HANDLE_ITEM(uncorr_hcs);		/* uncorrectable header errors */ \
17*53ee8cc1Swenshuai.xi     __HANDLE_ITEM(tx_cells);		/* cells sent */ \
18*53ee8cc1Swenshuai.xi     __HANDLE_ITEM(rx_cells);		/* cells received */
19*53ee8cc1Swenshuai.xi 
20*53ee8cc1Swenshuai.xi struct sonet_stats {
21*53ee8cc1Swenshuai.xi #define __HANDLE_ITEM(i) int i
22*53ee8cc1Swenshuai.xi 	__SONET_ITEMS
23*53ee8cc1Swenshuai.xi #undef __HANDLE_ITEM
24*53ee8cc1Swenshuai.xi } __attribute__ ((packed));
25*53ee8cc1Swenshuai.xi 
26*53ee8cc1Swenshuai.xi 
27*53ee8cc1Swenshuai.xi #define SONET_GETSTAT	_IOR('a',ATMIOC_PHYTYP,struct sonet_stats)
28*53ee8cc1Swenshuai.xi 					/* get statistics */
29*53ee8cc1Swenshuai.xi #define SONET_GETSTATZ	_IOR('a',ATMIOC_PHYTYP+1,struct sonet_stats)
30*53ee8cc1Swenshuai.xi 					/* ... and zero counters */
31*53ee8cc1Swenshuai.xi #define SONET_SETDIAG	_IOWR('a',ATMIOC_PHYTYP+2,int)
32*53ee8cc1Swenshuai.xi 					/* set error insertion */
33*53ee8cc1Swenshuai.xi #define SONET_CLRDIAG	_IOWR('a',ATMIOC_PHYTYP+3,int)
34*53ee8cc1Swenshuai.xi 					/* clear error insertion */
35*53ee8cc1Swenshuai.xi #define SONET_GETDIAG	_IOR('a',ATMIOC_PHYTYP+4,int)
36*53ee8cc1Swenshuai.xi 					/* query error insertion */
37*53ee8cc1Swenshuai.xi #define SONET_SETFRAMING _IO('a',ATMIOC_PHYTYP+5)
38*53ee8cc1Swenshuai.xi 					/* set framing mode (SONET/SDH) */
39*53ee8cc1Swenshuai.xi #define SONET_GETFRAMING _IOR('a',ATMIOC_PHYTYP+6,int)
40*53ee8cc1Swenshuai.xi 					/* get framing mode */
41*53ee8cc1Swenshuai.xi #define SONET_GETFRSENSE _IOR('a',ATMIOC_PHYTYP+7, \
42*53ee8cc1Swenshuai.xi   unsigned char[SONET_FRSENSE_SIZE])	/* get framing sense information */
43*53ee8cc1Swenshuai.xi 
44*53ee8cc1Swenshuai.xi #define SONET_INS_SBIP	  1		/* section BIP */
45*53ee8cc1Swenshuai.xi #define SONET_INS_LBIP	  2		/* line BIP */
46*53ee8cc1Swenshuai.xi #define SONET_INS_PBIP	  4		/* path BIP */
47*53ee8cc1Swenshuai.xi #define SONET_INS_FRAME	  8		/* out of frame */
48*53ee8cc1Swenshuai.xi #define SONET_INS_LOS	 16		/* set line to zero */
49*53ee8cc1Swenshuai.xi #define SONET_INS_LAIS	 32		/* line alarm indication signal */
50*53ee8cc1Swenshuai.xi #define SONET_INS_PAIS	 64		/* path alarm indication signal */
51*53ee8cc1Swenshuai.xi #define SONET_INS_HCS	128		/* insert HCS error */
52*53ee8cc1Swenshuai.xi 
53*53ee8cc1Swenshuai.xi #define SONET_FRAME_SONET 0		/* SONET STS-3 framing */
54*53ee8cc1Swenshuai.xi #define SONET_FRAME_SDH   1		/* SDH STM-1 framing */
55*53ee8cc1Swenshuai.xi 
56*53ee8cc1Swenshuai.xi #define SONET_FRSENSE_SIZE 6		/* C1[3],H1[3] (0xff for unknown) */
57*53ee8cc1Swenshuai.xi 
58*53ee8cc1Swenshuai.xi 
59*53ee8cc1Swenshuai.xi 
60*53ee8cc1Swenshuai.xi #endif
61