提交 3aa7f186 编写于 作者: J Jian Shen 提交者: Zheng Zengkai

net: hns3: add support for queue bonding mode of flow director

driver inclusion
category:feature
bugzilla: https://gitee.com/openeuler/kernel/issues/I62HX2

----------------------------------------------------------------------

For device version V3, it supports queue bonding, which can
identify the tuple information of TCP stream, and create flow
director rules automatically, in order to keep the tx and rx
packets are in the same queue pair. The driver set FD_ADD
field of TX BD for TCP SYN packet, and set FD_DEL filed for
TCP FIN or RST packet. The hardware create or remove a fd rule
according to the TX BD, and it also support to age-out a rule
if not hit for a long time.

The queue bonding mode is default to be disabled, and can be
enabled/disabled with ethtool priv-flags command.
Signed-off-by: NJian Shen <shenjian15@huawei.com>
Signed-off-by: NJiantao Xiao <xiaojiantao1@h-partners.com>
Reviewed-by: NYue Haibing <yuehaibing@huawei.com>
Reviewed-by: NJian Shen <shenjian15@huawei.com>
Signed-off-by: NZheng Zengkai <zhengzengkai@huawei.com>
上级 f96c7722
...@@ -553,6 +553,10 @@ struct hnae3_ae_dev { ...@@ -553,6 +553,10 @@ struct hnae3_ae_dev {
* Check if any cls flower rule exist * Check if any cls flower rule exist
* dbg_read_cmd * dbg_read_cmd
* Execute debugfs read command. * Execute debugfs read command.
* request_flush_qb_config
* Request to update queue bonding configuration
* query_fd_qb_state
* Query whether hw queue bonding enabled
* set_tx_hwts_info * set_tx_hwts_info
* Save information for 1588 tx packet * Save information for 1588 tx packet
* get_rx_hwts * get_rx_hwts
...@@ -746,6 +750,8 @@ struct hnae3_ae_ops { ...@@ -746,6 +750,8 @@ struct hnae3_ae_ops {
struct ethtool_link_ksettings *cmd); struct ethtool_link_ksettings *cmd);
int (*set_phy_link_ksettings)(struct hnae3_handle *handle, int (*set_phy_link_ksettings)(struct hnae3_handle *handle,
const struct ethtool_link_ksettings *cmd); const struct ethtool_link_ksettings *cmd);
void (*request_flush_qb_config)(struct hnae3_handle *handle);
bool (*query_fd_qb_state)(struct hnae3_handle *handle);
bool (*set_tx_hwts_info)(struct hnae3_handle *handle, bool (*set_tx_hwts_info)(struct hnae3_handle *handle,
struct sk_buff *skb); struct sk_buff *skb);
void (*get_rx_hwts)(struct hnae3_handle *handle, struct sk_buff *skb, void (*get_rx_hwts)(struct hnae3_handle *handle, struct sk_buff *skb,
...@@ -862,6 +868,7 @@ struct hnae3_roh_private_info { ...@@ -862,6 +868,7 @@ struct hnae3_roh_private_info {
enum hnae3_pflag { enum hnae3_pflag {
HNAE3_PFLAG_LIMIT_PROMISC, HNAE3_PFLAG_LIMIT_PROMISC,
HNAE3_PFLAG_PUSH_ENABLE, HNAE3_PFLAG_PUSH_ENABLE,
HNAE3_PFLAG_FD_QB_ENABLE,
HNAE3_PFLAG_MAX HNAE3_PFLAG_MAX
}; };
......
...@@ -927,7 +927,7 @@ static const struct hns3_dbg_item tx_bd_info_items[] = { ...@@ -927,7 +927,7 @@ static const struct hns3_dbg_item tx_bd_info_items[] = {
{ "OT_VLAN_TAG", 3 }, { "OT_VLAN_TAG", 3 },
{ "TV", 5 }, { "TV", 5 },
{ "OLT_VLAN_LEN", 2 }, { "OLT_VLAN_LEN", 2 },
{ "PAYLEN_OL4CS", 2 }, { "PAYLEN_FDOP_OL4CS", 2 },
{ "BD_FE_SC_VLD", 2 }, { "BD_FE_SC_VLD", 2 },
{ "MSS_HW_CSUM", 0 }, { "MSS_HW_CSUM", 0 },
}; };
...@@ -947,7 +947,7 @@ static void hns3_dump_tx_bd_info(struct hns3_nic_priv *priv, ...@@ -947,7 +947,7 @@ static void hns3_dump_tx_bd_info(struct hns3_nic_priv *priv,
sprintf(result[j++], "%u", le16_to_cpu(desc->tx.tv)); sprintf(result[j++], "%u", le16_to_cpu(desc->tx.tv));
sprintf(result[j++], "%u", sprintf(result[j++], "%u",
le32_to_cpu(desc->tx.ol_type_vlan_len_msec)); le32_to_cpu(desc->tx.ol_type_vlan_len_msec));
sprintf(result[j++], "%#x", le32_to_cpu(desc->tx.paylen_ol4cs)); sprintf(result[j++], "%#x", le32_to_cpu(desc->tx.paylen_fdop_ol4cs));
sprintf(result[j++], "%#x", le16_to_cpu(desc->tx.bdtp_fe_sc_vld_ra_ri)); sprintf(result[j++], "%#x", le16_to_cpu(desc->tx.bdtp_fe_sc_vld_ra_ri));
sprintf(result[j++], "%u", le16_to_cpu(desc->tx.mss_hw_csum)); sprintf(result[j++], "%u", le16_to_cpu(desc->tx.mss_hw_csum));
} }
......
...@@ -1543,6 +1543,73 @@ static int hns3_handle_vtags(struct hns3_enet_ring *tx_ring, ...@@ -1543,6 +1543,73 @@ static int hns3_handle_vtags(struct hns3_enet_ring *tx_ring,
return 0; return 0;
} }
static bool hns3_query_fd_qb_state(struct hnae3_handle *handle)
{
const struct hnae3_ae_ops *ops = handle->ae_algo->ops;
if (!test_bit(HNAE3_PFLAG_FD_QB_ENABLE, &handle->priv_flags))
return false;
if (!ops->query_fd_qb_state)
return false;
return ops->query_fd_qb_state(handle);
}
/* fd_op is the field of tx bd indicates hw whether to add or delete
* a qb rule or do nothing.
*/
static u8 hns3_fd_qb_handle(struct hns3_enet_ring *ring, struct sk_buff *skb)
{
struct hnae3_handle *handle = ring->tqp->handle;
union l4_hdr_info l4;
union l3_hdr_info l3;
u8 l4_proto_tmp = 0;
__be16 frag_off;
u8 ip_version;
u8 fd_op = 0;
if (!hns3_query_fd_qb_state(handle))
return 0;
if (skb->encapsulation) {
ip_version = inner_ip_hdr(skb)->version;
l3.hdr = skb_inner_network_header(skb);
l4.hdr = skb_inner_transport_header(skb);
} else {
ip_version = ip_hdr(skb)->version;
l3.hdr = skb_network_header(skb);
l4.hdr = skb_transport_header(skb);
}
if (ip_version == IP_VERSION_IPV6) {
unsigned char *exthdr;
exthdr = l3.hdr + sizeof(*l3.v6);
l4_proto_tmp = l3.v6->nexthdr;
if (l4.hdr != exthdr)
ipv6_skip_exthdr(skb, exthdr - skb->data,
&l4_proto_tmp, &frag_off);
} else if (ip_version == IP_VERSION_IPV4) {
l4_proto_tmp = l3.v4->protocol;
}
if (l4_proto_tmp != IPPROTO_TCP)
return 0;
ring->fd_qb_tx_sample++;
if (l4.tcp->fin || l4.tcp->rst) {
hnae3_set_bit(fd_op, HNS3_TXD_FD_DEL_B, 1);
ring->fd_qb_tx_sample = 0;
} else if (l4.tcp->syn ||
ring->fd_qb_tx_sample >= HNS3_FD_QB_FORCE_CNT_MAX) {
hnae3_set_bit(fd_op, HNS3_TXD_FD_ADD_B, 1);
ring->fd_qb_tx_sample = 0;
}
return fd_op;
}
/* check if the hardware is capable of checksum offloading */ /* check if the hardware is capable of checksum offloading */
static bool hns3_check_hw_tx_csum(struct sk_buff *skb) static bool hns3_check_hw_tx_csum(struct sk_buff *skb)
{ {
...@@ -1560,7 +1627,7 @@ static bool hns3_check_hw_tx_csum(struct sk_buff *skb) ...@@ -1560,7 +1627,7 @@ static bool hns3_check_hw_tx_csum(struct sk_buff *skb)
} }
struct hns3_desc_param { struct hns3_desc_param {
u32 paylen_ol4cs; u32 paylen_fdop_ol4cs;
u32 ol_type_vlan_len_msec; u32 ol_type_vlan_len_msec;
u32 type_cs_vlan_tso; u32 type_cs_vlan_tso;
u16 mss_hw_csum; u16 mss_hw_csum;
...@@ -1570,7 +1637,7 @@ struct hns3_desc_param { ...@@ -1570,7 +1637,7 @@ struct hns3_desc_param {
static void hns3_init_desc_data(struct sk_buff *skb, struct hns3_desc_param *pa) static void hns3_init_desc_data(struct sk_buff *skb, struct hns3_desc_param *pa)
{ {
pa->paylen_ol4cs = skb->len; pa->paylen_fdop_ol4cs = skb->len;
pa->ol_type_vlan_len_msec = 0; pa->ol_type_vlan_len_msec = 0;
pa->type_cs_vlan_tso = 0; pa->type_cs_vlan_tso = 0;
pa->mss_hw_csum = 0; pa->mss_hw_csum = 0;
...@@ -1638,7 +1705,7 @@ static int hns3_handle_csum_partial(struct hns3_enet_ring *ring, ...@@ -1638,7 +1705,7 @@ static int hns3_handle_csum_partial(struct hns3_enet_ring *ring,
return ret; return ret;
} }
ret = hns3_set_tso(skb, &param->paylen_ol4cs, &param->mss_hw_csum, ret = hns3_set_tso(skb, &param->paylen_fdop_ol4cs, &param->mss_hw_csum,
&param->type_cs_vlan_tso, &desc_cb->send_bytes); &param->type_cs_vlan_tso, &desc_cb->send_bytes);
if (unlikely(ret < 0)) { if (unlikely(ret < 0)) {
hns3_ring_stats_update(ring, tx_tso_err); hns3_ring_stats_update(ring, tx_tso_err);
...@@ -1652,6 +1719,7 @@ static int hns3_fill_skb_desc(struct hns3_enet_ring *ring, ...@@ -1652,6 +1719,7 @@ static int hns3_fill_skb_desc(struct hns3_enet_ring *ring,
struct hns3_desc_cb *desc_cb) struct hns3_desc_cb *desc_cb)
{ {
struct hns3_desc_param param; struct hns3_desc_param param;
u8 fd_op;
int ret; int ret;
hns3_init_desc_data(skb, &param); hns3_init_desc_data(skb, &param);
...@@ -1667,11 +1735,15 @@ static int hns3_fill_skb_desc(struct hns3_enet_ring *ring, ...@@ -1667,11 +1735,15 @@ static int hns3_fill_skb_desc(struct hns3_enet_ring *ring,
return ret; return ret;
} }
fd_op = hns3_fd_qb_handle(ring, skb);
hnae3_set_field(param.paylen_fdop_ol4cs, HNS3_TXD_FD_OP_M,
HNS3_TXD_FD_OP_S, fd_op);
/* Set txbd */ /* Set txbd */
desc->tx.ol_type_vlan_len_msec = desc->tx.ol_type_vlan_len_msec =
cpu_to_le32(param.ol_type_vlan_len_msec); cpu_to_le32(param.ol_type_vlan_len_msec);
desc->tx.type_cs_vlan_tso_len = cpu_to_le32(param.type_cs_vlan_tso); desc->tx.type_cs_vlan_tso_len = cpu_to_le32(param.type_cs_vlan_tso);
desc->tx.paylen_ol4cs = cpu_to_le32(param.paylen_ol4cs); desc->tx.paylen_fdop_ol4cs = cpu_to_le32(param.paylen_fdop_ol4cs);
desc->tx.mss_hw_csum = cpu_to_le16(param.mss_hw_csum); desc->tx.mss_hw_csum = cpu_to_le16(param.mss_hw_csum);
desc->tx.vlan_tag = cpu_to_le16(param.inner_vtag); desc->tx.vlan_tag = cpu_to_le16(param.inner_vtag);
desc->tx.outer_vlan_tag = cpu_to_le16(param.out_vtag); desc->tx.outer_vlan_tag = cpu_to_le16(param.out_vtag);
...@@ -5365,6 +5437,9 @@ static int hns3_client_init(struct hnae3_handle *handle) ...@@ -5365,6 +5437,9 @@ static int hns3_client_init(struct hnae3_handle *handle)
hns3_state_init(handle); hns3_state_init(handle);
if (test_bit(HNAE3_DEV_SUPPORT_QB_B, ae_dev->caps))
set_bit(HNAE3_PFLAG_FD_QB_ENABLE, &handle->supported_pflags);
ret = register_netdev(netdev); ret = register_netdev(netdev);
if (ret) { if (ret) {
dev_err(priv->dev, "probe register netdev fail!\n"); dev_err(priv->dev, "probe register netdev fail!\n");
......
...@@ -179,6 +179,11 @@ enum hns3_nic_state { ...@@ -179,6 +179,11 @@ enum hns3_nic_state {
#define HNS3_TXD_DECTTL_S 12 #define HNS3_TXD_DECTTL_S 12
#define HNS3_TXD_DECTTL_M (0xf << HNS3_TXD_DECTTL_S) #define HNS3_TXD_DECTTL_M (0xf << HNS3_TXD_DECTTL_S)
#define HNS3_TXD_FD_ADD_B 1
#define HNS3_TXD_FD_DEL_B 0
#define HNS3_TXD_FD_OP_M GENMASK(21, 20)
#define HNS3_TXD_FD_OP_S 20
#define HNS3_TXD_OL4CS_B 22 #define HNS3_TXD_OL4CS_B 22
#define HNS3_TXD_MSS_S 0 #define HNS3_TXD_MSS_S 0
...@@ -214,6 +219,8 @@ enum hns3_nic_state { ...@@ -214,6 +219,8 @@ enum hns3_nic_state {
#define HNS3_CQ_MODE_EQE 1U #define HNS3_CQ_MODE_EQE 1U
#define HNS3_CQ_MODE_CQE 0U #define HNS3_CQ_MODE_CQE 0U
#define HNS3_FD_QB_FORCE_CNT_MAX 20
enum hns3_pkt_l2t_type { enum hns3_pkt_l2t_type {
HNS3_L2_TYPE_UNICAST, HNS3_L2_TYPE_UNICAST,
HNS3_L2_TYPE_MULTICAST, HNS3_L2_TYPE_MULTICAST,
...@@ -285,7 +292,7 @@ struct __packed hns3_desc { ...@@ -285,7 +292,7 @@ struct __packed hns3_desc {
}; };
}; };
__le32 paylen_ol4cs; __le32 paylen_fdop_ol4cs;
__le16 bdtp_fe_sc_vld_ra_ri; __le16 bdtp_fe_sc_vld_ra_ri;
__le16 mss_hw_csum; __le16 mss_hw_csum;
} tx; } tx;
...@@ -398,6 +405,9 @@ enum hns3_pkt_ol4type { ...@@ -398,6 +405,9 @@ enum hns3_pkt_ol4type {
HNS3_OL4_TYPE_UNKNOWN HNS3_OL4_TYPE_UNKNOWN
}; };
#define IP_VERSION_IPV4 0x4
#define IP_VERSION_IPV6 0x6
struct hns3_rx_ptype { struct hns3_rx_ptype {
u32 ptype : 8; u32 ptype : 8;
u32 csum_level : 2; u32 csum_level : 2;
......
...@@ -467,6 +467,16 @@ static void hns3_update_limit_promisc_mode(struct net_device *netdev, ...@@ -467,6 +467,16 @@ static void hns3_update_limit_promisc_mode(struct net_device *netdev,
hns3_request_update_promisc_mode(handle); hns3_request_update_promisc_mode(handle);
} }
static void hns3_update_fd_qb_state(struct net_device *netdev, bool enable)
{
struct hnae3_handle *handle = hns3_get_handle(netdev);
if (!handle->ae_algo->ops->request_flush_qb_config)
return;
handle->ae_algo->ops->request_flush_qb_config(handle);
}
static void hns3_update_state(struct net_device *netdev, static void hns3_update_state(struct net_device *netdev,
enum hns3_nic_state state, bool enable) enum hns3_nic_state state, bool enable)
{ {
...@@ -485,7 +495,8 @@ static void hns3_update_push_state(struct net_device *netdev, bool enable) ...@@ -485,7 +495,8 @@ static void hns3_update_push_state(struct net_device *netdev, bool enable)
static const struct hns3_pflag_desc hns3_priv_flags[HNAE3_PFLAG_MAX] = { static const struct hns3_pflag_desc hns3_priv_flags[HNAE3_PFLAG_MAX] = {
{ "limit_promisc", hns3_update_limit_promisc_mode }, { "limit_promisc", hns3_update_limit_promisc_mode },
{ "tx_push_enable", hns3_update_push_state } { "tx_push_enable", hns3_update_push_state },
{ "qb_enable", hns3_update_fd_qb_state },
}; };
static int hns3_get_sset_count(struct net_device *netdev, int stringset) static int hns3_get_sset_count(struct net_device *netdev, int stringset)
......
...@@ -749,6 +749,12 @@ struct hclge_fd_ad_cnt_read_cmd { ...@@ -749,6 +749,12 @@ struct hclge_fd_ad_cnt_read_cmd {
u8 rsv2[8]; u8 rsv2[8];
}; };
struct hclge_fd_qb_cfg_cmd {
u8 en;
u8 vf_id;
u8 rsv[22];
};
#define HCLGE_FD_USER_DEF_OFT_S 0 #define HCLGE_FD_USER_DEF_OFT_S 0
#define HCLGE_FD_USER_DEF_OFT_M GENMASK(14, 0) #define HCLGE_FD_USER_DEF_OFT_M GENMASK(14, 0)
#define HCLGE_FD_USER_DEF_EN_B 15 #define HCLGE_FD_USER_DEF_EN_B 15
......
...@@ -4561,6 +4561,95 @@ static void hclge_update_vport_alive(struct hclge_dev *hdev) ...@@ -4561,6 +4561,95 @@ static void hclge_update_vport_alive(struct hclge_dev *hdev)
} }
} }
static int hclge_set_fd_qb(struct hclge_dev *hdev, u8 vf_id, bool enable)
{
struct hclge_fd_qb_cfg_cmd *req;
struct hclge_desc desc;
int ret;
hclge_cmd_setup_basic_desc(&desc, HCLGE_OPC_FD_QB_CTRL, false);
req = (struct hclge_fd_qb_cfg_cmd *)desc.data;
req->en = enable;
req->vf_id = vf_id;
ret = hclge_cmd_send(&hdev->hw, &desc, 1);
if (ret)
dev_err(&hdev->pdev->dev,
"failed to %s qb config for vport %u, ret = %d.\n",
enable ? "enable" : "disable", vf_id, ret);
return ret;
}
static int hclge_sync_pf_qb_mode(struct hclge_dev *hdev)
{
struct hclge_vport *vport = &hdev->vport[0];
struct hnae3_handle *handle = &vport->nic;
bool request_enable = true;
int ret;
if (!test_and_clear_bit(HCLGE_VPORT_STATE_QB_CHANGE, &vport->state))
return 0;
spin_lock_bh(&hdev->fd_rule_lock);
if (hdev->fd_active_type == HCLGE_FD_EP_ACTIVE ||
hdev->fd_active_type == HCLGE_FD_TC_FLOWER_ACTIVE ||
!test_bit(HNAE3_PFLAG_FD_QB_ENABLE, &handle->priv_flags))
request_enable = false;
if (request_enable ==
test_bit(HCLGE_STATE_HW_QB_ENABLE, &hdev->state)) {
spin_unlock_bh(&hdev->fd_rule_lock);
return 0;
}
if (request_enable)
hclge_clear_arfs_rules(hdev);
ret = hclge_set_fd_qb(hdev, vport->vport_id, request_enable);
if (!ret) {
if (request_enable) {
set_bit(HCLGE_STATE_HW_QB_ENABLE, &hdev->state);
hdev->fd_active_type = HCLGE_FD_QB_ACTIVE;
} else {
clear_bit(HCLGE_STATE_HW_QB_ENABLE, &hdev->state);
hdev->fd_active_type = HCLGE_FD_RULE_NONE;
}
} else {
set_bit(HCLGE_VPORT_STATE_QB_CHANGE, &vport->state);
}
spin_unlock_bh(&hdev->fd_rule_lock);
return ret;
}
static int hclge_disable_fd_qb_mode(struct hclge_dev *hdev)
{
struct hnae3_ae_dev *ae_dev = hdev->ae_dev;
int ret;
if (!test_bit(HNAE3_DEV_SUPPORT_QB_B, ae_dev->caps) ||
!test_bit(HCLGE_STATE_HW_QB_ENABLE, &hdev->state))
return 0;
ret = hclge_set_fd_qb(hdev, 0, false);
if (ret)
return ret;
clear_bit(HCLGE_STATE_HW_QB_ENABLE, &hdev->state);
return 0;
}
static void hclge_sync_fd_qb_mode(struct hclge_dev *hdev)
{
struct hnae3_ae_dev *ae_dev = hdev->ae_dev;
if (!test_bit(HNAE3_DEV_SUPPORT_QB_B, ae_dev->caps))
return;
hclge_sync_pf_qb_mode(hdev);
}
static void hclge_periodic_service_task(struct hclge_dev *hdev) static void hclge_periodic_service_task(struct hclge_dev *hdev)
{ {
unsigned long delta = round_jiffies_relative(HZ); unsigned long delta = round_jiffies_relative(HZ);
...@@ -4574,6 +4663,7 @@ static void hclge_periodic_service_task(struct hclge_dev *hdev) ...@@ -4574,6 +4663,7 @@ static void hclge_periodic_service_task(struct hclge_dev *hdev)
hclge_update_link_status(hdev); hclge_update_link_status(hdev);
hclge_sync_mac_table(hdev); hclge_sync_mac_table(hdev);
hclge_sync_promisc_mode(hdev); hclge_sync_promisc_mode(hdev);
hclge_sync_fd_qb_mode(hdev);
hclge_sync_fd_table(hdev); hclge_sync_fd_table(hdev);
if (time_is_after_jiffies(hdev->last_serv_processed + HZ)) { if (time_is_after_jiffies(hdev->last_serv_processed + HZ)) {
...@@ -5097,10 +5187,29 @@ static void hclge_request_update_promisc_mode(struct hnae3_handle *handle) ...@@ -5097,10 +5187,29 @@ static void hclge_request_update_promisc_mode(struct hnae3_handle *handle)
set_bit(HCLGE_VPORT_STATE_PROMISC_CHANGE, &vport->state); set_bit(HCLGE_VPORT_STATE_PROMISC_CHANGE, &vport->state);
} }
static bool hclge_query_fd_qb_state(struct hnae3_handle *handle)
{
struct hclge_vport *vport = hclge_get_vport(handle);
struct hclge_dev *hdev = vport->back;
return test_bit(HCLGE_STATE_HW_QB_ENABLE, &hdev->state);
}
static void hclge_flush_qb_config(struct hnae3_handle *handle)
{
struct hclge_vport *vport = hclge_get_vport(handle);
set_bit(HCLGE_VPORT_STATE_QB_CHANGE, &vport->state);
}
static void hclge_sync_fd_state(struct hclge_dev *hdev) static void hclge_sync_fd_state(struct hclge_dev *hdev)
{ {
if (hlist_empty(&hdev->fd_rule_list)) struct hclge_vport *vport = &hdev->vport[0];
if (hlist_empty(&hdev->fd_rule_list)) {
hdev->fd_active_type = HCLGE_FD_RULE_NONE; hdev->fd_active_type = HCLGE_FD_RULE_NONE;
set_bit(HCLGE_VPORT_STATE_QB_CHANGE, &vport->state);
}
} }
static void hclge_fd_inc_rule_cnt(struct hclge_dev *hdev, u16 location) static void hclge_fd_inc_rule_cnt(struct hclge_dev *hdev, u16 location)
...@@ -6546,6 +6655,10 @@ static int hclge_add_fd_entry_common(struct hclge_dev *hdev, ...@@ -6546,6 +6655,10 @@ static int hclge_add_fd_entry_common(struct hclge_dev *hdev,
{ {
int ret; int ret;
ret = hclge_disable_fd_qb_mode(hdev);
if (ret)
return ret;
spin_lock_bh(&hdev->fd_rule_lock); spin_lock_bh(&hdev->fd_rule_lock);
if (hdev->fd_active_type != rule->rule_type && if (hdev->fd_active_type != rule->rule_type &&
...@@ -8269,6 +8382,7 @@ int hclge_vport_start(struct hclge_vport *vport) ...@@ -8269,6 +8382,7 @@ int hclge_vport_start(struct hclge_vport *vport)
set_bit(HCLGE_VPORT_STATE_INITED, &vport->state); set_bit(HCLGE_VPORT_STATE_INITED, &vport->state);
set_bit(HCLGE_VPORT_STATE_ALIVE, &vport->state); set_bit(HCLGE_VPORT_STATE_ALIVE, &vport->state);
set_bit(HCLGE_VPORT_STATE_QB_CHANGE, &vport->state);
set_bit(HCLGE_VPORT_STATE_PROMISC_CHANGE, &vport->state); set_bit(HCLGE_VPORT_STATE_PROMISC_CHANGE, &vport->state);
vport->last_active_jiffies = jiffies; vport->last_active_jiffies = jiffies;
vport->need_notify = 0; vport->need_notify = 0;
...@@ -10486,6 +10600,7 @@ static void hclge_restore_hw_table(struct hclge_dev *hdev) ...@@ -10486,6 +10600,7 @@ static void hclge_restore_hw_table(struct hclge_dev *hdev)
hclge_restore_vport_port_base_vlan_config(hdev); hclge_restore_vport_port_base_vlan_config(hdev);
hclge_restore_vport_vlan_table(vport); hclge_restore_vport_vlan_table(vport);
set_bit(HCLGE_STATE_FD_USER_DEF_CHANGED, &hdev->state); set_bit(HCLGE_STATE_FD_USER_DEF_CHANGED, &hdev->state);
clear_bit(HCLGE_STATE_HW_QB_ENABLE, &hdev->state);
hclge_restore_fd_entries(handle); hclge_restore_fd_entries(handle);
} }
...@@ -13333,6 +13448,8 @@ static const struct hnae3_ae_ops hclge_ops = { ...@@ -13333,6 +13448,8 @@ static const struct hnae3_ae_ops hclge_ops = {
.put_vector = hclge_put_vector, .put_vector = hclge_put_vector,
.set_promisc_mode = hclge_set_promisc_mode, .set_promisc_mode = hclge_set_promisc_mode,
.request_update_promisc_mode = hclge_request_update_promisc_mode, .request_update_promisc_mode = hclge_request_update_promisc_mode,
.request_flush_qb_config = hclge_flush_qb_config,
.query_fd_qb_state = hclge_query_fd_qb_state,
.set_loopback = hclge_set_loopback, .set_loopback = hclge_set_loopback,
.start = hclge_ae_start, .start = hclge_ae_start,
.stop = hclge_ae_stop, .stop = hclge_ae_stop,
......
...@@ -215,6 +215,7 @@ enum HCLGE_DEV_STATE { ...@@ -215,6 +215,7 @@ enum HCLGE_DEV_STATE {
HCLGE_STATE_FD_TBL_CHANGED, HCLGE_STATE_FD_TBL_CHANGED,
HCLGE_STATE_FD_CLEAR_ALL, HCLGE_STATE_FD_CLEAR_ALL,
HCLGE_STATE_FD_USER_DEF_CHANGED, HCLGE_STATE_FD_USER_DEF_CHANGED,
HCLGE_STATE_HW_QB_ENABLE,
HCLGE_STATE_PTP_EN, HCLGE_STATE_PTP_EN,
HCLGE_STATE_PTP_TX_HANDLING, HCLGE_STATE_PTP_TX_HANDLING,
HCLGE_STATE_MAX HCLGE_STATE_MAX
...@@ -611,6 +612,7 @@ enum HCLGE_FD_ACTIVE_RULE_TYPE { ...@@ -611,6 +612,7 @@ enum HCLGE_FD_ACTIVE_RULE_TYPE {
HCLGE_FD_ARFS_ACTIVE, HCLGE_FD_ARFS_ACTIVE,
HCLGE_FD_EP_ACTIVE, HCLGE_FD_EP_ACTIVE,
HCLGE_FD_TC_FLOWER_ACTIVE, HCLGE_FD_TC_FLOWER_ACTIVE,
HCLGE_FD_QB_ACTIVE,
}; };
enum HCLGE_FD_PACKET_TYPE { enum HCLGE_FD_PACKET_TYPE {
...@@ -975,6 +977,7 @@ struct hclge_rx_vtag_cfg { ...@@ -975,6 +977,7 @@ struct hclge_rx_vtag_cfg {
enum HCLGE_VPORT_STATE { enum HCLGE_VPORT_STATE {
HCLGE_VPORT_STATE_ALIVE, HCLGE_VPORT_STATE_ALIVE,
HCLGE_VPORT_STATE_MAC_TBL_CHANGE, HCLGE_VPORT_STATE_MAC_TBL_CHANGE,
HCLGE_VPORT_STATE_QB_CHANGE,
HCLGE_VPORT_STATE_PROMISC_CHANGE, HCLGE_VPORT_STATE_PROMISC_CHANGE,
HCLGE_VPORT_STATE_VLAN_FLTR_CHANGE, HCLGE_VPORT_STATE_VLAN_FLTR_CHANGE,
HCLGE_VPORT_STATE_INITED, HCLGE_VPORT_STATE_INITED,
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册