 c06fb25d1f
			
		
	
	c06fb25d1f
	
	
		
			
	
		
	
	
		
			Some checks failed
		
		
	
	Build Kernel / Build all affected Kernels (push) Has been cancelled
				
			Build all core packages / Build all core packages for selected target (push) Has been cancelled
				
			Build and Push prebuilt tools container / Build and Push all prebuilt containers (push) Has been cancelled
				
			Build Toolchains / Build Toolchains for each target (push) Has been cancelled
				
			Build host tools / Build host tools for linux and macos based systems (push) Has been cancelled
				
			Coverity scan build / Coverity x86/64 build (push) Has been cancelled
				
			
		
			
				
	
	
		
			50 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			50 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From 0c12fba01d3baf5040f6863eff793f1050220435 Mon Sep 17 00:00:00 2001
 | |
| From: Phil Elwell <phil@raspberrypi.org>
 | |
| Date: Tue, 17 Oct 2017 15:04:29 +0100
 | |
| Subject: [PATCH 0081/1085] lan78xx: Enable LEDs and auto-negotiation
 | |
| 
 | |
| For applications of the LAN78xx that don't have valid programmed
 | |
| EEPROMs or OTPs, enabling both LEDs and auto-negotiation by default
 | |
| seems reasonable.
 | |
| 
 | |
| Signed-off-by: Phil Elwell <phil@raspberrypi.org>
 | |
| ---
 | |
|  drivers/net/usb/lan78xx.c | 12 ++++++++++++
 | |
|  1 file changed, 12 insertions(+)
 | |
| 
 | |
| --- a/drivers/net/usb/lan78xx.c
 | |
| +++ b/drivers/net/usb/lan78xx.c
 | |
| @@ -2884,6 +2884,11 @@ static int lan78xx_reset(struct lan78xx_
 | |
|  	int ret;
 | |
|  	u32 buf;
 | |
|  	u8 sig;
 | |
| +	bool has_eeprom;
 | |
| +	bool has_otp;
 | |
| +
 | |
| +	has_eeprom = !lan78xx_read_eeprom(dev, 0, 0, NULL);
 | |
| +	has_otp = !lan78xx_read_otp(dev, 0, 0, NULL);
 | |
|  
 | |
|  	ret = lan78xx_read_reg(dev, HW_CFG, &buf);
 | |
|  	if (ret < 0)
 | |
| @@ -2948,6 +2953,10 @@ static int lan78xx_reset(struct lan78xx_
 | |
|  
 | |
|  	buf |= HW_CFG_MEF_;
 | |
|  
 | |
| +	/* If no valid EEPROM and no valid OTP, enable the LEDs by default */
 | |
| +	if (!has_eeprom && !has_otp)
 | |
| +	    buf |= HW_CFG_LED0_EN_ | HW_CFG_LED1_EN_;
 | |
| +
 | |
|  	ret = lan78xx_write_reg(dev, HW_CFG, buf);
 | |
|  	if (ret < 0)
 | |
|  		return ret;
 | |
| @@ -3047,6 +3056,9 @@ static int lan78xx_reset(struct lan78xx_
 | |
|  			buf |= MAC_CR_AUTO_DUPLEX_ | MAC_CR_AUTO_SPEED_;
 | |
|  		}
 | |
|  	}
 | |
| +	/* If no valid EEPROM and no valid OTP, enable AUTO negotiation */
 | |
| +	if (!has_eeprom && !has_otp)
 | |
| +	    buf |= MAC_CR_AUTO_DUPLEX_ | MAC_CR_AUTO_SPEED_;
 | |
|  	ret = lan78xx_write_reg(dev, MAC_CR, buf);
 | |
|  	if (ret < 0)
 | |
|  		return ret;
 |