Initial commit
	
		
			
	
		
	
	
		
	
		
			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
				
			
		
		
	
	
				
					
				
			
		
			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
				
			This commit is contained in:
		| @@ -0,0 +1,31 @@ | ||||
| From: =?UTF-8?q?Rafa=C5=82=20Mi=C5=82ecki?= <rafal@milecki.pl> | ||||
| Date: Thu, 28 Mar 2024 10:24:34 +0100 | ||||
| Subject: [PATCH] arm64: dts: broadcom: bcmbca: bcm4908: set | ||||
|  brcm,wp-not-connected | ||||
| MIME-Version: 1.0 | ||||
| Content-Type: text/plain; charset=UTF-8 | ||||
| Content-Transfer-Encoding: 8bit | ||||
|  | ||||
| Every described BCM4908 board has WP pin not connected. This caused | ||||
| problems for drivers since day 0 but there was no property to describe | ||||
| that properly. Projects like OpenWrt were modifying Linux driver to deal | ||||
| with it. | ||||
|  | ||||
| It's not clear if that is hardware limitation or just reference design | ||||
| being copied over and over but this applies to all known / supported | ||||
| BCM4908 boards. Handle it by marking WP as not connected by default. | ||||
|  | ||||
| Fixes: 2961f69f151c ("arm64: dts: broadcom: add BCM4908 and Asus GT-AC5300 early DTS files") | ||||
| Signed-off-by: Rafał Miłecki <rafal@milecki.pl> | ||||
| --- | ||||
|  | ||||
| --- a/arch/arm64/boot/dts/broadcom/bcmbca/bcm4908.dtsi | ||||
| +++ b/arch/arm64/boot/dts/broadcom/bcmbca/bcm4908.dtsi | ||||
| @@ -594,6 +594,7 @@ | ||||
|  			reg-names = "nand", "nand-int-base"; | ||||
|  			interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>; | ||||
|  			interrupt-names = "nand_ctlrdy"; | ||||
| +			brcm,wp-not-connected; | ||||
|  			status = "okay"; | ||||
|   | ||||
|  			nandcs: nand@0 { | ||||
| @@ -0,0 +1,23 @@ | ||||
| From: =?UTF-8?q?Rafa=C5=82=20Mi=C5=82ecki?= <rafal@milecki.pl> | ||||
| Date: Mon, 15 Feb 2021 22:01:03 +0100 | ||||
| Subject: [PATCH] arm64: dts: broadcom: bcmbca: bcm4908: limit amount of GPIOs | ||||
| MIME-Version: 1.0 | ||||
| Content-Type: text/plain; charset=UTF-8 | ||||
| Content-Transfer-Encoding: 8bit | ||||
|  | ||||
| Linux driver can't handle more than 64 GPIOs | ||||
|  | ||||
| Signed-off-by: Rafał Miłecki <rafal@milecki.pl> | ||||
| --- | ||||
|  | ||||
| --- a/arch/arm64/boot/dts/broadcom/bcmbca/bcm4908.dtsi | ||||
| +++ b/arch/arm64/boot/dts/broadcom/bcmbca/bcm4908.dtsi | ||||
| @@ -341,7 +341,7 @@ | ||||
|  		gpio0: gpio-controller@500 { | ||||
|  			compatible = "brcm,bcm6345-gpio"; | ||||
|  			reg-names = "dirout", "dat"; | ||||
| -			reg = <0x500 0x28>, <0x528 0x28>; | ||||
| +			reg = <0x500 0x8>, <0x528 0x8>; | ||||
|   | ||||
|  			#gpio-cells = <2>; | ||||
|  			gpio-controller; | ||||
| @@ -0,0 +1,30 @@ | ||||
| From: =?UTF-8?q?Rafa=C5=82=20Mi=C5=82ecki?= <rafal@milecki.pl> | ||||
| Date: Thu, 12 Aug 2021 11:52:42 +0200 | ||||
| Subject: [PATCH] arm64: don't issue HVC on boot | ||||
| MIME-Version: 1.0 | ||||
| Content-Type: text/plain; charset=UTF-8 | ||||
| Content-Transfer-Encoding: 8bit | ||||
|  | ||||
| Broadcom's CFE loader seems to miss setting SCR_EL3.HCE which results in | ||||
| generating an UNDEF and kernel panic on the first HVC. | ||||
|  | ||||
| HVC gets issued by kernels 5.12+ while booting, by kexec and KVM. Until | ||||
| someone finds a workaround we have to avoid all above. | ||||
|  | ||||
| Workarounds: 0c93df9622d4 ("arm64: Initialise as nVHE before switching to VHE") | ||||
| Signed-off-by: Rafał Miłecki <rafal@milecki.pl> | ||||
| --- | ||||
|  arch/arm64/kernel/hyp-stub.S | 2 +- | ||||
|  1 file changed, 1 insertion(+), 1 deletion(-) | ||||
|  | ||||
| --- a/arch/arm64/kernel/hyp-stub.S | ||||
| +++ b/arch/arm64/kernel/hyp-stub.S | ||||
| @@ -252,7 +252,7 @@ SYM_FUNC_START(finalise_el2) | ||||
|  	b.ne	1f | ||||
|   | ||||
|  	mov	x0, #HVC_FINALISE_EL2 | ||||
| -	hvc	#0 | ||||
| +//	hvc	#0 | ||||
|  1: | ||||
|  	ret | ||||
|  SYM_FUNC_END(finalise_el2) | ||||
| @@ -0,0 +1,46 @@ | ||||
| From: =?UTF-8?q?Rafa=C5=82=20Mi=C5=82ecki?= <rafal@milecki.pl> | ||||
| Date: Mon, 15 Feb 2021 23:59:26 +0100 | ||||
| Subject: [PATCH] net: dsa: bcm_sf2: enable GPHY for switch probing | ||||
| MIME-Version: 1.0 | ||||
| Content-Type: text/plain; charset=UTF-8 | ||||
| Content-Transfer-Encoding: 8bit | ||||
|  | ||||
| GPHY needs to be enabled to succesfully probe & setup switch port | ||||
| connected to it. Otherwise hardcoding PHY OUI would be required. | ||||
|  | ||||
| Before: | ||||
| brcm-sf2 80080000.switch lan4 (uninitialized): PHY [800c05c0.mdio--1:08] driver [Generic PHY] (irq=POLL) | ||||
| brcm-sf2 80080000.switch lan3 (uninitialized): PHY [800c05c0.mdio--1:09] driver [Generic PHY] (irq=POLL) | ||||
| brcm-sf2 80080000.switch lan2 (uninitialized): PHY [800c05c0.mdio--1:0a] driver [Generic PHY] (irq=POLL) | ||||
| brcm-sf2 80080000.switch lan1 (uninitialized): PHY [800c05c0.mdio--1:0b] driver [Generic PHY] (irq=POLL) | ||||
| brcm-sf2 80080000.switch wan (uninitialized): error -5 setting up PHY for tree 0, switch 0, port 7 | ||||
|  | ||||
| After: | ||||
| brcm-sf2 80080000.switch lan4 (uninitialized): PHY [800c05c0.mdio--1:08] driver [Generic PHY] (irq=POLL) | ||||
| brcm-sf2 80080000.switch lan3 (uninitialized): PHY [800c05c0.mdio--1:09] driver [Generic PHY] (irq=POLL) | ||||
| brcm-sf2 80080000.switch lan2 (uninitialized): PHY [800c05c0.mdio--1:0a] driver [Generic PHY] (irq=POLL) | ||||
| brcm-sf2 80080000.switch lan1 (uninitialized): PHY [800c05c0.mdio--1:0b] driver [Generic PHY] (irq=POLL) | ||||
| brcm-sf2 80080000.switch wan (uninitialized): PHY [800c05c0.mdio--1:0c] driver [Generic PHY] (irq=POLL) | ||||
|  | ||||
| Signed-off-by: Rafał Miłecki <rafal@milecki.pl> | ||||
| --- | ||||
|  drivers/net/dsa/bcm_sf2.c | 4 ++++ | ||||
|  1 file changed, 4 insertions(+) | ||||
|  | ||||
| --- a/drivers/net/dsa/bcm_sf2.c | ||||
| +++ b/drivers/net/dsa/bcm_sf2.c | ||||
| @@ -1522,10 +1522,14 @@ static int bcm_sf2_sw_probe(struct platf | ||||
|  	rev = reg_readl(priv, REG_PHY_REVISION); | ||||
|  	priv->hw_params.gphy_rev = rev & PHY_REVISION_MASK; | ||||
|   | ||||
| +	bcm_sf2_gphy_enable_set(priv->dev->ds, true); | ||||
| + | ||||
|  	ret = b53_switch_register(dev); | ||||
|  	if (ret) | ||||
|  		goto out_mdio; | ||||
|   | ||||
| +	bcm_sf2_gphy_enable_set(priv->dev->ds, false); | ||||
| + | ||||
|  	dev_info(&pdev->dev, | ||||
|  		 "Starfighter 2 top: %x.%02x, core: %x.%02x, IRQs: %d, %d\n", | ||||
|  		 priv->hw_params.top_rev >> 8, priv->hw_params.top_rev & 0xff, | ||||
| @@ -0,0 +1,30 @@ | ||||
| From: =?UTF-8?q?Rafa=C5=82=20Mi=C5=82ecki?= <rafal@milecki.pl> | ||||
| Date: Tue, 16 Feb 2021 00:06:35 +0100 | ||||
| Subject: [PATCH] net: dsa: bcm_sf2: keep GPHY enabled on the BCM4908 | ||||
|  | ||||
| Trying to access disabled PHY results in MDIO_READ_FAIL and: | ||||
| [   11.962886] brcm-sf2 80080000.switch wan: configuring for phy/internal link mode | ||||
| [   11.972500] 8021q: adding VLAN 0 to HW filter on device wan | ||||
| [   11.980205] ------------[ cut here ]------------ | ||||
| [   11.984885] WARNING: CPU: 0 PID: 7 at phy_error+0x10/0x58 | ||||
|  | ||||
| Signed-off-by: Rafał Miłecki <rafal@milecki.pl> | ||||
| --- | ||||
|  drivers/net/dsa/bcm_sf2.c | 6 ++++++ | ||||
|  1 file changed, 6 insertions(+) | ||||
|  | ||||
| --- a/drivers/net/dsa/bcm_sf2.c | ||||
| +++ b/drivers/net/dsa/bcm_sf2.c | ||||
| @@ -1536,6 +1536,12 @@ static int bcm_sf2_sw_probe(struct platf | ||||
|  		 priv->hw_params.core_rev >> 8, priv->hw_params.core_rev & 0xff, | ||||
|  		 priv->irq0, priv->irq1); | ||||
|   | ||||
| +	/* BCM4908 has 5 GPHYs which means bcm_sf2_port_setup() will not enable | ||||
| +	 * GPHY when needed. Leave it enabled here. | ||||
| +	 */ | ||||
| +	if (priv->type == BCM4908_DEVICE_ID) | ||||
| +		bcm_sf2_gphy_enable_set(priv->dev->ds, true); | ||||
| + | ||||
|  	return 0; | ||||
|   | ||||
|  out_mdio: | ||||
		Reference in New Issue
	
	Block a user
	 domenico
					domenico