]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
net: hns3: fix bug when PF set the duplicate MAC address for VFs
authorJian Shen <shenjian15@huawei.com>
Thu, 24 Mar 2022 12:54:47 +0000 (20:54 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 8 Apr 2022 12:06:29 +0000 (14:06 +0200)
[ Upstream commit ccb18f05535c96d26e2d559d402acb87700fc5a7 ]

If the MAC address A is configured to vport A and then vport B. The MAC
address of vport A in the hardware becomes invalid. If the address of
vport A is changed to MAC address B, the driver needs to delete the MAC
address A of vport A. Due to the MAC address A of vport A has become
invalid in the hardware entry, so "-ENOENT" is returned. In this case, the
"used_umv_size" value recorded in driver is not updated. As a result, the
MAC entry status of the software is inconsistent with that of the hardware.

Therefore, the driver updates the umv size even if the MAC entry cannot be
found. Ensure that the software and hardware status is consistent.

Fixes: ee4bcd3b7ae4 ("net: hns3: refactor the MAC address configure")
Signed-off-by: Jian Shen <shenjian15@huawei.com>
Signed-off-by: Guangbin Huang <huangguangbin2@huawei.com>
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_main.c

index c2a58101144e3b4bbcd1237d77a4a58bedf3547a..0fc8810671dcf3c03c516942754bf64c48c1cf55 100644 (file)
@@ -8888,12 +8888,11 @@ int hclge_rm_uc_addr_common(struct hclge_vport *vport,
        hnae3_set_bit(req.entry_type, HCLGE_MAC_VLAN_BIT0_EN_B, 0);
        hclge_prepare_mac_addr(&req, addr, false);
        ret = hclge_remove_mac_vlan_tbl(vport, &req);
-       if (!ret) {
+       if (!ret || ret == -ENOENT) {
                mutex_lock(&hdev->vport_lock);
                hclge_update_umv_space(vport, true);
                mutex_unlock(&hdev->vport_lock);
-       } else if (ret == -ENOENT) {
-               ret = 0;
+               return 0;
        }
 
        return ret;