162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-only */ 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * linux/drivers/acorn/net/ether1.h 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Copyright (C) 1996 Russell King 662306a36Sopenharmony_ci * 762306a36Sopenharmony_ci * Network driver for Acorn Ether1 cards. 862306a36Sopenharmony_ci */ 962306a36Sopenharmony_ci 1062306a36Sopenharmony_ci#ifndef _LINUX_ether1_H 1162306a36Sopenharmony_ci#define _LINUX_ether1_H 1262306a36Sopenharmony_ci 1362306a36Sopenharmony_ci#ifdef __ETHER1_C 1462306a36Sopenharmony_ci/* use 0 for production, 1 for verification, >2 for debug */ 1562306a36Sopenharmony_ci#ifndef NET_DEBUG 1662306a36Sopenharmony_ci#define NET_DEBUG 0 1762306a36Sopenharmony_ci#endif 1862306a36Sopenharmony_ci 1962306a36Sopenharmony_ci#define priv(dev) ((struct ether1_priv *)netdev_priv(dev)) 2062306a36Sopenharmony_ci 2162306a36Sopenharmony_ci/* Page register */ 2262306a36Sopenharmony_ci#define REG_PAGE (priv(dev)->base + 0x0000) 2362306a36Sopenharmony_ci 2462306a36Sopenharmony_ci/* Control register */ 2562306a36Sopenharmony_ci#define REG_CONTROL (priv(dev)->base + 0x0004) 2662306a36Sopenharmony_ci#define CTRL_RST 0x01 2762306a36Sopenharmony_ci#define CTRL_LOOPBACK 0x02 2862306a36Sopenharmony_ci#define CTRL_CA 0x04 2962306a36Sopenharmony_ci#define CTRL_ACK 0x08 3062306a36Sopenharmony_ci 3162306a36Sopenharmony_ci#define ETHER1_RAM (priv(dev)->base + 0x2000) 3262306a36Sopenharmony_ci 3362306a36Sopenharmony_ci/* HW address */ 3462306a36Sopenharmony_ci#define IDPROM_ADDRESS (priv(dev)->base + 0x0024) 3562306a36Sopenharmony_ci 3662306a36Sopenharmony_cistruct ether1_priv { 3762306a36Sopenharmony_ci void __iomem *base; 3862306a36Sopenharmony_ci unsigned int tx_link; 3962306a36Sopenharmony_ci unsigned int tx_head; 4062306a36Sopenharmony_ci volatile unsigned int tx_tail; 4162306a36Sopenharmony_ci volatile unsigned int rx_head; 4262306a36Sopenharmony_ci volatile unsigned int rx_tail; 4362306a36Sopenharmony_ci unsigned char bus_type; 4462306a36Sopenharmony_ci unsigned char resetting; 4562306a36Sopenharmony_ci unsigned char initialising : 1; 4662306a36Sopenharmony_ci unsigned char restart : 1; 4762306a36Sopenharmony_ci}; 4862306a36Sopenharmony_ci 4962306a36Sopenharmony_ci#define I82586_NULL (-1) 5062306a36Sopenharmony_ci 5162306a36Sopenharmony_citypedef struct { /* tdr */ 5262306a36Sopenharmony_ci unsigned short tdr_status; 5362306a36Sopenharmony_ci unsigned short tdr_command; 5462306a36Sopenharmony_ci unsigned short tdr_link; 5562306a36Sopenharmony_ci unsigned short tdr_result; 5662306a36Sopenharmony_ci#define TDR_TIME (0x7ff) 5762306a36Sopenharmony_ci#define TDR_SHORT (1 << 12) 5862306a36Sopenharmony_ci#define TDR_OPEN (1 << 13) 5962306a36Sopenharmony_ci#define TDR_XCVRPROB (1 << 14) 6062306a36Sopenharmony_ci#define TDR_LNKOK (1 << 15) 6162306a36Sopenharmony_ci} tdr_t; 6262306a36Sopenharmony_ci 6362306a36Sopenharmony_citypedef struct { /* transmit */ 6462306a36Sopenharmony_ci unsigned short tx_status; 6562306a36Sopenharmony_ci unsigned short tx_command; 6662306a36Sopenharmony_ci unsigned short tx_link; 6762306a36Sopenharmony_ci unsigned short tx_tbdoffset; 6862306a36Sopenharmony_ci} tx_t; 6962306a36Sopenharmony_ci 7062306a36Sopenharmony_citypedef struct { /* tbd */ 7162306a36Sopenharmony_ci unsigned short tbd_opts; 7262306a36Sopenharmony_ci#define TBD_CNT (0x3fff) 7362306a36Sopenharmony_ci#define TBD_EOL (1 << 15) 7462306a36Sopenharmony_ci unsigned short tbd_link; 7562306a36Sopenharmony_ci unsigned short tbd_bufl; 7662306a36Sopenharmony_ci unsigned short tbd_bufh; 7762306a36Sopenharmony_ci} tbd_t; 7862306a36Sopenharmony_ci 7962306a36Sopenharmony_citypedef struct { /* rfd */ 8062306a36Sopenharmony_ci unsigned short rfd_status; 8162306a36Sopenharmony_ci#define RFD_NOEOF (1 << 6) 8262306a36Sopenharmony_ci#define RFD_FRAMESHORT (1 << 7) 8362306a36Sopenharmony_ci#define RFD_DMAOVRN (1 << 8) 8462306a36Sopenharmony_ci#define RFD_NORESOURCES (1 << 9) 8562306a36Sopenharmony_ci#define RFD_ALIGNERROR (1 << 10) 8662306a36Sopenharmony_ci#define RFD_CRCERROR (1 << 11) 8762306a36Sopenharmony_ci#define RFD_OK (1 << 13) 8862306a36Sopenharmony_ci#define RFD_FDCONSUMED (1 << 14) 8962306a36Sopenharmony_ci#define RFD_COMPLETE (1 << 15) 9062306a36Sopenharmony_ci unsigned short rfd_command; 9162306a36Sopenharmony_ci#define RFD_CMDSUSPEND (1 << 14) 9262306a36Sopenharmony_ci#define RFD_CMDEL (1 << 15) 9362306a36Sopenharmony_ci unsigned short rfd_link; 9462306a36Sopenharmony_ci unsigned short rfd_rbdoffset; 9562306a36Sopenharmony_ci unsigned char rfd_dest[6]; 9662306a36Sopenharmony_ci unsigned char rfd_src[6]; 9762306a36Sopenharmony_ci unsigned short rfd_len; 9862306a36Sopenharmony_ci} rfd_t; 9962306a36Sopenharmony_ci 10062306a36Sopenharmony_citypedef struct { /* rbd */ 10162306a36Sopenharmony_ci unsigned short rbd_status; 10262306a36Sopenharmony_ci#define RBD_ACNT (0x3fff) 10362306a36Sopenharmony_ci#define RBD_ACNTVALID (1 << 14) 10462306a36Sopenharmony_ci#define RBD_EOF (1 << 15) 10562306a36Sopenharmony_ci unsigned short rbd_link; 10662306a36Sopenharmony_ci unsigned short rbd_bufl; 10762306a36Sopenharmony_ci unsigned short rbd_bufh; 10862306a36Sopenharmony_ci unsigned short rbd_len; 10962306a36Sopenharmony_ci} rbd_t; 11062306a36Sopenharmony_ci 11162306a36Sopenharmony_citypedef struct { /* nop */ 11262306a36Sopenharmony_ci unsigned short nop_status; 11362306a36Sopenharmony_ci unsigned short nop_command; 11462306a36Sopenharmony_ci unsigned short nop_link; 11562306a36Sopenharmony_ci} nop_t; 11662306a36Sopenharmony_ci 11762306a36Sopenharmony_citypedef struct { /* set multicast */ 11862306a36Sopenharmony_ci unsigned short mc_status; 11962306a36Sopenharmony_ci unsigned short mc_command; 12062306a36Sopenharmony_ci unsigned short mc_link; 12162306a36Sopenharmony_ci unsigned short mc_cnt; 12262306a36Sopenharmony_ci unsigned char mc_addrs[1][6]; 12362306a36Sopenharmony_ci} mc_t; 12462306a36Sopenharmony_ci 12562306a36Sopenharmony_citypedef struct { /* set address */ 12662306a36Sopenharmony_ci unsigned short sa_status; 12762306a36Sopenharmony_ci unsigned short sa_command; 12862306a36Sopenharmony_ci unsigned short sa_link; 12962306a36Sopenharmony_ci unsigned char sa_addr[6]; 13062306a36Sopenharmony_ci} sa_t; 13162306a36Sopenharmony_ci 13262306a36Sopenharmony_citypedef struct { /* config command */ 13362306a36Sopenharmony_ci unsigned short cfg_status; 13462306a36Sopenharmony_ci unsigned short cfg_command; 13562306a36Sopenharmony_ci unsigned short cfg_link; 13662306a36Sopenharmony_ci unsigned char cfg_bytecnt; /* size foll data: 4 - 12 */ 13762306a36Sopenharmony_ci unsigned char cfg_fifolim; /* FIFO threshold */ 13862306a36Sopenharmony_ci unsigned char cfg_byte8; 13962306a36Sopenharmony_ci#define CFG8_SRDY (1 << 6) 14062306a36Sopenharmony_ci#define CFG8_SAVEBADF (1 << 7) 14162306a36Sopenharmony_ci unsigned char cfg_byte9; 14262306a36Sopenharmony_ci#define CFG9_ADDRLEN(x) (x) 14362306a36Sopenharmony_ci#define CFG9_ADDRLENBUF (1 << 3) 14462306a36Sopenharmony_ci#define CFG9_PREAMB2 (0 << 4) 14562306a36Sopenharmony_ci#define CFG9_PREAMB4 (1 << 4) 14662306a36Sopenharmony_ci#define CFG9_PREAMB8 (2 << 4) 14762306a36Sopenharmony_ci#define CFG9_PREAMB16 (3 << 4) 14862306a36Sopenharmony_ci#define CFG9_ILOOPBACK (1 << 6) 14962306a36Sopenharmony_ci#define CFG9_ELOOPBACK (1 << 7) 15062306a36Sopenharmony_ci unsigned char cfg_byte10; 15162306a36Sopenharmony_ci#define CFG10_LINPRI(x) (x) 15262306a36Sopenharmony_ci#define CFG10_ACR(x) (x << 4) 15362306a36Sopenharmony_ci#define CFG10_BOFMET (1 << 7) 15462306a36Sopenharmony_ci unsigned char cfg_ifs; 15562306a36Sopenharmony_ci unsigned char cfg_slotl; 15662306a36Sopenharmony_ci unsigned char cfg_byte13; 15762306a36Sopenharmony_ci#define CFG13_SLOTH(x) (x) 15862306a36Sopenharmony_ci#define CFG13_RETRY(x) (x << 4) 15962306a36Sopenharmony_ci unsigned char cfg_byte14; 16062306a36Sopenharmony_ci#define CFG14_PROMISC (1 << 0) 16162306a36Sopenharmony_ci#define CFG14_DISBRD (1 << 1) 16262306a36Sopenharmony_ci#define CFG14_MANCH (1 << 2) 16362306a36Sopenharmony_ci#define CFG14_TNCRS (1 << 3) 16462306a36Sopenharmony_ci#define CFG14_NOCRC (1 << 4) 16562306a36Sopenharmony_ci#define CFG14_CRC16 (1 << 5) 16662306a36Sopenharmony_ci#define CFG14_BTSTF (1 << 6) 16762306a36Sopenharmony_ci#define CFG14_FLGPAD (1 << 7) 16862306a36Sopenharmony_ci unsigned char cfg_byte15; 16962306a36Sopenharmony_ci#define CFG15_CSTF(x) (x) 17062306a36Sopenharmony_ci#define CFG15_ICSS (1 << 3) 17162306a36Sopenharmony_ci#define CFG15_CDTF(x) (x << 4) 17262306a36Sopenharmony_ci#define CFG15_ICDS (1 << 7) 17362306a36Sopenharmony_ci unsigned short cfg_minfrmlen; 17462306a36Sopenharmony_ci} cfg_t; 17562306a36Sopenharmony_ci 17662306a36Sopenharmony_citypedef struct { /* scb */ 17762306a36Sopenharmony_ci unsigned short scb_status; /* status of 82586 */ 17862306a36Sopenharmony_ci#define SCB_STRXMASK (7 << 4) /* Receive unit status */ 17962306a36Sopenharmony_ci#define SCB_STRXIDLE (0 << 4) /* Idle */ 18062306a36Sopenharmony_ci#define SCB_STRXSUSP (1 << 4) /* Suspended */ 18162306a36Sopenharmony_ci#define SCB_STRXNRES (2 << 4) /* No resources */ 18262306a36Sopenharmony_ci#define SCB_STRXRDY (4 << 4) /* Ready */ 18362306a36Sopenharmony_ci#define SCB_STCUMASK (7 << 8) /* Command unit status */ 18462306a36Sopenharmony_ci#define SCB_STCUIDLE (0 << 8) /* Idle */ 18562306a36Sopenharmony_ci#define SCB_STCUSUSP (1 << 8) /* Suspended */ 18662306a36Sopenharmony_ci#define SCB_STCUACTV (2 << 8) /* Active */ 18762306a36Sopenharmony_ci#define SCB_STRNR (1 << 12) /* Receive unit not ready */ 18862306a36Sopenharmony_ci#define SCB_STCNA (1 << 13) /* Command unit not ready */ 18962306a36Sopenharmony_ci#define SCB_STFR (1 << 14) /* Frame received */ 19062306a36Sopenharmony_ci#define SCB_STCX (1 << 15) /* Command completed */ 19162306a36Sopenharmony_ci unsigned short scb_command; /* Next command */ 19262306a36Sopenharmony_ci#define SCB_CMDRXSTART (1 << 4) /* Start (at rfa_offset) */ 19362306a36Sopenharmony_ci#define SCB_CMDRXRESUME (2 << 4) /* Resume reception */ 19462306a36Sopenharmony_ci#define SCB_CMDRXSUSPEND (3 << 4) /* Suspend reception */ 19562306a36Sopenharmony_ci#define SCB_CMDRXABORT (4 << 4) /* Abort reception */ 19662306a36Sopenharmony_ci#define SCB_CMDCUCSTART (1 << 8) /* Start (at cbl_offset) */ 19762306a36Sopenharmony_ci#define SCB_CMDCUCRESUME (2 << 8) /* Resume execution */ 19862306a36Sopenharmony_ci#define SCB_CMDCUCSUSPEND (3 << 8) /* Suspend execution */ 19962306a36Sopenharmony_ci#define SCB_CMDCUCABORT (4 << 8) /* Abort execution */ 20062306a36Sopenharmony_ci#define SCB_CMDACKRNR (1 << 12) /* Ack RU not ready */ 20162306a36Sopenharmony_ci#define SCB_CMDACKCNA (1 << 13) /* Ack CU not ready */ 20262306a36Sopenharmony_ci#define SCB_CMDACKFR (1 << 14) /* Ack Frame received */ 20362306a36Sopenharmony_ci#define SCB_CMDACKCX (1 << 15) /* Ack Command complete */ 20462306a36Sopenharmony_ci unsigned short scb_cbl_offset; /* Offset of first command unit */ 20562306a36Sopenharmony_ci unsigned short scb_rfa_offset; /* Offset of first receive frame area */ 20662306a36Sopenharmony_ci unsigned short scb_crc_errors; /* Properly aligned frame with CRC error*/ 20762306a36Sopenharmony_ci unsigned short scb_aln_errors; /* Misaligned frames */ 20862306a36Sopenharmony_ci unsigned short scb_rsc_errors; /* Frames lost due to no space */ 20962306a36Sopenharmony_ci unsigned short scb_ovn_errors; /* Frames lost due to slow bus */ 21062306a36Sopenharmony_ci} scb_t; 21162306a36Sopenharmony_ci 21262306a36Sopenharmony_citypedef struct { /* iscp */ 21362306a36Sopenharmony_ci unsigned short iscp_busy; /* set by CPU before CA */ 21462306a36Sopenharmony_ci unsigned short iscp_offset; /* offset of SCB */ 21562306a36Sopenharmony_ci unsigned short iscp_basel; /* base of SCB */ 21662306a36Sopenharmony_ci unsigned short iscp_baseh; 21762306a36Sopenharmony_ci} iscp_t; 21862306a36Sopenharmony_ci 21962306a36Sopenharmony_ci /* this address must be 0xfff6 */ 22062306a36Sopenharmony_citypedef struct { /* scp */ 22162306a36Sopenharmony_ci unsigned short scp_sysbus; /* bus size */ 22262306a36Sopenharmony_ci#define SCP_SY_16BBUS 0x00 22362306a36Sopenharmony_ci#define SCP_SY_8BBUS 0x01 22462306a36Sopenharmony_ci unsigned short scp_junk[2]; /* junk */ 22562306a36Sopenharmony_ci unsigned short scp_iscpl; /* lower 16 bits of iscp */ 22662306a36Sopenharmony_ci unsigned short scp_iscph; /* upper 16 bits of iscp */ 22762306a36Sopenharmony_ci} scp_t; 22862306a36Sopenharmony_ci 22962306a36Sopenharmony_ci/* commands */ 23062306a36Sopenharmony_ci#define CMD_NOP 0 23162306a36Sopenharmony_ci#define CMD_SETADDRESS 1 23262306a36Sopenharmony_ci#define CMD_CONFIG 2 23362306a36Sopenharmony_ci#define CMD_SETMULTICAST 3 23462306a36Sopenharmony_ci#define CMD_TX 4 23562306a36Sopenharmony_ci#define CMD_TDR 5 23662306a36Sopenharmony_ci#define CMD_DUMP 6 23762306a36Sopenharmony_ci#define CMD_DIAGNOSE 7 23862306a36Sopenharmony_ci 23962306a36Sopenharmony_ci#define CMD_MASK 7 24062306a36Sopenharmony_ci 24162306a36Sopenharmony_ci#define CMD_INTR (1 << 13) 24262306a36Sopenharmony_ci#define CMD_SUSP (1 << 14) 24362306a36Sopenharmony_ci#define CMD_EOL (1 << 15) 24462306a36Sopenharmony_ci 24562306a36Sopenharmony_ci#define STAT_COLLISIONS (15) 24662306a36Sopenharmony_ci#define STAT_COLLEXCESSIVE (1 << 5) 24762306a36Sopenharmony_ci#define STAT_COLLAFTERTX (1 << 6) 24862306a36Sopenharmony_ci#define STAT_TXDEFERRED (1 << 7) 24962306a36Sopenharmony_ci#define STAT_TXSLOWDMA (1 << 8) 25062306a36Sopenharmony_ci#define STAT_TXLOSTCTS (1 << 9) 25162306a36Sopenharmony_ci#define STAT_NOCARRIER (1 << 10) 25262306a36Sopenharmony_ci#define STAT_FAIL (1 << 11) 25362306a36Sopenharmony_ci#define STAT_ABORTED (1 << 12) 25462306a36Sopenharmony_ci#define STAT_OK (1 << 13) 25562306a36Sopenharmony_ci#define STAT_BUSY (1 << 14) 25662306a36Sopenharmony_ci#define STAT_COMPLETE (1 << 15) 25762306a36Sopenharmony_ci#endif 25862306a36Sopenharmony_ci#endif 25962306a36Sopenharmony_ci 26062306a36Sopenharmony_ci/* 26162306a36Sopenharmony_ci * Ether1 card definitions: 26262306a36Sopenharmony_ci * 26362306a36Sopenharmony_ci * FAST accesses: 26462306a36Sopenharmony_ci * +0 Page register 26562306a36Sopenharmony_ci * 16 pages 26662306a36Sopenharmony_ci * +4 Control 26762306a36Sopenharmony_ci * '1' = reset 26862306a36Sopenharmony_ci * '2' = loopback 26962306a36Sopenharmony_ci * '4' = CA 27062306a36Sopenharmony_ci * '8' = int ack 27162306a36Sopenharmony_ci * 27262306a36Sopenharmony_ci * RAM at address + 0x2000 27362306a36Sopenharmony_ci * Pod. Prod id = 3 27462306a36Sopenharmony_ci * Words after ID block [base + 8 words] 27562306a36Sopenharmony_ci * +0 pcb issue (0x0c and 0xf3 invalid) 27662306a36Sopenharmony_ci * +1 - +6 eth hw address 27762306a36Sopenharmony_ci */ 278