From bfa8064ccdf5fb7e342e3979b2a569a6979afbc5 Mon Sep 17 00:00:00 2001 From: Felix Fietkau Date: Sun, 22 Mar 2009 20:19:23 +0000 Subject: [PATCH] atheros: in later kernels, vlan 0 no longer works as expected, switch to (1,2) instead of (0,1) for lan/wan SVN-Revision: 14981 --- target/linux/atheros/base-files/etc/preinit.arch | 6 +++--- target/linux/atheros/base-files/etc/uci-defaults/network | 4 ++-- target/linux/generic-2.6/files/drivers/net/phy/mvswitch.c | 8 +++++--- 3 files changed, 10 insertions(+), 8 deletions(-) diff --git a/target/linux/atheros/base-files/etc/preinit.arch b/target/linux/atheros/base-files/etc/preinit.arch index 26bbf2c520..9bda9cc75e 100755 --- a/target/linux/atheros/base-files/etc/preinit.arch +++ b/target/linux/atheros/base-files/etc/preinit.arch @@ -4,8 +4,8 @@ grep 'Atheros AR231[567]' /proc/cpuinfo > /dev/null && { -e "/sys/bus/mdio_bus/drivers/Marvell 88E6060/0:10" ]; then vconfig set_name_type DEV_PLUS_VID_NO_PAD ifconfig eth0 up - vconfig add eth0 0 - ifname=eth0.0 + vconfig add eth0 1 + ifname=eth0.1 else ifname=eth0 fi @@ -15,7 +15,7 @@ grep 'Atheros AR231[567]' /proc/cpuinfo > /dev/null && { sleep 2 if [ -e "/sys/bus/mdio_bus/drivers/Infineon ADM6996/0:00" -o \ -e "/sys/bus/mdio_bus/drivers/Marvell 88E6060/0:10" ]; then - vconfig rem eth0.0 + vconfig rem eth0.1 ifconfig eth0 down fi } diff --git a/target/linux/atheros/base-files/etc/uci-defaults/network b/target/linux/atheros/base-files/etc/uci-defaults/network index 63bc5416b3..fa97109404 100644 --- a/target/linux/atheros/base-files/etc/uci-defaults/network +++ b/target/linux/atheros/base-files/etc/uci-defaults/network @@ -2,9 +2,9 @@ if [ -e "/sys/bus/mdio_bus/drivers/Infineon ADM6996/0:00" -o \ -e "/sys/bus/mdio_bus/drivers/Marvell 88E6060/0:10" ]; then uci batch <vlans[(i == MV_WANPORT ? 1 : 0)] |= (1 << i); + priv->vlans[(i == MV_WANPORT ? 2 : 1)] |= (1 << i); /* before entering reset, disable all ports */ for (i = 0; i < MV_PORTS; i++) @@ -422,7 +422,9 @@ mvswitch_fixup(struct phy_device *dev) { u16 reg; - /* look for the switch on the bus */ + if (dev->addr != 0x10) + return 0; + reg = dev->bus->read(dev->bus, MV_PORTREG(IDENT, 0)) & MV_IDENT_MASK; if (reg != MV_IDENT_VALUE) return 0; -- 2.30.2