bcm53xx: switch to the upstream DSA-based b53 driver
1. Drop swconfig 2. Simplify network setup 3. Verify network config 4. Disable Buffalo WZR-900DHP for now - it misses ports definition Signed-off-by: Rafał Miłecki <rafal@milecki.pl> Reviewed-By: Christian Lamparter <chunkeey@gmail.com>
This commit is contained in:
		@@ -22,7 +22,7 @@ include $(INCLUDE_DIR)/target.mk
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
KERNELNAME:=zImage dtbs
 | 
					KERNELNAME:=zImage dtbs
 | 
				
			||||||
 | 
					
 | 
				
			||||||
DEFAULT_PACKAGES += swconfig nvram \
 | 
					DEFAULT_PACKAGES += nvram \
 | 
				
			||||||
	osafeloader oseama otrx \
 | 
						osafeloader oseama otrx \
 | 
				
			||||||
	kmod-gpio-button-hotplug \
 | 
						kmod-gpio-button-hotplug \
 | 
				
			||||||
	kmod-leds-gpio
 | 
						kmod-leds-gpio
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -9,74 +9,24 @@ bcm53xx_setup_interfaces()
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
	local board="$1"
 | 
						local board="$1"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	# On BCM4708 / BCM4709(4) there are 3 Ethernet interfaces connected to 3 switch
 | 
					 | 
				
			||||||
	# ports. It's up to vendor which to use.
 | 
					 | 
				
			||||||
	case "$board" in
 | 
						case "$board" in
 | 
				
			||||||
	tenda,ac9)
 | 
						asus,rt-ac87u)
 | 
				
			||||||
		ucidef_add_switch "switch0" \
 | 
							ucidef_set_interfaces_lan_wan "lan1 lan2 lan3" "wan"
 | 
				
			||||||
			"1:lan" "2:lan" "3:lan" "4:lan" "8@eth0" "0:wan" "5@eth1"
 | 
					 | 
				
			||||||
		;;
 | 
					 | 
				
			||||||
	buffalo,wxr-1900dhp| \
 | 
					 | 
				
			||||||
	buffalo,wzr-1750dhp)
 | 
					 | 
				
			||||||
		ucidef_add_switch "switch0" \
 | 
					 | 
				
			||||||
			"0:lan:1" "1:lan:2" "2:lan:3" "3:lan:4" "4:wan:5" "5@eth0"
 | 
					 | 
				
			||||||
		;;
 | 
					 | 
				
			||||||
	dlink,dir-885l | \
 | 
					 | 
				
			||||||
	netgear,r7900 | \
 | 
					 | 
				
			||||||
	netgear,r8000 | \
 | 
					 | 
				
			||||||
	netgear,r8500)
 | 
					 | 
				
			||||||
		# NVRAM specifies port 8 (eth2) - unsupported by OpenWrt b53
 | 
					 | 
				
			||||||
		# Use port 5 (eth0) as workaround
 | 
					 | 
				
			||||||
		ucidef_add_switch "switch0" \
 | 
					 | 
				
			||||||
			"0:lan" "1:lan" "2:lan" "3:lan" "4:wan" "5t@eth0"
 | 
					 | 
				
			||||||
		;;
 | 
							;;
 | 
				
			||||||
	linksys,panamera)
 | 
						linksys,panamera)
 | 
				
			||||||
		ucidef_add_switch "switch1" \
 | 
							ucidef_set_interfaces_lan_wan "lan4 lan7 lan8 extsw" "wan"
 | 
				
			||||||
			"0:lan" "1:lan:7" "2:lan:4" "3:lan:8" "4:wan" "5t@eth0"
 | 
					 | 
				
			||||||
		;;
 | 
					 | 
				
			||||||
	luxul,abr-4500-v1|\
 | 
					 | 
				
			||||||
	luxul,xbr-4500-v1)
 | 
					 | 
				
			||||||
		ucidef_add_switch "switch0" \
 | 
					 | 
				
			||||||
			"0:wan" "1:lan:4" "2:lan:3" "3:lan:2" "4:lan:1" "5@eth0"
 | 
					 | 
				
			||||||
		;;
 | 
							;;
 | 
				
			||||||
	luxul,xap-1610-v1)
 | 
						luxul,xap-1610-v1)
 | 
				
			||||||
		ucidef_add_switch "switch0" \
 | 
							ucidef_set_interface_lan "poe lan" "dhcp"
 | 
				
			||||||
			"0:lan" "1:lan" "5@eth0"
 | 
					 | 
				
			||||||
		ucidef_set_interface_lan "eth0.1" "dhcp"
 | 
					 | 
				
			||||||
		;;
 | 
							;;
 | 
				
			||||||
	luxul,xwr-3150-v1)
 | 
						meraki,mr32)
 | 
				
			||||||
		ucidef_add_switch "switch0" \
 | 
							ucidef_set_interface_lan "poe" "dhcp"
 | 
				
			||||||
			"0:lan:4" "1:lan:3" "2:lan:2" "3:lan:1" "4:wan" "5@eth0"
 | 
					 | 
				
			||||||
		;;
 | 
							;;
 | 
				
			||||||
	phicomm,k3)
 | 
						phicomm,k3)
 | 
				
			||||||
		ucidef_add_switch "switch0" \
 | 
							ucidef_set_interfaces_lan_wan "lan1 lan2 lan3" "wan"
 | 
				
			||||||
			"0:lan" "1:lan" "2:lan" "3:wan" "5@eth0"
 | 
					 | 
				
			||||||
		;;
 | 
							;;
 | 
				
			||||||
	*)
 | 
						*)
 | 
				
			||||||
		# NVRAM entries may contain unsorted ports, e.g. Netgear R6250 uses
 | 
							ucidef_set_interfaces_lan_wan "lan1 lan2 lan3 lan4" "wan"
 | 
				
			||||||
		# vlan1ports=3 2 1 0 5*
 | 
					 | 
				
			||||||
		# vlan2ports=4 5u
 | 
					 | 
				
			||||||
		# and early Netgear R8000 was using
 | 
					 | 
				
			||||||
		# vlan1ports=3 2 1 0 5 7 8*
 | 
					 | 
				
			||||||
		# (the enclosing echo is needed to convert newline back to space)
 | 
					 | 
				
			||||||
		vlan1ports="$(echo $(nvram get vlan1ports | tr " " "\n" | sort))"
 | 
					 | 
				
			||||||
		vlan2ports="$(echo $(nvram get vlan2ports | tr " " "\n" | sort))"
 | 
					 | 
				
			||||||
		if echo "$vlan1ports" | egrep -q "^1 2 3 4 5" && \
 | 
					 | 
				
			||||||
		   echo "$vlan2ports" | egrep -q "^0 5"; then
 | 
					 | 
				
			||||||
			ucidef_add_switch "switch0" \
 | 
					 | 
				
			||||||
				"1:lan" "2:lan" "3:lan" "4:lan" "0:wan" "5t@eth0"
 | 
					 | 
				
			||||||
		elif echo "$vlan1ports" | egrep -q "^1 2 3 5 7" && \
 | 
					 | 
				
			||||||
		     echo "$vlan2ports" | egrep -q "^0 7"; then
 | 
					 | 
				
			||||||
			ucidef_add_switch "switch0" \
 | 
					 | 
				
			||||||
				"1:lan" "2:lan" "3:lan" "5:lan" "0:wan" "7t@eth1"
 | 
					 | 
				
			||||||
		elif echo "$vlan1ports" | egrep -q "^0 1 2 3 5 7 8" && \
 | 
					 | 
				
			||||||
		     echo "$vlan2ports" | egrep -q "^4 8"; then
 | 
					 | 
				
			||||||
			ucidef_add_switch "switch0" \
 | 
					 | 
				
			||||||
				"0:lan" "1:lan" "2:lan" "3:lan" "5:lan" "7:lan" "4:wan" "8t@eth2"
 | 
					 | 
				
			||||||
		else
 | 
					 | 
				
			||||||
			ucidef_add_switch "switch0" \
 | 
					 | 
				
			||||||
				"0:lan" "1:lan" "2:lan" "3:lan" "4:wan" "5t@eth0"
 | 
					 | 
				
			||||||
		fi
 | 
					 | 
				
			||||||
		;;
 | 
							;;
 | 
				
			||||||
	esac
 | 
						esac
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@@ -85,20 +35,8 @@ bcm53xx_setup_macs()
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
	local board="$1"
 | 
						local board="$1"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	case "$board" in
 | 
					 | 
				
			||||||
	dlink,dir-885l | \
 | 
					 | 
				
			||||||
	linksys,panamera | \
 | 
					 | 
				
			||||||
	netgear,r7900 | \
 | 
					 | 
				
			||||||
	netgear,r8000 | \
 | 
					 | 
				
			||||||
	netgear,r8500)
 | 
					 | 
				
			||||||
		# As vendor doesn't use eth0 its MAC may be missing. Use one from eth2.
 | 
					 | 
				
			||||||
		et2macaddr="$(nvram get et2macaddr)"
 | 
					 | 
				
			||||||
		;;
 | 
					 | 
				
			||||||
	esac
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	[ -n "$et2macaddr" ] && ucidef_set_interface_macaddr "lan" "$et2macaddr"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	wan_macaddr="$(nvram get wan_hwaddr)"
 | 
						wan_macaddr="$(nvram get wan_hwaddr)"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	case "$board" in
 | 
						case "$board" in
 | 
				
			||||||
	asus,rt-ac87u)
 | 
						asus,rt-ac87u)
 | 
				
			||||||
		etXmacaddr=$(nvram get et1macaddr)
 | 
							etXmacaddr=$(nvram get et1macaddr)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -0,0 +1,23 @@
 | 
				
			|||||||
 | 
					# SPDX-License-Identifier: GPL-2.0-only
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Exit if network doesn't contain any swconfig section
 | 
				
			||||||
 | 
					uci -q get network.@switch[0] > /dev/null || exit 0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					lan_proto="$(uci -q get network.lan.proto)"
 | 
				
			||||||
 | 
					lan_ipaddr="$(uci -q get network.lan.ipaddr)"
 | 
				
			||||||
 | 
					lan_netmask="$(uci -q get network.lan.netmask)"
 | 
				
			||||||
 | 
					wan_proto="$(uci -q get network.wan.proto)"
 | 
				
			||||||
 | 
					wan_ipaddr="$(uci -q get network.wan.ipaddr)"
 | 
				
			||||||
 | 
					wan_netmask="$(uci -q get network.wan.netmask)"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					rm /etc/config/network
 | 
				
			||||||
 | 
					config_generate
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					uci -q batch <<-EOF
 | 
				
			||||||
 | 
						set network.lan.proto="$lan_proto"
 | 
				
			||||||
 | 
						set network.lan.ipaddr="$lan_ipaddr"
 | 
				
			||||||
 | 
						set network.lan.netmask="$lan_netmask"
 | 
				
			||||||
 | 
						set network.wan.proto="$wan_proto"
 | 
				
			||||||
 | 
						set network.wan.ipaddr="$wan_ipaddr"
 | 
				
			||||||
 | 
						set network.wan.netmask="$wan_netmask"
 | 
				
			||||||
 | 
					EOF
 | 
				
			||||||
