From patchwork Mon Jul 22 06:58:25 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Jie Hai X-Patchwork-Id: 142573 X-Patchwork-Delegate: ferruh.yigit@amd.com Return-Path: X-Original-To: patchwork@inbox.dpdk.org Delivered-To: patchwork@inbox.dpdk.org Received: from mails.dpdk.org (mails.dpdk.org [217.70.189.124]) by inbox.dpdk.org (Postfix) with ESMTP id B53154567C; Mon, 22 Jul 2024 09:06:21 +0200 (CEST) Received: from mails.dpdk.org (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id C24F842F77; Mon, 22 Jul 2024 09:05:31 +0200 (CEST) Received: from szxga02-in.huawei.com (szxga02-in.huawei.com [45.249.212.188]) by mails.dpdk.org (Postfix) with ESMTP id 12B64427D6 for ; Mon, 22 Jul 2024 08:59:01 +0200 (CEST) Received: from mail.maildlp.com (unknown [172.19.88.105]) by szxga02-in.huawei.com (SkyGuard) with ESMTP id 4WSB1w0sZQznbbB; Mon, 22 Jul 2024 14:58:12 +0800 (CST) Received: from kwepemf500004.china.huawei.com (unknown [7.202.181.242]) by mail.maildlp.com (Postfix) with ESMTPS id 96D08140382; Mon, 22 Jul 2024 14:58:57 +0800 (CST) Received: from localhost.huawei.com (10.90.30.45) by kwepemf500004.china.huawei.com (7.202.181.242) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.1544.11; Mon, 22 Jul 2024 14:58:57 +0800 From: Jie Hai To: , Yisen Zhuang CC: , , , Subject: [PATCH v6 7/8] net/hns3: support report names of registers Date: Mon, 22 Jul 2024 14:58:25 +0800 Message-ID: <20240722065826.3039119-8-haijie1@huawei.com> X-Mailer: git-send-email 2.33.0 In-Reply-To: <20240722065826.3039119-1-haijie1@huawei.com> References: <20231214015650.3738578-1-haijie1@huawei.com> <20240722065826.3039119-1-haijie1@huawei.com> MIME-Version: 1.0 X-Originating-IP: [10.90.30.45] X-ClientProxiedBy: dggems704-chm.china.huawei.com (10.3.19.181) To kwepemf500004.china.huawei.com (7.202.181.242) X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org This patch adds names for register lists, and support report names of registers. Some registers has different names on different platform, use names of HIP08 as default names. Signed-off-by: Jie Hai --- drivers/net/hns3/hns3_regs.c | 1090 +++++++++++++++++++++++++++++----- 1 file changed, 957 insertions(+), 133 deletions(-) diff --git a/drivers/net/hns3/hns3_regs.c b/drivers/net/hns3/hns3_regs.c index 89858c2b1c09..622d2e1c3d02 100644 --- a/drivers/net/hns3/hns3_regs.c +++ b/drivers/net/hns3/hns3_regs.c @@ -14,73 +14,829 @@ static int hns3_get_dfx_reg_cnt(struct hns3_hw *hw, uint32_t *count); -static const uint32_t cmdq_reg_addrs[] = {HNS3_CMDQ_TX_DEPTH_REG, - HNS3_CMDQ_TX_TAIL_REG, - HNS3_CMDQ_TX_HEAD_REG, - HNS3_CMDQ_RX_DEPTH_REG, - HNS3_CMDQ_RX_TAIL_REG, - HNS3_CMDQ_RX_HEAD_REG, - HNS3_VECTOR0_CMDQ_SRC_REG, - HNS3_CMDQ_INTR_STS_REG, - HNS3_CMDQ_INTR_EN_REG, - HNS3_CMDQ_INTR_GEN_REG}; - -static const uint32_t common_reg_addrs[] = {HNS3_MISC_VECTOR_REG_BASE, - HNS3_VECTOR0_OTER_EN_REG, - HNS3_MISC_RESET_STS_REG, - HNS3_VECTOR0_OTHER_INT_STS_REG, - HNS3_GLOBAL_RESET_REG, - HNS3_FUN_RST_ING, - HNS3_GRO_EN_REG}; - -static const uint32_t common_vf_reg_addrs[] = {HNS3_MISC_VECTOR_REG_BASE, - HNS3_FUN_RST_ING, - HNS3_GRO_EN_REG}; - -static const uint32_t ring_reg_addrs[] = {HNS3_RING_RX_BD_NUM_REG, - HNS3_RING_RX_BD_LEN_REG, - HNS3_RING_RX_EN_REG, - HNS3_RING_RX_MERGE_EN_REG, - HNS3_RING_RX_TAIL_REG, - HNS3_RING_RX_HEAD_REG, - HNS3_RING_RX_FBDNUM_REG, - HNS3_RING_RX_OFFSET_REG, - HNS3_RING_RX_FBD_OFFSET_REG, - HNS3_RING_RX_STASH_REG, - HNS3_RING_RX_BD_ERR_REG, - HNS3_RING_TX_BD_NUM_REG, - HNS3_RING_TX_EN_REG, - HNS3_RING_TX_PRIORITY_REG, - HNS3_RING_TX_TC_REG, - HNS3_RING_TX_MERGE_EN_REG, - HNS3_RING_TX_TAIL_REG, - HNS3_RING_TX_HEAD_REG, - HNS3_RING_TX_FBDNUM_REG, - HNS3_RING_TX_OFFSET_REG, - HNS3_RING_TX_EBD_NUM_REG, - HNS3_RING_TX_EBD_OFFSET_REG, - HNS3_RING_TX_BD_ERR_REG, - HNS3_RING_EN_REG}; - -static const uint32_t tqp_intr_reg_addrs[] = {HNS3_TQP_INTR_CTRL_REG, - HNS3_TQP_INTR_GL0_REG, - HNS3_TQP_INTR_GL1_REG, - HNS3_TQP_INTR_GL2_REG, - HNS3_TQP_INTR_RL_REG}; +struct hns3_dirt_reg_entry { + const char *name; + uint32_t addr; +}; + +static const struct hns3_dirt_reg_entry cmdq_reg_list[] = { + {"cmdq_tx_depth", HNS3_CMDQ_TX_DEPTH_REG}, + {"cmdq_tx_tail", HNS3_CMDQ_TX_TAIL_REG}, + {"cmdq_tx_head", HNS3_CMDQ_TX_HEAD_REG}, + {"cmdq_rx_depth", HNS3_CMDQ_RX_DEPTH_REG}, + {"cmdq_rx_tail", HNS3_CMDQ_RX_TAIL_REG}, + {"cmdq_rx_head", HNS3_CMDQ_RX_HEAD_REG}, + {"vector0_cmdq_src", HNS3_VECTOR0_CMDQ_SRC_REG}, + {"cmdq_intr_sts", HNS3_CMDQ_INTR_STS_REG}, + {"cmdq_intr_en", HNS3_CMDQ_INTR_EN_REG}, + {"cmdq_intr_gen", HNS3_CMDQ_INTR_GEN_REG}, +}; + +static const struct hns3_dirt_reg_entry common_reg_list[] = { + {"misc_vector_reg_base", HNS3_MISC_VECTOR_REG_BASE}, + {"vector0_oter_en", HNS3_VECTOR0_OTER_EN_REG}, + {"misc_reset_sts", HNS3_MISC_RESET_STS_REG}, + {"vector0_other_int_sts", HNS3_VECTOR0_OTHER_INT_STS_REG}, + {"global_reset", HNS3_GLOBAL_RESET_REG}, + {"fun_rst_ing", HNS3_FUN_RST_ING}, + {"gro_en", HNS3_GRO_EN_REG}, +}; + +static const struct hns3_dirt_reg_entry common_vf_reg_list[] = { + {"misc_vector_reg_base", HNS3_MISC_VECTOR_REG_BASE}, + {"fun_rst_ing", HNS3_FUN_RST_ING}, + {"gro_en", HNS3_GRO_EN_REG}, +}; + +static const struct hns3_dirt_reg_entry ring_reg_list[] = { + {"ring_rx_bd_num", HNS3_RING_RX_BD_NUM_REG}, + {"ring_rx_bd_len", HNS3_RING_RX_BD_LEN_REG}, + {"ring_rx_en", HNS3_RING_RX_EN_REG}, + {"ring_rx_merge_en", HNS3_RING_RX_MERGE_EN_REG}, + {"ring_rx_tail", HNS3_RING_RX_TAIL_REG}, + {"ring_rx_head", HNS3_RING_RX_HEAD_REG}, + {"ring_rx_fbdnum", HNS3_RING_RX_FBDNUM_REG}, + {"ring_rx_offset", HNS3_RING_RX_OFFSET_REG}, + {"ring_rx_fbd_offset", HNS3_RING_RX_FBD_OFFSET_REG}, + {"ring_rx_stash", HNS3_RING_RX_STASH_REG}, + {"ring_rx_bd_err", HNS3_RING_RX_BD_ERR_REG}, + {"ring_tx_bd_num", HNS3_RING_TX_BD_NUM_REG}, + {"ring_tx_en", HNS3_RING_TX_EN_REG}, + {"ring_tx_priority", HNS3_RING_TX_PRIORITY_REG}, + {"ring_tx_tc", HNS3_RING_TX_TC_REG}, + {"ring_tx_merge_en", HNS3_RING_TX_MERGE_EN_REG}, + {"ring_tx_tail", HNS3_RING_TX_TAIL_REG}, + {"ring_tx_head", HNS3_RING_TX_HEAD_REG}, + {"ring_tx_fbdnum", HNS3_RING_TX_FBDNUM_REG}, + {"ring_tx_offset", HNS3_RING_TX_OFFSET_REG}, + {"ring_tx_ebd_num", HNS3_RING_TX_EBD_NUM_REG}, + {"ring_tx_ebd_offset", HNS3_RING_TX_EBD_OFFSET_REG}, + {"ring_tx_bd_err", HNS3_RING_TX_BD_ERR_REG}, + {"ring_en", HNS3_RING_EN_REG}, +}; + +static const struct hns3_dirt_reg_entry tqp_intr_reg_list[] = { + {"tqp_intr_ctrl", HNS3_TQP_INTR_CTRL_REG}, + {"tqp_intr_gl0", HNS3_TQP_INTR_GL0_REG}, + {"tqp_intr_gl1", HNS3_TQP_INTR_GL1_REG}, + {"tqp_intr_gl2", HNS3_TQP_INTR_GL2_REG}, + {"tqp_intr_rl", HNS3_TQP_INTR_RL_REG}, +}; + +struct hns3_dfx_reg_entry { + /** + * name_v1 -- default register name for all platforms (HIP08/HIP09/newer). + * name_v2 -- register name different from the default for HIP09. + * If there are more platform with different register name, name_vXX is extended. + * If the platform is newer than HIP09, use default name. + */ + const char *name_v1; + const char *name_v2; +}; + +static struct hns3_dfx_reg_entry regs_32_bit_list[] = { + {"ssu_common_err_int"}, + {"ssu_port_based_err_int"}, + {"ssu_fifo_overflow_int"}, + {"ssu_ets_tcg_int"}, + {"ssu_bp_status_0"}, + {"ssu_bp_status_1"}, + + {"ssu_bp_status_2"}, + {"ssu_bp_status_3"}, + {"ssu_bp_status_4"}, + {"ssu_bp_status_5"}, + {"ssu_mac_tx_pfc_ind"}, + {"ssu_mac_rx_pfc_ind"}, + + {"ssu_rx_oq_drop_pkt_cnt"}, + {"ssu_tx_oq_drop_pkt_cnt"}, +}; + +static struct hns3_dfx_reg_entry regs_64_bit_list[] = { + {"ppp_get_rx_pkt_cnt_l"}, + {"ppp_get_rx_pkt_cnt_h"}, + {"ppp_get_tx_pkt_cnt_l"}, + {"ppp_get_tx_pkt_cnt_h"}, + {"ppp_send_uc_prt2host_pkt_cnt_l"}, + {"ppp_send_uc_prt2host_pkt_cnt_h"}, + + {"ppp_send_uc_prt2prt_pkt_cnt_l"}, + {"ppp_send_uc_prt2prt_pkt_cnt_h"}, + {"ppp_send_uc_host2host_pkt_cnt_l"}, + {"ppp_send_uc_host2host_pkt_cnt_h"}, + {"ppp_send_uc_host2prt_pkt_cnt_l"}, + {"ppp_send_uc_host2prt_pkt_cnt_h"}, + {"ppp_send_mc_from_prt_cnt_l"}, + {"ppp_send_mc_from_prt_cnt_h"}, +}; + +static struct hns3_dfx_reg_entry dfx_bios_common_reg_list[] = { + {"bios_rsv0"}, + {"bp_cpu_state"}, + {"dfx_msix_info_nic_0"}, + {"dfx_msix_info_nic_1"}, + {"dfx_msix_info_nic_2"}, + {"dfx_msix_info_nic_3"}, + + {"dfx_msix_info_roce_0"}, + {"dfx_msix_info_roce_1"}, + {"dfx_msix_info_roce_2"}, + {"dfx_msix_info_roce_3"}, + {"bios_rsv1"}, + {"bios_rsv2"}, +}; + +static struct hns3_dfx_reg_entry dfx_ssu_reg_0_list[] = { + {"dfx_ssu0_rsv0"}, + {"ssu_ets_port_status"}, + {"ssu_ets_tcg_status"}, + {"dfx_ssu0_rsv1"}, + {"dfx_ssu0_rsv2"}, + {"ssu_bp_status_0"}, + + {"ssu_bp_status_1"}, + {"ssu_bp_status_2"}, + {"ssu_bp_status_3"}, + {"ssu_bp_status_4"}, + {"ssu_bp_status_5"}, + {"ssu_mac_tx_pfc_ind"}, + + {"mac_ssu_rx_pfc_ind"}, + {"btmp_ageing_st_b0"}, + {"btmp_ageing_st_b1"}, + {"btmp_ageing_st_b2"}, + {"dfx_ssu0_rsv3"}, + {"dfx_ssu0_rsv4"}, + + {"ssu_full_drop_num"}, + {"ssu_part_drop_num"}, + {"ppp_key_drop_num"}, + {"ppp_rlt_drop_num"}, + {"lo_pri_unicast_rlt_drop_num"}, + {"hi_pri_multicast_rlt_drop_num"}, + + {"lo_pri_multicast_rlt_drop_num"}, + {"ncsi_packet_curr_buffer_cnt"}, + {"btmp_ageing_rls_cnt_bank0", "dfx_ssu0_rsv5"}, + {"btmp_ageing_rls_cnt_bank1", "dfx_ssu0_rsv6"}, + {"btmp_ageing_rls_cnt_bank2", "dfx_ssu0_rsv7"}, + {"ssu_mb_rd_rlt_drop_cnt"}, + + {"ssu_ppp_mac_key_num_l"}, + {"ssu_ppp_mac_key_num_h"}, + {"ssu_ppp_host_key_num_l"}, + {"ssu_ppp_host_key_num_h"}, + {"ppp_ssu_mac_rlt_num_l"}, + {"ppp_ssu_mac_rlt_num_h"}, + + {"ppp_ssu_host_rlt_num_l"}, + {"ppp_ssu_host_rlt_num_h"}, + {"ncsi_rx_packet_in_cnt_l"}, + {"ncsi_rx_packet_in_cnt_h"}, + {"ncsi_tx_packet_out_cnt_l"}, + {"ncsi_tx_packet_out_cnt_h"}, + + {"ssu_key_drop_num"}, + {"mb_uncopy_num"}, + {"rx_oq_drop_pkt_cnt"}, + {"tx_oq_drop_pkt_cnt"}, + {"bank_unbalance_drop_cnt"}, + {"bank_unbalance_rx_drop_cnt"}, + + {"nic_l2_eer_drop_pkt_cnt"}, + {"roc_l2_eer_drop_pkt_cnt"}, + {"nic_l2_eer_drop_pkt_cnt_rx"}, + {"roc_l2_eer_drop_pkt_cnt_rx"}, + {"rx_oq_glb_drop_pkt_cnt"}, + {"dfx_ssu0_rsv8"}, + + {"lo_pri_unicast_cur_cnt"}, + {"hi_pri_multicast_cur_cnt"}, + {"lo_pri_multicast_cur_cnt"}, + {"dfx_ssu0_rsv9"}, + {"dfx_ssu0_rsv10"}, + {"dfx_ssu0_rsv11"}, +}; + +static struct hns3_dfx_reg_entry dfx_ssu_reg_1_list[] = { + {"dfx_ssu1_prt_id"}, + {"packet_tc_curr_buffer_cnt_0"}, + {"packet_tc_curr_buffer_cnt_1"}, + {"packet_tc_curr_buffer_cnt_2"}, + {"packet_tc_curr_buffer_cnt_3"}, + {"packet_tc_curr_buffer_cnt_4"}, + + {"packet_tc_curr_buffer_cnt_5"}, + {"packet_tc_curr_buffer_cnt_6"}, + {"packet_tc_curr_buffer_cnt_7"}, + {"packet_curr_buffer_cnt"}, + {"dfx_ssu1_rsv0"}, + {"dfx_ssu1_rsv1"}, + + {"rx_packet_in_cnt_l"}, + {"rx_packet_in_cnt_h"}, + {"rx_packet_out_cnt_l"}, + {"rx_packet_out_cnt_h"}, + {"tx_packet_in_cnt_l"}, + {"tx_packet_in_cnt_h"}, + + {"tx_packet_out_cnt_l"}, + {"tx_packet_out_cnt_h"}, + {"roc_rx_packet_in_cnt_l"}, + {"roc_rx_packet_in_cnt_h"}, + {"roc_tx_packet_in_cnt_l"}, + {"roc_tx_packet_in_cnt_h"}, + + {"rx_packet_tc_in_cnt_0_l"}, + {"rx_packet_tc_in_cnt_0_h"}, + {"rx_packet_tc_in_cnt_1_l"}, + {"rx_packet_tc_in_cnt_1_h"}, + {"rx_packet_tc_in_cnt_2_l"}, + {"rx_packet_tc_in_cnt_2_h"}, + + {"rx_packet_tc_in_cnt_3_l"}, + {"rx_packet_tc_in_cnt_3_h"}, + {"rx_packet_tc_in_cnt_4_l"}, + {"rx_packet_tc_in_cnt_4_h"}, + {"rx_packet_tc_in_cnt_5_l"}, + {"rx_packet_tc_in_cnt_5_h"}, + + {"rx_packet_tc_in_cnt_6_l"}, + {"rx_packet_tc_in_cnt_6_h"}, + {"rx_packet_tc_in_cnt_7_l"}, + {"rx_packet_tc_in_cnt_7_h"}, + {"rx_packet_tc_out_cnt_0_l"}, + {"rx_packet_tc_out_cnt_0_h"}, + + {"rx_packet_tc_out_cnt_1_l"}, + {"rx_packet_tc_out_cnt_1_h"}, + {"rx_packet_tc_out_cnt_2_l"}, + {"rx_packet_tc_out_cnt_2_h"}, + {"rx_packet_tc_out_cnt_3_l"}, + {"rx_packet_tc_out_cnt_3_h"}, + + {"rx_packet_tc_out_cnt_4_l"}, + {"rx_packet_tc_out_cnt_4_h"}, + {"rx_packet_tc_out_cnt_5_l"}, + {"rx_packet_tc_out_cnt_5_h"}, + {"rx_packet_tc_out_cnt_6_l"}, + {"rx_packet_tc_out_cnt_6_h"}, + + {"rx_packet_tc_out_cnt_7_l"}, + {"rx_packet_tc_out_cnt_7_h"}, + {"tx_packet_tc_in_cnt_0_l"}, + {"tx_packet_tc_in_cnt_0_h"}, + {"tx_packet_tc_in_cnt_1_l"}, + {"tx_packet_tc_in_cnt_1_h"}, + + {"tx_packet_tc_in_cnt_2_l"}, + {"tx_packet_tc_in_cnt_2_h"}, + {"tx_packet_tc_in_cnt_3_l"}, + {"tx_packet_tc_in_cnt_3_h"}, + {"tx_packet_tc_in_cnt_4_l"}, + {"tx_packet_tc_in_cnt_4_h"}, + + {"tx_packet_tc_in_cnt_5_l"}, + {"tx_packet_tc_in_cnt_5_h"}, + {"tx_packet_tc_in_cnt_6_l"}, + {"tx_packet_tc_in_cnt_6_h"}, + {"tx_packet_tc_in_cnt_7_l"}, + {"tx_packet_tc_in_cnt_7_h"}, + + {"tx_packet_tc_out_cnt_0_l"}, + {"tx_packet_tc_out_cnt_0_h"}, + {"tx_packet_tc_out_cnt_1_l"}, + {"tx_packet_tc_out_cnt_1_h"}, + {"tx_packet_tc_out_cnt_2_l"}, + {"tx_packet_tc_out_cnt_2_h"}, + + {"tx_packet_tc_out_cnt_3_l"}, + {"tx_packet_tc_out_cnt_3_h"}, + {"tx_packet_tc_out_cnt_4_l"}, + {"tx_packet_tc_out_cnt_4_h"}, + {"tx_packet_tc_out_cnt_5_l"}, + {"tx_packet_tc_out_cnt_5_h"}, + + {"tx_packet_tc_out_cnt_6_l"}, + {"tx_packet_tc_out_cnt_6_h"}, + {"tx_packet_tc_out_cnt_7_l"}, + {"tx_packet_tc_out_cnt_7_h"}, + {"dfx_ssu1_rsv2"}, + {"dfx_ssu1_rsv3"}, +}; + +static struct hns3_dfx_reg_entry dfx_igu_egu_reg_list[] = { + {"igu_egu_prt_id"}, + {"igu_rx_err_pkt"}, + {"igu_rx_no_sof_pkt"}, + {"egu_tx_1588_short_pkt"}, + {"egu_tx_1588_pkt"}, + {"egu_tx_1588_err_pkt"}, + + {"igu_rx_out_l2_pkt"}, + {"igu_rx_out_l3_pkt"}, + {"igu_rx_out_l4_pkt"}, + {"igu_rx_in_l2_pkt"}, + {"igu_rx_in_l3_pkt"}, + {"igu_rx_in_l4_pkt"}, + + {"igu_rx_el3e_pkt"}, + {"igu_rx_el4e_pkt"}, + {"igu_rx_l3e_pkt"}, + {"igu_rx_l4e_pkt"}, + {"igu_rx_rocee_pkt"}, + {"igu_rx_out_udp0_pkt"}, + + {"igu_rx_in_udp0_pkt"}, + {"igu_egu_rsv0", "igu_egu_mul_car_drop_pkt_cnt_l"}, + {"igu_egu_rsv1", "igu_egu_mul_car_drop_pkt_cnt_h"}, + {"igu_egu_rsv2", "igu_egu_bro_car_drop_pkt_cnt_l"}, + {"igu_egu_rsv3", "igu_egu_bro_car_drop_pkt_cnt_h"}, + {"igu_egu_rsv4", "igu_egu_rsv0"}, + + {"igu_rx_oversize_pkt_l"}, + {"igu_rx_oversize_pkt_h"}, + {"igu_rx_undersize_pkt_l"}, + {"igu_rx_undersize_pkt_h"}, + {"igu_rx_out_all_pkt_l"}, + {"igu_rx_out_all_pkt_h"}, + + {"igu_tx_out_all_pkt_l"}, + {"igu_tx_out_all_pkt_h"}, + {"igu_rx_uni_pkt_l"}, + {"igu_rx_uni_pkt_h"}, + {"igu_rx_multi_pkt_l"}, + {"igu_rx_multi_pkt_h"}, + + {"igu_rx_broad_pkt_l"}, + {"igu_rx_broad_pkt_h"}, + {"egu_tx_out_all_pkt_l"}, + {"egu_tx_out_all_pkt_h"}, + {"egu_tx_uni_pkt_l"}, + {"egu_tx_uni_pkt_h"}, + + {"egu_tx_multi_pkt_l"}, + {"egu_tx_multi_pkt_h"}, + {"egu_tx_broad_pkt_l"}, + {"egu_tx_broad_pkt_h"}, + {"igu_tx_key_num_l"}, + {"igu_tx_key_num_h"}, + + {"igu_rx_non_tun_pkt_l"}, + {"igu_rx_non_tun_pkt_h"}, + {"igu_rx_tun_pkt_l"}, + {"igu_rx_tun_pkt_h"}, + {"igu_egu_rsv5"}, + {"igu_egu_rsv6"}, +}; + +static struct hns3_dfx_reg_entry dfx_rpu_reg_0_list[] = { + {"rpu_tc_queue_num", "rpu_currport_tnl_index"}, + {"rpu_fsm_dfx_st0"}, + {"rpu_fsm_dfx_st1"}, + {"rpu_rpu_rx_pkt_drop_cnt"}, + {"rpu_buf_wait_timeout"}, + {"rpu_buf_wait_timeout_qid"}, +}; + +static struct hns3_dfx_reg_entry dfx_rpu_reg_1_list[] = { + {"rpu_rsv0"}, + {"rpu_fifo_dfx_st0"}, + {"rpu_fifo_dfx_st1"}, + {"rpu_fifo_dfx_st2"}, + {"rpu_fifo_dfx_st3"}, + {"rpu_fifo_dfx_st4"}, + + {"rpu_fifo_dfx_st5"}, + {"rpu_rsv1"}, + {"rpu_rsv2"}, + {"rpu_rsv3"}, + {"rpu_rsv4"}, + {"rpu_rsv5"}, +}; + +static struct hns3_dfx_reg_entry dfx_ncsi_reg_list[] = { + {"ncsi_rsv0"}, + {"ncsi_egu_tx_fifo_sts"}, + {"ncsi_pause_status"}, + {"ncsi_rx_ctrl_dmac_err_cnt"}, + {"ncsi_rx_ctrl_smac_err_cnt"}, + {"ncsi_rx_ctrl_cks_err_cnt"}, + + {"ncsi_rx_ctrl_pkt_err_cnt"}, + {"ncsi_rx_pt_dmac_err_cnt"}, + {"ncsi_rx_pt_smac_err_cnt"}, + {"ncsi_rx_pt_pkt_cnt"}, + {"ncsi_rx_fcs_err_cnt"}, + {"ncsi_tx_ctrl_dmac_err_cnt"}, + + {"ncsi_tx_ctrl_smac_err_cnt"}, + {"ncsi_tx_ctrl_pkt_cnt"}, + {"ncsi_tx_pt_dmac_err_cnt"}, + {"ncsi_tx_pt_smac_err_cnt"}, + {"ncsi_tx_pt_pkt_cnt"}, + {"ncsi_tx_pt_pkt_trun_cnt"}, + + {"ncsi_tx_pt_pkt_err_cnt"}, + {"ncsi_tx_ctrl_pkt_err_cnt"}, + {"ncsi_rx_ctrl_pkt_trun_cnt"}, + {"ncsi_rx_ctrl_pkt_cflit_cnt"}, + {"ncsi_rsv1"}, + {"ncsi_rsv2"}, + + {"ncsi_mac_rx_octets_ok"}, + {"ncsi_mac_rx_octets_bad"}, + {"ncsi_mac_rx_uc_pkts"}, + {"ncsi_mac_rx_mc_pkts"}, + {"ncsi_mac_rx_bc_pkts"}, + {"ncsi_mac_rx_pkts_64octets"}, + + {"ncsi_mac_rx_pkts_64to127_octets"}, + {"ncsi_mac_rx_pkts_128to255_octets"}, + {"ncsi_mac_rx_pkts_256to511_octets"}, + {"ncsi_mac_rx_pkts_512to1023_octets"}, + {"ncsi_mac_rx_pkts_1024to1518_octets"}, + {"ncsi_mac_rx_pkts_1519tomax_octets"}, + + {"ncsi_mac_rx_fcs_errors"}, + {"ncsi_mac_rx_long_errors"}, + {"ncsi_mac_rx_jabber_errors"}, + {"ncsi_mac_rx_runt_err_cnt"}, + {"ncsi_mac_rx_short_err_cnt"}, + {"ncsi_mac_rx_filt_pkt_cnt"}, + + {"ncsi_mac_rx_octets_total_filt"}, + {"ncsi_mac_tx_octets_ok"}, + {"ncsi_mac_tx_octets_bad"}, + {"ncsi_mac_tx_uc_pkts"}, + {"ncsi_mac_tx_mc_pkts"}, + {"ncsi_mac_tx_bc_pkts"}, + + {"ncsi_mac_tx_pkts_64octets"}, + {"ncsi_mac_tx_pkts_64to127_octets"}, + {"ncsi_mac_tx_pkts_128to255_octets"}, + {"ncsi_mac_tx_pkts_256to511_octets"}, + {"ncsi_mac_tx_pkts_512to1023_octets"}, + {"ncsi_mac_tx_pkts_1024to1518_octets"}, + + {"ncsi_mac_tx_pkts_1519tomax_octets"}, + {"ncsi_mac_tx_underrun"}, + {"ncsi_mac_tx_crc_error"}, + {"ncsi_mac_tx_pause_frames"}, + {"ncsi_mac_rx_pad_pkts"}, + {"ncsi_mac_rx_pause_frames"}, +}; + +static struct hns3_dfx_reg_entry dfx_rtc_reg_list[] = { + {"rtc_rsv0"}, + {"lge_igu_afifo_dfx_0"}, + {"lge_igu_afifo_dfx_1"}, + {"lge_igu_afifo_dfx_2"}, + {"lge_igu_afifo_dfx_3"}, + {"lge_igu_afifo_dfx_4"}, + + {"lge_igu_afifo_dfx_5"}, + {"lge_igu_afifo_dfx_6"}, + {"lge_igu_afifo_dfx_7"}, + {"lge_egu_afifo_dfx_0"}, + {"lge_egu_afifo_dfx_1"}, + {"lge_egu_afifo_dfx_2"}, + + {"lge_egu_afifo_dfx_3"}, + {"lge_egu_afifo_dfx_4"}, + {"lge_egu_afifo_dfx_5"}, + {"lge_egu_afifo_dfx_6"}, + {"lge_egu_afifo_dfx_7"}, + {"cge_igu_afifo_dfx_0"}, + + {"cge_igu_afifo_dfx_1"}, + {"cge_egu_afifo_dfx_0"}, + {"cge_egu_afifo_dfx_i"}, + {"rtc_rsv1"}, + {"rtc_rsv2"}, + {"rtc_rsv3"}, +}; + +static struct hns3_dfx_reg_entry dfx_ppp_reg_list[] = { + {"ppp_rsv0"}, + {"ppp_drop_from_prt_pkt_cnt"}, + {"ppp_drop_from_host_pkt_cnt"}, + {"ppp_drop_tx_vlan_proc_cnt"}, + {"ppp_drop_mng_cnt"}, + {"ppp_drop_fd_cnt"}, + + {"ppp_drop_no_dst_cnt"}, + {"ppp_drop_mc_mbid_full_cnt"}, + {"ppp_drop_sc_filtered"}, + {"ppp_ppp_mc_drop_pkt_cnt"}, + {"ppp_drop_pt_cnt"}, + {"ppp_drop_mac_anti_spoof_cnt"}, + + {"ppp_drop_ig_vfv_cnt"}, + {"ppp_drop_ig_prtv_cnt"}, + {"ppp_drop_cnm_pfc_pause_cnt"}, + {"ppp_drop_torus_tc_cnt"}, + {"ppp_drop_torus_lpbk_cnt"}, + {"ppp_ppp_hfs_sts"}, + + {"ppp_mc_rslt_sts"}, + {"ppp_p3u_sts"}, + {"ppp_rslt_descr_sts", "ppp_rsv1"}, + {"ppp_umv_sts_0"}, + {"ppp_umv_sts_1"}, + {"ppp_vfv_sts"}, + + {"ppp_gro_key_cnt"}, + {"ppp_gro_info_cnt"}, + {"ppp_gro_drop_cnt"}, + {"ppp_gro_out_cnt"}, + {"ppp_gro_key_match_data_cnt"}, + {"ppp_gro_key_match_tcam_cnt"}, + + {"ppp_gro_info_match_cnt"}, + {"ppp_gro_free_entry_cnt"}, + {"ppp_gro_inner_dfx_signal"}, + {"ppp_rsv2"}, + {"ppp_rsv3"}, + {"ppp_rsv4"}, + + {"ppp_get_rx_pkt_cnt_l"}, + {"ppp_get_rx_pkt_cnt_h"}, + {"ppp_get_tx_pkt_cnt_l"}, + {"ppp_get_tx_pkt_cnt_h"}, + {"ppp_send_uc_prt2host_pkt_cnt_l"}, + {"ppp_send_uc_prt2host_pkt_cnt_h"}, + + {"ppp_send_uc_prt2prt_pkt_cnt_l"}, + {"ppp_send_uc_prt2prt_pkt_cnt_h"}, + {"ppp_send_uc_host2host_pkt_cnt_l"}, + {"ppp_send_uc_host2host_pkt_cnt_h"}, + {"ppp_send_uc_host2prt_pkt_cnt_l"}, + {"ppp_send_uc_host2prt_pkt_cnt_h"}, + + {"ppp_send_mc_from_prt_cnt_l"}, + {"ppp_send_mc_from_prt_cnt_h"}, + {"ppp_send_mc_from_host_cnt_l"}, + {"ppp_send_mc_from_host_cnt_h"}, + {"ppp_ssu_mc_rd_cnt_l"}, + {"ppp_ssu_mc_rd_cnt_h"}, + + {"ppp_ssu_mc_drop_cnt_l"}, + {"ppp_ssu_mc_drop_cnt_h"}, + {"ppp_ssu_mc_rd_pkt_cnt_l"}, + {"ppp_ssu_mc_rd_pkt_cnt_h"}, + {"ppp_mc_2host_pkt_cnt_l"}, + {"ppp_mc_2host_pkt_cnt_h"}, + + {"ppp_mc_2prt_pkt_cnt_l"}, + {"ppp_mc_2prt_pkt_cnt_h"}, + {"ppp_ntsnos_pkt_cnt_l"}, + {"ppp_ntsnos_pkt_cnt_h"}, + {"ppp_ntup_pkt_cnt_l"}, + {"ppp_ntup_pkt_cnt_h"}, + + {"ppp_ntlcl_pkt_cnt_l"}, + {"ppp_ntlcl_pkt_cnt_h"}, + {"ppp_nttgt_pkt_cnt_l"}, + {"ppp_nttgt_pkt_cnt_h"}, + {"ppp_rtns_pkt_cnt_l"}, + {"ppp_rtns_pkt_cnt_h"}, + + {"ppp_rtlpbk_pkt_cnt_l"}, + {"ppp_rtlpbk_pkt_cnt_h"}, + {"ppp_nr_pkt_cnt_l"}, + {"ppp_nr_pkt_cnt_h"}, + {"ppp_rr_pkt_cnt_l"}, + {"ppp_rr_pkt_cnt_h"}, + + {"ppp_mng_tbl_hit_cnt_l"}, + {"ppp_mng_tbl_hit_cnt_h"}, + {"ppp_fd_tbl_hit_cnt_l"}, + {"ppp_fd_tbl_hit_cnt_h"}, + {"ppp_fd_lkup_cnt_l"}, + {"ppp_fd_lkup_cnt_h"}, + + {"ppp_bc_hit_cnt"}, + {"ppp_bc_hit_cnt_h"}, + {"ppp_um_tbl_uc_hit_cnt"}, + {"ppp_um_tbl_uc_hit_cnt_h"}, + {"ppp_um_tbl_mc_hit_cnt"}, + {"ppp_um_tbl_mc_hit_cnt_h"}, + + {"ppp_um_tbl_vmdq1_hit_cnt_l", "ppp_um_tbl_snq_hit_cnt_l"}, + {"ppp_um_tbl_vmdq1_hit_cnt_h", "ppp_um_tbl_snq_hit_cnt_h"}, + {"ppp_mta_tbl_hit_cnt_l", "ppp_rsv5"}, + {"ppp_mta_tbl_hit_cnt_h", "ppp_rsv6"}, + {"ppp_fwd_bonding_hit_cnt_l"}, + {"ppp_fwd_bonding_hit_cnt_h"}, + + {"ppp_promisc_tbl_hit_cnt_l"}, + {"ppp_promisc_tbl_hit_cnt_h"}, + {"ppp_get_tunl_pkt_cnt_l"}, + {"ppp_get_tunl_pkt_cnt_h"}, + {"ppp_get_bmc_pkt_cnt_l"}, + {"ppp_get_bmc_pkt_cnt_h"}, + + {"ppp_send_uc_prt2bmc_pkt_cnt_l"}, + {"ppp_send_uc_prt2bmc_pkt_cnt_h"}, + {"ppp_send_uc_host2bmc_pkt_cnt_l"}, + {"ppp_send_uc_host2bmc_pkt_cnt_h"}, + {"ppp_send_uc_bmc2host_pkt_cnt_l"}, + {"ppp_send_uc_bmc2host_pkt_cnt_h"}, + + {"ppp_send_uc_bmc2prt_pkt_cnt_l"}, + {"ppp_send_uc_bmc2prt_pkt_cnt_h"}, + {"ppp_mc_2bmc_pkt_cnt_l"}, + {"ppp_mc_2bmc_pkt_cnt_h"}, + {"ppp_vlan_mirr_cnt_l", "ppp_rsv7"}, + {"ppp_vlan_mirr_cnt_h", "ppp_rsv8"}, + + {"ppp_ig_mirr_cnt_l", "ppp_rsv9"}, + {"ppp_ig_mirr_cnt_h", "ppp_rsv10"}, + {"ppp_eg_mirr_cnt_l", "ppp_rsv11"}, + {"ppp_eg_mirr_cnt_h", "ppp_rsv12"}, + {"ppp_rx_default_host_hit_cnt_l"}, + {"ppp_rx_default_host_hit_cnt_h"}, + + {"ppp_lan_pair_cnt_l"}, + {"ppp_lan_pair_cnt_h"}, + {"ppp_um_tbl_mc_hit_pkt_cnt_l"}, + {"ppp_um_tbl_mc_hit_pkt_cnt_h"}, + {"ppp_mta_tbl_hit_pkt_cnt_l"}, + {"ppp_mta_tbl_hit_pkt_cnt_h"}, + + {"ppp_promisc_tbl_hit_pkt_cnt_l"}, + {"ppp_promisc_tbl_hit_pkt_cnt_h"}, + {"ppp_rsv13"}, + {"ppp_rsv14"}, + {"ppp_rsv15"}, + {"ppp_rsv16"}, +}; + +static struct hns3_dfx_reg_entry dfx_rcb_reg_list[] = { + {"rcb_rsv0"}, + {"rcb_fsm_dfx_st0"}, + {"rcb_fsm_dfx_st1"}, + {"rcb_fsm_dfx_st2"}, + {"rcb_fifo_dfx_st0"}, + {"rcb_fifo_dfx_st1"}, + + {"rcb_fifo_dfx_st2"}, + {"rcb_fifo_dfx_st3"}, + {"rcb_fifo_dfx_st4"}, + {"rcb_fifo_dfx_st5"}, + {"rcb_fifo_dfx_st6"}, + {"rcb_fifo_dfx_st7"}, + + {"rcb_fifo_dfx_st8"}, + {"rcb_fifo_dfx_st9"}, + {"rcb_fifo_dfx_st10"}, + {"rcb_fifo_dfx_st11"}, + {"rcb_q_credit_vld_0"}, + {"rcb_q_credit_vld_1"}, + + {"rcb_q_credit_vld_2"}, + {"rcb_q_credit_vld_3"}, + {"rcb_q_credit_vld_4"}, + {"rcb_q_credit_vld_5"}, + {"rcb_q_credit_vld_6"}, + {"rcb_q_credit_vld_7"}, + + {"rcb_q_credit_vld_8"}, + {"rcb_q_credit_vld_9"}, + {"rcb_q_credit_vld_10"}, + {"rcb_q_credit_vld_11"}, + {"rcb_q_credit_vld_12"}, + {"rcb_q_credit_vld_13"}, + + {"rcb_q_credit_vld_14"}, + {"rcb_q_credit_vld_15"}, + {"rcb_q_credit_vld_16"}, + {"rcb_q_credit_vld_17"}, + {"rcb_q_credit_vld_18"}, + {"rcb_q_credit_vld_19"}, + + {"rcb_q_credit_vld_20"}, + {"rcb_q_credit_vld_21"}, + {"rcb_q_credit_vld_22"}, + {"rcb_q_credit_vld_23"}, + {"rcb_q_credit_vld_24"}, + {"rcb_q_credit_vld_25"}, + + {"rcb_q_credit_vld_26"}, + {"rcb_q_credit_vld_27"}, + {"rcb_q_credit_vld_28"}, + {"rcb_q_credit_vld_29"}, + {"rcb_q_credit_vld_30"}, + {"rcb_q_credit_vld_31"}, + + {"rcb_gro_bd_serr_cnt"}, + {"rcb_gro_context_serr_cnt"}, + {"rcb_rx_stash_cfg_serr_cnt"}, + {"rcb_axi_rd_fbd_serr_cnt", "rcb_rcb_tx_mem_serr_cnt"}, + {"rcb_gro_bd_merr_cnt"}, + {"rcb_gro_context_merr_cnt"}, + + {"rcb_rx_stash_cfg_merr_cnt"}, + {"rcb_axi_rd_fbd_merr_cnt"}, + {"rcb_rsv1"}, + {"rcb_rsv2"}, + {"rcb_rsv3"}, + {"rcb_rsv4"}, +}; + +static struct hns3_dfx_reg_entry dfx_tqp_reg_list[] = { + {"dfx_tqp_q_num"}, + {"rcb_cfg_rx_ring_tail"}, + {"rcb_cfg_rx_ring_head"}, + {"rcb_cfg_rx_ring_fbdnum"}, + {"rcb_cfg_rx_ring_offset"}, + {"rcb_cfg_rx_ring_fbdoffset"}, + + {"rcb_cfg_rx_ring_pktnum_record"}, + {"rcb_cfg_tx_ring_tail"}, + {"rcb_cfg_tx_ring_head"}, + {"rcb_cfg_tx_ring_fbdnum"}, + {"rcb_cfg_tx_ring_offset"}, + {"rcb_cfg_tx_ring_ebdnum"}, +}; + +static struct hns3_dfx_reg_entry dfx_ssu_reg_2_list[] = { + {"dfx_ssu2_oq_index"}, + {"dfx_ssu2_queue_cnt"}, + {"dfx_ssu2_rsv0"}, + {"dfx_ssu2_rsv1"}, + {"dfx_ssu2_rsv2"}, + {"dfx_ssu2_rsv3"}, +}; + +enum hns3_reg_modules { + HNS3_BIOS_COMMON = 0, + HNS3_SSU_0, + HNS3_SSU_1, + HNS3_IGU_EGU, + HNS3_RPU_0, + HNS3_RPU_1, + HNS3_NCSI, + HNS3_RTC, + HNS3_PPP, + HNS3_RCB, + HNS3_TQP, + HNS3_SSU_2, + + HNS3_CMDQ = 12, + HNS3_COMMON_PF, + HNS3_COMMON_VF, + HNS3_RING, + HNS3_TQP_INTR, + + HNS3_32_BIT_DFX, + HNS3_64_BIT_DFX, +}; + +struct hns3_reg_list { + const void *reg_list; + uint32_t entry_num; +}; + +static struct hns3_reg_list hns3_reg_lists[] = { + [HNS3_BIOS_COMMON] = { dfx_bios_common_reg_list, RTE_DIM(dfx_bios_common_reg_list)}, + [HNS3_SSU_0] = { dfx_ssu_reg_0_list, RTE_DIM(dfx_ssu_reg_0_list)}, + [HNS3_SSU_1] = { dfx_ssu_reg_1_list, RTE_DIM(dfx_ssu_reg_1_list)}, + [HNS3_IGU_EGU] = { dfx_igu_egu_reg_list, RTE_DIM(dfx_igu_egu_reg_list)}, + [HNS3_RPU_0] = { dfx_rpu_reg_0_list, RTE_DIM(dfx_rpu_reg_0_list)}, + [HNS3_RPU_1] = { dfx_rpu_reg_1_list, RTE_DIM(dfx_rpu_reg_1_list)}, + [HNS3_NCSI] = { dfx_ncsi_reg_list, RTE_DIM(dfx_ncsi_reg_list)}, + [HNS3_RTC] = { dfx_rtc_reg_list, RTE_DIM(dfx_rtc_reg_list)}, + [HNS3_PPP] = { dfx_ppp_reg_list, RTE_DIM(dfx_ppp_reg_list)}, + [HNS3_RCB] = { dfx_rcb_reg_list, RTE_DIM(dfx_rcb_reg_list)}, + [HNS3_TQP] = { dfx_tqp_reg_list, RTE_DIM(dfx_tqp_reg_list)}, + [HNS3_SSU_2] = { dfx_ssu_reg_2_list, RTE_DIM(dfx_ssu_reg_2_list)}, + + [HNS3_CMDQ] = { cmdq_reg_list, RTE_DIM(cmdq_reg_list)}, + [HNS3_COMMON_PF] = { common_reg_list, RTE_DIM(common_reg_list)}, + [HNS3_COMMON_VF] = { common_vf_reg_list, RTE_DIM(common_vf_reg_list)}, + [HNS3_RING] = { ring_reg_list, RTE_DIM(ring_reg_list)}, + [HNS3_TQP_INTR] = { tqp_intr_reg_list, RTE_DIM(tqp_intr_reg_list)}, + + [HNS3_32_BIT_DFX] = { regs_32_bit_list, RTE_DIM(regs_32_bit_list)}, + [HNS3_64_BIT_DFX] = { regs_64_bit_list, RTE_DIM(regs_64_bit_list)}, +}; static const uint32_t hns3_dfx_reg_opcode_list[] = { - HNS3_OPC_DFX_BIOS_COMMON_REG, - HNS3_OPC_DFX_SSU_REG_0, - HNS3_OPC_DFX_SSU_REG_1, - HNS3_OPC_DFX_IGU_EGU_REG, - HNS3_OPC_DFX_RPU_REG_0, - HNS3_OPC_DFX_RPU_REG_1, - HNS3_OPC_DFX_NCSI_REG, - HNS3_OPC_DFX_RTC_REG, - HNS3_OPC_DFX_PPP_REG, - HNS3_OPC_DFX_RCB_REG, - HNS3_OPC_DFX_TQP_REG, - HNS3_OPC_DFX_SSU_REG_2 + [HNS3_BIOS_COMMON] = HNS3_OPC_DFX_BIOS_COMMON_REG, + [HNS3_SSU_0] = HNS3_OPC_DFX_SSU_REG_0, + [HNS3_SSU_1] = HNS3_OPC_DFX_SSU_REG_1, + [HNS3_IGU_EGU] = HNS3_OPC_DFX_IGU_EGU_REG, + [HNS3_RPU_0] = HNS3_OPC_DFX_RPU_REG_0, + [HNS3_RPU_1] = HNS3_OPC_DFX_RPU_REG_1, + [HNS3_NCSI] = HNS3_OPC_DFX_NCSI_REG, + [HNS3_RTC] = HNS3_OPC_DFX_RTC_REG, + [HNS3_PPP] = HNS3_OPC_DFX_PPP_REG, + [HNS3_RCB] = HNS3_OPC_DFX_RCB_REG, + [HNS3_TQP] = HNS3_OPC_DFX_TQP_REG, + [HNS3_SSU_2] = HNS3_OPC_DFX_SSU_REG_2 }; static int @@ -100,6 +856,11 @@ hns3_get_regs_num(struct hns3_hw *hw, uint32_t *regs_num_32_bit, *regs_num_32_bit = rte_le_to_cpu_32(desc.data[0]); *regs_num_64_bit = rte_le_to_cpu_32(desc.data[1]); + if (*regs_num_32_bit != RTE_DIM(regs_32_bit_list) || + *regs_num_64_bit * HNS3_64_BIT_REG_OUTPUT_SIZE != RTE_DIM(regs_64_bit_list)) { + hns3_err(hw, "Query register number differ from the list!"); + return -EINVAL; + } return 0; } @@ -161,6 +922,7 @@ hns3_get_dfx_reg_cnt(struct hns3_hw *hw, uint32_t *count) { int opcode_num = RTE_DIM(hns3_dfx_reg_opcode_list); uint32_t bd_num_list[opcode_num]; + uint32_t reg_num; int ret; int i; @@ -168,8 +930,14 @@ hns3_get_dfx_reg_cnt(struct hns3_hw *hw, uint32_t *count) if (ret) return ret; - for (i = 0; i < opcode_num; i++) - *count += bd_num_list[i] * HNS3_CMD_DESC_DATA_NUM; + for (i = 0; i < opcode_num; i++) { + reg_num = bd_num_list[i] * HNS3_CMD_DESC_DATA_NUM; + if (reg_num != hns3_reg_lists[i].entry_num) { + hns3_err(hw, "Query register number differ from the list for module!"); + return -EINVAL; + } + *count += reg_num; + } return 0; } @@ -196,14 +964,13 @@ hns3_get_regs_length(struct hns3_hw *hw, uint32_t *length) int ret; if (hns->is_vf) - common_cnt = sizeof(common_vf_reg_addrs); + common_cnt = RTE_DIM(common_vf_reg_list); else - common_cnt = sizeof(common_reg_addrs); + common_cnt = RTE_DIM(common_reg_list); - len = sizeof(cmdq_reg_addrs) + common_cnt + - sizeof(ring_reg_addrs) * hw->tqps_num + - sizeof(tqp_intr_reg_addrs) * hw->intr_tqps_num; - len /= sizeof(uint32_t); + len = RTE_DIM(cmdq_reg_list) + common_cnt + + RTE_DIM(ring_reg_list) * hw->tqps_num + + RTE_DIM(tqp_intr_reg_list) * hw->intr_tqps_num; if (!hns->is_vf) { ret = hns3_get_firmware_reg_cnt(hw, &dfx_reg_cnt); @@ -219,13 +986,31 @@ hns3_get_regs_length(struct hns3_hw *hw, uint32_t *length) return 0; } +static void +hns3_fill_dfx_regs_name(struct hns3_hw *hw, struct rte_dev_reg_info *regs, + const struct hns3_dfx_reg_entry *reg_list, uint32_t reg_num) +{ + uint32_t i, cnt = regs->length; + const char *name; + + if (regs->names == NULL) + return; + + for (i = 0; i < reg_num; i++) { + name = reg_list[i].name_v1; + if (hw->revision == PCI_REVISION_ID_HIP09_A && reg_list[i].name_v2 != NULL) + name = reg_list[i].name_v2; + snprintf(regs->names[cnt++].name, RTE_ETH_REG_NAME_SIZE, "%s", name); + } +} + static int -hns3_get_32_bit_regs(struct hns3_hw *hw, uint32_t regs_num, void *data) +hns3_get_32_bit_regs(struct hns3_hw *hw, uint32_t regs_num, struct rte_dev_reg_info *regs) { #define HNS3_32_BIT_REG_RTN_DATANUM 8 #define HNS3_32_BIT_DESC_NODATA_LEN 2 + uint32_t *reg_val = regs->data; struct hns3_cmd_desc *desc; - uint32_t *reg_val = data; uint32_t *desc_data; int cmd_num; int i, k, n; @@ -254,6 +1039,9 @@ hns3_get_32_bit_regs(struct hns3_hw *hw, uint32_t regs_num, void *data) return ret; } + hns3_fill_dfx_regs_name(hw, regs, regs_32_bit_list, regs_num); + reg_val += regs->length; + regs->length += regs_num; for (i = 0; i < cmd_num; i++) { if (i == 0) { desc_data = &desc[i].data[0]; @@ -265,7 +1053,6 @@ hns3_get_32_bit_regs(struct hns3_hw *hw, uint32_t regs_num, void *data) } for (k = 0; k < n; k++) { *reg_val++ = rte_le_to_cpu_32(*desc_data++); - regs_num--; if (regs_num == 0) break; @@ -277,12 +1064,12 @@ hns3_get_32_bit_regs(struct hns3_hw *hw, uint32_t regs_num, void *data) } static int -hns3_get_64_bit_regs(struct hns3_hw *hw, uint32_t regs_num, void *data) +hns3_get_64_bit_regs(struct hns3_hw *hw, uint32_t regs_num, struct rte_dev_reg_info *regs) { #define HNS3_64_BIT_REG_RTN_DATANUM 4 #define HNS3_64_BIT_DESC_NODATA_LEN 1 + uint32_t *reg_val = regs->data; struct hns3_cmd_desc *desc; - uint64_t *reg_val = data; uint64_t *desc_data; int cmd_num; int i, k, n; @@ -311,6 +1098,9 @@ hns3_get_64_bit_regs(struct hns3_hw *hw, uint32_t regs_num, void *data) return ret; } + hns3_fill_dfx_regs_name(hw, regs, regs_64_bit_list, regs_num * HNS3_64_BIT_REG_OUTPUT_SIZE); + reg_val += regs->length; + regs->length += regs_num * HNS3_64_BIT_REG_OUTPUT_SIZE; for (i = 0; i < cmd_num; i++) { if (i == 0) { desc_data = (uint64_t *)(&desc[i].data[0]); @@ -322,7 +1112,6 @@ hns3_get_64_bit_regs(struct hns3_hw *hw, uint32_t regs_num, void *data) } for (k = 0; k < n; k++) { *reg_val++ = rte_le_to_cpu_64(*desc_data++); - regs_num--; if (!regs_num) break; @@ -333,47 +1122,80 @@ hns3_get_64_bit_regs(struct hns3_hw *hw, uint32_t regs_num, void *data) return 0; } -static int -hns3_direct_access_regs(struct hns3_hw *hw, uint32_t *data) +static void +hns3_direct_access_regs_help(struct hns3_hw *hw, struct rte_dev_reg_info *regs, + enum hns3_reg_modules idx) { - struct hns3_adapter *hns = HNS3_DEV_HW_TO_ADAPTER(hw); - uint32_t *origin_data_ptr = data; - uint32_t reg_offset; - size_t reg_num; - uint16_t j; - size_t i; + const struct hns3_dirt_reg_entry *reg_list; + uint32_t *data = regs->data; + size_t reg_num, i, cnt; + + data += regs->length; + reg_num = hns3_reg_lists[idx].entry_num; + reg_list = hns3_reg_lists[idx].reg_list; + cnt = regs->length; + for (i = 0; i < reg_num; i++) { + *data++ = hns3_read_dev(hw, reg_list[i].addr); + if (regs->names != NULL) + snprintf(regs->names[cnt++].name, RTE_ETH_REG_NAME_SIZE, + "%s", reg_list[i].name); + } - /* fetching per-PF registers values from PF PCIe register space */ - reg_num = sizeof(cmdq_reg_addrs) / sizeof(uint32_t); - for (i = 0; i < reg_num; i++) - *data++ = hns3_read_dev(hw, cmdq_reg_addrs[i]); + regs->length += reg_num; +} + +static uint32_t +hns3_get_module_tqp_reg_offset(enum hns3_reg_modules idx, uint16_t queue_id) +{ + if (idx == HNS3_RING) + return hns3_get_tqp_reg_offset(queue_id); + else if (idx == HNS3_TQP_INTR) + return hns3_get_tqp_intr_reg_offset(queue_id); + + return 0; +} + +static void +hns3_direct_access_tqp_regs_help(struct hns3_hw *hw, struct rte_dev_reg_info *regs, + enum hns3_reg_modules idx) +{ + const struct hns3_dirt_reg_entry *reg_list; + uint16_t tqp_num, reg_offset; + uint32_t *data = regs->data; + uint32_t reg_num, i, j; + + if (idx != HNS3_RING && idx != HNS3_TQP_INTR) + return; + + tqp_num = (idx == HNS3_RING) ? hw->tqps_num : hw->intr_tqps_num; + reg_list = hns3_reg_lists[idx].reg_list; + reg_num = hns3_reg_lists[idx].entry_num; + data += regs->length; + for (i = 0; i < tqp_num; i++) { + reg_offset = hns3_get_module_tqp_reg_offset(idx, i); + for (j = 0; j < reg_num; j++) { + *data++ = hns3_read_dev(hw, reg_list[j].addr + reg_offset); + if (regs->names != NULL) + snprintf(regs->names[regs->length].name, + RTE_ETH_REG_NAME_SIZE, "Q%u_%s", i, reg_list[j].name); + regs->length++; + } + } +} + +static void +hns3_direct_access_regs(struct hns3_hw *hw, struct rte_dev_reg_info *regs) +{ + struct hns3_adapter *hns = HNS3_DEV_HW_TO_ADAPTER(hw); if (hns->is_vf) - reg_num = sizeof(common_vf_reg_addrs) / sizeof(uint32_t); + hns3_direct_access_regs_help(hw, regs, HNS3_COMMON_VF); else - reg_num = sizeof(common_reg_addrs) / sizeof(uint32_t); - for (i = 0; i < reg_num; i++) - if (hns->is_vf) - *data++ = hns3_read_dev(hw, common_vf_reg_addrs[i]); - else - *data++ = hns3_read_dev(hw, common_reg_addrs[i]); - - reg_num = sizeof(ring_reg_addrs) / sizeof(uint32_t); - for (j = 0; j < hw->tqps_num; j++) { - reg_offset = hns3_get_tqp_reg_offset(j); - for (i = 0; i < reg_num; i++) - *data++ = hns3_read_dev(hw, - ring_reg_addrs[i] + reg_offset); - } + hns3_direct_access_regs_help(hw, regs, HNS3_COMMON_PF); - reg_num = sizeof(tqp_intr_reg_addrs) / sizeof(uint32_t); - for (j = 0; j < hw->intr_tqps_num; j++) { - reg_offset = hns3_get_tqp_intr_reg_offset(j); - for (i = 0; i < reg_num; i++) - *data++ = hns3_read_dev(hw, tqp_intr_reg_addrs[i] + - reg_offset); - } - return data - origin_data_ptr; + hns3_direct_access_regs_help(hw, regs, HNS3_CMDQ); + hns3_direct_access_tqp_regs_help(hw, regs, HNS3_RING); + hns3_direct_access_tqp_regs_help(hw, regs, HNS3_TQP_INTR); } static int @@ -417,13 +1239,13 @@ hns3_dfx_reg_fetch_data(struct hns3_cmd_desc *desc, int bd_num, uint32_t *reg) } static int -hns3_get_dfx_regs(struct hns3_hw *hw, void **data) +hns3_get_dfx_regs(struct hns3_hw *hw, struct rte_dev_reg_info *regs) { int opcode_num = RTE_DIM(hns3_dfx_reg_opcode_list); - uint32_t max_bd_num, bd_num, opcode; + uint32_t max_bd_num, bd_num, opcode, regs_num; uint32_t bd_num_list[opcode_num]; struct hns3_cmd_desc *cmd_descs; - uint32_t *reg_val = (uint32_t *)*data; + uint32_t *data = regs->data; int ret; int i; @@ -447,42 +1269,47 @@ hns3_get_dfx_regs(struct hns3_hw *hw, void **data) ret = hns3_dfx_reg_cmd_send(hw, cmd_descs, bd_num, opcode); if (ret) break; - reg_val += hns3_dfx_reg_fetch_data(cmd_descs, bd_num, reg_val); + + data += regs->length; + regs_num = hns3_dfx_reg_fetch_data(cmd_descs, bd_num, data); + hns3_fill_dfx_regs_name(hw, regs, hns3_reg_lists[i].reg_list, regs_num); + regs->length += regs_num; } rte_free(cmd_descs); - *data = (void *)reg_val; return ret; } static int -hns3_get_regs_from_firmware(struct hns3_hw *hw, uint32_t *data) +hns3_get_regs_from_firmware(struct hns3_hw *hw, struct rte_dev_reg_info *regs) { + struct hns3_adapter *hns = HNS3_DEV_HW_TO_ADAPTER(hw); uint32_t regs_num_32_bit; uint32_t regs_num_64_bit; int ret; + if (hns->is_vf) + return 0; + ret = hns3_get_regs_num(hw, ®s_num_32_bit, ®s_num_64_bit); if (ret) { hns3_err(hw, "Get register number failed, ret = %d", ret); return ret; } - ret = hns3_get_32_bit_regs(hw, regs_num_32_bit, data); + ret = hns3_get_32_bit_regs(hw, regs_num_32_bit, regs); if (ret) { hns3_err(hw, "Get 32 bit register failed, ret = %d", ret); return ret; } - data += regs_num_32_bit; - ret = hns3_get_64_bit_regs(hw, regs_num_64_bit, data); + ret = hns3_get_64_bit_regs(hw, regs_num_64_bit, regs); if (ret) { hns3_err(hw, "Get 64 bit register failed, ret = %d", ret); return ret; } - data += regs_num_64_bit * HNS3_64_BIT_REG_OUTPUT_SIZE; - return hns3_get_dfx_regs(hw, (void **)&data); + return hns3_get_dfx_regs(hw, regs); } int @@ -491,15 +1318,13 @@ hns3_get_regs(struct rte_eth_dev *eth_dev, struct rte_dev_reg_info *regs) struct hns3_adapter *hns = eth_dev->data->dev_private; struct hns3_hw *hw = &hns->hw; uint32_t length; - uint32_t *data; int ret; ret = hns3_get_regs_length(hw, &length); if (ret) return ret; - data = regs->data; - if (data == NULL) { + if (regs->data == NULL) { regs->length = length; regs->width = sizeof(uint32_t); return 0; @@ -510,13 +1335,12 @@ hns3_get_regs(struct rte_eth_dev *eth_dev, struct rte_dev_reg_info *regs) return -ENOTSUP; regs->version = hw->fw_version; + /* to count the number of filled registers */ + regs->length = 0; /* fetching per-PF registers values from PF PCIe register space */ - data += hns3_direct_access_regs(hw, data); - - if (hns->is_vf) - return 0; + hns3_direct_access_regs(hw, regs); /* fetching PF common registers values from firmware */ - return hns3_get_regs_from_firmware(hw, data); + return hns3_get_regs_from_firmware(hw, regs); }