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
	 Rafał Miłecki
					Rafał Miłecki