@@ -39,6 +39,12 @@ CONFIG_ARM_UNWIND=y
 | 
				
			|||||||
CONFIG_ARM_VIRT_EXT=y
 | 
					CONFIG_ARM_VIRT_EXT=y
 | 
				
			||||||
CONFIG_ATAGS=y
 | 
					CONFIG_ATAGS=y
 | 
				
			||||||
CONFIG_AUTO_ZRELADDR=y
 | 
					CONFIG_AUTO_ZRELADDR=y
 | 
				
			||||||
 | 
					CONFIG_B53=y
 | 
				
			||||||
 | 
					CONFIG_B53_MDIO_DRIVER=y
 | 
				
			||||||
 | 
					# CONFIG_B53_MMAP_DRIVER is not set
 | 
				
			||||||
 | 
					# CONFIG_B53_SERDES is not set
 | 
				
			||||||
 | 
					# CONFIG_B53_SPI_DRIVER is not set
 | 
				
			||||||
 | 
					CONFIG_B53_SRAB_DRIVER=y
 | 
				
			||||||
CONFIG_BCM47XX_NVRAM=y
 | 
					CONFIG_BCM47XX_NVRAM=y
 | 
				
			||||||
CONFIG_BCM47XX_SPROM=y
 | 
					CONFIG_BCM47XX_SPROM=y
 | 
				
			||||||
