get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

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

{
    "id": 66695,
    "url": "http://patches.dpdk.org/api/patches/66695/?format=api",
    "web_url": "http://patches.dpdk.org/project/dpdk/patch/1584351224-23500-4-git-send-email-hkalra@marvell.com/",
    "project": {
        "id": 1,
        "url": "http://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": "<1584351224-23500-4-git-send-email-hkalra@marvell.com>",
    "list_archive_url": "https://inbox.dpdk.org/dev/1584351224-23500-4-git-send-email-hkalra@marvell.com",
    "date": "2020-03-16T09:33:39",
    "name": "[3/8] net/octeontx: add fast mbuf free support",
    "commit_ref": null,
    "pull_url": null,
    "state": "accepted",
    "archived": true,
    "hash": "66068a3012bb58a4b1a7ecdf20a1ee6a36679610",
    "submitter": {
        "id": 1182,
        "url": "http://patches.dpdk.org/api/people/1182/?format=api",
        "name": "Harman Kalra",
        "email": "hkalra@marvell.com"
    },
    "delegate": {
        "id": 310,
        "url": "http://patches.dpdk.org/api/users/310/?format=api",
        "username": "jerin",
        "first_name": "Jerin",
        "last_name": "Jacob",
        "email": "jerinj@marvell.com"
    },
    "mbox": "http://patches.dpdk.org/project/dpdk/patch/1584351224-23500-4-git-send-email-hkalra@marvell.com/mbox/",
    "series": [
        {
            "id": 8923,
            "url": "http://patches.dpdk.org/api/series/8923/?format=api",
            "web_url": "http://patches.dpdk.org/project/dpdk/list/?series=8923",
            "date": "2020-03-16T09:33:36",
            "name": "add new features to octeontx PMD",
            "version": 1,
            "mbox": "http://patches.dpdk.org/series/8923/mbox/"
        }
    ],
    "comments": "http://patches.dpdk.org/api/patches/66695/comments/",
    "check": "fail",
    "checks": "http://patches.dpdk.org/api/patches/66695/checks/",
    "tags": {},
    "related": [],
    "headers": {
        "Return-Path": "<dev-bounces@dpdk.org>",
        "X-Original-To": "patchwork@inbox.dpdk.org",
        "Delivered-To": "patchwork@inbox.dpdk.org",
        "Received": [
            "from dpdk.org (dpdk.org [92.243.14.124])\n\tby inbox.dpdk.org (Postfix) with ESMTP id D727EA0563;\n\tMon, 16 Mar 2020 10:35:12 +0100 (CET)",
            "from [92.243.14.124] (localhost [127.0.0.1])\n\tby dpdk.org (Postfix) with ESMTP id 016201C0B4;\n\tMon, 16 Mar 2020 10:34:57 +0100 (CET)",
            "from mx0b-0016f401.pphosted.com (mx0b-0016f401.pphosted.com\n [67.231.156.173]) by dpdk.org (Postfix) with ESMTP id 9F4691C07C\n for <dev@dpdk.org>; Mon, 16 Mar 2020 10:34:54 +0100 (CET)",
            "from pps.filterd (m0045851.ppops.net [127.0.0.1])\n by mx0b-0016f401.pphosted.com (8.16.0.42/8.16.0.42) with SMTP id\n 02G9UN1H015039; Mon, 16 Mar 2020 02:34:54 -0700",
            "from sc-exch02.marvell.com ([199.233.58.182])\n by mx0b-0016f401.pphosted.com with ESMTP id 2yrxsme52d-1\n (version=TLSv1.2 cipher=ECDHE-RSA-AES256-SHA384 bits=256 verify=NOT);\n Mon, 16 Mar 2020 02:34:54 -0700",
            "from DC5-EXCH02.marvell.com (10.69.176.39) by SC-EXCH02.marvell.com\n (10.93.176.82) with Microsoft SMTP Server (TLS) id 15.0.1497.2;\n Mon, 16 Mar 2020 02:34:51 -0700",
            "from SC-EXCH03.marvell.com (10.93.176.83) by DC5-EXCH02.marvell.com\n (10.69.176.39) with Microsoft SMTP Server (TLS) id 15.0.1497.2;\n Mon, 16 Mar 2020 02:34:51 -0700",
            "from NAM11-BN8-obe.outbound.protection.outlook.com (104.47.58.169)\n by SC-EXCH03.marvell.com (10.93.176.83) with Microsoft SMTP Server (TLS) id\n 15.0.1497.2 via Frontend Transport; Mon, 16 Mar 2020 02:34:50 -0700",
            "from MN2PR18MB2848.namprd18.prod.outlook.com (2603:10b6:208:38::19)\n by MN2PR18MB3117.namprd18.prod.outlook.com (2603:10b6:208:162::16)\n with Microsoft SMTP Server (version=TLS1_2,\n cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.2814.14; Mon, 16 Mar\n 2020 09:34:31 +0000",
            "from MN2PR18MB2848.namprd18.prod.outlook.com\n ([fe80::f829:3e55:94f6:4efb]) by MN2PR18MB2848.namprd18.prod.outlook.com\n ([fe80::f829:3e55:94f6:4efb%5]) with mapi id 15.20.2814.021; Mon, 16 Mar 2020\n 09:34:31 +0000",
            "from hkarlara-OptiPlex-3046.marvell.com (115.113.156.2) by\n BMXPR01CA0006.INDPRD01.PROD.OUTLOOK.COM (2603:1096:b00:d::16) with Microsoft\n SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256) id\n 15.20.2814.13 via Frontend Transport; Mon, 16 Mar 2020 09:34:29 +0000"
        ],
        "DKIM-Signature": [
            "v=1; a=rsa-sha256; c=relaxed/relaxed; d=marvell.com;\n h=from : to : cc :\n subject : date : message-id : in-reply-to : references : content-type :\n mime-version; s=pfpt0818; bh=jktj7WmHyZQFDq5C8rQcUiCizurN5P+ZblzoDYE9rxY=;\n b=Lh5qUULHuBEZXRXoe4KHYovSVtfS/WClUlaGchdmvdVEizIVd6B/175moO/omL+zxjtN\n BA6ekRTadMIncMH8F88xxSEfI+/tHB8g9iFNy9CXuh9OwevfsDyiIikcK0Yn6o+7D2rq\n ZVaZUjIc0Y4/ykKityiLnEaRZPKSj/hgDW+FEMT7V0U60cXJY64zaYDJ5eD48O4F5FvC\n jPqKCiY+JW4cL74sXN9rSYNN4+VB4ky4jIn1mjleFFN7l8LVuZU9GuOw9VP9148b6MeA\n Xr8861jE3j5rluNJSlaE+X47aczv4H7z/bVRrTOqYtltDWJR/SCf6HAXCbEs5dfOgoA1 1g==",
            "v=1; a=rsa-sha256; c=relaxed/relaxed;\n d=marvell.onmicrosoft.com; s=selector1-marvell-onmicrosoft-com;\n h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck;\n bh=jktj7WmHyZQFDq5C8rQcUiCizurN5P+ZblzoDYE9rxY=;\n b=PvMElnbIWPGtjUCoMW99QWujPtTf6TT1ku8QWP68YHoNA/yozo1eEJD0bmeT/oGNiBLA7UeW+2KNXesYAfP8uLkqrKyzOhPaJiXI/zoegtdnK7FS6CdwjAk6/IzKfJMO9MFE2fla3QISzXiRYDCEhnwZmtilgaawLkf5yLzZjZo="
        ],
        "ARC-Seal": "i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none;\n b=ZwyfOeTfoF0Tq2p1fmpdKZYoUf9GOJT2uc/KrLoC0NeHhv5vZJK0QLsdhB2ApnSeQH3wwbV7ahD71O3BgOtY89R7kQSzTzGW5cqByXWQGd6Zaqg6kj+Wknoj39rtPHeahXtW69xo2bxtH6zB4PzdxkQEwf6vTeY+7xt+La9lXRy6V/JOzJjicLXN/1u7wAKTIuiVBjM164vqe6cYSSg3ecQpu11MFtq5+FRQV2/XqPlwM6TN0I6qa8/R0T8jp36Cjop67IPPFu6jFvDsQAvY0t9yfv6Sa6a27+j+K1j5zcjgizKLhPqSupmzRaaGacL5SKlM2eIH/t7a6/1EBUse/A==",
        "ARC-Message-Signature": "i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com;\n s=arcselector9901;\n h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck;\n bh=jktj7WmHyZQFDq5C8rQcUiCizurN5P+ZblzoDYE9rxY=;\n b=ghMoIgTJsK7QKEdkgoeqm2ikAKBCvPeSeVKNN7mqUy1el42iKU2pNewubcsStEgLtbLZKdmlioUIEevqAaBlkDoa9xR+45HyGh7G8tXoskn6b+3O74sI0FWz3KnSzFUWlCU5kZtc+FCmJYTFpSRdc1G3cfjvJ6q28AEV7M+rnNorDHQDsF8Dn3atQ+jb9ump2cj5HxyUedL8+ZlEq/LlHBdSjHN1us1chAR0329oYS4+EKyQlbDiZT0GQIHfW70gKw2PY5qBgeZEA/ognjuMPcjBhchBnidsic6l0JX3ixFKtGdyW3jgbz9VvA4UMHf9ngsChrVTPJZD3gzIRA4/RA==",
        "ARC-Authentication-Results": "i=1; mx.microsoft.com 1; spf=pass\n smtp.mailfrom=marvell.com; dmarc=pass action=none header.from=marvell.com;\n dkim=pass header.d=marvell.com; arc=none",
        "From": "Harman Kalra <hkalra@marvell.com>",
        "To": "<jerinj@marvell.com>, <john.mcnamara@intel.com>,\n <marko.kovacevic@intel.com>",
        "CC": "<dev@dpdk.org>, <vattunuru@marvell.com>, Harman Kalra <hkalra@marvell.com>",
        "Date": "Mon, 16 Mar 2020 15:03:39 +0530",
        "Message-ID": "<1584351224-23500-4-git-send-email-hkalra@marvell.com>",
        "X-Mailer": [
            "git-send-email 2.7.4",
            "git-send-email 2.7.4"
        ],
        "In-Reply-To": "<1584351224-23500-1-git-send-email-hkalra@marvell.com>",
        "References": "<1584351224-23500-1-git-send-email-hkalra@marvell.com>",
        "Content-Type": "text/plain",
        "X-ClientProxiedBy": "BMXPR01CA0006.INDPRD01.PROD.OUTLOOK.COM\n (2603:1096:b00:d::16) To MN2PR18MB2848.namprd18.prod.outlook.com\n (2603:10b6:208:38::19)",
        "MIME-Version": "1.0",
        "X-MS-Exchange-MessageSentRepresentingType": "1",
        "X-Originating-IP": "[115.113.156.2]",
        "X-MS-PublicTrafficType": "Email",
        "X-MS-Office365-Filtering-Correlation-Id": "d37e15ee-5d57-41f7-6246-08d7c98d3adc",
        "X-MS-TrafficTypeDiagnostic": "MN2PR18MB3117:",
        "X-MS-Exchange-Transport-Forked": "True",
        "X-Microsoft-Antispam-PRVS": "\n <MN2PR18MB3117FDA0C56C5980021884CDC5F90@MN2PR18MB3117.namprd18.prod.outlook.com>",
        "X-MS-Oob-TLC-OOBClassifiers": "OLM:5236;",
        "X-Forefront-PRVS": "03449D5DD1",
        "X-Forefront-Antispam-Report": "SFV:NSPM;\n SFS:(10009020)(4636009)(366004)(136003)(376002)(39860400002)(346002)(396003)(199004)(52116002)(7696005)(478600001)(4326008)(8676002)(8936002)(107886003)(26005)(66556008)(2906002)(86362001)(5660300002)(36756003)(55236004)(16526019)(2616005)(956004)(66946007)(6486002)(66476007)(81156014)(81166006)(6666004)(186003)(316002);\n DIR:OUT; SFP:1101; SCL:1; SRVR:MN2PR18MB3117;\n H:MN2PR18MB2848.namprd18.prod.outlook.com; FPR:; SPF:None; LANG:en;\n PTR:InfoNoRecords; A:1;",
        "Received-SPF": "None (protection.outlook.com: marvell.com does not designate\n permitted sender hosts)",
        "X-MS-Exchange-SenderADCheck": "1",
        "X-Microsoft-Antispam": "BCL:0;",
        "X-Microsoft-Antispam-Message-Info": "\n Haxd/4VTNZFIwuGVa8fklmZnrfUw6l2BOEXB4vROoqnMn7uz4ORgwDWbXEtYlmEkPhGFZ2imNqWt3yR5tmnxOQnzeWSOpj/VbNFQw29A+EzUQp2J79IqeqtCguwVFdVEnqWjmkuBScHv1fclwP1ilKr9KixbejdSAEPjpzZbZMLEXQcVBZB/CG6ZqRqH/AlzLV0PKWga1CCTArnXefa/kp1G5uLKmusVOxO1FyBtdSy17qdNozEQ/MAsEzL/iHzi16wlCXAaz1otP5VzSUaqOs5y1S7rxiYP/uPUZLoeUDq4NumcKsPPGWoilwERB8YyjBaDfCyoQRRD7lYgFAKM4/NoqEWb4xWqJ6XwiJIJC+y2ZHFQ8GhOwFr8fmtGwQDxrVbsrCQxrbxXdDIIQGpxCgiTkyQOo1y+6PCfBu+Y1cokxDhmzVGJu4pF+UfmdI7N",
        "X-MS-Exchange-AntiSpam-MessageData": "\n 2yVy8w0EDJtjsd6/Hq/VKBSnPUdDz0pFUlBkHm2lGz9Rld5A01//XHtqBhm3uYkqN1PTLCS67GuOJTLTDSuY6uhsJTJA3RuKVqv2520NKwpTKm+Y5kV9zlbHM7iE+K5mRRb/E7u/kAPT2UA6tjUR5A==",
        "X-MS-Exchange-CrossTenant-Network-Message-Id": "\n d37e15ee-5d57-41f7-6246-08d7c98d3adc",
        "X-MS-Exchange-CrossTenant-OriginalArrivalTime": "16 Mar 2020 09:34:31.4735 (UTC)",
        "X-MS-Exchange-CrossTenant-FromEntityHeader": "Hosted",
        "X-MS-Exchange-CrossTenant-Id": "70e1fb47-1155-421d-87fc-2e58f638b6e0",
        "X-MS-Exchange-CrossTenant-MailboxType": "HOSTED",
        "X-MS-Exchange-CrossTenant-UserPrincipalName": "\n VCcP9fozoNvIzdZpBiaTpyo9pSMiOVgnVbhXQ4Qi9rSlCfUNGBYQwrEF8HVzu6d/tCskP5xhPsTgFQifZAtoXw==",
        "X-MS-Exchange-Transport-CrossTenantHeadersStamped": "MN2PR18MB3117",
        "X-OriginatorOrg": "marvell.com",
        "X-Proofpoint-Virus-Version": "vendor=fsecure engine=2.50.10434:6.0.138, 18.0.572\n definitions=2020-03-16_02:2020-03-12,\n 2020-03-16 signatures=0",
        "Subject": "[dpdk-dev] [PATCH 3/8] net/octeontx: add fast mbuf free support",
        "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 <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 <mailto:dev-request@dpdk.org?subject=subscribe>",
        "Errors-To": "dev-bounces@dpdk.org",
        "Sender": "\"dev\" <dev-bounces@dpdk.org>"
    },
    "content": "This patch adds capability to fast release of mbuf\nfollowing successful transmission.\n\nSigned-off-by: Harman Kalra <hkalra@marvell.com>\n---\n drivers/net/octeontx/octeontx_ethdev.c |  4 +-\n drivers/net/octeontx/octeontx_ethdev.h |  1 +\n drivers/net/octeontx/octeontx_rxtx.c   |  9 +--\n drivers/net/octeontx/octeontx_rxtx.h   | 93 ++++++++++++++++++++++++--\n 4 files changed, 98 insertions(+), 9 deletions(-)",
    "diff": "diff --git a/drivers/net/octeontx/octeontx_ethdev.c b/drivers/net/octeontx/octeontx_ethdev.c\nindex d6adbbc93..97b4298fe 100644\n--- a/drivers/net/octeontx/octeontx_ethdev.c\n+++ b/drivers/net/octeontx/octeontx_ethdev.c\n@@ -267,7 +267,9 @@ octeontx_tx_offload_flags(struct rte_eth_dev *eth_dev)\n \tstruct octeontx_nic *nic = octeontx_pmd_priv(eth_dev);\n \tuint16_t flags = 0;\n \n-\t/* Created function for supoorting future offloads */\n+\tif (!(nic->tx_offloads & DEV_TX_OFFLOAD_MBUF_FAST_FREE))\n+\t\tflags |= OCCTX_TX_OFFLOAD_MBUF_NOFF_F;\n+\n \tif (nic->tx_offloads & DEV_TX_OFFLOAD_MULTI_SEGS)\n \t\tflags |= OCCTX_TX_MULTI_SEG_F;\n \ndiff --git a/drivers/net/octeontx/octeontx_ethdev.h b/drivers/net/octeontx/octeontx_ethdev.h\nindex 06223e6e7..1abe1703b 100644\n--- a/drivers/net/octeontx/octeontx_ethdev.h\n+++ b/drivers/net/octeontx/octeontx_ethdev.h\n@@ -34,6 +34,7 @@\n \t\t\t\t\t DEV_RX_OFFLOAD_JUMBO_FRAME)\n \n #define OCTEONTX_TX_OFFLOADS\t\t(DEV_TX_OFFLOAD_MT_LOCKFREE    |  \\\n+\t\t\t\t\t DEV_TX_OFFLOAD_MBUF_FAST_FREE |  \\\n \t\t\t\t\t DEV_TX_OFFLOAD_MULTI_SEGS)\n \n static inline struct octeontx_nic *\ndiff --git a/drivers/net/octeontx/octeontx_rxtx.c b/drivers/net/octeontx/octeontx_rxtx.c\nindex 3de88e187..c817f7179 100644\n--- a/drivers/net/octeontx/octeontx_rxtx.c\n+++ b/drivers/net/octeontx/octeontx_rxtx.c\n@@ -41,7 +41,7 @@ octeontx_recv_pkts(void *rx_queue, struct rte_mbuf **rx_pkts, uint16_t nb_pkts)\n \treturn count; /* return number of pkts received */\n }\n \n-#define T(name, f1, sz, flags)\t\t\t\t\t\\\n+#define T(name, f1, f0, sz, flags)\t\t\t\t\t\\\n static uint16_t __rte_noinline\t__hot\t\t\t\t\t\\\n octeontx_xmit_pkts_ ##name(void *tx_queue,\t\t\t\t\\\n \t\t\tstruct rte_mbuf **tx_pkts, uint16_t pkts)\t\\\n@@ -60,14 +60,15 @@ octeontx_set_tx_function(struct rte_eth_dev *dev)\n {\n \tstruct octeontx_nic *nic = octeontx_pmd_priv(dev);\n \n-\tconst eth_tx_burst_t tx_burst_func[2] = {\n-#define T(name, f0, sz, flags)\t\t\t\\\n-\t[f0] =  octeontx_xmit_pkts_ ##name,\n+\tconst eth_tx_burst_t tx_burst_func[2][2] = {\n+#define T(name, f1, f0, sz, flags)\t\t\t\\\n+\t[f1][f0] =  octeontx_xmit_pkts_ ##name,\n \n OCCTX_TX_FASTPATH_MODES\n #undef T\n \t};\n \n \tdev->tx_pkt_burst = tx_burst_func\n+\t\t[!!(nic->tx_offload_flags & OCCTX_TX_OFFLOAD_MBUF_NOFF_F)]\n \t\t[!!(nic->tx_offload_flags & OCCTX_TX_MULTI_SEG_F)];\n }\ndiff --git a/drivers/net/octeontx/octeontx_rxtx.h b/drivers/net/octeontx/octeontx_rxtx.h\nindex 6182cd8ee..2383a8eb6 100644\n--- a/drivers/net/octeontx/octeontx_rxtx.h\n+++ b/drivers/net/octeontx/octeontx_rxtx.h\n@@ -22,6 +22,7 @@\n #define OCCTX_RX_MULTI_SEG_F\t\tBIT(15)\n \n #define OCCTX_TX_OFFLOAD_NONE\t\t(0)\n+#define OCCTX_TX_OFFLOAD_MBUF_NOFF_F\tBIT(3)\n \n #define OCCTX_TX_MULTI_SEG_F\t\tBIT(15)\n /* Packet type table */\n@@ -114,9 +115,75 @@ ptype_table[PTYPE_SIZE][PTYPE_SIZE][PTYPE_SIZE] = {\n };\n \n \n+static __rte_always_inline uint64_t\n+octeontx_pktmbuf_detach(struct rte_mbuf *m)\n+{\n+\tstruct rte_mempool *mp = m->pool;\n+\tuint32_t mbuf_size, buf_len;\n+\tstruct rte_mbuf *md;\n+\tuint16_t priv_size;\n+\tuint16_t refcount;\n+\n+\t/* Update refcount of direct mbuf */\n+\tmd = rte_mbuf_from_indirect(m);\n+\trefcount = rte_mbuf_refcnt_update(md, -1);\n+\n+\tpriv_size = rte_pktmbuf_priv_size(mp);\n+\tmbuf_size = (uint32_t)(sizeof(struct rte_mbuf) + priv_size);\n+\tbuf_len = rte_pktmbuf_data_room_size(mp);\n+\n+\tm->priv_size = priv_size;\n+\tm->buf_addr = (char *)m + mbuf_size;\n+\tm->buf_iova = rte_mempool_virt2iova(m) + mbuf_size;\n+\tm->buf_len = (uint16_t)buf_len;\n+\trte_pktmbuf_reset_headroom(m);\n+\tm->data_len = 0;\n+\tm->ol_flags = 0;\n+\tm->next = NULL;\n+\tm->nb_segs = 1;\n+\n+\t/* Now indirect mbuf is safe to free */\n+\trte_pktmbuf_free(m);\n+\n+\tif (refcount == 0) {\n+\t\trte_mbuf_refcnt_set(md, 1);\n+\t\tmd->data_len = 0;\n+\t\tmd->ol_flags = 0;\n+\t\tmd->next = NULL;\n+\t\tmd->nb_segs = 1;\n+\t\treturn 0;\n+\t} else {\n+\t\treturn 1;\n+\t}\n+}\n+\n+static __rte_always_inline uint64_t\n+octeontx_prefree_seg(struct rte_mbuf *m)\n+{\n+\tif (likely(rte_mbuf_refcnt_read(m) == 1)) {\n+\t\tif (!RTE_MBUF_DIRECT(m))\n+\t\t\treturn octeontx_pktmbuf_detach(m);\n+\n+\t\tm->next = NULL;\n+\t\tm->nb_segs = 1;\n+\t\treturn 0;\n+\t} else if (rte_mbuf_refcnt_update(m, -1) == 0) {\n+\t\tif (!RTE_MBUF_DIRECT(m))\n+\t\t\treturn octeontx_pktmbuf_detach(m);\n+\n+\t\trte_mbuf_refcnt_set(m, 1);\n+\t\tm->next = NULL;\n+\t\tm->nb_segs = 1;\n+\t\treturn 0;\n+\t}\n+\n+\t/* Mbuf is having refcount more than 1 so need not to be freed */\n+\treturn 1;\n+}\n+\n static __rte_always_inline uint16_t\n __octeontx_xmit_prepare(struct rte_mbuf *tx_pkt, uint64_t *cmd_buf,\n-\t\t\tconst uint16_t flag __rte_unused)\n+\t\t\tconst uint16_t flag)\n {\n \tuint16_t gaura_id, nb_desc = 0;\n \n@@ -124,6 +191,13 @@ __octeontx_xmit_prepare(struct rte_mbuf *tx_pkt, uint64_t *cmd_buf,\n \tcmd_buf[nb_desc++] = tx_pkt->data_len & 0xffff;\n \tcmd_buf[nb_desc++] = 0x0;\n \n+\t/* SEND_HDR[DF] bit controls if buffer is to be freed or\n+\t * not, as SG_DESC[I] and SEND_HDR[II] are clear.\n+\t */\n+\tif (flag & OCCTX_TX_OFFLOAD_MBUF_NOFF_F)\n+\t\tcmd_buf[0] |= (octeontx_prefree_seg(tx_pkt) <<\n+\t\t\t       58);\n+\n \t/* Mark mempool object as \"put\" since it is freed by PKO */\n \tif (!(cmd_buf[0] & (1ULL << 58)))\n \t\t__mempool_check_cookies(tx_pkt->pool, (void **)&tx_pkt,\n@@ -144,7 +218,7 @@ __octeontx_xmit_prepare(struct rte_mbuf *tx_pkt, uint64_t *cmd_buf,\n \n static __rte_always_inline uint16_t\n __octeontx_xmit_mseg_prepare(struct rte_mbuf *tx_pkt, uint64_t *cmd_buf,\n-\t\t\tconst uint16_t flag __rte_unused)\n+\t\t\tconst uint16_t flag)\n {\n \tuint16_t nb_segs, nb_desc = 0;\n \tuint16_t gaura_id, len = 0;\n@@ -169,6 +243,14 @@ __octeontx_xmit_mseg_prepare(struct rte_mbuf *tx_pkt, uint64_t *cmd_buf,\n \t\t\t\t   PKO_SEND_GATHER_GAUAR((long)gaura_id) |\n \t\t\t\t   tx_pkt->data_len;\n \n+\t\t/* SG_DESC[I] bit controls if buffer is to be freed or\n+\t\t * not, as SEND_HDR[DF] and SEND_HDR[II] are clear.\n+\t\t */\n+\t\tif (flag & OCCTX_TX_OFFLOAD_MBUF_NOFF_F) {\n+\t\t\tcmd_buf[nb_desc] |=\n+\t\t\t     (octeontx_prefree_seg(tx_pkt) << 57);\n+\t\t}\n+\n \t\t/* Mark mempool object as \"put\" since it is freed by\n \t\t * PKO.\n \t\t */\n@@ -222,10 +304,13 @@ __octeontx_xmit_pkts(void *tx_queue, struct rte_mbuf **tx_pkts,\n uint16_t\n octeontx_recv_pkts(void *rx_queue, struct rte_mbuf **rx_pkts, uint16_t nb_pkts);\n \n+#define NOFF_F       OCCTX_TX_OFFLOAD_MBUF_NOFF_F\n #define MULT_F       OCCTX_TX_MULTI_SEG_F\n /* [NOFF] [MULTI_SEG] */\n #define OCCTX_TX_FASTPATH_MODES\t\t\t\t\t\t      \\\n-T(no_offload,\t\t\t\t0,\t4,   OCCTX_TX_OFFLOAD_NONE)   \\\n-T(mseg,\t\t\t\t\t1,\t14,  MULT_F)\t\t      \\\n+T(no_offload,\t\t\t\t0, 0,\t4,   OCCTX_TX_OFFLOAD_NONE)   \\\n+T(mseg,\t\t\t\t\t0, 1,\t14,  MULT_F)\t\t      \\\n+T(noff,\t\t\t\t\t1, 0,\t4,   NOFF_F)\t\t      \\\n+T(noff_mseg,\t\t\t\t1, 1,\t14,  NOFF_F | MULT_F)\n \n  #endif /* __OCTEONTX_RXTX_H__ */\n",
    "prefixes": [
        "3/8"
    ]
}