1 // SPDX-License-Identifier: GPL-2.0+
2 /*
3  * Copyright (C) 2015 Microchip Technology
4  */
5 #include <linux/module.h>
6 #include <linux/netdevice.h>
7 #include <linux/etherdevice.h>
8 #include <linux/ethtool.h>
9 #include <linux/usb.h>
10 #include <linux/crc32.h>
11 #include <linux/signal.h>
12 #include <linux/slab.h>
13 #include <linux/if_vlan.h>
14 #include <linux/uaccess.h>
15 #include <linux/linkmode.h>
16 #include <linux/list.h>
17 #include <linux/ip.h>
18 #include <linux/ipv6.h>
19 #include <linux/mdio.h>
20 #include <linux/phy.h>
21 #include <net/ip6_checksum.h>
22 #include <net/vxlan.h>
23 #include <linux/interrupt.h>
24 #include <linux/irqdomain.h>
25 #include <linux/irq.h>
26 #include <linux/irqchip/chained_irq.h>
27 #include <linux/microchipphy.h>
28 #include <linux/phy_fixed.h>
29 #include <linux/of_mdio.h>
30 #include <linux/of_net.h>
31 #include "lan78xx.h"
32 
33 #define DRIVER_AUTHOR	"WOOJUNG HUH <woojung.huh@microchip.com>"
34 #define DRIVER_DESC	"LAN78XX USB 3.0 Gigabit Ethernet Devices"
35 #define DRIVER_NAME	"lan78xx"
36 
37 #define TX_TIMEOUT_JIFFIES		(5 * HZ)
38 #define THROTTLE_JIFFIES		(HZ / 8)
39 #define UNLINK_TIMEOUT_MS		3
40 
41 #define RX_MAX_QUEUE_MEMORY		(60 * 1518)
42 
43 #define SS_USB_PKT_SIZE			(1024)
44 #define HS_USB_PKT_SIZE			(512)
45 #define FS_USB_PKT_SIZE			(64)
46 
47 #define MAX_RX_FIFO_SIZE		(12 * 1024)
48 #define MAX_TX_FIFO_SIZE		(12 * 1024)
49 
50 #define FLOW_THRESHOLD(n)		((((n) + 511) / 512) & 0x7F)
51 #define FLOW_CTRL_THRESHOLD(on, off)	((FLOW_THRESHOLD(on)  << 0) | \
52 					 (FLOW_THRESHOLD(off) << 8))
53 
54 /* Flow control turned on when Rx FIFO level rises above this level (bytes) */
55 #define FLOW_ON_SS			9216
56 #define FLOW_ON_HS			8704
57 
58 /* Flow control turned off when Rx FIFO level falls below this level (bytes) */
59 #define FLOW_OFF_SS			4096
60 #define FLOW_OFF_HS			1024
61 
62 #define DEFAULT_BURST_CAP_SIZE		(MAX_TX_FIFO_SIZE)
63 #define DEFAULT_BULK_IN_DELAY		(0x0800)
64 #define MAX_SINGLE_PACKET_SIZE		(9000)
65 #define DEFAULT_TX_CSUM_ENABLE		(true)
66 #define DEFAULT_RX_CSUM_ENABLE		(true)
67 #define DEFAULT_TSO_CSUM_ENABLE		(true)
68 #define DEFAULT_VLAN_FILTER_ENABLE	(true)
69 #define DEFAULT_VLAN_RX_OFFLOAD		(true)
70 #define TX_ALIGNMENT			(4)
71 #define RXW_PADDING			2
72 
73 #define LAN78XX_USB_VENDOR_ID		(0x0424)
74 #define LAN7800_USB_PRODUCT_ID		(0x7800)
75 #define LAN7850_USB_PRODUCT_ID		(0x7850)
76 #define LAN7801_USB_PRODUCT_ID		(0x7801)
77 #define LAN78XX_EEPROM_MAGIC		(0x78A5)
78 #define LAN78XX_OTP_MAGIC		(0x78F3)
79 #define AT29M2AF_USB_VENDOR_ID		(0x07C9)
80 #define AT29M2AF_USB_PRODUCT_ID	(0x0012)
81 
82 #define	MII_READ			1
83 #define	MII_WRITE			0
84 
85 #define EEPROM_INDICATOR		(0xA5)
86 #define EEPROM_MAC_OFFSET		(0x01)
87 #define MAX_EEPROM_SIZE			512
88 #define OTP_INDICATOR_1			(0xF3)
89 #define OTP_INDICATOR_2			(0xF7)
90 
91 #define WAKE_ALL			(WAKE_PHY | WAKE_UCAST | \
92 					 WAKE_MCAST | WAKE_BCAST | \
93 					 WAKE_ARP | WAKE_MAGIC)
94 
95 #define TX_URB_NUM			10
96 #define TX_SS_URB_NUM			TX_URB_NUM
97 #define TX_HS_URB_NUM			TX_URB_NUM
98 #define TX_FS_URB_NUM			TX_URB_NUM
99 
100 /* A single URB buffer must be large enough to hold a complete jumbo packet
101  */
102 #define TX_SS_URB_SIZE			(32 * 1024)
103 #define TX_HS_URB_SIZE			(16 * 1024)
104 #define TX_FS_URB_SIZE			(10 * 1024)
105 
106 #define RX_SS_URB_NUM			30
107 #define RX_HS_URB_NUM			10
108 #define RX_FS_URB_NUM			10
109 #define RX_SS_URB_SIZE			TX_SS_URB_SIZE
110 #define RX_HS_URB_SIZE			TX_HS_URB_SIZE
111 #define RX_FS_URB_SIZE			TX_FS_URB_SIZE
112 
113 #define SS_BURST_CAP_SIZE		RX_SS_URB_SIZE
114 #define SS_BULK_IN_DELAY		0x2000
115 #define HS_BURST_CAP_SIZE		RX_HS_URB_SIZE
116 #define HS_BULK_IN_DELAY		0x2000
117 #define FS_BURST_CAP_SIZE		RX_FS_URB_SIZE
118 #define FS_BULK_IN_DELAY		0x2000
119 
120 #define TX_CMD_LEN			8
121 #define TX_SKB_MIN_LEN			(TX_CMD_LEN + ETH_HLEN)
122 #define LAN78XX_TSO_SIZE(dev)		((dev)->tx_urb_size - TX_SKB_MIN_LEN)
123 
124 #define RX_CMD_LEN			10
125 #define RX_SKB_MIN_LEN			(RX_CMD_LEN + ETH_HLEN)
126 #define RX_MAX_FRAME_LEN(mtu)		((mtu) + ETH_HLEN + VLAN_HLEN)
127 
128 /* USB related defines */
129 #define BULK_IN_PIPE			1
130 #define BULK_OUT_PIPE			2
131 
132 /* default autosuspend delay (mSec)*/
133 #define DEFAULT_AUTOSUSPEND_DELAY	(10 * 1000)
134 
135 /* statistic update interval (mSec) */
136 #define STAT_UPDATE_TIMER		(1 * 1000)
137 
138 /* time to wait for MAC or FCT to stop (jiffies) */
139 #define HW_DISABLE_TIMEOUT		(HZ / 10)
140 
141 /* time to wait between polling MAC or FCT state (ms) */
142 #define HW_DISABLE_DELAY_MS		1
143 
144 /* defines interrupts from interrupt EP */
145 #define MAX_INT_EP			(32)
146 #define INT_EP_INTEP			(31)
147 #define INT_EP_OTP_WR_DONE		(28)
148 #define INT_EP_EEE_TX_LPI_START		(26)
149 #define INT_EP_EEE_TX_LPI_STOP		(25)
150 #define INT_EP_EEE_RX_LPI		(24)
151 #define INT_EP_MAC_RESET_TIMEOUT	(23)
152 #define INT_EP_RDFO			(22)
153 #define INT_EP_TXE			(21)
154 #define INT_EP_USB_STATUS		(20)
155 #define INT_EP_TX_DIS			(19)
156 #define INT_EP_RX_DIS			(18)
157 #define INT_EP_PHY			(17)
158 #define INT_EP_DP			(16)
159 #define INT_EP_MAC_ERR			(15)
160 #define INT_EP_TDFU			(14)
161 #define INT_EP_TDFO			(13)
162 #define INT_EP_UTX			(12)
163 #define INT_EP_GPIO_11			(11)
164 #define INT_EP_GPIO_10			(10)
165 #define INT_EP_GPIO_9			(9)
166 #define INT_EP_GPIO_8			(8)
167 #define INT_EP_GPIO_7			(7)
168 #define INT_EP_GPIO_6			(6)
169 #define INT_EP_GPIO_5			(5)
170 #define INT_EP_GPIO_4			(4)
171 #define INT_EP_GPIO_3			(3)
172 #define INT_EP_GPIO_2			(2)
173 #define INT_EP_GPIO_1			(1)
174 #define INT_EP_GPIO_0			(0)
175 
176 static const char lan78xx_gstrings[][ETH_GSTRING_LEN] = {
177 	"RX FCS Errors",
178 	"RX Alignment Errors",
179 	"Rx Fragment Errors",
180 	"RX Jabber Errors",
181 	"RX Undersize Frame Errors",
182 	"RX Oversize Frame Errors",
183 	"RX Dropped Frames",
184 	"RX Unicast Byte Count",
185 	"RX Broadcast Byte Count",
186 	"RX Multicast Byte Count",
187 	"RX Unicast Frames",
188 	"RX Broadcast Frames",
189 	"RX Multicast Frames",
190 	"RX Pause Frames",
191 	"RX 64 Byte Frames",
192 	"RX 65 - 127 Byte Frames",
193 	"RX 128 - 255 Byte Frames",
194 	"RX 256 - 511 Bytes Frames",
195 	"RX 512 - 1023 Byte Frames",
196 	"RX 1024 - 1518 Byte Frames",
197 	"RX Greater 1518 Byte Frames",
198 	"EEE RX LPI Transitions",
199 	"EEE RX LPI Time",
200 	"TX FCS Errors",
201 	"TX Excess Deferral Errors",
202 	"TX Carrier Errors",
203 	"TX Bad Byte Count",
204 	"TX Single Collisions",
205 	"TX Multiple Collisions",
206 	"TX Excessive Collision",
207 	"TX Late Collisions",
208 	"TX Unicast Byte Count",
209 	"TX Broadcast Byte Count",
210 	"TX Multicast Byte Count",
211 	"TX Unicast Frames",
212 	"TX Broadcast Frames",
213 	"TX Multicast Frames",
214 	"TX Pause Frames",
215 	"TX 64 Byte Frames",
216 	"TX 65 - 127 Byte Frames",
217 	"TX 128 - 255 Byte Frames",
218 	"TX 256 - 511 Bytes Frames",
219 	"TX 512 - 1023 Byte Frames",
220 	"TX 1024 - 1518 Byte Frames",
221 	"TX Greater 1518 Byte Frames",
222 	"EEE TX LPI Transitions",
223 	"EEE TX LPI Time",
224 };
225 
226 struct lan78xx_statstage {
227 	u32 rx_fcs_errors;
228 	u32 rx_alignment_errors;
229 	u32 rx_fragment_errors;
230 	u32 rx_jabber_errors;
231 	u32 rx_undersize_frame_errors;
232 	u32 rx_oversize_frame_errors;
233 	u32 rx_dropped_frames;
234 	u32 rx_unicast_byte_count;
235 	u32 rx_broadcast_byte_count;
236 	u32 rx_multicast_byte_count;
237 	u32 rx_unicast_frames;
238 	u32 rx_broadcast_frames;
239 	u32 rx_multicast_frames;
240 	u32 rx_pause_frames;
241 	u32 rx_64_byte_frames;
242 	u32 rx_65_127_byte_frames;
243 	u32 rx_128_255_byte_frames;
244 	u32 rx_256_511_bytes_frames;
245 	u32 rx_512_1023_byte_frames;
246 	u32 rx_1024_1518_byte_frames;
247 	u32 rx_greater_1518_byte_frames;
248 	u32 eee_rx_lpi_transitions;
249 	u32 eee_rx_lpi_time;
250 	u32 tx_fcs_errors;
251 	u32 tx_excess_deferral_errors;
252 	u32 tx_carrier_errors;
253 	u32 tx_bad_byte_count;
254 	u32 tx_single_collisions;
255 	u32 tx_multiple_collisions;
256 	u32 tx_excessive_collision;
257 	u32 tx_late_collisions;
258 	u32 tx_unicast_byte_count;
259 	u32 tx_broadcast_byte_count;
260 	u32 tx_multicast_byte_count;
261 	u32 tx_unicast_frames;
262 	u32 tx_broadcast_frames;
263 	u32 tx_multicast_frames;
264 	u32 tx_pause_frames;
265 	u32 tx_64_byte_frames;
266 	u32 tx_65_127_byte_frames;
267 	u32 tx_128_255_byte_frames;
268 	u32 tx_256_511_bytes_frames;
269 	u32 tx_512_1023_byte_frames;
270 	u32 tx_1024_1518_byte_frames;
271 	u32 tx_greater_1518_byte_frames;
272 	u32 eee_tx_lpi_transitions;
273 	u32 eee_tx_lpi_time;
274 };
275 
276 struct lan78xx_statstage64 {
277 	u64 rx_fcs_errors;
278 	u64 rx_alignment_errors;
279 	u64 rx_fragment_errors;
280 	u64 rx_jabber_errors;
281 	u64 rx_undersize_frame_errors;
282 	u64 rx_oversize_frame_errors;
283 	u64 rx_dropped_frames;
284 	u64 rx_unicast_byte_count;
285 	u64 rx_broadcast_byte_count;
286 	u64 rx_multicast_byte_count;
287 	u64 rx_unicast_frames;
288 	u64 rx_broadcast_frames;
289 	u64 rx_multicast_frames;
290 	u64 rx_pause_frames;
291 	u64 rx_64_byte_frames;
292 	u64 rx_65_127_byte_frames;
293 	u64 rx_128_255_byte_frames;
294 	u64 rx_256_511_bytes_frames;
295 	u64 rx_512_1023_byte_frames;
296 	u64 rx_1024_1518_byte_frames;
297 	u64 rx_greater_1518_byte_frames;
298 	u64 eee_rx_lpi_transitions;
299 	u64 eee_rx_lpi_time;
300 	u64 tx_fcs_errors;
301 	u64 tx_excess_deferral_errors;
302 	u64 tx_carrier_errors;
303 	u64 tx_bad_byte_count;
304 	u64 tx_single_collisions;
305 	u64 tx_multiple_collisions;
306 	u64 tx_excessive_collision;
307 	u64 tx_late_collisions;
308 	u64 tx_unicast_byte_count;
309 	u64 tx_broadcast_byte_count;
310 	u64 tx_multicast_byte_count;
311 	u64 tx_unicast_frames;
312 	u64 tx_broadcast_frames;
313 	u64 tx_multicast_frames;
314 	u64 tx_pause_frames;
315 	u64 tx_64_byte_frames;
316 	u64 tx_65_127_byte_frames;
317 	u64 tx_128_255_byte_frames;
318 	u64 tx_256_511_bytes_frames;
319 	u64 tx_512_1023_byte_frames;
320 	u64 tx_1024_1518_byte_frames;
321 	u64 tx_greater_1518_byte_frames;
322 	u64 eee_tx_lpi_transitions;
323 	u64 eee_tx_lpi_time;
324 };
325 
326 static u32 lan78xx_regs[] = {
327 	ID_REV,
328 	INT_STS,
329 	HW_CFG,
330 	PMT_CTL,
331 	E2P_CMD,
332 	E2P_DATA,
333 	USB_STATUS,
334 	VLAN_TYPE,
335 	MAC_CR,
336 	MAC_RX,
337 	MAC_TX,
338 	FLOW,
339 	ERR_STS,
340 	MII_ACC,
341 	MII_DATA,
342 	EEE_TX_LPI_REQ_DLY,
343 	EEE_TW_TX_SYS,
344 	EEE_TX_LPI_REM_DLY,
345 	WUCSR
346 };
347 
348 #define PHY_REG_SIZE (32 * sizeof(u32))
349 
350 struct lan78xx_net;
351 
352 struct lan78xx_priv {
353 	struct lan78xx_net *dev;
354 	u32 rfe_ctl;
355 	u32 mchash_table[DP_SEL_VHF_HASH_LEN]; /* multicast hash table */
356 	u32 pfilter_table[NUM_OF_MAF][2]; /* perfect filter table */
357 	u32 vlan_table[DP_SEL_VHF_VLAN_LEN];
358 	struct mutex dataport_mutex; /* for dataport access */
359 	spinlock_t rfe_ctl_lock; /* for rfe register access */
360 	struct work_struct set_multicast;
361 	struct work_struct set_vlan;
362 	u32 wol;
363 };
364 
365 enum skb_state {
366 	illegal = 0,
367 	tx_start,
368 	tx_done,
369 	rx_start,
370 	rx_done,
371 	rx_cleanup,
372 	unlink_start
373 };
374 
375 struct skb_data {		/* skb->cb is one of these */
376 	struct urb *urb;
377 	struct lan78xx_net *dev;
378 	enum skb_state state;
379 	size_t length;
380 	int num_of_packet;
381 };
382 
383 struct usb_context {
384 	struct usb_ctrlrequest req;
385 	struct lan78xx_net *dev;
386 };
387 
388 #define EVENT_TX_HALT			0
389 #define EVENT_RX_HALT			1
390 #define EVENT_RX_MEMORY			2
391 #define EVENT_STS_SPLIT			3
392 #define EVENT_LINK_RESET		4
393 #define EVENT_RX_PAUSED			5
394 #define EVENT_DEV_WAKING		6
395 #define EVENT_DEV_ASLEEP		7
396 #define EVENT_DEV_OPEN			8
397 #define EVENT_STAT_UPDATE		9
398 #define EVENT_DEV_DISCONNECT		10
399 
400 struct statstage {
401 	struct mutex			access_lock;	/* for stats access */
402 	struct lan78xx_statstage	saved;
403 	struct lan78xx_statstage	rollover_count;
404 	struct lan78xx_statstage	rollover_max;
405 	struct lan78xx_statstage64	curr_stat;
406 };
407 
408 struct irq_domain_data {
409 	struct irq_domain	*irqdomain;
410 	unsigned int		phyirq;
411 	struct irq_chip		*irqchip;
412 	irq_flow_handler_t	irq_handler;
413 	u32			irqenable;
414 	struct mutex		irq_lock;		/* for irq bus access */
415 };
416 
417 struct lan78xx_net {
418 	struct net_device	*net;
419 	struct usb_device	*udev;
420 	struct usb_interface	*intf;
421 	void			*driver_priv;
422 
423 	unsigned int		tx_pend_data_len;
424 	size_t			n_tx_urbs;
425 	size_t			n_rx_urbs;
426 	size_t			tx_urb_size;
427 	size_t			rx_urb_size;
428 
429 	struct sk_buff_head	rxq_free;
430 	struct sk_buff_head	rxq;
431 	struct sk_buff_head	rxq_done;
432 	struct sk_buff_head	rxq_overflow;
433 	struct sk_buff_head	txq_free;
434 	struct sk_buff_head	txq;
435 	struct sk_buff_head	txq_pend;
436 
437 	struct napi_struct	napi;
438 
439 	struct delayed_work	wq;
440 
441 	int			msg_enable;
442 
443 	struct urb		*urb_intr;
444 	struct usb_anchor	deferred;
445 
446 	struct mutex		dev_mutex; /* serialise open/stop wrt suspend/resume */
447 	struct mutex		phy_mutex; /* for phy access */
448 	unsigned int		pipe_in, pipe_out, pipe_intr;
449 
450 	unsigned int		bulk_in_delay;
451 	unsigned int		burst_cap;
452 
453 	unsigned long		flags;
454 
455 	wait_queue_head_t	*wait;
456 	unsigned char		suspend_count;
457 
458 	unsigned int		maxpacket;
459 	struct timer_list	stat_monitor;
460 
461 	unsigned long		data[5];
462 
463 	int			link_on;
464 	u8			mdix_ctrl;
465 
466 	u32			chipid;
467 	u32			chiprev;
468 	struct mii_bus		*mdiobus;
469 	phy_interface_t		interface;
470 
471 	int			fc_autoneg;
472 	u8			fc_request_control;
473 
474 	int			delta;
475 	struct statstage	stats;
476 
477 	struct irq_domain_data	domain_data;
478 };
479 
480 /* define external phy id */
481 #define	PHY_LAN8835			(0x0007C130)
482 #define	PHY_KSZ9031RNX			(0x00221620)
483 
484 /* use ethtool to change the level for any given device */
485 static int msg_level = -1;
486 module_param(msg_level, int, 0);
487 MODULE_PARM_DESC(msg_level, "Override default message level");
488 
lan78xx_get_buf(struct sk_buff_head * buf_pool)489 static struct sk_buff *lan78xx_get_buf(struct sk_buff_head *buf_pool)
490 {
491 	if (skb_queue_empty(buf_pool))
492 		return NULL;
493 
494 	return skb_dequeue(buf_pool);
495 }
496 
lan78xx_release_buf(struct sk_buff_head * buf_pool,struct sk_buff * buf)497 static void lan78xx_release_buf(struct sk_buff_head *buf_pool,
498 				struct sk_buff *buf)
499 {
500 	buf->data = buf->head;
501 	skb_reset_tail_pointer(buf);
502 
503 	buf->len = 0;
504 	buf->data_len = 0;
505 
506 	skb_queue_tail(buf_pool, buf);
507 }
508 
lan78xx_free_buf_pool(struct sk_buff_head * buf_pool)509 static void lan78xx_free_buf_pool(struct sk_buff_head *buf_pool)
510 {
511 	struct skb_data *entry;
512 	struct sk_buff *buf;
513 
514 	while (!skb_queue_empty(buf_pool)) {
515 		buf = skb_dequeue(buf_pool);
516 		if (buf) {
517 			entry = (struct skb_data *)buf->cb;
518 			usb_free_urb(entry->urb);
519 			dev_kfree_skb_any(buf);
520 		}
521 	}
522 }
523 
lan78xx_alloc_buf_pool(struct sk_buff_head * buf_pool,size_t n_urbs,size_t urb_size,struct lan78xx_net * dev)524 static int lan78xx_alloc_buf_pool(struct sk_buff_head *buf_pool,
525 				  size_t n_urbs, size_t urb_size,
526 				  struct lan78xx_net *dev)
527 {
528 	struct skb_data *entry;
529 	struct sk_buff *buf;
530 	struct urb *urb;
531 	int i;
532 
533 	skb_queue_head_init(buf_pool);
534 
535 	for (i = 0; i < n_urbs; i++) {
536 		buf = alloc_skb(urb_size, GFP_ATOMIC);
537 		if (!buf)
538 			goto error;
539 
540 		if (skb_linearize(buf) != 0) {
541 			dev_kfree_skb_any(buf);
542 			goto error;
543 		}
544 
545 		urb = usb_alloc_urb(0, GFP_ATOMIC);
546 		if (!urb) {
547 			dev_kfree_skb_any(buf);
548 			goto error;
549 		}
550 
551 		entry = (struct skb_data *)buf->cb;
552 		entry->urb = urb;
553 		entry->dev = dev;
554 		entry->length = 0;
555 		entry->num_of_packet = 0;
556 
557 		skb_queue_tail(buf_pool, buf);
558 	}
559 
560 	return 0;
561 
562 error:
563 	lan78xx_free_buf_pool(buf_pool);
564 
565 	return -ENOMEM;
566 }
567 
lan78xx_get_rx_buf(struct lan78xx_net * dev)568 static struct sk_buff *lan78xx_get_rx_buf(struct lan78xx_net *dev)
569 {
570 	return lan78xx_get_buf(&dev->rxq_free);
571 }
572 
lan78xx_release_rx_buf(struct lan78xx_net * dev,struct sk_buff * rx_buf)573 static void lan78xx_release_rx_buf(struct lan78xx_net *dev,
574 				   struct sk_buff *rx_buf)
575 {
576 	lan78xx_release_buf(&dev->rxq_free, rx_buf);
577 }
578 
lan78xx_free_rx_resources(struct lan78xx_net * dev)579 static void lan78xx_free_rx_resources(struct lan78xx_net *dev)
580 {
581 	lan78xx_free_buf_pool(&dev->rxq_free);
582 }
583 
lan78xx_alloc_rx_resources(struct lan78xx_net * dev)584 static int lan78xx_alloc_rx_resources(struct lan78xx_net *dev)
585 {
586 	return lan78xx_alloc_buf_pool(&dev->rxq_free,
587 				      dev->n_rx_urbs, dev->rx_urb_size, dev);
588 }
589 
lan78xx_get_tx_buf(struct lan78xx_net * dev)590 static struct sk_buff *lan78xx_get_tx_buf(struct lan78xx_net *dev)
591 {
592 	return lan78xx_get_buf(&dev->txq_free);
593 }
594 
lan78xx_release_tx_buf(struct lan78xx_net * dev,struct sk_buff * tx_buf)595 static void lan78xx_release_tx_buf(struct lan78xx_net *dev,
596 				   struct sk_buff *tx_buf)
597 {
598 	lan78xx_release_buf(&dev->txq_free, tx_buf);
599 }
600 
lan78xx_free_tx_resources(struct lan78xx_net * dev)601 static void lan78xx_free_tx_resources(struct lan78xx_net *dev)
602 {
603 	lan78xx_free_buf_pool(&dev->txq_free);
604 }
605 
lan78xx_alloc_tx_resources(struct lan78xx_net * dev)606 static int lan78xx_alloc_tx_resources(struct lan78xx_net *dev)
607 {
608 	return lan78xx_alloc_buf_pool(&dev->txq_free,
609 				      dev->n_tx_urbs, dev->tx_urb_size, dev);
610 }
611 
lan78xx_read_reg(struct lan78xx_net * dev,u32 index,u32 * data)612 static int lan78xx_read_reg(struct lan78xx_net *dev, u32 index, u32 *data)
613 {
614 	u32 *buf;
615 	int ret;
616 
617 	if (test_bit(EVENT_DEV_DISCONNECT, &dev->flags))
618 		return -ENODEV;
619 
620 	buf = kmalloc(sizeof(u32), GFP_KERNEL);
621 	if (!buf)
622 		return -ENOMEM;
623 
624 	ret = usb_control_msg(dev->udev, usb_rcvctrlpipe(dev->udev, 0),
625 			      USB_VENDOR_REQUEST_READ_REGISTER,
626 			      USB_DIR_IN | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
627 			      0, index, buf, 4, USB_CTRL_GET_TIMEOUT);
628 	if (likely(ret >= 0)) {
629 		le32_to_cpus(buf);
630 		*data = *buf;
631 	} else if (net_ratelimit()) {
632 		netdev_warn(dev->net,
633 			    "Failed to read register index 0x%08x. ret = %d",
634 			    index, ret);
635 	}
636 
637 	kfree(buf);
638 
639 	return ret;
640 }
641 
lan78xx_write_reg(struct lan78xx_net * dev,u32 index,u32 data)642 static int lan78xx_write_reg(struct lan78xx_net *dev, u32 index, u32 data)
643 {
644 	u32 *buf;
645 	int ret;
646 
647 	if (test_bit(EVENT_DEV_DISCONNECT, &dev->flags))
648 		return -ENODEV;
649 
650 	buf = kmalloc(sizeof(u32), GFP_KERNEL);
651 	if (!buf)
652 		return -ENOMEM;
653 
654 	*buf = data;
655 	cpu_to_le32s(buf);
656 
657 	ret = usb_control_msg(dev->udev, usb_sndctrlpipe(dev->udev, 0),
658 			      USB_VENDOR_REQUEST_WRITE_REGISTER,
659 			      USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
660 			      0, index, buf, 4, USB_CTRL_SET_TIMEOUT);
661 	if (unlikely(ret < 0) &&
662 	    net_ratelimit()) {
663 		netdev_warn(dev->net,
664 			    "Failed to write register index 0x%08x. ret = %d",
665 			    index, ret);
666 	}
667 
668 	kfree(buf);
669 
670 	return ret;
671 }
672 
lan78xx_update_reg(struct lan78xx_net * dev,u32 reg,u32 mask,u32 data)673 static int lan78xx_update_reg(struct lan78xx_net *dev, u32 reg, u32 mask,
674 			      u32 data)
675 {
676 	int ret;
677 	u32 buf;
678 
679 	ret = lan78xx_read_reg(dev, reg, &buf);
680 	if (ret < 0)
681 		return ret;
682 
683 	buf &= ~mask;
684 	buf |= (mask & data);
685 
686 	ret = lan78xx_write_reg(dev, reg, buf);
687 	if (ret < 0)
688 		return ret;
689 
690 	return 0;
691 }
692 
lan78xx_read_stats(struct lan78xx_net * dev,struct lan78xx_statstage * data)693 static int lan78xx_read_stats(struct lan78xx_net *dev,
694 			      struct lan78xx_statstage *data)
695 {
696 	int ret = 0;
697 	int i;
698 	struct lan78xx_statstage *stats;
699 	u32 *src;
700 	u32 *dst;
701 
702 	stats = kmalloc(sizeof(*stats), GFP_KERNEL);
703 	if (!stats)
704 		return -ENOMEM;
705 
706 	ret = usb_control_msg(dev->udev,
707 			      usb_rcvctrlpipe(dev->udev, 0),
708 			      USB_VENDOR_REQUEST_GET_STATS,
709 			      USB_DIR_IN | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
710 			      0,
711 			      0,
712 			      (void *)stats,
713 			      sizeof(*stats),
714 			      USB_CTRL_SET_TIMEOUT);
715 	if (likely(ret >= 0)) {
716 		src = (u32 *)stats;
717 		dst = (u32 *)data;
718 		for (i = 0; i < sizeof(*stats) / sizeof(u32); i++) {
719 			le32_to_cpus(&src[i]);
720 			dst[i] = src[i];
721 		}
722 	} else {
723 		netdev_warn(dev->net,
724 			    "Failed to read stat ret = %d", ret);
725 	}
726 
727 	kfree(stats);
728 
729 	return ret;
730 }
731 
732 #define check_counter_rollover(struct1, dev_stats, member)		\
733 	do {								\
734 		if ((struct1)->member < (dev_stats).saved.member)	\
735 			(dev_stats).rollover_count.member++;		\
736 	} while (0)
737 
lan78xx_check_stat_rollover(struct lan78xx_net * dev,struct lan78xx_statstage * stats)738 static void lan78xx_check_stat_rollover(struct lan78xx_net *dev,
739 					struct lan78xx_statstage *stats)
740 {
741 	check_counter_rollover(stats, dev->stats, rx_fcs_errors);
742 	check_counter_rollover(stats, dev->stats, rx_alignment_errors);
743 	check_counter_rollover(stats, dev->stats, rx_fragment_errors);
744 	check_counter_rollover(stats, dev->stats, rx_jabber_errors);
745 	check_counter_rollover(stats, dev->stats, rx_undersize_frame_errors);
746 	check_counter_rollover(stats, dev->stats, rx_oversize_frame_errors);
747 	check_counter_rollover(stats, dev->stats, rx_dropped_frames);
748 	check_counter_rollover(stats, dev->stats, rx_unicast_byte_count);
749 	check_counter_rollover(stats, dev->stats, rx_broadcast_byte_count);
750 	check_counter_rollover(stats, dev->stats, rx_multicast_byte_count);
751 	check_counter_rollover(stats, dev->stats, rx_unicast_frames);
752 	check_counter_rollover(stats, dev->stats, rx_broadcast_frames);
753 	check_counter_rollover(stats, dev->stats, rx_multicast_frames);
754 	check_counter_rollover(stats, dev->stats, rx_pause_frames);
755 	check_counter_rollover(stats, dev->stats, rx_64_byte_frames);
756 	check_counter_rollover(stats, dev->stats, rx_65_127_byte_frames);
757 	check_counter_rollover(stats, dev->stats, rx_128_255_byte_frames);
758 	check_counter_rollover(stats, dev->stats, rx_256_511_bytes_frames);
759 	check_counter_rollover(stats, dev->stats, rx_512_1023_byte_frames);
760 	check_counter_rollover(stats, dev->stats, rx_1024_1518_byte_frames);
761 	check_counter_rollover(stats, dev->stats, rx_greater_1518_byte_frames);
762 	check_counter_rollover(stats, dev->stats, eee_rx_lpi_transitions);
763 	check_counter_rollover(stats, dev->stats, eee_rx_lpi_time);
764 	check_counter_rollover(stats, dev->stats, tx_fcs_errors);
765 	check_counter_rollover(stats, dev->stats, tx_excess_deferral_errors);
766 	check_counter_rollover(stats, dev->stats, tx_carrier_errors);
767 	check_counter_rollover(stats, dev->stats, tx_bad_byte_count);
768 	check_counter_rollover(stats, dev->stats, tx_single_collisions);
769 	check_counter_rollover(stats, dev->stats, tx_multiple_collisions);
770 	check_counter_rollover(stats, dev->stats, tx_excessive_collision);
771 	check_counter_rollover(stats, dev->stats, tx_late_collisions);
772 	check_counter_rollover(stats, dev->stats, tx_unicast_byte_count);
773 	check_counter_rollover(stats, dev->stats, tx_broadcast_byte_count);
774 	check_counter_rollover(stats, dev->stats, tx_multicast_byte_count);
775 	check_counter_rollover(stats, dev->stats, tx_unicast_frames);
776 	check_counter_rollover(stats, dev->stats, tx_broadcast_frames);
777 	check_counter_rollover(stats, dev->stats, tx_multicast_frames);
778 	check_counter_rollover(stats, dev->stats, tx_pause_frames);
779 	check_counter_rollover(stats, dev->stats, tx_64_byte_frames);
780 	check_counter_rollover(stats, dev->stats, tx_65_127_byte_frames);
781 	check_counter_rollover(stats, dev->stats, tx_128_255_byte_frames);
782 	check_counter_rollover(stats, dev->stats, tx_256_511_bytes_frames);
783 	check_counter_rollover(stats, dev->stats, tx_512_1023_byte_frames);
784 	check_counter_rollover(stats, dev->stats, tx_1024_1518_byte_frames);
785 	check_counter_rollover(stats, dev->stats, tx_greater_1518_byte_frames);
786 	check_counter_rollover(stats, dev->stats, eee_tx_lpi_transitions);
787 	check_counter_rollover(stats, dev->stats, eee_tx_lpi_time);
788 
789 	memcpy(&dev->stats.saved, stats, sizeof(struct lan78xx_statstage));
790 }
791 
lan78xx_update_stats(struct lan78xx_net * dev)792 static void lan78xx_update_stats(struct lan78xx_net *dev)
793 {
794 	u32 *p, *count, *max;
795 	u64 *data;
796 	int i;
797 	struct lan78xx_statstage lan78xx_stats;
798 
799 	if (usb_autopm_get_interface(dev->intf) < 0)
800 		return;
801 
802 	p = (u32 *)&lan78xx_stats;
803 	count = (u32 *)&dev->stats.rollover_count;
804 	max = (u32 *)&dev->stats.rollover_max;
805 	data = (u64 *)&dev->stats.curr_stat;
806 
807 	mutex_lock(&dev->stats.access_lock);
808 
809 	if (lan78xx_read_stats(dev, &lan78xx_stats) > 0)
810 		lan78xx_check_stat_rollover(dev, &lan78xx_stats);
811 
812 	for (i = 0; i < (sizeof(lan78xx_stats) / (sizeof(u32))); i++)
813 		data[i] = (u64)p[i] + ((u64)count[i] * ((u64)max[i] + 1));
814 
815 	mutex_unlock(&dev->stats.access_lock);
816 
817 	usb_autopm_put_interface(dev->intf);
818 }
819 
820 /* Loop until the read is completed with timeout called with phy_mutex held */
lan78xx_phy_wait_not_busy(struct lan78xx_net * dev)821 static int lan78xx_phy_wait_not_busy(struct lan78xx_net *dev)
822 {
823 	unsigned long start_time = jiffies;
824 	u32 val;
825 	int ret;
826 
827 	do {
828 		ret = lan78xx_read_reg(dev, MII_ACC, &val);
829 		if (unlikely(ret < 0))
830 			return -EIO;
831 
832 		if (!(val & MII_ACC_MII_BUSY_))
833 			return 0;
834 	} while (!time_after(jiffies, start_time + HZ));
835 
836 	return -EIO;
837 }
838 
mii_access(int id,int index,int read)839 static inline u32 mii_access(int id, int index, int read)
840 {
841 	u32 ret;
842 
843 	ret = ((u32)id << MII_ACC_PHY_ADDR_SHIFT_) & MII_ACC_PHY_ADDR_MASK_;
844 	ret |= ((u32)index << MII_ACC_MIIRINDA_SHIFT_) & MII_ACC_MIIRINDA_MASK_;
845 	if (read)
846 		ret |= MII_ACC_MII_READ_;
847 	else
848 		ret |= MII_ACC_MII_WRITE_;
849 	ret |= MII_ACC_MII_BUSY_;
850 
851 	return ret;
852 }
853 
lan78xx_wait_eeprom(struct lan78xx_net * dev)854 static int lan78xx_wait_eeprom(struct lan78xx_net *dev)
855 {
856 	unsigned long start_time = jiffies;
857 	u32 val;
858 	int ret;
859 
860 	do {
861 		ret = lan78xx_read_reg(dev, E2P_CMD, &val);
862 		if (unlikely(ret < 0))
863 			return -EIO;
864 
865 		if (!(val & E2P_CMD_EPC_BUSY_) ||
866 		    (val & E2P_CMD_EPC_TIMEOUT_))
867 			break;
868 		usleep_range(40, 100);
869 	} while (!time_after(jiffies, start_time + HZ));
870 
871 	if (val & (E2P_CMD_EPC_TIMEOUT_ | E2P_CMD_EPC_BUSY_)) {
872 		netdev_warn(dev->net, "EEPROM read operation timeout");
873 		return -EIO;
874 	}
875 
876 	return 0;
877 }
878 
lan78xx_eeprom_confirm_not_busy(struct lan78xx_net * dev)879 static int lan78xx_eeprom_confirm_not_busy(struct lan78xx_net *dev)
880 {
881 	unsigned long start_time = jiffies;
882 	u32 val;
883 	int ret;
884 
885 	do {
886 		ret = lan78xx_read_reg(dev, E2P_CMD, &val);
887 		if (unlikely(ret < 0))
888 			return -EIO;
889 
890 		if (!(val & E2P_CMD_EPC_BUSY_))
891 			return 0;
892 
893 		usleep_range(40, 100);
894 	} while (!time_after(jiffies, start_time + HZ));
895 
896 	netdev_warn(dev->net, "EEPROM is busy");
897 	return -EIO;
898 }
899 
lan78xx_read_raw_eeprom(struct lan78xx_net * dev,u32 offset,u32 length,u8 * data)900 static int lan78xx_read_raw_eeprom(struct lan78xx_net *dev, u32 offset,
901 				   u32 length, u8 *data)
902 {
903 	u32 val;
904 	u32 saved;
905 	int i, ret;
906 	int retval;
907 
908 	/* depends on chip, some EEPROM pins are muxed with LED function.
909 	 * disable & restore LED function to access EEPROM.
910 	 */
911 	ret = lan78xx_read_reg(dev, HW_CFG, &val);
912 	saved = val;
913 	if (dev->chipid == ID_REV_CHIP_ID_7800_) {
914 		val &= ~(HW_CFG_LED1_EN_ | HW_CFG_LED0_EN_);
915 		ret = lan78xx_write_reg(dev, HW_CFG, val);
916 	}
917 
918 	retval = lan78xx_eeprom_confirm_not_busy(dev);
919 	if (retval)
920 		return retval;
921 
922 	for (i = 0; i < length; i++) {
923 		val = E2P_CMD_EPC_BUSY_ | E2P_CMD_EPC_CMD_READ_;
924 		val |= (offset & E2P_CMD_EPC_ADDR_MASK_);
925 		ret = lan78xx_write_reg(dev, E2P_CMD, val);
926 		if (unlikely(ret < 0)) {
927 			retval = -EIO;
928 			goto exit;
929 		}
930 
931 		retval = lan78xx_wait_eeprom(dev);
932 		if (retval < 0)
933 			goto exit;
934 
935 		ret = lan78xx_read_reg(dev, E2P_DATA, &val);
936 		if (unlikely(ret < 0)) {
937 			retval = -EIO;
938 			goto exit;
939 		}
940 
941 		data[i] = val & 0xFF;
942 		offset++;
943 	}
944 
945 	retval = 0;
946 exit:
947 	if (dev->chipid == ID_REV_CHIP_ID_7800_)
948 		ret = lan78xx_write_reg(dev, HW_CFG, saved);
949 
950 	return retval;
951 }
952 
lan78xx_read_eeprom(struct lan78xx_net * dev,u32 offset,u32 length,u8 * data)953 static int lan78xx_read_eeprom(struct lan78xx_net *dev, u32 offset,
954 			       u32 length, u8 *data)
955 {
956 	u8 sig;
957 	int ret;
958 
959 	ret = lan78xx_read_raw_eeprom(dev, 0, 1, &sig);
960 	if ((ret == 0) && (sig == EEPROM_INDICATOR))
961 		ret = lan78xx_read_raw_eeprom(dev, offset, length, data);
962 	else
963 		ret = -EINVAL;
964 
965 	return ret;
966 }
967 
lan78xx_write_raw_eeprom(struct lan78xx_net * dev,u32 offset,u32 length,u8 * data)968 static int lan78xx_write_raw_eeprom(struct lan78xx_net *dev, u32 offset,
969 				    u32 length, u8 *data)
970 {
971 	u32 val;
972 	u32 saved;
973 	int i, ret;
974 	int retval;
975 
976 	/* depends on chip, some EEPROM pins are muxed with LED function.
977 	 * disable & restore LED function to access EEPROM.
978 	 */
979 	ret = lan78xx_read_reg(dev, HW_CFG, &val);
980 	saved = val;
981 	if (dev->chipid == ID_REV_CHIP_ID_7800_) {
982 		val &= ~(HW_CFG_LED1_EN_ | HW_CFG_LED0_EN_);
983 		ret = lan78xx_write_reg(dev, HW_CFG, val);
984 	}
985 
986 	retval = lan78xx_eeprom_confirm_not_busy(dev);
987 	if (retval)
988 		goto exit;
989 
990 	/* Issue write/erase enable command */
991 	val = E2P_CMD_EPC_BUSY_ | E2P_CMD_EPC_CMD_EWEN_;
992 	ret = lan78xx_write_reg(dev, E2P_CMD, val);
993 	if (unlikely(ret < 0)) {
994 		retval = -EIO;
995 		goto exit;
996 	}
997 
998 	retval = lan78xx_wait_eeprom(dev);
999 	if (retval < 0)
1000 		goto exit;
1001 
1002 	for (i = 0; i < length; i++) {
1003 		/* Fill data register */
1004 		val = data[i];
1005 		ret = lan78xx_write_reg(dev, E2P_DATA, val);
1006 		if (ret < 0) {
1007 			retval = -EIO;
1008 			goto exit;
1009 		}
1010 
1011 		/* Send "write" command */
1012 		val = E2P_CMD_EPC_BUSY_ | E2P_CMD_EPC_CMD_WRITE_;
1013 		val |= (offset & E2P_CMD_EPC_ADDR_MASK_);
1014 		ret = lan78xx_write_reg(dev, E2P_CMD, val);
1015 		if (ret < 0) {
1016 			retval = -EIO;
1017 			goto exit;
1018 		}
1019 
1020 		retval = lan78xx_wait_eeprom(dev);
1021 		if (retval < 0)
1022 			goto exit;
1023 
1024 		offset++;
1025 	}
1026 
1027 	retval = 0;
1028 exit:
1029 	if (dev->chipid == ID_REV_CHIP_ID_7800_)
1030 		ret = lan78xx_write_reg(dev, HW_CFG, saved);
1031 
1032 	return retval;
1033 }
1034 
lan78xx_read_raw_otp(struct lan78xx_net * dev,u32 offset,u32 length,u8 * data)1035 static int lan78xx_read_raw_otp(struct lan78xx_net *dev, u32 offset,
1036 				u32 length, u8 *data)
1037 {
1038 	int i;
1039 	u32 buf;
1040 	unsigned long timeout;
1041 
1042 	lan78xx_read_reg(dev, OTP_PWR_DN, &buf);
1043 
1044 	if (buf & OTP_PWR_DN_PWRDN_N_) {
1045 		/* clear it and wait to be cleared */
1046 		lan78xx_write_reg(dev, OTP_PWR_DN, 0);
1047 
1048 		timeout = jiffies + HZ;
1049 		do {
1050 			usleep_range(1, 10);
1051 			lan78xx_read_reg(dev, OTP_PWR_DN, &buf);
1052 			if (time_after(jiffies, timeout)) {
1053 				netdev_warn(dev->net,
1054 					    "timeout on OTP_PWR_DN");
1055 				return -EIO;
1056 			}
1057 		} while (buf & OTP_PWR_DN_PWRDN_N_);
1058 	}
1059 
1060 	for (i = 0; i < length; i++) {
1061 		lan78xx_write_reg(dev, OTP_ADDR1,
1062 				  ((offset + i) >> 8) & OTP_ADDR1_15_11);
1063 		lan78xx_write_reg(dev, OTP_ADDR2,
1064 				  ((offset + i) & OTP_ADDR2_10_3));
1065 
1066 		lan78xx_write_reg(dev, OTP_FUNC_CMD, OTP_FUNC_CMD_READ_);
1067 		lan78xx_write_reg(dev, OTP_CMD_GO, OTP_CMD_GO_GO_);
1068 
1069 		timeout = jiffies + HZ;
1070 		do {
1071 			udelay(1);
1072 			lan78xx_read_reg(dev, OTP_STATUS, &buf);
1073 			if (time_after(jiffies, timeout)) {
1074 				netdev_warn(dev->net,
1075 					    "timeout on OTP_STATUS");
1076 				return -EIO;
1077 			}
1078 		} while (buf & OTP_STATUS_BUSY_);
1079 
1080 		lan78xx_read_reg(dev, OTP_RD_DATA, &buf);
1081 
1082 		data[i] = (u8)(buf & 0xFF);
1083 	}
1084 
1085 	return 0;
1086 }
1087 
lan78xx_write_raw_otp(struct lan78xx_net * dev,u32 offset,u32 length,u8 * data)1088 static int lan78xx_write_raw_otp(struct lan78xx_net *dev, u32 offset,
1089 				 u32 length, u8 *data)
1090 {
1091 	int i;
1092 	u32 buf;
1093 	unsigned long timeout;
1094 
1095 	lan78xx_read_reg(dev, OTP_PWR_DN, &buf);
1096 
1097 	if (buf & OTP_PWR_DN_PWRDN_N_) {
1098 		/* clear it and wait to be cleared */
1099 		lan78xx_write_reg(dev, OTP_PWR_DN, 0);
1100 
1101 		timeout = jiffies + HZ;
1102 		do {
1103 			udelay(1);
1104 			lan78xx_read_reg(dev, OTP_PWR_DN, &buf);
1105 			if (time_after(jiffies, timeout)) {
1106 				netdev_warn(dev->net,
1107 					    "timeout on OTP_PWR_DN completion");
1108 				return -EIO;
1109 			}
1110 		} while (buf & OTP_PWR_DN_PWRDN_N_);
1111 	}
1112 
1113 	/* set to BYTE program mode */
1114 	lan78xx_write_reg(dev, OTP_PRGM_MODE, OTP_PRGM_MODE_BYTE_);
1115 
1116 	for (i = 0; i < length; i++) {
1117 		lan78xx_write_reg(dev, OTP_ADDR1,
1118 				  ((offset + i) >> 8) & OTP_ADDR1_15_11);
1119 		lan78xx_write_reg(dev, OTP_ADDR2,
1120 				  ((offset + i) & OTP_ADDR2_10_3));
1121 		lan78xx_write_reg(dev, OTP_PRGM_DATA, data[i]);
1122 		lan78xx_write_reg(dev, OTP_TST_CMD, OTP_TST_CMD_PRGVRFY_);
1123 		lan78xx_write_reg(dev, OTP_CMD_GO, OTP_CMD_GO_GO_);
1124 
1125 		timeout = jiffies + HZ;
1126 		do {
1127 			udelay(1);
1128 			lan78xx_read_reg(dev, OTP_STATUS, &buf);
1129 			if (time_after(jiffies, timeout)) {
1130 				netdev_warn(dev->net,
1131 					    "Timeout on OTP_STATUS completion");
1132 				return -EIO;
1133 			}
1134 		} while (buf & OTP_STATUS_BUSY_);
1135 	}
1136 
1137 	return 0;
1138 }
1139 
lan78xx_read_otp(struct lan78xx_net * dev,u32 offset,u32 length,u8 * data)1140 static int lan78xx_read_otp(struct lan78xx_net *dev, u32 offset,
1141 			    u32 length, u8 *data)
1142 {
1143 	u8 sig;
1144 	int ret;
1145 
1146 	ret = lan78xx_read_raw_otp(dev, 0, 1, &sig);
1147 
1148 	if (ret == 0) {
1149 		if (sig == OTP_INDICATOR_2)
1150 			offset += 0x100;
1151 		else if (sig != OTP_INDICATOR_1)
1152 			ret = -EINVAL;
1153 		if (!ret)
1154 			ret = lan78xx_read_raw_otp(dev, offset, length, data);
1155 	}
1156 
1157 	return ret;
1158 }
1159 
lan78xx_dataport_wait_not_busy(struct lan78xx_net * dev)1160 static int lan78xx_dataport_wait_not_busy(struct lan78xx_net *dev)
1161 {
1162 	int i, ret;
1163 
1164 	for (i = 0; i < 100; i++) {
1165 		u32 dp_sel;
1166 
1167 		ret = lan78xx_read_reg(dev, DP_SEL, &dp_sel);
1168 		if (unlikely(ret < 0))
1169 			return -EIO;
1170 
1171 		if (dp_sel & DP_SEL_DPRDY_)
1172 			return 0;
1173 
1174 		usleep_range(40, 100);
1175 	}
1176 
1177 	netdev_warn(dev->net, "%s timed out", __func__);
1178 
1179 	return -EIO;
1180 }
1181 
lan78xx_dataport_write(struct lan78xx_net * dev,u32 ram_select,u32 addr,u32 length,u32 * buf)1182 static int lan78xx_dataport_write(struct lan78xx_net *dev, u32 ram_select,
1183 				  u32 addr, u32 length, u32 *buf)
1184 {
1185 	struct lan78xx_priv *pdata = (struct lan78xx_priv *)(dev->data[0]);
1186 	u32 dp_sel;
1187 	int i, ret;
1188 
1189 	if (usb_autopm_get_interface(dev->intf) < 0)
1190 		return 0;
1191 
1192 	mutex_lock(&pdata->dataport_mutex);
1193 
1194 	ret = lan78xx_dataport_wait_not_busy(dev);
1195 	if (ret < 0)
1196 		goto done;
1197 
1198 	ret = lan78xx_read_reg(dev, DP_SEL, &dp_sel);
1199 
1200 	dp_sel &= ~DP_SEL_RSEL_MASK_;
1201 	dp_sel |= ram_select;
1202 	ret = lan78xx_write_reg(dev, DP_SEL, dp_sel);
1203 
1204 	for (i = 0; i < length; i++) {
1205 		ret = lan78xx_write_reg(dev, DP_ADDR, addr + i);
1206 
1207 		ret = lan78xx_write_reg(dev, DP_DATA, buf[i]);
1208 
1209 		ret = lan78xx_write_reg(dev, DP_CMD, DP_CMD_WRITE_);
1210 
1211 		ret = lan78xx_dataport_wait_not_busy(dev);
1212 		if (ret < 0)
1213 			goto done;
1214 	}
1215 
1216 done:
1217 	mutex_unlock(&pdata->dataport_mutex);
1218 	usb_autopm_put_interface(dev->intf);
1219 
1220 	return ret;
1221 }
1222 
lan78xx_set_addr_filter(struct lan78xx_priv * pdata,int index,u8 addr[ETH_ALEN])1223 static void lan78xx_set_addr_filter(struct lan78xx_priv *pdata,
1224 				    int index, u8 addr[ETH_ALEN])
1225 {
1226 	u32 temp;
1227 
1228 	if ((pdata) && (index > 0) && (index < NUM_OF_MAF)) {
1229 		temp = addr[3];
1230 		temp = addr[2] | (temp << 8);
1231 		temp = addr[1] | (temp << 8);
1232 		temp = addr[0] | (temp << 8);
1233 		pdata->pfilter_table[index][1] = temp;
1234 		temp = addr[5];
1235 		temp = addr[4] | (temp << 8);
1236 		temp |= MAF_HI_VALID_ | MAF_HI_TYPE_DST_;
1237 		pdata->pfilter_table[index][0] = temp;
1238 	}
1239 }
1240 
1241 /* returns hash bit number for given MAC address */
lan78xx_hash(char addr[ETH_ALEN])1242 static inline u32 lan78xx_hash(char addr[ETH_ALEN])
1243 {
1244 	return (ether_crc(ETH_ALEN, addr) >> 23) & 0x1ff;
1245 }
1246 
lan78xx_deferred_multicast_write(struct work_struct * param)1247 static void lan78xx_deferred_multicast_write(struct work_struct *param)
1248 {
1249 	struct lan78xx_priv *pdata =
1250 			container_of(param, struct lan78xx_priv, set_multicast);
1251 	struct lan78xx_net *dev = pdata->dev;
1252 	int i;
1253 
1254 	netif_dbg(dev, drv, dev->net, "deferred multicast write 0x%08x\n",
1255 		  pdata->rfe_ctl);
1256 
1257 	lan78xx_dataport_write(dev, DP_SEL_RSEL_VLAN_DA_, DP_SEL_VHF_VLAN_LEN,
1258 			       DP_SEL_VHF_HASH_LEN, pdata->mchash_table);
1259 
1260 	for (i = 1; i < NUM_OF_MAF; i++) {
1261 		lan78xx_write_reg(dev, MAF_HI(i), 0);
1262 		lan78xx_write_reg(dev, MAF_LO(i),
1263 				  pdata->pfilter_table[i][1]);
1264 		lan78xx_write_reg(dev, MAF_HI(i),
1265 				  pdata->pfilter_table[i][0]);
1266 	}
1267 
1268 	lan78xx_write_reg(dev, RFE_CTL, pdata->rfe_ctl);
1269 }
1270 
lan78xx_set_multicast(struct net_device * netdev)1271 static void lan78xx_set_multicast(struct net_device *netdev)
1272 {
1273 	struct lan78xx_net *dev = netdev_priv(netdev);
1274 	struct lan78xx_priv *pdata = (struct lan78xx_priv *)(dev->data[0]);
1275 	unsigned long flags;
1276 	int i;
1277 
1278 	spin_lock_irqsave(&pdata->rfe_ctl_lock, flags);
1279 
1280 	pdata->rfe_ctl &= ~(RFE_CTL_UCAST_EN_ | RFE_CTL_MCAST_EN_ |
1281 			    RFE_CTL_DA_PERFECT_ | RFE_CTL_MCAST_HASH_);
1282 
1283 	for (i = 0; i < DP_SEL_VHF_HASH_LEN; i++)
1284 		pdata->mchash_table[i] = 0;
1285 
1286 	/* pfilter_table[0] has own HW address */
1287 	for (i = 1; i < NUM_OF_MAF; i++) {
1288 		pdata->pfilter_table[i][0] = 0;
1289 		pdata->pfilter_table[i][1] = 0;
1290 	}
1291 
1292 	pdata->rfe_ctl |= RFE_CTL_BCAST_EN_;
1293 
1294 	if (dev->net->flags & IFF_PROMISC) {
1295 		netif_dbg(dev, drv, dev->net, "promiscuous mode enabled");
1296 		pdata->rfe_ctl |= RFE_CTL_MCAST_EN_ | RFE_CTL_UCAST_EN_;
1297 	} else {
1298 		if (dev->net->flags & IFF_ALLMULTI) {
1299 			netif_dbg(dev, drv, dev->net,
1300 				  "receive all multicast enabled");
1301 			pdata->rfe_ctl |= RFE_CTL_MCAST_EN_;
1302 		}
1303 	}
1304 
1305 	if (netdev_mc_count(dev->net)) {
1306 		struct netdev_hw_addr *ha;
1307 		int i;
1308 
1309 		netif_dbg(dev, drv, dev->net, "receive multicast hash filter");
1310 
1311 		pdata->rfe_ctl |= RFE_CTL_DA_PERFECT_;
1312 
1313 		i = 1;
1314 		netdev_for_each_mc_addr(ha, netdev) {
1315 			/* set first 32 into Perfect Filter */
1316 			if (i < 33) {
1317 				lan78xx_set_addr_filter(pdata, i, ha->addr);
1318 			} else {
1319 				u32 bitnum = lan78xx_hash(ha->addr);
1320 
1321 				pdata->mchash_table[bitnum / 32] |=
1322 							(1 << (bitnum % 32));
1323 				pdata->rfe_ctl |= RFE_CTL_MCAST_HASH_;
1324 			}
1325 			i++;
1326 		}
1327 	}
1328 
1329 	spin_unlock_irqrestore(&pdata->rfe_ctl_lock, flags);
1330 
1331 	/* defer register writes to a sleepable context */
1332 	schedule_work(&pdata->set_multicast);
1333 }
1334 
lan78xx_update_flowcontrol(struct lan78xx_net * dev,u8 duplex,u16 lcladv,u16 rmtadv)1335 static int lan78xx_update_flowcontrol(struct lan78xx_net *dev, u8 duplex,
1336 				      u16 lcladv, u16 rmtadv)
1337 {
1338 	u32 flow = 0, fct_flow = 0;
1339 	u8 cap;
1340 
1341 	if (dev->fc_autoneg)
1342 		cap = mii_resolve_flowctrl_fdx(lcladv, rmtadv);
1343 	else
1344 		cap = dev->fc_request_control;
1345 
1346 	if (cap & FLOW_CTRL_TX)
1347 		flow |= (FLOW_CR_TX_FCEN_ | 0xFFFF);
1348 
1349 	if (cap & FLOW_CTRL_RX)
1350 		flow |= FLOW_CR_RX_FCEN_;
1351 
1352 	if (dev->udev->speed == USB_SPEED_SUPER)
1353 		fct_flow = FLOW_CTRL_THRESHOLD(FLOW_ON_SS, FLOW_OFF_SS);
1354 	else if (dev->udev->speed == USB_SPEED_HIGH)
1355 		fct_flow = FLOW_CTRL_THRESHOLD(FLOW_ON_HS, FLOW_OFF_HS);
1356 
1357 	netif_dbg(dev, link, dev->net, "rx pause %s, tx pause %s",
1358 		  (cap & FLOW_CTRL_RX ? "enabled" : "disabled"),
1359 		  (cap & FLOW_CTRL_TX ? "enabled" : "disabled"));
1360 
1361 	lan78xx_write_reg(dev, FCT_FLOW, fct_flow);
1362 
1363 	/* threshold value should be set before enabling flow */
1364 	lan78xx_write_reg(dev, FLOW, flow);
1365 
1366 	return 0;
1367 }
1368 
1369 static void lan78xx_rx_urb_submit_all(struct lan78xx_net *dev);
1370 
lan78xx_mac_reset(struct lan78xx_net * dev)1371 static int lan78xx_mac_reset(struct lan78xx_net *dev)
1372 {
1373 	unsigned long start_time = jiffies;
1374 	u32 val;
1375 	int ret;
1376 
1377 	mutex_lock(&dev->phy_mutex);
1378 
1379 	/* Resetting the device while there is activity on the MDIO
1380 	 * bus can result in the MAC interface locking up and not
1381 	 * completing register access transactions.
1382 	 */
1383 	ret = lan78xx_phy_wait_not_busy(dev);
1384 	if (ret < 0)
1385 		goto done;
1386 
1387 	ret = lan78xx_read_reg(dev, MAC_CR, &val);
1388 	if (ret < 0)
1389 		goto done;
1390 
1391 	val |= MAC_CR_RST_;
1392 	ret = lan78xx_write_reg(dev, MAC_CR, val);
1393 	if (ret < 0)
1394 		goto done;
1395 
1396 	/* Wait for the reset to complete before allowing any further
1397 	 * MAC register accesses otherwise the MAC may lock up.
1398 	 */
1399 	do {
1400 		ret = lan78xx_read_reg(dev, MAC_CR, &val);
1401 		if (ret < 0)
1402 			goto done;
1403 
1404 		if (!(val & MAC_CR_RST_)) {
1405 			ret = 0;
1406 			goto done;
1407 		}
1408 	} while (!time_after(jiffies, start_time + HZ));
1409 
1410 	ret = -ETIMEDOUT;
1411 done:
1412 	mutex_unlock(&dev->phy_mutex);
1413 
1414 	return ret;
1415 }
1416 
lan78xx_link_reset(struct lan78xx_net * dev)1417 static int lan78xx_link_reset(struct lan78xx_net *dev)
1418 {
1419 	struct phy_device *phydev = dev->net->phydev;
1420 	struct ethtool_link_ksettings ecmd;
1421 	int ladv, radv, ret, link;
1422 	u32 buf;
1423 
1424 	/* clear LAN78xx interrupt status */
1425 	ret = lan78xx_write_reg(dev, INT_STS, INT_STS_PHY_INT_);
1426 	if (unlikely(ret < 0))
1427 		return ret;
1428 
1429 	mutex_lock(&phydev->lock);
1430 	phy_read_status(phydev);
1431 	link = phydev->link;
1432 	mutex_unlock(&phydev->lock);
1433 
1434 	if (!link && dev->link_on) {
1435 		dev->link_on = false;
1436 
1437 		/* reset MAC */
1438 		ret = lan78xx_mac_reset(dev);
1439 		if (ret < 0)
1440 			return ret;
1441 
1442 		del_timer(&dev->stat_monitor);
1443 	} else if (link && !dev->link_on) {
1444 		dev->link_on = true;
1445 
1446 		phy_ethtool_ksettings_get(phydev, &ecmd);
1447 
1448 		if (dev->udev->speed == USB_SPEED_SUPER) {
1449 			if (ecmd.base.speed == 1000) {
1450 				/* disable U2 */
1451 				ret = lan78xx_read_reg(dev, USB_CFG1, &buf);
1452 				if (ret < 0)
1453 					return ret;
1454 				buf &= ~USB_CFG1_DEV_U2_INIT_EN_;
1455 				ret = lan78xx_write_reg(dev, USB_CFG1, buf);
1456 				if (ret < 0)
1457 					return ret;
1458 				/* enable U1 */
1459 				ret = lan78xx_read_reg(dev, USB_CFG1, &buf);
1460 				if (ret < 0)
1461 					return ret;
1462 				buf |= USB_CFG1_DEV_U1_INIT_EN_;
1463 				ret = lan78xx_write_reg(dev, USB_CFG1, buf);
1464 				if (ret < 0)
1465 					return ret;
1466 			} else {
1467 				/* enable U1 & U2 */
1468 				ret = lan78xx_read_reg(dev, USB_CFG1, &buf);
1469 				if (ret < 0)
1470 					return ret;
1471 				buf |= USB_CFG1_DEV_U2_INIT_EN_;
1472 				buf |= USB_CFG1_DEV_U1_INIT_EN_;
1473 				ret = lan78xx_write_reg(dev, USB_CFG1, buf);
1474 				if (ret < 0)
1475 					return ret;
1476 			}
1477 		}
1478 
1479 		ladv = phy_read(phydev, MII_ADVERTISE);
1480 		if (ladv < 0)
1481 			return ladv;
1482 
1483 		radv = phy_read(phydev, MII_LPA);
1484 		if (radv < 0)
1485 			return radv;
1486 
1487 		netif_dbg(dev, link, dev->net,
1488 			  "speed: %u duplex: %d anadv: 0x%04x anlpa: 0x%04x",
1489 			  ecmd.base.speed, ecmd.base.duplex, ladv, radv);
1490 
1491 		ret = lan78xx_update_flowcontrol(dev, ecmd.base.duplex, ladv,
1492 						 radv);
1493 		if (ret < 0)
1494 			return ret;
1495 
1496 		if (!timer_pending(&dev->stat_monitor)) {
1497 			dev->delta = 1;
1498 			mod_timer(&dev->stat_monitor,
1499 				  jiffies + STAT_UPDATE_TIMER);
1500 		}
1501 
1502 		lan78xx_rx_urb_submit_all(dev);
1503 
1504 		local_bh_disable();
1505 		napi_schedule(&dev->napi);
1506 		local_bh_enable();
1507 	}
1508 
1509 	return 0;
1510 }
1511 
1512 /* some work can't be done in tasklets, so we use keventd
1513  *
1514  * NOTE:  annoying asymmetry:  if it's active, schedule_work() fails,
1515  * but tasklet_schedule() doesn't.	hope the failure is rare.
1516  */
lan78xx_defer_kevent(struct lan78xx_net * dev,int work)1517 static void lan78xx_defer_kevent(struct lan78xx_net *dev, int work)
1518 {
1519 	set_bit(work, &dev->flags);
1520 	if (!schedule_delayed_work(&dev->wq, 0))
1521 		netdev_err(dev->net, "kevent %d may have been dropped\n", work);
1522 }
1523 
lan78xx_status(struct lan78xx_net * dev,struct urb * urb)1524 static void lan78xx_status(struct lan78xx_net *dev, struct urb *urb)
1525 {
1526 	u32 intdata;
1527 
1528 	if (urb->actual_length != 4) {
1529 		netdev_warn(dev->net,
1530 			    "unexpected urb length %d", urb->actual_length);
1531 		return;
1532 	}
1533 
1534 	intdata = get_unaligned_le32(urb->transfer_buffer);
1535 
1536 	if (intdata & INT_ENP_PHY_INT) {
1537 		netif_dbg(dev, link, dev->net, "PHY INTR: 0x%08x\n", intdata);
1538 		lan78xx_defer_kevent(dev, EVENT_LINK_RESET);
1539 
1540 		if (dev->domain_data.phyirq > 0)
1541 			generic_handle_irq_safe(dev->domain_data.phyirq);
1542 	} else {
1543 		netdev_warn(dev->net,
1544 			    "unexpected interrupt: 0x%08x\n", intdata);
1545 	}
1546 }
1547 
lan78xx_ethtool_get_eeprom_len(struct net_device * netdev)1548 static int lan78xx_ethtool_get_eeprom_len(struct net_device *netdev)
1549 {
1550 	return MAX_EEPROM_SIZE;
1551 }
1552 
lan78xx_ethtool_get_eeprom(struct net_device * netdev,struct ethtool_eeprom * ee,u8 * data)1553 static int lan78xx_ethtool_get_eeprom(struct net_device *netdev,
1554 				      struct ethtool_eeprom *ee, u8 *data)
1555 {
1556 	struct lan78xx_net *dev = netdev_priv(netdev);
1557 	int ret;
1558 
1559 	ret = usb_autopm_get_interface(dev->intf);
1560 	if (ret)
1561 		return ret;
1562 
1563 	ee->magic = LAN78XX_EEPROM_MAGIC;
1564 
1565 	ret = lan78xx_read_raw_eeprom(dev, ee->offset, ee->len, data);
1566 
1567 	usb_autopm_put_interface(dev->intf);
1568 
1569 	return ret;
1570 }
1571 
lan78xx_ethtool_set_eeprom(struct net_device * netdev,struct ethtool_eeprom * ee,u8 * data)1572 static int lan78xx_ethtool_set_eeprom(struct net_device *netdev,
1573 				      struct ethtool_eeprom *ee, u8 *data)
1574 {
1575 	struct lan78xx_net *dev = netdev_priv(netdev);
1576 	int ret;
1577 
1578 	ret = usb_autopm_get_interface(dev->intf);
1579 	if (ret)
1580 		return ret;
1581 
1582 	/* Invalid EEPROM_INDICATOR at offset zero will result in a failure
1583 	 * to load data from EEPROM
1584 	 */
1585 	if (ee->magic == LAN78XX_EEPROM_MAGIC)
1586 		ret = lan78xx_write_raw_eeprom(dev, ee->offset, ee->len, data);
1587 	else if ((ee->magic == LAN78XX_OTP_MAGIC) &&
1588 		 (ee->offset == 0) &&
1589 		 (ee->len == 512) &&
1590 		 (data[0] == OTP_INDICATOR_1))
1591 		ret = lan78xx_write_raw_otp(dev, ee->offset, ee->len, data);
1592 
1593 	usb_autopm_put_interface(dev->intf);
1594 
1595 	return ret;
1596 }
1597 
lan78xx_get_strings(struct net_device * netdev,u32 stringset,u8 * data)1598 static void lan78xx_get_strings(struct net_device *netdev, u32 stringset,
1599 				u8 *data)
1600 {
1601 	if (stringset == ETH_SS_STATS)
1602 		memcpy(data, lan78xx_gstrings, sizeof(lan78xx_gstrings));
1603 }
1604 
lan78xx_get_sset_count(struct net_device * netdev,int sset)1605 static int lan78xx_get_sset_count(struct net_device *netdev, int sset)
1606 {
1607 	if (sset == ETH_SS_STATS)
1608 		return ARRAY_SIZE(lan78xx_gstrings);
1609 	else
1610 		return -EOPNOTSUPP;
1611 }
1612 
lan78xx_get_stats(struct net_device * netdev,struct ethtool_stats * stats,u64 * data)1613 static void lan78xx_get_stats(struct net_device *netdev,
1614 			      struct ethtool_stats *stats, u64 *data)
1615 {
1616 	struct lan78xx_net *dev = netdev_priv(netdev);
1617 
1618 	lan78xx_update_stats(dev);
1619 
1620 	mutex_lock(&dev->stats.access_lock);
1621 	memcpy(data, &dev->stats.curr_stat, sizeof(dev->stats.curr_stat));
1622 	mutex_unlock(&dev->stats.access_lock);
1623 }
1624 
lan78xx_get_wol(struct net_device * netdev,struct ethtool_wolinfo * wol)1625 static void lan78xx_get_wol(struct net_device *netdev,
1626 			    struct ethtool_wolinfo *wol)
1627 {
1628 	struct lan78xx_net *dev = netdev_priv(netdev);
1629 	int ret;
1630 	u32 buf;
1631 	struct lan78xx_priv *pdata = (struct lan78xx_priv *)(dev->data[0]);
1632 
1633 	if (usb_autopm_get_interface(dev->intf) < 0)
1634 		return;
1635 
1636 	ret = lan78xx_read_reg(dev, USB_CFG0, &buf);
1637 	if (unlikely(ret < 0)) {
1638 		wol->supported = 0;
1639 		wol->wolopts = 0;
1640 	} else {
1641 		if (buf & USB_CFG_RMT_WKP_) {
1642 			wol->supported = WAKE_ALL;
1643 			wol->wolopts = pdata->wol;
1644 		} else {
1645 			wol->supported = 0;
1646 			wol->wolopts = 0;
1647 		}
1648 	}
1649 
1650 	usb_autopm_put_interface(dev->intf);
1651 }
1652 
lan78xx_set_wol(struct net_device * netdev,struct ethtool_wolinfo * wol)1653 static int lan78xx_set_wol(struct net_device *netdev,
1654 			   struct ethtool_wolinfo *wol)
1655 {
1656 	struct lan78xx_net *dev = netdev_priv(netdev);
1657 	struct lan78xx_priv *pdata = (struct lan78xx_priv *)(dev->data[0]);
1658 	int ret;
1659 
1660 	ret = usb_autopm_get_interface(dev->intf);
1661 	if (ret < 0)
1662 		return ret;
1663 
1664 	if (wol->wolopts & ~WAKE_ALL)
1665 		return -EINVAL;
1666 
1667 	pdata->wol = wol->wolopts;
1668 
1669 	device_set_wakeup_enable(&dev->udev->dev, (bool)wol->wolopts);
1670 
1671 	phy_ethtool_set_wol(netdev->phydev, wol);
1672 
1673 	usb_autopm_put_interface(dev->intf);
1674 
1675 	return ret;
1676 }
1677 
lan78xx_get_eee(struct net_device * net,struct ethtool_eee * edata)1678 static int lan78xx_get_eee(struct net_device *net, struct ethtool_eee *edata)
1679 {
1680 	struct lan78xx_net *dev = netdev_priv(net);
1681 	struct phy_device *phydev = net->phydev;
1682 	int ret;
1683 	u32 buf;
1684 
1685 	ret = usb_autopm_get_interface(dev->intf);
1686 	if (ret < 0)
1687 		return ret;
1688 
1689 	ret = phy_ethtool_get_eee(phydev, edata);
1690 	if (ret < 0)
1691 		goto exit;
1692 
1693 	ret = lan78xx_read_reg(dev, MAC_CR, &buf);
1694 	if (buf & MAC_CR_EEE_EN_) {
1695 		edata->eee_enabled = true;
1696 		edata->eee_active = !!(edata->advertised &
1697 				       edata->lp_advertised);
1698 		edata->tx_lpi_enabled = true;
1699 		/* EEE_TX_LPI_REQ_DLY & tx_lpi_timer are same uSec unit */
1700 		ret = lan78xx_read_reg(dev, EEE_TX_LPI_REQ_DLY, &buf);
1701 		edata->tx_lpi_timer = buf;
1702 	} else {
1703 		edata->eee_enabled = false;
1704 		edata->eee_active = false;
1705 		edata->tx_lpi_enabled = false;
1706 		edata->tx_lpi_timer = 0;
1707 	}
1708 
1709 	ret = 0;
1710 exit:
1711 	usb_autopm_put_interface(dev->intf);
1712 
1713 	return ret;
1714 }
1715 
lan78xx_set_eee(struct net_device * net,struct ethtool_eee * edata)1716 static int lan78xx_set_eee(struct net_device *net, struct ethtool_eee *edata)
1717 {
1718 	struct lan78xx_net *dev = netdev_priv(net);
1719 	int ret;
1720 	u32 buf;
1721 
1722 	ret = usb_autopm_get_interface(dev->intf);
1723 	if (ret < 0)
1724 		return ret;
1725 
1726 	if (edata->eee_enabled) {
1727 		ret = lan78xx_read_reg(dev, MAC_CR, &buf);
1728 		buf |= MAC_CR_EEE_EN_;
1729 		ret = lan78xx_write_reg(dev, MAC_CR, buf);
1730 
1731 		phy_ethtool_set_eee(net->phydev, edata);
1732 
1733 		buf = (u32)edata->tx_lpi_timer;
1734 		ret = lan78xx_write_reg(dev, EEE_TX_LPI_REQ_DLY, buf);
1735 	} else {
1736 		ret = lan78xx_read_reg(dev, MAC_CR, &buf);
1737 		buf &= ~MAC_CR_EEE_EN_;
1738 		ret = lan78xx_write_reg(dev, MAC_CR, buf);
1739 	}
1740 
1741 	usb_autopm_put_interface(dev->intf);
1742 
1743 	return 0;
1744 }
1745 
lan78xx_get_link(struct net_device * net)1746 static u32 lan78xx_get_link(struct net_device *net)
1747 {
1748 	u32 link;
1749 
1750 	mutex_lock(&net->phydev->lock);
1751 	phy_read_status(net->phydev);
1752 	link = net->phydev->link;
1753 	mutex_unlock(&net->phydev->lock);
1754 
1755 	return link;
1756 }
1757 
lan78xx_get_drvinfo(struct net_device * net,struct ethtool_drvinfo * info)1758 static void lan78xx_get_drvinfo(struct net_device *net,
1759 				struct ethtool_drvinfo *info)
1760 {
1761 	struct lan78xx_net *dev = netdev_priv(net);
1762 
1763 	strncpy(info->driver, DRIVER_NAME, sizeof(info->driver));
1764 	usb_make_path(dev->udev, info->bus_info, sizeof(info->bus_info));
1765 }
1766 
lan78xx_get_msglevel(struct net_device * net)1767 static u32 lan78xx_get_msglevel(struct net_device *net)
1768 {
1769 	struct lan78xx_net *dev = netdev_priv(net);
1770 
1771 	return dev->msg_enable;
1772 }
1773 
lan78xx_set_msglevel(struct net_device * net,u32 level)1774 static void lan78xx_set_msglevel(struct net_device *net, u32 level)
1775 {
1776 	struct lan78xx_net *dev = netdev_priv(net);
1777 
1778 	dev->msg_enable = level;
1779 }
1780 
lan78xx_get_link_ksettings(struct net_device * net,struct ethtool_link_ksettings * cmd)1781 static int lan78xx_get_link_ksettings(struct net_device *net,
1782 				      struct ethtool_link_ksettings *cmd)
1783 {
1784 	struct lan78xx_net *dev = netdev_priv(net);
1785 	struct phy_device *phydev = net->phydev;
1786 	int ret;
1787 
1788 	ret = usb_autopm_get_interface(dev->intf);
1789 	if (ret < 0)
1790 		return ret;
1791 
1792 	phy_ethtool_ksettings_get(phydev, cmd);
1793 
1794 	usb_autopm_put_interface(dev->intf);
1795 
1796 	return ret;
1797 }
1798 
lan78xx_set_link_ksettings(struct net_device * net,const struct ethtool_link_ksettings * cmd)1799 static int lan78xx_set_link_ksettings(struct net_device *net,
1800 				      const struct ethtool_link_ksettings *cmd)
1801 {
1802 	struct lan78xx_net *dev = netdev_priv(net);
1803 	struct phy_device *phydev = net->phydev;
1804 	int ret = 0;
1805 	int temp;
1806 
1807 	ret = usb_autopm_get_interface(dev->intf);
1808 	if (ret < 0)
1809 		return ret;
1810 
1811 	/* change speed & duplex */
1812 	ret = phy_ethtool_ksettings_set(phydev, cmd);
1813 
1814 	if (!cmd->base.autoneg) {
1815 		/* force link down */
1816 		temp = phy_read(phydev, MII_BMCR);
1817 		phy_write(phydev, MII_BMCR, temp | BMCR_LOOPBACK);
1818 		mdelay(1);
1819 		phy_write(phydev, MII_BMCR, temp);
1820 	}
1821 
1822 	usb_autopm_put_interface(dev->intf);
1823 
1824 	return ret;
1825 }
1826 
lan78xx_get_pause(struct net_device * net,struct ethtool_pauseparam * pause)1827 static void lan78xx_get_pause(struct net_device *net,
1828 			      struct ethtool_pauseparam *pause)
1829 {
1830 	struct lan78xx_net *dev = netdev_priv(net);
1831 	struct phy_device *phydev = net->phydev;
1832 	struct ethtool_link_ksettings ecmd;
1833 
1834 	phy_ethtool_ksettings_get(phydev, &ecmd);
1835 
1836 	pause->autoneg = dev->fc_autoneg;
1837 
1838 	if (dev->fc_request_control & FLOW_CTRL_TX)
1839 		pause->tx_pause = 1;
1840 
1841 	if (dev->fc_request_control & FLOW_CTRL_RX)
1842 		pause->rx_pause = 1;
1843 }
1844 
lan78xx_set_pause(struct net_device * net,struct ethtool_pauseparam * pause)1845 static int lan78xx_set_pause(struct net_device *net,
1846 			     struct ethtool_pauseparam *pause)
1847 {
1848 	struct lan78xx_net *dev = netdev_priv(net);
1849 	struct phy_device *phydev = net->phydev;
1850 	struct ethtool_link_ksettings ecmd;
1851 	int ret;
1852 
1853 	phy_ethtool_ksettings_get(phydev, &ecmd);
1854 
1855 	if (pause->autoneg && !ecmd.base.autoneg) {
1856 		ret = -EINVAL;
1857 		goto exit;
1858 	}
1859 
1860 	dev->fc_request_control = 0;
1861 	if (pause->rx_pause)
1862 		dev->fc_request_control |= FLOW_CTRL_RX;
1863 
1864 	if (pause->tx_pause)
1865 		dev->fc_request_control |= FLOW_CTRL_TX;
1866 
1867 	if (ecmd.base.autoneg) {
1868 		__ETHTOOL_DECLARE_LINK_MODE_MASK(fc) = { 0, };
1869 		u32 mii_adv;
1870 
1871 		linkmode_clear_bit(ETHTOOL_LINK_MODE_Pause_BIT,
1872 				   ecmd.link_modes.advertising);
1873 		linkmode_clear_bit(ETHTOOL_LINK_MODE_Asym_Pause_BIT,
1874 				   ecmd.link_modes.advertising);
1875 		mii_adv = (u32)mii_advertise_flowctrl(dev->fc_request_control);
1876 		mii_adv_to_linkmode_adv_t(fc, mii_adv);
1877 		linkmode_or(ecmd.link_modes.advertising, fc,
1878 			    ecmd.link_modes.advertising);
1879 
1880 		phy_ethtool_ksettings_set(phydev, &ecmd);
1881 	}
1882 
1883 	dev->fc_autoneg = pause->autoneg;
1884 
1885 	ret = 0;
1886 exit:
1887 	return ret;
1888 }
1889 
lan78xx_get_regs_len(struct net_device * netdev)1890 static int lan78xx_get_regs_len(struct net_device *netdev)
1891 {
1892 	if (!netdev->phydev)
1893 		return (sizeof(lan78xx_regs));
1894 	else
1895 		return (sizeof(lan78xx_regs) + PHY_REG_SIZE);
1896 }
1897 
1898 static void
lan78xx_get_regs(struct net_device * netdev,struct ethtool_regs * regs,void * buf)1899 lan78xx_get_regs(struct net_device *netdev, struct ethtool_regs *regs,
1900 		 void *buf)
1901 {
1902 	u32 *data = buf;
1903 	int i, j;
1904 	struct lan78xx_net *dev = netdev_priv(netdev);
1905 
1906 	/* Read Device/MAC registers */
1907 	for (i = 0; i < ARRAY_SIZE(lan78xx_regs); i++)
1908 		lan78xx_read_reg(dev, lan78xx_regs[i], &data[i]);
1909 
1910 	if (!netdev->phydev)
1911 		return;
1912 
1913 	/* Read PHY registers */
1914 	for (j = 0; j < 32; i++, j++)
1915 		data[i] = phy_read(netdev->phydev, j);
1916 }
1917 
1918 static const struct ethtool_ops lan78xx_ethtool_ops = {
1919 	.get_link	= lan78xx_get_link,
1920 	.nway_reset	= phy_ethtool_nway_reset,
1921 	.get_drvinfo	= lan78xx_get_drvinfo,
1922 	.get_msglevel	= lan78xx_get_msglevel,
1923 	.set_msglevel	= lan78xx_set_msglevel,
1924 	.get_eeprom_len = lan78xx_ethtool_get_eeprom_len,
1925 	.get_eeprom	= lan78xx_ethtool_get_eeprom,
1926 	.set_eeprom	= lan78xx_ethtool_set_eeprom,
1927 	.get_ethtool_stats = lan78xx_get_stats,
1928 	.get_sset_count = lan78xx_get_sset_count,
1929 	.get_strings	= lan78xx_get_strings,
1930 	.get_wol	= lan78xx_get_wol,
1931 	.set_wol	= lan78xx_set_wol,
1932 	.get_ts_info	= ethtool_op_get_ts_info,
1933 	.get_eee	= lan78xx_get_eee,
1934 	.set_eee	= lan78xx_set_eee,
1935 	.get_pauseparam	= lan78xx_get_pause,
1936 	.set_pauseparam	= lan78xx_set_pause,
1937 	.get_link_ksettings = lan78xx_get_link_ksettings,
1938 	.set_link_ksettings = lan78xx_set_link_ksettings,
1939 	.get_regs_len	= lan78xx_get_regs_len,
1940 	.get_regs	= lan78xx_get_regs,
1941 };
1942 
lan78xx_init_mac_address(struct lan78xx_net * dev)1943 static void lan78xx_init_mac_address(struct lan78xx_net *dev)
1944 {
1945 	u32 addr_lo, addr_hi;
1946 	u8 addr[6];
1947 
1948 	lan78xx_read_reg(dev, RX_ADDRL, &addr_lo);
1949 	lan78xx_read_reg(dev, RX_ADDRH, &addr_hi);
1950 
1951 	addr[0] = addr_lo & 0xFF;
1952 	addr[1] = (addr_lo >> 8) & 0xFF;
1953 	addr[2] = (addr_lo >> 16) & 0xFF;
1954 	addr[3] = (addr_lo >> 24) & 0xFF;
1955 	addr[4] = addr_hi & 0xFF;
1956 	addr[5] = (addr_hi >> 8) & 0xFF;
1957 
1958 	if (!is_valid_ether_addr(addr)) {
1959 		if (!eth_platform_get_mac_address(&dev->udev->dev, addr)) {
1960 			/* valid address present in Device Tree */
1961 			netif_dbg(dev, ifup, dev->net,
1962 				  "MAC address read from Device Tree");
1963 		} else if (((lan78xx_read_eeprom(dev, EEPROM_MAC_OFFSET,
1964 						 ETH_ALEN, addr) == 0) ||
1965 			    (lan78xx_read_otp(dev, EEPROM_MAC_OFFSET,
1966 					      ETH_ALEN, addr) == 0)) &&
1967 			   is_valid_ether_addr(addr)) {
1968 			/* eeprom values are valid so use them */
1969 			netif_dbg(dev, ifup, dev->net,
1970 				  "MAC address read from EEPROM");
1971 		} else {
1972 			/* generate random MAC */
1973 			eth_random_addr(addr);
1974 			netif_dbg(dev, ifup, dev->net,
1975 				  "MAC address set to random addr");
1976 		}
1977 
1978 		addr_lo = addr[0] | (addr[1] << 8) |
1979 			  (addr[2] << 16) | (addr[3] << 24);
1980 		addr_hi = addr[4] | (addr[5] << 8);
1981 
1982 		lan78xx_write_reg(dev, RX_ADDRL, addr_lo);
1983 		lan78xx_write_reg(dev, RX_ADDRH, addr_hi);
1984 	}
1985 
1986 	lan78xx_write_reg(dev, MAF_LO(0), addr_lo);
1987 	lan78xx_write_reg(dev, MAF_HI(0), addr_hi | MAF_HI_VALID_);
1988 
1989 	eth_hw_addr_set(dev->net, addr);
1990 }
1991 
1992 /* MDIO read and write wrappers for phylib */
lan78xx_mdiobus_read(struct mii_bus * bus,int phy_id,int idx)1993 static int lan78xx_mdiobus_read(struct mii_bus *bus, int phy_id, int idx)
1994 {
1995 	struct lan78xx_net *dev = bus->priv;
1996 	u32 val, addr;
1997 	int ret;
1998 
1999 	ret = usb_autopm_get_interface(dev->intf);
2000 	if (ret < 0)
2001 		return ret;
2002 
2003 	mutex_lock(&dev->phy_mutex);
2004 
2005 	/* confirm MII not busy */
2006 	ret = lan78xx_phy_wait_not_busy(dev);
2007 	if (ret < 0)
2008 		goto done;
2009 
2010 	/* set the address, index & direction (read from PHY) */
2011 	addr = mii_access(phy_id, idx, MII_READ);
2012 	ret = lan78xx_write_reg(dev, MII_ACC, addr);
2013 
2014 	ret = lan78xx_phy_wait_not_busy(dev);
2015 	if (ret < 0)
2016 		goto done;
2017 
2018 	ret = lan78xx_read_reg(dev, MII_DATA, &val);
2019 
2020 	ret = (int)(val & 0xFFFF);
2021 
2022 done:
2023 	mutex_unlock(&dev->phy_mutex);
2024 	usb_autopm_put_interface(dev->intf);
2025 
2026 	return ret;
2027 }
2028 
lan78xx_mdiobus_write(struct mii_bus * bus,int phy_id,int idx,u16 regval)2029 static int lan78xx_mdiobus_write(struct mii_bus *bus, int phy_id, int idx,
2030 				 u16 regval)
2031 {
2032 	struct lan78xx_net *dev = bus->priv;
2033 	u32 val, addr;
2034 	int ret;
2035 
2036 	ret = usb_autopm_get_interface(dev->intf);
2037 	if (ret < 0)
2038 		return ret;
2039 
2040 	mutex_lock(&dev->phy_mutex);
2041 
2042 	/* confirm MII not busy */
2043 	ret = lan78xx_phy_wait_not_busy(dev);
2044 	if (ret < 0)
2045 		goto done;
2046 
2047 	val = (u32)regval;
2048 	ret = lan78xx_write_reg(dev, MII_DATA, val);
2049 
2050 	/* set the address, index & direction (write to PHY) */
2051 	addr = mii_access(phy_id, idx, MII_WRITE);
2052 	ret = lan78xx_write_reg(dev, MII_ACC, addr);
2053 
2054 	ret = lan78xx_phy_wait_not_busy(dev);
2055 	if (ret < 0)
2056 		goto done;
2057 
2058 done:
2059 	mutex_unlock(&dev->phy_mutex);
2060 	usb_autopm_put_interface(dev->intf);
2061 	return 0;
2062 }
2063 
lan78xx_mdio_init(struct lan78xx_net * dev)2064 static int lan78xx_mdio_init(struct lan78xx_net *dev)
2065 {
2066 	struct device_node *node;
2067 	int ret;
2068 
2069 	dev->mdiobus = mdiobus_alloc();
2070 	if (!dev->mdiobus) {
2071 		netdev_err(dev->net, "can't allocate MDIO bus\n");
2072 		return -ENOMEM;
2073 	}
2074 
2075 	dev->mdiobus->priv = (void *)dev;
2076 	dev->mdiobus->read = lan78xx_mdiobus_read;
2077 	dev->mdiobus->write = lan78xx_mdiobus_write;
2078 	dev->mdiobus->name = "lan78xx-mdiobus";
2079 	dev->mdiobus->parent = &dev->udev->dev;
2080 
2081 	snprintf(dev->mdiobus->id, MII_BUS_ID_SIZE, "usb-%03d:%03d",
2082 		 dev->udev->bus->busnum, dev->udev->devnum);
2083 
2084 	switch (dev->chipid) {
2085 	case ID_REV_CHIP_ID_7800_:
2086 	case ID_REV_CHIP_ID_7850_:
2087 		/* set to internal PHY id */
2088 		dev->mdiobus->phy_mask = ~(1 << 1);
2089 		break;
2090 	case ID_REV_CHIP_ID_7801_:
2091 		/* scan thru PHYAD[2..0] */
2092 		dev->mdiobus->phy_mask = ~(0xFF);
2093 		break;
2094 	}
2095 
2096 	node = of_get_child_by_name(dev->udev->dev.of_node, "mdio");
2097 	ret = of_mdiobus_register(dev->mdiobus, node);
2098 	of_node_put(node);
2099 	if (ret) {
2100 		netdev_err(dev->net, "can't register MDIO bus\n");
2101 		goto exit1;
2102 	}
2103 
2104 	netdev_dbg(dev->net, "registered mdiobus bus %s\n", dev->mdiobus->id);
2105 	return 0;
2106 exit1:
2107 	mdiobus_free(dev->mdiobus);
2108 	return ret;
2109 }
2110 
lan78xx_remove_mdio(struct lan78xx_net * dev)2111 static void lan78xx_remove_mdio(struct lan78xx_net *dev)
2112 {
2113 	mdiobus_unregister(dev->mdiobus);
2114 	mdiobus_free(dev->mdiobus);
2115 }
2116 
lan78xx_link_status_change(struct net_device * net)2117 static void lan78xx_link_status_change(struct net_device *net)
2118 {
2119 	struct phy_device *phydev = net->phydev;
2120 
2121 	phy_print_status(phydev);
2122 }
2123 
irq_map(struct irq_domain * d,unsigned int irq,irq_hw_number_t hwirq)2124 static int irq_map(struct irq_domain *d, unsigned int irq,
2125 		   irq_hw_number_t hwirq)
2126 {
2127 	struct irq_domain_data *data = d->host_data;
2128 
2129 	irq_set_chip_data(irq, data);
2130 	irq_set_chip_and_handler(irq, data->irqchip, data->irq_handler);
2131 	irq_set_noprobe(irq);
2132 
2133 	return 0;
2134 }
2135 
irq_unmap(struct irq_domain * d,unsigned int irq)2136 static void irq_unmap(struct irq_domain *d, unsigned int irq)
2137 {
2138 	irq_set_chip_and_handler(irq, NULL, NULL);
2139 	irq_set_chip_data(irq, NULL);
2140 }
2141 
2142 static const struct irq_domain_ops chip_domain_ops = {
2143 	.map	= irq_map,
2144 	.unmap	= irq_unmap,
2145 };
2146 
lan78xx_irq_mask(struct irq_data * irqd)2147 static void lan78xx_irq_mask(struct irq_data *irqd)
2148 {
2149 	struct irq_domain_data *data = irq_data_get_irq_chip_data(irqd);
2150 
2151 	data->irqenable &= ~BIT(irqd_to_hwirq(irqd));
2152 }
2153 
lan78xx_irq_unmask(struct irq_data * irqd)2154 static void lan78xx_irq_unmask(struct irq_data *irqd)
2155 {
2156 	struct irq_domain_data *data = irq_data_get_irq_chip_data(irqd);
2157 
2158 	data->irqenable |= BIT(irqd_to_hwirq(irqd));
2159 }
2160 
lan78xx_irq_bus_lock(struct irq_data * irqd)2161 static void lan78xx_irq_bus_lock(struct irq_data *irqd)
2162 {
2163 	struct irq_domain_data *data = irq_data_get_irq_chip_data(irqd);
2164 
2165 	mutex_lock(&data->irq_lock);
2166 }
2167 
lan78xx_irq_bus_sync_unlock(struct irq_data * irqd)2168 static void lan78xx_irq_bus_sync_unlock(struct irq_data *irqd)
2169 {
2170 	struct irq_domain_data *data = irq_data_get_irq_chip_data(irqd);
2171 	struct lan78xx_net *dev =
2172 			container_of(data, struct lan78xx_net, domain_data);
2173 	u32 buf;
2174 
2175 	/* call register access here because irq_bus_lock & irq_bus_sync_unlock
2176 	 * are only two callbacks executed in non-atomic contex.
2177 	 */
2178 	lan78xx_read_reg(dev, INT_EP_CTL, &buf);
2179 	if (buf != data->irqenable)
2180 		lan78xx_write_reg(dev, INT_EP_CTL, data->irqenable);
2181 
2182 	mutex_unlock(&data->irq_lock);
2183 }
2184 
2185 static struct irq_chip lan78xx_irqchip = {
2186 	.name			= "lan78xx-irqs",
2187 	.irq_mask		= lan78xx_irq_mask,
2188 	.irq_unmask		= lan78xx_irq_unmask,
2189 	.irq_bus_lock		= lan78xx_irq_bus_lock,
2190 	.irq_bus_sync_unlock	= lan78xx_irq_bus_sync_unlock,
2191 };
2192 
lan78xx_setup_irq_domain(struct lan78xx_net * dev)2193 static int lan78xx_setup_irq_domain(struct lan78xx_net *dev)
2194 {
2195 	struct device_node *of_node;
2196 	struct irq_domain *irqdomain;
2197 	unsigned int irqmap = 0;
2198 	u32 buf;
2199 	int ret = 0;
2200 
2201 	of_node = dev->udev->dev.parent->of_node;
2202 
2203 	mutex_init(&dev->domain_data.irq_lock);
2204 
2205 	lan78xx_read_reg(dev, INT_EP_CTL, &buf);
2206 	dev->domain_data.irqenable = buf;
2207 
2208 	dev->domain_data.irqchip = &lan78xx_irqchip;
2209 	dev->domain_data.irq_handler = handle_simple_irq;
2210 
2211 	irqdomain = irq_domain_add_simple(of_node, MAX_INT_EP, 0,
2212 					  &chip_domain_ops, &dev->domain_data);
2213 	if (irqdomain) {
2214 		/* create mapping for PHY interrupt */
2215 		irqmap = irq_create_mapping(irqdomain, INT_EP_PHY);
2216 		if (!irqmap) {
2217 			irq_domain_remove(irqdomain);
2218 
2219 			irqdomain = NULL;
2220 			ret = -EINVAL;
2221 		}
2222 	} else {
2223 		ret = -EINVAL;
2224 	}
2225 
2226 	dev->domain_data.irqdomain = irqdomain;
2227 	dev->domain_data.phyirq = irqmap;
2228 
2229 	return ret;
2230 }
2231 
lan78xx_remove_irq_domain(struct lan78xx_net * dev)2232 static void lan78xx_remove_irq_domain(struct lan78xx_net *dev)
2233 {
2234 	if (dev->domain_data.phyirq > 0) {
2235 		irq_dispose_mapping(dev->domain_data.phyirq);
2236 
2237 		if (dev->domain_data.irqdomain)
2238 			irq_domain_remove(dev->domain_data.irqdomain);
2239 	}
2240 	dev->domain_data.phyirq = 0;
2241 	dev->domain_data.irqdomain = NULL;
2242 }
2243 
lan8835_fixup(struct phy_device * phydev)2244 static int lan8835_fixup(struct phy_device *phydev)
2245 {
2246 	int buf;
2247 	struct lan78xx_net *dev = netdev_priv(phydev->attached_dev);
2248 
2249 	/* LED2/PME_N/IRQ_N/RGMII_ID pin to IRQ_N mode */
2250 	buf = phy_read_mmd(phydev, MDIO_MMD_PCS, 0x8010);
2251 	buf &= ~0x1800;
2252 	buf |= 0x0800;
2253 	phy_write_mmd(phydev, MDIO_MMD_PCS, 0x8010, buf);
2254 
2255 	/* RGMII MAC TXC Delay Enable */
2256 	lan78xx_write_reg(dev, MAC_RGMII_ID,
2257 			  MAC_RGMII_ID_TXC_DELAY_EN_);
2258 
2259 	/* RGMII TX DLL Tune Adjust */
2260 	lan78xx_write_reg(dev, RGMII_TX_BYP_DLL, 0x3D00);
2261 
2262 	dev->interface = PHY_INTERFACE_MODE_RGMII_TXID;
2263 
2264 	return 1;
2265 }
2266 
ksz9031rnx_fixup(struct phy_device * phydev)2267 static int ksz9031rnx_fixup(struct phy_device *phydev)
2268 {
2269 	struct lan78xx_net *dev = netdev_priv(phydev->attached_dev);
2270 
2271 	/* Micrel9301RNX PHY configuration */
2272 	/* RGMII Control Signal Pad Skew */
2273 	phy_write_mmd(phydev, MDIO_MMD_WIS, 4, 0x0077);
2274 	/* RGMII RX Data Pad Skew */
2275 	phy_write_mmd(phydev, MDIO_MMD_WIS, 5, 0x7777);
2276 	/* RGMII RX Clock Pad Skew */
2277 	phy_write_mmd(phydev, MDIO_MMD_WIS, 8, 0x1FF);
2278 
2279 	dev->interface = PHY_INTERFACE_MODE_RGMII_RXID;
2280 
2281 	return 1;
2282 }
2283 
lan7801_phy_init(struct lan78xx_net * dev)2284 static struct phy_device *lan7801_phy_init(struct lan78xx_net *dev)
2285 {
2286 	u32 buf;
2287 	int ret;
2288 	struct fixed_phy_status fphy_status = {
2289 		.link = 1,
2290 		.speed = SPEED_1000,
2291 		.duplex = DUPLEX_FULL,
2292 	};
2293 	struct phy_device *phydev;
2294 
2295 	phydev = phy_find_first(dev->mdiobus);
2296 	if (!phydev) {
2297 		netdev_dbg(dev->net, "PHY Not Found!! Registering Fixed PHY\n");
2298 		phydev = fixed_phy_register(PHY_POLL, &fphy_status, NULL);
2299 		if (IS_ERR(phydev)) {
2300 			netdev_err(dev->net, "No PHY/fixed_PHY found\n");
2301 			return NULL;
2302 		}
2303 		netdev_dbg(dev->net, "Registered FIXED PHY\n");
2304 		dev->interface = PHY_INTERFACE_MODE_RGMII;
2305 		ret = lan78xx_write_reg(dev, MAC_RGMII_ID,
2306 					MAC_RGMII_ID_TXC_DELAY_EN_);
2307 		ret = lan78xx_write_reg(dev, RGMII_TX_BYP_DLL, 0x3D00);
2308 		ret = lan78xx_read_reg(dev, HW_CFG, &buf);
2309 		buf |= HW_CFG_CLK125_EN_;
2310 		buf |= HW_CFG_REFCLK25_EN_;
2311 		ret = lan78xx_write_reg(dev, HW_CFG, buf);
2312 	} else {
2313 		if (!phydev->drv) {
2314 			netdev_err(dev->net, "no PHY driver found\n");
2315 			return NULL;
2316 		}
2317 		dev->interface = PHY_INTERFACE_MODE_RGMII;
2318 		/* external PHY fixup for KSZ9031RNX */
2319 		ret = phy_register_fixup_for_uid(PHY_KSZ9031RNX, 0xfffffff0,
2320 						 ksz9031rnx_fixup);
2321 		if (ret < 0) {
2322 			netdev_err(dev->net, "Failed to register fixup for PHY_KSZ9031RNX\n");
2323 			return NULL;
2324 		}
2325 		/* external PHY fixup for LAN8835 */
2326 		ret = phy_register_fixup_for_uid(PHY_LAN8835, 0xfffffff0,
2327 						 lan8835_fixup);
2328 		if (ret < 0) {
2329 			netdev_err(dev->net, "Failed to register fixup for PHY_LAN8835\n");
2330 			return NULL;
2331 		}
2332 		/* add more external PHY fixup here if needed */
2333 
2334 		phydev->is_internal = false;
2335 	}
2336 	return phydev;
2337 }
2338 
lan78xx_phy_init(struct lan78xx_net * dev)2339 static int lan78xx_phy_init(struct lan78xx_net *dev)
2340 {
2341 	__ETHTOOL_DECLARE_LINK_MODE_MASK(fc) = { 0, };
2342 	int ret;
2343 	u32 mii_adv;
2344 	struct phy_device *phydev;
2345 
2346 	switch (dev->chipid) {
2347 	case ID_REV_CHIP_ID_7801_:
2348 		phydev = lan7801_phy_init(dev);
2349 		if (!phydev) {
2350 			netdev_err(dev->net, "lan7801: PHY Init Failed");
2351 			return -EIO;
2352 		}
2353 		break;
2354 
2355 	case ID_REV_CHIP_ID_7800_:
2356 	case ID_REV_CHIP_ID_7850_:
2357 		phydev = phy_find_first(dev->mdiobus);
2358 		if (!phydev) {
2359 			netdev_err(dev->net, "no PHY found\n");
2360 			return -EIO;
2361 		}
2362 		phydev->is_internal = true;
2363 		dev->interface = PHY_INTERFACE_MODE_GMII;
2364 		break;
2365 
2366 	default:
2367 		netdev_err(dev->net, "Unknown CHIP ID found\n");
2368 		return -EIO;
2369 	}
2370 
2371 	/* if phyirq is not set, use polling mode in phylib */
2372 	if (dev->domain_data.phyirq > 0)
2373 		phydev->irq = dev->domain_data.phyirq;
2374 	else
2375 		phydev->irq = PHY_POLL;
2376 	netdev_dbg(dev->net, "phydev->irq = %d\n", phydev->irq);
2377 
2378 	/* set to AUTOMDIX */
2379 	phydev->mdix = ETH_TP_MDI_AUTO;
2380 
2381 	ret = phy_connect_direct(dev->net, phydev,
2382 				 lan78xx_link_status_change,
2383 				 dev->interface);
2384 	if (ret) {
2385 		netdev_err(dev->net, "can't attach PHY to %s\n",
2386 			   dev->mdiobus->id);
2387 		if (dev->chipid == ID_REV_CHIP_ID_7801_) {
2388 			if (phy_is_pseudo_fixed_link(phydev)) {
2389 				fixed_phy_unregister(phydev);
2390 			} else {
2391 				phy_unregister_fixup_for_uid(PHY_KSZ9031RNX,
2392 							     0xfffffff0);
2393 				phy_unregister_fixup_for_uid(PHY_LAN8835,
2394 							     0xfffffff0);
2395 			}
2396 		}
2397 		return -EIO;
2398 	}
2399 
2400 	/* MAC doesn't support 1000T Half */
2401 	phy_remove_link_mode(phydev, ETHTOOL_LINK_MODE_1000baseT_Half_BIT);
2402 
2403 	/* support both flow controls */
2404 	dev->fc_request_control = (FLOW_CTRL_RX | FLOW_CTRL_TX);
2405 	linkmode_clear_bit(ETHTOOL_LINK_MODE_Pause_BIT,
2406 			   phydev->advertising);
2407 	linkmode_clear_bit(ETHTOOL_LINK_MODE_Asym_Pause_BIT,
2408 			   phydev->advertising);
2409 	mii_adv = (u32)mii_advertise_flowctrl(dev->fc_request_control);
2410 	mii_adv_to_linkmode_adv_t(fc, mii_adv);
2411 	linkmode_or(phydev->advertising, fc, phydev->advertising);
2412 
2413 	if (phydev->mdio.dev.of_node) {
2414 		u32 reg;
2415 		int len;
2416 
2417 		len = of_property_count_elems_of_size(phydev->mdio.dev.of_node,
2418 						      "microchip,led-modes",
2419 						      sizeof(u32));
2420 		if (len >= 0) {
2421 			/* Ensure the appropriate LEDs are enabled */
2422 			lan78xx_read_reg(dev, HW_CFG, &reg);
2423 			reg &= ~(HW_CFG_LED0_EN_ |
2424 				 HW_CFG_LED1_EN_ |
2425 				 HW_CFG_LED2_EN_ |
2426 				 HW_CFG_LED3_EN_);
2427 			reg |= (len > 0) * HW_CFG_LED0_EN_ |
2428 				(len > 1) * HW_CFG_LED1_EN_ |
2429 				(len > 2) * HW_CFG_LED2_EN_ |
2430 				(len > 3) * HW_CFG_LED3_EN_;
2431 			lan78xx_write_reg(dev, HW_CFG, reg);
2432 		}
2433 	}
2434 
2435 	genphy_config_aneg(phydev);
2436 
2437 	dev->fc_autoneg = phydev->autoneg;
2438 
2439 	return 0;
2440 }
2441 
lan78xx_set_rx_max_frame_length(struct lan78xx_net * dev,int size)2442 static int lan78xx_set_rx_max_frame_length(struct lan78xx_net *dev, int size)
2443 {
2444 	u32 buf;
2445 	bool rxenabled;
2446 
2447 	lan78xx_read_reg(dev, MAC_RX, &buf);
2448 
2449 	rxenabled = ((buf & MAC_RX_RXEN_) != 0);
2450 
2451 	if (rxenabled) {
2452 		buf &= ~MAC_RX_RXEN_;
2453 		lan78xx_write_reg(dev, MAC_RX, buf);
2454 	}
2455 
2456 	/* add 4 to size for FCS */
2457 	buf &= ~MAC_RX_MAX_SIZE_MASK_;
2458 	buf |= (((size + 4) << MAC_RX_MAX_SIZE_SHIFT_) & MAC_RX_MAX_SIZE_MASK_);
2459 
2460 	lan78xx_write_reg(dev, MAC_RX, buf);
2461 
2462 	if (rxenabled) {
2463 		buf |= MAC_RX_RXEN_;
2464 		lan78xx_write_reg(dev, MAC_RX, buf);
2465 	}
2466 
2467 	return 0;
2468 }
2469 
unlink_urbs(struct lan78xx_net * dev,struct sk_buff_head * q)2470 static int unlink_urbs(struct lan78xx_net *dev, struct sk_buff_head *q)
2471 {
2472 	struct sk_buff *skb;
2473 	unsigned long flags;
2474 	int count = 0;
2475 
2476 	spin_lock_irqsave(&q->lock, flags);
2477 	while (!skb_queue_empty(q)) {
2478 		struct skb_data	*entry;
2479 		struct urb *urb;
2480 		int ret;
2481 
2482 		skb_queue_walk(q, skb) {
2483 			entry = (struct skb_data *)skb->cb;
2484 			if (entry->state != unlink_start)
2485 				goto found;
2486 		}
2487 		break;
2488 found:
2489 		entry->state = unlink_start;
2490 		urb = entry->urb;
2491 
2492 		/* Get reference count of the URB to avoid it to be
2493 		 * freed during usb_unlink_urb, which may trigger
2494 		 * use-after-free problem inside usb_unlink_urb since
2495 		 * usb_unlink_urb is always racing with .complete
2496 		 * handler(include defer_bh).
2497 		 */
2498 		usb_get_urb(urb);
2499 		spin_unlock_irqrestore(&q->lock, flags);
2500 		/* during some PM-driven resume scenarios,
2501 		 * these (async) unlinks complete immediately
2502 		 */
2503 		ret = usb_unlink_urb(urb);
2504 		if (ret != -EINPROGRESS && ret != 0)
2505 			netdev_dbg(dev->net, "unlink urb err, %d\n", ret);
2506 		else
2507 			count++;
2508 		usb_put_urb(urb);
2509 		spin_lock_irqsave(&q->lock, flags);
2510 	}
2511 	spin_unlock_irqrestore(&q->lock, flags);
2512 	return count;
2513 }
2514 
lan78xx_change_mtu(struct net_device * netdev,int new_mtu)2515 static int lan78xx_change_mtu(struct net_device *netdev, int new_mtu)
2516 {
2517 	struct lan78xx_net *dev = netdev_priv(netdev);
2518 	int max_frame_len = RX_MAX_FRAME_LEN(new_mtu);
2519 	int ret;
2520 
2521 	/* no second zero-length packet read wanted after mtu-sized packets */
2522 	if ((max_frame_len % dev->maxpacket) == 0)
2523 		return -EDOM;
2524 
2525 	ret = usb_autopm_get_interface(dev->intf);
2526 	if (ret < 0)
2527 		return ret;
2528 
2529 	ret = lan78xx_set_rx_max_frame_length(dev, max_frame_len);
2530 	if (!ret)
2531 		netdev->mtu = new_mtu;
2532 
2533 	usb_autopm_put_interface(dev->intf);
2534 
2535 	return ret;
2536 }
2537 
lan78xx_set_mac_addr(struct net_device * netdev,void * p)2538 static int lan78xx_set_mac_addr(struct net_device *netdev, void *p)
2539 {
2540 	struct lan78xx_net *dev = netdev_priv(netdev);
2541 	struct sockaddr *addr = p;
2542 	u32 addr_lo, addr_hi;
2543 
2544 	if (netif_running(netdev))
2545 		return -EBUSY;
2546 
2547 	if (!is_valid_ether_addr(addr->sa_data))
2548 		return -EADDRNOTAVAIL;
2549 
2550 	eth_hw_addr_set(netdev, addr->sa_data);
2551 
2552 	addr_lo = netdev->dev_addr[0] |
2553 		  netdev->dev_addr[1] << 8 |
2554 		  netdev->dev_addr[2] << 16 |
2555 		  netdev->dev_addr[3] << 24;
2556 	addr_hi = netdev->dev_addr[4] |
2557 		  netdev->dev_addr[5] << 8;
2558 
2559 	lan78xx_write_reg(dev, RX_ADDRL, addr_lo);
2560 	lan78xx_write_reg(dev, RX_ADDRH, addr_hi);
2561 
2562 	/* Added to support MAC address changes */
2563 	lan78xx_write_reg(dev, MAF_LO(0), addr_lo);
2564 	lan78xx_write_reg(dev, MAF_HI(0), addr_hi | MAF_HI_VALID_);
2565 
2566 	return 0;
2567 }
2568 
2569 /* Enable or disable Rx checksum offload engine */
lan78xx_set_features(struct net_device * netdev,netdev_features_t features)2570 static int lan78xx_set_features(struct net_device *netdev,
2571 				netdev_features_t features)
2572 {
2573 	struct lan78xx_net *dev = netdev_priv(netdev);
2574 	struct lan78xx_priv *pdata = (struct lan78xx_priv *)(dev->data[0]);
2575 	unsigned long flags;
2576 
2577 	spin_lock_irqsave(&pdata->rfe_ctl_lock, flags);
2578 
2579 	if (features & NETIF_F_RXCSUM) {
2580 		pdata->rfe_ctl |= RFE_CTL_TCPUDP_COE_ | RFE_CTL_IP_COE_;
2581 		pdata->rfe_ctl |= RFE_CTL_ICMP_COE_ | RFE_CTL_IGMP_COE_;
2582 	} else {
2583 		pdata->rfe_ctl &= ~(RFE_CTL_TCPUDP_COE_ | RFE_CTL_IP_COE_);
2584 		pdata->rfe_ctl &= ~(RFE_CTL_ICMP_COE_ | RFE_CTL_IGMP_COE_);
2585 	}
2586 
2587 	if (features & NETIF_F_HW_VLAN_CTAG_RX)
2588 		pdata->rfe_ctl |= RFE_CTL_VLAN_STRIP_;
2589 	else
2590 		pdata->rfe_ctl &= ~RFE_CTL_VLAN_STRIP_;
2591 
2592 	if (features & NETIF_F_HW_VLAN_CTAG_FILTER)
2593 		pdata->rfe_ctl |= RFE_CTL_VLAN_FILTER_;
2594 	else
2595 		pdata->rfe_ctl &= ~RFE_CTL_VLAN_FILTER_;
2596 
2597 	spin_unlock_irqrestore(&pdata->rfe_ctl_lock, flags);
2598 
2599 	lan78xx_write_reg(dev, RFE_CTL, pdata->rfe_ctl);
2600 
2601 	return 0;
2602 }
2603 
lan78xx_deferred_vlan_write(struct work_struct * param)2604 static void lan78xx_deferred_vlan_write(struct work_struct *param)
2605 {
2606 	struct lan78xx_priv *pdata =
2607 			container_of(param, struct lan78xx_priv, set_vlan);
2608 	struct lan78xx_net *dev = pdata->dev;
2609 
2610 	lan78xx_dataport_write(dev, DP_SEL_RSEL_VLAN_DA_, 0,
2611 			       DP_SEL_VHF_VLAN_LEN, pdata->vlan_table);
2612 }
2613 
lan78xx_vlan_rx_add_vid(struct net_device * netdev,__be16 proto,u16 vid)2614 static int lan78xx_vlan_rx_add_vid(struct net_device *netdev,
2615 				   __be16 proto, u16 vid)
2616 {
2617 	struct lan78xx_net *dev = netdev_priv(netdev);
2618 	struct lan78xx_priv *pdata = (struct lan78xx_priv *)(dev->data[0]);
2619 	u16 vid_bit_index;
2620 	u16 vid_dword_index;
2621 
2622 	vid_dword_index = (vid >> 5) & 0x7F;
2623 	vid_bit_index = vid & 0x1F;
2624 
2625 	pdata->vlan_table[vid_dword_index] |= (1 << vid_bit_index);
2626 
2627 	/* defer register writes to a sleepable context */
2628 	schedule_work(&pdata->set_vlan);
2629 
2630 	return 0;
2631 }
2632 
lan78xx_vlan_rx_kill_vid(struct net_device * netdev,__be16 proto,u16 vid)2633 static int lan78xx_vlan_rx_kill_vid(struct net_device *netdev,
2634 				    __be16 proto, u16 vid)
2635 {
2636 	struct lan78xx_net *dev = netdev_priv(netdev);
2637 	struct lan78xx_priv *pdata = (struct lan78xx_priv *)(dev->data[0]);
2638 	u16 vid_bit_index;
2639 	u16 vid_dword_index;
2640 
2641 	vid_dword_index = (vid >> 5) & 0x7F;
2642 	vid_bit_index = vid & 0x1F;
2643 
2644 	pdata->vlan_table[vid_dword_index] &= ~(1 << vid_bit_index);
2645 
2646 	/* defer register writes to a sleepable context */
2647 	schedule_work(&pdata->set_vlan);
2648 
2649 	return 0;
2650 }
2651 
lan78xx_init_ltm(struct lan78xx_net * dev)2652 static void lan78xx_init_ltm(struct lan78xx_net *dev)
2653 {
2654 	int ret;
2655 	u32 buf;
2656 	u32 regs[6] = { 0 };
2657 
2658 	ret = lan78xx_read_reg(dev, USB_CFG1, &buf);
2659 	if (buf & USB_CFG1_LTM_ENABLE_) {
2660 		u8 temp[2];
2661 		/* Get values from EEPROM first */
2662 		if (lan78xx_read_eeprom(dev, 0x3F, 2, temp) == 0) {
2663 			if (temp[0] == 24) {
2664 				ret = lan78xx_read_raw_eeprom(dev,
2665 							      temp[1] * 2,
2666 							      24,
2667 							      (u8 *)regs);
2668 				if (ret < 0)
2669 					return;
2670 			}
2671 		} else if (lan78xx_read_otp(dev, 0x3F, 2, temp) == 0) {
2672 			if (temp[0] == 24) {
2673 				ret = lan78xx_read_raw_otp(dev,
2674 							   temp[1] * 2,
2675 							   24,
2676 							   (u8 *)regs);
2677 				if (ret < 0)
2678 					return;
2679 			}
2680 		}
2681 	}
2682 
2683 	lan78xx_write_reg(dev, LTM_BELT_IDLE0, regs[0]);
2684 	lan78xx_write_reg(dev, LTM_BELT_IDLE1, regs[1]);
2685 	lan78xx_write_reg(dev, LTM_BELT_ACT0, regs[2]);
2686 	lan78xx_write_reg(dev, LTM_BELT_ACT1, regs[3]);
2687 	lan78xx_write_reg(dev, LTM_INACTIVE0, regs[4]);
2688 	lan78xx_write_reg(dev, LTM_INACTIVE1, regs[5]);
2689 }
2690 
lan78xx_urb_config_init(struct lan78xx_net * dev)2691 static int lan78xx_urb_config_init(struct lan78xx_net *dev)
2692 {
2693 	int result = 0;
2694 
2695 	switch (dev->udev->speed) {
2696 	case USB_SPEED_SUPER:
2697 		dev->rx_urb_size = RX_SS_URB_SIZE;
2698 		dev->tx_urb_size = TX_SS_URB_SIZE;
2699 		dev->n_rx_urbs = RX_SS_URB_NUM;
2700 		dev->n_tx_urbs = TX_SS_URB_NUM;
2701 		dev->bulk_in_delay = SS_BULK_IN_DELAY;
2702 		dev->burst_cap = SS_BURST_CAP_SIZE / SS_USB_PKT_SIZE;
2703 		break;
2704 	case USB_SPEED_HIGH:
2705 		dev->rx_urb_size = RX_HS_URB_SIZE;
2706 		dev->tx_urb_size = TX_HS_URB_SIZE;
2707 		dev->n_rx_urbs = RX_HS_URB_NUM;
2708 		dev->n_tx_urbs = TX_HS_URB_NUM;
2709 		dev->bulk_in_delay = HS_BULK_IN_DELAY;
2710 		dev->burst_cap = HS_BURST_CAP_SIZE / HS_USB_PKT_SIZE;
2711 		break;
2712 	case USB_SPEED_FULL:
2713 		dev->rx_urb_size = RX_FS_URB_SIZE;
2714 		dev->tx_urb_size = TX_FS_URB_SIZE;
2715 		dev->n_rx_urbs = RX_FS_URB_NUM;
2716 		dev->n_tx_urbs = TX_FS_URB_NUM;
2717 		dev->bulk_in_delay = FS_BULK_IN_DELAY;
2718 		dev->burst_cap = FS_BURST_CAP_SIZE / FS_USB_PKT_SIZE;
2719 		break;
2720 	default:
2721 		netdev_warn(dev->net, "USB bus speed not supported\n");
2722 		result = -EIO;
2723 		break;
2724 	}
2725 
2726 	return result;
2727 }
2728 
lan78xx_start_hw(struct lan78xx_net * dev,u32 reg,u32 hw_enable)2729 static int lan78xx_start_hw(struct lan78xx_net *dev, u32 reg, u32 hw_enable)
2730 {
2731 	return lan78xx_update_reg(dev, reg, hw_enable, hw_enable);
2732 }
2733 
lan78xx_stop_hw(struct lan78xx_net * dev,u32 reg,u32 hw_enabled,u32 hw_disabled)2734 static int lan78xx_stop_hw(struct lan78xx_net *dev, u32 reg, u32 hw_enabled,
2735 			   u32 hw_disabled)
2736 {
2737 	unsigned long timeout;
2738 	bool stopped = true;
2739 	int ret;
2740 	u32 buf;
2741 
2742 	/* Stop the h/w block (if not already stopped) */
2743 
2744 	ret = lan78xx_read_reg(dev, reg, &buf);
2745 	if (ret < 0)
2746 		return ret;
2747 
2748 	if (buf & hw_enabled) {
2749 		buf &= ~hw_enabled;
2750 
2751 		ret = lan78xx_write_reg(dev, reg, buf);
2752 		if (ret < 0)
2753 			return ret;
2754 
2755 		stopped = false;
2756 		timeout = jiffies + HW_DISABLE_TIMEOUT;
2757 		do  {
2758 			ret = lan78xx_read_reg(dev, reg, &buf);
2759 			if (ret < 0)
2760 				return ret;
2761 
2762 			if (buf & hw_disabled)
2763 				stopped = true;
2764 			else
2765 				msleep(HW_DISABLE_DELAY_MS);
2766 		} while (!stopped && !time_after(jiffies, timeout));
2767 	}
2768 
2769 	ret = stopped ? 0 : -ETIME;
2770 
2771 	return ret;
2772 }
2773 
lan78xx_flush_fifo(struct lan78xx_net * dev,u32 reg,u32 fifo_flush)2774 static int lan78xx_flush_fifo(struct lan78xx_net *dev, u32 reg, u32 fifo_flush)
2775 {
2776 	return lan78xx_update_reg(dev, reg, fifo_flush, fifo_flush);
2777 }
2778 
lan78xx_start_tx_path(struct lan78xx_net * dev)2779 static int lan78xx_start_tx_path(struct lan78xx_net *dev)
2780 {
2781 	int ret;
2782 
2783 	netif_dbg(dev, drv, dev->net, "start tx path");
2784 
2785 	/* Start the MAC transmitter */
2786 
2787 	ret = lan78xx_start_hw(dev, MAC_TX, MAC_TX_TXEN_);
2788 	if (ret < 0)
2789 		return ret;
2790 
2791 	/* Start the Tx FIFO */
2792 
2793 	ret = lan78xx_start_hw(dev, FCT_TX_CTL, FCT_TX_CTL_EN_);
2794 	if (ret < 0)
2795 		return ret;
2796 
2797 	return 0;
2798 }
2799 
lan78xx_stop_tx_path(struct lan78xx_net * dev)2800 static int lan78xx_stop_tx_path(struct lan78xx_net *dev)
2801 {
2802 	int ret;
2803 
2804 	netif_dbg(dev, drv, dev->net, "stop tx path");
2805 
2806 	/* Stop the Tx FIFO */
2807 
2808 	ret = lan78xx_stop_hw(dev, FCT_TX_CTL, FCT_TX_CTL_EN_, FCT_TX_CTL_DIS_);
2809 	if (ret < 0)
2810 		return ret;
2811 
2812 	/* Stop the MAC transmitter */
2813 
2814 	ret = lan78xx_stop_hw(dev, MAC_TX, MAC_TX_TXEN_, MAC_TX_TXD_);
2815 	if (ret < 0)
2816 		return ret;
2817 
2818 	return 0;
2819 }
2820 
2821 /* The caller must ensure the Tx path is stopped before calling
2822  * lan78xx_flush_tx_fifo().
2823  */
lan78xx_flush_tx_fifo(struct lan78xx_net * dev)2824 static int lan78xx_flush_tx_fifo(struct lan78xx_net *dev)
2825 {
2826 	return lan78xx_flush_fifo(dev, FCT_TX_CTL, FCT_TX_CTL_RST_);
2827 }
2828 
lan78xx_start_rx_path(struct lan78xx_net * dev)2829 static int lan78xx_start_rx_path(struct lan78xx_net *dev)
2830 {
2831 	int ret;
2832 
2833 	netif_dbg(dev, drv, dev->net, "start rx path");
2834 
2835 	/* Start the Rx FIFO */
2836 
2837 	ret = lan78xx_start_hw(dev, FCT_RX_CTL, FCT_RX_CTL_EN_);
2838 	if (ret < 0)
2839 		return ret;
2840 
2841 	/* Start the MAC receiver*/
2842 
2843 	ret = lan78xx_start_hw(dev, MAC_RX, MAC_RX_RXEN_);
2844 	if (ret < 0)
2845 		return ret;
2846 
2847 	return 0;
2848 }
2849 
lan78xx_stop_rx_path(struct lan78xx_net * dev)2850 static int lan78xx_stop_rx_path(struct lan78xx_net *dev)
2851 {
2852 	int ret;
2853 
2854 	netif_dbg(dev, drv, dev->net, "stop rx path");
2855 
2856 	/* Stop the MAC receiver */
2857 
2858 	ret = lan78xx_stop_hw(dev, MAC_RX, MAC_RX_RXEN_, MAC_RX_RXD_);
2859 	if (ret < 0)
2860 		return ret;
2861 
2862 	/* Stop the Rx FIFO */
2863 
2864 	ret = lan78xx_stop_hw(dev, FCT_RX_CTL, FCT_RX_CTL_EN_, FCT_RX_CTL_DIS_);
2865 	if (ret < 0)
2866 		return ret;
2867 
2868 	return 0;
2869 }
2870 
2871 /* The caller must ensure the Rx path is stopped before calling
2872  * lan78xx_flush_rx_fifo().
2873  */
lan78xx_flush_rx_fifo(struct lan78xx_net * dev)2874 static int lan78xx_flush_rx_fifo(struct lan78xx_net *dev)
2875 {
2876 	return lan78xx_flush_fifo(dev, FCT_RX_CTL, FCT_RX_CTL_RST_);
2877 }
2878 
lan78xx_reset(struct lan78xx_net * dev)2879 static int lan78xx_reset(struct lan78xx_net *dev)
2880 {
2881 	struct lan78xx_priv *pdata = (struct lan78xx_priv *)(dev->data[0]);
2882 	unsigned long timeout;
2883 	int ret;
2884 	u32 buf;
2885 	u8 sig;
2886 
2887 	ret = lan78xx_read_reg(dev, HW_CFG, &buf);
2888 	if (ret < 0)
2889 		return ret;
2890 
2891 	buf |= HW_CFG_LRST_;
2892 
2893 	ret = lan78xx_write_reg(dev, HW_CFG, buf);
2894 	if (ret < 0)
2895 		return ret;
2896 
2897 	timeout = jiffies + HZ;
2898 	do {
2899 		mdelay(1);
2900 		ret = lan78xx_read_reg(dev, HW_CFG, &buf);
2901 		if (ret < 0)
2902 			return ret;
2903 
2904 		if (time_after(jiffies, timeout)) {
2905 			netdev_warn(dev->net,
2906 				    "timeout on completion of LiteReset");
2907 			ret = -ETIMEDOUT;
2908 			return ret;
2909 		}
2910 	} while (buf & HW_CFG_LRST_);
2911 
2912 	lan78xx_init_mac_address(dev);
2913 
2914 	/* save DEVID for later usage */
2915 	ret = lan78xx_read_reg(dev, ID_REV, &buf);
2916 	if (ret < 0)
2917 		return ret;
2918 
2919 	dev->chipid = (buf & ID_REV_CHIP_ID_MASK_) >> 16;
2920 	dev->chiprev = buf & ID_REV_CHIP_REV_MASK_;
2921 
2922 	/* Respond to the IN token with a NAK */
2923 	ret = lan78xx_read_reg(dev, USB_CFG0, &buf);
2924 	if (ret < 0)
2925 		return ret;
2926 
2927 	buf |= USB_CFG_BIR_;
2928 
2929 	ret = lan78xx_write_reg(dev, USB_CFG0, buf);
2930 	if (ret < 0)
2931 		return ret;
2932 
2933 	/* Init LTM */
2934 	lan78xx_init_ltm(dev);
2935 
2936 	ret = lan78xx_write_reg(dev, BURST_CAP, dev->burst_cap);
2937 	if (ret < 0)
2938 		return ret;
2939 
2940 	ret = lan78xx_write_reg(dev, BULK_IN_DLY, dev->bulk_in_delay);
2941 	if (ret < 0)
2942 		return ret;
2943 
2944 	ret = lan78xx_read_reg(dev, HW_CFG, &buf);
2945 	if (ret < 0)
2946 		return ret;
2947 
2948 	buf |= HW_CFG_MEF_;
2949 
2950 	ret = lan78xx_write_reg(dev, HW_CFG, buf);
2951 	if (ret < 0)
2952 		return ret;
2953 
2954 	ret = lan78xx_read_reg(dev, USB_CFG0, &buf);
2955 	if (ret < 0)
2956 		return ret;
2957 
2958 	buf |= USB_CFG_BCE_;
2959 
2960 	ret = lan78xx_write_reg(dev, USB_CFG0, buf);
2961 	if (ret < 0)
2962 		return ret;
2963 
2964 	/* set FIFO sizes */
2965 	buf = (MAX_RX_FIFO_SIZE - 512) / 512;
2966 
2967 	ret = lan78xx_write_reg(dev, FCT_RX_FIFO_END, buf);
2968 	if (ret < 0)
2969 		return ret;
2970 
2971 	buf = (MAX_TX_FIFO_SIZE - 512) / 512;
2972 
2973 	ret = lan78xx_write_reg(dev, FCT_TX_FIFO_END, buf);
2974 	if (ret < 0)
2975 		return ret;
2976 
2977 	ret = lan78xx_write_reg(dev, INT_STS, INT_STS_CLEAR_ALL_);
2978 	if (ret < 0)
2979 		return ret;
2980 
2981 	ret = lan78xx_write_reg(dev, FLOW, 0);
2982 	if (ret < 0)
2983 		return ret;
2984 
2985 	ret = lan78xx_write_reg(dev, FCT_FLOW, 0);
2986 	if (ret < 0)
2987 		return ret;
2988 
2989 	/* Don't need rfe_ctl_lock during initialisation */
2990 	ret = lan78xx_read_reg(dev, RFE_CTL, &pdata->rfe_ctl);
2991 	if (ret < 0)
2992 		return ret;
2993 
2994 	pdata->rfe_ctl |= RFE_CTL_BCAST_EN_ | RFE_CTL_DA_PERFECT_;
2995 
2996 	ret = lan78xx_write_reg(dev, RFE_CTL, pdata->rfe_ctl);
2997 	if (ret < 0)
2998 		return ret;
2999 
3000 	/* Enable or disable checksum offload engines */
3001 	ret = lan78xx_set_features(dev->net, dev->net->features);
3002 	if (ret < 0)
3003 		return ret;
3004 
3005 	lan78xx_set_multicast(dev->net);
3006 
3007 	/* reset PHY */
3008 	ret = lan78xx_read_reg(dev, PMT_CTL, &buf);
3009 	if (ret < 0)
3010 		return ret;
3011 
3012 	buf |= PMT_CTL_PHY_RST_;
3013 
3014 	ret = lan78xx_write_reg(dev, PMT_CTL, buf);
3015 	if (ret < 0)
3016 		return ret;
3017 
3018 	timeout = jiffies + HZ;
3019 	do {
3020 		mdelay(1);
3021 		ret = lan78xx_read_reg(dev, PMT_CTL, &buf);
3022 		if (ret < 0)
3023 			return ret;
3024 
3025 		if (time_after(jiffies, timeout)) {
3026 			netdev_warn(dev->net, "timeout waiting for PHY Reset");
3027 			ret = -ETIMEDOUT;
3028 			return ret;
3029 		}
3030 	} while ((buf & PMT_CTL_PHY_RST_) || !(buf & PMT_CTL_READY_));
3031 
3032 	ret = lan78xx_read_reg(dev, MAC_CR, &buf);
3033 	if (ret < 0)
3034 		return ret;
3035 
3036 	/* LAN7801 only has RGMII mode */
3037 	if (dev->chipid == ID_REV_CHIP_ID_7801_)
3038 		buf &= ~MAC_CR_GMII_EN_;
3039 
3040 	if (dev->chipid == ID_REV_CHIP_ID_7800_ ||
3041 	    dev->chipid == ID_REV_CHIP_ID_7850_) {
3042 		ret = lan78xx_read_raw_eeprom(dev, 0, 1, &sig);
3043 		if (!ret && sig != EEPROM_INDICATOR) {
3044 			/* Implies there is no external eeprom. Set mac speed */
3045 			netdev_info(dev->net, "No External EEPROM. Setting MAC Speed\n");
3046 			buf |= MAC_CR_AUTO_DUPLEX_ | MAC_CR_AUTO_SPEED_;
3047 		}
3048 	}
3049 	ret = lan78xx_write_reg(dev, MAC_CR, buf);
3050 	if (ret < 0)
3051 		return ret;
3052 
3053 	ret = lan78xx_set_rx_max_frame_length(dev,
3054 					      RX_MAX_FRAME_LEN(dev->net->mtu));
3055 
3056 	return ret;
3057 }
3058 
lan78xx_init_stats(struct lan78xx_net * dev)3059 static void lan78xx_init_stats(struct lan78xx_net *dev)
3060 {
3061 	u32 *p;
3062 	int i;
3063 
3064 	/* initialize for stats update
3065 	 * some counters are 20bits and some are 32bits
3066 	 */
3067 	p = (u32 *)&dev->stats.rollover_max;
3068 	for (i = 0; i < (sizeof(dev->stats.rollover_max) / (sizeof(u32))); i++)
3069 		p[i] = 0xFFFFF;
3070 
3071 	dev->stats.rollover_max.rx_unicast_byte_count = 0xFFFFFFFF;
3072 	dev->stats.rollover_max.rx_broadcast_byte_count = 0xFFFFFFFF;
3073 	dev->stats.rollover_max.rx_multicast_byte_count = 0xFFFFFFFF;
3074 	dev->stats.rollover_max.eee_rx_lpi_transitions = 0xFFFFFFFF;
3075 	dev->stats.rollover_max.eee_rx_lpi_time = 0xFFFFFFFF;
3076 	dev->stats.rollover_max.tx_unicast_byte_count = 0xFFFFFFFF;
3077 	dev->stats.rollover_max.tx_broadcast_byte_count = 0xFFFFFFFF;
3078 	dev->stats.rollover_max.tx_multicast_byte_count = 0xFFFFFFFF;
3079 	dev->stats.rollover_max.eee_tx_lpi_transitions = 0xFFFFFFFF;
3080 	dev->stats.rollover_max.eee_tx_lpi_time = 0xFFFFFFFF;
3081 
3082 	set_bit(EVENT_STAT_UPDATE, &dev->flags);
3083 }
3084 
lan78xx_open(struct net_device * net)3085 static int lan78xx_open(struct net_device *net)
3086 {
3087 	struct lan78xx_net *dev = netdev_priv(net);
3088 	int ret;
3089 
3090 	netif_dbg(dev, ifup, dev->net, "open device");
3091 
3092 	ret = usb_autopm_get_interface(dev->intf);
3093 	if (ret < 0)
3094 		return ret;
3095 
3096 	mutex_lock(&dev->dev_mutex);
3097 
3098 	phy_start(net->phydev);
3099 
3100 	netif_dbg(dev, ifup, dev->net, "phy initialised successfully");
3101 
3102 	/* for Link Check */
3103 	if (dev->urb_intr) {
3104 		ret = usb_submit_urb(dev->urb_intr, GFP_KERNEL);
3105 		if (ret < 0) {
3106 			netif_err(dev, ifup, dev->net,
3107 				  "intr submit %d\n", ret);
3108 			goto done;
3109 		}
3110 	}
3111 
3112 	ret = lan78xx_flush_rx_fifo(dev);
3113 	if (ret < 0)
3114 		goto done;
3115 	ret = lan78xx_flush_tx_fifo(dev);
3116 	if (ret < 0)
3117 		goto done;
3118 
3119 	ret = lan78xx_start_tx_path(dev);
3120 	if (ret < 0)
3121 		goto done;
3122 	ret = lan78xx_start_rx_path(dev);
3123 	if (ret < 0)
3124 		goto done;
3125 
3126 	lan78xx_init_stats(dev);
3127 
3128 	set_bit(EVENT_DEV_OPEN, &dev->flags);
3129 
3130 	netif_start_queue(net);
3131 
3132 	dev->link_on = false;
3133 
3134 	napi_enable(&dev->napi);
3135 
3136 	lan78xx_defer_kevent(dev, EVENT_LINK_RESET);
3137 done:
3138 	mutex_unlock(&dev->dev_mutex);
3139 
3140 	usb_autopm_put_interface(dev->intf);
3141 
3142 	return ret;
3143 }
3144 
lan78xx_terminate_urbs(struct lan78xx_net * dev)3145 static void lan78xx_terminate_urbs(struct lan78xx_net *dev)
3146 {
3147 	DECLARE_WAIT_QUEUE_HEAD_ONSTACK(unlink_wakeup);
3148 	DECLARE_WAITQUEUE(wait, current);
3149 	int temp;
3150 
3151 	/* ensure there are no more active urbs */
3152 	add_wait_queue(&unlink_wakeup, &wait);
3153 	set_current_state(TASK_UNINTERRUPTIBLE);
3154 	dev->wait = &unlink_wakeup;
3155 	temp = unlink_urbs(dev, &dev->txq) + unlink_urbs(dev, &dev->rxq);
3156 
3157 	/* maybe wait for deletions to finish. */
3158 	while (!skb_queue_empty(&dev->rxq) ||
3159 	       !skb_queue_empty(&dev->txq)) {
3160 		schedule_timeout(msecs_to_jiffies(UNLINK_TIMEOUT_MS));
3161 		set_current_state(TASK_UNINTERRUPTIBLE);
3162 		netif_dbg(dev, ifdown, dev->net,
3163 			  "waited for %d urb completions", temp);
3164 	}
3165 	set_current_state(TASK_RUNNING);
3166 	dev->wait = NULL;
3167 	remove_wait_queue(&unlink_wakeup, &wait);
3168 
3169 	/* empty Rx done, Rx overflow and Tx pend queues
3170 	 */
3171 	while (!skb_queue_empty(&dev->rxq_done)) {
3172 		struct sk_buff *skb = skb_dequeue(&dev->rxq_done);
3173 
3174 		lan78xx_release_rx_buf(dev, skb);
3175 	}
3176 
3177 	skb_queue_purge(&dev->rxq_overflow);
3178 	skb_queue_purge(&dev->txq_pend);
3179 }
3180 
lan78xx_stop(struct net_device * net)3181 static int lan78xx_stop(struct net_device *net)
3182 {
3183 	struct lan78xx_net *dev = netdev_priv(net);
3184 
3185 	netif_dbg(dev, ifup, dev->net, "stop device");
3186 
3187 	mutex_lock(&dev->dev_mutex);
3188 
3189 	if (timer_pending(&dev->stat_monitor))
3190 		del_timer_sync(&dev->stat_monitor);
3191 
3192 	clear_bit(EVENT_DEV_OPEN, &dev->flags);
3193 	netif_stop_queue(net);
3194 	napi_disable(&dev->napi);
3195 
3196 	lan78xx_terminate_urbs(dev);
3197 
3198 	netif_info(dev, ifdown, dev->net,
3199 		   "stop stats: rx/tx %lu/%lu, errs %lu/%lu\n",
3200 		   net->stats.rx_packets, net->stats.tx_packets,
3201 		   net->stats.rx_errors, net->stats.tx_errors);
3202 
3203 	/* ignore errors that occur stopping the Tx and Rx data paths */
3204 	lan78xx_stop_tx_path(dev);
3205 	lan78xx_stop_rx_path(dev);
3206 
3207 	if (net->phydev)
3208 		phy_stop(net->phydev);
3209 
3210 	usb_kill_urb(dev->urb_intr);
3211 
3212 	/* deferred work (task, timer, softirq) must also stop.
3213 	 * can't flush_scheduled_work() until we drop rtnl (later),
3214 	 * else workers could deadlock; so make workers a NOP.
3215 	 */
3216 	clear_bit(EVENT_TX_HALT, &dev->flags);
3217 	clear_bit(EVENT_RX_HALT, &dev->flags);
3218 	clear_bit(EVENT_LINK_RESET, &dev->flags);
3219 	clear_bit(EVENT_STAT_UPDATE, &dev->flags);
3220 
3221 	cancel_delayed_work_sync(&dev->wq);
3222 
3223 	usb_autopm_put_interface(dev->intf);
3224 
3225 	mutex_unlock(&dev->dev_mutex);
3226 
3227 	return 0;
3228 }
3229 
defer_bh(struct lan78xx_net * dev,struct sk_buff * skb,struct sk_buff_head * list,enum skb_state state)3230 static enum skb_state defer_bh(struct lan78xx_net *dev, struct sk_buff *skb,
3231 			       struct sk_buff_head *list, enum skb_state state)
3232 {
3233 	unsigned long flags;
3234 	enum skb_state old_state;
3235 	struct skb_data *entry = (struct skb_data *)skb->cb;
3236 
3237 	spin_lock_irqsave(&list->lock, flags);
3238 	old_state = entry->state;
3239 	entry->state = state;
3240 
3241 	__skb_unlink(skb, list);
3242 	spin_unlock(&list->lock);
3243 	spin_lock(&dev->rxq_done.lock);
3244 
3245 	__skb_queue_tail(&dev->rxq_done, skb);
3246 	if (skb_queue_len(&dev->rxq_done) == 1)
3247 		napi_schedule(&dev->napi);
3248 
3249 	spin_unlock_irqrestore(&dev->rxq_done.lock, flags);
3250 
3251 	return old_state;
3252 }
3253 
tx_complete(struct urb * urb)3254 static void tx_complete(struct urb *urb)
3255 {
3256 	struct sk_buff *skb = (struct sk_buff *)urb->context;
3257 	struct skb_data *entry = (struct skb_data *)skb->cb;
3258 	struct lan78xx_net *dev = entry->dev;
3259 
3260 	if (urb->status == 0) {
3261 		dev->net->stats.tx_packets += entry->num_of_packet;
3262 		dev->net->stats.tx_bytes += entry->length;
3263 	} else {
3264 		dev->net->stats.tx_errors += entry->num_of_packet;
3265 
3266 		switch (urb->status) {
3267 		case -EPIPE:
3268 			lan78xx_defer_kevent(dev, EVENT_TX_HALT);
3269 			break;
3270 
3271 		/* software-driven interface shutdown */
3272 		case -ECONNRESET:
3273 		case -ESHUTDOWN:
3274 			netif_dbg(dev, tx_err, dev->net,
3275 				  "tx err interface gone %d\n",
3276 				  entry->urb->status);
3277 			break;
3278 
3279 		case -EPROTO:
3280 		case -ETIME:
3281 		case -EILSEQ:
3282 			netif_stop_queue(dev->net);
3283 			netif_dbg(dev, tx_err, dev->net,
3284 				  "tx err queue stopped %d\n",
3285 				  entry->urb->status);
3286 			break;
3287 		default:
3288 			netif_dbg(dev, tx_err, dev->net,
3289 				  "unknown tx err %d\n",
3290 				  entry->urb->status);
3291 			break;
3292 		}
3293 	}
3294 
3295 	usb_autopm_put_interface_async(dev->intf);
3296 
3297 	skb_unlink(skb, &dev->txq);
3298 
3299 	lan78xx_release_tx_buf(dev, skb);
3300 
3301 	/* Re-schedule NAPI if Tx data pending but no URBs in progress.
3302 	 */
3303 	if (skb_queue_empty(&dev->txq) &&
3304 	    !skb_queue_empty(&dev->txq_pend))
3305 		napi_schedule(&dev->napi);
3306 }
3307 
lan78xx_queue_skb(struct sk_buff_head * list,struct sk_buff * newsk,enum skb_state state)3308 static void lan78xx_queue_skb(struct sk_buff_head *list,
3309 			      struct sk_buff *newsk, enum skb_state state)
3310 {
3311 	struct skb_data *entry = (struct skb_data *)newsk->cb;
3312 
3313 	__skb_queue_tail(list, newsk);
3314 	entry->state = state;
3315 }
3316 
lan78xx_tx_urb_space(struct lan78xx_net * dev)3317 static unsigned int lan78xx_tx_urb_space(struct lan78xx_net *dev)
3318 {
3319 	return skb_queue_len(&dev->txq_free) * dev->tx_urb_size;
3320 }
3321 
lan78xx_tx_pend_data_len(struct lan78xx_net * dev)3322 static unsigned int lan78xx_tx_pend_data_len(struct lan78xx_net *dev)
3323 {
3324 	return dev->tx_pend_data_len;
3325 }
3326 
lan78xx_tx_pend_skb_add(struct lan78xx_net * dev,struct sk_buff * skb,unsigned int * tx_pend_data_len)3327 static void lan78xx_tx_pend_skb_add(struct lan78xx_net *dev,
3328 				    struct sk_buff *skb,
3329 				    unsigned int *tx_pend_data_len)
3330 {
3331 	unsigned long flags;
3332 
3333 	spin_lock_irqsave(&dev->txq_pend.lock, flags);
3334 
3335 	__skb_queue_tail(&dev->txq_pend, skb);
3336 
3337 	dev->tx_pend_data_len += skb->len;
3338 	*tx_pend_data_len = dev->tx_pend_data_len;
3339 
3340 	spin_unlock_irqrestore(&dev->txq_pend.lock, flags);
3341 }
3342 
lan78xx_tx_pend_skb_head_add(struct lan78xx_net * dev,struct sk_buff * skb,unsigned int * tx_pend_data_len)3343 static void lan78xx_tx_pend_skb_head_add(struct lan78xx_net *dev,
3344 					 struct sk_buff *skb,
3345 					 unsigned int *tx_pend_data_len)
3346 {
3347 	unsigned long flags;
3348 
3349 	spin_lock_irqsave(&dev->txq_pend.lock, flags);
3350 
3351 	__skb_queue_head(&dev->txq_pend, skb);
3352 
3353 	dev->tx_pend_data_len += skb->len;
3354 	*tx_pend_data_len = dev->tx_pend_data_len;
3355 
3356 	spin_unlock_irqrestore(&dev->txq_pend.lock, flags);
3357 }
3358 
lan78xx_tx_pend_skb_get(struct lan78xx_net * dev,struct sk_buff ** skb,unsigned int * tx_pend_data_len)3359 static void lan78xx_tx_pend_skb_get(struct lan78xx_net *dev,
3360 				    struct sk_buff **skb,
3361 				    unsigned int *tx_pend_data_len)
3362 {
3363 	unsigned long flags;
3364 
3365 	spin_lock_irqsave(&dev->txq_pend.lock, flags);
3366 
3367 	*skb = __skb_dequeue(&dev->txq_pend);
3368 	if (*skb)
3369 		dev->tx_pend_data_len -= (*skb)->len;
3370 	*tx_pend_data_len = dev->tx_pend_data_len;
3371 
3372 	spin_unlock_irqrestore(&dev->txq_pend.lock, flags);
3373 }
3374 
3375 static netdev_tx_t
lan78xx_start_xmit(struct sk_buff * skb,struct net_device * net)3376 lan78xx_start_xmit(struct sk_buff *skb, struct net_device *net)
3377 {
3378 	struct lan78xx_net *dev = netdev_priv(net);
3379 	unsigned int tx_pend_data_len;
3380 
3381 	if (test_bit(EVENT_DEV_ASLEEP, &dev->flags))
3382 		schedule_delayed_work(&dev->wq, 0);
3383 
3384 	skb_tx_timestamp(skb);
3385 
3386 	lan78xx_tx_pend_skb_add(dev, skb, &tx_pend_data_len);
3387 
3388 	/* Set up a Tx URB if none is in progress */
3389 
3390 	if (skb_queue_empty(&dev->txq))
3391 		napi_schedule(&dev->napi);
3392 
3393 	/* Stop stack Tx queue if we have enough data to fill
3394 	 * all the free Tx URBs.
3395 	 */
3396 	if (tx_pend_data_len > lan78xx_tx_urb_space(dev)) {
3397 		netif_stop_queue(net);
3398 
3399 		netif_dbg(dev, hw, dev->net, "tx data len: %u, urb space %u",
3400 			  tx_pend_data_len, lan78xx_tx_urb_space(dev));
3401 
3402 		/* Kick off transmission of pending data */
3403 
3404 		if (!skb_queue_empty(&dev->txq_free))
3405 			napi_schedule(&dev->napi);
3406 	}
3407 
3408 	return NETDEV_TX_OK;
3409 }
3410 
lan78xx_bind(struct lan78xx_net * dev,struct usb_interface * intf)3411 static int lan78xx_bind(struct lan78xx_net *dev, struct usb_interface *intf)
3412 {
3413 	struct lan78xx_priv *pdata = NULL;
3414 	int ret;
3415 	int i;
3416 
3417 	dev->data[0] = (unsigned long)kzalloc(sizeof(*pdata), GFP_KERNEL);
3418 
3419 	pdata = (struct lan78xx_priv *)(dev->data[0]);
3420 	if (!pdata) {
3421 		netdev_warn(dev->net, "Unable to allocate lan78xx_priv");
3422 		return -ENOMEM;
3423 	}
3424 
3425 	pdata->dev = dev;
3426 
3427 	spin_lock_init(&pdata->rfe_ctl_lock);
3428 	mutex_init(&pdata->dataport_mutex);
3429 
3430 	INIT_WORK(&pdata->set_multicast, lan78xx_deferred_multicast_write);
3431 
3432 	for (i = 0; i < DP_SEL_VHF_VLAN_LEN; i++)
3433 		pdata->vlan_table[i] = 0;
3434 
3435 	INIT_WORK(&pdata->set_vlan, lan78xx_deferred_vlan_write);
3436 
3437 	dev->net->features = 0;
3438 
3439 	if (DEFAULT_TX_CSUM_ENABLE)
3440 		dev->net->features |= NETIF_F_HW_CSUM;
3441 
3442 	if (DEFAULT_RX_CSUM_ENABLE)
3443 		dev->net->features |= NETIF_F_RXCSUM;
3444 
3445 	if (DEFAULT_TSO_CSUM_ENABLE)
3446 		dev->net->features |= NETIF_F_TSO | NETIF_F_TSO6 | NETIF_F_SG;
3447 
3448 	if (DEFAULT_VLAN_RX_OFFLOAD)
3449 		dev->net->features |= NETIF_F_HW_VLAN_CTAG_RX;
3450 
3451 	if (DEFAULT_VLAN_FILTER_ENABLE)
3452 		dev->net->features |= NETIF_F_HW_VLAN_CTAG_FILTER;
3453 
3454 	dev->net->hw_features = dev->net->features;
3455 
3456 	ret = lan78xx_setup_irq_domain(dev);
3457 	if (ret < 0) {
3458 		netdev_warn(dev->net,
3459 			    "lan78xx_setup_irq_domain() failed : %d", ret);
3460 		goto out1;
3461 	}
3462 
3463 	/* Init all registers */
3464 	ret = lan78xx_reset(dev);
3465 	if (ret) {
3466 		netdev_warn(dev->net, "Registers INIT FAILED....");
3467 		goto out2;
3468 	}
3469 
3470 	ret = lan78xx_mdio_init(dev);
3471 	if (ret) {
3472 		netdev_warn(dev->net, "MDIO INIT FAILED.....");
3473 		goto out2;
3474 	}
3475 
3476 	dev->net->flags |= IFF_MULTICAST;
3477 
3478 	pdata->wol = WAKE_MAGIC;
3479 
3480 	return ret;
3481 
3482 out2:
3483 	lan78xx_remove_irq_domain(dev);
3484 
3485 out1:
3486 	netdev_warn(dev->net, "Bind routine FAILED");
3487 	cancel_work_sync(&pdata->set_multicast);
3488 	cancel_work_sync(&pdata->set_vlan);
3489 	kfree(pdata);
3490 	return ret;
3491 }
3492 
lan78xx_unbind(struct lan78xx_net * dev,struct usb_interface * intf)3493 static void lan78xx_unbind(struct lan78xx_net *dev, struct usb_interface *intf)
3494 {
3495 	struct lan78xx_priv *pdata = (struct lan78xx_priv *)(dev->data[0]);
3496 
3497 	lan78xx_remove_irq_domain(dev);
3498 
3499 	lan78xx_remove_mdio(dev);
3500 
3501 	if (pdata) {
3502 		cancel_work_sync(&pdata->set_multicast);
3503 		cancel_work_sync(&pdata->set_vlan);
3504 		netif_dbg(dev, ifdown, dev->net, "free pdata");
3505 		kfree(pdata);
3506 		pdata = NULL;
3507 		dev->data[0] = 0;
3508 	}
3509 }
3510 
lan78xx_rx_csum_offload(struct lan78xx_net * dev,struct sk_buff * skb,u32 rx_cmd_a,u32 rx_cmd_b)3511 static void lan78xx_rx_csum_offload(struct lan78xx_net *dev,
3512 				    struct sk_buff *skb,
3513 				    u32 rx_cmd_a, u32 rx_cmd_b)
3514 {
3515 	/* HW Checksum offload appears to be flawed if used when not stripping
3516 	 * VLAN headers. Drop back to S/W checksums under these conditions.
3517 	 */
3518 	if (!(dev->net->features & NETIF_F_RXCSUM) ||
3519 	    unlikely(rx_cmd_a & RX_CMD_A_ICSM_) ||
3520 	    ((rx_cmd_a & RX_CMD_A_FVTG_) &&
3521 	     !(dev->net->features & NETIF_F_HW_VLAN_CTAG_RX))) {
3522 		skb->ip_summed = CHECKSUM_NONE;
3523 	} else {
3524 		skb->csum = ntohs((u16)(rx_cmd_b >> RX_CMD_B_CSUM_SHIFT_));
3525 		skb->ip_summed = CHECKSUM_COMPLETE;
3526 	}
3527 }
3528 
lan78xx_rx_vlan_offload(struct lan78xx_net * dev,struct sk_buff * skb,u32 rx_cmd_a,u32 rx_cmd_b)3529 static void lan78xx_rx_vlan_offload(struct lan78xx_net *dev,
3530 				    struct sk_buff *skb,
3531 				    u32 rx_cmd_a, u32 rx_cmd_b)
3532 {
3533 	if ((dev->net->features & NETIF_F_HW_VLAN_CTAG_RX) &&
3534 	    (rx_cmd_a & RX_CMD_A_FVTG_))
3535 		__vlan_hwaccel_put_tag(skb, htons(ETH_P_8021Q),
3536 				       (rx_cmd_b & 0xffff));
3537 }
3538 
lan78xx_skb_return(struct lan78xx_net * dev,struct sk_buff * skb)3539 static void lan78xx_skb_return(struct lan78xx_net *dev, struct sk_buff *skb)
3540 {
3541 	dev->net->stats.rx_packets++;
3542 	dev->net->stats.rx_bytes += skb->len;
3543 
3544 	skb->protocol = eth_type_trans(skb, dev->net);
3545 
3546 	netif_dbg(dev, rx_status, dev->net, "< rx, len %zu, type 0x%x\n",
3547 		  skb->len + sizeof(struct ethhdr), skb->protocol);
3548 	memset(skb->cb, 0, sizeof(struct skb_data));
3549 
3550 	if (skb_defer_rx_timestamp(skb))
3551 		return;
3552 
3553 	napi_gro_receive(&dev->napi, skb);
3554 }
3555 
lan78xx_rx(struct lan78xx_net * dev,struct sk_buff * skb,int budget,int * work_done)3556 static int lan78xx_rx(struct lan78xx_net *dev, struct sk_buff *skb,
3557 		      int budget, int *work_done)
3558 {
3559 	if (skb->len < RX_SKB_MIN_LEN)
3560 		return 0;
3561 
3562 	/* Extract frames from the URB buffer and pass each one to
3563 	 * the stack in a new NAPI SKB.
3564 	 */
3565 	while (skb->len > 0) {
3566 		u32 rx_cmd_a, rx_cmd_b, align_count, size;
3567 		u16 rx_cmd_c;
3568 		unsigned char *packet;
3569 
3570 		rx_cmd_a = get_unaligned_le32(skb->data);
3571 		skb_pull(skb, sizeof(rx_cmd_a));
3572 
3573 		rx_cmd_b = get_unaligned_le32(skb->data);
3574 		skb_pull(skb, sizeof(rx_cmd_b));
3575 
3576 		rx_cmd_c = get_unaligned_le16(skb->data);
3577 		skb_pull(skb, sizeof(rx_cmd_c));
3578 
3579 		packet = skb->data;
3580 
3581 		/* get the packet length */
3582 		size = (rx_cmd_a & RX_CMD_A_LEN_MASK_);
3583 		align_count = (4 - ((size + RXW_PADDING) % 4)) % 4;
3584 
3585 		if (unlikely(size > skb->len)) {
3586 			netif_dbg(dev, rx_err, dev->net,
3587 				  "size err rx_cmd_a=0x%08x\n",
3588 				  rx_cmd_a);
3589 			return 0;
3590 		}
3591 
3592 		if (unlikely(rx_cmd_a & RX_CMD_A_RED_)) {
3593 			netif_dbg(dev, rx_err, dev->net,
3594 				  "Error rx_cmd_a=0x%08x", rx_cmd_a);
3595 		} else {
3596 			u32 frame_len;
3597 			struct sk_buff *skb2;
3598 
3599 			if (unlikely(size < ETH_FCS_LEN)) {
3600 				netif_dbg(dev, rx_err, dev->net,
3601 					  "size err rx_cmd_a=0x%08x\n",
3602 					  rx_cmd_a);
3603 				return 0;
3604 			}
3605 
3606 			frame_len = size - ETH_FCS_LEN;
3607 
3608 			skb2 = napi_alloc_skb(&dev->napi, frame_len);
3609 			if (!skb2)
3610 				return 0;
3611 
3612 			memcpy(skb2->data, packet, frame_len);
3613 
3614 			skb_put(skb2, frame_len);
3615 
3616 			lan78xx_rx_csum_offload(dev, skb2, rx_cmd_a, rx_cmd_b);
3617 			lan78xx_rx_vlan_offload(dev, skb2, rx_cmd_a, rx_cmd_b);
3618 
3619 			/* Processing of the URB buffer must complete once
3620 			 * it has started. If the NAPI work budget is exhausted
3621 			 * while frames remain they are added to the overflow
3622 			 * queue for delivery in the next NAPI polling cycle.
3623 			 */
3624 			if (*work_done < budget) {
3625 				lan78xx_skb_return(dev, skb2);
3626 				++(*work_done);
3627 			} else {
3628 				skb_queue_tail(&dev->rxq_overflow, skb2);
3629 			}
3630 		}
3631 
3632 		skb_pull(skb, size);
3633 
3634 		/* skip padding bytes before the next frame starts */
3635 		if (skb->len)
3636 			skb_pull(skb, align_count);
3637 	}
3638 
3639 	return 1;
3640 }
3641 
rx_process(struct lan78xx_net * dev,struct sk_buff * skb,int budget,int * work_done)3642 static inline void rx_process(struct lan78xx_net *dev, struct sk_buff *skb,
3643 			      int budget, int *work_done)
3644 {
3645 	if (!lan78xx_rx(dev, skb, budget, work_done)) {
3646 		netif_dbg(dev, rx_err, dev->net, "drop\n");
3647 		dev->net->stats.rx_errors++;
3648 	}
3649 }
3650 
rx_complete(struct urb * urb)3651 static void rx_complete(struct urb *urb)
3652 {
3653 	struct sk_buff	*skb = (struct sk_buff *)urb->context;
3654 	struct skb_data	*entry = (struct skb_data *)skb->cb;
3655 	struct lan78xx_net *dev = entry->dev;
3656 	int urb_status = urb->status;
3657 	enum skb_state state;
3658 
3659 	netif_dbg(dev, rx_status, dev->net,
3660 		  "rx done: status %d", urb->status);
3661 
3662 	skb_put(skb, urb->actual_length);
3663 	state = rx_done;
3664 
3665 	if (urb != entry->urb)
3666 		netif_warn(dev, rx_err, dev->net, "URB pointer mismatch");
3667 
3668 	switch (urb_status) {
3669 	case 0:
3670 		if (skb->len < RX_SKB_MIN_LEN) {
3671 			state = rx_cleanup;
3672 			dev->net->stats.rx_errors++;
3673 			dev->net->stats.rx_length_errors++;
3674 			netif_dbg(dev, rx_err, dev->net,
3675 				  "rx length %d\n", skb->len);
3676 		}
3677 		usb_mark_last_busy(dev->udev);
3678 		break;
3679 	case -EPIPE:
3680 		dev->net->stats.rx_errors++;
3681 		lan78xx_defer_kevent(dev, EVENT_RX_HALT);
3682 		fallthrough;
3683 	case -ECONNRESET:				/* async unlink */
3684 	case -ESHUTDOWN:				/* hardware gone */
3685 		netif_dbg(dev, ifdown, dev->net,
3686 			  "rx shutdown, code %d\n", urb_status);
3687 		state = rx_cleanup;
3688 		break;
3689 	case -EPROTO:
3690 	case -ETIME:
3691 	case -EILSEQ:
3692 		dev->net->stats.rx_errors++;
3693 		state = rx_cleanup;
3694 		break;
3695 
3696 	/* data overrun ... flush fifo? */
3697 	case -EOVERFLOW:
3698 		dev->net->stats.rx_over_errors++;
3699 		fallthrough;
3700 
3701 	default:
3702 		state = rx_cleanup;
3703 		dev->net->stats.rx_errors++;
3704 		netif_dbg(dev, rx_err, dev->net, "rx status %d\n", urb_status);
3705 		break;
3706 	}
3707 
3708 	state = defer_bh(dev, skb, &dev->rxq, state);
3709 }
3710 
rx_submit(struct lan78xx_net * dev,struct sk_buff * skb,gfp_t flags)3711 static int rx_submit(struct lan78xx_net *dev, struct sk_buff *skb, gfp_t flags)
3712 {
3713 	struct skb_data	*entry = (struct skb_data *)skb->cb;
3714 	size_t size = dev->rx_urb_size;
3715 	struct urb *urb = entry->urb;
3716 	unsigned long lockflags;
3717 	int ret = 0;
3718 
3719 	usb_fill_bulk_urb(urb, dev->udev, dev->pipe_in,
3720 			  skb->data, size, rx_complete, skb);
3721 
3722 	spin_lock_irqsave(&dev->rxq.lock, lockflags);
3723 
3724 	if (netif_device_present(dev->net) &&
3725 	    netif_running(dev->net) &&
3726 	    !test_bit(EVENT_RX_HALT, &dev->flags) &&
3727 	    !test_bit(EVENT_DEV_ASLEEP, &dev->flags)) {
3728 		ret = usb_submit_urb(urb, flags);
3729 		switch (ret) {
3730 		case 0:
3731 			lan78xx_queue_skb(&dev->rxq, skb, rx_start);
3732 			break;
3733 		case -EPIPE:
3734 			lan78xx_defer_kevent(dev, EVENT_RX_HALT);
3735 			break;
3736 		case -ENODEV:
3737 		case -ENOENT:
3738 			netif_dbg(dev, ifdown, dev->net, "device gone\n");
3739 			netif_device_detach(dev->net);
3740 			break;
3741 		case -EHOSTUNREACH:
3742 			ret = -ENOLINK;
3743 			napi_schedule(&dev->napi);
3744 			break;
3745 		default:
3746 			netif_dbg(dev, rx_err, dev->net,
3747 				  "rx submit, %d\n", ret);
3748 			napi_schedule(&dev->napi);
3749 			break;
3750 		}
3751 	} else {
3752 		netif_dbg(dev, ifdown, dev->net, "rx: stopped\n");
3753 		ret = -ENOLINK;
3754 	}
3755 	spin_unlock_irqrestore(&dev->rxq.lock, lockflags);
3756 
3757 	if (ret)
3758 		lan78xx_release_rx_buf(dev, skb);
3759 
3760 	return ret;
3761 }
3762 
lan78xx_rx_urb_submit_all(struct lan78xx_net * dev)3763 static void lan78xx_rx_urb_submit_all(struct lan78xx_net *dev)
3764 {
3765 	struct sk_buff *rx_buf;
3766 
3767 	/* Ensure the maximum number of Rx URBs is submitted
3768 	 */
3769 	while ((rx_buf = lan78xx_get_rx_buf(dev)) != NULL) {
3770 		if (rx_submit(dev, rx_buf, GFP_ATOMIC) != 0)
3771 			break;
3772 	}
3773 }
3774 
lan78xx_rx_urb_resubmit(struct lan78xx_net * dev,struct sk_buff * rx_buf)3775 static void lan78xx_rx_urb_resubmit(struct lan78xx_net *dev,
3776 				    struct sk_buff *rx_buf)
3777 {
3778 	/* reset SKB data pointers */
3779 
3780 	rx_buf->data = rx_buf->head;
3781 	skb_reset_tail_pointer(rx_buf);
3782 	rx_buf->len = 0;
3783 	rx_buf->data_len = 0;
3784 
3785 	rx_submit(dev, rx_buf, GFP_ATOMIC);
3786 }
3787 
lan78xx_fill_tx_cmd_words(struct sk_buff * skb,u8 * buffer)3788 static void lan78xx_fill_tx_cmd_words(struct sk_buff *skb, u8 *buffer)
3789 {
3790 	u32 tx_cmd_a;
3791 	u32 tx_cmd_b;
3792 
3793 	tx_cmd_a = (u32)(skb->len & TX_CMD_A_LEN_MASK_) | TX_CMD_A_FCS_;
3794 
3795 	if (skb->ip_summed == CHECKSUM_PARTIAL)
3796 		tx_cmd_a |= TX_CMD_A_IPE_ | TX_CMD_A_TPE_;
3797 
3798 	tx_cmd_b = 0;
3799 	if (skb_is_gso(skb)) {
3800 		u16 mss = max(skb_shinfo(skb)->gso_size, TX_CMD_B_MSS_MIN_);
3801 
3802 		tx_cmd_b = (mss << TX_CMD_B_MSS_SHIFT_) & TX_CMD_B_MSS_MASK_;
3803 
3804 		tx_cmd_a |= TX_CMD_A_LSO_;
3805 	}
3806 
3807 	if (skb_vlan_tag_present(skb)) {
3808 		tx_cmd_a |= TX_CMD_A_IVTG_;
3809 		tx_cmd_b |= skb_vlan_tag_get(skb) & TX_CMD_B_VTAG_MASK_;
3810 	}
3811 
3812 	put_unaligned_le32(tx_cmd_a, buffer);
3813 	put_unaligned_le32(tx_cmd_b, buffer + 4);
3814 }
3815 
lan78xx_tx_buf_fill(struct lan78xx_net * dev,struct sk_buff * tx_buf)3816 static struct skb_data *lan78xx_tx_buf_fill(struct lan78xx_net *dev,
3817 					    struct sk_buff *tx_buf)
3818 {
3819 	struct skb_data *entry = (struct skb_data *)tx_buf->cb;
3820 	int remain = dev->tx_urb_size;
3821 	u8 *tx_data = tx_buf->data;
3822 	u32 urb_len = 0;
3823 
3824 	entry->num_of_packet = 0;
3825 	entry->length = 0;
3826 
3827 	/* Work through the pending SKBs and copy the data of each SKB into
3828 	 * the URB buffer if there room for all the SKB data.
3829 	 *
3830 	 * There must be at least DST+SRC+TYPE in the SKB (with padding enabled)
3831 	 */
3832 	while (remain >= TX_SKB_MIN_LEN) {
3833 		unsigned int pending_bytes;
3834 		unsigned int align_bytes;
3835 		struct sk_buff *skb;
3836 		unsigned int len;
3837 
3838 		lan78xx_tx_pend_skb_get(dev, &skb, &pending_bytes);
3839 
3840 		if (!skb)
3841 			break;
3842 
3843 		align_bytes = (TX_ALIGNMENT - (urb_len % TX_ALIGNMENT)) %
3844 			      TX_ALIGNMENT;
3845 		len = align_bytes + TX_CMD_LEN + skb->len;
3846 		if (len > remain) {
3847 			lan78xx_tx_pend_skb_head_add(dev, skb, &pending_bytes);
3848 			break;
3849 		}
3850 
3851 		tx_data += align_bytes;
3852 
3853 		lan78xx_fill_tx_cmd_words(skb, tx_data);
3854 		tx_data += TX_CMD_LEN;
3855 
3856 		len = skb->len;
3857 		if (skb_copy_bits(skb, 0, tx_data, len) < 0) {
3858 			struct net_device_stats *stats = &dev->net->stats;
3859 
3860 			stats->tx_dropped++;
3861 			dev_kfree_skb_any(skb);
3862 			tx_data -= TX_CMD_LEN;
3863 			continue;
3864 		}
3865 
3866 		tx_data += len;
3867 		entry->length += len;
3868 		entry->num_of_packet += skb_shinfo(skb)->gso_segs ?: 1;
3869 
3870 		dev_kfree_skb_any(skb);
3871 
3872 		urb_len = (u32)(tx_data - (u8 *)tx_buf->data);
3873 
3874 		remain = dev->tx_urb_size - urb_len;
3875 	}
3876 
3877 	skb_put(tx_buf, urb_len);
3878 
3879 	return entry;
3880 }
3881 
lan78xx_tx_bh(struct lan78xx_net * dev)3882 static void lan78xx_tx_bh(struct lan78xx_net *dev)
3883 {
3884 	int ret;
3885 
3886 	/* Start the stack Tx queue if it was stopped
3887 	 */
3888 	netif_tx_lock(dev->net);
3889 	if (netif_queue_stopped(dev->net)) {
3890 		if (lan78xx_tx_pend_data_len(dev) < lan78xx_tx_urb_space(dev))
3891 			netif_wake_queue(dev->net);
3892 	}
3893 	netif_tx_unlock(dev->net);
3894 
3895 	/* Go through the Tx pending queue and set up URBs to transfer
3896 	 * the data to the device. Stop if no more pending data or URBs,
3897 	 * or if an error occurs when a URB is submitted.
3898 	 */
3899 	do {
3900 		struct skb_data *entry;
3901 		struct sk_buff *tx_buf;
3902 		unsigned long flags;
3903 
3904 		if (skb_queue_empty(&dev->txq_pend))
3905 			break;
3906 
3907 		tx_buf = lan78xx_get_tx_buf(dev);
3908 		if (!tx_buf)
3909 			break;
3910 
3911 		entry = lan78xx_tx_buf_fill(dev, tx_buf);
3912 
3913 		spin_lock_irqsave(&dev->txq.lock, flags);
3914 		ret = usb_autopm_get_interface_async(dev->intf);
3915 		if (ret < 0) {
3916 			spin_unlock_irqrestore(&dev->txq.lock, flags);
3917 			goto out;
3918 		}
3919 
3920 		usb_fill_bulk_urb(entry->urb, dev->udev, dev->pipe_out,
3921 				  tx_buf->data, tx_buf->len, tx_complete,
3922 				  tx_buf);
3923 
3924 		if (tx_buf->len % dev->maxpacket == 0) {
3925 			/* send USB_ZERO_PACKET */
3926 			entry->urb->transfer_flags |= URB_ZERO_PACKET;
3927 		}
3928 
3929 #ifdef CONFIG_PM
3930 		/* if device is asleep stop outgoing packet processing */
3931 		if (test_bit(EVENT_DEV_ASLEEP, &dev->flags)) {
3932 			usb_anchor_urb(entry->urb, &dev->deferred);
3933 			netif_stop_queue(dev->net);
3934 			spin_unlock_irqrestore(&dev->txq.lock, flags);
3935 			netdev_dbg(dev->net,
3936 				   "Delaying transmission for resumption\n");
3937 			return;
3938 		}
3939 #endif
3940 		ret = usb_submit_urb(entry->urb, GFP_ATOMIC);
3941 		switch (ret) {
3942 		case 0:
3943 			netif_trans_update(dev->net);
3944 			lan78xx_queue_skb(&dev->txq, tx_buf, tx_start);
3945 			break;
3946 		case -EPIPE:
3947 			netif_stop_queue(dev->net);
3948 			lan78xx_defer_kevent(dev, EVENT_TX_HALT);
3949 			usb_autopm_put_interface_async(dev->intf);
3950 			break;
3951 		case -ENODEV:
3952 		case -ENOENT:
3953 			netif_dbg(dev, tx_err, dev->net,
3954 				  "tx submit urb err %d (disconnected?)", ret);
3955 			netif_device_detach(dev->net);
3956 			break;
3957 		default:
3958 			usb_autopm_put_interface_async(dev->intf);
3959 			netif_dbg(dev, tx_err, dev->net,
3960 				  "tx submit urb err %d\n", ret);
3961 			break;
3962 		}
3963 
3964 		spin_unlock_irqrestore(&dev->txq.lock, flags);
3965 
3966 		if (ret) {
3967 			netdev_warn(dev->net, "failed to tx urb %d\n", ret);
3968 out:
3969 			dev->net->stats.tx_dropped += entry->num_of_packet;
3970 			lan78xx_release_tx_buf(dev, tx_buf);
3971 		}
3972 	} while (ret == 0);
3973 }
3974 
lan78xx_bh(struct lan78xx_net * dev,int budget)3975 static int lan78xx_bh(struct lan78xx_net *dev, int budget)
3976 {
3977 	struct sk_buff_head done;
3978 	struct sk_buff *rx_buf;
3979 	struct skb_data *entry;
3980 	unsigned long flags;
3981 	int work_done = 0;
3982 
3983 	/* Pass frames received in the last NAPI cycle before
3984 	 * working on newly completed URBs.
3985 	 */
3986 	while (!skb_queue_empty(&dev->rxq_overflow)) {
3987 		lan78xx_skb_return(dev, skb_dequeue(&dev->rxq_overflow));
3988 		++work_done;
3989 	}
3990 
3991 	/* Take a snapshot of the done queue and move items to a
3992 	 * temporary queue. Rx URB completions will continue to add
3993 	 * to the done queue.
3994 	 */
3995 	__skb_queue_head_init(&done);
3996 
3997 	spin_lock_irqsave(&dev->rxq_done.lock, flags);
3998 	skb_queue_splice_init(&dev->rxq_done, &done);
3999 	spin_unlock_irqrestore(&dev->rxq_done.lock, flags);
4000 
4001 	/* Extract receive frames from completed URBs and
4002 	 * pass them to the stack. Re-submit each completed URB.
4003 	 */
4004 	while ((work_done < budget) &&
4005 	       (rx_buf = __skb_dequeue(&done))) {
4006 		entry = (struct skb_data *)(rx_buf->cb);
4007 		switch (entry->state) {
4008 		case rx_done:
4009 			rx_process(dev, rx_buf, budget, &work_done);
4010 			break;
4011 		case rx_cleanup:
4012 			break;
4013 		default:
4014 			netdev_dbg(dev->net, "rx buf state %d\n",
4015 				   entry->state);
4016 			break;
4017 		}
4018 
4019 		lan78xx_rx_urb_resubmit(dev, rx_buf);
4020 	}
4021 
4022 	/* If budget was consumed before processing all the URBs put them
4023 	 * back on the front of the done queue. They will be first to be
4024 	 * processed in the next NAPI cycle.
4025 	 */
4026 	spin_lock_irqsave(&dev->rxq_done.lock, flags);
4027 	skb_queue_splice(&done, &dev->rxq_done);
4028 	spin_unlock_irqrestore(&dev->rxq_done.lock, flags);
4029 
4030 	if (netif_device_present(dev->net) && netif_running(dev->net)) {
4031 		/* reset update timer delta */
4032 		if (timer_pending(&dev->stat_monitor) && (dev->delta != 1)) {
4033 			dev->delta = 1;
4034 			mod_timer(&dev->stat_monitor,
4035 				  jiffies + STAT_UPDATE_TIMER);
4036 		}
4037 
4038 		/* Submit all free Rx URBs */
4039 
4040 		if (!test_bit(EVENT_RX_HALT, &dev->flags))
4041 			lan78xx_rx_urb_submit_all(dev);
4042 
4043 		/* Submit new Tx URBs */
4044 
4045 		lan78xx_tx_bh(dev);
4046 	}
4047 
4048 	return work_done;
4049 }
4050 
lan78xx_poll(struct napi_struct * napi,int budget)4051 static int lan78xx_poll(struct napi_struct *napi, int budget)
4052 {
4053 	struct lan78xx_net *dev = container_of(napi, struct lan78xx_net, napi);
4054 	int result = budget;
4055 	int work_done;
4056 
4057 	/* Don't do any work if the device is suspended */
4058 
4059 	if (test_bit(EVENT_DEV_ASLEEP, &dev->flags)) {
4060 		napi_complete_done(napi, 0);
4061 		return 0;
4062 	}
4063 
4064 	/* Process completed URBs and submit new URBs */
4065 
4066 	work_done = lan78xx_bh(dev, budget);
4067 
4068 	if (work_done < budget) {
4069 		napi_complete_done(napi, work_done);
4070 
4071 		/* Start a new polling cycle if data was received or
4072 		 * data is waiting to be transmitted.
4073 		 */
4074 		if (!skb_queue_empty(&dev->rxq_done)) {
4075 			napi_schedule(napi);
4076 		} else if (netif_carrier_ok(dev->net)) {
4077 			if (skb_queue_empty(&dev->txq) &&
4078 			    !skb_queue_empty(&dev->txq_pend)) {
4079 				napi_schedule(napi);
4080 			} else {
4081 				netif_tx_lock(dev->net);
4082 				if (netif_queue_stopped(dev->net)) {
4083 					netif_wake_queue(dev->net);
4084 					napi_schedule(napi);
4085 				}
4086 				netif_tx_unlock(dev->net);
4087 			}
4088 		}
4089 		result = work_done;
4090 	}
4091 
4092 	return result;
4093 }
4094 
lan78xx_delayedwork(struct work_struct * work)4095 static void lan78xx_delayedwork(struct work_struct *work)
4096 {
4097 	int status;
4098 	struct lan78xx_net *dev;
4099 
4100 	dev = container_of(work, struct lan78xx_net, wq.work);
4101 
4102 	if (test_bit(EVENT_DEV_DISCONNECT, &dev->flags))
4103 		return;
4104 
4105 	if (usb_autopm_get_interface(dev->intf) < 0)
4106 		return;
4107 
4108 	if (test_bit(EVENT_TX_HALT, &dev->flags)) {
4109 		unlink_urbs(dev, &dev->txq);
4110 
4111 		status = usb_clear_halt(dev->udev, dev->pipe_out);
4112 		if (status < 0 &&
4113 		    status != -EPIPE &&
4114 		    status != -ESHUTDOWN) {
4115 			if (netif_msg_tx_err(dev))
4116 				netdev_err(dev->net,
4117 					   "can't clear tx halt, status %d\n",
4118 					   status);
4119 		} else {
4120 			clear_bit(EVENT_TX_HALT, &dev->flags);
4121 			if (status != -ESHUTDOWN)
4122 				netif_wake_queue(dev->net);
4123 		}
4124 	}
4125 
4126 	if (test_bit(EVENT_RX_HALT, &dev->flags)) {
4127 		unlink_urbs(dev, &dev->rxq);
4128 		status = usb_clear_halt(dev->udev, dev->pipe_in);
4129 		if (status < 0 &&
4130 		    status != -EPIPE &&
4131 		    status != -ESHUTDOWN) {
4132 			if (netif_msg_rx_err(dev))
4133 				netdev_err(dev->net,
4134 					   "can't clear rx halt, status %d\n",
4135 					   status);
4136 		} else {
4137 			clear_bit(EVENT_RX_HALT, &dev->flags);
4138 			napi_schedule(&dev->napi);
4139 		}
4140 	}
4141 
4142 	if (test_bit(EVENT_LINK_RESET, &dev->flags)) {
4143 		int ret = 0;
4144 
4145 		clear_bit(EVENT_LINK_RESET, &dev->flags);
4146 		if (lan78xx_link_reset(dev) < 0) {
4147 			netdev_info(dev->net, "link reset failed (%d)\n",
4148 				    ret);
4149 		}
4150 	}
4151 
4152 	if (test_bit(EVENT_STAT_UPDATE, &dev->flags)) {
4153 		lan78xx_update_stats(dev);
4154 
4155 		clear_bit(EVENT_STAT_UPDATE, &dev->flags);
4156 
4157 		mod_timer(&dev->stat_monitor,
4158 			  jiffies + (STAT_UPDATE_TIMER * dev->delta));
4159 
4160 		dev->delta = min((dev->delta * 2), 50);
4161 	}
4162 
4163 	usb_autopm_put_interface(dev->intf);
4164 }
4165 
intr_complete(struct urb * urb)4166 static void intr_complete(struct urb *urb)
4167 {
4168 	struct lan78xx_net *dev = urb->context;
4169 	int status = urb->status;
4170 
4171 	switch (status) {
4172 	/* success */
4173 	case 0:
4174 		lan78xx_status(dev, urb);
4175 		break;
4176 
4177 	/* software-driven interface shutdown */
4178 	case -ENOENT:			/* urb killed */
4179 	case -ENODEV:			/* hardware gone */
4180 	case -ESHUTDOWN:		/* hardware gone */
4181 		netif_dbg(dev, ifdown, dev->net,
4182 			  "intr shutdown, code %d\n", status);
4183 		return;
4184 
4185 	/* NOTE:  not throttling like RX/TX, since this endpoint
4186 	 * already polls infrequently
4187 	 */
4188 	default:
4189 		netdev_dbg(dev->net, "intr status %d\n", status);
4190 		break;
4191 	}
4192 
4193 	if (!netif_device_present(dev->net) ||
4194 	    !netif_running(dev->net)) {
4195 		netdev_warn(dev->net, "not submitting new status URB");
4196 		return;
4197 	}
4198 
4199 	memset(urb->transfer_buffer, 0, urb->transfer_buffer_length);
4200 	status = usb_submit_urb(urb, GFP_ATOMIC);
4201 
4202 	switch (status) {
4203 	case  0:
4204 		break;
4205 	case -ENODEV:
4206 	case -ENOENT:
4207 		netif_dbg(dev, timer, dev->net,
4208 			  "intr resubmit %d (disconnect?)", status);
4209 		netif_device_detach(dev->net);
4210 		break;
4211 	default:
4212 		netif_err(dev, timer, dev->net,
4213 			  "intr resubmit --> %d\n", status);
4214 		break;
4215 	}
4216 }
4217 
lan78xx_disconnect(struct usb_interface * intf)4218 static void lan78xx_disconnect(struct usb_interface *intf)
4219 {
4220 	struct lan78xx_net *dev;
4221 	struct usb_device *udev;
4222 	struct net_device *net;
4223 	struct phy_device *phydev;
4224 
4225 	dev = usb_get_intfdata(intf);
4226 	usb_set_intfdata(intf, NULL);
4227 	if (!dev)
4228 		return;
4229 
4230 	netif_napi_del(&dev->napi);
4231 
4232 	udev = interface_to_usbdev(intf);
4233 	net = dev->net;
4234 
4235 	unregister_netdev(net);
4236 
4237 	timer_shutdown_sync(&dev->stat_monitor);
4238 	set_bit(EVENT_DEV_DISCONNECT, &dev->flags);
4239 	cancel_delayed_work_sync(&dev->wq);
4240 
4241 	phydev = net->phydev;
4242 
4243 	phy_unregister_fixup_for_uid(PHY_KSZ9031RNX, 0xfffffff0);
4244 	phy_unregister_fixup_for_uid(PHY_LAN8835, 0xfffffff0);
4245 
4246 	phy_disconnect(net->phydev);
4247 
4248 	if (phy_is_pseudo_fixed_link(phydev))
4249 		fixed_phy_unregister(phydev);
4250 
4251 	usb_scuttle_anchored_urbs(&dev->deferred);
4252 
4253 	lan78xx_unbind(dev, intf);
4254 
4255 	lan78xx_free_tx_resources(dev);
4256 	lan78xx_free_rx_resources(dev);
4257 
4258 	usb_kill_urb(dev->urb_intr);
4259 	usb_free_urb(dev->urb_intr);
4260 
4261 	free_netdev(net);
4262 	usb_put_dev(udev);
4263 }
4264 
lan78xx_tx_timeout(struct net_device * net,unsigned int txqueue)4265 static void lan78xx_tx_timeout(struct net_device *net, unsigned int txqueue)
4266 {
4267 	struct lan78xx_net *dev = netdev_priv(net);
4268 
4269 	unlink_urbs(dev, &dev->txq);
4270 	napi_schedule(&dev->napi);
4271 }
4272 
lan78xx_features_check(struct sk_buff * skb,struct net_device * netdev,netdev_features_t features)4273 static netdev_features_t lan78xx_features_check(struct sk_buff *skb,
4274 						struct net_device *netdev,
4275 						netdev_features_t features)
4276 {
4277 	struct lan78xx_net *dev = netdev_priv(netdev);
4278 
4279 	if (skb->len > LAN78XX_TSO_SIZE(dev))
4280 		features &= ~NETIF_F_GSO_MASK;
4281 
4282 	features = vlan_features_check(skb, features);
4283 	features = vxlan_features_check(skb, features);
4284 
4285 	return features;
4286 }
4287 
4288 static const struct net_device_ops lan78xx_netdev_ops = {
4289 	.ndo_open		= lan78xx_open,
4290 	.ndo_stop		= lan78xx_stop,
4291 	.ndo_start_xmit		= lan78xx_start_xmit,
4292 	.ndo_tx_timeout		= lan78xx_tx_timeout,
4293 	.ndo_change_mtu		= lan78xx_change_mtu,
4294 	.ndo_set_mac_address	= lan78xx_set_mac_addr,
4295 	.ndo_validate_addr	= eth_validate_addr,
4296 	.ndo_eth_ioctl		= phy_do_ioctl_running,
4297 	.ndo_set_rx_mode	= lan78xx_set_multicast,
4298 	.ndo_set_features	= lan78xx_set_features,
4299 	.ndo_vlan_rx_add_vid	= lan78xx_vlan_rx_add_vid,
4300 	.ndo_vlan_rx_kill_vid	= lan78xx_vlan_rx_kill_vid,
4301 	.ndo_features_check	= lan78xx_features_check,
4302 };
4303 
lan78xx_stat_monitor(struct timer_list * t)4304 static void lan78xx_stat_monitor(struct timer_list *t)
4305 {
4306 	struct lan78xx_net *dev = from_timer(dev, t, stat_monitor);
4307 
4308 	lan78xx_defer_kevent(dev, EVENT_STAT_UPDATE);
4309 }
4310 
lan78xx_probe(struct usb_interface * intf,const struct usb_device_id * id)4311 static int lan78xx_probe(struct usb_interface *intf,
4312 			 const struct usb_device_id *id)
4313 {
4314 	struct usb_host_endpoint *ep_blkin, *ep_blkout, *ep_intr;
4315 	struct lan78xx_net *dev;
4316 	struct net_device *netdev;
4317 	struct usb_device *udev;
4318 	int ret;
4319 	unsigned int maxp;
4320 	unsigned int period;
4321 	u8 *buf = NULL;
4322 
4323 	udev = interface_to_usbdev(intf);
4324 	udev = usb_get_dev(udev);
4325 
4326 	netdev = alloc_etherdev(sizeof(struct lan78xx_net));
4327 	if (!netdev) {
4328 		dev_err(&intf->dev, "Error: OOM\n");
4329 		ret = -ENOMEM;
4330 		goto out1;
4331 	}
4332 
4333 	/* netdev_printk() needs this */
4334 	SET_NETDEV_DEV(netdev, &intf->dev);
4335 
4336 	dev = netdev_priv(netdev);
4337 	dev->udev = udev;
4338 	dev->intf = intf;
4339 	dev->net = netdev;
4340 	dev->msg_enable = netif_msg_init(msg_level, NETIF_MSG_DRV
4341 					| NETIF_MSG_PROBE | NETIF_MSG_LINK);
4342 
4343 	skb_queue_head_init(&dev->rxq);
4344 	skb_queue_head_init(&dev->txq);
4345 	skb_queue_head_init(&dev->rxq_done);
4346 	skb_queue_head_init(&dev->txq_pend);
4347 	skb_queue_head_init(&dev->rxq_overflow);
4348 	mutex_init(&dev->phy_mutex);
4349 	mutex_init(&dev->dev_mutex);
4350 
4351 	ret = lan78xx_urb_config_init(dev);
4352 	if (ret < 0)
4353 		goto out2;
4354 
4355 	ret = lan78xx_alloc_tx_resources(dev);
4356 	if (ret < 0)
4357 		goto out2;
4358 
4359 	ret = lan78xx_alloc_rx_resources(dev);
4360 	if (ret < 0)
4361 		goto out3;
4362 
4363 	/* MTU range: 68 - 9000 */
4364 	netdev->max_mtu = MAX_SINGLE_PACKET_SIZE;
4365 
4366 	netif_set_tso_max_size(netdev, LAN78XX_TSO_SIZE(dev));
4367 
4368 	netif_napi_add(netdev, &dev->napi, lan78xx_poll);
4369 
4370 	INIT_DELAYED_WORK(&dev->wq, lan78xx_delayedwork);
4371 	init_usb_anchor(&dev->deferred);
4372 
4373 	netdev->netdev_ops = &lan78xx_netdev_ops;
4374 	netdev->watchdog_timeo = TX_TIMEOUT_JIFFIES;
4375 	netdev->ethtool_ops = &lan78xx_ethtool_ops;
4376 
4377 	dev->delta = 1;
4378 	timer_setup(&dev->stat_monitor, lan78xx_stat_monitor, 0);
4379 
4380 	mutex_init(&dev->stats.access_lock);
4381 
4382 	if (intf->cur_altsetting->desc.bNumEndpoints < 3) {
4383 		ret = -ENODEV;
4384 		goto out4;
4385 	}
4386 
4387 	dev->pipe_in = usb_rcvbulkpipe(udev, BULK_IN_PIPE);
4388 	ep_blkin = usb_pipe_endpoint(udev, dev->pipe_in);
4389 	if (!ep_blkin || !usb_endpoint_is_bulk_in(&ep_blkin->desc)) {
4390 		ret = -ENODEV;
4391 		goto out4;
4392 	}
4393 
4394 	dev->pipe_out = usb_sndbulkpipe(udev, BULK_OUT_PIPE);
4395 	ep_blkout = usb_pipe_endpoint(udev, dev->pipe_out);
4396 	if (!ep_blkout || !usb_endpoint_is_bulk_out(&ep_blkout->desc)) {
4397 		ret = -ENODEV;
4398 		goto out4;
4399 	}
4400 
4401 	ep_intr = &intf->cur_altsetting->endpoint[2];
4402 	if (!usb_endpoint_is_int_in(&ep_intr->desc)) {
4403 		ret = -ENODEV;
4404 		goto out4;
4405 	}
4406 
4407 	dev->pipe_intr = usb_rcvintpipe(dev->udev,
4408 					usb_endpoint_num(&ep_intr->desc));
4409 
4410 	ret = lan78xx_bind(dev, intf);
4411 	if (ret < 0)
4412 		goto out4;
4413 
4414 	period = ep_intr->desc.bInterval;
4415 	maxp = usb_maxpacket(dev->udev, dev->pipe_intr);
4416 	buf = kmalloc(maxp, GFP_KERNEL);
4417 	if (!buf) {
4418 		ret = -ENOMEM;
4419 		goto out5;
4420 	}
4421 
4422 	dev->urb_intr = usb_alloc_urb(0, GFP_KERNEL);
4423 	if (!dev->urb_intr) {
4424 		ret = -ENOMEM;
4425 		goto out6;
4426 	} else {
4427 		usb_fill_int_urb(dev->urb_intr, dev->udev,
4428 				 dev->pipe_intr, buf, maxp,
4429 				 intr_complete, dev, period);
4430 		dev->urb_intr->transfer_flags |= URB_FREE_BUFFER;
4431 	}
4432 
4433 	dev->maxpacket = usb_maxpacket(dev->udev, dev->pipe_out);
4434 
4435 	/* Reject broken descriptors. */
4436 	if (dev->maxpacket == 0) {
4437 		ret = -ENODEV;
4438 		goto out6;
4439 	}
4440 
4441 	/* driver requires remote-wakeup capability during autosuspend. */
4442 	intf->needs_remote_wakeup = 1;
4443 
4444 	ret = lan78xx_phy_init(dev);
4445 	if (ret < 0)
4446 		goto out7;
4447 
4448 	ret = register_netdev(netdev);
4449 	if (ret != 0) {
4450 		netif_err(dev, probe, netdev, "couldn't register the device\n");
4451 		goto out8;
4452 	}
4453 
4454 	usb_set_intfdata(intf, dev);
4455 
4456 	ret = device_set_wakeup_enable(&udev->dev, true);
4457 
4458 	 /* Default delay of 2sec has more overhead than advantage.
4459 	  * Set to 10sec as default.
4460 	  */
4461 	pm_runtime_set_autosuspend_delay(&udev->dev,
4462 					 DEFAULT_AUTOSUSPEND_DELAY);
4463 
4464 	return 0;
4465 
4466 out8:
4467 	phy_disconnect(netdev->phydev);
4468 out7:
4469 	usb_free_urb(dev->urb_intr);
4470 out6:
4471 	kfree(buf);
4472 out5:
4473 	lan78xx_unbind(dev, intf);
4474 out4:
4475 	netif_napi_del(&dev->napi);
4476 	lan78xx_free_rx_resources(dev);
4477 out3:
4478 	lan78xx_free_tx_resources(dev);
4479 out2:
4480 	free_netdev(netdev);
4481 out1:
4482 	usb_put_dev(udev);
4483 
4484 	return ret;
4485 }
4486 
lan78xx_wakeframe_crc16(const u8 * buf,int len)4487 static u16 lan78xx_wakeframe_crc16(const u8 *buf, int len)
4488 {
4489 	const u16 crc16poly = 0x8005;
4490 	int i;
4491 	u16 bit, crc, msb;
4492 	u8 data;
4493 
4494 	crc = 0xFFFF;
4495 	for (i = 0; i < len; i++) {
4496 		data = *buf++;
4497 		for (bit = 0; bit < 8; bit++) {
4498 			msb = crc >> 15;
4499 			crc <<= 1;
4500 
4501 			if (msb ^ (u16)(data & 1)) {
4502 				crc ^= crc16poly;
4503 				crc |= (u16)0x0001U;
4504 			}
4505 			data >>= 1;
4506 		}
4507 	}
4508 
4509 	return crc;
4510 }
4511 
lan78xx_set_auto_suspend(struct lan78xx_net * dev)4512 static int lan78xx_set_auto_suspend(struct lan78xx_net *dev)
4513 {
4514 	u32 buf;
4515 	int ret;
4516 
4517 	ret = lan78xx_stop_tx_path(dev);
4518 	if (ret < 0)
4519 		return ret;
4520 
4521 	ret = lan78xx_stop_rx_path(dev);
4522 	if (ret < 0)
4523 		return ret;
4524 
4525 	/* auto suspend (selective suspend) */
4526 
4527 	ret = lan78xx_write_reg(dev, WUCSR, 0);
4528 	if (ret < 0)
4529 		return ret;
4530 	ret = lan78xx_write_reg(dev, WUCSR2, 0);
4531 	if (ret < 0)
4532 		return ret;
4533 	ret = lan78xx_write_reg(dev, WK_SRC, 0xFFF1FF1FUL);
4534 	if (ret < 0)
4535 		return ret;
4536 
4537 	/* set goodframe wakeup */
4538 
4539 	ret = lan78xx_read_reg(dev, WUCSR, &buf);
4540 	if (ret < 0)
4541 		return ret;
4542 
4543 	buf |= WUCSR_RFE_WAKE_EN_;
4544 	buf |= WUCSR_STORE_WAKE_;
4545 
4546 	ret = lan78xx_write_reg(dev, WUCSR, buf);
4547 	if (ret < 0)
4548 		return ret;
4549 
4550 	ret = lan78xx_read_reg(dev, PMT_CTL, &buf);
4551 	if (ret < 0)
4552 		return ret;
4553 
4554 	buf &= ~PMT_CTL_RES_CLR_WKP_EN_;
4555 	buf |= PMT_CTL_RES_CLR_WKP_STS_;
4556 	buf |= PMT_CTL_PHY_WAKE_EN_;
4557 	buf |= PMT_CTL_WOL_EN_;
4558 	buf &= ~PMT_CTL_SUS_MODE_MASK_;
4559 	buf |= PMT_CTL_SUS_MODE_3_;
4560 
4561 	ret = lan78xx_write_reg(dev, PMT_CTL, buf);
4562 	if (ret < 0)
4563 		return ret;
4564 
4565 	ret = lan78xx_read_reg(dev, PMT_CTL, &buf);
4566 	if (ret < 0)
4567 		return ret;
4568 
4569 	buf |= PMT_CTL_WUPS_MASK_;
4570 
4571 	ret = lan78xx_write_reg(dev, PMT_CTL, buf);
4572 	if (ret < 0)
4573 		return ret;
4574 
4575 	ret = lan78xx_start_rx_path(dev);
4576 
4577 	return ret;
4578 }
4579 
lan78xx_set_suspend(struct lan78xx_net * dev,u32 wol)4580 static int lan78xx_set_suspend(struct lan78xx_net *dev, u32 wol)
4581 {
4582 	const u8 ipv4_multicast[3] = { 0x01, 0x00, 0x5E };
4583 	const u8 ipv6_multicast[3] = { 0x33, 0x33 };
4584 	const u8 arp_type[2] = { 0x08, 0x06 };
4585 	u32 temp_pmt_ctl;
4586 	int mask_index;
4587 	u32 temp_wucsr;
4588 	u32 buf;
4589 	u16 crc;
4590 	int ret;
4591 
4592 	ret = lan78xx_stop_tx_path(dev);
4593 	if (ret < 0)
4594 		return ret;
4595 	ret = lan78xx_stop_rx_path(dev);
4596 	if (ret < 0)
4597 		return ret;
4598 
4599 	ret = lan78xx_write_reg(dev, WUCSR, 0);
4600 	if (ret < 0)
4601 		return ret;
4602 	ret = lan78xx_write_reg(dev, WUCSR2, 0);
4603 	if (ret < 0)
4604 		return ret;
4605 	ret = lan78xx_write_reg(dev, WK_SRC, 0xFFF1FF1FUL);
4606 	if (ret < 0)
4607 		return ret;
4608 
4609 	temp_wucsr = 0;
4610 
4611 	temp_pmt_ctl = 0;
4612 
4613 	ret = lan78xx_read_reg(dev, PMT_CTL, &temp_pmt_ctl);
4614 	if (ret < 0)
4615 		return ret;
4616 
4617 	temp_pmt_ctl &= ~PMT_CTL_RES_CLR_WKP_EN_;
4618 	temp_pmt_ctl |= PMT_CTL_RES_CLR_WKP_STS_;
4619 
4620 	for (mask_index = 0; mask_index < NUM_OF_WUF_CFG; mask_index++) {
4621 		ret = lan78xx_write_reg(dev, WUF_CFG(mask_index), 0);
4622 		if (ret < 0)
4623 			return ret;
4624 	}
4625 
4626 	mask_index = 0;
4627 	if (wol & WAKE_PHY) {
4628 		temp_pmt_ctl |= PMT_CTL_PHY_WAKE_EN_;
4629 
4630 		temp_pmt_ctl |= PMT_CTL_WOL_EN_;
4631 		temp_pmt_ctl &= ~PMT_CTL_SUS_MODE_MASK_;
4632 		temp_pmt_ctl |= PMT_CTL_SUS_MODE_0_;
4633 	}
4634 	if (wol & WAKE_MAGIC) {
4635 		temp_wucsr |= WUCSR_MPEN_;
4636 
4637 		temp_pmt_ctl |= PMT_CTL_WOL_EN_;
4638 		temp_pmt_ctl &= ~PMT_CTL_SUS_MODE_MASK_;
4639 		temp_pmt_ctl |= PMT_CTL_SUS_MODE_3_;
4640 	}
4641 	if (wol & WAKE_BCAST) {
4642 		temp_wucsr |= WUCSR_BCST_EN_;
4643 
4644 		temp_pmt_ctl |= PMT_CTL_WOL_EN_;
4645 		temp_pmt_ctl &= ~PMT_CTL_SUS_MODE_MASK_;
4646 		temp_pmt_ctl |= PMT_CTL_SUS_MODE_0_;
4647 	}
4648 	if (wol & WAKE_MCAST) {
4649 		temp_wucsr |= WUCSR_WAKE_EN_;
4650 
4651 		/* set WUF_CFG & WUF_MASK for IPv4 Multicast */
4652 		crc = lan78xx_wakeframe_crc16(ipv4_multicast, 3);
4653 		ret = lan78xx_write_reg(dev, WUF_CFG(mask_index),
4654 					WUF_CFGX_EN_ |
4655 					WUF_CFGX_TYPE_MCAST_ |
4656 					(0 << WUF_CFGX_OFFSET_SHIFT_) |
4657 					(crc & WUF_CFGX_CRC16_MASK_));
4658 		if (ret < 0)
4659 			return ret;
4660 
4661 		ret = lan78xx_write_reg(dev, WUF_MASK0(mask_index), 7);
4662 		if (ret < 0)
4663 			return ret;
4664 		ret = lan78xx_write_reg(dev, WUF_MASK1(mask_index), 0);
4665 		if (ret < 0)
4666 			return ret;
4667 		ret = lan78xx_write_reg(dev, WUF_MASK2(mask_index), 0);
4668 		if (ret < 0)
4669 			return ret;
4670 		ret = lan78xx_write_reg(dev, WUF_MASK3(mask_index), 0);
4671 		if (ret < 0)
4672 			return ret;
4673 
4674 		mask_index++;
4675 
4676 		/* for IPv6 Multicast */
4677 		crc = lan78xx_wakeframe_crc16(ipv6_multicast, 2);
4678 		ret = lan78xx_write_reg(dev, WUF_CFG(mask_index),
4679 					WUF_CFGX_EN_ |
4680 					WUF_CFGX_TYPE_MCAST_ |
4681 					(0 << WUF_CFGX_OFFSET_SHIFT_) |
4682 					(crc & WUF_CFGX_CRC16_MASK_));
4683 		if (ret < 0)
4684 			return ret;
4685 
4686 		ret = lan78xx_write_reg(dev, WUF_MASK0(mask_index), 3);
4687 		if (ret < 0)
4688 			return ret;
4689 		ret = lan78xx_write_reg(dev, WUF_MASK1(mask_index), 0);
4690 		if (ret < 0)
4691 			return ret;
4692 		ret = lan78xx_write_reg(dev, WUF_MASK2(mask_index), 0);
4693 		if (ret < 0)
4694 			return ret;
4695 		ret = lan78xx_write_reg(dev, WUF_MASK3(mask_index), 0);
4696 		if (ret < 0)
4697 			return ret;
4698 
4699 		mask_index++;
4700 
4701 		temp_pmt_ctl |= PMT_CTL_WOL_EN_;
4702 		temp_pmt_ctl &= ~PMT_CTL_SUS_MODE_MASK_;
4703 		temp_pmt_ctl |= PMT_CTL_SUS_MODE_0_;
4704 	}
4705 	if (wol & WAKE_UCAST) {
4706 		temp_wucsr |= WUCSR_PFDA_EN_;
4707 
4708 		temp_pmt_ctl |= PMT_CTL_WOL_EN_;
4709 		temp_pmt_ctl &= ~PMT_CTL_SUS_MODE_MASK_;
4710 		temp_pmt_ctl |= PMT_CTL_SUS_MODE_0_;
4711 	}
4712 	if (wol & WAKE_ARP) {
4713 		temp_wucsr |= WUCSR_WAKE_EN_;
4714 
4715 		/* set WUF_CFG & WUF_MASK
4716 		 * for packettype (offset 12,13) = ARP (0x0806)
4717 		 */
4718 		crc = lan78xx_wakeframe_crc16(arp_type, 2);
4719 		ret = lan78xx_write_reg(dev, WUF_CFG(mask_index),
4720 					WUF_CFGX_EN_ |
4721 					WUF_CFGX_TYPE_ALL_ |
4722 					(0 << WUF_CFGX_OFFSET_SHIFT_) |
4723 					(crc & WUF_CFGX_CRC16_MASK_));
4724 		if (ret < 0)
4725 			return ret;
4726 
4727 		ret = lan78xx_write_reg(dev, WUF_MASK0(mask_index), 0x3000);
4728 		if (ret < 0)
4729 			return ret;
4730 		ret = lan78xx_write_reg(dev, WUF_MASK1(mask_index), 0);
4731 		if (ret < 0)
4732 			return ret;
4733 		ret = lan78xx_write_reg(dev, WUF_MASK2(mask_index), 0);
4734 		if (ret < 0)
4735 			return ret;
4736 		ret = lan78xx_write_reg(dev, WUF_MASK3(mask_index), 0);
4737 		if (ret < 0)
4738 			return ret;
4739 
4740 		mask_index++;
4741 
4742 		temp_pmt_ctl |= PMT_CTL_WOL_EN_;
4743 		temp_pmt_ctl &= ~PMT_CTL_SUS_MODE_MASK_;
4744 		temp_pmt_ctl |= PMT_CTL_SUS_MODE_0_;
4745 	}
4746 
4747 	ret = lan78xx_write_reg(dev, WUCSR, temp_wucsr);
4748 	if (ret < 0)
4749 		return ret;
4750 
4751 	/* when multiple WOL bits are set */
4752 	if (hweight_long((unsigned long)wol) > 1) {
4753 		temp_pmt_ctl |= PMT_CTL_WOL_EN_;
4754 		temp_pmt_ctl &= ~PMT_CTL_SUS_MODE_MASK_;
4755 		temp_pmt_ctl |= PMT_CTL_SUS_MODE_0_;
4756 	}
4757 	ret = lan78xx_write_reg(dev, PMT_CTL, temp_pmt_ctl);
4758 	if (ret < 0)
4759 		return ret;
4760 
4761 	/* clear WUPS */
4762 	ret = lan78xx_read_reg(dev, PMT_CTL, &buf);
4763 	if (ret < 0)
4764 		return ret;
4765 
4766 	buf |= PMT_CTL_WUPS_MASK_;
4767 
4768 	ret = lan78xx_write_reg(dev, PMT_CTL, buf);
4769 	if (ret < 0)
4770 		return ret;
4771 
4772 	ret = lan78xx_start_rx_path(dev);
4773 
4774 	return ret;
4775 }
4776 
lan78xx_suspend(struct usb_interface * intf,pm_message_t message)4777 static int lan78xx_suspend(struct usb_interface *intf, pm_message_t message)
4778 {
4779 	struct lan78xx_net *dev = usb_get_intfdata(intf);
4780 	bool dev_open;
4781 	int ret;
4782 
4783 	mutex_lock(&dev->dev_mutex);
4784 
4785 	netif_dbg(dev, ifdown, dev->net,
4786 		  "suspending: pm event %#x", message.event);
4787 
4788 	dev_open = test_bit(EVENT_DEV_OPEN, &dev->flags);
4789 
4790 	if (dev_open) {
4791 		spin_lock_irq(&dev->txq.lock);
4792 		/* don't autosuspend while transmitting */
4793 		if ((skb_queue_len(&dev->txq) ||
4794 		     skb_queue_len(&dev->txq_pend)) &&
4795 		    PMSG_IS_AUTO(message)) {
4796 			spin_unlock_irq(&dev->txq.lock);
4797 			ret = -EBUSY;
4798 			goto out;
4799 		} else {
4800 			set_bit(EVENT_DEV_ASLEEP, &dev->flags);
4801 			spin_unlock_irq(&dev->txq.lock);
4802 		}
4803 
4804 		/* stop RX */
4805 		ret = lan78xx_stop_rx_path(dev);
4806 		if (ret < 0)
4807 			goto out;
4808 
4809 		ret = lan78xx_flush_rx_fifo(dev);
4810 		if (ret < 0)
4811 			goto out;
4812 
4813 		/* stop Tx */
4814 		ret = lan78xx_stop_tx_path(dev);
4815 		if (ret < 0)
4816 			goto out;
4817 
4818 		/* empty out the Rx and Tx queues */
4819 		netif_device_detach(dev->net);
4820 		lan78xx_terminate_urbs(dev);
4821 		usb_kill_urb(dev->urb_intr);
4822 
4823 		/* reattach */
4824 		netif_device_attach(dev->net);
4825 
4826 		del_timer(&dev->stat_monitor);
4827 
4828 		if (PMSG_IS_AUTO(message)) {
4829 			ret = lan78xx_set_auto_suspend(dev);
4830 			if (ret < 0)
4831 				goto out;
4832 		} else {
4833 			struct lan78xx_priv *pdata;
4834 
4835 			pdata = (struct lan78xx_priv *)(dev->data[0]);
4836 			netif_carrier_off(dev->net);
4837 			ret = lan78xx_set_suspend(dev, pdata->wol);
4838 			if (ret < 0)
4839 				goto out;
4840 		}
4841 	} else {
4842 		/* Interface is down; don't allow WOL and PHY
4843 		 * events to wake up the host
4844 		 */
4845 		u32 buf;
4846 
4847 		set_bit(EVENT_DEV_ASLEEP, &dev->flags);
4848 
4849 		ret = lan78xx_write_reg(dev, WUCSR, 0);
4850 		if (ret < 0)
4851 			goto out;
4852 		ret = lan78xx_write_reg(dev, WUCSR2, 0);
4853 		if (ret < 0)
4854 			goto out;
4855 
4856 		ret = lan78xx_read_reg(dev, PMT_CTL, &buf);
4857 		if (ret < 0)
4858 			goto out;
4859 
4860 		buf &= ~PMT_CTL_RES_CLR_WKP_EN_;
4861 		buf |= PMT_CTL_RES_CLR_WKP_STS_;
4862 		buf &= ~PMT_CTL_SUS_MODE_MASK_;
4863 		buf |= PMT_CTL_SUS_MODE_3_;
4864 
4865 		ret = lan78xx_write_reg(dev, PMT_CTL, buf);
4866 		if (ret < 0)
4867 			goto out;
4868 
4869 		ret = lan78xx_read_reg(dev, PMT_CTL, &buf);
4870 		if (ret < 0)
4871 			goto out;
4872 
4873 		buf |= PMT_CTL_WUPS_MASK_;
4874 
4875 		ret = lan78xx_write_reg(dev, PMT_CTL, buf);
4876 		if (ret < 0)
4877 			goto out;
4878 	}
4879 
4880 	ret = 0;
4881 out:
4882 	mutex_unlock(&dev->dev_mutex);
4883 
4884 	return ret;
4885 }
4886 
lan78xx_submit_deferred_urbs(struct lan78xx_net * dev)4887 static bool lan78xx_submit_deferred_urbs(struct lan78xx_net *dev)
4888 {
4889 	bool pipe_halted = false;
4890 	struct urb *urb;
4891 
4892 	while ((urb = usb_get_from_anchor(&dev->deferred))) {
4893 		struct sk_buff *skb = urb->context;
4894 		int ret;
4895 
4896 		if (!netif_device_present(dev->net) ||
4897 		    !netif_carrier_ok(dev->net) ||
4898 		    pipe_halted) {
4899 			lan78xx_release_tx_buf(dev, skb);
4900 			continue;
4901 		}
4902 
4903 		ret = usb_submit_urb(urb, GFP_ATOMIC);
4904 
4905 		if (ret == 0) {
4906 			netif_trans_update(dev->net);
4907 			lan78xx_queue_skb(&dev->txq, skb, tx_start);
4908 		} else {
4909 			if (ret == -EPIPE) {
4910 				netif_stop_queue(dev->net);
4911 				pipe_halted = true;
4912 			} else if (ret == -ENODEV) {
4913 				netif_device_detach(dev->net);
4914 			}
4915 
4916 			lan78xx_release_tx_buf(dev, skb);
4917 		}
4918 	}
4919 
4920 	return pipe_halted;
4921 }
4922 
lan78xx_resume(struct usb_interface * intf)4923 static int lan78xx_resume(struct usb_interface *intf)
4924 {
4925 	struct lan78xx_net *dev = usb_get_intfdata(intf);
4926 	bool dev_open;
4927 	int ret;
4928 
4929 	mutex_lock(&dev->dev_mutex);
4930 
4931 	netif_dbg(dev, ifup, dev->net, "resuming device");
4932 
4933 	dev_open = test_bit(EVENT_DEV_OPEN, &dev->flags);
4934 
4935 	if (dev_open) {
4936 		bool pipe_halted = false;
4937 
4938 		ret = lan78xx_flush_tx_fifo(dev);
4939 		if (ret < 0)
4940 			goto out;
4941 
4942 		if (dev->urb_intr) {
4943 			int ret = usb_submit_urb(dev->urb_intr, GFP_KERNEL);
4944 
4945 			if (ret < 0) {
4946 				if (ret == -ENODEV)
4947 					netif_device_detach(dev->net);
4948 				netdev_warn(dev->net, "Failed to submit intr URB");
4949 			}
4950 		}
4951 
4952 		spin_lock_irq(&dev->txq.lock);
4953 
4954 		if (netif_device_present(dev->net)) {
4955 			pipe_halted = lan78xx_submit_deferred_urbs(dev);
4956 
4957 			if (pipe_halted)
4958 				lan78xx_defer_kevent(dev, EVENT_TX_HALT);
4959 		}
4960 
4961 		clear_bit(EVENT_DEV_ASLEEP, &dev->flags);
4962 
4963 		spin_unlock_irq(&dev->txq.lock);
4964 
4965 		if (!pipe_halted &&
4966 		    netif_device_present(dev->net) &&
4967 		    (lan78xx_tx_pend_data_len(dev) < lan78xx_tx_urb_space(dev)))
4968 			netif_start_queue(dev->net);
4969 
4970 		ret = lan78xx_start_tx_path(dev);
4971 		if (ret < 0)
4972 			goto out;
4973 
4974 		napi_schedule(&dev->napi);
4975 
4976 		if (!timer_pending(&dev->stat_monitor)) {
4977 			dev->delta = 1;
4978 			mod_timer(&dev->stat_monitor,
4979 				  jiffies + STAT_UPDATE_TIMER);
4980 		}
4981 
4982 	} else {
4983 		clear_bit(EVENT_DEV_ASLEEP, &dev->flags);
4984 	}
4985 
4986 	ret = lan78xx_write_reg(dev, WUCSR2, 0);
4987 	if (ret < 0)
4988 		goto out;
4989 	ret = lan78xx_write_reg(dev, WUCSR, 0);
4990 	if (ret < 0)
4991 		goto out;
4992 	ret = lan78xx_write_reg(dev, WK_SRC, 0xFFF1FF1FUL);
4993 	if (ret < 0)
4994 		goto out;
4995 
4996 	ret = lan78xx_write_reg(dev, WUCSR2, WUCSR2_NS_RCD_ |
4997 					     WUCSR2_ARP_RCD_ |
4998 					     WUCSR2_IPV6_TCPSYN_RCD_ |
4999 					     WUCSR2_IPV4_TCPSYN_RCD_);
5000 	if (ret < 0)
5001 		goto out;
5002 
5003 	ret = lan78xx_write_reg(dev, WUCSR, WUCSR_EEE_TX_WAKE_ |
5004 					    WUCSR_EEE_RX_WAKE_ |
5005 					    WUCSR_PFDA_FR_ |
5006 					    WUCSR_RFE_WAKE_FR_ |
5007 					    WUCSR_WUFR_ |
5008 					    WUCSR_MPR_ |
5009 					    WUCSR_BCST_FR_);
5010 	if (ret < 0)
5011 		goto out;
5012 
5013 	ret = 0;
5014 out:
5015 	mutex_unlock(&dev->dev_mutex);
5016 
5017 	return ret;
5018 }
5019 
lan78xx_reset_resume(struct usb_interface * intf)5020 static int lan78xx_reset_resume(struct usb_interface *intf)
5021 {
5022 	struct lan78xx_net *dev = usb_get_intfdata(intf);
5023 	int ret;
5024 
5025 	netif_dbg(dev, ifup, dev->net, "(reset) resuming device");
5026 
5027 	ret = lan78xx_reset(dev);
5028 	if (ret < 0)
5029 		return ret;
5030 
5031 	phy_start(dev->net->phydev);
5032 
5033 	ret = lan78xx_resume(intf);
5034 
5035 	return ret;
5036 }
5037 
5038 static const struct usb_device_id products[] = {
5039 	{
5040 	/* LAN7800 USB Gigabit Ethernet Device */
5041 	USB_DEVICE(LAN78XX_USB_VENDOR_ID, LAN7800_USB_PRODUCT_ID),
5042 	},
5043 	{
5044 	/* LAN7850 USB Gigabit Ethernet Device */
5045 	USB_DEVICE(LAN78XX_USB_VENDOR_ID, LAN7850_USB_PRODUCT_ID),
5046 	},
5047 	{
5048 	/* LAN7801 USB Gigabit Ethernet Device */
5049 	USB_DEVICE(LAN78XX_USB_VENDOR_ID, LAN7801_USB_PRODUCT_ID),
5050 	},
5051 	{
5052 	/* ATM2-AF USB Gigabit Ethernet Device */
5053 	USB_DEVICE(AT29M2AF_USB_VENDOR_ID, AT29M2AF_USB_PRODUCT_ID),
5054 	},
5055 	{},
5056 };
5057 MODULE_DEVICE_TABLE(usb, products);
5058 
5059 static struct usb_driver lan78xx_driver = {
5060 	.name			= DRIVER_NAME,
5061 	.id_table		= products,
5062 	.probe			= lan78xx_probe,
5063 	.disconnect		= lan78xx_disconnect,
5064 	.suspend		= lan78xx_suspend,
5065 	.resume			= lan78xx_resume,
5066 	.reset_resume		= lan78xx_reset_resume,
5067 	.supports_autosuspend	= 1,
5068 	.disable_hub_initiated_lpm = 1,
5069 };
5070 
5071 module_usb_driver(lan78xx_driver);
5072 
5073 MODULE_AUTHOR(DRIVER_AUTHOR);
5074 MODULE_DESCRIPTION(DRIVER_DESC);
5075 MODULE_LICENSE("GPL");
5076