CONFIG_BCM47XX_WDT=y
 | 
					CONFIG_BCM47XX_WDT=y
 | 
				
			||||||
@@ -149,6 +155,7 @@ CONFIG_GPIOLIB_IRQCHIP=y
 | 
				
			|||||||
CONFIG_GPIO_74X164=y
 | 
					CONFIG_GPIO_74X164=y
 | 
				
			||||||
CONFIG_GPIO_BCM_XGS_IPROC=y
 | 
					CONFIG_GPIO_BCM_XGS_IPROC=y
 | 
				
			||||||
CONFIG_GPIO_GENERIC=y
 | 
					CONFIG_GPIO_GENERIC=y
 | 
				
			||||||
 | 
					CONFIG_GRO_CELLS=y
 | 
				
			||||||
CONFIG_HANDLE_DOMAIN_IRQ=y
 | 
					CONFIG_HANDLE_DOMAIN_IRQ=y
 | 
				
			||||||
CONFIG_HARDEN_BRANCH_PREDICTOR=y
 | 
					CONFIG_HARDEN_BRANCH_PREDICTOR=y
 | 
				
			||||||
CONFIG_HARDIRQS_SW_RESEND=y
 | 
					CONFIG_HARDIRQS_SW_RESEND=y
 | 
				
			||||||
