net: hns3: add support for imp-handle ras capability
IMP(Intelligent Management Processor) firmware add a new feature to handle and consolidate RAS information for new devices, NIC driver only needs to query the reported RAS information. NIC driver adds support for this feature. Driver queries device capability to check whether IMP support this feature, If yes, execute the new RAS processing branch. In order to add a method to check whether PF supports imp-handle RAS feature, add dumping this info in debugfs. Signed-off-by: Jiaran Zhang <zhangjiaran@huawei.com> Signed-off-by: Guangbin Huang <huangguangbin2@huawei.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
2e2deee761
commit
e65e9f5c2e
|
@ -91,6 +91,7 @@ enum HNAE3_DEV_CAP_BITS {
|
||||||
HNAE3_DEV_SUPPORT_STASH_B,
|
HNAE3_DEV_SUPPORT_STASH_B,
|
||||||
HNAE3_DEV_SUPPORT_UDP_TUNNEL_CSUM_B,
|
HNAE3_DEV_SUPPORT_UDP_TUNNEL_CSUM_B,
|
||||||
HNAE3_DEV_SUPPORT_PAUSE_B,
|
HNAE3_DEV_SUPPORT_PAUSE_B,
|
||||||
|
HNAE3_DEV_SUPPORT_RAS_IMP_B,
|
||||||
HNAE3_DEV_SUPPORT_RXD_ADV_LAYOUT_B,
|
HNAE3_DEV_SUPPORT_RXD_ADV_LAYOUT_B,
|
||||||
HNAE3_DEV_SUPPORT_PORT_VLAN_BYPASS_B,
|
HNAE3_DEV_SUPPORT_PORT_VLAN_BYPASS_B,
|
||||||
HNAE3_DEV_SUPPORT_VLAN_FLTR_MDF_B,
|
HNAE3_DEV_SUPPORT_VLAN_FLTR_MDF_B,
|
||||||
|
@ -129,6 +130,9 @@ enum HNAE3_DEV_CAP_BITS {
|
||||||
#define hnae3_dev_phy_imp_supported(hdev) \
|
#define hnae3_dev_phy_imp_supported(hdev) \
|
||||||
test_bit(HNAE3_DEV_SUPPORT_PHY_IMP_B, (hdev)->ae_dev->caps)
|
test_bit(HNAE3_DEV_SUPPORT_PHY_IMP_B, (hdev)->ae_dev->caps)
|
||||||
|
|
||||||
|
#define hnae3_dev_ras_imp_supported(hdev) \
|
||||||
|
test_bit(HNAE3_DEV_SUPPORT_RAS_IMP_B, (hdev)->ae_dev->caps)
|
||||||
|
|
||||||
#define hnae3_dev_tqp_txrx_indep_supported(hdev) \
|
#define hnae3_dev_tqp_txrx_indep_supported(hdev) \
|
||||||
test_bit(HNAE3_DEV_SUPPORT_TQP_TXRX_INDEP_B, (hdev)->ae_dev->caps)
|
test_bit(HNAE3_DEV_SUPPORT_TQP_TXRX_INDEP_B, (hdev)->ae_dev->caps)
|
||||||
|
|
||||||
|
|
|
@ -349,6 +349,9 @@ static struct hns3_dbg_cap_info hns3_dbg_cap[] = {
|
||||||
}, {
|
}, {
|
||||||
.name = "support imp-controlled PHY",
|
.name = "support imp-controlled PHY",
|
||||||
.cap_bit = HNAE3_DEV_SUPPORT_PHY_IMP_B,
|
.cap_bit = HNAE3_DEV_SUPPORT_PHY_IMP_B,
|
||||||
|
}, {
|
||||||
|
.name = "support imp-controlled RAS",
|
||||||
|
.cap_bit = HNAE3_DEV_SUPPORT_RAS_IMP_B,
|
||||||
}, {
|
}, {
|
||||||
.name = "support rxd advanced layout",
|
.name = "support rxd advanced layout",
|
||||||
.cap_bit = HNAE3_DEV_SUPPORT_RXD_ADV_LAYOUT_B,
|
.cap_bit = HNAE3_DEV_SUPPORT_RXD_ADV_LAYOUT_B,
|
||||||
|
|
|
@ -387,6 +387,8 @@ static void hclge_parse_capability(struct hclge_dev *hdev,
|
||||||
set_bit(HNAE3_DEV_SUPPORT_PAUSE_B, ae_dev->caps);
|
set_bit(HNAE3_DEV_SUPPORT_PAUSE_B, ae_dev->caps);
|
||||||
if (hnae3_get_bit(caps, HCLGE_CAP_PHY_IMP_B))
|
if (hnae3_get_bit(caps, HCLGE_CAP_PHY_IMP_B))
|
||||||
set_bit(HNAE3_DEV_SUPPORT_PHY_IMP_B, ae_dev->caps);
|
set_bit(HNAE3_DEV_SUPPORT_PHY_IMP_B, ae_dev->caps);
|
||||||
|
if (hnae3_get_bit(caps, HCLGE_CAP_RAS_IMP_B))
|
||||||
|
set_bit(HNAE3_DEV_SUPPORT_RAS_IMP_B, ae_dev->caps);
|
||||||
if (hnae3_get_bit(caps, HCLGE_CAP_RXD_ADV_LAYOUT_B))
|
if (hnae3_get_bit(caps, HCLGE_CAP_RXD_ADV_LAYOUT_B))
|
||||||
set_bit(HNAE3_DEV_SUPPORT_RXD_ADV_LAYOUT_B, ae_dev->caps);
|
set_bit(HNAE3_DEV_SUPPORT_RXD_ADV_LAYOUT_B, ae_dev->caps);
|
||||||
if (hnae3_get_bit(caps, HCLGE_CAP_PORT_VLAN_BYPASS_B)) {
|
if (hnae3_get_bit(caps, HCLGE_CAP_PORT_VLAN_BYPASS_B)) {
|
||||||
|
|
|
@ -392,6 +392,7 @@ enum HCLGE_CAP_BITS {
|
||||||
HCLGE_CAP_HW_PAD_B,
|
HCLGE_CAP_HW_PAD_B,
|
||||||
HCLGE_CAP_STASH_B,
|
HCLGE_CAP_STASH_B,
|
||||||
HCLGE_CAP_UDP_TUNNEL_CSUM_B,
|
HCLGE_CAP_UDP_TUNNEL_CSUM_B,
|
||||||
|
HCLGE_CAP_RAS_IMP_B = 12,
|
||||||
HCLGE_CAP_FEC_B = 13,
|
HCLGE_CAP_FEC_B = 13,
|
||||||
HCLGE_CAP_PAUSE_B = 14,
|
HCLGE_CAP_PAUSE_B = 14,
|
||||||
HCLGE_CAP_RXD_ADV_LAYOUT_B = 15,
|
HCLGE_CAP_RXD_ADV_LAYOUT_B = 15,
|
||||||
|
|
|
@ -4299,7 +4299,7 @@ static void hclge_errhand_service_task(struct hclge_dev *hdev)
|
||||||
if (!test_and_clear_bit(HCLGE_STATE_ERR_SERVICE_SCHED, &hdev->state))
|
if (!test_and_clear_bit(HCLGE_STATE_ERR_SERVICE_SCHED, &hdev->state))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (hdev->ae_dev->dev_version >= HNAE3_DEVICE_VERSION_V3)
|
if (hnae3_dev_ras_imp_supported(hdev))
|
||||||
hclge_handle_err_recovery(hdev);
|
hclge_handle_err_recovery(hdev);
|
||||||
else
|
else
|
||||||
hclge_misc_err_recovery(hdev);
|
hclge_misc_err_recovery(hdev);
|
||||||
|
|
Loading…
Reference in New Issue