mirror of
git://projects.qi-hardware.com/openwrt-xburst.git
synced 2024-12-12 16:53:45 +02:00
ar71xx: enable MIB counters in the built-in switch of the AR934x
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@31476 3c298f89-4303-0410-b956-a3cf2f4a3e73
This commit is contained in:
parent
efae7066fc
commit
1d61105c25
@ -83,6 +83,7 @@
|
|||||||
#define AR7240_MIB_AT_HALF_EN BIT(16)
|
#define AR7240_MIB_AT_HALF_EN BIT(16)
|
||||||
#define AR7240_MIB_BUSY BIT(17)
|
#define AR7240_MIB_BUSY BIT(17)
|
||||||
#define AR7240_MIB_FUNC_S 24
|
#define AR7240_MIB_FUNC_S 24
|
||||||
|
#define AR7240_MIB_FUNC_M BITM(3)
|
||||||
#define AR7240_MIB_FUNC_NO_OP 0x0
|
#define AR7240_MIB_FUNC_NO_OP 0x0
|
||||||
#define AR7240_MIB_FUNC_FLUSH 0x1
|
#define AR7240_MIB_FUNC_FLUSH 0x1
|
||||||
#define AR7240_MIB_FUNC_CAPTURE 0x3
|
#define AR7240_MIB_FUNC_CAPTURE 0x3
|
||||||
@ -218,6 +219,8 @@
|
|||||||
#define AR934X_AT_CTRL_AGE_EN BIT(17)
|
#define AR934X_AT_CTRL_AGE_EN BIT(17)
|
||||||
#define AR934X_AT_CTRL_LEARN_CHANGE BIT(18)
|
#define AR934X_AT_CTRL_LEARN_CHANGE BIT(18)
|
||||||
|
|
||||||
|
#define AR934X_MIB_ENABLE BIT(30)
|
||||||
|
|
||||||
#define AR934X_REG_PORT_BASE(_port) (0x100 + (_port) * 0x100)
|
#define AR934X_REG_PORT_BASE(_port) (0x100 + (_port) * 0x100)
|
||||||
|
|
||||||
#define AR934X_REG_PORT_VLAN1(_port) (AR934X_REG_PORT_BASE((_port)) + 0x08)
|
#define AR934X_REG_PORT_VLAN1(_port) (AR934X_REG_PORT_BASE((_port)) + 0x08)
|
||||||
@ -517,8 +520,9 @@ static int ar7240sw_capture_stats(struct ar7240sw *as)
|
|||||||
write_lock(&as->stats_lock);
|
write_lock(&as->stats_lock);
|
||||||
|
|
||||||
/* Capture the hardware statistics for all ports */
|
/* Capture the hardware statistics for all ports */
|
||||||
ar7240sw_reg_write(mii, AR7240_REG_MIB_FUNCTION0,
|
ar7240sw_reg_rmw(mii, AR7240_REG_MIB_FUNCTION0,
|
||||||
(AR7240_MIB_FUNC_CAPTURE << AR7240_MIB_FUNC_S));
|
(AR7240_MIB_FUNC_M << AR7240_MIB_FUNC_S),
|
||||||
|
(AR7240_MIB_FUNC_CAPTURE << AR7240_MIB_FUNC_S));
|
||||||
|
|
||||||
/* Wait for the capturing to complete. */
|
/* Wait for the capturing to complete. */
|
||||||
ret = ar7240sw_reg_wait(mii, AR7240_REG_MIB_FUNCTION0,
|
ret = ar7240sw_reg_wait(mii, AR7240_REG_MIB_FUNCTION0,
|
||||||
@ -579,6 +583,11 @@ static void ar7240sw_setup(struct ar7240sw *as)
|
|||||||
/* Enable Broadcast frames transmitted to the CPU */
|
/* Enable Broadcast frames transmitted to the CPU */
|
||||||
ar7240sw_reg_set(mii, AR934X_REG_FLOOD_MASK,
|
ar7240sw_reg_set(mii, AR934X_REG_FLOOD_MASK,
|
||||||
AR934X_FLOOD_MASK_BC_DP(0));
|
AR934X_FLOOD_MASK_BC_DP(0));
|
||||||
|
|
||||||
|
/* Enable MIB counters */
|
||||||
|
ar7240sw_reg_set(mii, AR7240_REG_MIB_FUNCTION0,
|
||||||
|
AR934X_MIB_ENABLE);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
/* Enable ARP frame acknowledge, aging, MAC replacing */
|
/* Enable ARP frame acknowledge, aging, MAC replacing */
|
||||||
ar7240sw_reg_write(mii, AR7240_REG_AT_CTRL,
|
ar7240sw_reg_write(mii, AR7240_REG_AT_CTRL,
|
||||||
|
Loading…
Reference in New Issue
Block a user