From patchwork Wed Oct 17 07:27:29 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Raslan Darawsheh X-Patchwork-Id: 46945 X-Patchwork-Delegate: ferruh.yigit@amd.com Return-Path: X-Original-To: patchwork@dpdk.org Delivered-To: patchwork@dpdk.org Received: from [92.243.14.124] (localhost [127.0.0.1]) by dpdk.org (Postfix) with ESMTP id 662E65F65; Wed, 17 Oct 2018 09:27:46 +0200 (CEST) Received: from EUR01-VE1-obe.outbound.protection.outlook.com (mail-ve1eur01on0041.outbound.protection.outlook.com [104.47.1.41]) by dpdk.org (Postfix) with ESMTP id 903255F4D for ; Wed, 17 Oct 2018 09:27:44 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=Mellanox.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=iE367GY2uGyFml2YHWLaj7lAEoHEZtu3G2NEaWQ1bEc=; b=AAR//Ae7At2lPDD/aWZ2yYADs4PZ2WBId69ZKn8xjJsGyE6Ebs1wksJ2WRD4aR8XA0WfTfydl4NXX7mpXUbMng15v9PC7wnINS3za6SUcgO94T33UrsN3N9W58fUMqRESvR2rpc5Rc1Bb9eiEFuDpuxP4CuWiMjjfC2qvXNId+s= Authentication-Results: spf=none (sender IP is ) smtp.mailfrom=rasland@mellanox.com; Received: from mellanox.com (37.142.13.130) by DB5PR05MB1253.eurprd05.prod.outlook.com (2a01:111:e400:51cb::14) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.1228.23; Wed, 17 Oct 2018 07:27:40 +0000 From: Raslan Darawsheh To: jingjing.wu@intel.com Cc: thomas@monjalon.net, dev@dpdk.org, shahafs@mellanox.com, rasland@mellanox.com, xuemingl@mellanox.com, orika@mellanox.com, jerin.jacob@caviumnetworks.com, david.marchand@6wind.com, bernard.iremonger@intel.com, ferruh.yigit@intel.com Date: Wed, 17 Oct 2018 10:27:29 +0300 Message-Id: <1539761251-7677-1-git-send-email-rasland@mellanox.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1538897848-1693-1-git-send-email-rasland@mellanox.com> References: <1538897848-1693-1-git-send-email-rasland@mellanox.com> MIME-Version: 1.0 X-Originating-IP: [37.142.13.130] X-ClientProxiedBy: CWLP265CA0322.GBRP265.PROD.OUTLOOK.COM (2603:10a6:401:57::22) To DB5PR05MB1253.eurprd05.prod.outlook.com (2a01:111:e400:51cb::14) X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 5a3267f7-e1cf-4210-65f0-08d6340205dd X-MS-Office365-Filtering-HT: Tenant X-Microsoft-Antispam: BCL:0; PCL:0; RULEID:(7020095)(4652040)(8989299)(4534185)(4627221)(201703031133081)(201702281549075)(8990200)(5600074)(711020)(4618075)(2017052603328)(7153060)(7193020); SRVR:DB5PR05MB1253; X-Microsoft-Exchange-Diagnostics: 1; DB5PR05MB1253; 3:icLfWFeNH0cYdT0GhmPjgkhlTXrKbq0qj9wn12B56pQT1D+Jb6xkhKiVHqrzRlvEFysy4VT0wbLlc/c4iZ/A/DQcJBZsNUX8XzpS27oUg/Nlw/XxQNJ94pP5E8mstXuKqedyYi7TwDJPUDSpjl8ZdolSTFJWgwjr0tSlYSXI9UiJKNxeyw+hwpArY22cx+rnsO0maJujy22SMZfoUeXydYolI2Dd8tyPLqh/2wRntWEafmIMNJ4vUQRXGy9UGOx7; 25:zKvRQWJSz5ZGu9aGJ88++WfLJ6jN5uWhRNrmorK3crXXWMw3ZXrELPwpafUHHkTjzIm+kWBQAgKK6x6UB5UC7M37SmbfXzRITHpw0Mm0JKkgBcJEfhfM+KHZ6F8dN/qdoEdegGsIwlxYZUCTirrjJVQ3KBHQp+dpJKknQm/T+gNjZ2f7F52qd3iM9c7blAxDrjWS3HiNIap+wE+ws6RIO+mP4fbwXnZ258kTdkQ/kmGUpLhYckCkZagDkVIN8Vnn/jJivl8aAbWPdWsvDx0r6PehM7Zxa5wgXNTPcWo8YGSfvAKUhjMgnf3XzNuAMj2qbKsFd0kQ93aSp85hMWnPHFXAvLeT1wF9ytqwSnKr4zo=; 31:6YlwpS/fo+4YshZvdxfe68j1A9zZey/Cq2X0NJ4uOaMw/0iOSrVc8lUBRd3fQ/aUl0T6nbdUaefFe0DnZB5AeQSF3HZnZRRLYBTvdEJpK2aobAwCebd44FH3M3UGwq3ariDFxRcoLIGYPWponCLcAoZ+3E9+AiDPPaZMCg+epQFbnxuIBfKAySwQBsoCyDUcASCAGm9Y80pULzchDAj/467hRliOlw/T/NRM/Rp/d/w= X-MS-TrafficTypeDiagnostic: DB5PR05MB1253: X-LD-Processed: a652971c-7d2e-4d9b-a6a4-d149256f461b,ExtAddr X-Microsoft-Exchange-Diagnostics: 1; DB5PR05MB1253; 20:MhUNK795BDckunKaGiYqAf003vJisoS7+MVMvw7CQLrZ/Dk1jf7R42zwG8N6+r9Zkn3ypISYudIvklbVkafhnru55y24MWae9jULmX+nQ8Sx5vY/FyMOlJdVGti3+fhRtcKrnHivYLRbqZrThTP87KoSSU1RkhGcl4SaMv1THrM0fNDH4f1mfoC+CFpsGfW+lX2Ht8PS2YRrsJYBXAR7LlmpAXwJCAKcEtDIMmRqZXROIzz0lsofhcKj6/IyBrw6QI9Nzdo+oB0vxkbKSxbwTbGe/IZkm0ZOJnlThFL8qeL4361hZR+YOiGIoHjL4X9h4Nk6yCHCIv3RnZ2LEGANBlEmLcrUhSorHceZlcvkdenSq88a76meZw1Piiqsg1ASfnDNHGj9fdir2d9k6qYENXQ/g6+H2EzRBTfWfUr5SKFVkfSjPKIAwvm5BksDCEL6WvpNlnN6hZ5FNBAHCRCUNirKhfeyygcm9WSQ17ndVs/Lr2LLIsRzDns0U+KPuU4G; 4:cjZbIf3Ya3YtQs+dfFroD2DIhKymJJyl0vbjHYsLRXo9R3Npcx7MUqe9qGrrN4/MH43nYoGBzYDxvlcxy6Ed1GaGGp3MbRzozcBdBTZ3k1LIcKy9TYyVjJmIYMugnlwevJKqRxBNVlvXAlSIdLehzbfuZFp+xgibjB5lYQkxQJrVO8mubmHYMNdxm46BYKUH4+jDlpW0luE3DWN/3scnI46FBU17ZPelta7dupdm8PHwsmz5KC9L2mvYHmAy6Z7Kekggkr5mYLKVhPlmzA61e9/vy+Tp4IorF0oOAm7/MgdaK6kzmfUoCn7owTT5/vps X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:(228905959029699); X-MS-Exchange-SenderADCheck: 1 X-Exchange-Antispam-Report-CFA-Test: BCL:0; PCL:0; RULEID:(8211001083)(6040522)(2401047)(8121501046)(5005006)(3002001)(3231355)(944501410)(52105095)(10201501046)(93006095)(93001095)(6055026)(149066)(150057)(6041310)(20161123560045)(201703131423095)(201702281528075)(20161123555045)(201703061421075)(201703061406153)(20161123564045)(20161123558120)(20161123562045)(201708071742011)(7699051)(76991095); SRVR:DB5PR05MB1253; BCL:0; PCL:0; RULEID:; SRVR:DB5PR05MB1253; X-Forefront-PRVS: 08286A0BE2 X-Forefront-Antispam-Report: SFV:NSPM; SFS:(10009020)(396003)(346002)(136003)(39860400002)(376002)(366004)(199004)(189003)(33026002)(476003)(97736004)(50466002)(48376002)(55016002)(50226002)(16586007)(4744004)(11346002)(21086003)(105586002)(36756003)(3846002)(106356001)(6116002)(446003)(2616005)(956004)(68736007)(69596002)(316002)(4326008)(2361001)(2351001)(7736002)(6666004)(53936002)(47776003)(25786009)(305945005)(66066001)(486006)(186003)(7696005)(52116002)(16526019)(81156014)(2906002)(26005)(8886007)(8676002)(86362001)(5660300001)(575784001)(386003)(81166006)(478600001)(6916009)(76176011)(8936002)(51416003); DIR:OUT; SFP:1101; SCL:1; SRVR:DB5PR05MB1253; H:mellanox.com; FPR:; SPF:None; LANG:en; PTR:InfoNoRecords; A:1; MX:1; Received-SPF: None (protection.outlook.com: mellanox.com does not designate permitted sender hosts) X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; DB5PR05MB1253; 23:F+2WJQLUet75M+R7FScLfBBvd67BsupZv+p8yEVtm?= C8J0wD784VfCQDGOvgwOTdHZWiwut2wjKdIBsUdSX9zP0y/v7xpcoOqjweoo4WZIx+kbfWhyNehx4AvGPbOii6qrWSHtCLwKKSRM2n8gQRI1u9YbiRQLKETzD8eKJGyN7YFZ40II3oa7We8vchxdoCIVEkkmHZkqWdx45KB5z3JtXv/ONryJKgjFKCdKeByKQYhuf0t0dGfshfuKpRuiVKmSPQrFy2yKKjDsLr6qOivqvR1Fu13hFlxt4i+muc3BL4fen8iDuM0xr6szM9XZN7Wt0ySKmUKRPqUSEyVDhOjw3+Wenp12Ub/NsxBq0sQ+7uOkWrfvfxew9YDsF/80Ot23qaKcfzwRGZ/bpXsmMAabdeG2Q01cQGsS4DqfuQOtrYoqBzRpkSMyUoorzRzRnsP4ewRgDobLv4wrSpXIZ3uz/x//sOweRwf7vcxWQHJIRhOAgLlsSbXmNQEPm3TH1T0QLsbvAg/mWaZNJ6Qo48NIU6JgvJHYq557H1zuOywabVBAkwIS2CeKu6Vzm7q5sOXqWw2fn2aovero0eoAB4eb2weAzTpC/DnBjgFr1g+BlMCkTrvitbwFBPFfSd1jeuw824IQP+f34wsWqUmZDY8sTbPkxzwgVnfpMVYTwL3f5tnNeLxtDCjd8GGvyFnYQSU+gCm/hpFSZylkpGZkYgQIh+0H+BQPVirKrLFecw35iHjNeJXdyzytR6e83BlKeXMvanzRhSsHGjL0ZG2yjnFKDJNaK5K8GiJUts9W//FnbtQkze/QVwZYz/WMwy7Nmdn9/VFhdmMoB0hEP8u1CxpzU0Ghjn/Bkm8ymMsXKAruU3MWQ9pRixGwYj0YWJ9njj8inKxS+k8zY3jg48+qGOzy9BcUScu5wwY+OGZcpHuVZM57XLjwshLrujb8AKVt/QtogWV8lFf61db33tKqzc+d2aEsxnt56VADStHX0bwaAHzqXExF3T8yKrruVclDLyqQnQh1GrfrBZ6oauUwJWPFw04K8hUBCxLWuriSmQPAo9tVUxUJVGanaiJkF7hYVPr1jOwt4tpVAPrYYCdHMmxOvPbPKQfGTcndDz3Smz6Ix6X02q/MyGB/A8AaAY1OA0j+GlA6bYbQN3IRvgZc3GSSS2mSduwVAxqnTHciKv6w0JVgTeJFon+RPEj9tLg4RbZ0TipI44Th8mzLgRNy4joelxm0qd1LTEkHMIWfmBxOXRiW7NH3DUuuFEIR2G/K6AJoSbHIjoVpUMu7eOtwpzkoKpkElHSasoXJ5NFrljE2fA= X-Microsoft-Antispam-Message-Info: nYrJUp7jlCFRWSPIBC6K7DJC7tuzSh+O7JS9LXHPn9T4nc+KVtA8u5BbB0EBLaWAstx0ITk0rWRLEFFiiDc5kN5HvNmPt2M7j086nU4B1GTNc30Y9QmiU87GWOurWDY/X5g4wolFrSBJL4+GyrjdDXSr+Mt8tTM7bfxhWJqYpjcG+vULu6kQ+eXK0p1KmWMjjATLApGUT2QYSiWcCZCcrfJx0r35KKa6ZZESYDj6rA7aCL3jImA/+XYhate6HwBpvkBEK6VSCgYX5FPWd9hI9EwYfOUs4tWyztL3pssm4PmWrCGtqsG+AFvBJzZPGT8XaZyItqEJT6XUtx+aF4TCToPGGmhrGDqmpjuBLameQQk= X-Microsoft-Exchange-Diagnostics: 1; DB5PR05MB1253; 6:ToOY4me8dOnsEZhD/p5C1Gj30ErOz2nkfsDRnt+h0Bn1Zs8w3UxXiyWBFLh1jGS2QWBl0DaK/a53FeOpj8SPlcioeRkkS7tjvI+FuN6otc84zYP8pEuK+rKkoGcek0HdQU+2EkVD9dUZtVqBfZU02ycoXz/73vfQr8Oso7KkvP5t5+kB3PTj8AkATcnu+oKX1ySzLtYYPY9qg3B/mrCEOIbN1EtZIi/fqUoNek7OJNmeAChwRuah8Qql5vXtNV8KiDVHhUkAPj2iIPYy1UtDeU2ZmLr8h9d6gEaRevjLFTLN+4AxB6CANs4FuphcXTpBePfq6eq2I+sVwPWA2+hUvr/KMMKpuTPxDcATU7o3wFcA+1h2lvIOH06lwxAihB56Ze01MpKFreOhS8XAMxRAc98dkLhAfY99FebVXkxkpA2zg6Xe/ekM6uQ5OSHL2ZktP7s74EsGT4ypj484FfZN7A==; 5:fSrANlRdc4Cn3qBiKmoAEi98fVPGKbyn/UB10EjEFJ0yGFLfKWmoG12N2Lnr6lj7wKeVqv4KqWccGZjl+bu8vdqVe64b5NZ/a8oWWz36Fbh8XnJQ1/WL787dG6fJQGCAqaPW1lv4cPnbA2yyKytaw7OVytiSNiGRHS2DFsO5SS4=; 7:0OnTEMqul1WFavufHn/AWn+Kaqyh5XJ/KtZ9fP9dTjHeRLlPlIXvHdlUNUVi1VFT1b4gF4mLz9bviwbQFO5nauTUDY9x5OVrgF4zG4yUaun1METkhdd+CYCDSgHTIR3zBUEAxEpjSxEngQ2nmxp6DkXxsO7DGrhtlNFhPILejK2JhF+ZOnLPLWwzqCWQAIPDu0Gis1Y02D6qnr3af0svqGknllZz21bA+LuGr3yLE4aYkpOAT9yF2oPN5fAX/QEi SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-OriginatorOrg: Mellanox.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 17 Oct 2018 07:27:40.1819 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 5a3267f7-e1cf-4210-65f0-08d6340205dd X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: a652971c-7d2e-4d9b-a6a4-d149256f461b X-MS-Exchange-Transport-CrossTenantHeadersStamped: DB5PR05MB1253 Subject: [dpdk-dev] [PATCH v5 1/3] app/testpmd: move dumping packets to a separate function X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Sender: "dev" verbosity for the received/sent packets is needed in all of the forwarding engines so moving it to be in a separate function Acked-by: Bernard Iremonger Signed-off-by: Raslan Darawsheh --- changes in v5: fix alligning convention fix copyright --- --- app/test-pmd/Makefile | 1 + app/test-pmd/meson.build | 3 +- app/test-pmd/rxonly.c | 134 +---------------------------------------- app/test-pmd/util.c | 151 +++++++++++++++++++++++++++++++++++++++++++++++ 4 files changed, 157 insertions(+), 132 deletions(-) create mode 100644 app/test-pmd/util.c diff --git a/app/test-pmd/Makefile b/app/test-pmd/Makefile index e2581ca..8e4ff5b 100644 --- a/app/test-pmd/Makefile +++ b/app/test-pmd/Makefile @@ -36,6 +36,7 @@ SRCS-y += icmpecho.c SRCS-y += noisy_vnf.c SRCS-$(CONFIG_RTE_LIBRTE_IEEE1588) += ieee1588fwd.c SRCS-$(CONFIG_RTE_LIBRTE_BPF) += bpf_cmd.c +SRCS-y += util.c ifeq ($(CONFIG_RTE_LIBRTE_PMD_SOFTNIC), y) SRCS-y += softnicfwd.c diff --git a/app/test-pmd/meson.build b/app/test-pmd/meson.build index 9ef6ed9..cd66618 100644 --- a/app/test-pmd/meson.build +++ b/app/test-pmd/meson.build @@ -21,7 +21,8 @@ sources = files('cmdline.c', 'parameters.c', 'rxonly.c', 'testpmd.c', - 'txonly.c') + 'txonly.c', + 'util.c') deps = ['ethdev', 'gro', 'gso', 'cmdline', 'metrics', 'meter', 'bus_pci'] if dpdk_conf.has('RTE_LIBRTE_PDUMP') diff --git a/app/test-pmd/rxonly.c b/app/test-pmd/rxonly.c index 41db0ff..3eca89c 100644 --- a/app/test-pmd/rxonly.c +++ b/app/test-pmd/rxonly.c @@ -40,14 +40,6 @@ #include "testpmd.h" -static inline void -print_ether_addr(const char *what, struct ether_addr *eth_addr) -{ - char buf[ETHER_ADDR_FMT_SIZE]; - ether_format_addr(buf, ETHER_ADDR_FMT_SIZE, eth_addr); - printf("%s%s", what, buf); -} - /* * Received a burst of packets. */ @@ -55,16 +47,8 @@ static void pkt_burst_receive(struct fwd_stream *fs) { struct rte_mbuf *pkts_burst[MAX_PKT_BURST]; - struct rte_mbuf *mb; - struct ether_hdr *eth_hdr; - uint16_t eth_type; - uint64_t ol_flags; uint16_t nb_rx; - uint16_t i, packet_type; - uint16_t is_encapsulation; - char buf[256]; - struct rte_net_hdr_lens hdr_lens; - uint32_t sw_packet_type; + uint16_t i; #ifdef RTE_TEST_PMD_RECORD_CORE_CYCLES uint64_t start_tsc; @@ -90,120 +74,8 @@ pkt_burst_receive(struct fwd_stream *fs) /* * Dump each received packet if verbose_level > 0. */ - if (verbose_level > 0) - printf("port %u/queue %u: received %u packets\n", - fs->rx_port, - (unsigned) fs->rx_queue, - (unsigned) nb_rx); - for (i = 0; i < nb_rx; i++) { - mb = pkts_burst[i]; - if (verbose_level == 0) { - rte_pktmbuf_free(mb); - continue; - } - eth_hdr = rte_pktmbuf_mtod(mb, struct ether_hdr *); - eth_type = RTE_BE_TO_CPU_16(eth_hdr->ether_type); - ol_flags = mb->ol_flags; - packet_type = mb->packet_type; - is_encapsulation = RTE_ETH_IS_TUNNEL_PKT(packet_type); - - print_ether_addr(" src=", ð_hdr->s_addr); - print_ether_addr(" - dst=", ð_hdr->d_addr); - printf(" - type=0x%04x - length=%u - nb_segs=%d", - eth_type, (unsigned) mb->pkt_len, - (int)mb->nb_segs); - if (ol_flags & PKT_RX_RSS_HASH) { - printf(" - RSS hash=0x%x", (unsigned) mb->hash.rss); - printf(" - RSS queue=0x%x",(unsigned) fs->rx_queue); - } - if (ol_flags & PKT_RX_FDIR) { - printf(" - FDIR matched "); - if (ol_flags & PKT_RX_FDIR_ID) - printf("ID=0x%x", - mb->hash.fdir.hi); - else if (ol_flags & PKT_RX_FDIR_FLX) - printf("flex bytes=0x%08x %08x", - mb->hash.fdir.hi, mb->hash.fdir.lo); - else - printf("hash=0x%x ID=0x%x ", - mb->hash.fdir.hash, mb->hash.fdir.id); - } - if (ol_flags & PKT_RX_TIMESTAMP) - printf(" - timestamp %"PRIu64" ", mb->timestamp); - if (ol_flags & PKT_RX_QINQ) - printf(" - QinQ VLAN tci=0x%x, VLAN tci outer=0x%x", - mb->vlan_tci, mb->vlan_tci_outer); - else if (ol_flags & PKT_RX_VLAN) - printf(" - VLAN tci=0x%x", mb->vlan_tci); - if (mb->packet_type) { - rte_get_ptype_name(mb->packet_type, buf, sizeof(buf)); - printf(" - hw ptype: %s", buf); - } - sw_packet_type = rte_net_get_ptype(mb, &hdr_lens, - RTE_PTYPE_ALL_MASK); - rte_get_ptype_name(sw_packet_type, buf, sizeof(buf)); - printf(" - sw ptype: %s", buf); - if (sw_packet_type & RTE_PTYPE_L2_MASK) - printf(" - l2_len=%d", hdr_lens.l2_len); - if (sw_packet_type & RTE_PTYPE_L3_MASK) - printf(" - l3_len=%d", hdr_lens.l3_len); - if (sw_packet_type & RTE_PTYPE_L4_MASK) - printf(" - l4_len=%d", hdr_lens.l4_len); - if (sw_packet_type & RTE_PTYPE_TUNNEL_MASK) - printf(" - tunnel_len=%d", hdr_lens.tunnel_len); - if (sw_packet_type & RTE_PTYPE_INNER_L2_MASK) - printf(" - inner_l2_len=%d", hdr_lens.inner_l2_len); - if (sw_packet_type & RTE_PTYPE_INNER_L3_MASK) - printf(" - inner_l3_len=%d", hdr_lens.inner_l3_len); - if (sw_packet_type & RTE_PTYPE_INNER_L4_MASK) - printf(" - inner_l4_len=%d", hdr_lens.inner_l4_len); - if (is_encapsulation) { - struct ipv4_hdr *ipv4_hdr; - struct ipv6_hdr *ipv6_hdr; - struct udp_hdr *udp_hdr; - uint8_t l2_len; - uint8_t l3_len; - uint8_t l4_len; - uint8_t l4_proto; - struct vxlan_hdr *vxlan_hdr; - - l2_len = sizeof(struct ether_hdr); - - /* Do not support ipv4 option field */ - if (RTE_ETH_IS_IPV4_HDR(packet_type)) { - l3_len = sizeof(struct ipv4_hdr); - ipv4_hdr = rte_pktmbuf_mtod_offset(mb, - struct ipv4_hdr *, - l2_len); - l4_proto = ipv4_hdr->next_proto_id; - } else { - l3_len = sizeof(struct ipv6_hdr); - ipv6_hdr = rte_pktmbuf_mtod_offset(mb, - struct ipv6_hdr *, - l2_len); - l4_proto = ipv6_hdr->proto; - } - if (l4_proto == IPPROTO_UDP) { - udp_hdr = rte_pktmbuf_mtod_offset(mb, - struct udp_hdr *, - l2_len + l3_len); - l4_len = sizeof(struct udp_hdr); - vxlan_hdr = rte_pktmbuf_mtod_offset(mb, - struct vxlan_hdr *, - l2_len + l3_len + l4_len); - - printf(" - VXLAN packet: packet type =%d, " - "Destination UDP port =%d, VNI = %d", - packet_type, RTE_BE_TO_CPU_16(udp_hdr->dst_port), - rte_be_to_cpu_32(vxlan_hdr->vx_vni) >> 8); - } - } - printf(" - Receive queue=0x%x", (unsigned) fs->rx_queue); - printf("\n"); - rte_get_rx_ol_flag_list(mb->ol_flags, buf, sizeof(buf)); - printf(" ol_flags: %s\n", buf); - rte_pktmbuf_free(mb); - } + for (i = 0; i < nb_rx; i++) + rte_pktmbuf_free(pkts_burst[i]); #ifdef RTE_TEST_PMD_RECORD_CORE_CYCLES end_tsc = rte_rdtsc(); diff --git a/app/test-pmd/util.c b/app/test-pmd/util.c new file mode 100644 index 0000000..4fcb2f9 --- /dev/null +++ b/app/test-pmd/util.c @@ -0,0 +1,151 @@ +/* SPDX-License-Identifier: BSD-3-Clause + * Copyright(c) 2010-2014 Intel Corporation + * Copyright(c) 2018 Mellanox Technology + */ + +#include + +#include +#include +#include +#include +#include + +#include "testpmd.h" + +static inline void +print_ether_addr(const char *what, struct ether_addr *eth_addr) +{ + char buf[ETHER_ADDR_FMT_SIZE]; + ether_format_addr(buf, ETHER_ADDR_FMT_SIZE, eth_addr); + printf("%s%s", what, buf); +} + +static inline void +dump_pkt_burst(uint16_t port_id, uint16_t queue, struct rte_mbuf *pkts[], + uint16_t nb_pkts, int is_rx) +{ + struct rte_mbuf *mb; + struct ether_hdr *eth_hdr; + uint16_t eth_type; + uint64_t ol_flags; + uint16_t i, packet_type; + uint16_t is_encapsulation; + char buf[256]; + struct rte_net_hdr_lens hdr_lens; + uint32_t sw_packet_type; + uint16_t udp_port; + uint32_t vx_vni; + + if (!nb_pkts) + return; + printf("port %u/queue %u: %s %u packets\n", + port_id, queue, + is_rx ? "received" : "sent", + (unsigned int) nb_pkts); + for (i = 0; i < nb_pkts; i++) { + mb = pkts[i]; + eth_hdr = rte_pktmbuf_mtod(mb, struct ether_hdr *); + eth_type = RTE_BE_TO_CPU_16(eth_hdr->ether_type); + ol_flags = mb->ol_flags; + packet_type = mb->packet_type; + is_encapsulation = RTE_ETH_IS_TUNNEL_PKT(packet_type); + + print_ether_addr(" src=", ð_hdr->s_addr); + print_ether_addr(" - dst=", ð_hdr->d_addr); + printf(" - type=0x%04x - length=%u - nb_segs=%d", + eth_type, (unsigned int) mb->pkt_len, + (int)mb->nb_segs); + if (ol_flags & PKT_RX_RSS_HASH) { + printf(" - RSS hash=0x%x", (unsigned int) mb->hash.rss); + printf(" - RSS queue=0x%x", (unsigned int) queue); + } + if (ol_flags & PKT_RX_FDIR) { + printf(" - FDIR matched "); + if (ol_flags & PKT_RX_FDIR_ID) + printf("ID=0x%x", + mb->hash.fdir.hi); + else if (ol_flags & PKT_RX_FDIR_FLX) + printf("flex bytes=0x%08x %08x", + mb->hash.fdir.hi, mb->hash.fdir.lo); + else + printf("hash=0x%x ID=0x%x ", + mb->hash.fdir.hash, mb->hash.fdir.id); + } + if (ol_flags & PKT_RX_TIMESTAMP) + printf(" - timestamp %"PRIu64" ", mb->timestamp); + if (ol_flags & PKT_RX_QINQ) + printf(" - QinQ VLAN tci=0x%x, VLAN tci outer=0x%x", + mb->vlan_tci, mb->vlan_tci_outer); + else if (ol_flags & PKT_RX_VLAN) + printf(" - VLAN tci=0x%x", mb->vlan_tci); + if (mb->packet_type) { + rte_get_ptype_name(mb->packet_type, buf, sizeof(buf)); + printf(" - hw ptype: %s", buf); + } + sw_packet_type = rte_net_get_ptype(mb, &hdr_lens, + RTE_PTYPE_ALL_MASK); + rte_get_ptype_name(sw_packet_type, buf, sizeof(buf)); + printf(" - sw ptype: %s", buf); + if (sw_packet_type & RTE_PTYPE_L2_MASK) + printf(" - l2_len=%d", hdr_lens.l2_len); + if (sw_packet_type & RTE_PTYPE_L3_MASK) + printf(" - l3_len=%d", hdr_lens.l3_len); + if (sw_packet_type & RTE_PTYPE_L4_MASK) + printf(" - l4_len=%d", hdr_lens.l4_len); + if (sw_packet_type & RTE_PTYPE_TUNNEL_MASK) + printf(" - tunnel_len=%d", hdr_lens.tunnel_len); + if (sw_packet_type & RTE_PTYPE_INNER_L2_MASK) + printf(" - inner_l2_len=%d", hdr_lens.inner_l2_len); + if (sw_packet_type & RTE_PTYPE_INNER_L3_MASK) + printf(" - inner_l3_len=%d", hdr_lens.inner_l3_len); + if (sw_packet_type & RTE_PTYPE_INNER_L4_MASK) + printf(" - inner_l4_len=%d", hdr_lens.inner_l4_len); + if (is_encapsulation) { + struct ipv4_hdr *ipv4_hdr; + struct ipv6_hdr *ipv6_hdr; + struct udp_hdr *udp_hdr; + uint8_t l2_len; + uint8_t l3_len; + uint8_t l4_len; + uint8_t l4_proto; + struct vxlan_hdr *vxlan_hdr; + + l2_len = sizeof(struct ether_hdr); + + /* Do not support ipv4 option field */ + if (RTE_ETH_IS_IPV4_HDR(packet_type)) { + l3_len = sizeof(struct ipv4_hdr); + ipv4_hdr = rte_pktmbuf_mtod_offset(mb, + struct ipv4_hdr *, + l2_len); + l4_proto = ipv4_hdr->next_proto_id; + } else { + l3_len = sizeof(struct ipv6_hdr); + ipv6_hdr = rte_pktmbuf_mtod_offset(mb, + struct ipv6_hdr *, + l2_len); + l4_proto = ipv6_hdr->proto; + } + if (l4_proto == IPPROTO_UDP) { + udp_hdr = rte_pktmbuf_mtod_offset(mb, + struct udp_hdr *, + l2_len + l3_len); + l4_len = sizeof(struct udp_hdr); + vxlan_hdr = rte_pktmbuf_mtod_offset(mb, + struct vxlan_hdr *, + l2_len + l3_len + l4_len); + udp_port = RTE_BE_TO_CPU_16(udp_hdr->dst_port); + vx_vni = rte_be_to_cpu_32(vxlan_hdr->vx_vni); + printf(" - VXLAN packet: packet type =%d, " + "Destination UDP port =%d, VNI = %d", + packet_type, udp_port, vx_vni >> 8); + } + } + printf(" - %s queue=0x%x", is_rx ? "Receive" : "Send", + (unsigned int) queue); + printf("\n"); + rte_get_rx_ol_flag_list(mb->ol_flags, buf, sizeof(buf)); + printf(" ol_flags: %s\n", buf); + } +} From patchwork Wed Oct 17 07:27:30 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Raslan Darawsheh X-Patchwork-Id: 46946 X-Patchwork-Delegate: ferruh.yigit@amd.com Return-Path: X-Original-To: patchwork@dpdk.org Delivered-To: patchwork@dpdk.org Received: from [92.243.14.124] (localhost [127.0.0.1]) by dpdk.org (Postfix) with ESMTP id 9E13F6C9B; Wed, 17 Oct 2018 09:27:48 +0200 (CEST) Received: from EUR01-VE1-obe.outbound.protection.outlook.com (mail-ve1eur01on0041.outbound.protection.outlook.com [104.47.1.41]) by dpdk.org (Postfix) with ESMTP id 2073A5F65 for ; Wed, 17 Oct 2018 09:27:45 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=Mellanox.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=QrbrkqGo7G8iEqCbI1tCD6UIbllv+Dai+xjy479np1o=; b=a13Tbj/oy6+sAsLh0XJGe0RsguOyLge9dyvXEWKxAxcuEmaT6Y5UINv01x9F3pnDtj1ufN9l60PBk+dD1an7dN7qGQRNm0YE+6JmTb68lyY5OwFjuYt9w0dRsD8QkImSDJT8j3nssJpKRSSECwwOgdLg8wK6Y59Ka5mjiip7Fl8= Authentication-Results: spf=none (sender IP is ) smtp.mailfrom=rasland@mellanox.com; Received: from mellanox.com (37.142.13.130) by DB5PR05MB1253.eurprd05.prod.outlook.com (2a01:111:e400:51cb::14) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.1228.23; Wed, 17 Oct 2018 07:27:42 +0000 From: Raslan Darawsheh To: jingjing.wu@intel.com Cc: thomas@monjalon.net, dev@dpdk.org, shahafs@mellanox.com, rasland@mellanox.com, xuemingl@mellanox.com, orika@mellanox.com, jerin.jacob@caviumnetworks.com, david.marchand@6wind.com, bernard.iremonger@intel.com, ferruh.yigit@intel.com Date: Wed, 17 Oct 2018 10:27:30 +0300 Message-Id: <1539761251-7677-2-git-send-email-rasland@mellanox.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1539761251-7677-1-git-send-email-rasland@mellanox.com> References: <1538897848-1693-1-git-send-email-rasland@mellanox.com> <1539761251-7677-1-git-send-email-rasland@mellanox.com> MIME-Version: 1.0 X-Originating-IP: [37.142.13.130] X-ClientProxiedBy: CWLP265CA0322.GBRP265.PROD.OUTLOOK.COM (2603:10a6:401:57::22) To DB5PR05MB1253.eurprd05.prod.outlook.com (2a01:111:e400:51cb::14) X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 63707c58-7770-4cf2-3d98-08d634020729 X-MS-Office365-Filtering-HT: Tenant X-Microsoft-Antispam: BCL:0; PCL:0; RULEID:(7020095)(4652040)(8989299)(4534185)(4627221)(201703031133081)(201702281549075)(8990200)(5600074)(711020)(4618075)(2017052603328)(7153060)(7193020); SRVR:DB5PR05MB1253; X-Microsoft-Exchange-Diagnostics: 1; DB5PR05MB1253; 3:nRPfb5IL7P0/wZOglVxaJcUAdw1+NmC46V8twsWEdDF2UYydnIHgG9xk2tqpEH7XDO/Vi7GROW3jCZCjCernH1PLoIMQeBvfwAGG77qR03bbwFPag21u1rNWYMJORyaQsbbeMgha9om2/FSYJSBWikdFPt6tdvrNyiSLWLVrUqPy8dkhwf3I/T8NYcFn6zSScHWqkrei0ZJWMBBfniug3+AuUFSKPeIE3esaJbbODW1Ngor9FgELPFENvFAT7qwM; 25:0TDsQz4+g9iJ2FjcLiAXPl1JVo2m/kxY1HXolh7b7Ie4Skp+MNLmFYNMCIvg3zMhB8S03y3Xkxs7oazfuZ0S5Fv4KK3SQSsPStno4nzgHWwDcMkMTAcBMkdRgQ0dYK7jhOHD7Hl+XsI4k8vzhBFV4FZIB8RjWe1KnxgQhg0EwpHGpTp160pIw+1q8KqawzRH4Dd6JJ4+YtRX0U91Q8lKWhawhOAmbr4gvz9UvqCFw8M9y8j1HhQc19V0PqOEcKA/buODbtac1VE5TvabFbaanzzlaRf3zqM+YXp+7nyYe0gYd+lfc4IU2o/5mn3UU71wypE53Uht9xd/buSaW8ut3eYPGJH7tEpjUH1xjjIN0zY=; 31:gfZSJnOtVQ+6Kv/D9rmUL0g+ncQP3p52LXOpy1s/t2EXAxKRMqAXnqhZJsm2/GhWRwJSKl5illQ5SyL54Eb4cHJZBsvCKfQO4A6njpVJ1jJ2unPU6fUqwsZBxSOAKrIJ12xYj06KEh8/AMn6gk/D06vqXFpmZDLHuNKjzYJbhJpbG3HuZrs8SYHn6KQbPceONxS364X7l9/xjND+xW7Gp7438kcmhNCLV1pvYeIjrG8= X-MS-TrafficTypeDiagnostic: DB5PR05MB1253: X-LD-Processed: a652971c-7d2e-4d9b-a6a4-d149256f461b,ExtAddr X-Microsoft-Exchange-Diagnostics: 1; DB5PR05MB1253; 20:49Nu4fFUa4cECcWSJSfifOQXBWrJpUr05SlXsFr+xY3aIM22j/xTuH3zGfxuDcx2v8PIN12hyELw06rkjwRc2WA6bKeXHtRdy/bYTtb36WSHf2zaaB58XLnqt4wN/6DQIpPQosPEvAaiep7f65w+4VJeTnlAwgGx7Eo08p1afFJUSv2T+b9DqRlJNDcbflRdSXt2XmA0TGhLfnbgHtr4XAk+jvjRzPXb1ZYQVbV3QSgaa1jTgV60a7EdcUrUGgzV1ZfBewObaMz3neobco1nwFZ2Qj/NxG5X063MeAQf6JmwU3LlJZ2qMLyF+pcM3t6t/t+8WDtswZrkDQ+OFSZsZverSuiGr4QWLQDSDhK97ivT3Gowg96sSbLst1fp+FpCGWTAv6g9A5D+f6wgZWl/Rh9YWShOCyVEAku5ZBkQ8lcZDm/edUqvwUY7aDuAF7nt7gOMOs7iMhByvG8r+n6C4Rm1hXxo7MgtJwv37PbDYRTjG3UkLjItRFIzjLHQEsoT; 4:mzBzLsY0QUk1aJ6kjJ3PEM5Rbu/lb9TN6zukomJ8/50digJLL8i4kxlRCFtB766vuyPs/PBdhPfMXLedUIgKR09WP8SDXbSmJLGsDeRDKFf2l17wQrpmsNoxy0ey4HYarr+jL0mg4Y+noEj3Ur4BOB0vzvN1G+QY8mw4zmQXn65zx1Rrf3qfBWCHTX+UJm6Cw+nh0UIiUwAOqOISSa2CVKukyFP/RME0eXzqj2tDgaaCpGenBSnOvDb+PV8epfsOVJK6b3rEE1IjI1M3A4Dp9hc8aj5xXwGfClCse8hDlxeT38iwUJakYR+KYqtZRwsk X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:(228905959029699); X-MS-Exchange-SenderADCheck: 1 X-Exchange-Antispam-Report-CFA-Test: BCL:0; PCL:0; RULEID:(8211001083)(6040522)(2401047)(8121501046)(5005006)(3002001)(3231355)(944501410)(52105095)(10201501046)(93006095)(93001095)(6055026)(149066)(150057)(6041310)(20161123560045)(201703131423095)(201702281528075)(20161123555045)(201703061421075)(201703061406153)(20161123564045)(20161123558120)(20161123562045)(201708071742011)(7699051)(76991095); SRVR:DB5PR05MB1253; BCL:0; PCL:0; RULEID:; SRVR:DB5PR05MB1253; X-Forefront-PRVS: 08286A0BE2 X-Forefront-Antispam-Report: SFV:NSPM; SFS:(10009020)(396003)(346002)(136003)(39860400002)(376002)(366004)(199004)(189003)(33026002)(476003)(97736004)(50466002)(48376002)(55016002)(50226002)(16586007)(11346002)(21086003)(105586002)(36756003)(3846002)(106356001)(6116002)(446003)(2616005)(956004)(68736007)(69596002)(316002)(4326008)(2361001)(2351001)(7736002)(6666004)(53936002)(47776003)(25786009)(305945005)(66066001)(486006)(186003)(7696005)(52116002)(16526019)(81156014)(2906002)(26005)(8886007)(8676002)(86362001)(5660300001)(575784001)(386003)(81166006)(478600001)(6916009)(76176011)(8936002)(51416003); DIR:OUT; SFP:1101; SCL:1; SRVR:DB5PR05MB1253; H:mellanox.com; FPR:; SPF:None; LANG:en; PTR:InfoNoRecords; A:1; MX:1; Received-SPF: None (protection.outlook.com: mellanox.com does not designate permitted sender hosts) X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; DB5PR05MB1253; 23:Kmy3MtYd9kdKk4s12XzjdxldI/rs71NypmFseFJm2?= ntMLgPZs8XLmpa1v6ooIqKJpW2O2Kcz87knMSjpxZV/ocTpRK5K1shSiunTD/kCjduuXwXaFRPuFMiQkxmUJ+YkASK9olAucS9NdsO8gu57HATzVpu/I3BnlZnuHoTsjPTIMjuKCxNCwRy0TxLDbmHjwIzzXg9B6cKRSbPj5sBT3cfdhuUnq8IQ2BUXFfC/zXLWeRr67V84eEgFgulgAZqfgjruWRKTFcGQbMjczI7hI1/4ygjTTytpGy8822wM2kvoMymMXXDS+Zvfw4hHHvawWpH8F/xVevrMbI7YEOqRoGRYeJjeViYP8f1PeSlqTbOsZ+U/IUevrTbZXQI8gqaOy1hnI/EXuf4Opdbw2YGtJh85Mus+MrAYQlRbXdMs5uwyq0ZS+3l/+sceK93BD+KqL185bifFZVNq0D677/A2TqrOs3zTjL2UTGPgnrfdh1FnT5xkiGf1ygU9p44Ms/uu5QqF7fAP/kTs+x1gPOKWy3wSP4MjgIcTb+G2rH0uyGJR6OxQkeZ7E3i9+wopDHmTi1rOXvzL6pIJcQkFkkxzkNxZOkiUcMhGLCkcEAY8pY0hOHgjuNtKbT+vh5D3sxOwqNbuZA12upNs/C5wBTFL4gfmlm2BeZL8p9W+aKE5zbBUoT2SrRE1nXEnAzU3DZWSFXLAcxK6ypV0IStmSXrJVah3i2l7rqO34cvTAyyCHOd/n748YZx0g+OAdPcD2Qpt7UHCdvA1gHTsvvX3EgXy6QNDFk75cnx7qhniU3HcW4G346vH4TSILJXG63T3LsPT6IxJDcOxf89OR6af8u80glatZCNdDfc4RSa2raMABESozv/Koybty3KHTvo2OF3mKUlyP1QdnsHtwcVgvgILU7QjGrIhesbILsp12edBmZgpI2zUDzrKuTA/71Z7BmpbMp4oCrSjpzlupURP1Dd1FFA/KLEQrNjKatjS0vqfAKswu2l0c3jnyubQ3P8UPvl+DYnQu5dppNYVZmuNH9WBm7lLzG59HFua0OBCl4miWb94sK0PYdVheruM2dQ0oDs38NnAcLYRonxN2mpFOxcDmQ/wLyu8cIkaviIaDRQvid3loodVGrjyUeYx1WBA5Zb7MKsB48YlXESrmSuZWWkeS7c4qr71zqoaG6n14LK9fVLUa187YeYN5yFF7CCDxE4CvnFO9V4pV3bArp3R4tM+UseBIqn080ClW6EhDEIYVNVEUgooZPa0TZCsRtCpKmMbrzJWn2XT/EcNz2vOSxDhhg== X-Microsoft-Antispam-Message-Info: O/983u1h9lsa0qk2wOKMKma4YClAxxGUBRyQJfbTw1vnKHJizSaAOWmI9A+xjrj1WFLAKE+NG89CnIGC/s4N10kNWILLZ3QfH4fPDfc4Ud3SSJxu9a/qU2eb0qFzOR8IOJF+yAsqcmnOcLgcHcBzLAotyJvV5aZf8ARAOgopFXWQzvmqEWDHYW8tPIPTtJCp0wYHJYpPhn+/EI6IzUEkiTBpPZjuIvVO1UDSKJFtgSOAbS5n4dwCpATUyUn7WEmxLSON9MFW7SRDtcOo5x7GNcFNkjNlcKYuYXyVULjf+KZLPfwe1Dz7kIbgmPzl5SLpZn/ekZin+VXqMiKRQmghqr0cXgHO/22i+/qYRmsQgh4= X-Microsoft-Exchange-Diagnostics: 1; DB5PR05MB1253; 6:SUc30+nPb89+wkl4bO0hCOxFr1lXUBQVzPWd/Zwg13nlOKptQ5uWdZDb7U73iM6b62B8uvvnoRSpIqKwbeTG2EgvpMNchYZ1i6IX0LsqJAtCCJrtXGSICPkt+/ChfBpX0K79jJHm5rWffKxXSR9QhLVbeR8JLAb0EoSGcbwp79q+o5HU0ETayo1Wc3uyNVomsnae/mXUSPpIvKTSk41Pt4e0yZd9YEzjNEYOV7DeqrtwYNTTsTZSU0SKaDWj++6tXvRoro0CsRN6+9WTbgmP/nPnPFX9c3wsA11Ir1kMyH15cY+JWIjvlcaJ1vNqS1P5f7hdX1djYcM8sqTs8nkDijGta/6O2PgIEhEomK7IrV+EPJloqPC0i6yrvGYrG3icz62J3upApcNHUV+jJ9W7ngvNuQhxpvNftYt4bxo7sgYyRIeAhavdpJAfX9+wbUjrCwO50vurY8e+aLNCycVpaw==; 5:pnZHljrmC/9F7qH/TipuSKcW0QTWzyvBkKpfDGHGHfcN7gmsdSaXD5nXJvoQx/Dqx6mvmyvmn/lHyC9nsNOOMSUPAw3NpdfVT78JFliSCrsH6inQBic44xaOrbgu+kkTVLNGP2w3ErH58is9cWvG9Bc8OrpekeEMR6tWnpDTX1E=; 7:JhwVfF1jtqoV/dUXpAA+5z6+PoTcAn2oXnYu8BRvKxHdnw7AT4vZauUgJh6SnWEyupAp0pJwdI+pButmqYcTNtfPhgk8BFlPsOI42pq+Rg2PKnO0j3H5LVvIoWeMxL21bbKamsMIgYsz1oBYveO7lljSv0zJrfq1yqaPaip0szW7frFjRTSgECww/k0cfPbtM1uxbinKTt1FoON6PNfI3Bdd7a3n4JZAU6XPP0SQuzfboHZc5Uye0MRLUSfeeHmp SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-OriginatorOrg: Mellanox.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 17 Oct 2018 07:27:42.3617 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 63707c58-7770-4cf2-3d98-08d634020729 X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: a652971c-7d2e-4d9b-a6a4-d149256f461b X-MS-Exchange-Transport-CrossTenantHeadersStamped: DB5PR05MB1253 Subject: [dpdk-dev] [PATCH v5 2/3] app/testpmd: add packet dump callback functions X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Sender: "dev" add new rx/tx callback functions to be used for dumping the packets. Signed-off-by: Raslan Darawsheh Acked-by: Bernard Iremonger --- app/test-pmd/config.c | 67 ++++++++++++++++++++++++++++++++++++++++++++++++++ app/test-pmd/testpmd.h | 15 +++++++++++ app/test-pmd/util.c | 17 +++++++++++++ 3 files changed, 99 insertions(+) diff --git a/app/test-pmd/config.c b/app/test-pmd/config.c index bf3cd0a..431fa2a 100644 --- a/app/test-pmd/config.c +++ b/app/test-pmd/config.c @@ -2706,6 +2706,73 @@ set_pkt_forwarding_mode(const char *fwd_mode_name) } void +add_rx_dump_callbacks(portid_t portid) +{ + struct rte_eth_dev_info dev_info; + uint16_t queue; + + if (port_id_is_invalid(portid, ENABLED_WARN)) + return; + + rte_eth_dev_info_get(portid, &dev_info); + for (queue = 0; queue < dev_info.nb_rx_queues; queue++) + if (!ports[portid].rx_dump_cb[queue]) + ports[portid].rx_dump_cb[queue] = + rte_eth_add_rx_callback(portid, queue, + dump_rx_pkts, NULL); +} + +void +add_tx_dump_callbacks(portid_t portid) +{ + struct rte_eth_dev_info dev_info; + uint16_t queue; + + if (port_id_is_invalid(portid, ENABLED_WARN)) + return; + rte_eth_dev_info_get(portid, &dev_info); + for (queue = 0; queue < dev_info.nb_tx_queues; queue++) + if (!ports[portid].tx_dump_cb[queue]) + ports[portid].tx_dump_cb[queue] = + rte_eth_add_tx_callback(portid, queue, + dump_tx_pkts, NULL); +} + +void +remove_rx_dump_callbacks(portid_t portid) +{ + struct rte_eth_dev_info dev_info; + uint16_t queue; + + if (port_id_is_invalid(portid, ENABLED_WARN)) + return; + rte_eth_dev_info_get(portid, &dev_info); + for (queue = 0; queue < dev_info.nb_rx_queues; queue++) + if (ports[portid].rx_dump_cb[queue]) { + rte_eth_remove_rx_callback(portid, queue, + ports[portid].rx_dump_cb[queue]); + ports[portid].rx_dump_cb[queue] = NULL; + } +} + +void +remove_tx_dump_callbacks(portid_t portid) +{ + struct rte_eth_dev_info dev_info; + uint16_t queue; + + if (port_id_is_invalid(portid, ENABLED_WARN)) + return; + rte_eth_dev_info_get(portid, &dev_info); + for (queue = 0; queue < dev_info.nb_tx_queues; queue++) + if (ports[portid].tx_dump_cb[queue]) { + rte_eth_remove_tx_callback(portid, queue, + ports[portid].tx_dump_cb[queue]); + ports[portid].tx_dump_cb[queue] = NULL; + } +} + +void set_verbose_level(uint16_t vb_level) { printf("Change verbose level from %u to %u\n", diff --git a/app/test-pmd/testpmd.h b/app/test-pmd/testpmd.h index 121b756..0e923d7 100644 --- a/app/test-pmd/testpmd.h +++ b/app/test-pmd/testpmd.h @@ -191,6 +191,8 @@ struct rte_port { uint32_t mc_addr_nb; /**< nb. of addr. in mc_addr_pool */ uint8_t slave_flag; /**< bonding slave port */ struct port_flow *flow_list; /**< Associated flows. */ + const struct rte_eth_rxtx_callback *rx_dump_cb[MAX_QUEUE_ID+1]; + const struct rte_eth_rxtx_callback *tx_dump_cb[MAX_QUEUE_ID+1]; #ifdef SOFTNIC struct softnic_port softport; /**< softnic params */ #endif @@ -764,6 +766,19 @@ int check_nb_rxq(queueid_t rxq); queueid_t get_allowed_max_nb_txq(portid_t *pid); int check_nb_txq(queueid_t txq); + +uint16_t dump_rx_pkts(uint16_t port_id, uint16_t queue, struct rte_mbuf *pkts[], + uint16_t nb_pkts, __rte_unused uint16_t max_pkts, + __rte_unused void *user_param); + +uint16_t dump_tx_pkts(uint16_t port_id, uint16_t queue, struct rte_mbuf *pkts[], + uint16_t nb_pkts, __rte_unused void *user_param); + +void add_rx_dump_callbacks(portid_t portid); +void remove_rx_dump_callbacks(portid_t portid); +void add_tx_dump_callbacks(portid_t portid); +void remove_tx_dump_callbacks(portid_t portid); + /* * Work-around of a compilation error with ICC on invocations of the * rte_be_to_cpu_16() function. diff --git a/app/test-pmd/util.c b/app/test-pmd/util.c index 4fcb2f9..27908c6 100644 --- a/app/test-pmd/util.c +++ b/app/test-pmd/util.c @@ -149,3 +149,20 @@ dump_pkt_burst(uint16_t port_id, uint16_t queue, struct rte_mbuf *pkts[], printf(" ol_flags: %s\n", buf); } } + +uint16_t +dump_rx_pkts(uint16_t port_id, uint16_t queue, struct rte_mbuf *pkts[], + uint16_t nb_pkts, __rte_unused uint16_t max_pkts, + __rte_unused void *user_param) +{ + dump_pkt_burst(port_id, queue, pkts, nb_pkts, 1); + return nb_pkts; +} + +uint16_t +dump_tx_pkts(uint16_t port_id, uint16_t queue, struct rte_mbuf *pkts[], + uint16_t nb_pkts, __rte_unused void *user_param) +{ + dump_pkt_burst(port_id, queue, pkts, nb_pkts, 0); + return nb_pkts; +} From patchwork Wed Oct 17 07:27:31 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Raslan Darawsheh X-Patchwork-Id: 46947 X-Patchwork-Delegate: ferruh.yigit@amd.com Return-Path: X-Original-To: patchwork@dpdk.org Delivered-To: patchwork@dpdk.org Received: from [92.243.14.124] (localhost [127.0.0.1]) by dpdk.org (Postfix) with ESMTP id D9E649B67; Wed, 17 Oct 2018 09:27:54 +0200 (CEST) Received: from EUR01-VE1-obe.outbound.protection.outlook.com (mail-ve1eur01on0051.outbound.protection.outlook.com [104.47.1.51]) by dpdk.org (Postfix) with ESMTP id 137736C9B for ; Wed, 17 Oct 2018 09:27:47 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=Mellanox.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=RZdWZzBwt5wMumt/SftlxRldI2XIG3FCgmtCXwtZ22o=; b=uH0XoRfe1+rWuQiTR0AHDMUPkPuzauI8dDYY3dLlWn6IETxfqnJz9acsXyH1GvTt4+e5e40adFZCaJu5aHzUdso2AHLJxBRnmo5VZ6yGHEYAhGoK6O1KLqb4VntWMkOwSyvWXyW69gX0nSwYWzEImiTIix6AS0iEDVMmPCP4N8I= Authentication-Results: spf=none (sender IP is ) smtp.mailfrom=rasland@mellanox.com; Received: from mellanox.com (37.142.13.130) by DB5PR05MB1253.eurprd05.prod.outlook.com (2a01:111:e400:51cb::14) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.1228.23; Wed, 17 Oct 2018 07:27:43 +0000 From: Raslan Darawsheh To: jingjing.wu@intel.com Cc: thomas@monjalon.net, dev@dpdk.org, shahafs@mellanox.com, rasland@mellanox.com, xuemingl@mellanox.com, orika@mellanox.com, jerin.jacob@caviumnetworks.com, david.marchand@6wind.com, bernard.iremonger@intel.com, ferruh.yigit@intel.com Date: Wed, 17 Oct 2018 10:27:31 +0300 Message-Id: <1539761251-7677-3-git-send-email-rasland@mellanox.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1539761251-7677-1-git-send-email-rasland@mellanox.com> References: <1538897848-1693-1-git-send-email-rasland@mellanox.com> <1539761251-7677-1-git-send-email-rasland@mellanox.com> MIME-Version: 1.0 X-Originating-IP: [37.142.13.130] X-ClientProxiedBy: CWLP265CA0322.GBRP265.PROD.OUTLOOK.COM (2603:10a6:401:57::22) To DB5PR05MB1253.eurprd05.prod.outlook.com (2a01:111:e400:51cb::14) X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 2fac6fb3-1bc4-41e6-5e1a-08d634020806 X-MS-Office365-Filtering-HT: Tenant X-Microsoft-Antispam: BCL:0; PCL:0; RULEID:(7020095)(4652040)(8989299)(4534185)(4627221)(201703031133081)(201702281549075)(8990200)(5600074)(711020)(4618075)(2017052603328)(7153060)(7193020); SRVR:DB5PR05MB1253; X-Microsoft-Exchange-Diagnostics: 1; DB5PR05MB1253; 3:WNTZuCY7DwDo21hTFxw8PjD8ax53tw3ltzwjHSyvEjnSief0jmO5H7iwSrGX8CCYuAMlhkMc9a2/mafyxJmT3nqAEsHFMD6kT6ljk9eui9/PYi6IPiT1VVT0V6vLas+lLLgM0n0J3VgDs1BGZPKz5C0zRFzZYs71ei83l4mlbItEW4uySSPTi8sFZnsTXeLd2/Bg+n20/UHf+SGx4t4SlUgq7pGHYiZ6F6e30PqRzaWNINO0q75OSBtAY0lByws7; 25:45T4LNc85v4Cke9fVCf65Y9wCPhGkEeofQcDfYUOCV/iT2SEJtazMi6np/MA72mDhQe5pjSHVofFhaUnJWKK+vfQksLqxCv20SAqVx/dNrLEjMA2LlBiKSmDw9xPU++4nMgYAT4Y9mNVT9iH2mYlWLPieBts3TyEiRNGPIvGLQxJH4tcPeaYelMiQuZ9RhTnRImMxF2Y4QmbwykqUR53+Me4y1D7HmJNQucFF072me0qbw/qNch1MF6W3xsUtBfGftreuXdEZtsqAWcezVHc9jKKa8GOzx5/vhtyDn1/fDY9A5hA7kFKWybJzSoNL9uxMLQhmGzhlmxP4CZpuZkHKhaB5WQetjB35QqzQPVDl9Q=; 31:nacYbYe0qQwYsDCKXjh3WrRaN04JWtSLRsgZo+u40MtzPrVZGNOiiz/Uaq0568QOz6jWUy+cTaNOkBuqxbJUql8TiZ5+aKViP+faNLhxxeo4/cghz3lyn1jkFfxFRD5vR5+csTnEQeftBvtJeTDuegpnN0bieLBBshNi5TPt0pfoXPKI9ygR+ou/bb1HHLuICLe2ACv1ohvKhiIj2xNf373nTToXMBppLEoiZmhGSxs= X-MS-TrafficTypeDiagnostic: DB5PR05MB1253: X-LD-Processed: a652971c-7d2e-4d9b-a6a4-d149256f461b,ExtAddr X-Microsoft-Exchange-Diagnostics: 1; DB5PR05MB1253; 20:x5FXSP0xZZisY4VNsOHiADsBgJt/8yxen8PLm/7O5no13bm+BPrEvnbf3wKX0uoN5d/r758YEb4DD9jD+MkBIqKgLVIj7pFrF5+FHs95csw/wOyZ6zB2hXE5rkWmLJegoIu6GDTjIL5TmejPVHtnYxyknM4ja7osEL365P8gqPKfJh1CsCRW6owvEqGpq4/tVX1YwMRe/0dzttRx42Jg+fS9V9/9tRxsyfNXCF9qg63qn7cv77JC6kxTHCto828JsUyHFs4W99nOnuWG26XFJ/PJZ9wdwTCmAqzAc60Nw7nekeY5meg7nVakURx00QfAksl18EyHm7xmLlZLs1qnpPXstuJEsOOm65iyJqGAJq4Yo/URSzL+aqPtkr7drLpohDRtjqv3sOgnVBCMCZ/hYob3mMgKlMf1SnKDfu52c45+V8emlTSnFMvbWFyqdhFHyBeFgILm/s1Nh7it8N4J2/CsKAJ1Jsr8dGwuqUuAct9gQJxXrMDyBIHTDhTu6MuN; 4:LqIXOzQ8kx5L8I4bn1OzAiIz4GPX7+KcRRxcfXvWRj91JaVveJlHn3ee4+R75sgqIGIHT5DDtnWG9B26f0jDJPXtTJghqnOzNlfJZe9mkiHoPduA3aFGkCmn8nHbiUNb+eKrbU/imRNzErehafvvPw8Gg36MsbaBu5Xr8UD/6PPwfdn4jlPb/JgXvyzirXprnQaTzjmlM6S3c+zrV4lO6e/6WF4cbL451Ls6FGGJdZSSNQWPZCkhs5n9A7iuO6MvreLnfhDt5Y7xwQh1oCx67JjD9JKmB7+ZsTOP86QhcExi04zi7N/C0KmVwrs/EpWO X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:(228905959029699); X-MS-Exchange-SenderADCheck: 1 X-Exchange-Antispam-Report-CFA-Test: BCL:0; PCL:0; RULEID:(8211001083)(6040522)(2401047)(8121501046)(5005006)(3002001)(3231355)(944501410)(52105095)(10201501046)(93006095)(93001095)(6055026)(149066)(150057)(6041310)(20161123560045)(201703131423095)(201702281528075)(20161123555045)(201703061421075)(201703061406153)(20161123564045)(20161123558120)(20161123562045)(201708071742011)(7699051)(76991095); SRVR:DB5PR05MB1253; BCL:0; PCL:0; RULEID:; SRVR:DB5PR05MB1253; X-Forefront-PRVS: 08286A0BE2 X-Forefront-Antispam-Report: SFV:NSPM; SFS:(10009020)(979002)(396003)(346002)(136003)(39860400002)(376002)(366004)(199004)(189003)(33026002)(476003)(97736004)(50466002)(48376002)(55016002)(50226002)(16586007)(11346002)(21086003)(105586002)(36756003)(3846002)(106356001)(6116002)(446003)(2616005)(956004)(68736007)(69596002)(316002)(4326008)(2361001)(2351001)(7736002)(6666004)(53936002)(47776003)(25786009)(305945005)(66066001)(486006)(186003)(7696005)(52116002)(16526019)(81156014)(2906002)(26005)(8886007)(8676002)(86362001)(5660300001)(386003)(81166006)(478600001)(6916009)(76176011)(8936002)(51416003)(969003)(989001)(999001)(1009001)(1019001); DIR:OUT; SFP:1101; SCL:1; SRVR:DB5PR05MB1253; H:mellanox.com; FPR:; SPF:None; LANG:en; PTR:InfoNoRecords; A:1; MX:1; Received-SPF: None (protection.outlook.com: mellanox.com does not designate permitted sender hosts) X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; DB5PR05MB1253; 23:DCsNkvBehbBIwXFsPYLuArVXymRWDOuN9sggh6nSJ?= L6cSvwOwCrSZqzdo26Us5AxX+m7eYASjtC+0sU0194kMYYr3nOJ6xhBYwByfWSCsNUCPbsXy+l8lMQpK9w7v3bUgU4IdXo65aDKF75F29MFt5IAy4PwWZ90k8Ztb5qEBYHNSOFp3ZVY3hVlN8lDCwhamu83jWivd7x4fqMxXYy3ZdD1Ab0AbRJDxXFPKF1+criLYSeGJDcO51ok8t3LUmLYW+RW9gLJQmgfJedY8z5SffslSRQYqhU5IfUiTO2/d1ToojmcLcRGtb6chE9p7Y/yhPiU4N9TmwX5xGMRnUVj/pM5S+Zkgk/PJfLBLViboeJgafJiXDSairWEcRqyC1wWxNYnoSALBUEFw8nBMrCs6WV8+5yrB434hhDGHNDe0VSUQUiSVGlO1FhWXKQvj50CrvoP2uOVxw2YoDdNFyamI6SPqsdcQhojX9+cBjpc39xRt+97lc3IcMp72ugy0koRGYKSex1jWkyK/lwU26UWYavx5kwh+QHtBNdeHAwV8e6clr1Gcbn9EMczf3DP6duX49UHxL6t25q9epJTD3gOnGiqD7EsBfIdi9yYpIqL9h6KVAYxftHAXGu2qp6QDp/jPb4IoVOD53owCylKoJPJa4cQYK+Z89HMZKF0bZuK1QsoxMpvqEszMUat6eAle/rpR4ShgnFAI6VI1ud8XCvQR+1m2IDxdU9z6HEjUaz2WQcZbU4VuTpV8P71yE2K7vPvnFqemJIT7psmOcKm4XngfluCrSH8Z1xjvSVLkvtkMzaX7zcxeF68pJv4Nt5GgCbMqmQPpSFQH7dG4EhrkNspEOMO9uTvsD5/o/Cp5sOyaZGnG9KjS/3OaMmRY8XGQoN8YKPtXme5Efkx3JiZ2OX0UDrj6uOJgOE6wQnLTp5J/HZ+tKd1hXnrbEctIFGu3SG3+peoUOgdy6j8fuGuzrwD64OcROsa1uF76qtmOoxv71h0wr36ByXMEl1DdDB4DDlv9CabICNUIKVWvQMUglA1I3PhOkl402QIGB7nzWzV0+3cEHlD4P8ogiY+AKN8pkMrduPSmEiD2NyUQOoeFGDbLJZN0qfNab6PhsQatCqay/kzA9or+9FLKgnlO9KQxb142QVVHcaYPUcY6rYPU94g2oHCyGumuYDBEIZEKc8jHVNZ8P1V96HXr+F9FodCVO1rRNuXqL8F0VYeW1/1pyRDP/VKKiBENjS3l4AaGYSQBBGE0Ry2ysX+kUXg+UJ/EWQXPpSTsQg0FcZ7N9S7JpjytO7Ufz+bRPhmoAXXKz3Q5J9FlbQ/dOCXYl43jGhXnoBtSoarCm0jQP6j882bi1AG6BDm+zJkRiUQInBx6Y69MdA= X-Microsoft-Antispam-Message-Info: G1ao5sSYnFdw1JCjiLtQwMzO//Vtffx73tWodAHIrjzfwkv8mVVGs5TEosn+n45QE2s0Xbj57u/7kMiwpctpf3yo+sA0Zc22sRKH3jiIV7f5OZCspXDTNHGNW5n2msNCN7A0DBIopKowJ2cNuKB/mo8jI7Hl3Uaem09Qf2qecHUReRdCcXSIaTAv6x9YMO+L1YanAo2XZxJjlDBnPXTjBUYtLTYnCbO3EDcBtprrSI17juVhrcshIRJXochvCjrf1xzzyV1g+9r0qTaa+jxGgY3zFOhNE+jdAHdaozhV7gh6xIrNlARDlo/MClRy6JA1pk59lrUB9RMCey4i3RIe+caUk+fxN45jLNWqo4O2nNA= X-Microsoft-Exchange-Diagnostics: 1; DB5PR05MB1253; 6:Bxneoj4iBaNxKF07qMAVMaMWxHSUOMHtggUMXgiVvFquO4ihniLY3Tuk8NJIhxA9v9mUaVEAz5msPZIAew9/p0f1ZTfHl0H6uzb+W6N8lNFpN0gNeiV36hGjNdQAITPdESnuIn3L3tV7s1hJh++2u7T3tsQR2rc6IeVZ4Mf/TdDwCR+C8HinRUynNJTRKopEvVeYacxUfIlZ07N9SymhtY5vX3Xt2CcU2bX6ocw/qDtZOBR2sbnCAsEwGQdVEBisnaCSK1oMNi+LNjGyEYDOWV9XfhN/b+4B7165t5b3vJ+O2gHzTqj/rd9YOY+HcUVCimv3Mw94LiHwp0ZNofY90AvfUJl9l2UkDALOkcmw0u6C32KP9uafke1rR/h1+AEVK5nSLWV30cygwLi7dYPmIWVNUe8c9ydJ50OGduqRobvg580y9cSXDLjE5mNaApExD80jVq4XBkakA1mj7n+cag==; 5:Yeh9KGKkJQs2k1G2+39N+NQA8JAeKw+VSRnlPeV4sD1g0n3YFoQFyoCmE5OniFhqNK0cfUzIG9rl6COTLzxRazdFpctb0ZafQ4vixoFMEycSkXT1SkmJYZ1C2xlFmAlhCJJMHCdRBH4zwjv/Aoxwr6NrP9yUyJiTpGv0N5SFM7o=; 7:Nnx/I2ou6P5uJymaXMGqDIBD+dwPTdyom3GzcujHo9WJ/MJR/k8TuFGd3+BYhrTV2XnA7PhIDxJZg1700BXKxudoZUNuqNKRicW7kJtLWWhOEGgnX2PU75ahSxY2P+aFcKEamy9NFUKHIdLhX1j+H4vO9mc/eZsuZb6UEsSN4HYNXTTjphZdzrobTvgPWy0ucr0PtKgHCX3GYkoqRBTF0YiAtlVJ6J99StZ35zzeCDito810p/ELInGQ+gRhE5TG SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-OriginatorOrg: Mellanox.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 17 Oct 2018 07:27:43.8019 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 2fac6fb3-1bc4-41e6-5e1a-08d634020806 X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: a652971c-7d2e-4d9b-a6a4-d149256f461b X-MS-Exchange-Transport-CrossTenantHeadersStamped: DB5PR05MB1253 Subject: [dpdk-dev] [PATCH v5 3/3] app/testpmd: set packet dump based on verbosity level X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Sender: "dev" when changing verbosity level it will configure rx/tx callbacks to dump packets based on the verbosity value as following: 1- dump only received packets: testpmd> set verbose 1 2- dump only sent packets: testpmd> set verbose 2 3- dump sent and received packets: testpmd> set verbose (any number > 2) 4- disable dump testpmd> set verbose 0 Signed-off-by: Raslan Darawsheh Acked-by: Bernard Iremonger --- app/test-pmd/config.c | 25 +++++++++++++++++++++++++ app/test-pmd/testpmd.c | 4 ++-- app/test-pmd/testpmd.h | 1 + 3 files changed, 28 insertions(+), 2 deletions(-) diff --git a/app/test-pmd/config.c b/app/test-pmd/config.c index 431fa2a..87a90ad 100644 --- a/app/test-pmd/config.c +++ b/app/test-pmd/config.c @@ -50,6 +50,7 @@ #endif #include #include +#include #include "testpmd.h" @@ -2773,11 +2774,35 @@ remove_tx_dump_callbacks(portid_t portid) } void +configure_rxtx_dump_callbacks(uint16_t verbose) +{ + portid_t portid; + +#ifndef RTE_ETHDEV_RXTX_CALLBACKS + TESTPMD_LOG(ERR, "setting rxtx callbacks is not enabled\n"); + return; +#endif + + RTE_ETH_FOREACH_DEV(portid) + { + if (verbose == 1 || verbose > 2) + add_rx_dump_callbacks(portid); + else + remove_rx_dump_callbacks(portid); + if (verbose >= 2) + add_tx_dump_callbacks(portid); + else + remove_tx_dump_callbacks(portid); + } +} + +void set_verbose_level(uint16_t vb_level) { printf("Change verbose level from %u to %u\n", (unsigned int) verbose_level, (unsigned int) vb_level); verbose_level = vb_level; + configure_rxtx_dump_callbacks(verbose_level); } void diff --git a/app/test-pmd/testpmd.c b/app/test-pmd/testpmd.c index d550bda..20582e4 100644 --- a/app/test-pmd/testpmd.c +++ b/app/test-pmd/testpmd.c @@ -1991,7 +1991,7 @@ start_port(portid_t pid) return -1; } } - + configure_rxtx_dump_callbacks(0); printf("Configuring Port %d (socket %u)\n", pi, port->socket_id); /* configure port */ @@ -2090,7 +2090,7 @@ start_port(portid_t pid) return -1; } } - + configure_rxtx_dump_callbacks(verbose_level); /* start port */ if (rte_eth_dev_start(pi) < 0) { printf("Fail to start port %d\n", pi); diff --git a/app/test-pmd/testpmd.h b/app/test-pmd/testpmd.h index 0e923d7..1ca7c6a 100644 --- a/app/test-pmd/testpmd.h +++ b/app/test-pmd/testpmd.h @@ -778,6 +778,7 @@ void add_rx_dump_callbacks(portid_t portid); void remove_rx_dump_callbacks(portid_t portid); void add_tx_dump_callbacks(portid_t portid); void remove_tx_dump_callbacks(portid_t portid); +void configure_rxtx_dump_callbacks(uint16_t verbose); /* * Work-around of a compilation error with ICC on invocations of the