]> www.infradead.org Git - users/dwmw2/linux.git/commitdiff
net: stmmac: fix incorrect GMAC_VLAN_TAG register writting in GMAC4+
authorTan, Tee Min <tee.min.tan@intel.com>
Fri, 7 Feb 2020 07:33:20 +0000 (15:33 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 11 Feb 2020 12:37:24 +0000 (04:37 -0800)
[ Upstream commit 9eeeb3c9de4e3aeaa2bec097162f09305dd9f4c3 ]

It should always do a read of current value of GMAC_VLAN_TAG instead of
directly overwriting the register value.

Fixes: c1be0022df0d ("net: stmmac: Add VLAN HASH filtering support in GMAC4+")
Signed-off-by: Tan, Tee Min <tee.min.tan@intel.com>
Signed-off-by: Ong Boon Leong <boon.leong.ong@intel.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/net/ethernet/stmicro/stmmac/dwmac4_core.c

index 40ca00e596dd7c8594c446dd9a53dd412be2200b..6e3d0ab0ecd6d2a8c7da0e137874c4855409e426 100644 (file)
@@ -736,11 +736,14 @@ static void dwmac4_update_vlan_hash(struct mac_device_info *hw, u32 hash,
                                    __le16 perfect_match, bool is_double)
 {
        void __iomem *ioaddr = hw->pcsr;
+       u32 value;
 
        writel(hash, ioaddr + GMAC_VLAN_HASH_TABLE);
 
+       value = readl(ioaddr + GMAC_VLAN_TAG);
+
        if (hash) {
-               u32 value = GMAC_VLAN_VTHM | GMAC_VLAN_ETV;
+               value |= GMAC_VLAN_VTHM | GMAC_VLAN_ETV;
                if (is_double) {
                        value |= GMAC_VLAN_EDVLP;
                        value |= GMAC_VLAN_ESVL;
@@ -759,8 +762,6 @@ static void dwmac4_update_vlan_hash(struct mac_device_info *hw, u32 hash,
 
                writel(value | perfect_match, ioaddr + GMAC_VLAN_TAG);
        } else {
-               u32 value = readl(ioaddr + GMAC_VLAN_TAG);
-
                value &= ~(GMAC_VLAN_VTHM | GMAC_VLAN_ETV);
                value &= ~(GMAC_VLAN_EDVLP | GMAC_VLAN_ESVL);
                value &= ~GMAC_VLAN_DOVLTC;