if_levar.h revision 1.2 1 1.2 mycroft /* $NetBSD: if_levar.h,v 1.2 1995/07/27 04:39:08 mycroft Exp $ */
2 1.1 mycroft
3 1.1 mycroft /*
4 1.1 mycroft * LANCE Ethernet driver header file
5 1.1 mycroft *
6 1.1 mycroft * Copyright (c) 1994, 1995 Charles M. Hannum. All rights reserved.
7 1.1 mycroft *
8 1.1 mycroft * Copyright (C) 1993, Paul Richards. This software may be used, modified,
9 1.1 mycroft * copied, distributed, and sold, in both source and binary form provided
10 1.1 mycroft * that the above copyright and these terms are retained. Under no
11 1.1 mycroft * circumstances is the author responsible for the proper functioning
12 1.1 mycroft * of this software, nor does the author assume any responsibility
13 1.1 mycroft * for damages incurred with its use.
14 1.1 mycroft */
15 1.1 mycroft
16 1.1 mycroft /* Board types */
17 1.1 mycroft #define BICC 1
18 1.1 mycroft #define BICC_RDP 0xc
19 1.1 mycroft #define BICC_RAP 0xe
20 1.1 mycroft
21 1.1 mycroft #define NE2100 2
22 1.2 mycroft #define PCnet_ISA 4
23 1.2 mycroft #define PCnet_PCI 5
24 1.1 mycroft #define NE2100_RDP 0x10
25 1.1 mycroft #define NE2100_RAP 0x12
26 1.1 mycroft
27 1.1 mycroft #define DEPCA 3
28 1.1 mycroft #define DEPCA_CSR 0x0
29 1.1 mycroft #define DEPCA_CSR_SHE 0x80 /* Shared memory enabled */
30 1.1 mycroft #define DEPCA_CSR_SWAP32 0x40 /* Byte swapped */
31 1.1 mycroft #define DEPCA_CSR_DUM 0x08 /* rev E compatibility */
32 1.1 mycroft #define DEPCA_CSR_IM 0x04 /* Interrupt masked */
33 1.1 mycroft #define DEPCA_CSR_IEN 0x02 /* Interrupt enabled */
34 1.1 mycroft #define DEPCA_CSR_NORMAL \
35 1.1 mycroft (DEPCA_CSR_SHE | DEPCA_CSR_DUM | DEPCA_CSR_IEN)
36 1.1 mycroft #define DEPCA_RDP 0x4
37 1.1 mycroft #define DEPCA_RAP 0x6
38 1.1 mycroft #define DEPCA_ADP 0xc
39 1.1 mycroft
40 1.1 mycroft /*
41 1.1 mycroft * Ethernet software status per interface.
42 1.1 mycroft *
43 1.1 mycroft * Each interface is referenced by a network interface structure,
44 1.1 mycroft * arpcom.ac_if, which the routing code uses to locate the interface.
45 1.1 mycroft * This structure contains the output queue for the interface, its address, ...
46 1.1 mycroft */
47 1.1 mycroft struct le_softc {
48 1.1 mycroft struct device sc_dev; /* base structure */
49 1.1 mycroft struct arpcom sc_arpcom; /* Ethernet common part */
50 1.1 mycroft
51 1.1 mycroft void (*sc_copytodesc)(); /* Copy to descriptor */
52 1.1 mycroft void (*sc_copyfromdesc)(); /* Copy from descriptor */
53 1.1 mycroft
54 1.1 mycroft void (*sc_copytobuf)(); /* Copy to buffer */
55 1.1 mycroft void (*sc_copyfrombuf)(); /* Copy from buffer */
56 1.1 mycroft void (*sc_zerobuf)(); /* and Zero bytes in buffer */
57 1.1 mycroft
58 1.1 mycroft u_int16_t sc_conf3; /* CSR3 value */
59 1.1 mycroft
60 1.1 mycroft void *sc_mem; /* base address of RAM -- CPU's view */
61 1.1 mycroft u_long sc_addr; /* base address of RAM -- LANCE's view */
62 1.1 mycroft u_long sc_memsize; /* size of RAM */
63 1.1 mycroft
64 1.1 mycroft int sc_nrbuf; /* number of receive buffers */
65 1.1 mycroft int sc_ntbuf; /* number of transmit buffers */
66 1.1 mycroft int sc_last_rd;
67 1.1 mycroft int sc_first_td, sc_last_td, sc_no_td;
68 1.1 mycroft
69 1.1 mycroft int sc_initaddr;
70 1.1 mycroft int sc_rmdaddr;
71 1.1 mycroft int sc_tmdaddr;
72 1.1 mycroft int sc_rbufaddr;
73 1.1 mycroft int sc_tbufaddr;
74 1.1 mycroft
75 1.1 mycroft #ifdef LEDEBUG
76 1.1 mycroft int sc_debug;
77 1.1 mycroft #endif
78 1.1 mycroft
79 1.1 mycroft void *sc_ih;
80 1.2 mycroft int sc_card;
81 1.1 mycroft int sc_rap, sc_rdp; /* LANCE registers */
82 1.1 mycroft };
83