123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225 |
- /*
- * 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 BIT(nr) (1UL << (nr))
- #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__ */
|