1 /* SPDX-License-Identifier: GPL-2.0+ */
3 * Copyright (c) 2017 Microchip Technology Inc. All rights reserved.
9 /* USB Vendor Requests */
10 #define USB_VENDOR_REQUEST_WRITE_REGISTER 0xA0
11 #define USB_VENDOR_REQUEST_READ_REGISTER 0xA1
12 #define USB_VENDOR_REQUEST_GET_STATS 0xA2
15 #define TX_CMD_A_FCS BIT(22)
16 #define TX_CMD_A_LEN_MASK 0x000FFFFF
19 #define RX_CMD_A_RXE BIT(18)
20 #define RX_CMD_A_LEN_MASK 0x00003FFF
24 #define ID_REV_CHIP_ID_MASK 0xFFFF0000
25 #define ID_REV_CHIP_ID_7500 0x7500
26 #define ID_REV_CHIP_ID_7800 0x7800
27 #define ID_REV_CHIP_ID_7850 0x7850
32 #define HW_CFG_LRST BIT(1)
35 #define PMT_CTL_PHY_PWRUP BIT(10)
36 #define PMT_CTL_READY BIT(7)
37 #define PMT_CTL_PHY_RST BIT(4)
40 #define E2P_CMD_EPC_BUSY BIT(31)
41 #define E2P_CMD_EPC_CMD_READ 0x00000000
42 #define E2P_CMD_EPC_TIMEOUT BIT(10)
43 #define E2P_CMD_EPC_ADDR_MASK 0x000001FF
45 #define E2P_DATA 0x044
47 #define RFE_CTL_BCAST_EN BIT(10)
48 #define RFE_CTL_DA_PERFECT BIT(1)
50 #define FCT_RX_CTL_EN BIT(31)
52 #define FCT_TX_CTL_EN BIT(31)
55 #define MAC_CR_ADP BIT(13)
56 #define MAC_CR_AUTO_DUPLEX BIT(12)
57 #define MAC_CR_AUTO_SPEED BIT(11)
60 #define MAC_RX_FCS_STRIP BIT(4)
61 #define MAC_RX_RXEN BIT(0)
64 #define MAC_TX_TXEN BIT(0)
67 #define FLOW_CR_TX_FCEN BIT(30)
68 #define FLOW_CR_RX_FCEN BIT(29)
70 #define RX_ADDRH 0x118
71 #define RX_ADDRL 0x11C
74 #define MII_ACC_MII_READ 0x00000000
75 #define MII_ACC_MII_WRITE 0x00000002
76 #define MII_ACC_MII_BUSY BIT(0)
78 #define MII_DATA 0x124
80 #define SS_USB_PKT_SIZE 1024
81 #define HS_USB_PKT_SIZE 512
82 #define FS_USB_PKT_SIZE 64
84 #define MAX_RX_FIFO_SIZE (12 * 1024)
85 #define MAX_TX_FIFO_SIZE (12 * 1024)
86 #define DEFAULT_BULK_IN_DELAY 0x0800
88 #define EEPROM_INDICATOR 0xA5
89 #define EEPROM_MAC_OFFSET 0x01
91 /* Some extra defines */
92 #define LAN7X_INTERNAL_PHY_ID 1
94 #define LAN7X_MAC_RX_MAX_SIZE(mtu) \
95 ((mtu) << 16) /* Max frame size */
96 #define LAN7X_MAC_RX_MAX_SIZE_DEFAULT \
97 LAN7X_MAC_RX_MAX_SIZE(PKTSIZE_ALIGN + 4 /* VLAN */ + 4 /* CRC */)
100 #define USB_CTRL_SET_TIMEOUT_MS 5000
101 #define USB_CTRL_GET_TIMEOUT_MS 5000
102 #define USB_BULK_SEND_TIMEOUT_MS 5000
103 #define USB_BULK_RECV_TIMEOUT_MS 5000
104 #define TIMEOUT_RESOLUTION_MS 50
105 #define PHY_CONNECT_TIMEOUT_MS 5000
107 #define RX_URB_SIZE 2048
110 struct lan7x_private {
111 struct ueth_data ueth;
112 u32 chipid; /* Chip or device ID */
113 struct mii_dev *mdiobus;
114 struct phy_device *phydev;
118 * Lan7x infrastructure commands
121 int lan7x_write_reg(struct usb_device *udev, u32 index, u32 data);
123 int lan7x_read_reg(struct usb_device *udev, u32 index, u32 *data);
125 static inline int lan7x_wait_for_bit(struct usb_device *udev,
126 const char *prefix, const u32 reg,
127 const u32 mask, const bool set,
128 const unsigned int timeout_ms,
129 const bool breakable)
132 unsigned long start = get_timer(0);
135 lan7x_read_reg(udev, reg, &val);
140 if ((val & mask) == mask)
143 if (get_timer(start) > timeout_ms)
146 if (breakable && ctrlc()) {
155 debug("%s: Timeout (reg=0x%x mask=%08x wait_set=%i)\n", prefix, reg,
161 int lan7x_mdio_read(struct usb_device *udev, int phy_id, int idx);
163 void lan7x_mdio_write(struct usb_device *udev, int phy_id, int idx,
166 static inline int lan7x_mdio_wait_for_bit(struct usb_device *udev,
168 int phy_id, const u32 reg,
169 const u32 mask, const bool set,
170 const unsigned int timeout_ms,
171 const bool breakable)
174 unsigned long start = get_timer(0);
177 val = lan7x_mdio_read(udev, phy_id, reg);
182 if ((val & mask) == mask)
185 if (get_timer(start) > timeout_ms)
188 if (breakable && ctrlc()) {
197 debug("%s: Timeout (reg=0x%x mask=%08x wait_set=%i)\n", prefix, reg,
203 int lan7x_phylib_register(struct udevice *udev);
205 int lan7x_eth_phylib_connect(struct udevice *udev, struct ueth_data *dev);
207 int lan7x_eth_phylib_config_start(struct udevice *udev);
209 int lan7x_pmt_phy_reset(struct usb_device *udev,
210 struct ueth_data *dev);
212 int lan7x_update_flowcontrol(struct usb_device *udev,
213 struct ueth_data *dev,
214 uint32_t *flow, uint32_t *fct_flow);
216 int lan7x_read_eeprom_mac(unsigned char *enetaddr, struct usb_device *udev);
218 int lan7x_basic_reset(struct usb_device *udev,
219 struct ueth_data *dev);
221 void lan7x_eth_stop(struct udevice *dev);
223 int lan7x_eth_send(struct udevice *dev, void *packet, int length);
225 int lan7x_eth_recv(struct udevice *dev, int flags, uchar **packetp);
227 int lan7x_free_pkt(struct udevice *dev, uchar *packet, int packet_len);
229 int lan7x_eth_remove(struct udevice *dev);