@@ -204,7 +211,14 @@ CONFIG_MTD_UBI_BLOCK=y
 | 
				
			|||||||
CONFIG_MTD_UBI_WL_THRESHOLD=4096
 | 
					CONFIG_MTD_UBI_WL_THRESHOLD=4096
 | 
				
			||||||
CONFIG_MUTEX_SPIN_ON_OWNER=y
 | 
					CONFIG_MUTEX_SPIN_ON_OWNER=y
 | 
				
			||||||
CONFIG_NEED_DMA_MAP_STATE=y
 | 
					CONFIG_NEED_DMA_MAP_STATE=y
 | 
				
			||||||
 | 
					CONFIG_NET_DEVLINK=y
 | 
				
			||||||
 | 
					CONFIG_NET_DSA=y
 | 
				
			||||||
 | 
					CONFIG_NET_DSA_TAG_BRCM=y
 | 
				
			||||||
 | 
					CONFIG_NET_DSA_TAG_BRCM_COMMON=y
 | 
				
			||||||
 | 
					CONFIG_NET_DSA_TAG_BRCM_LEGACY=y
 | 
				
			||||||
 | 
					CONFIG_NET_DSA_TAG_BRCM_PREPEND=y
 | 
				
			||||||
CONFIG_NET_FLOW_LIMIT=y
 | 
					CONFIG_NET_FLOW_LIMIT=y
 | 
				
			||||||
 | 
					CONFIG_NET_SWITCHDEV=y
 | 
				
			||||||
