get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

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

{
    "id": 29270,
    "url": "http://patches.dpdk.org/api/patches/29270/?format=api",
    "web_url": "http://patches.dpdk.org/project/dpdk/patch/20170928113344.12248-38-shreyansh.jain@nxp.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": "<20170928113344.12248-38-shreyansh.jain@nxp.com>",
    "list_archive_url": "https://inbox.dpdk.org/dev/20170928113344.12248-38-shreyansh.jain@nxp.com",
    "date": "2017-09-28T11:33:41",
    "name": "[dpdk-dev,v5,37/40] net/dpaa: support Scattered Rx",
    "commit_ref": null,
    "pull_url": null,
    "state": "superseded",
    "archived": true,
    "hash": "54534ec7b9811859efb4455a2c5ad9f0fdd36b11",
    "submitter": {
        "id": 497,
        "url": "http://patches.dpdk.org/api/people/497/?format=api",
        "name": "Shreyansh Jain",
        "email": "shreyansh.jain@nxp.com"
    },
    "delegate": null,
    "mbox": "http://patches.dpdk.org/project/dpdk/patch/20170928113344.12248-38-shreyansh.jain@nxp.com/mbox/",
    "series": [],
    "comments": "http://patches.dpdk.org/api/patches/29270/comments/",
    "check": "success",
    "checks": "http://patches.dpdk.org/api/patches/29270/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 9761A1B237;\n\tThu, 28 Sep 2017 13:25:59 +0200 (CEST)",
            "from NAM01-SN1-obe.outbound.protection.outlook.com\n\t(mail-sn1nam01on0043.outbound.protection.outlook.com [104.47.32.43])\n\tby dpdk.org (Postfix) with ESMTP id 401D21B219\n\tfor <dev@dpdk.org>; Thu, 28 Sep 2017 13:24:25 +0200 (CEST)",
            "from BN6PR03CA0091.namprd03.prod.outlook.com (10.164.122.157) by\n\tCY1PR03MB2364.namprd03.prod.outlook.com (10.166.207.151) with\n\tMicrosoft SMTP Server (version=TLS1_2,\n\tcipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P256) id\n\t15.20.77.7; Thu, 28 Sep 2017 11:24:18 +0000",
            "from BN1AFFO11FD011.protection.gbl (2a01:111:f400:7c10::136) by\n\tBN6PR03CA0091.outlook.office365.com (2603:10b6:405:6f::29) with\n\tMicrosoft SMTP Server (version=TLS1_2,\n\tcipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384) id\n\t15.20.56.11 via Frontend Transport; Thu, 28 Sep 2017 11:24:18 +0000",
            "from tx30smr01.am.freescale.net (192.88.168.50) by\n\tBN1AFFO11FD011.mail.protection.outlook.com (10.58.52.71) with\n\tMicrosoft SMTP Server (version=TLS1_0,\n\tcipher=TLS_RSA_WITH_AES_256_CBC_SHA) id 15.20.56.11\n\tvia Frontend Transport; Thu, 28 Sep 2017 11:24:18 +0000",
            "from Tophie.ap.freescale.net ([10.232.14.39])\n\tby tx30smr01.am.freescale.net (8.14.3/8.14.0) with ESMTP id\n\tv8SBMpGD016035; Thu, 28 Sep 2017 04:24:15 -0700"
        ],
        "Authentication-Results": "spf=fail (sender IP is 192.88.168.50)\n\tsmtp.mailfrom=nxp.com; nxp.com; dkim=none (message not signed)\n\theader.d=none;nxp.com; dmarc=fail action=none header.from=nxp.com;",
        "Received-SPF": "Fail (protection.outlook.com: domain of nxp.com does not\n\tdesignate 192.88.168.50 as permitted sender)\n\treceiver=protection.outlook.com; \n\tclient-ip=192.88.168.50; helo=tx30smr01.am.freescale.net;",
        "From": "Shreyansh Jain <shreyansh.jain@nxp.com>",
        "To": "<dev@dpdk.org>",
        "CC": "<ferruh.yigit@intel.com>, <hemant.agrawal@nxp.com>",
        "Date": "Thu, 28 Sep 2017 17:03:41 +0530",
        "Message-ID": "<20170928113344.12248-38-shreyansh.jain@nxp.com>",
        "X-Mailer": "git-send-email 2.9.3",
        "In-Reply-To": "<20170928113344.12248-1-shreyansh.jain@nxp.com>",
        "References": "<20170909112132.13936-1-shreyansh.jain@nxp.com>\n\t<20170928113344.12248-1-shreyansh.jain@nxp.com>",
        "X-EOPAttributedMessage": "0",
        "X-Matching-Connectors": "131510714582412817;\n\t(91ab9b29-cfa4-454e-5278-08d120cd25b8); ()",
        "X-Forefront-Antispam-Report": "CIP:192.88.168.50; IPV:NLI; CTRY:US; EFV:NLI;\n\tSFV:NSPM;\n\tSFS:(10009020)(6009001)(7966004)(336005)(346002)(376002)(39860400002)(39380400002)(2980300002)(1110001)(1109001)(339900001)(189002)(199003)(86362001)(105606002)(81166006)(81156014)(33646002)(8676002)(8656003)(2351001)(106466001)(50226002)(53936002)(4326008)(97736004)(104016004)(54906003)(16586007)(47776003)(316002)(50466002)(48376002)(189998001)(5660300001)(2950100002)(6916009)(2906002)(5003940100001)(8936002)(68736007)(6666003)(356003)(36756003)(85426001)(50986999)(76176999)(77096006)(305945005)(498600001)(1076002)(83323001);\n\tDIR:OUT; SFP:1101; SCL:1; SRVR:CY1PR03MB2364;\n\tH:tx30smr01.am.freescale.net; \n\tFPR:; SPF:Fail; PTR:InfoDomainNonexistent; MX:1; A:1; LANG:en; ",
        "X-Microsoft-Exchange-Diagnostics": [
            "1; BN1AFFO11FD011;\n\t1:ti+N8t13G2tSdFaUQzOIK7iVkyDLs4rZpK2QVYvrFUmw3Ns7YT3c0S1HpLeTe9jo4BCKwjvNBoDYoTcVU3ykQnKFAGhBdytpTffTzsqK6BLd1M5I6YO4ATxiUXLDZPJS",
            "1; CY1PR03MB2364;\n\t3:ivilwYtWvyN5JMBWo7bOCtTKGzhOBThPhnhaKwihjuZkzs/fPiCS0+lTYMm9VMfCXwi+DciN+zyI/Yk1Y1QoFuMuupU9A4G/vGzOAsVrIbrTmhojCKHg8kwDQ4mMrFs6H3hIV0z1qLoJdF4vqRwHzs8rCsgJcrUXnPL2lN400DN9dQodr/6QtoR8rU4GyZbyE21n6i+8zpxDu2nr4XTnglCBi7wF8BgnPfqDnnMLsJ3ydFLZJwDh7mrl9GoVdZJ7w89o9W7tjEGSYrmqXEtEdpa/4tfX5as9sOr78rwmaaCyPzwENHhFjh8sUibd6wvdVeKqwwIrRBDGTBQjKwGj6CX+OVn3pw6Ri+cwAcVi8u0=;\n\t25:t+CAzaV4HP1Ba0AjeGav0GwOGA1MkLdURgsNPH+VTvhnXEtnvTzmG9OaakUFd6jtVBMf7+NXe1Jy9Ii6Zkse0eD3G+S6V+xXqKfdgRVrCTkdzmww/Bgt2vdHG3ZJyPXBwYiBpshGAokwbdReU3lIfiAsgblBo8rt5PCNuFn0FbTA5Nv17RuwZSMGlU2K9zMxAH1WltRSkO4zx4BsfILkPebB3QF3jrzXzd+Jmtwn5kHp75z7ex58y607bYCAAjJSVWQyuYpzNGmg92eBWXMj5hSe6DFiq28X9hVuOvysD8pFYPVNQoX2yg/ecmdTA3zMXly8eLkeK6nEwHyLt7UoqA==",
            "1; CY1PR03MB2364;\n\t31:6BGZOVBr9SgeCN1KYcXAfok0S5qgow0n/1I6jjFguPl23GiWfcgeAlPAvqtDVhPyCvCsH9GN1o2lYP5WDuOX/ZanMRoR8k3QkZ9zNW/Vha8eOet3cBEMKMk06usZdhMARWUD0fV7t+Xn3JQfOycTSecTbe8ZEawjvlrmMQnHOnxU7FeosbF8+WLpgAOjM8AiMgjCm8E0rEMA1hsVOno0cjlFSL8m815F4nEaYEkQvAg=;\n\t4:aFBBDQVgg2a2pom7rUGFQDBDf3M5Ceblp6qSrWh8sAweYU76+/CRqOlhDa33BWdsV7Bq7BgOSYO5onpNU6GIQixCgGs1IdzIGMasqh3DIp18pkZkSkbF3ZWfZHa3FBOGtuPDRr8w+PeVgJl1K/oMa29BD+e/9uzzprAsj/KckCBO+DH7x7/y22gWL63NoD4f8E8gEqlaDdZR7J1uIcDkMhyNm/m3cK3zP5KVmgM7PQV94nntS8TjeadUC5giYoW47j2E16WsxkK33FaK/xuResZ4ikgu9F0/A9UvAzVvv2Y=",
            "=?us-ascii?Q?1; CY1PR03MB2364;\n\t23:Lg5zykZnP0XlS4vwXZJpnlWXodSJrc0K5uHbt3GSq?=\n\t5PofpahOz/wM2r2RFGOFky27WVwYzswh64IJG00u+y3tOPh9KB2yqLJ50hXrvTLaNQXan0Lj8GXm/X31zLrgsoRllNHGWqzti5gu2ay7aWhwGeYgztIiO5V2GCapSzKDgrmherAmnLZnTgrhn7UE58Rwfn6ZfHAYxlpwjV+DWTXqxEpb2i3+oBj/Jw8Pi6yNzlMgafyil95Sdloy9rA0yfheOiEcvp0FI3i9SUW7n8Xddh42mTpHFA9HC9gjOUxKI/mVLzTEee2xmEdGUdLtwlyTVSAlMarF0r3R2aGNEtazbssTrRu4zp53SpEKHsX6Vvy8cbd1EA3rwNwtR4H+nooCWFF+f886WLdg9XLXq+e7EdgHflEwxD//WgrSM4ePDQESjbIRTqZBvZeyAcSqH2sXObR0LmicBHIcxAHi+1AKaczxRatAP/yThMRJMmD9XlIbEP6StB2g/FVwMnJuohTdLRsVbK6mnc+Zq9XQNS2ddZpwqNJIZAGkTtfrK282IMD2LpJ7hGPBLNldX5+KjgmGSJcsr6k22qbNDx4DMMLyH4A1x5/jkB23lGygstxsxjpFgNpcKgTK4+dVUZJCEEU26/uQJjLFEZ0xtHMSIpgzT4B3cmLMiFC01FI8X5BWNWNAkkue2CrDGEM62ttJQrxM4Fzn4/0vJNEr6WAYrlYKHezisbk+EWlHyHGA5hVSeWfXoHG7dhZTJTLz5l/KRb2mSOap1EM231TPB8Nb/lxAwjko78DjQYzEYjdrjYzTDBEnG5JyTHQ5l9YUnXMa4CMduKzaFofVdpn/D3oGkMqnHR436hRAR8FDmmi8mIUzH2dfmWfMm4GaRPQaDkmC7VV4+TD89Xs6pXZFRk9wmdzu4OmkiChGQuUWbTKkWBiM5EwT3r87bAIUgEGxH3Z4KKxCTjc20B4/c/C/4PY6/cbmWgImpmQzCdHsquT4tAujbkjcnGypjM1sFxPJAYpXvg5ghSRywqlXSmHxi31XLRlLJmJfdr7fwdeSYHqXB/wo0DOYyoE5AtNZMOQQXh+U2WCZMZm5L+UFB+DbL1j38wkhGa+1tEtOcuPlYdFOyJtPKg0KjwPic0WU4xZPtYt2HoqZaHSZFY34TMJCYH77Nm5EsSShhVDx32Pi5RyDoJu3eAs7nonkPwvKMH+wLdnASasRknYseTVjZChosoPEzoa/Q==",
            "1; CY1PR03MB2364;\n\t6:muVM6QQGNuRb7mEdckmaWqIgJyUnXk4A2gEOesyhfIhFvP5lbfr2emtjHDxTp3skmztBP93pm8sJ9lV9hYiujdNtDobu8DcwR3KUi0/FHa4Gnc3fh9u3Uy6MPIFM3zDA0ADnaaKqzpBoiWF2mg4FTMpyNLrUrrN71Jr+nEySbf/qfHyuY4XskslK9bzn2GpUHp+9X+GOEAP+RKe+OBxrC5mVWIRXQ5WsZrFE+3zEJzjwx+k/d5h83my/BajZHBbMMXO8XBD2/JilA120I2dko3l1Zmqk8mmAcBJpojKoUfxUEY6HWBypDGyTWyLQYIJYeJ5O4VSRuJorRAj6RbbX5Q==;\n\t5:P8Sht+bYWxnkbWsm/QNGg9RNM+Z37e6MljL6yAv2dq9mSK+WLvs8iWsGuJg4m3fA/MVhd9oVndzPMAnxsmhIg+4z+P55xArIyHNFwufStEFvzR3c+gV//GByWYV2EDN5cc2qilTYOsOAiH9AJaPA5w==;\n\t24:Cii60sjEp2s5H2GGtDjW2P/AaxO1TiXm6Z+bQ0Hbzb1+64w4/jU4fIVmwOiFU8Pt2tivzMWdvXY7TYiVpQOWEArwjvId35D/O9wsexgT0aE=;\n\t7:VDdLBd+MJLeNwWCq0EDsftAj6PBYLKa98/SpNvoZZWi5UsY4TNNyAdMhsBdg4u2Qix9vRm2Z8hrJaRTz2WawsX85MMwRz6alOJVlK+mJ869I2k6bTS5cAFiNrC6ECA/dUUkxThPt5JypKdku/KruqrYJ363KZINbPJf9Jxra+pnH8IZR2+ct7MLpo+XZrr1e7tQiaYwWBG1Srz9TVWwizMSabl2lDKaZ7hiGAxzPWWo="
        ],
        "MIME-Version": "1.0",
        "Content-Type": "text/plain",
        "X-MS-PublicTrafficType": "Email",
        "X-MS-Office365-Filtering-Correlation-Id": "da56af79-4cff-4d85-4cb1-08d50663754c",
        "X-Microsoft-Antispam": "UriScan:; BCL:0; PCL:0;\n\tRULEID:(22001)(2017052603199)(201703131430075)(201703131517081);\n\tSRVR:CY1PR03MB2364; ",
        "X-MS-TrafficTypeDiagnostic": "CY1PR03MB2364:",
        "X-Exchange-Antispam-Report-Test": "UriScan:(185117386973197);",
        "X-Microsoft-Antispam-PRVS": "<CY1PR03MB23646DA716367B74D6F4CCE290790@CY1PR03MB2364.namprd03.prod.outlook.com>",
        "X-Exchange-Antispam-Report-CFA-Test": "BCL:0; PCL:0;\n\tRULEID:(100000700101)(100105000095)(100000701101)(100105300095)(100000702101)(100105100095)(6095135)(2401047)(5005006)(8121501046)(100000703101)(100105400095)(93006095)(93001095)(10201501046)(3002001)(6055026)(6096035)(20161123563025)(20161123565025)(20161123561025)(20161123559100)(201703131430075)(201703131441075)(201703131448075)(201703131433075)(201703161259150)(20161123556025)(201708071742011)(100000704101)(100105200095)(100000705101)(100105500095);\n\tSRVR:CY1PR03MB2364; BCL:0; PCL:0;\n\tRULEID:(100000800101)(100110000095)(100000801101)(100110300095)(100000802101)(100110100095)(100000803101)(100110400095)(400006)(100000804101)(100110200095)(100000805101)(100110500095);\n\tSRVR:CY1PR03MB2364; ",
        "X-Forefront-PRVS": "0444EB1997",
        "SpamDiagnosticOutput": "1:99",
        "SpamDiagnosticMetadata": "NSPM",
        "X-MS-Exchange-CrossTenant-OriginalArrivalTime": "28 Sep 2017 11:24:18.0540\n\t(UTC)",
        "X-MS-Exchange-CrossTenant-Id": "5afe0b00-7697-4969-b663-5eab37d5f47e",
        "X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp": "TenantId=5afe0b00-7697-4969-b663-5eab37d5f47e;\n\tIp=[192.88.168.50]; \n\tHelo=[tx30smr01.am.freescale.net]",
        "X-MS-Exchange-CrossTenant-FromEntityHeader": "HybridOnPrem",
        "X-MS-Exchange-Transport-CrossTenantHeadersStamped": "CY1PR03MB2364",
        "Subject": "[dpdk-dev] [PATCH v5 37/40] net/dpaa: support Scattered Rx",
        "X-BeenThere": "dev@dpdk.org",
        "X-Mailman-Version": "2.1.15",
        "Precedence": "list",
        "List-Id": "DPDK patches and discussions <dev.dpdk.org>",
        "List-Unsubscribe": "<http://dpdk.org/ml/options/dev>,\n\t<mailto:dev-request@dpdk.org?subject=unsubscribe>",
        "List-Archive": "<http://dpdk.org/ml/archives/dev/>",
        "List-Post": "<mailto:dev@dpdk.org>",
        "List-Help": "<mailto:dev-request@dpdk.org?subject=help>",
        "List-Subscribe": "<http://dpdk.org/ml/listinfo/dev>,\n\t<mailto:dev-request@dpdk.org?subject=subscribe>",
        "Errors-To": "dev-bounces@dpdk.org",
        "Sender": "\"dev\" <dev-bounces@dpdk.org>"
    },
    "content": "Signed-off-by: Hemant Agrawal <hemant.agrawal@nxp.com>\nSigned-off-by: Shreyansh Jain <shreyansh.jain@nxp.com>\n---\n doc/guides/nics/features/dpaa.ini |   1 +\n drivers/net/dpaa/dpaa_rxtx.c      | 159 ++++++++++++++++++++++++++++++++++++++\n drivers/net/dpaa/dpaa_rxtx.h      |   9 +++\n 3 files changed, 169 insertions(+)",
    "diff": "diff --git a/doc/guides/nics/features/dpaa.ini b/doc/guides/nics/features/dpaa.ini\nindex 23626c0..0e7956c 100644\n--- a/doc/guides/nics/features/dpaa.ini\n+++ b/doc/guides/nics/features/dpaa.ini\n@@ -8,6 +8,7 @@ Speed capabilities   = P\n Link status          = Y\n Jumbo frame          = Y\n MTU update           = Y\n+Scattered Rx         = Y\n Promiscuous mode     = Y\n Allmulticast mode    = Y\n Unicast MAC filter   = Y\ndiff --git a/drivers/net/dpaa/dpaa_rxtx.c b/drivers/net/dpaa/dpaa_rxtx.c\nindex 976268b..9c25d8c 100644\n--- a/drivers/net/dpaa/dpaa_rxtx.c\n+++ b/drivers/net/dpaa/dpaa_rxtx.c\n@@ -276,18 +276,82 @@ static inline void dpaa_checksum_offload(struct rte_mbuf *mbuf,\n \tfd->cmd = DPAA_FD_CMD_RPD | DPAA_FD_CMD_DTC;\n }\n \n+struct rte_mbuf *\n+dpaa_eth_sg_to_mbuf(struct qm_fd *fd, uint32_t ifid)\n+{\n+\tstruct dpaa_bp_info *bp_info = DPAA_BPID_TO_POOL_INFO(fd->bpid);\n+\tstruct rte_mbuf *first_seg, *prev_seg, *cur_seg, *temp;\n+\tstruct qm_sg_entry *sgt, *sg_temp;\n+\tvoid *vaddr, *sg_vaddr;\n+\tint i = 0;\n+\tuint8_t fd_offset = fd->offset;\n+\n+\tDPAA_DP_LOG(DEBUG, \"Received an SG frame\");\n+\n+\tvaddr = rte_dpaa_mem_ptov(qm_fd_addr(fd));\n+\tif (!vaddr) {\n+\t\tDPAA_PMD_ERR(\"unable to convert physical address\");\n+\t\treturn NULL;\n+\t}\n+\tsgt = vaddr + fd_offset;\n+\tsg_temp = &sgt[i++];\n+\thw_sg_to_cpu(sg_temp);\n+\ttemp = (struct rte_mbuf *)((char *)vaddr - bp_info->meta_data_size);\n+\tsg_vaddr = rte_dpaa_mem_ptov(qm_sg_entry_get64(sg_temp));\n+\n+\tfirst_seg = (struct rte_mbuf *)((char *)sg_vaddr -\n+\t\t\t\t\t\tbp_info->meta_data_size);\n+\tfirst_seg->data_off = sg_temp->offset;\n+\tfirst_seg->data_len = sg_temp->length;\n+\tfirst_seg->pkt_len = sg_temp->length;\n+\trte_mbuf_refcnt_set(first_seg, 1);\n+\n+\tfirst_seg->port = ifid;\n+\tfirst_seg->nb_segs = 1;\n+\tfirst_seg->ol_flags = 0;\n+\tprev_seg = first_seg;\n+\twhile (i < DPAA_SGT_MAX_ENTRIES) {\n+\t\tsg_temp = &sgt[i++];\n+\t\thw_sg_to_cpu(sg_temp);\n+\t\tsg_vaddr = rte_dpaa_mem_ptov(qm_sg_entry_get64(sg_temp));\n+\t\tcur_seg = (struct rte_mbuf *)((char *)sg_vaddr -\n+\t\t\t\t\t\t      bp_info->meta_data_size);\n+\t\tcur_seg->data_off = sg_temp->offset;\n+\t\tcur_seg->data_len = sg_temp->length;\n+\t\tfirst_seg->pkt_len += sg_temp->length;\n+\t\tfirst_seg->nb_segs += 1;\n+\t\trte_mbuf_refcnt_set(cur_seg, 1);\n+\t\tprev_seg->next = cur_seg;\n+\t\tif (sg_temp->final) {\n+\t\t\tcur_seg->next = NULL;\n+\t\t\tbreak;\n+\t\t}\n+\t\tprev_seg = cur_seg;\n+\t}\n+\n+\tdpaa_eth_packet_info(first_seg, (uint64_t)vaddr);\n+\trte_pktmbuf_free_seg(temp);\n+\n+\treturn first_seg;\n+}\n+\n static inline struct rte_mbuf *dpaa_eth_fd_to_mbuf(struct qm_fd *fd,\n \t\t\t\t\t\t\tuint32_t ifid)\n {\n \tstruct dpaa_bp_info *bp_info = DPAA_BPID_TO_POOL_INFO(fd->bpid);\n \tstruct rte_mbuf *mbuf;\n \tvoid *ptr;\n+\tuint8_t format =\n+\t\t(fd->opaque & DPAA_FD_FORMAT_MASK) >> DPAA_FD_FORMAT_SHIFT;\n \tuint16_t offset =\n \t\t(fd->opaque & DPAA_FD_OFFSET_MASK) >> DPAA_FD_OFFSET_SHIFT;\n \tuint32_t length = fd->opaque & DPAA_FD_LENGTH_MASK;\n \n \tDPAA_DP_LOG(DEBUG, \" FD--->MBUF\");\n \n+\tif (unlikely(format == qm_fd_sg))\n+\t\treturn dpaa_eth_sg_to_mbuf(fd, ifid);\n+\n \t/* Ignoring case when format != qm_fd_contig */\n \tptr = rte_dpaa_mem_ptov(fd->addr);\n \t/* Ignoring case when ptr would be NULL. That is only possible incase\n@@ -390,6 +454,95 @@ static struct rte_mbuf *dpaa_get_dmable_mbuf(struct rte_mbuf *mbuf,\n \treturn dpaa_mbuf;\n }\n \n+int\n+dpaa_eth_mbuf_to_sg_fd(struct rte_mbuf *mbuf,\n+\t\tstruct qm_fd *fd,\n+\t\tuint32_t bpid)\n+{\n+\tstruct rte_mbuf *cur_seg = mbuf, *prev_seg = NULL;\n+\tstruct dpaa_bp_info *bp_info = DPAA_BPID_TO_POOL_INFO(bpid);\n+\tstruct rte_mbuf *temp, *mi;\n+\tstruct qm_sg_entry *sg_temp, *sgt;\n+\tint i = 0;\n+\n+\tDPAA_DP_LOG(DEBUG, \"Creating SG FD to transmit\");\n+\n+\ttemp = rte_pktmbuf_alloc(bp_info->mp);\n+\tif (!temp) {\n+\t\tDPAA_PMD_ERR(\"Failure in allocation of mbuf\");\n+\t\treturn -1;\n+\t}\n+\tif (temp->buf_len < ((mbuf->nb_segs * sizeof(struct qm_sg_entry))\n+\t\t\t\t+ temp->data_off)) {\n+\t\tDPAA_PMD_ERR(\"Insufficient space in mbuf for SG entries\");\n+\t\treturn -1;\n+\t}\n+\n+\tfd->cmd = 0;\n+\tfd->opaque_addr = 0;\n+\n+\tif (mbuf->ol_flags & DPAA_TX_CKSUM_OFFLOAD_MASK) {\n+\t\tif (temp->data_off < DEFAULT_TX_ICEOF\n+\t\t\t+ sizeof(struct dpaa_eth_parse_results_t))\n+\t\t\ttemp->data_off = DEFAULT_TX_ICEOF\n+\t\t\t\t+ sizeof(struct dpaa_eth_parse_results_t);\n+\t\tdcbz_64(temp->buf_addr);\n+\t\tdpaa_checksum_offload(mbuf, fd, temp->buf_addr);\n+\t}\n+\n+\tsgt = temp->buf_addr + temp->data_off;\n+\tfd->format = QM_FD_SG;\n+\tfd->addr = temp->buf_physaddr;\n+\tfd->offset = temp->data_off;\n+\tfd->bpid = bpid;\n+\tfd->length20 = mbuf->pkt_len;\n+\n+\twhile (i < DPAA_SGT_MAX_ENTRIES) {\n+\t\tsg_temp = &sgt[i++];\n+\t\tsg_temp->opaque = 0;\n+\t\tsg_temp->val = 0;\n+\t\tsg_temp->addr = cur_seg->buf_physaddr;\n+\t\tsg_temp->offset = cur_seg->data_off;\n+\t\tsg_temp->length = cur_seg->data_len;\n+\t\tif (RTE_MBUF_DIRECT(cur_seg)) {\n+\t\t\tif (rte_mbuf_refcnt_read(cur_seg) > 1) {\n+\t\t\t\t/*If refcnt > 1, invalid bpid is set to ensure\n+\t\t\t\t * buffer is not freed by HW.\n+\t\t\t\t */\n+\t\t\t\tsg_temp->bpid = 0xff;\n+\t\t\t\trte_mbuf_refcnt_update(cur_seg, -1);\n+\t\t\t} else {\n+\t\t\t\tsg_temp->bpid =\n+\t\t\t\t\tDPAA_MEMPOOL_TO_BPID(cur_seg->pool);\n+\t\t\t}\n+\t\t\tcur_seg = cur_seg->next;\n+\t\t} else {\n+\t\t\t/* Get owner MBUF from indirect buffer */\n+\t\t\tmi = rte_mbuf_from_indirect(cur_seg);\n+\t\t\tif (rte_mbuf_refcnt_read(mi) > 1) {\n+\t\t\t\t/*If refcnt > 1, invalid bpid is set to ensure\n+\t\t\t\t * owner buffer is not freed by HW.\n+\t\t\t\t */\n+\t\t\t\tsg_temp->bpid = 0xff;\n+\t\t\t} else {\n+\t\t\t\tsg_temp->bpid = DPAA_MEMPOOL_TO_BPID(mi->pool);\n+\t\t\t\trte_mbuf_refcnt_update(mi, 1);\n+\t\t\t}\n+\t\t\tprev_seg = cur_seg;\n+\t\t\tcur_seg = cur_seg->next;\n+\t\t\tprev_seg->next = NULL;\n+\t\t\trte_pktmbuf_free(prev_seg);\n+\t\t}\n+\t\tif (cur_seg == NULL) {\n+\t\t\tsg_temp->final = 1;\n+\t\t\tcpu_to_hw_sg(sg_temp);\n+\t\t\tbreak;\n+\t\t}\n+\t\tcpu_to_hw_sg(sg_temp);\n+\t}\n+\treturn 0;\n+}\n+\n /* Handle mbufs which are not segmented (non SG) */\n static inline void\n tx_on_dpaa_pool_unsegmented(struct rte_mbuf *mbuf,\n@@ -460,6 +613,12 @@ tx_on_dpaa_pool(struct rte_mbuf *mbuf,\n \tif (mbuf->nb_segs == 1) {\n \t\t/* Case for non-segmented buffers */\n \t\ttx_on_dpaa_pool_unsegmented(mbuf, bp_info, fd_arr);\n+\t} else if (mbuf->nb_segs > 1 &&\n+\t\t   mbuf->nb_segs <= DPAA_SGT_MAX_ENTRIES) {\n+\t\tif (dpaa_eth_mbuf_to_sg_fd(mbuf, fd_arr, bp_info->bpid)) {\n+\t\t\tDPAA_PMD_DEBUG(\"Unable to create Scatter Gather FD\");\n+\t\t\treturn 1;\n+\t\t}\n \t} else {\n \t\tDPAA_PMD_DEBUG(\"Number of Segments not supported\");\n \t\treturn 1;\ndiff --git a/drivers/net/dpaa/dpaa_rxtx.h b/drivers/net/dpaa/dpaa_rxtx.h\nindex d10298e..2ffc4ff 100644\n--- a/drivers/net/dpaa/dpaa_rxtx.h\n+++ b/drivers/net/dpaa/dpaa_rxtx.h\n@@ -58,6 +58,8 @@\n /* L4 Type field: TCP */\n #define DPAA_L4_PARSE_RESULT_TCP\t0x20\n \n+#define DPAA_SGT_MAX_ENTRIES 16 /* maximum number of entries in SG Table */\n+\n #define DPAA_MAX_DEQUEUE_NUM_FRAMES    63\n \t/** <Maximum number of frames to be dequeued in a single rx call*/\n \n@@ -285,4 +287,11 @@ uint16_t dpaa_eth_queue_tx(void *q, struct rte_mbuf **bufs, uint16_t nb_bufs);\n uint16_t dpaa_eth_tx_drop_all(void *q  __rte_unused,\n \t\t\t      struct rte_mbuf **bufs __rte_unused,\n \t\t\t      uint16_t nb_bufs __rte_unused);\n+\n+struct rte_mbuf *dpaa_eth_sg_to_mbuf(struct qm_fd *fd, uint32_t ifid);\n+\n+int dpaa_eth_mbuf_to_sg_fd(struct rte_mbuf *mbuf,\n+\t\t\t   struct qm_fd *fd,\n+\t\t\t   uint32_t bpid);\n+\n #endif\n",
    "prefixes": [
        "dpdk-dev",
        "v5",
        "37/40"
    ]
}