773ec77d3f
USB ethernet drivers. usbnet.h introduces a new set of APIs to provide common solutions for these driver features: - USB endpoint pipe handling - rx and tx chain handling - generic handlers or support for several struct ifnet callbacks - MII bus locking - interrupt handling - partial autoconf handling: much of attach, and detach/activate can use common versions directly. currently, only axen(4) and cdce(4) are converted. the reductions in these drivers are quite significant: if_cdce.c is reduced from 1000 lines to 320 lines, and if_axen is reduced from 1902 lines to 1021 lines. add a "usbnet" module and make the if_axen module depend upon it.
236 lines
6.8 KiB
C
236 lines
6.8 KiB
C
/* $NetBSD: if_axenreg.h,v 1.15 2019/07/31 09:13:16 mrg Exp $ */
|
|
/* $OpenBSD: if_axenreg.h,v 1.1 2013/10/07 05:37:41 yuo Exp $ */
|
|
|
|
/*
|
|
* Copyright (c) 2013 Yojiro UO <yuo@openbsd.org>. All right reserved.
|
|
*
|
|
*/
|
|
|
|
#include <sys/rndsource.h>
|
|
|
|
/*
|
|
* Definitions for the ASIX Electronics AX88179 to ethernet controller.
|
|
*/
|
|
|
|
#define AXEN_PHY_ID 0x0003
|
|
#define AXEN_MCAST_FILTER_SIZE 8
|
|
/* unit: KB */
|
|
#define AXEN_BUFSZ_LS 8
|
|
#define AXEN_BUFSZ_HS 16
|
|
#define AXEN_BUFSZ_SS 24
|
|
|
|
#define AXEN_REV_UA1 0
|
|
#define AXEN_REV_UA2 1
|
|
|
|
|
|
/* receive header */
|
|
/*
|
|
* +-multicast/broadcast
|
|
* | +-rx_ok
|
|
* | | ++-----L3_type (1:ipv4, 0/2:ipv6)
|
|
* pkt_len(13) | | ||+ ++-L4_type(0: icmp, 1: UDP, 4: TCP)
|
|
* |765|43210 76543210|7654 3210 7654 3210|
|
|
* | +-crc_err |+-L4_err |+-L4_CSUM_ERR
|
|
* +--drop_err +--L3_err +--L3_CSUM_ERR
|
|
*
|
|
* ex) pkt_hdr 0x00680820
|
|
* drop_err, crc_err: none
|
|
* pkt_length = 104 byte
|
|
* 0x0820 = 0000 1000 0010 0000 => ipv4 icmp
|
|
*
|
|
* ex) pkt_hdr 0x004c8800
|
|
* drop_err, crc_err: none
|
|
* pkt_length = 76 byte
|
|
* 0x8800 = 1000 1000 0000 0000 => ipv6 mcast icmp
|
|
*
|
|
* [memo]
|
|
* 0x0820: ipv4 icmp 0000 1000 0010 0000
|
|
* 0x8820: ipv4 icmp (broadcast) 1000 1000 0010 0000
|
|
* 0x0824: ipv4 udp (nping) 0000 1000 0010 0100
|
|
* 0x0830: ipv4 tcp (ssh) 0000 1000 0011 0000
|
|
*
|
|
* 0x0800: ipv6 icmp 0000 1000 0000 0000
|
|
* 0x8800: ipv6 icmp (multicast) 1000 1000 0000 0000
|
|
* 0x8844: ipv6 UDP/MDNS mcast 1000 1000 0100 0100
|
|
* 0x0850: ipv6 tcp (ssh) 0000 1000 0101 0000
|
|
*/
|
|
|
|
#define AXEN_RXHDR_DROP_ERR (1 << 31)
|
|
#define AXEN_RXHDR_CRC_ERR (1 << 29)
|
|
#define AXEN_RXHDR_MCAST (1 << 15)
|
|
#define AXEN_RXHDR_RX_OK (1 << 11)
|
|
#define AXEN_RXHDR_L3_ERR (1 << 9)
|
|
#define AXEN_RXHDR_L4_ERR (1 << 8)
|
|
#define AXEN_RXHDR_L3CSUM_ERR (1 << 1)
|
|
#define AXEN_RXHDR_L4CSUM_ERR (1 << 0)
|
|
|
|
/* L4 packet type (3bit) */
|
|
#define AXEN_RXHDR_L4_TYPE_MASK 0x0000001c
|
|
#define AXEN_RXHDR_L4_TYPE_OFFSET 2
|
|
#define AXEN_RXHDR_L4_TYPE_ICMP 0x0
|
|
#define AXEN_RXHDR_L4_TYPE_UDP 0x1
|
|
#define AXEN_RXHDR_L4_TYPE_TCP 0x4
|
|
|
|
/* L3 packet type (2bit) */
|
|
#define AXEN_RXHDR_L3_TYPE_MASK 0x00000060
|
|
#define AXEN_RXHDR_L3_TYPE_OFFSET 5
|
|
#define AXEN_RXHDR_L3_TYPE_UNDEF 0x0
|
|
#define AXEN_RXHDR_L3_TYPE_IPV4 0x1
|
|
#define AXEN_RXHDR_L3_TYPE_IPV6 0x2
|
|
|
|
/*
|
|
* commands
|
|
*/
|
|
#define AXEN_CMD_LEN(x) (((x) & 0xF000) >> 12)
|
|
#define AXEN_CMD_DIR(x) (((x) & 0x0F00) >> 8)
|
|
#define AXEN_CMD_CMD(x) ((x) & 0x00FF)
|
|
|
|
/* ---MAC--- */
|
|
/* 1byte cmd */
|
|
#define AXEN_CMD_MAC_READ 0x1001
|
|
#define AXEN_CMD_MAC_WRITE 0x1101
|
|
|
|
#define AXEN_USB_UPLINK 0x02
|
|
#define AXEN_USB_FS 0x01
|
|
#define AXEN_USB_HS 0x02
|
|
#define AXEN_USB_SS 0x04
|
|
#define AXEN_GENERAL_STATUS 0x03
|
|
#define AXEN_GENERAL_STATUS_MASK 0x4
|
|
#define AXEN_REV0 0x0
|
|
#define AXEN_REV1 0x4
|
|
#define AXEN_UNK_05 0x05
|
|
#define AXEN_MAC_EEPROM_ADDR 0x07
|
|
#define AXEN_MAC_EEPROM_READ 0x08
|
|
#define AXEN_MAC_EEPROM_CMD 0x0a
|
|
#define AXEN_EEPROM_READ 0x04
|
|
#define AXEN_EEPROM_WRITE 0x08
|
|
#define AXEN_EEPROM_BUSY 0x10
|
|
#define AXEN_MONITOR_MODE 0x24
|
|
#define AXEN_MONITOR_NONE 0x00
|
|
#define AXEN_MONITOR_RWLC 0x02
|
|
#define AXEN_MONITOR_RWMP 0x04
|
|
#define AXEN_MONITOR_RWWF 0x08
|
|
#define AXEN_MONITOR_RW_FLAG 0x10
|
|
#define AXEN_MONITOR_PMEPOL 0x20
|
|
#define AXEN_MONITOR_PMETYPE 0x40
|
|
#define AXEN_UNK_28 0x28
|
|
#define AXEN_PHYCLK 0x33
|
|
#define AXEN_PHYCLK_BCS 0x01
|
|
#define AXEN_PHYCLK_ACS 0x02
|
|
#define AXEN_PHYCLK_ULR 0x08
|
|
#define AXEN_PHYCLK_ACSREQ 0x10
|
|
#define AXEN_RX_COE 0x34
|
|
#define AXEN_RXCOE_OFF 0x00
|
|
#define AXEN_RXCOE_IPv4 0x01
|
|
#define AXEN_RXCOE_TCPv4 0x02
|
|
#define AXEN_RXCOE_UDPv4 0x04
|
|
#define AXEN_RXCOE_ICMP 0x08
|
|
#define AXEN_RXCOE_IGMP 0x10
|
|
#define AXEN_RXCOE_TCPv6 0x20
|
|
#define AXEN_RXCOE_UDPv6 0x40
|
|
#define AXEN_RXCOE_ICMPv6 0x80
|
|
#define AXEN_TX_COE 0x35
|
|
#define AXEN_TXCOE_OFF 0x00
|
|
#define AXEN_TXCOE_IPv4 0x01
|
|
#define AXEN_TXCOE_TCPv4 0x02
|
|
#define AXEN_TXCOE_UDPv4 0x04
|
|
#define AXEN_TXCOE_ICMP 0x08
|
|
#define AXEN_TXCOE_IGMP 0x10
|
|
#define AXEN_TXCOE_TCPv6 0x20
|
|
#define AXEN_TXCOE_UDPv6 0x40
|
|
#define AXEN_TXCOE_ICMPv6 0x80
|
|
#define AXEN_PAUSE_HIGH_WATERMARK 0x54
|
|
#define AXEN_PAUSE_LOW_WATERMARK 0x55
|
|
|
|
|
|
/* 2byte cmd */
|
|
#define AXEN_CMD_MAC_READ2 0x2001
|
|
#define AXEN_CMD_MAC_WRITE2 0x2101
|
|
|
|
#define AXEN_MAC_RXCTL 0x0b
|
|
#define AXEN_RXCTL_STOP 0x0000
|
|
#define AXEN_RXCTL_PROMISC 0x0001
|
|
#define AXEN_RXCTL_ACPT_ALL_MCAST 0x0002
|
|
#define AXEN_RXCTL_HA8B 0x0004
|
|
#define AXEN_RXCTL_AUTOB 0x0008
|
|
#define AXEN_RXCTL_ACPT_MCAST 0x0010
|
|
#define AXEN_RXCTL_ACPT_PHY_MCAST 0x0020
|
|
#define AXEN_RXCTL_START 0x0080
|
|
#define AXEN_RXCTL_DROPCRCERR 0x0100
|
|
#define AXEN_RXCTL_IPE 0x0200
|
|
#define AXEN_RXCTL_TXPADCRC 0x0400
|
|
#define AXEN_MEDIUM_STATUS 0x22
|
|
#define AXEN_MEDIUM_NONE 0x0000
|
|
#define AXEN_MEDIUM_GIGA 0x0001
|
|
#define AXEN_MEDIUM_FDX 0x0002
|
|
#define AXEN_MEDIUM_ALWAYS_ONE 0x0004
|
|
#define AXEN_MEDIUM_EN_125MHZ 0x0008
|
|
#define AXEN_MEDIUM_RXFLOW_CTRL_EN 0x0010
|
|
#define AXEN_MEDIUM_TXFLOW_CTRL_EN 0x0020
|
|
#define AXEN_MEDIUM_RECV_EN 0x0100
|
|
#define AXEN_MEDIUM_PS 0x0200
|
|
#define AXEN_MEDIUM_JUMBO_EN 0x8040
|
|
#define AXEN_PHYPWR_RSTCTL 0x26
|
|
#define AXEN_PHYPWR_RSTCTL_BZ 0x0010
|
|
#define AXEN_PHYPWR_RSTCTL_IPRL 0x0020
|
|
#define AXEN_PHYPWR_RSTCTL_AUTODETACH 0x1000
|
|
|
|
#define AXEN_CMD_EEPROM_READ 0x2004
|
|
#define AXEN_EEPROM_STAT 0x43
|
|
|
|
/* 5byte cmd */
|
|
#define AXEN_CMD_MAC_SET_RXSR 0x5101
|
|
#define AXEN_RX_BULKIN_QCTRL 0x2e
|
|
|
|
/* 6byte cmd */
|
|
#define AXEN_CMD_MAC_READ_ETHER 0x6001
|
|
#define AXEN_CMD_MAC_NODE_ID 0x10
|
|
|
|
/* 8byte cmd */
|
|
#define AXEN_CMD_MAC_READ_FILTER 0x8001
|
|
#define AXEN_CMD_MAC_WRITE_FILTER 0x8101
|
|
#define AXEN_FILTER_MULTI 0x16
|
|
|
|
/* ---PHY--- */
|
|
/* 2byte cmd */
|
|
#define AXEN_CMD_MII_READ_REG 0x2002
|
|
#define AXEN_CMD_MII_WRITE_REG 0x2102
|
|
|
|
|
|
|
|
/* ========= */
|
|
#define AXEN_GPIO0_EN 0x01
|
|
#define AXEN_GPIO0 0x02
|
|
#define AXEN_GPIO1_EN 0x04
|
|
#define AXEN_GPIO1 0x08
|
|
#define AXEN_GPIO2_EN 0x10
|
|
#define AXEN_GPIO2 0x20
|
|
#define AXEN_GPIO_RELOAD_EEPROM 0x80
|
|
|
|
|
|
#define AXEN_TIMEOUT 1000
|
|
|
|
#ifndef AXEN_RX_LIST_CNT
|
|
#define AXEN_RX_LIST_CNT 4 /* 22 for SS mode in Linux driver */
|
|
#endif
|
|
#ifndef AXEN_TX_LIST_CNT
|
|
#define AXEN_TX_LIST_CNT 4 /* 60 */
|
|
#endif
|
|
|
|
|
|
#define AXEN_CONFIG_NO 1
|
|
#define AXEN_IFACE_IDX 0
|
|
|
|
struct axen_qctrl {
|
|
uint8_t ctrl;
|
|
uint8_t timer_low;
|
|
uint8_t timer_high;
|
|
uint8_t bufsize;
|
|
uint8_t ifg;
|
|
} __packed;
|
|
|
|
struct axen_sframe_hdr {
|
|
uint32_t plen; /* packet length */
|
|
uint32_t gso;
|
|
} __packed;
|