 c721bccece
			
		
	
	
	c721bccece
	
	
	
		
			
			hysdn defines its own types: ulong, uint, uchar and word. Problem is, the module_param macros rely upon some of those identifiers having special meanings too. The net effect is that module_param() and friends cannot be used in ISDN because of this namespace clash. So remove the hysdn-private defines and open-code them all. Cc: Karsten Keil <kkeil@suse.de> Cc: Rusty Russell <rusty@rustcorp.com.au> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
		
			
				
	
	
		
			134 lines
		
	
	
	
		
			4.6 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			134 lines
		
	
	
	
		
			4.6 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Linux driver for HYSDN cards
 | |
|  * common definitions for both sides of the bus:
 | |
|  * - conventions both spoolers must know
 | |
|  * - channel numbers agreed upon
 | |
|  *
 | |
|  * Author    M. Steinkopf
 | |
|  * Copyright 1999 by M. Steinkopf
 | |
|  *
 | |
|  * This software may be used and distributed according to the terms
 | |
|  * of the GNU General Public License, incorporated herein by reference.
 | |
|  *
 | |
|  */
 | |
| 
 | |
| #ifndef __INCE1PC_H__
 | |
| #define __INCE1PC_H__
 | |
| 
 | |
| /*  basic scalar definitions have same meanning,
 | |
|  *  but their declaration location depends on environment
 | |
|  */ 
 | |
| 
 | |
| /*--------------------------------------channel numbers---------------------*/ 
 | |
| #define CHAN_SYSTEM     0x0001      /* system channel (spooler to spooler) */
 | |
| #define CHAN_ERRLOG     0x0005      /* error logger */
 | |
| #define CHAN_CAPI       0x0064      /* CAPI interface */
 | |
| #define CHAN_NDIS_DATA  0x1001      /* NDIS data transfer */
 | |
| 
 | |
| /*--------------------------------------POF ready msg-----------------------*/ 
 | |
| 	    /* NOTE: after booting POF sends system ready message to PC: */ 
 | |
| #define RDY_MAGIC       0x52535953UL    /* 'SYSR' reversed */
 | |
| #define RDY_MAGIC_SIZE  4               /* size in bytes */
 | |
| 
 | |
| #define MAX_N_TOK_BYTES 255
 | |
| 
 | |
| #define MIN_RDY_MSG_SIZE    RDY_MAGIC_SIZE
 | |
| #define MAX_RDY_MSG_SIZE    (RDY_MAGIC_SIZE+MAX_N_TOK_BYTES)
 | |
| 
 | |
| #define SYSR_TOK_END            0
 | |
| #define SYSR_TOK_B_CHAN         1   /* nr. of B-Channels;   DataLen=1; def: 2 */
 | |
| #define SYSR_TOK_FAX_CHAN       2   /* nr. of FAX Channels; DataLen=1; def: 0 */
 | |
| #define SYSR_TOK_MAC_ADDR       3   /* MAC-Address; DataLen=6; def: auto */
 | |
| #define SYSR_TOK_ESC            255 /* undefined data size yet */
 | |
| 			    /* default values, if not corrected by token: */ 
 | |
| #define SYSR_TOK_B_CHAN_DEF     2   /* assume 2 B-Channels */
 | |
| #define SYSR_TOK_FAX_CHAN_DEF   1   /* assume 1 FAX Channel */
 | |
| 
 | |
