From: Jian Shen <shenjia...@huawei.com>

Previously, when set VF VLAN with command "ip link set <pf name>
vf <vf id> vlan <vlan id>", the vf id 0 is handled as PF incorrectly,
which should be the first VF. This patch fixes it.

This patch also adds VF VLAN information for command "ip link show".

Fixes: 21e043cd8124 ("net: hns3: fix set port based VLAN for PF")
Signed-off-by: Jian Shen <shenjia...@huawei.com>
Signed-off-by: Huazhong Tan <tanhuazh...@huawei.com>
---
 .../net/ethernet/hisilicon/hns3/hns3pf/hclge_main.c | 21 +++++++++------------
 1 file changed, 9 insertions(+), 12 deletions(-)

diff --git a/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_main.c 
b/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_main.c
index 72c19b3..60aba81 100644
--- a/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_main.c
+++ b/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_main.c
@@ -2940,6 +2940,9 @@ static int hclge_get_vf_config(struct hnae3_handle 
*handle, int vf,
        ivf->trusted = vport->vf_info.trusted;
        ivf->min_tx_rate = 0;
        ivf->max_tx_rate = vport->vf_info.max_tx_rate;
+       ivf->vlan = vport->port_base_vlan_cfg.vlan_info.vlan_tag;
+       ivf->vlan_proto = htons(vport->port_base_vlan_cfg.vlan_info.vlan_proto);
+       ivf->qos = vport->port_base_vlan_cfg.vlan_info.qos;
        ether_addr_copy(ivf->mac, vport->vf_info.mac);
 
        return 0;
@@ -8407,13 +8410,16 @@ static int hclge_set_vf_vlan_filter(struct hnae3_handle 
*handle, int vfid,
        if (hdev->pdev->revision == 0x20)
                return -EOPNOTSUPP;
 
+       vport = hclge_get_vf_vport(hdev, vfid);
+       if (!vport)
+               return -EINVAL;
+
        /* qos is a 3 bits value, so can not be bigger than 7 */
-       if (vfid >= hdev->num_alloc_vfs || vlan > VLAN_N_VID - 1 || qos > 7)
+       if (vlan > VLAN_N_VID - 1 || qos > 7)
                return -EINVAL;
        if (proto != htons(ETH_P_8021Q))
                return -EPROTONOSUPPORT;
 
-       vport = &hdev->vport[vfid];
        state = hclge_get_port_base_vlan_state(vport,
                                               vport->port_base_vlan_cfg.state,
                                               vlan);
@@ -8424,21 +8430,12 @@ static int hclge_set_vf_vlan_filter(struct hnae3_handle 
*handle, int vfid,
        vlan_info.qos = qos;
        vlan_info.vlan_proto = ntohs(proto);
 
-       /* update port based VLAN for PF */
-       if (!vfid) {
-               hclge_notify_client(hdev, HNAE3_DOWN_CLIENT);
-               ret = hclge_update_port_base_vlan_cfg(vport, state, &vlan_info);
-               hclge_notify_client(hdev, HNAE3_UP_CLIENT);
-
-               return ret;
-       }
-
        if (!test_bit(HCLGE_VPORT_STATE_ALIVE, &vport->state)) {
                return hclge_update_port_base_vlan_cfg(vport, state,
                                                       &vlan_info);
        } else {
                ret = hclge_push_vf_port_base_vlan_info(&hdev->vport[0],
-                                                       (u8)vfid, state,
+                                                       vport->vport_id, state,
                                                        vlan, qos,
                                                        ntohs(proto));
                return ret;
-- 
2.7.4

Reply via email to