2004-04-23 06:58:27 +04:00
|
|
|
/* $NetBSD: if_eireg.h,v 1.3 2004/04/23 02:58:29 simonb Exp $ */
|
2001-03-20 02:58:12 +03:00
|
|
|
|
|
|
|
/*
|
|
|
|
* 2000 Ben Harris
|
|
|
|
*
|
|
|
|
* This file is in the public domain.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* if_eireg.h - register definitions etc for the Acorn Ether1 card
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _IF_EIREG_H_
|
|
|
|
#define _IF_EIREG_H_
|
|
|
|
|
|
|
|
/*
|
|
|
|
* The card has three address spaces. The ROM is mapped into the
|
2001-12-22 01:33:28 +03:00
|
|
|
* bottom 32 bytes of SYNC address space, and contains the
|
2001-03-20 02:58:12 +03:00
|
|
|
* expansion card ID information and the Ethernet address. There is a
|
2001-12-22 01:33:28 +03:00
|
|
|
* pair of write-only registers at the start of the FAST address
|
2001-03-20 02:58:12 +03:00
|
|
|
* space. One of these performs miscellaneous control functions, and
|
|
|
|
* the other acts as a page selector for the board memory. The board
|
|
|
|
* has 64k of RAM, and 4k pages of this can be mapped at offset 0x2000
|
|
|
|
* in the FAST space by writing the page number to the page register.
|
|
|
|
* The 82586 has access to the whole of this memory and (I believe)
|
|
|
|
* sees it as the top 64k of its address space.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* Registers in the board's control space */
|
|
|
|
#define EI_PAGE 0
|
|
|
|
#define EI_CONTROL 1
|
2001-12-22 01:33:28 +03:00
|
|
|
#define EI_CTL_RST 0x01 /* Reset */
|
|
|
|
#define EI_CTL_LB 0x02 /* Loop-back */
|
|
|
|
#define EI_CTL_CA 0x04 /* Channel Attention */
|
|
|
|
#define EI_CTL_CLI 0x08 /* Clear Interrupt */
|
2001-03-20 02:58:12 +03:00
|
|
|
|
|
|
|
/* Offset of base of memory in bus_addr_t units */
|
|
|
|
#define EI_MEMOFF 0x2000
|
|
|
|
|
|
|
|
/*
|
|
|
|
* All addresses within board RAM are in bytes of actual RAM. RAM is
|
2001-12-22 01:33:28 +03:00
|
|
|
* 16 bits wide, and can only be accessed by word transfers
|
2001-03-20 02:58:12 +03:00
|
|
|
* (bus_space_xxx_2).
|
|
|
|
*/
|
|
|
|
#define EI_MEMSIZE 0x10000
|
|
|
|
#define EI_MEMBASE (0x1000000 - EI_MEMSIZE)
|
|
|
|
#define EI_PAGESIZE 0x1000
|
|
|
|
#define EI_NPAGES (EI_MEMSIZE / EI_PAGESIZE)
|
|
|
|
#define ei_atop(a) (((a) % EI_MEMSIZE) / EI_PAGESIZE)
|
|
|
|
#define ei_atopo(a) ((a) % EI_PAGESIZE)
|
|
|
|
|
|
|
|
#define EI_SCP_ADDR IE_SCP_ADDR % EI_MEMSIZE
|
|
|
|
|
2001-12-22 01:33:28 +03:00
|
|
|
/*
|
2004-04-23 06:58:27 +04:00
|
|
|
* The ROM on the Ether1 is a bit oddly wired, in that the interrupt line
|
|
|
|
* is wired up as the high-order address line, so as to allow the interrupt
|
|
|
|
* status bit the first byte to reflect the actual interrupt status.
|
2001-12-22 01:33:28 +03:00
|
|
|
*/
|
|
|
|
|
|
|
|
#define EI_ROMSIZE 0x20
|
|
|
|
/* First eight bytes are standard extended podule ID. */
|
|
|
|
#define EI_ROM_HWREV 0x08
|
|
|
|
#define EI_ROM_EADDR 0x09
|
|
|
|
#define EI_ROM_CRC 0x1c
|
2001-03-20 02:58:12 +03:00
|
|
|
|
|
|
|
#endif
|