⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 hapn.h

📁 TCP_IPprotocol.rar
💻 H
字号:
#ifndef	_HAPN_H
#define	_HAPN_H

#ifndef	_GLOBAL_H
#include "global.h"
#endif

#ifndef	_MBUF_H
#include "mbuf.h"
#endif

#ifndef	_IFACE_H
#include "iface.h"
#endif

#ifndef	_TIMER_H
#include "timer.h"
#endif

/*  HAPN-1 PC plug-in card driver.
 *  This card contains an Intel 8273 SDLC/HDLC Protocol Controller
 *  The card is hardwired to addresses 310-31f and IRQ 2
 */

#define NHAPN 1
#define INTMASK 0x21		/*  PC interrupt controller (8259) */

struct hapn {
	struct iface *iface;

	long rxints;            /* RX interupt count                  */
	long txints;            /* TX interrupt count                 */
				/* Error counters                     */
	int badint;             /* Bad interrupt type                 */
	int crcerr;             /* CRC errors                         */
	int aborts;             /* RX frame aborts                    */
	int dmaorun;            /* DMA overun                         */
	int toobig;             /* RX frame too large                 */
	int rframes;            /* # of RX frames                     */
	int cdloss;             /* Loss of DCD during receive         */
	int rxorun;             /* Receive interrupt overun           */
	int nomem;              /* insufficient memory                */
	int t_urun;             /* TX underruns                       */
	int ctsloss;            /* Loss of CTS (dead-man timeout)     */
	int taborts;            /* TX aborts                          */
	int tframes;            /* # of TX frames                     */

	struct mbuf *rcvbuf;    /* Current receive buffer             */
	uint16 bufsiz;           /* Maximum RX frame size              */
	uint8 *rcp;		/* RX data pointer                    */

	struct mbuf *sndq;      /* Transmit frames queue              */
	uint16 sndcnt;           /* Count of frames on sndq            */
	struct mbuf *sndbuf;    /* Current TX frame buffer            */
	int tstate;             /* Transmitter state                  */
#define IDLE 0
#define DEFER 1
#define ACTIVE 2
	struct timer defer;
	int mode;               /* Channel-access mode                */
#define CSMA 0
#define FULLDUP 1
	uint16 base;             /* Base I/O address of board          */
	unsigned vec;           /* Interrupt level                    */
	INTERRUPT (*oldvec)(void);	/* Previous interrupt service vector */
	uint8 chain;		/* Interrupt chaining enable */
};

extern struct hapn Hapn[];

/*  Interrupt vector handler  */

/* In hapn.c: */
INTERRUPT (far *(haint)(int dev))();

/* In hapnvec.asm: */
INTERRUPT ha0vec(void);

/*  8273 register addresses  */

#define CMD 0
#define STA 0
#define PAR 1
#define RES 1
#define RST 1
#define TXI 2
#define RXI 3
#define TXD 4
#define RXD 8

/*  8273 commands  */

#define	SET_ONE		0xa4
#define	RST_ONE		0x64
#define	SET_XFER	0x97
#define	RST_XFER	0x57
#define	SET_MODE	0x91
#define	RST_MODE	0x51
#define	HDLC		0x20
#define	EOP		0x10
#define	EARLY		0x8
#define	BUFFERD		4
#define	PREFRM		2
#define	FLG_STM		1
#define	SET_SERIAL	0xa0
#define	RST_SERIAL	0x60
#define	LOOP		4
#define	TXC_RXC		2
#define	NRZI		1
#define GENERAL_RX	0xc0
#define SELECT_RX	0xc1
#define SELECT_LRX	0xc2
#define RX_DISABLE	0xc5
#define TX_FRAME	0xc8
#define LOOP_TX		0xca
#define TX_TRANS	0xc9
#define ABORT_TXF	0xcc
#define ABORT_LTX	0xce
#define ABORT_TXT	0xcd
#define READ_A		0x22
#define	CD		2
#define	CTS		1
#define READ_B		0x23
#define SET_B		0xa3
#define RST_B		0x63
#define FLAG_D		0x20
#define IRQ_ENB		8
#define RTS		1

/*  Status register bits  */

#define CBSY	0x80
#define CBF	0x40
#define CPBF	0x20
#define CRBF	0x10
#define RXINT	8
#define TXINT	4
#define RXIRA	2
#define TXIRA	1

/*  Transmit result codes  */

#define EARLY_TXI	0xc
#define TX_CMPLT	0xd
#define DMA_URUN	0xe
#define CTS_LOSS	0xf
#define ABORT_CMPLT	0x10

/*  Receive result codes  */

#define A1_MATCH	0
#define A2_MATCH	1
#define CRCERR		3
#define ABORT_DET	4
#define IDLE_DET	5
#define EOP_DET		6
#define SHORT_FRM	7
#define DMA_OVRN	8
#define MEM_OVFL	9
#define CD_LOSS		0xa
#define RX_ORUN		0xb

#endif	/* _HAPN_H */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -