if_levar.h revision 1.4 1 1.4 christos /* $NetBSD: if_levar.h,v 1.4 1996/04/29 20:03:23 christos 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.4 christos void (*sc_copytodesc) /* Copy to descriptor */
52 1.4 christos __P((struct le_softc *, void *, int, int));
53 1.4 christos void (*sc_copyfromdesc) /* Copy from descriptor */
54 1.4 christos __P((struct le_softc *, void *, int, int));
55 1.4 christos void (*sc_copytobuf) /* Copy to buffer */
56 1.4 christos __P((struct le_softc *, void *, int, int));
57 1.4 christos void (*sc_copyfrombuf) /* Copy from buffer */
58 1.4 christos __P((struct le_softc *, void *, int, int));
59 1.4 christos void (*sc_zerobuf) /* and Zero bytes in buffer */
60 1.4 christos __P((struct le_softc *, int, int));
61 1.1 mycroft
62 1.1 mycroft u_int16_t sc_conf3; /* CSR3 value */
63 1.1 mycroft
64 1.1 mycroft void *sc_mem; /* base address of RAM -- CPU's view */
65 1.1 mycroft u_long sc_addr; /* base address of RAM -- LANCE's view */
66 1.1 mycroft u_long sc_memsize; /* size of RAM */
67 1.1 mycroft
68 1.1 mycroft int sc_nrbuf; /* number of receive buffers */
69 1.1 mycroft int sc_ntbuf; /* number of transmit buffers */
70 1.1 mycroft int sc_last_rd;
71 1.1 mycroft int sc_first_td, sc_last_td, sc_no_td;
72 1.1 mycroft
73 1.1 mycroft int sc_initaddr;
74 1.1 mycroft int sc_rmdaddr;
75 1.1 mycroft int sc_tmdaddr;
76 1.1 mycroft int sc_rbufaddr;
77 1.1 mycroft int sc_tbufaddr;
78 1.1 mycroft
79 1.1 mycroft #ifdef LEDEBUG
80 1.1 mycroft int sc_debug;
81 1.1 mycroft #endif
82 1.1 mycroft
83 1.1 mycroft void *sc_ih;
84 1.4 christos bus_io_handle_t sc_ioh;
85 1.3 mycroft void *sc_sh;
86 1.2 mycroft int sc_card;
87 1.1 mycroft int sc_rap, sc_rdp; /* LANCE registers */
88 1.1 mycroft };
89