|  | /* | 
|  | * 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__ */ |