get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

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

{
    "id": 19893,
    "url": "http://patches.dpdk.org/api/patches/19893/?format=api",
    "web_url": "http://patches.dpdk.org/project/dpdk/patch/1485172803-17288-22-git-send-email-hemant.agrawal@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": "<1485172803-17288-22-git-send-email-hemant.agrawal@nxp.com>",
    "list_archive_url": "https://inbox.dpdk.org/dev/1485172803-17288-22-git-send-email-hemant.agrawal@nxp.com",
    "date": "2017-01-23T11:59:51",
    "name": "[dpdk-dev,PATCHv6,21/33] net/dpaa2: attach the buffer pool to dpni",
    "commit_ref": null,
    "pull_url": null,
    "state": "changes-requested",
    "archived": true,
    "hash": "d272278fdf4c3be9813ddfc99324501ddf455813",
    "submitter": {
        "id": 477,
        "url": "http://patches.dpdk.org/api/people/477/?format=api",
        "name": "Hemant Agrawal",
        "email": "hemant.agrawal@nxp.com"
    },
    "delegate": {
        "id": 319,
        "url": "http://patches.dpdk.org/api/users/319/?format=api",
        "username": "fyigit",
        "first_name": "Ferruh",
        "last_name": "Yigit",
        "email": "ferruh.yigit@amd.com"
    },
    "mbox": "http://patches.dpdk.org/project/dpdk/patch/1485172803-17288-22-git-send-email-hemant.agrawal@nxp.com/mbox/",
    "series": [],
    "comments": "http://patches.dpdk.org/api/patches/19893/comments/",
    "check": "success",
    "checks": "http://patches.dpdk.org/api/patches/19893/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 [IPv6:::1])\n\tby dpdk.org (Postfix) with ESMTP id 2B131FA50;\n\tMon, 23 Jan 2017 13:01:53 +0100 (CET)",
            "from NAM03-BY2-obe.outbound.protection.outlook.com\n\t(mail-by2nam03on0050.outbound.protection.outlook.com [104.47.42.50])\n\tby dpdk.org (Postfix) with ESMTP id DFDDCF965\n\tfor <dev@dpdk.org>; Mon, 23 Jan 2017 13:01:23 +0100 (CET)",
            "from CY1PR03CA0034.namprd03.prod.outlook.com (10.174.128.44) by\n\tCY4PR03MB2472.namprd03.prod.outlook.com (10.168.165.8) with Microsoft\n\tSMTP Server (version=TLS1_2,\n\tcipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P384) id\n\t15.1.860.13; Mon, 23 Jan 2017 12:01:22 +0000",
            "from BY2FFO11FD004.protection.gbl (2a01:111:f400:7c0c::126) by\n\tCY1PR03CA0034.outlook.office365.com (2603:10b6:600::44) with\n\tMicrosoft SMTP Server (version=TLS1_2,\n\tcipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P384) id\n\t15.1.860.13 via Frontend Transport; Mon, 23 Jan 2017 12:01:22 +0000",
            "from tx30smr01.am.freescale.net (192.88.168.50) by\n\tBY2FFO11FD004.mail.protection.outlook.com (10.1.14.158) with\n\tMicrosoft SMTP Server (version=TLS1_0,\n\tcipher=TLS_RSA_WITH_AES_256_CBC_SHA) id 15.1.803.8\n\tvia Frontend Transport; Mon, 23 Jan 2017 12:01:21 +0000",
            "from bf-netperf1.idc ([10.232.134.28])\n\tby tx30smr01.am.freescale.net (8.14.3/8.14.0) with ESMTP id\n\tv0NC07ej019311; Mon, 23 Jan 2017 05:01:18 -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;\n\tnxp.com; \n\tdkim=none (message not signed) header.d=none;",
        "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": "Hemant Agrawal <hemant.agrawal@nxp.com>",
        "To": "<dev@dpdk.org>",
        "CC": "<thomas.monjalon@6wind.com>, <bruce.richardson@intel.com>,\n\t<shreyansh.jain@nxp.com>, <john.mcnamara@intel.com>,\n\t<ferruh.yigit@intel.com>, <jerin.jacob@caviumnetworks.com>,\n\tHemant Agrawal <hemant.agrawal@nxp.com>",
        "Date": "Mon, 23 Jan 2017 17:29:51 +0530",
        "Message-ID": "<1485172803-17288-22-git-send-email-hemant.agrawal@nxp.com>",
        "X-Mailer": "git-send-email 1.9.1",
        "In-Reply-To": "<1485172803-17288-1-git-send-email-hemant.agrawal@nxp.com>",
        "References": "<1484832240-2048-1-git-send-email-hemant.agrawal@nxp.com>\n\t<1485172803-17288-1-git-send-email-hemant.agrawal@nxp.com>",
        "X-EOPAttributedMessage": "0",
        "X-Matching-Connectors": "131296464815960152;\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)(7916002)(336005)(39450400003)(39850400002)(39410400002)(39400400002)(39380400002)(39860400002)(39840400002)(2980300002)(1110001)(1109001)(339900001)(199003)(189002)(110136003)(305945005)(356003)(33646002)(5660300001)(50986999)(76176999)(6916009)(54906002)(97736004)(8656002)(5890100001)(77096006)(2950100002)(189998001)(6666003)(626004)(5003940100001)(38730400001)(4326007)(106466001)(2906002)(2351001)(53936002)(68736007)(85426001)(104016004)(86362001)(48376002)(36756003)(47776003)(105606002)(8676002)(50466002)(50226002)(8936002)(81156014)(92566002)(81166006);\n\tDIR:OUT; SFP:1101; SCL:1; SRVR:CY4PR03MB2472;\n\tH:tx30smr01.am.freescale.net; \n\tFPR:; SPF:Fail; PTR:InfoDomainNonexistent; A:1; MX:1; LANG:en; ",
        "X-Microsoft-Exchange-Diagnostics": [
            "1; BY2FFO11FD004;\n\t1:D6wQwqNXe5nZ9yTmGZXtnkygykPzMPGEjAEn3nRFQoG/4kvH17H6D1R08v1WrF+LfBUbdWyJdcYCXeWndfg1x3wyYL4dFRGiJUMfGeesjQv2D2EYzze2Bhp6PUxq0zpHiMk+g4ZvWMRFBxEAVjtMq7qVIVdVhXlYuU+fbozmiYDjhANcLxGGnr3/VSjlwQ/OeGduISe/br1GdpcxhF0xH4EkX2V15belHhoERRytM9stpgyF6leH5x11hR1w0HlQGW6Ggf6l0rkg5UBa8FlIDGLRVby+LruJ26bSPSi04erS4PZVSdvDcxqgLSG/DPNf2YG9Nf41RDS/n7bw4hWq1fTsUnom8S+Q6F5WDUk2S7NwFKW11TVuc/PyzCi0XyTiEQoqA+UnOe/W8kgQWlGndrm6JOBo4+sVDSz095R22o15Ap+eRj8t5kGbEaA5wpy73MjDZaY9Tj0Y/RS3e66kMlV29qSCEiq9NmZwrX5x2rNyhpzRc2XeAeK7T2jsiwEPRdzrMdLwI3DDP29ip1CmRPk8M2RPt8rfw/inDgqOpeDZABWXhjvMgQgbOvj0kztgcxKr1Q7OhLVDWgAiuqCfL2Qu/HtFBNE5XsEzrPUSzsuSz0NwDYK/rpGVmBkQVT2iDe4msq2eszApstZ3KmWp6gn/tSVC23+xwKQgVcSS1FqAKCxs2ct2Te++uujTJ82V8SaMSnGcWwwoSF0fFYI/u1NsyCUg10cxPxKOyyXYc2nNsxOIlgBwNZgX+LQl/7Hw",
            "1; CY4PR03MB2472;\n\t3:N01bAnfQ2szNt/fYD15go+zkG3cIh/tTPSMGkiIT3DKP4MXYx1Acwd2c82cNuNcdowGGDVQ+ledlzpANPFKPUj2tEZ4EgKAQZsyIBBKBCTLeICQGVvBqfIlZuLQO41N/4dqSVrTYbdbNLWjZdo7+k1ihr5PJ5TzOLz5fEvA+7HXrvZYs2F0NeTXBsf2WwyAs3JW35K9aBt6860HVVtYSwSCjFSVwt/IPC2hqzBbeMPUD8JVCsi9GurHY5NH7YUV3HPAiOPfQ0+fOFw5zxfkRTg5os37ccBbMowYC7p+I5yX64ZNsnRmyl/cVzEob4Oti9b+h530Fhr7ZS2KeWWou6bdXKS3O9mEbPpTovIW0aBBFogTZdiGZiGM6a3nX8VJt",
            "1; CY4PR03MB2472;\n\t25:PekvUV6PMfUXizw3CiPNyqaFMM7tUhaqX50anoy11SPmCG1r8lTzqNkokcmQv0Ux85Bu//FKAxlPwP9vaceNx/7PyP9UbPsa9pHHV7ACNmfgA/W452auddyeqGN+9fwohwkFr7HyVS9ehTsXIHi5FGfaNrEzXCBAdd4kGBo0iMNc6LXZyh2I8R/x7lg6mC+PRFQQ4HWhhMcmpoqzIPoIRcgqveBOPcyjTHwE02UZCqH6cA7LGz445rgs9Fux0G+GyXgCxS3as9KxPH/k7H+foAovf40qvjZFt+Bm4twrIcPmwMkx0Zm9ZlZTVCNxbgghDmNM4QG1PoUQHZ+ZUYWLWNVf5jQItyQs2gizfklRqE6qol3lmGdF8Xu1QmP0wgSFmINTdN1t1/ddYi6SNcgWPPPN5pwv6u4FkBBb7IZ3tmGUDhIAy1G0M9NZhGSGUU6unBdcI6v4QvoizLUhmx7DgGV834BuGuzjlnpOHEn6H86reP04JoPEExusTaiL3xmEQVc8HEWFtcSuln2QMVqtxuT+AE1YPxDbkn4v63HeFe1LiwTdTk/UszTKEJf91+3mibTabshPHsvfjyqZcnJi56PxO0CumlR8YhnP7NRyhf8zivTKpo+vqosBNi4fsMNWWn4gsnmiMuRBq9xg9YBdrqDBIyEs/JXKvOFtef94ug7KvfpPuH21/Y+WCsldivreYxxohlVdswd5WoF3FPFkEEzq2RM9Fl8MR0HyP3qBKueNHAhrGPpT3IcvYpkBFATi9qJeprHrUXXgF2RSQR5nQqpVNuq7vc0QN6lbJJ8Vjx2/QvPaZK+UazXstGYdkHHD",
            "1; CY4PR03MB2472;\n\t31:MPBZAUDXLIoSlAI2qDHNj5DWL9zyAmQA28tdjW97KEvRiU0cXl0PiejNik+lGZcNAx57A7qYdZjEGh111z40To08YJqeQl6qtT1mU3SRyzh/H4oYsgR6YciT7popRm6OALBEeArdvCqNg4taJSk4mNkjmTJ3NHqcZi3yQ8NoH/Ru5O7XOQYMxFP0NlLTyUauWpildO4bJUO590XE0Sq2ZxabuwwZ54XqD03IrfzDzdrqgIqSm8UXsJ8ToC3xKlu7/zftE9HwN6aanhpyTnjI9p3s+Q/YsST9m6e0vZ1wKp8=",
            "1; CY4PR03MB2472;\n\t4:VRIYNzkhXuYRteP3Uzknc7he8gzKtiHwEyTCCgL5BL/UKlh9s6prwVj58fkFQyK2g6z2zc8FmjZVDJIuav5lyEERQq/NPe+hV8/ypucZtDQS6MYc9co6/AiwEKle7o4SW0m8fG3Hm5/uoxYz9OYNrU0QkvekwyaLPwxxpuUXhk71uJs1EVaNQPTWNJD+yP8uabVajH5zBHfV5hRMmjpJnfSwgNzSHdhtl2EfNw/k9xBVfxq5FphVuvBfk6vriO8oW55RgXuqGG6PE5h6ssQ1w0dXL370i0+BkXe9M2aNYTyUj3JgMDf82qOyNYrJuDSxmlqcPTMLMc87GsIz7q1Ed/GxoXwmIhzhm/c2EKLgwDMX4esiiV58q/2OCITqJaix+bqcz0LXOq12DPDanD6CZ0nIJDlqsxfUCTaMV7LmDUvYiI6ZRCiJIeIWMYoa9l3M4b0IEdV01Fa3+UvhamAxHbzWfia/D0tipbUxYa6trx0ayjkT13L6swOuCXLSy5TVElqrolJnE5FRYIfGPhCxAAIz8AWlm09CFArwB5GF7xA1wBpTONiVdbTre7GG7Ad1vAAw2Mji44dpNu+ZiHZ7DbxN9GxTu9rTJnXRgd2mw01kLhve8xSGK3wKvYvUpgmAitygv7B+kTMJrNPPVlZPckDYk6xYtteGFNAi0xXdaz0rmpVVAPwr1NjRJ66bDEyYSDqu8FE7AhypmFgDHoRJ+4JpvZWp4vaRpt2XN9FLqvGsGXHqMBS7EfNnDGNTNTigjvvI2TfxJ47mFzuAtqeJPA==",
            "=?us-ascii?Q?1; CY4PR03MB2472;\n\t23:ImFglvweHOUb98uVMuX9bEovUkTLANAY9H2quCljB?=\n\tCfbZz2+5i4UwP8zPAd2M+IciO+KL0moMHPCpu9uHtXQi7HRZLt44OBJ4BycpgDcrvjFhF5j+oda0cpKSRRI1UC+MziNQUD4bex7qZJtBJXta1fI3OKjk85XNy9RPeTvK3+Vd3ST++o1p+On2AsXAQB1y52gbwzJvYvT0fsBEpUKtKYv3KMTu8EOCCBVO6emjFR9kQaKHxyymSu4xQTbff5Fob9Ge7siEzQKV6TBa5jYjMhueD60evAYI/HOfdljcX2pmOgEhEtP6FTIAu9YSelR4jPOkhFJQqY3piD9XTIcbNSFUXg96zIYuoFKJ8iJHFwcTu1CjDyU7jOM2Hm3FkniPDqF/Zl3wt17983oGLHlTzUGEBKtI/Syl26TXrVRLor9uUVUlStvRft2zNm5pRSfrpFuqxJ/1c+xxYXRE4rz9BvIIP5YMDvQ8KOXRSA8ZM7mZCNSuWcxbPzqAA0nbSYaBSUFUqqMTunh7JC3yYkH4nxmeWznLEvrt0yZf+AG8SJO87TSRTu7y1YVw/h3FgVHNtHOu0jC3J3WVSaQO1JcyacNIg4lRa6iQu5scqVd5ti9mcUfK9QJf/vOLRGKvrqvc1LHfN1PIa0BuxERvNmESmS12pkmkdPRa06jKYdRiHrphEU+F0f7+oGhGiMKGsPR6wsNna739c4R8TTa478OzFJU7e3OcL9ftPuMlyr9XlsI5RZpY23/xCs39zmYxX/eswKrt1PT15FaTCM+KCG/TeojwgqvGvD8yyUU1mXqzSq607ispO4BTa9u5lzclkh8HyawhzysLWX8yee4QaV37cEJ40iCvGNK/p8uJkSDlX74VRtxipEQoDGcUKW9CeZzxL5h3G3yFVoSred7zihkYVAUuFgo0Fb9MlraqrG/jNMBs1ibhXKn7fOZX/90z03Zibxa2nRaQ1aag3N5rS5mTZJKrlEkyq8g2HqjWQc08nqB+lWriGWTDkxvANDrL/XrS0Xwfn4B4Zm0hOdKtg9QQgTWTguI/jFSiOG5velP2BbnWogpG8n+Sc9WjH5zhx7DgVMOwaVYt4N3aQn2JuUdCEl38lCkHBY7a2QMCFbOhP1JvQXbVwT0tL+rK1emhvFTvjrYv1KN9OMHaGe7+j+hizUPlPJbLJgHJbrOdNEZxnUA8t9IDp3pf5i78hptSRphLlzs+mH1dQi7PGHrM9jx6qZPId0GvqrkOx3AorarmhXEIyvKPdZhf19hemWYJKJ+Z+SdGCcVX6+ihaRS0N3pme9C8HG9V5I+Jj6rwO5L1AfTHNHAOSn7V7cvjxoVByJ4",
            "1; CY4PR03MB2472;\n\t6:uhZMmPX8SRJ3u4AmoexCOk+nio3edbRaLvq1na/0YcpT6FY70jyBduXOPIFXmz6dQIKnkMOTbksv812KPg0hRmJ8ZSBj7Yt1mRkGMXafsVMQqFT9BH1XxneTR7NUjJW42qVQDw+d8Ty9SM6wat+1grerJjS4s4gKk0gnGjRKdUVllngDAIY5K+FaasMDUoJWSemi7B8pdHFUK9pDEJZ+doZaFlz/GYbsoz/dqf+Bg1QyizoS0sMmp/bYsqdDHKNlw1suziCmzPWtZo2jgLxPo26YTrsuTRfTc7OVhRf5VnpqY/Y2wT/VZ0QfKNylJtvwvXONA1NUQ4TQ+YG8+NKf+C7dje2lizNjRSa6zXbymhY5zyjvWI614UmNBZom/Ez0HMjAxXNpL8iZQ/V4u7+sraB+SmQQebbAcNW9VSzfyHj+i7ChEnGfia05qiAQFerU;\n\t5:tWu+9ABLkthwoXRrGzF7rVa3lwjz9/ybqbr4Qukl7p6/y9mYWwrsLOv/7dZK7LUhJ7sMI4zbX1if7xVcAwD/drhHaNcONFMQNN2fXC/uTqp2X5CGbNfc2jSNJI6llIozHdhcNtrGwyBgF5vpLzyZShTjJn0Xn6pXrMKo1vZHLpzNbY82ZrdCVqAEf9jFfynb;\n\t24:QG/Z3jUd4ni5hwWkSs+amD/J16o2cIGfxjrId5R8oRcHKK6T4wvw6ndeTaLBSsVpR8n2w6Nd+IBlWO+70bbuTp2gDKB3RLQ8Z1IsZ1P9Fac=",
            "1; CY4PR03MB2472;\n\t7:imo6VD+/pDmKPG34L5LdSLdMYq0NN3TMogSVptFrzv83F3qj4vKSQj2SLfwahtGpfo4Bua0pRhp2gKhrUZecqwV5Bl8YQqKsOug4AqkoTEUg4+h2iVWy7Ma0EcDiAJmNX5gQDmOfdAJNEiO5sEoGxPnra+BPGc52QHT2saf9ZyBVJWhZmVgGEH2M+Nq5F/lrT+LBydI8pfFgdJ1onnmZwvm01Xo3WTXBpcuosbIm+R5+kv5HXLwBJbgwApQKoExClhwKaVzG7xqKbxYry098cgQkCr8AtT6aHkBFoq1VZGpQI5nicEEyIh1krOyegDjgGICTnMmSlImftnRmAN3CBsaNvRgDwBDYQjhXk7VZesCQhpPcoBqC0qK0iLgSfZ66lyj8G0BMi8YNYjAnKYF4+JlNg443N4ObybWadaOYUj0MTwrD9ATmX4c/mMMbE8FalrHDGjdRzSLM4Qn+juyjog=="
        ],
        "MIME-Version": "1.0",
        "Content-Type": "text/plain",
        "X-MS-Office365-Filtering-Correlation-Id": "33146667-4648-4854-441c-08d443878c00",
        "X-Microsoft-Antispam": "UriScan:; BCL:0; PCL:0; RULEID:(22001);\n\tSRVR:CY4PR03MB2472; ",
        "X-Microsoft-Antispam-PRVS": "<CY4PR03MB247263BAC3E450FDF64BFE4C89720@CY4PR03MB2472.namprd03.prod.outlook.com>",
        "X-Exchange-Antispam-Report-Test": "UriScan:(185117386973197)(275809806118684); ",
        "X-Exchange-Antispam-Report-CFA-Test": "BCL:0; PCL:0;\n\tRULEID:(6095060)(601004)(2401047)(13023025)(13017025)(13015025)(13024025)(13018025)(5005006)(8121501046)(3002001)(10201501046)(6055026)(6096035)(20161123561025)(20161123559025)(20161123556025)(20161123563025)(20161123565025);\n\tSRVR:CY4PR03MB2472; BCL:0; PCL:0; RULEID:(400006); SRVR:CY4PR03MB2472;",
        "X-Forefront-PRVS": "0196A226D1",
        "SpamDiagnosticOutput": "1:99",
        "SpamDiagnosticMetadata": "NSPM",
        "X-MS-Exchange-CrossTenant-OriginalArrivalTime": "23 Jan 2017 12:01:21.2684\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": "CY4PR03MB2472",
        "Subject": "[dpdk-dev] [PATCHv6 21/33] net/dpaa2: attach the buffer pool to dpni",
        "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": "This patch configures a MC-DPNI based DPAA2 PMD network\nport with a DPBP based buffer pool.\n\nSigned-off-by: Hemant Agrawal <hemant.agrawal@nxp.com>\n---\n drivers/bus/fslmc/portal/dpaa2_hw_pvt.h | 10 ++++++\n drivers/net/dpaa2/Makefile              |  3 ++\n drivers/net/dpaa2/base/dpaa2_hw_dpni.c  | 57 ++++++++++++++++++++++++++++++\n drivers/net/dpaa2/dpaa2_ethdev.c        | 62 +++++++++++++++++++++++++++++++++\n drivers/net/dpaa2/dpaa2_ethdev.h        |  6 ++++\n 5 files changed, 138 insertions(+)",
    "diff": "diff --git a/drivers/bus/fslmc/portal/dpaa2_hw_pvt.h b/drivers/bus/fslmc/portal/dpaa2_hw_pvt.h\nindex 42c5517..8efac2d 100644\n--- a/drivers/bus/fslmc/portal/dpaa2_hw_pvt.h\n+++ b/drivers/bus/fslmc/portal/dpaa2_hw_pvt.h\n@@ -50,6 +50,16 @@\n #define DPAA2_MBUF_MAX_ACQ_REL\t7\n \n #define MAX_BPID 256\n+#define DPAA2_MBUF_HW_ANNOTATION\t64\n+#define DPAA2_FD_PTA_SIZE\t\t64\n+\n+#if (DPAA2_MBUF_HW_ANNOTATION + DPAA2_FD_PTA_SIZE) > RTE_PKTMBUF_HEADROOM\n+#error \"Annotation requirement is more than RTE_PKTMBUF_HEADROOM\"\n+#endif\n+\n+/* we will re-use the HEADROOM for annotation in RX */\n+#define DPAA2_HW_BUF_RESERVE\t0\n+#define DPAA2_PACKET_LAYOUT_ALIGN\t64 /*changing from 256 */\n \n struct dpaa2_dpio_dev {\n \tTAILQ_ENTRY(dpaa2_dpio_dev) next;\ndiff --git a/drivers/net/dpaa2/Makefile b/drivers/net/dpaa2/Makefile\nindex 7d62f1e..fadabb5 100644\n--- a/drivers/net/dpaa2/Makefile\n+++ b/drivers/net/dpaa2/Makefile\n@@ -49,6 +49,7 @@ CFLAGS += -I$(RTE_SDK)/drivers/bus/fslmc\n CFLAGS += -I$(RTE_SDK)/drivers/bus/fslmc/mc\n CFLAGS += -I$(RTE_SDK)/drivers/bus/fslmc/portal\n CFLAGS += -I$(RTE_SDK)/drivers/common/dpaa2/qbman/include\n+CFLAGS += -I$(RTE_SDK)/drivers/pool/dpaa2\n CFLAGS += -I$(RTE_SDK)/lib/librte_eal/linuxapp/eal\n \n # versioning export map\n@@ -62,7 +63,9 @@ SRCS-$(CONFIG_RTE_LIBRTE_DPAA2_PMD) += dpaa2_ethdev.c\n \n # library dependencies\n DEPDIRS-$(CONFIG_RTE_LIBRTE_DPAA2_PMD) += lib/librte_eal lib/librte_ether\n+DEPDIRS-$(CONFIG_RTE_LIBRTE_DPAA2_PMD) += lib/librte_mempool lib/librte_mbuf\n DEPDIRS-$(CONFIG_RTE_LIBRTE_DPAA2_PMD) += lib/librte_common_dpaa2_qbman\n DEPDIRS-$(CONFIG_RTE_LIBRTE_DPAA2_PMD) += lib/librte_bus_fslmc\n+DEPDIRS-$(CONFIG_RTE_LIBRTE_DPAA2_PMD) += lib/librte_pmd_dpaa2_pool\n \n include $(RTE_SDK)/mk/rte.lib.mk\ndiff --git a/drivers/net/dpaa2/base/dpaa2_hw_dpni.c b/drivers/net/dpaa2/base/dpaa2_hw_dpni.c\nindex c95c083..08f53b3 100644\n--- a/drivers/net/dpaa2/base/dpaa2_hw_dpni.c\n+++ b/drivers/net/dpaa2/base/dpaa2_hw_dpni.c\n@@ -46,6 +46,7 @@\n \n #include <fslmc_logs.h>\n #include <dpaa2_hw_pvt.h>\n+#include <dpaa2_hw_mempool.h>\n \n #include \"../dpaa2_ethdev.h\"\n \n@@ -285,3 +286,59 @@ int dpaa2_remove_flow_dist(\n \t}\n \tkg_cfg->num_extracts = i;\n }\n+\n+int\n+dpaa2_attach_bp_list(struct dpaa2_dev_priv *priv,\n+\t\t     void *blist)\n+{\n+\t/* Function to attach a DPNI with a buffer pool list. Buffer pool list\n+\t * handle is passed in blist.\n+\t */\n+\tint32_t retcode;\n+\tstruct fsl_mc_io *dpni = priv->hw;\n+\tstruct dpni_pools_cfg bpool_cfg;\n+\tstruct dpaa2_bp_list *bp_list = (struct dpaa2_bp_list *)blist;\n+\tstruct dpni_buffer_layout layout;\n+\tint tot_size;\n+\n+\t/* ... rx buffer layout .\n+\t * Check alignment for buffer layouts first\n+\t */\n+\n+\t/* ... rx buffer layout ... */\n+\ttot_size = DPAA2_HW_BUF_RESERVE + RTE_PKTMBUF_HEADROOM;\n+\ttot_size = RTE_ALIGN_CEIL(tot_size,\n+\t\t\t\t  DPAA2_PACKET_LAYOUT_ALIGN);\n+\n+\tmemset(&layout, 0, sizeof(struct dpni_buffer_layout));\n+\tlayout.options = DPNI_BUF_LAYOUT_OPT_DATA_HEAD_ROOM;\n+\n+\tlayout.data_head_room =\n+\t\ttot_size - DPAA2_FD_PTA_SIZE - DPAA2_MBUF_HW_ANNOTATION;\n+\tretcode = dpni_set_buffer_layout(dpni, CMD_PRI_LOW, priv->token,\n+\t\t\t\t\t DPNI_QUEUE_RX, &layout);\n+\tif (retcode) {\n+\t\tPMD_INIT_LOG(ERR, \"Err(%d) in setting rx buffer layout\\n\",\n+\t\t\t     retcode);\n+\t\treturn retcode;\n+\t}\n+\n+\t/*Attach buffer pool to the network interface as described by the user*/\n+\tbpool_cfg.num_dpbp = 1;\n+\tbpool_cfg.pools[0].dpbp_id = bp_list->buf_pool.dpbp_node->dpbp_id;\n+\tbpool_cfg.pools[0].backup_pool = 0;\n+\tbpool_cfg.pools[0].buffer_size =\n+\t\tRTE_ALIGN_CEIL(bp_list->buf_pool.size,\n+\t\t\t       256 /*DPAA2_PACKET_LAYOUT_ALIGN*/);\n+\n+\tretcode = dpni_set_pools(dpni, CMD_PRI_LOW, priv->token, &bpool_cfg);\n+\tif (retcode != 0) {\n+\t\tPMD_INIT_LOG(ERR, \"Error in attaching the buffer pool list\"\n+\t\t\t\t\" bpid = %d Error code = %d\\n\",\n+\t\t\t\tbpool_cfg.pools[0].dpbp_id, retcode);\n+\t\treturn retcode;\n+\t}\n+\n+\tpriv->bp_list = bp_list;\n+\treturn 0;\n+}\ndiff --git a/drivers/net/dpaa2/dpaa2_ethdev.c b/drivers/net/dpaa2/dpaa2_ethdev.c\nindex 979dba4..6de571a 100644\n--- a/drivers/net/dpaa2/dpaa2_ethdev.c\n+++ b/drivers/net/dpaa2/dpaa2_ethdev.c\n@@ -48,6 +48,7 @@\n #include <fslmc_logs.h>\n #include <fslmc_vfio.h>\n #include <dpaa2_hw_pvt.h>\n+#include <dpaa2_hw_mempool.h>\n \n #include \"dpaa2_ethdev.h\"\n \n@@ -63,6 +64,8 @@\n \tdev_info->if_index = priv->hw_id;\n \n \tdev_info->max_mac_addrs = priv->max_mac_filters;\n+\tdev_info->max_rx_pktlen = DPAA2_MAX_RX_PKT_LEN;\n+\tdev_info->min_rx_bufsize = DPAA2_MIN_RX_BUF_SIZE;\n \tdev_info->max_rx_queues = (uint16_t)priv->nb_rx_queues;\n \tdev_info->max_tx_queues = (uint16_t)priv->nb_tx_queues;\n \n@@ -187,6 +190,7 @@\n \tstruct dpni_queue cfg;\n \tuint8_t options = 0;\n \tuint8_t flow_id;\n+\tuint32_t bpid;\n \tint ret;\n \n \tPMD_INIT_FUNC_TRACE();\n@@ -194,6 +198,13 @@\n \tPMD_INIT_LOG(DEBUG, \"dev =%p, queue =%d, pool = %p, conf =%p\",\n \t\t     dev, rx_queue_id, mb_pool, rx_conf);\n \n+\tif (!priv->bp_list || priv->bp_list->mp != mb_pool) {\n+\t\tbpid = mempool_to_bpid(mb_pool);\n+\t\tret = dpaa2_attach_bp_list(priv,\n+\t\t\t\t\t   rte_dpaa2_bpid_info[bpid].bp_list);\n+\t\tif (ret)\n+\t\t\treturn ret;\n+\t}\n \tdpaa2_q = (struct dpaa2_queue *)priv->rx_vq[rx_queue_id];\n \tdpaa2_q->mb_pool = mb_pool; /**< mbuf pool to populate RX ring. */\n \n@@ -388,7 +399,9 @@\n \tstruct fsl_mc_io *dpni_dev;\n \tstruct dpni_attr attr;\n \tstruct dpaa2_dev_priv *priv = eth_dev->data->dev_private;\n+\tstruct dpni_buffer_layout layout;\n \tint i, ret, hw_id;\n+\tint tot_size;\n \n \tPMD_INIT_FUNC_TRACE();\n \n@@ -477,6 +490,55 @@\n \t\treturn -ret;\n \t}\n \n+\t/* ... rx buffer layout ... */\n+\ttot_size = DPAA2_HW_BUF_RESERVE + RTE_PKTMBUF_HEADROOM;\n+\ttot_size = RTE_ALIGN_CEIL(tot_size,\n+\t\t\t\t  DPAA2_PACKET_LAYOUT_ALIGN);\n+\n+\tmemset(&layout, 0, sizeof(struct dpni_buffer_layout));\n+\tlayout.options = DPNI_BUF_LAYOUT_OPT_FRAME_STATUS |\n+\t\t\t\tDPNI_BUF_LAYOUT_OPT_PARSER_RESULT |\n+\t\t\t\tDPNI_BUF_LAYOUT_OPT_DATA_HEAD_ROOM |\n+\t\t\t\tDPNI_BUF_LAYOUT_OPT_PRIVATE_DATA_SIZE;\n+\n+\tlayout.pass_frame_status = 1;\n+\tlayout.data_head_room = tot_size\n+\t\t- DPAA2_FD_PTA_SIZE - DPAA2_MBUF_HW_ANNOTATION;\n+\tlayout.private_data_size = DPAA2_FD_PTA_SIZE;\n+\tlayout.pass_parser_result = 1;\n+\tPMD_INIT_LOG(DEBUG, \"Tot_size = %d, head room = %d, private = %d\",\n+\t\t     tot_size, layout.data_head_room, layout.private_data_size);\n+\tret = dpni_set_buffer_layout(dpni_dev, CMD_PRI_LOW, priv->token,\n+\t\t\t\t     DPNI_QUEUE_RX, &layout);\n+\tif (ret) {\n+\t\tPMD_INIT_LOG(ERR, \"Err(%d) in setting rx buffer layout\", ret);\n+\t\treturn -1;\n+\t}\n+\n+\t/* ... tx buffer layout ... */\n+\tmemset(&layout, 0, sizeof(struct dpni_buffer_layout));\n+\tlayout.options = DPNI_BUF_LAYOUT_OPT_FRAME_STATUS;\n+\tlayout.pass_frame_status = 1;\n+\tret = dpni_set_buffer_layout(dpni_dev, CMD_PRI_LOW, priv->token,\n+\t\t\t\t     DPNI_QUEUE_TX, &layout);\n+\tif (ret) {\n+\t\tPMD_INIT_LOG(ERR, \"Error (%d) in setting tx buffer\"\n+\t\t\t\t  \" layout\", ret);\n+\t\treturn -1;\n+\t}\n+\n+\t/* ... tx-conf and error buffer layout ... */\n+\tmemset(&layout, 0, sizeof(struct dpni_buffer_layout));\n+\tlayout.options = DPNI_BUF_LAYOUT_OPT_FRAME_STATUS;\n+\tlayout.pass_frame_status = 1;\n+\tret = dpni_set_buffer_layout(dpni_dev, CMD_PRI_LOW, priv->token,\n+\t\t\t\t     DPNI_QUEUE_TX_CONFIRM, &layout);\n+\tif (ret) {\n+\t\tPMD_INIT_LOG(ERR, \"Error (%d) in setting tx-conf buffer\"\n+\t\t\t\t  \" layout\", ret);\n+\t\treturn -1;\n+\t}\n+\n \teth_dev->dev_ops = &dpaa2_ethdev_ops;\n \teth_dev->data->drv_name = rte_dpaa2_pmd.driver.name;\n \ndiff --git a/drivers/net/dpaa2/dpaa2_ethdev.h b/drivers/net/dpaa2/dpaa2_ethdev.h\nindex 2d13137..a56b525 100644\n--- a/drivers/net/dpaa2/dpaa2_ethdev.h\n+++ b/drivers/net/dpaa2/dpaa2_ethdev.h\n@@ -37,6 +37,9 @@\n #include <mc/fsl_dpni.h>\n #include <mc/fsl_mc_sys.h>\n \n+#define DPAA2_MIN_RX_BUF_SIZE 512\n+#define DPAA2_MAX_RX_PKT_LEN  10240 /*WRIOP support*/\n+\n #define MAX_TCS\t\t\tDPNI_MAX_TC\n #define MAX_RX_QUEUES\t\t16\n #define MAX_TX_QUEUES\t\t16\n@@ -57,6 +60,7 @@ struct dpaa2_dev_priv {\n \tvoid *rx_vq[MAX_RX_QUEUES];\n \tvoid *tx_vq[MAX_TX_QUEUES];\n \n+\tstruct dpaa2_bp_list *bp_list; /**<Attached buffer pool list */\n \tuint32_t options;\n \tuint16_t num_dist_per_tc[MAX_TCS];\n \tuint8_t max_mac_filters;\n@@ -71,4 +75,6 @@ int dpaa2_setup_flow_dist(struct rte_eth_dev *eth_dev,\n int dpaa2_remove_flow_dist(struct rte_eth_dev *eth_dev,\n \t\t\t   uint8_t tc_index);\n \n+int dpaa2_attach_bp_list(struct dpaa2_dev_priv *priv, void *blist);\n+\n #endif /* _DPAA2_ETHDEV_H */\n",
    "prefixes": [
        "dpdk-dev",
        "PATCHv6",
        "21/33"
    ]
}