/* * Copyright (c) 2006-2021, RT-Thread Development Team * * SPDX-License-Identifier: Apache-2.0 * * Change Logs: * Date Author Notes * 2020-10-30 bigmagic first version */ #ifndef __DRV_ETH_H__ #define __DRV_ETH_H__ #define MAC_REG (void *)(0xfd580000) #define SYS_REV_CTRL (0x00) #define SYS_PORT_CTRL (0x04) #define PORT_MODE_EXT_GPHY (3) #define GENET_SYS_OFF (0x0000) #define SYS_RBUF_FLUSH_CTRL (GENET_SYS_OFF + 0x08) #define SYS_TBUF_FLUSH_CTRL (GENET_SYS_OFF + 0x0c) #define GENET_EXT_OFF (0x0080) #define EXT_RGMII_OOB_CTRL (GENET_EXT_OFF + 0x0c) #define RGMII_LINK BIT(4) #define OOB_DISABLE BIT(5) #define RGMII_MODE_EN BIT(6) #define ID_MODE_DIS BIT(16) #define GENET_RBUF_OFF (0x0300) #define RBUF_TBUF_SIZE_CTRL (GENET_RBUF_OFF + 0xb4) #define RBUF_CTRL (GENET_RBUF_OFF + 0x00) #define RBUF_ALIGN_2B BIT(1) #define GENET_UMAC_OFF (0x0800) #define UMAC_MIB_CTRL (GENET_UMAC_OFF + 0x580) #define UMAC_MAX_FRAME_LEN (GENET_UMAC_OFF + 0x014) #define UMAC_MAC0 (GENET_UMAC_OFF + 0x00c) #define UMAC_MAC1 (GENET_UMAC_OFF + 0x010) #define UMAC_CMD (GENET_UMAC_OFF + 0x008) #define MDIO_CMD (GENET_UMAC_OFF + 0x614) #define UMAC_TX_FLUSH (GENET_UMAC_OFF + 0x334) #define MDIO_START_BUSY BIT(29) #define MDIO_READ_FAIL BIT(28) #define MDIO_RD (2 << 26) #define MDIO_WR BIT(26) #define MDIO_PMD_SHIFT (21) #define MDIO_PMD_MASK (0x1f) #define MDIO_REG_SHIFT (16) #define MDIO_REG_MASK (0x1f) #define GENET_INTRL2_OFF (0x0200) #define GENET_INTRL2_CPU_STAT (GENET_INTRL2_OFF + 0x00) #define GENET_INTRL2_CPU_CLEAR (GENET_INTRL2_OFF + 0x08) #define GENET_INTRL2_CPU_STAT_MASK (GENET_INTRL2_OFF + 0x0c) #define GENET_INTRL2_CPU_SET_MASK (GENET_INTRL2_OFF + 0x10) #define GENET_INTRL2_CPU_CLEAR_MASK (GENET_INTRL2_OFF + 0x14) #define GENET_IRQ_MDIO_ERROR BIT(24) #define GENET_IRQ_MDIO_DONE BIT(23) #define GENET_IRQ_TXDMA_DONE BIT(16) #define GENET_IRQ_RXDMA_DONE BIT(13) #define CMD_TX_EN BIT(0) #define CMD_RX_EN BIT(1) #define UMAC_SPEED_10 (0) #define UMAC_SPEED_100 (1) #define UMAC_SPEED_1000 (2) #define UMAC_SPEED_2500 (3) #define CMD_SPEED_SHIFT (2) #define CMD_SPEED_MASK (3) #define CMD_SW_RESET BIT(13) #define CMD_LCL_LOOP_EN BIT(15) #define CMD_TX_EN BIT(0) #define CMD_RX_EN BIT(1) #define MIB_RESET_RX BIT(0) #define MIB_RESET_RUNT BIT(1) #define MIB_RESET_TX BIT(2) /* total number of Buffer Descriptors, same for Rx/Tx */ #define TOTAL_DESCS (256) #define RX_DESCS TOTAL_DESCS #define TX_DESCS TOTAL_DESCS #define DEFAULT_Q (0x10) #define ETH_DATA_LEN (1500) #define ETH_HLEN (14) #define VLAN_HLEN (4) #define ETH_FCS_LEN (4) /* * Body(1500) + EH_SIZE(14) + VLANTAG(4) + BRCMTAG(6) + FCS(4) = 1528. * 1536 is multiple of 256 bytes */ #define ENET_BRCM_TAG_LEN (6) #define ENET_PAD (8) #define ENET_MAX_MTU_SIZE (ETH_DATA_LEN + ETH_HLEN + VLAN_HLEN + ENET_BRCM_TAG_LEN + ETH_FCS_LEN + ENET_PAD) /* Tx/Rx Dma Descriptor common bits */ #define DMA_EN BIT(0) #define DMA_RING_BUF_EN_SHIFT (0x01) #define DMA_RING_BUF_EN_MASK (0xffff) #define DMA_BUFLENGTH_MASK (0x0fff) #define DMA_BUFLENGTH_SHIFT (16) #define DMA_RING_SIZE_SHIFT (16) #define DMA_OWN (0x8000) #define DMA_EOP (0x4000) #define DMA_SOP (0x2000) #define DMA_WRAP (0x1000) #define DMA_MAX_BURST_LENGTH (0x8) /* Tx specific DMA descriptor bits */ #define DMA_TX_UNDERRUN (0x0200) #define DMA_TX_APPEND_CRC (0x0040) #define DMA_TX_OW_CRC (0x0020) #define DMA_TX_DO_CSUM (0x0010) #define DMA_TX_QTAG_SHIFT (7) /* DMA rings size */ #define DMA_RING_SIZE (0x40) #define DMA_RINGS_SIZE (DMA_RING_SIZE * (DEFAULT_Q + 1)) /* DMA descriptor */ #define DMA_DESC_LENGTH_STATUS (0x00) #define DMA_DESC_ADDRESS_LO (0x04) #define DMA_DESC_ADDRESS_HI (0x08) #define DMA_DESC_SIZE (12) #define GENET_RX_OFF (0x2000) #define GENET_RDMA_REG_OFF (GENET_RX_OFF + TOTAL_DESCS * DMA_DESC_SIZE) #define GENET_TX_OFF (0x4000) #define GENET_TDMA_REG_OFF (GENET_TX_OFF + TOTAL_DESCS * DMA_DESC_SIZE) #define DMA_FC_THRESH_HI (RX_DESCS >> 4) #define DMA_FC_THRESH_LO (5) #define DMA_FC_THRESH_VALUE ((DMA_FC_THRESH_LO << 16) | DMA_FC_THRESH_HI) #define DMA_XOFF_THRESHOLD_SHIFT (16) #define TDMA_RING_REG_BASE (GENET_TDMA_REG_OFF + DEFAULT_Q * DMA_RING_SIZE) #define TDMA_READ_PTR (TDMA_RING_REG_BASE + 0x00) #define TDMA_CONS_INDEX (TDMA_RING_REG_BASE + 0x08) #define TDMA_PROD_INDEX (TDMA_RING_REG_BASE + 0x0c) #define DMA_RING_BUF_SIZE (0x10) #define DMA_START_ADDR (0x14) #define DMA_END_ADDR (0x1c) #define DMA_MBUF_DONE_THRESH (0x24) #define TDMA_FLOW_PERIOD (TDMA_RING_REG_BASE + 0x28) #define TDMA_WRITE_PTR (TDMA_RING_REG_BASE + 0x2c) #define RDMA_RING_REG_BASE (GENET_RDMA_REG_OFF + DEFAULT_Q * DMA_RING_SIZE) #define RDMA_WRITE_PTR (RDMA_RING_REG_BASE + 0x00) #define RDMA_PROD_INDEX (RDMA_RING_REG_BASE + 0x08) #define RDMA_CONS_INDEX (RDMA_RING_REG_BASE + 0x0c) #define RDMA_XON_XOFF_THRESH (RDMA_RING_REG_BASE + 0x28) #define RDMA_READ_PTR (RDMA_RING_REG_BASE + 0x2c) #define TDMA_REG_BASE (GENET_TDMA_REG_OFF + DMA_RINGS_SIZE) #define RDMA_REG_BASE (GENET_RDMA_REG_OFF + DMA_RINGS_SIZE) #define DMA_RING_CFG (0x00) #define DMA_CTRL (0x04) #define DMA_SCB_BURST_SIZE (0x0c) #define RX_BUF_LENGTH (2048) #define RX_TOTAL_BUFSIZE (RX_BUF_LENGTH * RX_DESCS) #define RX_BUF_OFFSET (2) #define PHY_INTERFACE_MODE_RGMII (7) #define PHY_INTERFACE_MODE_RGMII_RXID (9) #define BCM54213PE_MII_CONTROL (0x00) #define BCM54213PE_MII_STATUS (0x01) #define BCM54213PE_PHY_IDENTIFIER_HIGH (0x02) #define BCM54213PE_PHY_IDENTIFIER_LOW (0x03) #define BCM54213PE_AUTO_NEGOTIATION_ADV (0x04) #define BCM54213PE_AUTO_NEGOTIATION_LINK (0x05) #define BCM54213PE_AUTO_NEGOTIATION_EXPANSION (0x06) #define BCM54213PE_NEXT_PAGE_TX (0x07) #define BCM54213PE_PARTNER_RX (0x08) #define BCM54213PE_CONTROL (0x09) #define BCM54213PE_STATUS (0x0A) #define BCM54213PE_IEEE_EXTENDED_STATUS (0x0F) #define BCM54213PE_PHY_EXTENDED_CONTROL (0x10) #define BCM54213PE_PHY_EXTENDED_STATUS (0x11) #define BCM54213PE_RECEIVE_ERROR_COUNTER (0x12) #define BCM54213PE_FALSE_C_S_COUNTER (0x13) #define BCM54213PE_RECEIVE_NOT_OK_COUNTER (0x14) #define BCM54213PE_VERSION_B1 (0x600d84a2) #define BCM54213PE_VERSION_X (0x600d84a0) //BCM54213PE_MII_CONTROL #define MII_CONTROL_PHY_RESET (1 << 15) #define MII_CONTROL_AUTO_NEGOTIATION_ENABLED (1 << 12) #define MII_CONTROL_AUTO_NEGOTIATION_RESTART (1 << 9) #define MII_CONTROL_PHY_FULL_DUPLEX (1 << 8) #define MII_CONTROL_SPEED_SELECTION (1 << 6) //BCM54213PE_MII_STATUS #define MII_STATUS_LINK_UP (1 << 2) //BCM54213PE_CONTROL #define CONTROL_FULL_DUPLEX_CAPABILITY (1 << 9) #define CONTROL_HALF_DUPLEX_CAPABILITY (1 << 8) #define SPEED_1000 (1000) #define SPEED_100 (100) #define SPEED_10 (10) #endif/* __DRV_ETH_H__ */