get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

GET /api/patches/46994/?format=api
HTTP 200 OK
Allow: GET, PUT, PATCH, HEAD, OPTIONS
Content-Type: application/json
Vary: Accept

{
    "id": 46994,
    "url": "https://patches.dpdk.org/api/patches/46994/?format=api",
    "web_url": "https://patches.dpdk.org/project/dpdk/patch/1539789731-18409-1-git-send-email-rasland@mellanox.com/",
    "project": {
        "id": 1,
        "url": "https://patches.dpdk.org/api/projects/1/?format=api",
        "name": "DPDK",
        "link_name": "dpdk",
        "list_id": "dev.dpdk.org",
        "list_email": "dev@dpdk.org",
        "web_url": "http://core.dpdk.org",
        "scm_url": "git://dpdk.org/dpdk",
        "webscm_url": "http://git.dpdk.org/dpdk",
        "list_archive_url": "https://inbox.dpdk.org/dev",
        "list_archive_url_format": "https://inbox.dpdk.org/dev/{}",
        "commit_url_format": ""
    },
    "msgid": "<1539789731-18409-1-git-send-email-rasland@mellanox.com>",
    "list_archive_url": "https://inbox.dpdk.org/dev/1539789731-18409-1-git-send-email-rasland@mellanox.com",
    "date": "2018-10-17T15:22:09",
    "name": "[v6,1/3] app/testpmd: move dumping packets to a separate function",
    "commit_ref": null,
    "pull_url": null,
    "state": "accepted",
    "archived": true,
    "hash": "4c769445289d57c5acbd63ec9aafbe92ceede97a",
    "submitter": {
        "id": 513,
        "url": "https://patches.dpdk.org/api/people/513/?format=api",
        "name": "Raslan Darawsheh",
        "email": "rasland@mellanox.com"
    },
    "delegate": {
        "id": 319,
        "url": "https://patches.dpdk.org/api/users/319/?format=api",
        "username": "fyigit",
        "first_name": "Ferruh",
        "last_name": "Yigit",
        "email": "ferruh.yigit@amd.com"
    },
    "mbox": "https://patches.dpdk.org/project/dpdk/patch/1539789731-18409-1-git-send-email-rasland@mellanox.com/mbox/",
    "series": [
        {
            "id": 1959,
            "url": "https://patches.dpdk.org/api/series/1959/?format=api",
            "web_url": "https://patches.dpdk.org/project/dpdk/list/?series=1959",
            "date": "2018-10-17T15:22:09",
            "name": "[v6,1/3] app/testpmd: move dumping packets to a separate function",
            "version": 6,
            "mbox": "https://patches.dpdk.org/series/1959/mbox/"
        }
    ],
    "comments": "https://patches.dpdk.org/api/patches/46994/comments/",
    "check": "success",
    "checks": "https://patches.dpdk.org/api/patches/46994/checks/",
    "tags": {},
    "related": [],
    "headers": {
        "Return-Path": "<dev-bounces@dpdk.org>",
        "X-Original-To": "patchwork@dpdk.org",
        "Delivered-To": "patchwork@dpdk.org",
        "Received": [
            "from [92.243.14.124] (localhost [127.0.0.1])\n\tby dpdk.org (Postfix) with ESMTP id F11125F1A;\n\tWed, 17 Oct 2018 17:22:25 +0200 (CEST)",
            "from EUR04-DB3-obe.outbound.protection.outlook.com\n\t(mail-eopbgr60054.outbound.protection.outlook.com [40.107.6.54])\n\tby dpdk.org (Postfix) with ESMTP id AC1B8559A\n\tfor <dev@dpdk.org>; Wed, 17 Oct 2018 17:22:23 +0200 (CEST)",
            "from mellanox.com (37.142.13.130) by\n\tHE1PR05MB1257.eurprd05.prod.outlook.com (2a01:111:e400:5889::14) with\n\tMicrosoft SMTP Server (version=TLS1_2,\n\tcipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.1250.21;\n\tWed, 17 Oct 2018 15:22:20 +0000"
        ],
        "DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed; d=Mellanox.com;\n\ts=selector1;\n\th=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck;\n\tbh=ZcAGZJn+pDoQ6GYAsZSYNeBwk2mDuYrt8uCe+Or77lw=;\n\tb=dRdKJ5KKDK2BzLu+z8hNnlqRHNVQUawTw8dcNZeA5ZYTQWaU1za2znwtSWMHZaXyqvwHuQpVxhM91AsLj0L5+BYrHNRSeUIq4EcjCY2BLIrOCNKkyRTPYdsSfpcQb2845Musgxp+quneg8v7lzS0MbfcjS4oh3A7odrb42sKiEc=",
        "Authentication-Results": "spf=none (sender IP is )\n\tsmtp.mailfrom=rasland@mellanox.com; ",
        "From": "Raslan Darawsheh <rasland@mellanox.com>",
        "To": "jingjing.wu@intel.com",
        "Cc": "thomas@monjalon.net, dev@dpdk.org, shahafs@mellanox.com,\n\trasland@mellanox.com, xuemingl@mellanox.com, orika@mellanox.com,\n\tjerin.jacob@caviumnetworks.com, david.marchand@6wind.com,\n\tbernard.iremonger@intel.com, ferruh.yigit@intel.com",
        "Date": "Wed, 17 Oct 2018 18:22:09 +0300",
        "Message-Id": "<1539789731-18409-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",
        "Content-Type": "text/plain",
        "X-Originating-IP": "[37.142.13.130]",
        "X-ClientProxiedBy": "LO2P265CA0158.GBRP265.PROD.OUTLOOK.COM\n\t(2603:10a6:600:9::26) To HE1PR05MB1257.eurprd05.prod.outlook.com\n\t(2a01:111:e400:5889::14)",
        "X-MS-PublicTrafficType": "Email",
        "X-MS-Office365-Filtering-Correlation-Id": "44783337-d3b6-4756-5347-08d634445580",
        "X-MS-Office365-Filtering-HT": "Tenant",
        "X-Microsoft-Antispam": "BCL:0; PCL:0;\n\tRULEID:(7020095)(4652040)(8989299)(5600074)(711020)(4618075)(4534185)(4627221)(201703031133081)(201702281549075)(8990200)(2017052603328)(7153060)(7193020);\n\tSRVR:HE1PR05MB1257; ",
        "X-Microsoft-Exchange-Diagnostics": [
            "1; HE1PR05MB1257;\n\t3:KRetMHWouWfPuGtjC1v6CLdsvkm9Aw5AXnwCZU+N/0ai2miYE8eJz+RggZpcuwD6kSbsoPoDSawQqp+HKBIFI4lmc4hNucBDpukEUnvpmxOqZ/WOiya8jzRBQro4/Aadw1jWkFRKstmpZ51hR0/bdgwaZCVy+3UuZPP1O63E3T2APwaF+jA76D0PhJ1b1/nwWz/iQss2VR83/xvI/hD371uFrUJP+Y9uYnDV7Ca0ugzjMmjiFJOGx+5avPn9D8bR;\n\t25:pm6dWYXGUWhctHFbekxP1NbYLGT+7FUI+mtY0En9j6Tw1JANkLTBIdCOzgqbyXjHqljGqRpc8sxByqE+3QqtAPwHX+nur2tF2pjQcE9GFf3SM+I1GBYGff2HGifyem5QsbhZ3XbEFDXhS9ICF4HJoWlxtV7E1e29QJVMJT7SG+k1+/Ham3IKRnKmQZWsp4drDA0KMU/q4B8UmaolLlzS/Hyaa6MarPS8O4jNN1uwjqlti4xtTMQ3IiY4vhbzCYzyfex5v0uEOJ0oI6cqvaHKfhmYH0KXV7zy10COzTA/SoiQw2/rLwGWxX06LUNLkWs1r0szcwaVkX5St4msTPEFxOipxDpfx9vEjy+b1GSt6MM=;\n\t31:X2+Zdt1POykYe/BlgnWQ8J3UPC2jzU0jdy3ceABnW2dL2kwxoYOIB+yIMPu6a/N9WO6V4WpVGb1UUhHTUtopSMZyn+OcqO/iVOcLeI6B0AdFfPzo257fRS+c57r1NPV+xBQCBapfFux7cDqVzsKQRjlEO/SlvVwF1GoKAMjKUw8eGD37ZsrWf92kVIIo2aWLXKdU/apntk5aTdvRejfF2s8r4qjzz+/+m1io08T8JkE=",
            "1; HE1PR05MB1257;\n\t20:TIZrizh6pL+PO+3EwsPbsx4qrupw8VeRDyxAMciBB2vfEu5VdpSKq8W1eNc53cofo58LH8AtVfhvw+fmthX7iScG1zTwli3HlVvyaBUBbYWav7NWL8vkzt+gRzGXZM5DEmhUhopMdmtMUgT1UugoDEPRrYF+W2azNix/rJQuKLfUBLlB3TcDo8OQvCSXCe+F75Pp+S6rtxyO+8UQIG5iYBaD74/8a3NMoNPeI2SDY0d/v09fiDNo8QsC5J1fheaL9Yf/IC8kHuzsWr8QADuyhFRWacCiHyYDDTuTRzyXYkMeZOd2Y/0zVmWQmy53thvKF9FqnX51T+zCPx/sG4+fLnxHBrF6i2sSN+u4T7R95xZ6CINsckphRdELCP5ge/3iA4kN+IRsxGtKDDXEp9/u0HdyILohjIf8NC1aoP9xa30LP9XhsocKLJQKJZG/qR/7KvHK561S1dsgzl1sYIEQ5i1k/PW9lIwXIGuem9geaPUlIbS04ShcNi+GQEMDNmso;\n\t4:drrjAs3+E9zcXRJAXvAKS4i0Ab2V5xEn3uSd8/KMYuO/dBx37Ggt6rvINU/M8Fjy/JHilCpRzYEIgHesYflowB+Lqo3QGuuQUdkznmaToZ2j2fczfBFLTDP2Jn/dj8Z7NPYWIqMA2viJgmQsItoqJvGupiF3KftRuFUDGMQi3p0yQa3JdRfLmgIHJ8Herdj9Gp+hEeX+xTAYyY0jjRgoozsFN7bwSktXO6kQB0uaN1wZ1lu+wmKFF2Hi3dejCj5MYPHO43I6jiRhYr1wHrG+sE+oxGLlKrVn3vxWMN+CnnAy9cVtRwFz7ko7UveHVHpc",
            "=?us-ascii?Q?1; HE1PR05MB1257;\n\t23:bbwqjAK9dMuqtuPi02wM8eMIdqYkisx80VfDmUQGk?=\n\tqsXRUzC2ia1wv4JR6ktXexGsgXhzEtsCP+rIMeBIVybSoD4/nJmIYu2hLCncy2yuI/GEj98ivcEsdxP6VFFX1/YgfRL1TksqauKek9dMV3/VAAsgPGNEsSCz7lk6UUx5KG313M+mcK4knQpYwdOopvxTCrdo0toC2Kx1ElozUmPEQorskZEjNLbAyQg/DXmZ+japTJtSaKvvVyvzBh880BG4PQjbHRP2lQcKsYeUC0Go1+Ld5i/HbKbw+9Y9F4qgO2pnV5n8GU4bU9FrhthO0cbT1XImEilz/Inwcc8ZmCfMgAEeplBGXhs6AdctbG8TEX2iQysdGkSNWZ5ZKKRmPAN8/W/3tjdQSuTDpTPalMj+hb6Hrqt3JUYRpq29gYGx6NP2DbZvdbJGTGmJLbS/nUrJEYnB2YmVjHzRF/72nb7Ntd56eU6Oc5vdPzr9Rc8Nlv9Rikn/hBCHtzNr342x6S4RPNuebyLt9aGMjdZ+sNbIKlsPlPwrDlkW9d8YV+3ZEjdEPI1M79RL75YTETu/uipfYx8Vaw/CJXlQ1hoqTtiCDteujH2Hc7YwhBbAOkEqmPJefmRW+0JqC90SSMQQMl10WMX5YuQvvPQNcy4f+AqvJ8W9gaGTuFTYgfWehCmf+w3s+fckLllPnjcOpMndcqxDD2IY0vYyShN47UjmAxvrJ62oMumlGxA+oEKb9vXrlAwbcbw8qzYjH8XhOP150hT46WiSc9KUcP+l5cgkG7aSX9He00IMKk3u1+zPXK25lHFAGIeoQqqAwsjlUnpYH0GvwVQPYsJu60pirb8sQwVGYfCgfl3+04RHSfFapE0wQb8QlMupja73vuN2jC/mXsmoIRW9eu3Q+4Q5iYTWpXSeRZTnsKGoKlIVFt+wQ3PgFS4TtJtYNKCm9jtZu2fovh+4fqQL7zlUX6dkttsNeFCLhqh4GHItpKcRDhK6/M8WDxRoTAlBgp/+ot84J0i8NsMd7FRpC7JS53cB8R1bSjSZDkhHhX8+R6kXJoWoUaomkMuKIYGaVbneA0H3rxOHV1mCUBKoxi+x+v3cxnufSiVuPhA631pjJ8V4hVtO9IGmiuK3T7rz2AxfxOFSWLjkUIBfscCCbMRR84/E0K1cHqAtNahOwmqf0cXJjqrtHz1hBIHlSZY+QycqRHIQU3WePQ4xgB8u5fzSlXQUNdsX06ThwQgFRkovuF4NW4MsgYDkPYdKVl4WPyHQBEJPjNZUwCwROioPUSZHqLx6bDwSO4XKtle7Hc0uV+yk3wuHtPNOKE=",
            "1; HE1PR05MB1257;\n\t6:JpUymhJufPLZ342wOqIKtuOv8RlcSTPDOHGuoFh2KzvP0V+RcuJSPTW/DKVMsDWbp/Gmc8ID7EGz0QzJ9IbwAoOv0Nz+UlKEIGkCEDtCn3hr+brIl5eL8w8DQpcybOS3jqnTm5AwPxcVn7K0Dz/ZccE6mbpWf0EUht62uUmi0HfB9wqMACy9LovBCQ8fqBEg0TKsE2fqvjt+S/tn1H5kJsMLWd1lrDsilfdkU720Pjkc8oe7SYehb5iMh7+5NOALAQxz9qyJqqqAMjRW5eucT+ojoX7tUTgN2Z65f7U8zXdmQsGFRlW+B1XwwuvqTe9mFZ+3jV9+UiGwq8X6yp58Ix0kKff/t+7+7vHO3VZDaJUJmslvpeWIRo3r9HuFoZC5YfWYOhG0PZyYe6kGNcfeiy2TnuVg7zjzQuQ04I51Mm876UYw20ZI01xQQAsF5bzFTcGJEpY9QNOtB0BBXeRj5Q==;\n\t5:NcNaR7tJws8OAlb97uIWEKkSiQRulbXbJvpxwCuQH6Ln4wHf5s2VQPPVPn/Y+4yrc/QH2Zf3Agw2NhCW0sysuA8c1PXCYMby/nnc0quePJiAVt9CDA/AMcG0zDo9BGX84dE8mLdlNHwa32eCoFEYzg9kUlr+p+YpAKYHgIEe8p8=;\n\t7:Tv3WDsJ1+3frBTOFroEAqr17sHx+VvIoybTLCx2jF9kl9s/qf1xxgDR9gFQRV/6Y9I4YwMWmAcz8pjmmrUtn3YoNEMdLwisRY3h9Jdr9C8cKTzaphF8RXsGbWS4WqjZwp3W/Dp0HDOmyVMrH2N9l84I8qO7b9CPNnAFZX9QnHqNc8Mb3ldywlffeIeVfUmZ3ZDFVi6dSJbq4MAvN6sx9OZs9OOWXDY20h78mqtBQMr5D1zKOzsHvOig8qlFx9o5U"
        ],
        "X-MS-TrafficTypeDiagnostic": "HE1PR05MB1257:",
        "X-LD-Processed": "a652971c-7d2e-4d9b-a6a4-d149256f461b,ExtAddr",
        "X-Microsoft-Antispam-PRVS": "<HE1PR05MB1257EBB458C9AACA5A00C6FEC2FF0@HE1PR05MB1257.eurprd05.prod.outlook.com>",
        "X-Exchange-Antispam-Report-Test": "UriScan:(228905959029699);",
        "X-MS-Exchange-SenderADCheck": "1",
        "X-Exchange-Antispam-Report-CFA-Test": "BCL:0; PCL:0;\n\tRULEID:(8211001083)(6040522)(2401047)(5005006)(8121501046)(93006095)(93001095)(10201501046)(3231355)(944501410)(52105095)(3002001)(6055026)(149066)(150057)(6041310)(20161123562045)(20161123564045)(201703131423095)(201702281528075)(20161123555045)(201703061421075)(201703061406153)(20161123558120)(20161123560045)(201708071742011)(7699051)(76991095);\n\tSRVR:HE1PR05MB1257; BCL:0; PCL:0; RULEID:; SRVR:HE1PR05MB1257; ",
        "X-Forefront-PRVS": "08286A0BE2",
        "X-Forefront-Antispam-Report": "SFV:NSPM;\n\tSFS:(10009020)(396003)(39860400002)(366004)(376002)(346002)(136003)(189003)(199004)(53936002)(47776003)(3846002)(8886007)(97736004)(55016002)(4326008)(316002)(16586007)(2361001)(66066001)(305945005)(33026002)(4744004)(446003)(6116002)(11346002)(956004)(2906002)(50466002)(476003)(7736002)(486006)(21086003)(2616005)(36756003)(50226002)(51416003)(69596002)(48376002)(478600001)(5660300001)(386003)(86362001)(2351001)(52116002)(7696005)(575784001)(68736007)(76176011)(186003)(25786009)(8676002)(81166006)(16526019)(81156014)(106356001)(105586002)(26005)(6916009)(6666004)(8936002);\n\tDIR:OUT; SFP:1101; SCL:1; SRVR:HE1PR05MB1257; H:mellanox.com; FPR:;\n\tSPF:None; \n\tLANG:en; PTR:InfoNoRecords; MX:1; A:1; ",
        "Received-SPF": "None (protection.outlook.com: mellanox.com does not designate\n\tpermitted sender hosts)",
        "X-Microsoft-Antispam-Message-Info": "YXy3ROwmd6yJkHwPL4put0NN6xyelgsN+/QEVAbG+owKp7MhMkEIDO+eYOpy3uIaaMtftBYDD3Ggg4empkMxoIVsFxbhdUeN1whUrqYWDNxS9V469yZsC3bdRLOQYriT5KAQUQ4BcTAujVYeltbEvAlBrh8OJFay8S5D6SSDk1NiG/m48BAzhnScn3W8xlO/v/7aMdlcTiq+8F+Zj1JzWskJ+WBc3hQ20G97/Euk8UGwpY2ACdL14fCtqMaJmZGfFKqD/5dp9nbmuh742ulEAMvZrPNP+EaT6KphKeWZy+huLEMlzMFgu/WupQsWemNLSHuRWidOsyN0fzXVpNBx4UVzUyeE2xhlQZ6qORTTd3U=",
        "SpamDiagnosticOutput": "1:99",
        "SpamDiagnosticMetadata": "NSPM",
        "X-OriginatorOrg": "Mellanox.com",
        "X-MS-Exchange-CrossTenant-OriginalArrivalTime": "17 Oct 2018 15:22:20.0913\n\t(UTC)",
        "X-MS-Exchange-CrossTenant-Network-Message-Id": "44783337-d3b6-4756-5347-08d634445580",
        "X-MS-Exchange-CrossTenant-FromEntityHeader": "Hosted",
        "X-MS-Exchange-CrossTenant-Id": "a652971c-7d2e-4d9b-a6a4-d149256f461b",
        "X-MS-Exchange-Transport-CrossTenantHeadersStamped": "HE1PR05MB1257",
        "Subject": "[dpdk-dev] [PATCH v6 1/3] app/testpmd: move dumping packets to a\n\tseparate function",
        "X-BeenThere": "dev@dpdk.org",
        "X-Mailman-Version": "2.1.15",
        "Precedence": "list",
        "List-Id": "DPDK patches and discussions <dev.dpdk.org>",
        "List-Unsubscribe": "<https://mails.dpdk.org/options/dev>,\n\t<mailto:dev-request@dpdk.org?subject=unsubscribe>",
        "List-Archive": "<http://mails.dpdk.org/archives/dev/>",
        "List-Post": "<mailto:dev@dpdk.org>",
        "List-Help": "<mailto:dev-request@dpdk.org?subject=help>",
        "List-Subscribe": "<https://mails.dpdk.org/listinfo/dev>,\n\t<mailto:dev-request@dpdk.org?subject=subscribe>",
        "Errors-To": "dev-bounces@dpdk.org",
        "Sender": "\"dev\" <dev-bounces@dpdk.org>"
    },
    "content": "verbosity for the received/sent packets is needed in all of the\nforwarding engines so moving it to be in a separate function\n\nAcked-by: Bernard Iremonger <bernard.iremonger@intel.com>\nSigned-off-by: Raslan Darawsheh <rasland@mellanox.com>\n\n---\nchanges in v6:\n\t- fix compilation issue for patch\n---\n---\n app/test-pmd/Makefile    |   1 +\n app/test-pmd/meson.build |   3 +-\n app/test-pmd/rxonly.c    | 134 +----------------------------------------\n app/test-pmd/testpmd.h   |   3 +\n app/test-pmd/util.c      | 151 +++++++++++++++++++++++++++++++++++++++++++++++\n 5 files changed, 160 insertions(+), 132 deletions(-)\n create mode 100644 app/test-pmd/util.c",
    "diff": "diff --git a/app/test-pmd/Makefile b/app/test-pmd/Makefile\nindex e2581ca..8e4ff5b 100644\n--- a/app/test-pmd/Makefile\n+++ b/app/test-pmd/Makefile\n@@ -36,6 +36,7 @@ SRCS-y += icmpecho.c\n SRCS-y += noisy_vnf.c\n SRCS-$(CONFIG_RTE_LIBRTE_IEEE1588) += ieee1588fwd.c\n SRCS-$(CONFIG_RTE_LIBRTE_BPF) += bpf_cmd.c\n+SRCS-y += util.c\n \n ifeq ($(CONFIG_RTE_LIBRTE_PMD_SOFTNIC), y)\n SRCS-y += softnicfwd.c\ndiff --git a/app/test-pmd/meson.build b/app/test-pmd/meson.build\nindex 9ef6ed9..cd66618 100644\n--- a/app/test-pmd/meson.build\n+++ b/app/test-pmd/meson.build\n@@ -21,7 +21,8 @@ sources = files('cmdline.c',\n \t'parameters.c',\n \t'rxonly.c',\n \t'testpmd.c',\n-\t'txonly.c')\n+\t'txonly.c',\n+\t'util.c')\n \n deps = ['ethdev', 'gro', 'gso', 'cmdline', 'metrics', 'meter', 'bus_pci']\n if dpdk_conf.has('RTE_LIBRTE_PDUMP')\ndiff --git a/app/test-pmd/rxonly.c b/app/test-pmd/rxonly.c\nindex 41db0ff..3eca89c 100644\n--- a/app/test-pmd/rxonly.c\n+++ b/app/test-pmd/rxonly.c\n@@ -40,14 +40,6 @@\n \n #include \"testpmd.h\"\n \n-static inline void\n-print_ether_addr(const char *what, struct ether_addr *eth_addr)\n-{\n-\tchar buf[ETHER_ADDR_FMT_SIZE];\n-\tether_format_addr(buf, ETHER_ADDR_FMT_SIZE, eth_addr);\n-\tprintf(\"%s%s\", what, buf);\n-}\n-\n /*\n  * Received a burst of packets.\n  */\n@@ -55,16 +47,8 @@ static void\n pkt_burst_receive(struct fwd_stream *fs)\n {\n \tstruct rte_mbuf  *pkts_burst[MAX_PKT_BURST];\n-\tstruct rte_mbuf  *mb;\n-\tstruct ether_hdr *eth_hdr;\n-\tuint16_t eth_type;\n-\tuint64_t ol_flags;\n \tuint16_t nb_rx;\n-\tuint16_t i, packet_type;\n-\tuint16_t is_encapsulation;\n-\tchar buf[256];\n-\tstruct rte_net_hdr_lens hdr_lens;\n-\tuint32_t sw_packet_type;\n+\tuint16_t i;\n \n #ifdef RTE_TEST_PMD_RECORD_CORE_CYCLES\n \tuint64_t start_tsc;\n@@ -90,120 +74,8 @@ pkt_burst_receive(struct fwd_stream *fs)\n \t/*\n \t * Dump each received packet if verbose_level > 0.\n \t */\n-\tif (verbose_level > 0)\n-\t\tprintf(\"port %u/queue %u: received %u packets\\n\",\n-\t\t       fs->rx_port,\n-\t\t       (unsigned) fs->rx_queue,\n-\t\t       (unsigned) nb_rx);\n-\tfor (i = 0; i < nb_rx; i++) {\n-\t\tmb = pkts_burst[i];\n-\t\tif (verbose_level == 0) {\n-\t\t\trte_pktmbuf_free(mb);\n-\t\t\tcontinue;\n-\t\t}\n-\t\teth_hdr = rte_pktmbuf_mtod(mb, struct ether_hdr *);\n-\t\teth_type = RTE_BE_TO_CPU_16(eth_hdr->ether_type);\n-\t\tol_flags = mb->ol_flags;\n-\t\tpacket_type = mb->packet_type;\n-\t\tis_encapsulation = RTE_ETH_IS_TUNNEL_PKT(packet_type);\n-\n-\t\tprint_ether_addr(\"  src=\", &eth_hdr->s_addr);\n-\t\tprint_ether_addr(\" - dst=\", &eth_hdr->d_addr);\n-\t\tprintf(\" - type=0x%04x - length=%u - nb_segs=%d\",\n-\t\t       eth_type, (unsigned) mb->pkt_len,\n-\t\t       (int)mb->nb_segs);\n-\t\tif (ol_flags & PKT_RX_RSS_HASH) {\n-\t\t\tprintf(\" - RSS hash=0x%x\", (unsigned) mb->hash.rss);\n-\t\t\tprintf(\" - RSS queue=0x%x\",(unsigned) fs->rx_queue);\n-\t\t}\n-\t\tif (ol_flags & PKT_RX_FDIR) {\n-\t\t\tprintf(\" - FDIR matched \");\n-\t\t\tif (ol_flags & PKT_RX_FDIR_ID)\n-\t\t\t\tprintf(\"ID=0x%x\",\n-\t\t\t\t       mb->hash.fdir.hi);\n-\t\t\telse if (ol_flags & PKT_RX_FDIR_FLX)\n-\t\t\t\tprintf(\"flex bytes=0x%08x %08x\",\n-\t\t\t\t       mb->hash.fdir.hi, mb->hash.fdir.lo);\n-\t\t\telse\n-\t\t\t\tprintf(\"hash=0x%x ID=0x%x \",\n-\t\t\t\t       mb->hash.fdir.hash, mb->hash.fdir.id);\n-\t\t}\n-\t\tif (ol_flags & PKT_RX_TIMESTAMP)\n-\t\t\tprintf(\" - timestamp %\"PRIu64\" \", mb->timestamp);\n-\t\tif (ol_flags & PKT_RX_QINQ)\n-\t\t\tprintf(\" - QinQ VLAN tci=0x%x, VLAN tci outer=0x%x\",\n-\t\t\t\t\tmb->vlan_tci, mb->vlan_tci_outer);\n-\t\telse if (ol_flags & PKT_RX_VLAN)\n-\t\t\tprintf(\" - VLAN tci=0x%x\", mb->vlan_tci);\n-\t\tif (mb->packet_type) {\n-\t\t\trte_get_ptype_name(mb->packet_type, buf, sizeof(buf));\n-\t\t\tprintf(\" - hw ptype: %s\", buf);\n-\t\t}\n-\t\tsw_packet_type = rte_net_get_ptype(mb, &hdr_lens,\n-\t\t\tRTE_PTYPE_ALL_MASK);\n-\t\trte_get_ptype_name(sw_packet_type, buf, sizeof(buf));\n-\t\tprintf(\" - sw ptype: %s\", buf);\n-\t\tif (sw_packet_type & RTE_PTYPE_L2_MASK)\n-\t\t\tprintf(\" - l2_len=%d\", hdr_lens.l2_len);\n-\t\tif (sw_packet_type & RTE_PTYPE_L3_MASK)\n-\t\t\tprintf(\" - l3_len=%d\", hdr_lens.l3_len);\n-\t\tif (sw_packet_type & RTE_PTYPE_L4_MASK)\n-\t\t\tprintf(\" - l4_len=%d\", hdr_lens.l4_len);\n-\t\tif (sw_packet_type & RTE_PTYPE_TUNNEL_MASK)\n-\t\t\tprintf(\" - tunnel_len=%d\", hdr_lens.tunnel_len);\n-\t\tif (sw_packet_type & RTE_PTYPE_INNER_L2_MASK)\n-\t\t\tprintf(\" - inner_l2_len=%d\", hdr_lens.inner_l2_len);\n-\t\tif (sw_packet_type & RTE_PTYPE_INNER_L3_MASK)\n-\t\t\tprintf(\" - inner_l3_len=%d\", hdr_lens.inner_l3_len);\n-\t\tif (sw_packet_type & RTE_PTYPE_INNER_L4_MASK)\n-\t\t\tprintf(\" - inner_l4_len=%d\", hdr_lens.inner_l4_len);\n-\t\tif (is_encapsulation) {\n-\t\t\tstruct ipv4_hdr *ipv4_hdr;\n-\t\t\tstruct ipv6_hdr *ipv6_hdr;\n-\t\t\tstruct udp_hdr *udp_hdr;\n-\t\t\tuint8_t l2_len;\n-\t\t\tuint8_t l3_len;\n-\t\t\tuint8_t l4_len;\n-\t\t\tuint8_t l4_proto;\n-\t\t\tstruct  vxlan_hdr *vxlan_hdr;\n-\n-\t\t\tl2_len  = sizeof(struct ether_hdr);\n-\n-\t\t\t /* Do not support ipv4 option field */\n-\t\t\tif (RTE_ETH_IS_IPV4_HDR(packet_type)) {\n-\t\t\t\tl3_len = sizeof(struct ipv4_hdr);\n-\t\t\t\tipv4_hdr = rte_pktmbuf_mtod_offset(mb,\n-\t\t\t\t\t\t\t\t   struct ipv4_hdr *,\n-\t\t\t\t\t\t\t\t   l2_len);\n-\t\t\t\tl4_proto = ipv4_hdr->next_proto_id;\n-\t\t\t} else {\n-\t\t\t\tl3_len = sizeof(struct ipv6_hdr);\n-\t\t\t\tipv6_hdr = rte_pktmbuf_mtod_offset(mb,\n-\t\t\t\t\t\t\t\t   struct ipv6_hdr *,\n-\t\t\t\t\t\t\t\t   l2_len);\n-\t\t\t\tl4_proto = ipv6_hdr->proto;\n-\t\t\t}\n-\t\t\tif (l4_proto == IPPROTO_UDP) {\n-\t\t\t\tudp_hdr = rte_pktmbuf_mtod_offset(mb,\n-\t\t\t\t\t\t\t\t  struct udp_hdr *,\n-\t\t\t\t\t\t\t\t  l2_len + l3_len);\n-\t\t\t\tl4_len = sizeof(struct udp_hdr);\n-\t\t\t\tvxlan_hdr = rte_pktmbuf_mtod_offset(mb,\n-\t\t\t\t\t\t\t\t    struct vxlan_hdr *,\n-\t\t\t\t\t\t\t\t    l2_len + l3_len + l4_len);\n-\n-\t\t\t\tprintf(\" - VXLAN packet: packet type =%d, \"\n-\t\t\t\t\t\"Destination UDP port =%d, VNI = %d\",\n-\t\t\t\t\tpacket_type, RTE_BE_TO_CPU_16(udp_hdr->dst_port),\n-\t\t\t\t\trte_be_to_cpu_32(vxlan_hdr->vx_vni) >> 8);\n-\t\t\t}\n-\t\t}\n-\t\tprintf(\" - Receive queue=0x%x\", (unsigned) fs->rx_queue);\n-\t\tprintf(\"\\n\");\n-\t\trte_get_rx_ol_flag_list(mb->ol_flags, buf, sizeof(buf));\n-\t\tprintf(\"  ol_flags: %s\\n\", buf);\n-\t\trte_pktmbuf_free(mb);\n-\t}\n+\tfor (i = 0; i < nb_rx; i++)\n+\t\trte_pktmbuf_free(pkts_burst[i]);\n \n #ifdef RTE_TEST_PMD_RECORD_CORE_CYCLES\n \tend_tsc = rte_rdtsc();\ndiff --git a/app/test-pmd/testpmd.h b/app/test-pmd/testpmd.h\nindex 121b756..cba9640 100644\n--- a/app/test-pmd/testpmd.h\n+++ b/app/test-pmd/testpmd.h\n@@ -764,6 +764,9 @@ int check_nb_rxq(queueid_t rxq);\n queueid_t get_allowed_max_nb_txq(portid_t *pid);\n int check_nb_txq(queueid_t txq);\n \n+void dump_pkt_burst(uint16_t port_id, uint16_t queue, struct rte_mbuf *pkts[],\n+\t uint16_t nb_pkts, int is_rx);\n+\n /*\n  * Work-around of a compilation error with ICC on invocations of the\n  * rte_be_to_cpu_16() function.\ndiff --git a/app/test-pmd/util.c b/app/test-pmd/util.c\nnew file mode 100644\nindex 0000000..3ba3b58\n--- /dev/null\n+++ b/app/test-pmd/util.c\n@@ -0,0 +1,151 @@\n+/* SPDX-License-Identifier: BSD-3-Clause\n+ * Copyright(c) 2010-2014 Intel Corporation\n+ * Copyright(c) 2018 Mellanox Technology\n+ */\n+\n+#include <stdio.h>\n+\n+#include <rte_net.h>\n+#include <rte_mbuf.h>\n+#include <rte_ether.h>\n+#include <rte_ethdev.h>\n+#include <rte_flow.h>\n+\n+#include \"testpmd.h\"\n+\n+static inline void\n+print_ether_addr(const char *what, struct ether_addr *eth_addr)\n+{\n+\tchar buf[ETHER_ADDR_FMT_SIZE];\n+\tether_format_addr(buf, ETHER_ADDR_FMT_SIZE, eth_addr);\n+\tprintf(\"%s%s\", what, buf);\n+}\n+\n+void\n+dump_pkt_burst(uint16_t port_id, uint16_t queue, struct rte_mbuf *pkts[],\n+\t      uint16_t nb_pkts, int is_rx)\n+{\n+\tstruct rte_mbuf  *mb;\n+\tstruct ether_hdr *eth_hdr;\n+\tuint16_t eth_type;\n+\tuint64_t ol_flags;\n+\tuint16_t i, packet_type;\n+\tuint16_t is_encapsulation;\n+\tchar buf[256];\n+\tstruct rte_net_hdr_lens hdr_lens;\n+\tuint32_t sw_packet_type;\n+\tuint16_t udp_port;\n+\tuint32_t vx_vni;\n+\n+\tif (!nb_pkts)\n+\t\treturn;\n+\tprintf(\"port %u/queue %u: %s %u packets\\n\",\n+\t\tport_id, queue,\n+\t       is_rx ? \"received\" : \"sent\",\n+\t       (unsigned int) nb_pkts);\n+\tfor (i = 0; i < nb_pkts; i++) {\n+\t\tmb = pkts[i];\n+\t\teth_hdr = rte_pktmbuf_mtod(mb, struct ether_hdr *);\n+\t\teth_type = RTE_BE_TO_CPU_16(eth_hdr->ether_type);\n+\t\tol_flags = mb->ol_flags;\n+\t\tpacket_type = mb->packet_type;\n+\t\tis_encapsulation = RTE_ETH_IS_TUNNEL_PKT(packet_type);\n+\n+\t\tprint_ether_addr(\"  src=\", &eth_hdr->s_addr);\n+\t\tprint_ether_addr(\" - dst=\", &eth_hdr->d_addr);\n+\t\tprintf(\" - type=0x%04x - length=%u - nb_segs=%d\",\n+\t\t       eth_type, (unsigned int) mb->pkt_len,\n+\t\t       (int)mb->nb_segs);\n+\t\tif (ol_flags & PKT_RX_RSS_HASH) {\n+\t\t\tprintf(\" - RSS hash=0x%x\", (unsigned int) mb->hash.rss);\n+\t\t\tprintf(\" - RSS queue=0x%x\", (unsigned int) queue);\n+\t\t}\n+\t\tif (ol_flags & PKT_RX_FDIR) {\n+\t\t\tprintf(\" - FDIR matched \");\n+\t\t\tif (ol_flags & PKT_RX_FDIR_ID)\n+\t\t\t\tprintf(\"ID=0x%x\",\n+\t\t\t\t       mb->hash.fdir.hi);\n+\t\t\telse if (ol_flags & PKT_RX_FDIR_FLX)\n+\t\t\t\tprintf(\"flex bytes=0x%08x %08x\",\n+\t\t\t\t       mb->hash.fdir.hi, mb->hash.fdir.lo);\n+\t\t\telse\n+\t\t\t\tprintf(\"hash=0x%x ID=0x%x \",\n+\t\t\t\t       mb->hash.fdir.hash, mb->hash.fdir.id);\n+\t\t}\n+\t\tif (ol_flags & PKT_RX_TIMESTAMP)\n+\t\t\tprintf(\" - timestamp %\"PRIu64\" \", mb->timestamp);\n+\t\tif (ol_flags & PKT_RX_QINQ)\n+\t\t\tprintf(\" - QinQ VLAN tci=0x%x, VLAN tci outer=0x%x\",\n+\t\t\t       mb->vlan_tci, mb->vlan_tci_outer);\n+\t\telse if (ol_flags & PKT_RX_VLAN)\n+\t\t\tprintf(\" - VLAN tci=0x%x\", mb->vlan_tci);\n+\t\tif (mb->packet_type) {\n+\t\t\trte_get_ptype_name(mb->packet_type, buf, sizeof(buf));\n+\t\t\tprintf(\" - hw ptype: %s\", buf);\n+\t\t}\n+\t\tsw_packet_type = rte_net_get_ptype(mb, &hdr_lens,\n+\t\t\t\t\tRTE_PTYPE_ALL_MASK);\n+\t\trte_get_ptype_name(sw_packet_type, buf, sizeof(buf));\n+\t\tprintf(\" - sw ptype: %s\", buf);\n+\t\tif (sw_packet_type & RTE_PTYPE_L2_MASK)\n+\t\t\tprintf(\" - l2_len=%d\", hdr_lens.l2_len);\n+\t\tif (sw_packet_type & RTE_PTYPE_L3_MASK)\n+\t\t\tprintf(\" - l3_len=%d\", hdr_lens.l3_len);\n+\t\tif (sw_packet_type & RTE_PTYPE_L4_MASK)\n+\t\t\tprintf(\" - l4_len=%d\", hdr_lens.l4_len);\n+\t\tif (sw_packet_type & RTE_PTYPE_TUNNEL_MASK)\n+\t\t\tprintf(\" - tunnel_len=%d\", hdr_lens.tunnel_len);\n+\t\tif (sw_packet_type & RTE_PTYPE_INNER_L2_MASK)\n+\t\t\tprintf(\" - inner_l2_len=%d\", hdr_lens.inner_l2_len);\n+\t\tif (sw_packet_type & RTE_PTYPE_INNER_L3_MASK)\n+\t\t\tprintf(\" - inner_l3_len=%d\", hdr_lens.inner_l3_len);\n+\t\tif (sw_packet_type & RTE_PTYPE_INNER_L4_MASK)\n+\t\t\tprintf(\" - inner_l4_len=%d\", hdr_lens.inner_l4_len);\n+\t\tif (is_encapsulation) {\n+\t\t\tstruct ipv4_hdr *ipv4_hdr;\n+\t\t\tstruct ipv6_hdr *ipv6_hdr;\n+\t\t\tstruct udp_hdr *udp_hdr;\n+\t\t\tuint8_t l2_len;\n+\t\t\tuint8_t l3_len;\n+\t\t\tuint8_t l4_len;\n+\t\t\tuint8_t l4_proto;\n+\t\t\tstruct  vxlan_hdr *vxlan_hdr;\n+\n+\t\t\tl2_len  = sizeof(struct ether_hdr);\n+\n+\t\t\t/* Do not support ipv4 option field */\n+\t\t\tif (RTE_ETH_IS_IPV4_HDR(packet_type)) {\n+\t\t\t\tl3_len = sizeof(struct ipv4_hdr);\n+\t\t\t\tipv4_hdr = rte_pktmbuf_mtod_offset(mb,\n+\t\t\t\tstruct ipv4_hdr *,\n+\t\t\t\tl2_len);\n+\t\t\t\tl4_proto = ipv4_hdr->next_proto_id;\n+\t\t\t} else {\n+\t\t\t\tl3_len = sizeof(struct ipv6_hdr);\n+\t\t\t\tipv6_hdr = rte_pktmbuf_mtod_offset(mb,\n+\t\t\t\tstruct ipv6_hdr *,\n+\t\t\t\tl2_len);\n+\t\t\t\tl4_proto = ipv6_hdr->proto;\n+\t\t\t}\n+\t\t\tif (l4_proto == IPPROTO_UDP) {\n+\t\t\t\tudp_hdr = rte_pktmbuf_mtod_offset(mb,\n+\t\t\t\tstruct udp_hdr *,\n+\t\t\t\tl2_len + l3_len);\n+\t\t\t\tl4_len = sizeof(struct udp_hdr);\n+\t\t\t\tvxlan_hdr = rte_pktmbuf_mtod_offset(mb,\n+\t\t\t\tstruct vxlan_hdr *,\n+\t\t\t\tl2_len + l3_len + l4_len);\n+\t\t\t\tudp_port = RTE_BE_TO_CPU_16(udp_hdr->dst_port);\n+\t\t\t\tvx_vni = rte_be_to_cpu_32(vxlan_hdr->vx_vni);\n+\t\t\t\tprintf(\" - VXLAN packet: packet type =%d, \"\n+\t\t\t\t       \"Destination UDP port =%d, VNI = %d\",\n+\t\t\t\t       packet_type, udp_port, vx_vni >> 8);\n+\t\t\t}\n+\t\t}\n+\t\tprintf(\" - %s queue=0x%x\", is_rx ? \"Receive\" : \"Send\",\n+\t\t\t(unsigned int) queue);\n+\t\tprintf(\"\\n\");\n+\t\trte_get_rx_ol_flag_list(mb->ol_flags, buf, sizeof(buf));\n+\t\tprintf(\"  ol_flags: %s\\n\", buf);\n+\t}\n+}\n",
    "prefixes": [
        "v6",
        "1/3"
    ]
}