From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mails.dpdk.org (mails.dpdk.org [217.70.189.124]) by inbox.dpdk.org (Postfix) with ESMTP id D430EA0524 for ; Fri, 5 Feb 2021 12:34:22 +0100 (CET) Received: from [217.70.189.124] (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id CE46E188A12; Fri, 5 Feb 2021 12:34:22 +0100 (CET) Received: from mail-wr1-f47.google.com (mail-wr1-f47.google.com [209.85.221.47]) by mails.dpdk.org (Postfix) with ESMTP id 15D2440682 for ; Fri, 5 Feb 2021 12:34:21 +0100 (CET) Received: by mail-wr1-f47.google.com with SMTP id c4so7271813wru.9 for ; Fri, 05 Feb 2021 03:34:21 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=oAIR4kLUw4g8JNYR2Y0iw1audOL01DrP0ZrvVLaFPz4=; b=jLWrfVBstIpzCQ04piAEbjcQFCS3maidrAS1EW990DLiuSNDG89G7gQy4UBChes+OY IpNWD0tzBOvbpfo4yYmijIdQq8JXbNJxWZA2RPx4byCQEZ8pP7INKE/Tu0XGDgwIb32e gF7bx3ihu+esfsP6RKMbC3e+UGXyTREMtzhHtnP2ONIUIpS6Dz+o7f2dqrEmnMiiDvmH I4mcZ5Pvz3FYZaVnflNU7V60DjSNjZ2Hs75JbVvMnq8K53UIjRbjzhTiw2epcHcuJplg eso4diGwQDHKBkq5p2MqiYWNGObeycScA1dvHPLU/yy+6TvyaNJ8vwJn37QDk7Enba2X 52aA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=oAIR4kLUw4g8JNYR2Y0iw1audOL01DrP0ZrvVLaFPz4=; b=rwGgtTBVKufWbhn+jCP1pp8y4SHfSkUO1rYi1JSseJWOer8C6AMBu61zYxGkAeX6Ck n6vqdIRnOtX+om4cVUbvBGLhMTJOGN72YkIMbK0gt5jXQkv1rzlDRvjzzR6b2gGf/9TT qJVUiWqsuFSC6cdt5GZQAdSDtOj3sjUrwozw/CbKVsOdgyGMm05zI8dS37n8AiTls9bI I3CAULUTo43XVv/u13HwayDR3GowhCwOcLfkFvBEZW4T01Pf9rnEzDktIgw0hj6XkNBt AypJpldY3/VHjuTsubpqqpKfDijLLThuPTnw5uoBx1VHLaKafrHV0vxa4BeshtZHCpej Wiww== X-Gm-Message-State: AOAM531uD5sqPaO0x86Lj0etTNKjBIbjwKC+MkK+5td43dt1O3me/OS2 CrLvR7E7u9sSFce9Cjtal4I= X-Google-Smtp-Source: ABdhPJz/q6g9iQ4XKpmb9zIFOHOFyUMTW8fjkfGs9rvmIflT22guD069FfifYfzcyUwTiNJyZzDooA== X-Received: by 2002:a05:6000:1202:: with SMTP id e2mr4566182wrx.328.1612524860890; Fri, 05 Feb 2021 03:34:20 -0800 (PST) Received: from localhost ([88.98.246.218]) by smtp.gmail.com with ESMTPSA id a132sm8638506wmf.42.2021.02.05.03.34.20 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 05 Feb 2021 03:34:20 -0800 (PST) From: luca.boccassi@gmail.com To: Chengchang Tang Cc: Lijun Ou , dpdk stable Date: Fri, 5 Feb 2021 11:17:38 +0000 Message-Id: <20210205111920.1272063-172-luca.boccassi@gmail.com> X-Mailer: git-send-email 2.29.2 In-Reply-To: <20210205111920.1272063-1-luca.boccassi@gmail.com> References: <20210205111920.1272063-1-luca.boccassi@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Subject: [dpdk-stable] patch 'net/hns3: fix data overwriting during register dump' has been queued to stable release 20.11.1 X-BeenThere: stable@dpdk.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: patches for DPDK stable branches List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: stable-bounces@dpdk.org Sender: "stable" Hi, FYI, your patch has been queued to stable release 20.11.1 Note it hasn't been pushed to http://dpdk.org/browse/dpdk-stable yet. It will be pushed if I get no objections before 02/07/21. So please shout if anyone has objections. Also note that after the patch there's a diff of the upstream commit vs the patch applied to the branch. This will indicate if there was any rebasing needed to apply to the stable branch. If there were code changes for rebasing (ie: not only metadata diffs), please double check that the rebase was correctly done. Queued patches are on a temporary branch at: https://github.com/bluca/dpdk-stable This queued commit can be viewed at: https://github.com/bluca/dpdk-stable/commit/febf166092ad6a786641951356f3b594a4a39716 Thanks. Luca Boccassi --- >From febf166092ad6a786641951356f3b594a4a39716 Mon Sep 17 00:00:00 2001 From: Chengchang Tang Date: Thu, 14 Jan 2021 21:33:35 +0800 Subject: [PATCH] net/hns3: fix data overwriting during register dump [ upstream commit 6da903befad6a7da52ee6b80554f63bf74bb9ad1 ] The data pointer has not moved after BAR register dumped. This causes the later register to overwrite the previous data. This patch fix the overwriting by move the pointer after every dump function. And the missing separator between 32-bit register and the 64-bit register is also added to avoid a parsing error. Fixes: 936eda25e8da ("net/hns3: support dump register") Signed-off-by: Chengchang Tang Signed-off-by: Lijun Ou --- drivers/net/hns3/hns3_regs.c | 70 ++++++++++++++++++++---------------- 1 file changed, 40 insertions(+), 30 deletions(-) diff --git a/drivers/net/hns3/hns3_regs.c b/drivers/net/hns3/hns3_regs.c index 32597fe21c..775e0965f7 100644 --- a/drivers/net/hns3/hns3_regs.c +++ b/drivers/net/hns3/hns3_regs.c @@ -252,63 +252,68 @@ hns3_get_64_bit_regs(struct hns3_hw *hw, uint32_t regs_num, void *data) return 0; } -static void +static int +hns3_insert_reg_separator(int reg_num, uint32_t *data) +{ + int separator_num; + int i; + + separator_num = MAX_SEPARATE_NUM - reg_num % REG_NUM_PER_LINE; + for (i = 0; i < separator_num; i++) + *data++ = SEPARATOR_VALUE; + return separator_num; +} + +static int hns3_direct_access_regs(struct hns3_hw *hw, uint32_t *data) { struct hns3_adapter *hns = HNS3_DEV_HW_TO_ADAPTER(hw); + uint32_t *origin_data_ptr = data; uint32_t reg_offset; - int separator_num; - int reg_um; + int reg_num; int i, j; /* fetching per-PF registers values from PF PCIe register space */ - reg_um = sizeof(cmdq_reg_addrs) / sizeof(uint32_t); - separator_num = MAX_SEPARATE_NUM - reg_um % REG_NUM_PER_LINE; - for (i = 0; i < reg_um; i++) + 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]); - for (i = 0; i < separator_num; i++) - *data++ = SEPARATOR_VALUE; + data += hns3_insert_reg_separator(reg_num, data); if (hns->is_vf) - reg_um = sizeof(common_vf_reg_addrs) / sizeof(uint32_t); + reg_num = sizeof(common_vf_reg_addrs) / sizeof(uint32_t); else - reg_um = sizeof(common_reg_addrs) / sizeof(uint32_t); - separator_num = MAX_SEPARATE_NUM - reg_um % REG_NUM_PER_LINE; - for (i = 0; i < reg_um; i++) + 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]); - for (i = 0; i < separator_num; i++) - *data++ = SEPARATOR_VALUE; + data += hns3_insert_reg_separator(reg_num, data); - reg_um = sizeof(ring_reg_addrs) / sizeof(uint32_t); - separator_num = MAX_SEPARATE_NUM - reg_um % REG_NUM_PER_LINE; + 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_um; i++) + for (i = 0; i < reg_num; i++) *data++ = hns3_read_dev(hw, ring_reg_addrs[i] + reg_offset); - for (i = 0; i < separator_num; i++) - *data++ = SEPARATOR_VALUE; + data += hns3_insert_reg_separator(reg_num, data); } - reg_um = sizeof(tqp_intr_reg_addrs) / sizeof(uint32_t); - separator_num = MAX_SEPARATE_NUM - reg_um % REG_NUM_PER_LINE; + reg_num = sizeof(tqp_intr_reg_addrs) / sizeof(uint32_t); for (j = 0; j < hw->num_msi; j++) { reg_offset = HNS3_TQP_INTR_REG_SIZE * j; - for (i = 0; i < reg_um; i++) - *data++ = hns3_read_dev(hw, - tqp_intr_reg_addrs[i] + + for (i = 0; i < reg_num; i++) + *data++ = hns3_read_dev(hw, tqp_intr_reg_addrs[i] + reg_offset); - for (i = 0; i < separator_num; i++) - *data++ = SEPARATOR_VALUE; + data += hns3_insert_reg_separator(reg_num, data); } + return data - origin_data_ptr; } int hns3_get_regs(struct rte_eth_dev *eth_dev, struct rte_dev_reg_info *regs) { +#define HNS3_64_BIT_REG_SIZE (sizeof(uint64_t) / sizeof(uint32_t)) struct hns3_adapter *hns = eth_dev->data->dev_private; struct hns3_hw *hw = &hns->hw; uint32_t regs_num_32_bit; @@ -338,7 +343,7 @@ hns3_get_regs(struct rte_eth_dev *eth_dev, struct rte_dev_reg_info *regs) return -ENOTSUP; /* fetching per-PF registers values from PF PCIe register space */ - hns3_direct_access_regs(hw, data); + data += hns3_direct_access_regs(hw, data); if (hns->is_vf) return 0; @@ -355,11 +360,16 @@ hns3_get_regs(struct rte_eth_dev *eth_dev, struct rte_dev_reg_info *regs) hns3_err(hw, "Get 32 bit register failed, ret = %d", ret); return ret; } - data += regs_num_32_bit; + data += hns3_insert_reg_separator(regs_num_32_bit, data); + ret = hns3_get_64_bit_regs(hw, regs_num_64_bit, data); - if (ret) + if (ret) { hns3_err(hw, "Get 64 bit register failed, ret = %d", ret); - + return ret; + } + data += regs_num_64_bit * HNS3_64_BIT_REG_SIZE; + data += hns3_insert_reg_separator(regs_num_64_bit * + HNS3_64_BIT_REG_SIZE, data); return ret; } -- 2.29.2 --- Diff of the applied patch vs upstream commit (please double-check if non-empty: --- --- - 2021-02-05 11:18:36.951437534 +0000 +++ 0172-net-hns3-fix-data-overwriting-during-register-dump.patch 2021-02-05 11:18:29.130697280 +0000 @@ -1 +1 @@ -From 6da903befad6a7da52ee6b80554f63bf74bb9ad1 Mon Sep 17 00:00:00 2001 +From febf166092ad6a786641951356f3b594a4a39716 Mon Sep 17 00:00:00 2001 @@ -5,0 +6,2 @@ +[ upstream commit 6da903befad6a7da52ee6b80554f63bf74bb9ad1 ] + @@ -14 +15,0 @@ -Cc: stable@dpdk.org