home *** CD-ROM | disk | FTP | other *** search
/ Media Share 9 / MEDIASHARE_09.ISO / hamradio / s920603.zip / PC100.H < prev    next >
C/C++ Source or Header  |  1992-04-03  |  3KB  |  109 lines

  1. #ifndef    _PC100_H
  2. #define    _PC100_H
  3.  
  4. /* UNFINISHED! */
  5. /* Hardware-dependent routines for the PACCOMM PC-100 card for the PC
  6.  * This card contains a Zilog 8530 plus two modems, one of which is an
  7.  * AMD 7910, and one of which is a TCM3105.
  8.  *
  9.  * Originally written by Phil Karn KA9Q for an early rev of the board which
  10.  * did interrupt acks wrong.  Hacked by Bdale Garbee N3EUA to work with beta
  11.  * copies of the second major revision of the card.
  12.  */
  13. #ifndef    _GLOBAL_H
  14. #include "global.h"
  15. #endif
  16.  
  17. #ifndef    _MBUF_H
  18. #include "mbuf.h"
  19. #endif
  20.  
  21. #define    NPC    1        /* One card max */
  22. #define    AX_MTU    512
  23. #define    INTMASK    0x21        /* Intel 8259 interrupt controller mask */
  24.  
  25. struct pc100 {
  26.     INTERRUPT (*oldvec) __ARGS((void));/* Original interrupt vector contents */
  27.     int16 addr;    /* Base I/O address */
  28.     unsigned vec;    /* Vector */
  29.     long ints;    /* Interrupt count */
  30.     char chain;    /* Interrupt chaining enable */    
  31. };
  32. extern struct pc100 Pc100[];
  33.  
  34. /* Register offset info, specific to the PC-100
  35.  * E.g., to read the data port on channel A, use
  36.  *      inportb(hdlc[dev].base + CHANA + DATA)
  37.  */
  38. #define    MODEM_CTL    0    /* modem control port, write only */
  39. /* #define    CHANB        4    /* Base of channel B regs */
  40. /* #define    CHANA        6    /* Base of channel A regs */
  41. #define    CHANB        6    /* Base of channel B regs */
  42. #define    CHANA        4    /* Base of channel A regs */
  43. #define INTACK        8    /* access this to wang 8530's INTA.L */
  44.  
  45. /* 8530 ports on each channel */
  46. /* #define    CTL    0 */
  47. /* #define    DATA    1 */
  48. #define    CTL    1
  49. #define    DATA    0
  50.  
  51. struct hdlc {
  52.     long rxints;        /* Receiver interrupts */
  53.     long txints;        /* Transmitter interrupts */
  54.     long exints;        /* External/status interrupts */
  55.     long spints;        /* Special receiver interrupts */
  56.  
  57.     int nomem;        /* Buffer allocate failures */
  58.     int toobig;        /* Giant receiver packets */
  59.     int crcerr;        /* CRC Errors */
  60.     int aborts;        /* Receiver aborts */
  61.  
  62.     char status;        /* Copy of R0 at last external interrupt */
  63.     struct mbuf *rcvq;    /* Receive queue */
  64.     int16 rcvcnt;        /* Number of packets on rcvq */
  65.     struct mbuf *rcvbuf;    /* Buffer for current rx packet */
  66.     int16 bufsiz;        /* Size of rcvbuf */
  67.     char *rcp;        /* Pointer into rcvbuf */
  68.  
  69.     struct mbuf *sndq;    /* Packets awaiting transmission */
  70.     int16 sndcnt;        /* Number of packets on sndq */
  71.     struct mbuf *sndbuf;    /* Current buffer being transmitted */
  72.     int tstate;        /* Tranmsitter state */
  73. #define    IDLE    0        /* Transmitter off, no data pending */
  74. #define    DEFER    1        /* Transmitter off, waiting for channel clear*/
  75. #define    KEYUP    2        /* Transmitter on, waiting for CTS */
  76. #define    ACTIVE    3        /* Transmitter on, sending data */
  77. #define    FLUSH    4        /* Transmitter on, flushing tx buffers */
  78. #define    FIN2    5        /* Ditto, second char */
  79.  
  80.     int mode;        /* Transmitter mode */
  81. #define    CSMA    0        /* Carrier-sense multiple access */
  82. #define    FULLDUP    1        /* Full duplex */
  83.  
  84.     int dev;        /* Device number */
  85.     int16 base;        /* Base of I/O registers */
  86.     int16 speed;        /* Line speed, bps */
  87. };
  88.  
  89. #define    OFF    0
  90. #define    ON    1
  91.  
  92. /* 8530 clock speed */
  93. /* #define    XTAL    ((unsigned)38400)    /* 2.4576 Mhz / (2*32) */
  94. #define    XTAL    ((unsigned)76797)    /* 4.915 Mhz / (2*32) */
  95.  
  96. /* Baud rate generator definitions */
  97. struct baudrate {
  98.     int16 speed;
  99.     char val;
  100. };
  101.  
  102. /* In pc100.c: */
  103. INTERRUPT (far *(pcint) __ARGS((int dev)))();
  104.  
  105. /* In pc100vec.asm: */
  106. INTERRUPT pc0vec __ARGS((void));
  107.  
  108. #endif    /* _PC100_H */
  109.