summaryrefslogtreecommitdiff
path: root/sys/arch/mac68k/dev/if_aereg.h
blob: 6f7aaffe087bc1e364aeb55128991c811aaa9d7a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
/*	$OpenBSD: if_aereg.h,v 1.6 2002/06/03 20:01:36 deraadt Exp $	*/
/*	$NetBSD: if_aereg.h,v 1.14 1997/02/24 07:34:20 scottr Exp $	*/

/*
 * National Semiconductor DS8390 NIC register definitions.
 *
 * Copyright (C) 1993, David Greenman.  This software may be used, modified,
 * copied, distributed, and sold, in both source and binary form provided that
 * the above copyright and these terms are retained.  Under no circumstances is
 * the author responsible for the proper functioning of this software, nor does
 * the author assume any responsibility for damages incurred with its use.
 */

/*
 * The following is a structure that we should be pulling from
 * dev/ic/dp8390reg.h, but since we have the card in x86 mode and
 * the std. include file assumes that big-endian processors will
 * have the card in m68k mode, we're hosed for the moment.
 * Fix this.  --  XXX
 */
struct ae_ring {
	u_char  rsr;		/* receiver status */
	u_char  next_packet;	/* pointer to next packet */
	u_short count;		/* bytes in packet (length + 4) */
};
/*
 * Vendor types
 */
#define AE_VENDOR_UNKNOWN	0xff	/* Unknown network card */
#define AE_VENDOR_APPLE		0x00	/* Apple Ethernet card */
#define AE_VENDOR_INTERLAN	0x01	/* Interlan A310 card (GatorCard) */
#define AE_VENDOR_DAYNA		0x02	/* DaynaPORT E/30s (and others?) */
#define AE_VENDOR_ASANTE	0x03	/* Asante MacCon II/E */
#define AE_VENDOR_FARALLON	0x04	/* Farallon EtherMac II-TP */
#define AE_VENDOR_FOCUS		0x05	/* FOCUS Enhancements EtherLAN */
#define AE_VENDOR_KINETICS	0x06	/* Kinetics EtherPort SE/30 */

/*
 * Compile-time config flags
 */
/*
 * This sets the default for enabling/disablng the transceiver.
 */
#define AE_FLAGS_DISABLE_TRANSCEIVER	0x0001

/*
 * This disables the use of double transmit buffers.
 */
#define AE_FLAGS_NO_DOUBLE_BUFFERING	0x0008

/* */
#define	GC_RESET_OFFSET		0x000c0000	/* writes here reset NIC */
#define	GC_ROM_OFFSET		0x000c0000	/* address prom */
#define GC_DATA_OFFSET		0x000d0000	/* Offset to NIC memory */
#define GC_REG_OFFSET		0x000e0000	/* Offset to NIC registers */

#define DP_ROM_OFFSET		0x000f0007	/* Offset to MAC address */
#define DP_DATA_OFFSET		0x00000000	/* Offset to NIC memory */
#define DP_REG_OFFSET		0x00080000	/* Offset to NIC registers */

#define AE_ROM_OFFSET		0x000f0000
#define AE_DATA_OFFSET		0x000d0000	/* Offset to NIC memory */
#define AE_REG_OFFSET		0x000e0000	/* Offset to NIC registers */

#define FE_ROM_OFFSET		0x000d0006	/* Determined empirically */

#define KE_ROM_OFFSET		0x000f0007
#define KE_DATA_OFFSET		0x00000000	/* Offset to NIC memory */
#define KE_REG_OFFSET		0x00080003	/* Offset to NIC registers */

#define AE_REG_SIZE		0x40		/* Size of register space */