From: nbd Date: Thu, 26 Jan 2006 04:02:48 +0000 (+0000) Subject: reset port settings and default vlan assignment when reset is issued on switch-robo... X-Git-Url: http://git.rohieb.name/openwrt.git/commitdiff_plain/7170d88b06300ca09f33e1f354e531b27426d184 reset port settings and default vlan assignment when reset is issued on switch-robo (fixes #245) git-svn-id: svn://svn.openwrt.org/openwrt/trunk@3045 3c298f89-4303-0410-b956-a3cf2f4a3e73 --- diff --git a/openwrt/target/linux/package/switch/src/switch-robo.c b/openwrt/target/linux/package/switch/src/switch-robo.c index 6af0ff713..7e4c4de29 100644 --- a/openwrt/target/linux/package/switch/src/switch-robo.c +++ b/openwrt/target/linux/package/switch/src/switch-robo.c @@ -55,6 +55,7 @@ static int use_et = 0; static int is_5350 = 0; static struct ifreq ifr; static struct net_device *dev; +static unsigned char port[6] = { 0, 1, 2, 3, 4, 8 }; static int do_ioctl(int cmd, void *buf) { @@ -406,7 +407,13 @@ static int handle_reset(void *driver, char *buf, int nr) robo_write16(ROBO_VLAN_PAGE, ROBO_VLAN_WRITE, 0); robo_write16(ROBO_VLAN_PAGE, (is_5350 ? ROBO_VLAN_TABLE_ACCESS_5350 : ROBO_VLAN_TABLE_ACCESS), val16); } - + + /* reset ports to a known good state */ + for (j = 0; j < d->ports; j++) { + robo_write16(ROBO_CTRL_PAGE, port[j], 0x0000); + robo_write16(ROBO_VLAN_PAGE, ROBO_VLAN_PORT0_DEF_TAG + (j << 1), 0); + } + /* enable switching */ set_switch(1);