Ok. I didn't make 2.4.0 in 2000. Tough. I tried, but we had some
[davej-history.git] / drivers / net / sgiseeq.h
blob0b5d39c688a71739442e58615255e24a298fb6a4
1 /* $Id: sgiseeq.h,v 1.4 1999/10/09 00:01:24 ralf Exp $
2 * sgiseeq.h: Defines for the Seeq8003 ethernet controller.
4 * Copyright (C) 1996 David S. Miller (dm@engr.sgi.com)
5 */
6 #ifndef _SGISEEQ_H
7 #define _SGISEEQ_H
9 struct sgiseeq_wregs {
10 volatileunsigned int multicase_high[2];
11 volatileunsigned int frame_gap;
12 volatileunsigned int control;
15 struct sgiseeq_rregs {
16 volatileunsigned int collision_tx[2];
17 volatileunsigned int collision_all[2];
18 volatileunsigned int _unused0;
19 volatileunsigned int rflags;
22 struct sgiseeq_regs {
23 union{
24 volatileunsigned int eth_addr[6];
25 volatileunsigned int multicast_low[6];
26 struct sgiseeq_wregs wregs;
27 struct sgiseeq_rregs rregs;
28 } rw;
29 volatileunsigned int rstat;
30 volatileunsigned int tstat;
33 /* Seeq8003 receive status register */
34 #define SEEQ_RSTAT_OVERF 0x001/* Overflow */
35 #define SEEQ_RSTAT_CERROR 0x002/* CRC error */
36 #define SEEQ_RSTAT_DERROR 0x004/* Dribble error */
37 #define SEEQ_RSTAT_SFRAME 0x008/* Short frame */
38 #define SEEQ_RSTAT_REOF 0x010/* Received end of frame */
39 #define SEEQ_RSTAT_FIG 0x020/* Frame is good */
40 #define SEEQ_RSTAT_TIMEO 0x040/* Timeout, or late receive */
41 #define SEEQ_RSTAT_WHICH 0x080/* Which status, 1=old 0=new */
42 #define SEEQ_RSTAT_LITTLE 0x100/* DMA is done in little endian format */
43 #define SEEQ_RSTAT_SDMA 0x200/* DMA has started */
44 #define SEEQ_RSTAT_ADMA 0x400/* DMA is active */
45 #define SEEQ_RSTAT_ROVERF 0x800/* Receive buffer overflow */
47 /* Seeq8003 receive command register */
48 #define SEEQ_RCMD_RDISAB 0x000/* Disable receiver on the Seeq8003 */
49 #define SEEQ_RCMD_IOVERF 0x001/* IRQ on buffer overflows */
50 #define SEEQ_RCMD_ICRC 0x002/* IRQ on CRC errors */
51 #define SEEQ_RCMD_IDRIB 0x004/* IRQ on dribble errors */
52 #define SEEQ_RCMD_ISHORT 0x008/* IRQ on short frames */
53 #define SEEQ_RCMD_IEOF 0x010/* IRQ on end of frame */
54 #define SEEQ_RCMD_IGOOD 0x020/* IRQ on good frames */
55 #define SEEQ_RCMD_RANY 0x040/* Receive any frame */
56 #define SEEQ_RCMD_RBCAST 0x080/* Receive broadcasts */
57 #define SEEQ_RCMD_RBMCAST 0x0c0/* Receive broadcasts/multicasts */
59 /* Seeq8003 transmit status register */
60 #define SEEQ_TSTAT_UFLOW 0x001/* Transmit buffer underflow */
61 #define SEEQ_TSTAT_CLS 0x002/* Collision detected */
62 #define SEEQ_TSTAT_R16 0x004/* Did 16 retries to tx a frame */
63 #define SEEQ_TSTAT_PTRANS 0x008/* Packet was transmitted ok */
64 #define SEEQ_TSTAT_LCLS 0x010/* Late collision occurred */
65 #define SEEQ_TSTAT_WHICH 0x080/* Which status, 1=old 0=new */
66 #define SEEQ_TSTAT_TLE 0x100/* DMA is done in little endian format */
67 #define SEEQ_TSTAT_SDMA 0x200/* DMA has started */
68 #define SEEQ_TSTAT_ADMA 0x400/* DMA is active */
70 /* Seeq8003 transmit command register */
71 #define SEEQ_TCMD_RB0 0x00/* Register bank zero w/station addr */
72 #define SEEQ_TCMD_IUF 0x01/* IRQ on tx underflow */
73 #define SEEQ_TCMD_IC 0x02/* IRQ on collisions */
74 #define SEEQ_TCMD_I16 0x04/* IRQ after 16 failed attempts to tx frame */
75 #define SEEQ_TCMD_IPT 0x08/* IRQ when packet successfully transmitted */
76 #define SEEQ_TCMD_RB1 0x20/* Register bank one w/multi-cast low byte */
77 #define SEEQ_TCMD_RB2 0x40/* Register bank two w/multi-cast high byte */
79 /* Seeq8003 control register */
80 #define SEEQ_CTRL_XCNT 0x01
81 #define SEEQ_CTRL_ACCNT 0x02
82 #define SEEQ_CTRL_SFLAG 0x04
83 #define SEEQ_CTRL_EMULTI 0x08
84 #define SEEQ_CTRL_ESHORT 0x10
85 #define SEEQ_CTRL_ENCARR 0x20
87 /* Seeq8003 control registers on the SGI Hollywood HPC. */
88 #define SEEQ_HPIO_P1BITS 0x00000001/* cycles to stay in P1 phase for PIO */
89 #define SEEQ_HPIO_P2BITS 0x00000060/* cycles to stay in P2 phase for PIO */
90 #define SEEQ_HPIO_P3BITS 0x00000100/* cycles to stay in P3 phase for PIO */
91 #define SEEQ_HDMA_D1BITS 0x00000006/* cycles to stay in D1 phase for DMA */
92 #define SEEQ_HDMA_D2BITS 0x00000020/* cycles to stay in D2 phase for DMA */
93 #define SEEQ_HDMA_D3BITS 0x00000000/* cycles to stay in D3 phase for DMA */
94 #define SEEQ_HDMA_TIMEO 0x00030000/* cycles for DMA timeout */
95 #define SEEQ_HCTL_NORM 0x00000000/* Normal operation mode */
96 #define SEEQ_HCTL_RESET 0x00000001/* Reset Seeq8003 and HPC interface */
97 #define SEEQ_HCTL_IPEND 0x00000002/* IRQ is pending for the chip */
98 #define SEEQ_HCTL_IPG 0x00001000/* Inter-packet gap */
99 #define SEEQ_HCTL_RFIX 0x00002000/* At rxdc, clear end-of-packet */
100 #define SEEQ_HCTL_EFIX 0x00004000/* fixes intr status bit settings */
101 #define SEEQ_HCTL_IFIX 0x00008000/* enable startup timeouts */
103 #endif/* !(_SGISEEQ_H) */
close