get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

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

{
    "id": 43253,
    "url": "http://patches.dpdk.org/api/patches/43253/?format=api",
    "web_url": "http://patches.dpdk.org/project/dpdk/patch/1532197069-24224-3-git-send-email-shally.verma@caviumnetworks.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": "<1532197069-24224-3-git-send-email-shally.verma@caviumnetworks.com>",
    "list_archive_url": "https://inbox.dpdk.org/dev/1532197069-24224-3-git-send-email-shally.verma@caviumnetworks.com",
    "date": "2018-07-21T18:17:46",
    "name": "[v3,2/5] compress/zlib: add device PMD ops",
    "commit_ref": null,
    "pull_url": null,
    "state": "superseded",
    "archived": true,
    "hash": "7e0df968322af5ff2ceb05c2213ad23a012f3981",
    "submitter": {
        "id": 960,
        "url": "http://patches.dpdk.org/api/people/960/?format=api",
        "name": "Shally Verma",
        "email": "shally.verma@caviumnetworks.com"
    },
    "delegate": {
        "id": 22,
        "url": "http://patches.dpdk.org/api/users/22/?format=api",
        "username": "pdelarag",
        "first_name": "Pablo",
        "last_name": "de Lara Guarch",
        "email": "pablo.de.lara.guarch@intel.com"
    },
    "mbox": "http://patches.dpdk.org/project/dpdk/patch/1532197069-24224-3-git-send-email-shally.verma@caviumnetworks.com/mbox/",
    "series": [
        {
            "id": 703,
            "url": "http://patches.dpdk.org/api/series/703/?format=api",
            "web_url": "http://patches.dpdk.org/project/dpdk/list/?series=703",
            "date": "2018-07-21T18:17:44",
            "name": "compress: add ZLIB compression PMD",
            "version": 3,
            "mbox": "http://patches.dpdk.org/series/703/mbox/"
        }
    ],
    "comments": "http://patches.dpdk.org/api/patches/43253/comments/",
    "check": "success",
    "checks": "http://patches.dpdk.org/api/patches/43253/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 BD02E2E81;\n\tSat, 21 Jul 2018 20:18:30 +0200 (CEST)",
            "from NAM03-DM3-obe.outbound.protection.outlook.com\n\t(mail-dm3nam03on0075.outbound.protection.outlook.com [104.47.41.75])\n\tby dpdk.org (Postfix) with ESMTP id 9D3782C28\n\tfor <dev@dpdk.org>; Sat, 21 Jul 2018 20:18:27 +0200 (CEST)",
            "from hyd1sverma-dt.caveonetworks.com (115.113.156.2) by\n\tCY4PR0701MB3634.namprd07.prod.outlook.com (2603:10b6:910:92::36) with\n\tMicrosoft SMTP Server (version=TLS1_2,\n\tcipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.973.21;\n\tSat, 21 Jul 2018 18:18:24 +0000"
        ],
        "DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed;\n\td=CAVIUMNETWORKS.onmicrosoft.com; s=selector1-cavium-com;\n\th=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck;\n\tbh=ZApVFzksUhUlbS3rT9WCLYs17mKXNJrjA2t6/MC4R+c=;\n\tb=cwu/rnI2AZa0nMmVTycnBfVt0fMG95Vzqvnr6MRbUBC8IzQNR3bgccSP0b2mEPy0LTypjIR4YHMQfllz8Gj7SPZH6t/lPUwBAUvuk/M7kWF6/M2D85rdOQNVGl3+5Renpg8wBOzxdR9CouZd9YfuteypzR7t9CqOLN0L03ybhNQ=",
        "Authentication-Results": "spf=none (sender IP is )\n\tsmtp.mailfrom=Shally.Verma@cavium.com; ",
        "From": "Shally Verma <shally.verma@caviumnetworks.com>",
        "To": "pablo.de.lara.guarch@intel.com",
        "Cc": "dev@dpdk.org, pathreya@caviumnetworks.com, mchalla@caviumnetworks.com,\n\tashish.gupta@caviumnetworks.com, sunila.sahu@caviumnetworks.com",
        "Date": "Sat, 21 Jul 2018 23:47:46 +0530",
        "Message-Id": "<1532197069-24224-3-git-send-email-shally.verma@caviumnetworks.com>",
        "X-Mailer": "git-send-email 1.9.1",
        "In-Reply-To": "<1532197069-24224-1-git-send-email-shally.verma@caviumnetworks.com>",
        "References": "<1532197069-24224-1-git-send-email-shally.verma@caviumnetworks.com>",
        "MIME-Version": "1.0",
        "Content-Type": "text/plain",
        "X-Originating-IP": "[115.113.156.2]",
        "X-ClientProxiedBy": "MA1PR01CA0103.INDPRD01.PROD.OUTLOOK.COM\n\t(2603:1096:a00:1::19) To CY4PR0701MB3634.namprd07.prod.outlook.com\n\t(2603:10b6:910:92::36)",
        "X-MS-PublicTrafficType": "Email",
        "X-MS-Office365-Filtering-Correlation-Id": "5219223d-fa3c-4d67-9258-08d5ef365a25",
        "X-Microsoft-Antispam": "BCL:0; PCL:0;\n\tRULEID:(7020095)(4652040)(8989117)(5600073)(711020)(4534165)(7168020)(4627221)(201703031133081)(201702281549075)(8990107)(2017052603328)(7153060)(7193020);\n\tSRVR:CY4PR0701MB3634; ",
        "X-Microsoft-Exchange-Diagnostics": [
            "1; CY4PR0701MB3634;\n\t3:JyZzukh9p4Hk8u5qkYuFw38ywtC2OOb3rwp/XBrf1NegzjUmoUjMxV7N+LkyOb9ugT1BuYB6Fgc71w96VZ7pgW98uEKmwJOyhg5Kh5gv9nzzCczeFgQ6e2y/MARtL1gh5YSg8CWSFimM2uWiJeKyMGv6shC9mR/jyFosI9Ds1YnfSyY747yZxqEW1qBqwffG64+vG7XB6qzemMz2LTOz8waZFCR9GbAT3pk4BMMoSvEbGWuUFdtzIKrvLHMkF8WD;\n\t25:ps/495+B+RH/Q+Kp4Y2hCQZZBNafU4dHxiWIwtsKJgG6F/DX8T9ADmBwpt6i+r+0UXHICS6DzVUr9FmpbKHhTekRHxlkqAdRoy7e8S2R9NEOHPsKMpNn+OotfkMchDclL5df8Khsa74vFxOC0Sc5LKUWKdprV/H9LJ8CDtulEQRORYaFAbDi377WdmxfTYBXWtDXykNSdBbZu7FAqWqUfOsuJzLP2a61KrbQuzTPROJW9UVhm1ynDcZmgz6jQBk7+TFIt8YrIXHpEulwvpxf1CoG9uHH8tWFxn7rU7Y72qqQcXhQcQpIe9N/C/HuKTyy+dWqeRVaj2NIBd6LnCn6aQ==;\n\t31:hTkVn13WYQ2sIDRZKDLNuPXRzRl77Y8Ha+MspWSuDDoy2V9s2Y6jEPtDdT0liGuf9DxjegKESe8K2wW45ixmxdTiXPnYGR7MgV/ZDARFEKX6vuVQtGo78PHeC5gMzWZgdJKGa9IRwhj4umf8Tf024/wq27Pyb3F/kICcFJODaKSJQ+6kzl8EGbXiuLWd0td2wuW6wQY1zO3+Uh/hbZjEw62u+XyLh0UeFHpZBfosJvs=",
            "1; CY4PR0701MB3634;\n\t20:R3BHQ3KeZ8I+/tNIsHTes6hCuBjhmXISWzefIF+CilWKoJj/BYJe5pwhjgB8OQJFF8jM9ggrdL+WwMfDvRqQcedRFWV9NBVsPZkw3wAVodneuWXnQDDD6Dmz+05TcLsuGO+Es4iyEWf5ZUYtanrgQIHYPU48XrKkwuEFPQegGKnznlcSsNzHoampf8tA+q1qipWn68IfLj/iLaJLllEVw/iuYHkIpn5z7fIJzREehnbqcjsKV4MDUhjzA2mbpSVWJDv19cy1e0jpz3ZLbPmsNndxO8GmW1gmyn444cu0ftQyJcxG2WtISo4tISBoyIAJJ0WQ+eo/kZSBWOPOvA2H1+rf1050DwJRLsDOLxY5kBfUh4GAjh2raREJLQmC+i4yNS5QE92vgmpvR9EeXHFupsExBloDQ7DOBiF1iw9Hvfp4imKXj6+58NVHMrPwdidn5eOZX+cPNkLwRfdvWXdTeeqmhvBKtaFE+3r++nTmcoRapUY2kTIABTCNsjnUEkkw8yqErlxfkzLVN39jQiL2vG5v0gukS51twVS7ZPc5CCLMqC/xjHyC9p4zRFoaBNC5bgB4KWInV/ZY8iKOHIXMolIlSks+Fs9Ssrgo9QwBobE=;\n\t4:hQyV4YWcr4yGIWGsk2HvPPK1gAPFDPXxovjFuZ4k2UMJ8W2aI8TktbonmLOVcdrIhG/IJnNm/NukhKJmWqYk+qGXtJjj+9JKEC/VpFkwlLw6UAuuALxFl/epDajdqJmgFQ2Xyr0AOoSrv8kcKoqKK7K+UwLehZhoKeuWE8MX2JMUtGJIU+5J+KAFhqs6hn28R52lej8Vhlkam/6hGUn0U5KRgIFtsnVmnVk+/BdiFi4BPzia4t41jw2u6eFsn5G3gObMht+cURcctmoryxJpAA==",
            "=?us-ascii?Q?1; CY4PR0701MB3634;\n\t23:3QUNBh6oKNBbqQQsBZeoAAmpY2ObmwFeeOP/V/n?=\n\tEBKmZWnN/5V6rUyIaSKpfESrctb4dbPyal5ASD8Y/6IhUg+0n/+BigR9yYHT9QbRz1eJzI4c7CcGJrVJyZ5g2WqlBka2wn4hmQqdDeEcpY0XRALa22pLeZz6prdlBTeb14bMU7Ti8xdw0PddVc9Cm0EjmRntPlQKWYJBOQct3OuEZTrVu47twnoyad/MYJMX7xcg+LprtU4ZRKlrzobOfu8QM5KYwlfIUkr+ZEak+OXj2Jel/kF90eGHW22CacMqyqpOQ8lH5OC6JMVPsxoLN6ZOEFmrfIxjbIYpDR1Fe/xE+8qBrtlnatHuUAGwAuoK9fR9C4HAaEPONu0s52EEGAPJ8jmfCaKvChF3pR/ImEADh9/7ZJ67k8nlzYlFmcPoeASeVzKx7tlK/LBK5RlL5nKsPVneUUpf77Kksu7fb2II0YbXGo7k7d3EuPPnsK30NBZV0TZz4m6UVAIVfkEzV+TYfoviyj/PLUjoSw7eeDxe4dyWaPnyUTcasBwSq91VjFDBDJO2GmvvUItNmDrB4tfEN78rD1p/bO/QIVFL1EtBhZCXssF1lf5iaFh8kXgmsSL2rAdY2wyM8cHvOWlBqR5r/h2XCbqI1Z/BQjMPFytvHwHnS+S+GCUfLpEErkKBrSxEKHirhoS8YsebaIDtbGz/ZXqhKgqwszkrx6jGAS2+qIfJiNkBio8rR+ixYSLF+lYdZktT1duTa92NrY56rn6ublDGvcW1ay8bIgCZuYtWS84qR2kuTRNWDe+4BfUmi0853qB+SyUCCgMUO76wCOCPFd+OlijhW3H2s7l9VuMpFZ+YfPU/vGCRqXRyzGxd1DM66G32qzoBJ42HbQm3mGMAdVs/DH+e407jnUIUp0UoIqIum49KtT1T21QjDMNYh4xBrYG9Iu+muJDswCZ95Lpco1Z3dKuRoMLuc8nIx2bzcOksbI7j32GxJOntUkXw2JD+pGUR+Ll+DJ/v/KpEj3vSFahsQV0eoXMHsFKTsj/KiyeYM+Qt1b+dAdnRaQraYc0LhDnxIOw3Tfl5ovyDi4kOd0muNZ7UU4by1Vl6KlC/iPvT0Py4b+EwLGpsomSoSPsX3Z8K86oJ8EPhG7rxk/9fIFf+ALkJJ7uKFd5ZBxGTtZH7fLByDc1Ua8H3Scp3GMVd+a4IxHVFwepcglwGQ2iH09VDy/CtJXNhol7xi/WBQyiI5uqs/1otvJz7khNj+KMIHb5biklR+Y69FvOnE8wxr5Gm5nk/4bbRBc3ZNcJLhg2Mc41NwYffyk9EZCam8Mgll/rFSmpOiqcnmKt5Ohb3RZN3gpiqRZl+8hOn/9V1FH+gTf1oDdIvJOpa0xzcfFCM=",
            "1; CY4PR0701MB3634;\n\t6:+I/IcgSvfuZVei/DDmFT2+4hddKuW3iSjcuelwmBbLWDj25gxDhjegoq7kAYM/wH+BsMynb/oLZE89slxOVr08jaVKUb/yophB9leLMHVNpTk/Zipus7HQJEJi9WDTDBczT7JUWKVKYWi64XAvADxkj7G+7z6JlKf7thFVbCbCD9TiiVYM3YRifOgAbIEnT4n9q7jIzRGKFD2t3wvjlgd3wMRtfPK/KxBxYY3Ku7fMrPfKARDBxmxv9OJikfswS8XV4NMJM3pZzNgDVG9QykKZhSiuAqj44892fWeqLSzetAjMRul07FHpt1Hj319fAoeBHkkVT6QzkrtvPy+ILtj+YPkEm1P/7oNMekpYoQ5PQ64SsnB02DSwvJjW9mvYYPXBJP1s8DVh+x9NseoMFy5I8P3N9N8pLZIUao8sDRSK2r8Spg1vhuZ+Y4LTZtzs+oB3sLCcYA6/KZ5m3I2h5Rww==;\n\t5:hNPEAJds+1zSdv6rRIKZC8PylP0YVuwMmpgRIN1K8dYFTF12FBBwWcjLH5MiReBdGZ3H0HRkzRrvaK6sQZqifGYh+i0GfQUZWpXdDLqpEeus6hzv/nbUhu6Z8cUebrFHyOsyALRJgAbiesJCRYBSyvoF2w9GbqtSf2uVR5bvdmg=;\n\t7:vF/HLE416CnAk+y/MjcnIVYPLLXLqqQf06zvwU7BeQ7QcZ6hmde68nKa25hxazmFGKMF/6b29VmLZQajftspoqJ3jn5IcB4vdFb89dkfpodWNTd/0Plxevb0ML45utY9UmQUTDfW7h9qnC4o4zeH8iTQO+z2t/6qZBVuSgk6Asrkpf9mezbf0Zdlj8U3oW4wertRXcMkUGDe/i2PMP4xcXXwH8+FkQ5n/lU8p5szDO8mvTACcdH/yTvYlhqrcFf+"
        ],
        "X-MS-TrafficTypeDiagnostic": "CY4PR0701MB3634:",
        "X-Microsoft-Antispam-PRVS": "<CY4PR0701MB36340D374EA2CB3A90E62088F0500@CY4PR0701MB3634.namprd07.prod.outlook.com>",
        "X-Exchange-Antispam-Report-Test": "UriScan:;",
        "X-MS-Exchange-SenderADCheck": "1",
        "X-Exchange-Antispam-Report-CFA-Test": "BCL:0; PCL:0;\n\tRULEID:(8211001083)(6040522)(2401047)(8121501046)(5005006)(10201501046)(3002001)(93006095)(3231311)(944501410)(52105095)(149027)(150027)(6041310)(20161123564045)(20161123562045)(20161123558120)(20161123560045)(201703131423095)(201702281528075)(20161123555045)(201703061421075)(201703061406153)(6072148)(201708071742011)(7699016);\n\tSRVR:CY4PR0701MB3634; BCL:0; PCL:0; RULEID:; SRVR:CY4PR0701MB3634; ",
        "X-Forefront-PRVS": "074040B844",
        "X-Forefront-Antispam-Report": "SFV:NSPM;\n\tSFS:(10009020)(366004)(136003)(346002)(396003)(39850400004)(376002)(199004)(189003)(69596002)(25786009)(6512007)(316002)(6116002)(3846002)(55236004)(7736002)(305945005)(26005)(4326008)(107886003)(53936002)(16526019)(186003)(16586007)(97736004)(575784001)(478600001)(6486002)(72206003)(2351001)(48376002)(8676002)(47776003)(2361001)(66066001)(50466002)(36756003)(106356001)(81156014)(81166006)(53416004)(105586002)(11346002)(486006)(68736007)(5660300001)(446003)(476003)(2616005)(956004)(14444005)(44832011)(42882007)(76176011)(6506007)(6666003)(6916009)(8936002)(386003)(51416003)(50226002)(2906002)(52116002);\n\tDIR:OUT; SFP:1101; SCL:1; SRVR:CY4PR0701MB3634;\n\tH:hyd1sverma-dt.caveonetworks.com; FPR:; SPF:None; LANG:en;\n\tPTR:InfoNoRecords; A:1; MX:1; ",
        "Received-SPF": "None (protection.outlook.com: cavium.com does not designate\n\tpermitted sender hosts)",
        "X-Microsoft-Antispam-Message-Info": "OTWG/W7yM4ryuo3EiwsW68abQMzl7aeHXaidmfRRWei/+TEUzs9EhRFzI1044cTcbZp1Mihc5NwVzjXldlOuY9D7NwQo7ySm7B3Tw3/HfPThpPWg/NXfht2RdOjv3NCMPvqQPGv63WBNKKWUbPPGfdFDKo10UzndXu2/Z4hlu3I8ZLEmw1XwhYV+SIfrFpIera4IQvsSJ+pU0zLZ+LssNWnjXCxsX7DpcBBaoiP6f12fEJxbqs/j1CJbCxjK54TDmRup7i2+yXSBdnUoV/7POTr9SN+14bfyTi/4gu7IQOre+7l9WmgXWy5iym4wTlzuah/RkJWDYTAJ7dhS0sNamBi9UoAJreDIBYBwKw8vmcI=",
        "SpamDiagnosticOutput": "1:99",
        "SpamDiagnosticMetadata": "NSPM",
        "X-OriginatorOrg": "caviumnetworks.com",
        "X-MS-Exchange-CrossTenant-OriginalArrivalTime": "21 Jul 2018 18:18:24.2592\n\t(UTC)",
        "X-MS-Exchange-CrossTenant-Network-Message-Id": "5219223d-fa3c-4d67-9258-08d5ef365a25",
        "X-MS-Exchange-CrossTenant-FromEntityHeader": "Hosted",
        "X-MS-Exchange-CrossTenant-Id": "711e4ccf-2e9b-4bcf-a551-4094005b6194",
        "X-MS-Exchange-Transport-CrossTenantHeadersStamped": "CY4PR0701MB3634",
        "Subject": "[dpdk-dev] [PATCH v3 2/5] compress/zlib: add device PMD ops",
        "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": "From: Ashish Gupta <ashish.gupta@caviumnetworks.com>\n\nImplement device configure and queue pair\nsetup PMD ops\n\nSigned-off-by: Sunila Sahu <sunila.sahu@caviumnetworks.com>\nSigned-off-by: Shally Verma <shally.verma@caviumnetworks.com>\nSigned-off-by: Ashish Gupta <ashish.gupta@caviumnetworks.com>\n---\n drivers/compress/zlib/Makefile           |   1 +\n drivers/compress/zlib/meson.build        |   2 +-\n drivers/compress/zlib/zlib_pmd.c         |   2 +\n drivers/compress/zlib/zlib_pmd_ops.c     | 238 +++++++++++++++++++++++++++++++\n drivers/compress/zlib/zlib_pmd_private.h |  35 +++++\n 5 files changed, 277 insertions(+), 1 deletion(-)",
    "diff": "diff --git a/drivers/compress/zlib/Makefile b/drivers/compress/zlib/Makefile\nindex bd322c9..5cf8de6 100644\n--- a/drivers/compress/zlib/Makefile\n+++ b/drivers/compress/zlib/Makefile\n@@ -24,5 +24,6 @@ LDLIBS += -lrte_bus_vdev\n \n # library source files\n SRCS-$(CONFIG_RTE_LIBRTE_PMD_ZLIB) += zlib_pmd.c\n+SRCS-$(CONFIG_RTE_LIBRTE_PMD_ZLIB) += zlib_pmd_ops.c\n \n include $(RTE_SDK)/mk/rte.lib.mk\ndiff --git a/drivers/compress/zlib/meson.build b/drivers/compress/zlib/meson.build\nindex 3f0a77b..7748de2 100644\n--- a/drivers/compress/zlib/meson.build\n+++ b/drivers/compress/zlib/meson.build\n@@ -7,7 +7,7 @@ if not dep.found()\n endif\n \n deps += 'bus_vdev'\n-sources = files('zlib_pmd.c')\n+sources = files('zlib_pmd.c', 'zlib_pmd_ops.c')\n ext_deps += dep\n pkgconfig_extra_libs += '-lz'\n \ndiff --git a/drivers/compress/zlib/zlib_pmd.c b/drivers/compress/zlib/zlib_pmd.c\nindex 39d3628..9363808 100644\n--- a/drivers/compress/zlib/zlib_pmd.c\n+++ b/drivers/compress/zlib/zlib_pmd.c\n@@ -21,6 +21,8 @@ zlib_create(const char *name,\n \t\treturn -ENODEV;\n \t}\n \n+\tdev->dev_ops = rte_zlib_pmd_ops;\n+\n \treturn 0;\n }\n \ndiff --git a/drivers/compress/zlib/zlib_pmd_ops.c b/drivers/compress/zlib/zlib_pmd_ops.c\nnew file mode 100644\nindex 0000000..645c5b1\n--- /dev/null\n+++ b/drivers/compress/zlib/zlib_pmd_ops.c\n@@ -0,0 +1,238 @@\n+/* SPDX-License-Identifier: BSD-3-Clause\n+ * Copyright(c) 2018 Cavium Networks\n+ */\n+\n+#include <string.h>\n+\n+#include <rte_common.h>\n+#include <rte_malloc.h>\n+\n+#include \"zlib_pmd_private.h\"\n+\n+static const struct rte_compressdev_capabilities zlib_pmd_capabilities[] = {\n+\t{   /* Deflate */\n+\t\t.algo = RTE_COMP_ALGO_DEFLATE,\n+\t\t.comp_feature_flags = (RTE_COMP_FF_NONCOMPRESSED_BLOCKS |\n+\t\t\t\t\tRTE_COMP_FF_HUFFMAN_FIXED |\n+\t\t\t\t\tRTE_COMP_FF_HUFFMAN_DYNAMIC |\n+\t\t\t\t\tRTE_COMP_FF_OOP_SGL_IN_SGL_OUT),\n+\t\t.window_size = {\n+\t\t\t.min = 8,\n+\t\t\t.max = 15,\n+\t\t\t.increment = 1\n+\t\t},\n+\t},\n+\n+\tRTE_COMP_END_OF_CAPABILITIES_LIST()\n+\n+};\n+\n+/** Configure device */\n+static int\n+zlib_pmd_config(struct rte_compressdev *dev,\n+\t\tstruct rte_compressdev_config *config)\n+{\n+\tstruct rte_mempool *mp;\n+\tchar mp_name[RTE_MEMPOOL_NAMESIZE];\n+\tstruct zlib_private *internals = dev->data->dev_private;\n+\n+\tsnprintf(mp_name, RTE_MEMPOOL_NAMESIZE,\n+\t\t\t\"stream_mp_%u\", dev->data->dev_id);\n+\tmp = internals->mp;\n+\tif (mp == NULL) {\n+\t\tmp = rte_mempool_create(mp_name,\n+\t\t\t\tconfig->max_nb_priv_xforms +\n+\t\t\t\tconfig->max_nb_streams,\n+\t\t\t\tsizeof(struct zlib_priv_xform),\n+\t\t\t\t0, 0, NULL, NULL, NULL,\n+\t\t\t\tNULL, config->socket_id,\n+\t\t\t\t0);\n+\t\tif (mp == NULL) {\n+\t\t\tZLIB_PMD_ERR(\"Cannot create private xform pool on \"\n+\t\t\t\"socket %d\\n\", config->socket_id);\n+\t\t\treturn -ENOMEM;\n+\t\t}\n+\t\tinternals->mp = mp;\n+\t}\n+\treturn 0;\n+}\n+\n+/** Start device */\n+static int\n+zlib_pmd_start(__rte_unused struct rte_compressdev *dev)\n+{\n+\treturn 0;\n+}\n+\n+/** Stop device */\n+static void\n+zlib_pmd_stop(__rte_unused struct rte_compressdev *dev)\n+{\n+}\n+\n+/** Close device */\n+static int\n+zlib_pmd_close(struct rte_compressdev *dev)\n+{\n+\tstruct zlib_private *internals = dev->data->dev_private;\n+\trte_mempool_free(internals->mp);\n+\tinternals->mp = NULL;\n+\treturn 0;\n+}\n+\n+/** Get device statistics */\n+static void\n+zlib_pmd_stats_get(struct rte_compressdev *dev,\n+\t\tstruct rte_compressdev_stats *stats)\n+{\n+\tint qp_id;\n+\n+\tfor (qp_id = 0; qp_id < dev->data->nb_queue_pairs; qp_id++) {\n+\t\tstruct zlib_qp *qp = dev->data->queue_pairs[qp_id];\n+\n+\t\tstats->enqueued_count += qp->qp_stats.enqueued_count;\n+\t\tstats->dequeued_count += qp->qp_stats.dequeued_count;\n+\n+\t\tstats->enqueue_err_count += qp->qp_stats.enqueue_err_count;\n+\t\tstats->dequeue_err_count += qp->qp_stats.dequeue_err_count;\n+\t}\n+}\n+\n+/** Reset device statistics */\n+static void\n+zlib_pmd_stats_reset(struct rte_compressdev *dev)\n+{\n+\tint qp_id;\n+\n+\tfor (qp_id = 0; qp_id < dev->data->nb_queue_pairs; qp_id++) {\n+\t\tstruct zlib_qp *qp = dev->data->queue_pairs[qp_id];\n+\n+\t\tmemset(&qp->qp_stats, 0, sizeof(qp->qp_stats));\n+\t}\n+}\n+\n+/** Get device info */\n+static void\n+zlib_pmd_info_get(struct rte_compressdev *dev,\n+\t\tstruct rte_compressdev_info *dev_info)\n+{\n+\tif (dev_info != NULL) {\n+\t\tdev_info->driver_name = dev->device->name;\n+\t\tdev_info->feature_flags = dev->feature_flags;\n+\t\tdev_info->capabilities = zlib_pmd_capabilities;\n+\t}\n+}\n+\n+/** Release queue pair */\n+static int\n+zlib_pmd_qp_release(struct rte_compressdev *dev, uint16_t qp_id)\n+{\n+\tstruct zlib_qp *qp = dev->data->queue_pairs[qp_id];\n+\n+\tif (qp != NULL) {\n+\t\trte_ring_free(qp->processed_pkts);\n+\t\trte_free(qp);\n+\t\tdev->data->queue_pairs[qp_id] = NULL;\n+\t}\n+\treturn 0;\n+}\n+\n+/** set a unique name for the queue pair based on its name, dev_id and qp_id */\n+static int\n+zlib_pmd_qp_set_unique_name(struct rte_compressdev *dev,\n+\t\tstruct zlib_qp *qp)\n+{\n+\tunsigned int n = snprintf(qp->name, sizeof(qp->name),\n+\t\t\t\t\"zlib_pmd_%u_qp_%u\",\n+\t\t\t\tdev->data->dev_id, qp->id);\n+\n+\tif (n >= sizeof(qp->name))\n+\t\treturn -1;\n+\n+\treturn 0;\n+}\n+\n+/** Create a ring to place process packets on */\n+static struct rte_ring *\n+zlib_pmd_qp_create_processed_pkts_ring(struct zlib_qp *qp,\n+\t\tunsigned int ring_size, int socket_id)\n+{\n+\tstruct rte_ring *r = qp->processed_pkts;\n+\n+\tif (r) {\n+\t\tif (rte_ring_get_size(r) >= ring_size) {\n+\t\t\tZLIB_PMD_INFO(\"Reusing existing ring %s for processed\"\n+\t\t\t\t\t\" packets\", qp->name);\n+\t\t\treturn r;\n+\t\t}\n+\n+\t\tZLIB_PMD_ERR(\"Unable to reuse existing ring %s for processed\"\n+\t\t\t\t\" packets\", qp->name);\n+\t\treturn NULL;\n+\t}\n+\n+\treturn rte_ring_create(qp->name, ring_size, socket_id,\n+\t\t\t\t\t\tRING_F_EXACT_SZ);\n+}\n+\n+/** Setup a queue pair */\n+static int\n+zlib_pmd_qp_setup(struct rte_compressdev *dev, uint16_t qp_id,\n+\t\tuint32_t max_inflight_ops, int socket_id)\n+{\n+\tstruct zlib_qp *qp = NULL;\n+\n+\t/* Free memory prior to re-allocation if needed. */\n+\tif (dev->data->queue_pairs[qp_id] != NULL)\n+\t\tzlib_pmd_qp_release(dev, qp_id);\n+\n+\t/* Allocate the queue pair data structure. */\n+\tqp = rte_zmalloc_socket(\"ZLIB PMD Queue Pair\", sizeof(*qp),\n+\t\t\t\t\tRTE_CACHE_LINE_SIZE, socket_id);\n+\tif (qp == NULL)\n+\t\treturn (-ENOMEM);\n+\n+\tqp->id = qp_id;\n+\tdev->data->queue_pairs[qp_id] = qp;\n+\n+\tif (zlib_pmd_qp_set_unique_name(dev, qp))\n+\t\tgoto qp_setup_cleanup;\n+\n+\tqp->processed_pkts = zlib_pmd_qp_create_processed_pkts_ring(qp,\n+\t\t\tmax_inflight_ops, socket_id);\n+\tif (qp->processed_pkts == NULL)\n+\t\tgoto qp_setup_cleanup;\n+\n+\tmemset(&qp->qp_stats, 0, sizeof(qp->qp_stats));\n+\treturn 0;\n+\n+qp_setup_cleanup:\n+\tif (qp) {\n+\t\trte_free(qp);\n+\t\tqp = NULL;\n+\t}\n+\treturn -1;\n+}\n+\n+struct rte_compressdev_ops zlib_pmd_ops = {\n+\t\t.dev_configure\t\t= zlib_pmd_config,\n+\t\t.dev_start\t\t= zlib_pmd_start,\n+\t\t.dev_stop\t\t= zlib_pmd_stop,\n+\t\t.dev_close\t\t= zlib_pmd_close,\n+\n+\t\t.stats_get\t\t= zlib_pmd_stats_get,\n+\t\t.stats_reset\t\t= zlib_pmd_stats_reset,\n+\n+\t\t.dev_infos_get\t\t= zlib_pmd_info_get,\n+\n+\t\t.queue_pair_setup\t= zlib_pmd_qp_setup,\n+\t\t.queue_pair_release\t= zlib_pmd_qp_release,\n+\n+\t\t.private_xform_create\t= NULL,\n+\t\t.private_xform_free\t= NULL,\n+\n+\t\t.stream_create\t= NULL,\n+\t\t.stream_free\t= NULL\n+};\n+\n+struct rte_compressdev_ops *rte_zlib_pmd_ops = &zlib_pmd_ops;\ndiff --git a/drivers/compress/zlib/zlib_pmd_private.h b/drivers/compress/zlib/zlib_pmd_private.h\nindex d26a740..0e391a4 100644\n--- a/drivers/compress/zlib/zlib_pmd_private.h\n+++ b/drivers/compress/zlib/zlib_pmd_private.h\n@@ -27,6 +27,41 @@ int zlib_logtype_driver;\n \tZLIB_PMD_LOG(WARNING, fmt, ## args)\n \n struct zlib_private {\n+\tstruct rte_mempool *mp;\n };\n \n+struct zlib_qp {\n+\tstruct rte_ring *processed_pkts;\n+\t/**< Ring for placing process packets */\n+\tstruct rte_compressdev_stats qp_stats;\n+\t/**< Queue pair statistics */\n+\tuint16_t id;\n+\t/**< Queue Pair Identifier */\n+\tchar name[RTE_COMPRESSDEV_NAME_MAX_LEN];\n+\t/**< Unique Queue Pair Name */\n+} __rte_cache_aligned;\n+\n+/* Algorithm handler function prototype */\n+typedef void (*comp_func_t)(struct rte_comp_op *op, z_stream *strm);\n+\n+typedef int (*comp_free_t)(z_stream *strm);\n+\n+/** ZLIB Stream structure */\n+struct zlib_stream {\n+\tz_stream strm;\n+\t/**< zlib stream structure */\n+\tcomp_func_t comp;\n+\t/**< Operation (compression/decompression) */\n+\tcomp_free_t free;\n+\t/**< Free Operation (compression/decompression) */\n+} __rte_cache_aligned;\n+\n+/** ZLIB private xform structure */\n+struct zlib_priv_xform {\n+\tstruct zlib_stream stream;\n+} __rte_cache_aligned;\n+\n+/** Device specific operations function pointer structure */\n+extern struct rte_compressdev_ops *rte_zlib_pmd_ops;\n+\n #endif /* _RTE_ZLIB_PMD_PRIVATE_H_ */\n",
    "prefixes": [
        "v3",
        "2/5"
    ]
}