CONFIG_NR_CPUS=2
 | 
					CONFIG_NR_CPUS=2
 | 
				
			||||||
CONFIG_NVMEM=y
 | 
					CONFIG_NVMEM=y
 | 
				
			||||||
CONFIG_NVMEM_BRCM_NVRAM=y
 | 
					CONFIG_NVMEM_BRCM_NVRAM=y
 | 
				
			||||||
@@ -233,6 +247,7 @@ CONFIG_PCI_DOMAINS_GENERIC=y
 | 
				
			|||||||
CONFIG_PERF_USE_VMALLOC=y
 | 
					CONFIG_PERF_USE_VMALLOC=y
 | 
				
			||||||
CONFIG_PGTABLE_LEVELS=2
 | 
					CONFIG_PGTABLE_LEVELS=2
 | 
				
			||||||
CONFIG_PHYLIB=y
 | 
					CONFIG_PHYLIB=y
 | 
				
			||||||
 | 
					CONFIG_PHYLINK=y
 | 
				
			||||||
# CONFIG_PHY_BCM_NS_USB2 is not set
 | 
					# CONFIG_PHY_BCM_NS_USB2 is not set
 | 
				
			||||||
# CONFIG_PHY_BCM_NS_USB3 is not set
 | 
					# CONFIG_PHY_BCM_NS_USB3 is not set
 | 
				
			||||||
# CONFIG_PHY_BCM_SR_PCIE is not set
 | 
					# CONFIG_PHY_BCM_SR_PCIE is not set
 | 
				
			||||||
@@ -266,11 +281,6 @@ CONFIG_SPI_GPIO=y
 | 
				
			|||||||
CONFIG_SPI_MASTER=y
 | 
					CONFIG_SPI_MASTER=y
 | 
				
			||||||
CONFIG_SPI_MEM=y
 | 
					CONFIG_SPI_MEM=y
 | 
				
			||||||
CONFIG_SRCU=y
 | 
					CONFIG_SRCU=y
 | 
				
			||||||
CONFIG_SWCONFIG=y
 | 
					 | 
				
			||||||
CONFIG_SWCONFIG_B53=y
 | 
					 | 
				
			||||||
CONFIG_SWCONFIG_B53_PHY_DRIVER=y
 | 
					 | 
				
			||||||
CONFIG_SWCONFIG_B53_PHY_FIXUP=y
 | 
					 | 
				
			||||||
CONFIG_SWCONFIG_B53_SRAB_DRIVER=y
 | 
					 | 
				
			||||||
CONFIG_SWPHY=y
 | 
					CONFIG_SWPHY=y
 | 
				
			||||||
CONFIG_SWP_EMULATE=y
 | 
					CONFIG_SWP_EMULATE=y
 | 
				
			||||||
CONFIG_SYS_SUPPORTS_APM_EMULATION=y
 | 
					CONFIG_SYS_SUPPORTS_APM_EMULATION=y
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -218,6 +218,7 @@ define Device/buffalo_wzr-900dhp
 | 
				
			|||||||
	buffalo-enc WZR-900DHP2 $$(BUFFALO_TAG_VERSION) | \
 | 
						buffalo-enc WZR-900DHP2 $$(BUFFALO_TAG_VERSION) | \
 | 
				
			||||||
	buffalo-tag-dhp WZR-900DHP2 JP jp | buffalo-enc-tag | \
 | 
						buffalo-tag-dhp WZR-900DHP2 JP jp | buffalo-enc-tag | \
 | 
				
			||||||
	buffalo-dhp-image
 | 
						buffalo-dhp-image
 | 
				
			||||||
 | 
					  BROKEN := y
 | 
				
			||||||
endef
 | 
					endef
 | 
				
			||||||
TARGET_DEVICES += buffalo_wzr-900dhp
 | 
					TARGET_DEVICES += buffalo_wzr-900dhp
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user