| /*  syntax of new SYSR token stream:
 | |
|  *  channel: CHAN_SYSTEM
 | |
|  *  msgsize: MIN_RDY_MSG_SIZE <= x <= MAX_RDY_MSG_SIZE
 | |
|  *           RDY_MAGIC_SIZE   <= x <= (RDY_MAGIC_SIZE+MAX_N_TOK_BYTES)
 | |
|  *  msg    : 0 1 2 3 {4 5 6 ..}
 | |
|  *           S Y S R  MAX_N_TOK_BYTES bytes of TokenStream
 | |
|  *
 | |
|  *  TokenStream     :=   empty
 | |
|  *                     | {NonEndTokenChunk} EndToken RotlCRC
 | |
|  *  NonEndTokenChunk:= NonEndTokenId DataLen [Data]
 | |
|  *  NonEndTokenId   := 0x01 .. 0xFE                 1 BYTE
 | |
|  *  DataLen         := 0x00 .. 0xFF                 1 BYTE
 | |
|  *  Data            := DataLen bytes
 | |
|  *  EndToken        := 0x00
 | |
|  *  RotlCRC         := special 1 byte CRC over all NonEndTokenChunk bytes
 | |
|  *                     s. RotlCRC algorithm
 | |
|  *
 | |
|  *  RotlCRC algorithm:
 | |
|  *      ucSum= 0                        1 unsigned char
 | |
|  *      for all NonEndTokenChunk bytes:
 | |
|  *          ROTL(ucSum,1)               rotate left by 1
 | |
|  *          ucSum += Char;              add current byte with swap around
 | |
|  *      RotlCRC= ~ucSum;                invert all bits for result
 | |
|  *
 | |
|  *  note:
 | |
|  *  - for 16-bit FIFO add padding 0 byte to achieve even token data bytes!
 | |
|  */ 
 | |
| 
 | |
| /*--------------------------------------error logger------------------------*/ 
 | |
| 					    /* note: pof needs final 0 ! */ 
 | |
| #define ERRLOG_CMD_REQ          "ERRLOG ON"
 | |
| #define ERRLOG_CMD_REQ_SIZE     10              /* with final 0 byte ! */
 | |
| #define ERRLOG_CMD_STOP         "ERRLOG OFF"
 | |
| #define ERRLOG_CMD_STOP_SIZE    11              /* with final 0 byte ! */
 | |
| 
 | |
| #define ERRLOG_ENTRY_SIZE       64      /* sizeof(tErrLogEntry) */
 | |
| 					/* remaining text size = 55 */ 
 | |
| #define ERRLOG_TEXT_SIZE    (ERRLOG_ENTRY_SIZE-2*4-1)
 | |
| 
 | |
| typedef struct ErrLogEntry_tag {
 | |
| 	
 | |
| /*00 */ unsigned long ulErrType;
 | |
| 	
 | |
| /*04 */ unsigned long ulErrSubtype;
 | |
| 	
 | |
| /*08 */ unsigned char ucTextSize;
 | |
| 	
 | |
| 	/*09 */ unsigned char ucText[ERRLOG_TEXT_SIZE];
 | |
| 	/* ASCIIZ of len ucTextSize-1 */
 | |
| 	
 | |
| /*40 */ 
 | |
| } tErrLogEntry;
 | |
| 
 | |
| 
 | |
| #if defined(__TURBOC__)
 | |
| #if sizeof(tErrLogEntry) != ERRLOG_ENTRY_SIZE
 | |
| #error size of tErrLogEntry != ERRLOG_ENTRY_SIZE
 | |
| #endif				/*  */
 | |
| #endif				/*  */
 | |
| 
 | |
| /*--------------------------------------DPRAM boot spooler------------------*/ 
 | |
| 				/*  this is the struture used between pc and
 | |
| 				 *  hyperstone to exchange boot data
 | |
| 				 */ 
 | |
| #define DPRAM_SPOOLER_DATA_SIZE 0x20
 | |
| typedef struct DpramBootSpooler_tag {
 | |
| 	
 | |
| /*00 */ unsigned char Len;
 | |
| 	
 | |
| /*01 */ volatile unsigned char RdPtr;
 | |
| 	
 | |
| /*02 */ unsigned char WrPtr;
 | |
| 	
 | |
| /*03 */ unsigned char Data[DPRAM_SPOOLER_DATA_SIZE];
 | |
| 	
 | |
| /*23 */ 
 | |
| } tDpramBootSpooler;
 | |
| 
 | |
| 
 | |
| #define DPRAM_SPOOLER_MIN_SIZE  5       /* Len+RdPtr+Wrptr+2*data */
 | |
| #define DPRAM_SPOOLER_DEF_SIZE  0x23    /* current default size   */
 | |
| 
 | |
| /*--------------------------------------HYCARD/ERGO DPRAM SoftUart----------*/ 
 | |
| 				    /* at DPRAM offset 0x1C00: */ 
 | |
| #define SIZE_RSV_SOFT_UART  0x1B0   /* 432 bytes reserved for SoftUart */
 | |
| 
 | |
| 
 | |
| #endif	/* __INCE1PC_H__ */
 |