/*1* Linux driver for HYSDN cards2* common definitions for both sides of the bus:3* - conventions both spoolers must know4* - channel numbers agreed upon5*6* Author M. Steinkopf7* Copyright 1999 by M. Steinkopf8*9* This software may be used and distributed according to the terms10* of the GNU General Public License, incorporated herein by reference.11*12*/1314#ifndef __INCE1PC_H__15#define __INCE1PC_H__1617/* basic scalar definitions have same meanning,18* but their declaration location depends on environment19*/2021/*--------------------------------------channel numbers---------------------*/22#define CHAN_SYSTEM 0x0001 /* system channel (spooler to spooler) */23#define CHAN_ERRLOG 0x0005 /* error logger */24#define CHAN_CAPI 0x0064 /* CAPI interface */25#define CHAN_NDIS_DATA 0x1001 /* NDIS data transfer */2627/*--------------------------------------POF ready msg-----------------------*/28/* NOTE: after booting POF sends system ready message to PC: */29#define RDY_MAGIC 0x52535953UL /* 'SYSR' reversed */30#define RDY_MAGIC_SIZE 4 /* size in bytes */3132#define MAX_N_TOK_BYTES 2553334#define MIN_RDY_MSG_SIZE RDY_MAGIC_SIZE35#define MAX_RDY_MSG_SIZE (RDY_MAGIC_SIZE+MAX_N_TOK_BYTES)3637#define SYSR_TOK_END 038#define SYSR_TOK_B_CHAN 1 /* nr. of B-Channels; DataLen=1; def: 2 */39#define SYSR_TOK_FAX_CHAN 2 /* nr. of FAX Channels; DataLen=1; def: 0 */40#define SYSR_TOK_MAC_ADDR 3 /* MAC-Address; DataLen=6; def: auto */41#define SYSR_TOK_ESC 255 /* undefined data size yet */42/* default values, if not corrected by token: */43#define SYSR_TOK_B_CHAN_DEF 2 /* assume 2 B-Channels */44#define SYSR_TOK_FAX_CHAN_DEF 1 /* assume 1 FAX Channel */4546/* syntax of new SYSR token stream:47* channel: CHAN_SYSTEM48* msgsize: MIN_RDY_MSG_SIZE <= x <= MAX_RDY_MSG_SIZE49* RDY_MAGIC_SIZE <= x <= (RDY_MAGIC_SIZE+MAX_N_TOK_BYTES)50* msg : 0 1 2 3 {4 5 6 ..}51* S Y S R MAX_N_TOK_BYTES bytes of TokenStream52*53* TokenStream := empty54* | {NonEndTokenChunk} EndToken RotlCRC55* NonEndTokenChunk:= NonEndTokenId DataLen [Data]56* NonEndTokenId := 0x01 .. 0xFE 1 BYTE57* DataLen := 0x00 .. 0xFF 1 BYTE58* Data := DataLen bytes59* EndToken := 0x0060* RotlCRC := special 1 byte CRC over all NonEndTokenChunk bytes61* s. RotlCRC algorithm62*63* RotlCRC algorithm:64* ucSum= 0 1 unsigned char65* for all NonEndTokenChunk bytes:66* ROTL(ucSum,1) rotate left by 167* ucSum += Char; add current byte with swap around68* RotlCRC= ~ucSum; invert all bits for result69*70* note:71* - for 16-bit FIFO add padding 0 byte to achieve even token data bytes!72*/7374/*--------------------------------------error logger------------------------*/75/* note: pof needs final 0 ! */76#define ERRLOG_CMD_REQ "ERRLOG ON"77#define ERRLOG_CMD_REQ_SIZE 10 /* with final 0 byte ! */78#define ERRLOG_CMD_STOP "ERRLOG OFF"79#define ERRLOG_CMD_STOP_SIZE 11 /* with final 0 byte ! */8081#define ERRLOG_ENTRY_SIZE 64 /* sizeof(tErrLogEntry) */82/* remaining text size = 55 */83#define ERRLOG_TEXT_SIZE (ERRLOG_ENTRY_SIZE-2*4-1)8485typedef struct ErrLogEntry_tag {8687/*00 */ unsigned long ulErrType;8889/*04 */ unsigned long ulErrSubtype;9091/*08 */ unsigned char ucTextSize;9293/*09 */ unsigned char ucText[ERRLOG_TEXT_SIZE];94/* ASCIIZ of len ucTextSize-1 */9596/*40 */97} tErrLogEntry;9899100#if defined(__TURBOC__)101#if sizeof(tErrLogEntry) != ERRLOG_ENTRY_SIZE102#error size of tErrLogEntry != ERRLOG_ENTRY_SIZE103#endif /* */104#endif /* */105106/*--------------------------------------DPRAM boot spooler------------------*/107/* this is the struture used between pc and108* hyperstone to exchange boot data109*/110#define DPRAM_SPOOLER_DATA_SIZE 0x20111typedef struct DpramBootSpooler_tag {112113/*00 */ unsigned char Len;114115/*01 */ volatile unsigned char RdPtr;116117/*02 */ unsigned char WrPtr;118119/*03 */ unsigned char Data[DPRAM_SPOOLER_DATA_SIZE];120121/*23 */122} tDpramBootSpooler;123124125#define DPRAM_SPOOLER_MIN_SIZE 5 /* Len+RdPtr+Wrptr+2*data */126#define DPRAM_SPOOLER_DEF_SIZE 0x23 /* current default size */127128/*--------------------------------------HYCARD/ERGO DPRAM SoftUart----------*/129/* at DPRAM offset 0x1C00: */130#define SIZE_RSV_SOFT_UART 0x1B0 /* 432 bytes reserved for SoftUart */131132133#endif /* __INCE1PC_H__ */134135136