2018-11-10 11:03:18 +00:00
|
|
|
From 519f76313689c7e2f03da2e7c91e3c75e68c9034 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Phil Elwell <phil@raspberrypi.org>
|
|
|
|
Date: Fri, 9 Mar 2018 12:01:00 +0000
|
|
|
|
Subject: [PATCH 251/454] lan78xx: Read initial EEE status from DT
|
|
|
|
|
|
|
|
Add two new DT properties:
|
|
|
|
* microchip,eee-enabled - a boolean to enable EEE
|
|
|
|
* microchip,tx-lpi-timer - time in microseconds to wait before entering
|
|
|
|
low power state
|
|
|
|
|
|
|
|
Signed-off-by: Phil Elwell <phil@raspberrypi.org>
|
|
|
|
---
|
|
|
|
drivers/net/usb/lan78xx.c | 16 ++++++++++++++++
|
|
|
|
1 file changed, 16 insertions(+)
|
|
|
|
|
|
|
|
--- a/drivers/net/usb/lan78xx.c
|
|
|
|
+++ b/drivers/net/usb/lan78xx.c
|
kernel: bump 4.14 to 4.14.93
Refresh patches.
Remove upstreamed patches:
- backport/096-mips-math-emu-Write-protect-delay-slot-emulation-pages.patch
- pending/510-f2fs-fix-sanity_check_raw_super-on-big-endian-machines.patch
- brcm2708/950-0415-qmi_wwan-apply-SET_DTR-quirk-to-the-SIMCOM-shared-de.patch
Compile-tested: ar71xx, ath79, brcm2708/bcm27{08,10}, octeon, x86/64
Runtime-tested: ar71xx, ath79, brcm2708/bcm27{08,10}, octeon, x86/64
Signed-off-by: Stijn Tintel <stijn@linux-ipv6.be>
2019-01-13 19:50:36 +00:00
|
|
|
@@ -2514,6 +2514,22 @@ static int lan78xx_open(struct net_devic
|
2018-11-10 11:03:18 +00:00
|
|
|
|
|
|
|
netif_dbg(dev, ifup, dev->net, "phy initialised successfully");
|
|
|
|
|
|
|
|
+ if (of_property_read_bool(dev->udev->dev.of_node,
|
|
|
|
+ "microchip,eee-enabled")) {
|
|
|
|
+ struct ethtool_eee edata;
|
|
|
|
+ memset(&edata, 0, sizeof(edata));
|
|
|
|
+ edata.cmd = ETHTOOL_SEEE;
|
|
|
|
+ edata.advertised = ADVERTISED_1000baseT_Full |
|
|
|
|
+ ADVERTISED_100baseT_Full;
|
|
|
|
+ edata.eee_enabled = true;
|
|
|
|
+ edata.tx_lpi_enabled = true;
|
|
|
|
+ if (of_property_read_u32(dev->udev->dev.of_node,
|
|
|
|
+ "microchip,tx-lpi-timer",
|
|
|
|
+ &edata.tx_lpi_timer))
|
|
|
|
+ edata.tx_lpi_timer = 600; /* non-aggressive */
|
|
|
|
+ (void)lan78xx_set_eee(net, &edata);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
/* for Link Check */
|
|
|
|
if (dev->urb_intr) {
|
|
|
|
ret = usb_submit_urb(dev->urb_intr, GFP_KERNEL);
|