diff options
author | juhosg <juhosg@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2012-03-18 22:06:30 +0000 |
---|---|---|
committer | juhosg <juhosg@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2012-03-18 22:06:30 +0000 |
commit | c097ab2bbd8d45e3cc0075cf27dca6f76cb5efe5 (patch) | |
tree | 409788f3761995d0daf6650e2f0e8dc92b67913c /target/linux/generic/files | |
parent | 6934b97c4e701732bc5b2e33cdcd628ed63ce0db (diff) |
generic: ar8216: add vtu_load_vlan field to ar8xxx_chip
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@31002 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'target/linux/generic/files')
-rw-r--r-- | target/linux/generic/files/drivers/net/phy/ar8216.c | 19 |
1 files changed, 15 insertions, 4 deletions
diff --git a/target/linux/generic/files/drivers/net/phy/ar8216.c b/target/linux/generic/files/drivers/net/phy/ar8216.c index 54d57d5499..d514ec724f 100644 --- a/target/linux/generic/files/drivers/net/phy/ar8216.c +++ b/target/linux/generic/files/drivers/net/phy/ar8216.c @@ -45,6 +45,7 @@ struct ar8xxx_chip { u32 ingress, u32 members, u32 pvid); int (*atu_flush)(struct ar8216_priv *priv); void (*vtu_flush)(struct ar8216_priv *priv); + void (*vtu_load_vlan)(struct ar8216_priv *priv, u32 vid, u32 port_mask); }; struct ar8216_priv { @@ -489,6 +490,15 @@ ar8216_vtu_flush(struct ar8216_priv *priv) ar8216_vtu_op(priv, AR8216_VTU_OP_FLUSH, 0); } +static void +ar8216_vtu_load_vlan(struct ar8216_priv *priv, u32 vid, u32 port_mask) +{ + u32 op; + + op = AR8216_VTU_OP_LOAD | (vid << AR8216_VTU_VID_S); + ar8216_vtu_op(priv, op, port_mask); +} + static int ar8216_atu_flush(struct ar8216_priv *priv) { @@ -578,10 +588,8 @@ ar8216_hw_apply(struct switch_dev *dev) portmask[i] |= vp & ~mask; } - ar8216_vtu_op(priv, - AR8216_VTU_OP_LOAD | - (priv->vlan_id[j] << AR8216_VTU_VID_S), - priv->vlan_table[j]); + priv->chip->vtu_load_vlan(priv, priv->vlan_id[j], + priv->vlan_table[j]); } } else { /* vlan disabled: @@ -768,6 +776,7 @@ static const struct ar8xxx_chip ar8216_chip = { .setup_port = ar8216_setup_port, .atu_flush = ar8216_atu_flush, .vtu_flush = ar8216_vtu_flush, + .vtu_load_vlan = ar8216_vtu_load_vlan, }; static const struct ar8xxx_chip ar8236_chip = { @@ -776,6 +785,7 @@ static const struct ar8xxx_chip ar8236_chip = { .setup_port = ar8236_setup_port, .atu_flush = ar8216_atu_flush, .vtu_flush = ar8216_vtu_flush, + .vtu_load_vlan = ar8216_vtu_load_vlan, }; static const struct ar8xxx_chip ar8316_chip = { @@ -784,6 +794,7 @@ static const struct ar8xxx_chip ar8316_chip = { .setup_port = ar8216_setup_port, .atu_flush = ar8216_atu_flush, .vtu_flush = ar8216_vtu_flush, + .vtu_load_vlan = ar8216_vtu_load_vlan, }; static int |