get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

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

{
    "id": 43277,
    "url": "http://patches.dpdk.org/api/patches/43277/?format=api",
    "web_url": "http://patches.dpdk.org/project/dpdk/patch/1532357474-9544-2-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": "<1532357474-9544-2-git-send-email-shally.verma@caviumnetworks.com>",
    "list_archive_url": "https://inbox.dpdk.org/dev/1532357474-9544-2-git-send-email-shally.verma@caviumnetworks.com",
    "date": "2018-07-23T14:51:10",
    "name": "[v4,1/5] compress/zlib: add ZLIB PMD",
    "commit_ref": null,
    "pull_url": null,
    "state": "superseded",
    "archived": true,
    "hash": "21ad5e79c00e204a997d98bc65285d3feb2055e4",
    "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/1532357474-9544-2-git-send-email-shally.verma@caviumnetworks.com/mbox/",
    "series": [
        {
            "id": 718,
            "url": "http://patches.dpdk.org/api/series/718/?format=api",
            "web_url": "http://patches.dpdk.org/project/dpdk/list/?series=718",
            "date": "2018-07-23T14:51:09",
            "name": "compress: add ZLIB compression PMD",
            "version": 4,
            "mbox": "http://patches.dpdk.org/series/718/mbox/"
        }
    ],
    "comments": "http://patches.dpdk.org/api/patches/43277/comments/",
    "check": "success",
    "checks": "http://patches.dpdk.org/api/patches/43277/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 7B99C3257;\n\tMon, 23 Jul 2018 16:51:49 +0200 (CEST)",
            "from NAM05-DM3-obe.outbound.protection.outlook.com\n\t(mail-dm3nam05hn0205.outbound.protection.outlook.com [104.47.49.205])\n\tby dpdk.org (Postfix) with ESMTP id 5AD943195\n\tfor <dev@dpdk.org>; Mon, 23 Jul 2018 16:51:47 +0200 (CEST)",
            "from hyd1sverma-dt.caveonetworks.com (115.113.156.2) by\n\tMWHPR0701MB3641.namprd07.prod.outlook.com (2603:10b6:301:7d::34) with\n\tMicrosoft SMTP Server (version=TLS1_2,\n\tcipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.973.16;\n\tMon, 23 Jul 2018 14:51:44 +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=lptheu4xQsj+zjJRKDw/HqbzEw7JrJWMkCo5E0xBlNA=;\n\tb=If5ElUh0i4yvNa/OSfducXh5c02rcIcbmBRMasKFMF2y/PwelPB1v1bNhNFvN+G3cNCk8hCfXVlrA1g8r8VQZfxDeJiDqcRJA4uZI8e3e/DUn2C0gChHqfCDD0i+sUWHsDAhxhx4UQkhuwH1AzPBddrjyJcr/ttwyZj/j4fKCJs=",
        "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 <ashish.gupta@caviumnetworks.com>,\n\tSunila Sahu <sunila.sahu@caviumnetworks.com>",
        "Date": "Mon, 23 Jul 2018 20:21:10 +0530",
        "Message-Id": "<1532357474-9544-2-git-send-email-shally.verma@caviumnetworks.com>",
        "X-Mailer": "git-send-email 1.9.1",
        "In-Reply-To": "<1532357474-9544-1-git-send-email-shally.verma@caviumnetworks.com>",
        "References": "<1532357474-9544-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": "PN1PR0101CA0041.INDPRD01.PROD.OUTLOOK.COM\n\t(2603:1096:c00:c::27) To MWHPR0701MB3641.namprd07.prod.outlook.com\n\t(2603:10b6:301:7d::34)",
        "X-MS-PublicTrafficType": "Email",
        "X-MS-Office365-Filtering-Correlation-Id": "987cdfa2-0b0f-4554-5e74-08d5f0abcfe4",
        "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:MWHPR0701MB3641; ",
        "X-Microsoft-Exchange-Diagnostics": [
            "1; MWHPR0701MB3641;\n\t3:OADOCDp2LkGJ7uF/K7ShWq9FajMs5I9JbnaseJrNu9S+4eRPQPo6R6N4OC+QbbNZ3vha9qJvG/+H+jwSidUFhYkQHu6eqpxvbHCkaWgYdXVd5wpDL+CP0OIB6vhdvAW2rYy8O3LY+s0GoBzIyYQRjdX5or1sSZJ6F6Iu3ylG0SSbYc6Yq2QVfIaFeZHCaT5r0k+YF1VqyEUin+FH/K5pXTCKbjB8Fr76yxaybjLrWRJCVGkJa9/mky9PELIiwioL;\n\t25:JbxY5uRF1PXhLhC0VFRSoLlUugY8ffzOD8FYWATupCQbUgN0ZOcirCITvaIK82Xl5V5m/NrzPE+dNSLg3CkY+qJyfzEnlYYUzmrBc4+Jm/LLwgL6J4Sz/qWF1Q+gKxiqDwJ6BlS66QEGl4+3d8BugqjLYriJCH1Wa4p5lCGNL5IHYHA/AoePz+7d9W7BWEBziWJRF+MJPYQliKDOkZMkSUgU5fUJGJB1CRw6fm002kpZBDN5RXNnpNnxqy8BFcdHz3FDhbi+MzI1Hc5oCje3Tm1WRn7F5ExFZBSKWd9GzIByjsR4nDFHj+5EydTXm3o2wOAsnQt5b6zMZgvKDtZNCA==;\n\t31:OU4kaowy/WqCzKFCXGLGcGvLPBgotKBSbAJBAZzDIVHnkhkZh/DsV2Iqw5YZTrZ6DTCCueHftqsEjS1N94niswDa4MKO9Bp/ed9sixHwJ4vxx82QScrvJCSPO3yNDVERTSTGFkIyXORTw4XIDMy/k91MLEmFaSOpyn/VKOzj2ekMGpbjG+FGr0r6151+uCM0AbU4j4HCIu79PXnoMmVB2JfIaEhHrSzUkz7XVM/cz34=",
            "1; MWHPR0701MB3641;\n\t20:NzKjG+rj8eHc56YX1OSlTfzgk1yLZ+0T6OL/JM7k99C6sADO1tCgcUrCOYETlagfat8I6Vptwy03PbHZBSQkiSqDDy2oDhbfJAjm1r00HMWJiU0k3tyDkP6foIXLeeYmezeQGmmiwGE22OhgpjAMYQumgu0wOWaWZqo+r2+pquOPLozEMRSizCuK4RwQuKUCS4c16AMH+ql6taGPVqbVq8V8y51RpOVWBQ6jvcmOKb/NmMQOqK1tVEoxJxIzC3irjx1HrSBJRsPQgtNmSSA8egwd6mgFMtmKxr3waEeNyBdJ0+FpZ7uN/WUdI8CvPC9S1j+FBGPfZ1lhLqog8mueaiyv8gJ/YB9C4IuCLWQlJaPzb2RclT9gB4jv1B7zJZ6Yxmrjh/zdtmaqD7QZo6FwxthqbdqNnGIWsDMvgPfhvUIznlS5Haka+nIman0tn4P2DstrvIZ0lFChVLFlkL6sytI0wLVw/AyIW6msSo3XW6GgntvoTpiSjc7mV+ElrVsXvoDo40GUozwbLZvj+skaFe4/pVRsh8QyYlvSiqp4K0P5Low8MO+K5GLiFF0+HeZ1Fc5rA6ODSIrRwlvor22hGhNENAXo2NjtT8gUtLq+IvA=",
            "1; MWHPR0701MB3641;\n\t4:1fPCvDUu2VYmGjPnMU1lM8HAvUT8MI52zbYPPHnEUIe0Ez0O34HiKn5OziwvRwEDc5tBwVkA0GlWTuQsUBQNru6EwFoiqIyvg5Ov/3DXCTJrQq03ag6Q7OP26R1NHJ1Lj4FhMc0UJJwld9LYh+MuZVKRVO5xOOgn4ZQEc4pX3EEUY3InR5AwEeY2v/MVcRP10CROgvaM1c1/6WpmBVtq1ADc8P/EhM85eAJqKNSik523zKWNB9J9rcRahYyS4+Ge/C3dL09YxvXlkOCMcKHIP7fHPs5D0X3iv9SQnYRd8q7BuWZw5QqqTJF+DuING3fd3GM6+P6M29e0rRX/ev7mjp5Wl02LwxH0eUBsi2D67Sc=",
            "=?us-ascii?Q?1; MWHPR0701MB3641;\n\t23:mzhQDaTTdoptEkXBeOFBhb361MRw/TBb+UFYIND?=\n\t51W+MAZQ++sNVX8gWd6do0ZxHoB7tRqtgnGrBLi5eE6kkspv2zrK1L3yEtRgvThsrIlf5eaiYFlYPymIkNzU5fnf9T2R7lKm5iZGwyZioDNj4J+UW8S6Qc+DDjEJmLcX4K8JgTyqgOPMVJ/FU2NSkh5c+z1e5/SYj3K8HhKN1XP9t0aX06QRBgo8eWJrdwgfYxqXNWS3GYce5oMhN3Sf3Hh7LZIHuGQ0vzicJ0ZIgcZr1ucIeHe5PMtIDFtX0/CAUTl0PYu8vVWK7f3+qwVzmxYwk3o/kRvH/aUjINfI4L/4H3xYvaOvzoJ4fte2WYaSey0oWbHfC4Iw4BVYGa4hJwHdtqN+y5xQVADf9ST1//RI4UKWHEk7FpGsfVGVJB5vrcimxXzyWLWRzUqV0mEOgFM9RDrFNG8i0PyO5JAoxhUftcG+6tanJg9dZhy1ZYIAfQGq0qlaQhV8/Oi5GnNJuxr8G4PXFJOEmr/GIns8j9pYjJ2+pJjUisfn9cg6iY13MqrDGqa0pbrwN7wHfdpOk8TQww00icr3fhYuVolQwpJMcu3ARpl7U0ZyfvMFC1TQst9FgmgHHryTLa97LEmP2xo2rPV1vgqnpoFKvFAmeWwJJjEFwIRrlq10Nin7ezz+ndKRwVNovL5cD9q/eUTcrp+HNoCxT4kP/0aLGPy6zHRs9/IhJVYXxSyAaCLlF2DZq/tI8Ztweehggo8F35xjEndy2dtKZ2KnpOY/yijj004/VFvQC6ih0u8qZhNkdaO4BLKhjGXPwxLbdn1bkxUEl/LGTcFzwXhQKJUOJ2ui3tTOffw5YrE9Q8SdO38LhMJhR7K38lBMxxZ504i67UQJKhKoyeG1oW399mGZxQey5tm40DtHkb/yujUIVaJE5ayAhNQjBp46Id+Z79wIz3QJ53ezrLpK4ildnhO9jqSx7OSRfVuUvzCn6QN9iRtj+7vVLDuofS32kcscsCwD8es01iNS8U2sSzb80Lp65pNdQaNum7kVW61dNDkACo3thstgHRbhS7KIbdlCW+BjTzV6Yh1jfmLYcvrW5p/efuybvkG+kgXpzVSShymwSbEmaPpMICToSvLCLNpPSieYQ1BXjs1E29WI8zZkAnEv2WBfkr6XeLtR/3yPlq7vV5pcrsTTvFnsMnfjjEaucQ8hPCqHJVqW1CHAVKb7bNB4ZG3j/a6SfhL4tpGLVWP1N1pTnGvDNdggqpPp1xhdwrN6n2tBlQ/Ff/VnnYDwRr9uRwPK51K5H9raxNPjLRH+TbyDx34miBhcJAzYRPESiBg08a5zZgFHuCrjFMTzgYVDWdF1QOn7DHyCyfBuYhuC5ghBX+7ltLg0vaX43BnDQILjKdZeizEgii/F2aMRmWGf/3Lo9rVlIcUMuCr/arGqnzKLPaQQdRO6OdEPjzIsvYryiD2dLbwPa",
            "=?us-ascii?Q?1; MWHPR0701MB3641;\n\t6:16Zh5b6exDO8UcpPlB1J7xNYEN7085fvhVJLWnOj?=\n\tchRyrTHc+MevMLcMlRzOy8SAgI92vMoQjT6x2rvmR+ElksHr3t+AZ5zMhyCad2t1+QFR9ArXlVGrVa1a1wxUKg7PrGZ4QjY9og5QstBU6AWGlO/3I9lxOvRVpLwIdkJIqM2xOd1cWwXN6SCn2v93Q3sdgVqEQ5YpgGF/eKZC1h5oc0loxdf1HoZVrfiOVPqvGG/U57VvlkWUemrO+YhvkJ+HGAXILiNQUO4N1tcA21aiNP7tb4OKWKMkMNu3A7gaBVPPW6lHC6zreVdcEkfWrJ09+2gEd7jWA3qXpabduyXfe+pgAoOb9btwGteXh+DcwVln2TNEe1F5N0WoFBfKfN97qVvn3d3jL5YdrQpYHn0xOJ+cSuK4/wbNpadwAuuLkJhKwnWJSD0pyXhZES30dVmmyZTE2rrcyRQ65NdIfAwSovUjUqYk9aVB/tuP1pfthfhFb93N26zfohpQM+AktQ2a;\n\t5:cXAnWzkkA+99GeW7xywh27fXlvskzX7f3Mwc2xT6S/YEL+/6or45uoxqHYECVEs+p1793ga9xql7AJR3RCTJ4MqLIzMLWTP+nn2RbdSPvJfCGUDaWnzawZ4sxkXExLWsbYpuMUPtAQq9Xa8o5nMnRNhUP/bMPPL8gFsVKm2NaII=;\n\t7:Kju48pRz8sJ4CT6YNVN09cxInoVsiveni/hoo6z6xOkTSqhPiJTqex4vlicNXExUvf/7TlDZp6SATosaXgcqIvvzw3mUA7TYScEK0F2D0NCNJnPtg35bQnxeD+yyQxRl1pZ0kvvSZhZmVBGBBst61/TemL8roz+VB3cFflRZfW0IMfCNn6NyJEaRiVsTdYrMiaHbevNbz8TcKsvfvxt+T6O+wKeQX6hct6QGECOjZ0bA9V9Y05rNf9UkpSY8FUk6"
        ],
        "X-MS-TrafficTypeDiagnostic": "MWHPR0701MB3641:",
        "X-Microsoft-Antispam-PRVS": "<MWHPR0701MB364182F1ED4EB7D138D04BB8F0560@MWHPR0701MB3641.namprd07.prod.outlook.com>",
        "X-Exchange-Antispam-Report-Test": "UriScan:(66839620246622)(228905959029699);",
        "X-MS-Exchange-SenderADCheck": "1",
        "X-Exchange-Antispam-Report-CFA-Test": "BCL:0; PCL:0;\n\tRULEID:(8211001083)(6040522)(2401047)(5005006)(8121501046)(3231311)(2232096)(944501410)(52105095)(3002001)(10201501046)(93006095)(149027)(150027)(6041310)(201703131423095)(201702281528075)(20161123555045)(201703061421075)(201703061406153)(20161123560045)(20161123564045)(20161123558120)(20161123562045)(6072148)(201708071742011)(7699016);\n\tSRVR:MWHPR0701MB3641; BCL:0; PCL:0; RULEID:; SRVR:MWHPR0701MB3641; ",
        "X-Forefront-PRVS": "0742443479",
        "X-Forefront-Antispam-Report": "SFV:SPM;\n\tSFS:(10009020)(396003)(366004)(39860400002)(136003)(346002)(376002)(199004)(189003)(6512007)(25786009)(53936002)(48376002)(107886003)(47776003)(66066001)(50466002)(14444005)(50226002)(2351001)(69596002)(55236004)(4326008)(36756003)(446003)(42882007)(7736002)(575784001)(305945005)(5660300001)(3846002)(478600001)(6116002)(72206003)(11346002)(316002)(8676002)(97736004)(44832011)(76176011)(16586007)(81156014)(68736007)(81166006)(52116002)(476003)(956004)(2616005)(486006)(51416003)(26005)(2906002)(386003)(6506007)(2361001)(6486002)(105586002)(6916009)(53416004)(186003)(6666003)(54906003)(16526019)(106356001)(8936002)(59010400001);\n\tDIR:OUT; SFP:1501; SCL:5; SRVR:MWHPR0701MB3641;\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": "DO6Qe/e6lQXJvszGZgQKP1lfzl4hQjR0nAQgGs1NrSrSLXSXVzzBKtunlAdznZPKi0shdgFuWarHw0baZ525LPIwSiPRzah+lPIEavh0SLyulmJKrjWmDc1aGORskUXfK4uDZB8HiiuSWW8LjJd5BombqZQl00OGTTzWqg9hKAP3vvWHV8RRAOs7N88mksP+rCE12pURKNTey3vF9zTVzjAO8FBWxQMpnh/12e4Mm5uKVYvMtM4MqoGRBbFeiT4ytZBHA99PTKdSwa1sNGJv0iki9c9qcuMxIXoTRyWc9ahAJs//SkOSHzGAPMP7rOIz59H9YS2TWo/uEigySBhqS6Ik1u8wJGDYgtzjT24UpkhxHKrd6LG7dpQzWHy/A9qp0u6rSn3F6lZIPonQHl4QRvs1fsPTypRkD2Povn9/F00qORVBrZjZuoM4eITPmecOFShVu+4Bh5ocIBczWAQN4r0SCHcbgYIli81ncnHVOyVFvHO5ICyg+qkB9FpRD1qa7x0TLfGA21q/ikCpg+QBPIs51WvDAVRlLPsbdjBNizSVV8YM/yU8CXFhS467+NUyQtD8KEj8Qvzr0TTL59Qzv2pXeTtdYU6fp+x67odmnCYoBmAlQ+E1PqEaBMj+a8MidHVxp/PelDOU/9owIIGUMmfIAa8EmEA2GMYCFKUrORm75Q2ywBJ3lEUgwesfQwkfh9UJre+2c3CwhbQfCQHQVA==",
        "SpamDiagnosticOutput": "1:22",
        "X-OriginatorOrg": "caviumnetworks.com",
        "X-MS-Exchange-CrossTenant-OriginalArrivalTime": "23 Jul 2018 14:51:44.0560\n\t(UTC)",
        "X-MS-Exchange-CrossTenant-Network-Message-Id": "987cdfa2-0b0f-4554-5e74-08d5f0abcfe4",
        "X-MS-Exchange-CrossTenant-FromEntityHeader": "Hosted",
        "X-MS-Exchange-CrossTenant-Id": "711e4ccf-2e9b-4bcf-a551-4094005b6194",
        "X-MS-Exchange-Transport-CrossTenantHeadersStamped": "MWHPR0701MB3641",
        "Subject": "[dpdk-dev] [PATCH v4 1/5] compress/zlib: add ZLIB PMD",
        "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\nAdd initial PMD setup routines in compressdev\nframework. ZLIB PMD appears as virtual compression\ndevice. User would need to install zlib prior to\nenabling this PMD.\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 MAINTAINERS                                    |  3 +\n config/common_base                             |  5 ++\n drivers/compress/Makefile                      |  1 +\n drivers/compress/meson.build                   |  2 +-\n drivers/compress/zlib/Makefile                 | 28 +++++++++\n drivers/compress/zlib/meson.build              | 14 +++++\n drivers/compress/zlib/rte_pmd_zlib_version.map |  3 +\n drivers/compress/zlib/zlib_pmd.c               | 78 ++++++++++++++++++++++++++\n drivers/compress/zlib/zlib_pmd_private.h       | 32 +++++++++++\n mk/rte.app.mk                                  |  2 +\n 10 files changed, 167 insertions(+), 1 deletion(-)",
    "diff": "diff --git a/MAINTAINERS b/MAINTAINERS\nindex 7b2414d..ca27c6f 100644\n--- a/MAINTAINERS\n+++ b/MAINTAINERS\n@@ -872,6 +872,9 @@ M: Fiona Trahe <fiona.trahe@intel.com>\n F: drivers/compress/qat/\n F: drivers/common/qat/\n \n+ZLIB\n+M: Sunila Sahu <sunila.sahu@caviumnetworks.com>\n+F: drivers/compress/zlib/\n \n Eventdev Drivers\n ----------------\ndiff --git a/config/common_base b/config/common_base\nindex a061c21..d9b238c 100644\n--- a/config/common_base\n+++ b/config/common_base\n@@ -582,6 +582,11 @@ CONFIG_RTE_COMPRESSDEV_TEST=n\n CONFIG_RTE_LIBRTE_PMD_ISAL=n\n \n #\n+# Compile PMD for ZLIB compression device\n+#\n+CONFIG_RTE_LIBRTE_PMD_ZLIB=n\n+\n+#\n # Compile generic event device library\n #\n CONFIG_RTE_LIBRTE_EVENTDEV=y\ndiff --git a/drivers/compress/Makefile b/drivers/compress/Makefile\nindex 592497f..1f159a5 100644\n--- a/drivers/compress/Makefile\n+++ b/drivers/compress/Makefile\n@@ -4,5 +4,6 @@\n include $(RTE_SDK)/mk/rte.vars.mk\n \n DIRS-$(CONFIG_RTE_LIBRTE_PMD_ISAL) += isal\n+DIRS-$(CONFIG_RTE_LIBRTE_PMD_ZLIB) += zlib\n \n include $(RTE_SDK)/mk/rte.subdir.mk\ndiff --git a/drivers/compress/meson.build b/drivers/compress/meson.build\nindex 2352ad5..d2ca8fc 100644\n--- a/drivers/compress/meson.build\n+++ b/drivers/compress/meson.build\n@@ -1,7 +1,7 @@\n # SPDX-License-Identifier: BSD-3-Clause\n # Copyright(c) 2018 Intel Corporation\n \n-drivers = ['isal', 'qat']\n+drivers = ['isal', 'qat', 'zlib']\n \n std_deps = ['compressdev'] # compressdev pulls in all other needed deps\n config_flag_fmt = 'RTE_LIBRTE_@0@_PMD'\ndiff --git a/drivers/compress/zlib/Makefile b/drivers/compress/zlib/Makefile\nnew file mode 100644\nindex 0000000..bd322c9\n--- /dev/null\n+++ b/drivers/compress/zlib/Makefile\n@@ -0,0 +1,28 @@\n+# SPDX-License-Identifier: BSD-3-Clause\n+# Copyright(c) 2018 Cavium Networks\n+\n+include $(RTE_SDK)/mk/rte.vars.mk\n+\n+# library name\n+LIB = librte_pmd_zlib.a\n+\n+# build flags\n+CFLAGS += -O3\n+CFLAGS += $(WERROR_FLAGS)\n+CFLAGS += -DALLOW_EXPERIMENTAL_API\n+\n+# library version\n+LIBABIVER := 1\n+\n+# versioning export map\n+EXPORT_MAP := rte_pmd_zlib_version.map\n+\n+# external library dependencies\n+LDLIBS += -lrte_eal -lrte_mbuf -lrte_mempool -lrte_ring -lz\n+LDLIBS += -lrte_compressdev\n+LDLIBS += -lrte_bus_vdev\n+\n+# library source files\n+SRCS-$(CONFIG_RTE_LIBRTE_PMD_ZLIB) += zlib_pmd.c\n+\n+include $(RTE_SDK)/mk/rte.lib.mk\ndiff --git a/drivers/compress/zlib/meson.build b/drivers/compress/zlib/meson.build\nnew file mode 100644\nindex 0000000..3f0a77b\n--- /dev/null\n+++ b/drivers/compress/zlib/meson.build\n@@ -0,0 +1,14 @@\n+# SPDX-License-Identifier: BSD-3-Clause\n+# Copyright(c) 2018 Cavium Networks\n+\n+dep = dependency('zlib', required: false)\n+if not dep.found()\n+\tbuild = false\n+endif\n+\n+deps += 'bus_vdev'\n+sources = files('zlib_pmd.c')\n+ext_deps += dep\n+pkgconfig_extra_libs += '-lz'\n+\n+allow_experimental_apis = true\ndiff --git a/drivers/compress/zlib/rte_pmd_zlib_version.map b/drivers/compress/zlib/rte_pmd_zlib_version.map\nnew file mode 100644\nindex 0000000..ad6e191\n--- /dev/null\n+++ b/drivers/compress/zlib/rte_pmd_zlib_version.map\n@@ -0,0 +1,3 @@\n+DPDK_18.08 {\n+\tlocal: *;\n+};\ndiff --git a/drivers/compress/zlib/zlib_pmd.c b/drivers/compress/zlib/zlib_pmd.c\nnew file mode 100644\nindex 0000000..39d3628\n--- /dev/null\n+++ b/drivers/compress/zlib/zlib_pmd.c\n@@ -0,0 +1,78 @@\n+/* SPDX-License-Identifier: BSD-3-Clause\n+ * Copyright(c) 2018 Cavium Networks\n+ */\n+\n+#include <rte_bus_vdev.h>\n+#include <rte_common.h>\n+\n+#include \"zlib_pmd_private.h\"\n+\n+static int\n+zlib_create(const char *name,\n+\t\tstruct rte_vdev_device *vdev,\n+\t\tstruct rte_compressdev_pmd_init_params *init_params)\n+{\n+\tstruct rte_compressdev *dev;\n+\n+\tdev = rte_compressdev_pmd_create(name, &vdev->device,\n+\t\t\tsizeof(struct zlib_private), init_params);\n+\tif (dev == NULL) {\n+\t\tZLIB_PMD_ERR(\"driver %s: create failed\", init_params->name);\n+\t\treturn -ENODEV;\n+\t}\n+\n+\treturn 0;\n+}\n+\n+static int\n+zlib_probe(struct rte_vdev_device *vdev)\n+{\n+\tstruct rte_compressdev_pmd_init_params init_params = {\n+\t\t\"\",\n+\t\trte_socket_id()\n+\t};\n+\tconst char *name;\n+\tconst char *input_args;\n+\n+\tname = rte_vdev_device_name(vdev);\n+\n+\tif (name == NULL)\n+\t\treturn -EINVAL;\n+\tinput_args = rte_vdev_device_args(vdev);\n+\trte_compressdev_pmd_parse_input_args(&init_params, input_args);\n+\n+\treturn zlib_create(name, vdev, &init_params);\n+}\n+\n+static int\n+zlib_remove(struct rte_vdev_device *vdev)\n+{\n+\tstruct rte_compressdev *compressdev;\n+\tconst char *name;\n+\n+\tname = rte_vdev_device_name(vdev);\n+\tif (name == NULL)\n+\t\treturn -EINVAL;\n+\n+\tcompressdev = rte_compressdev_pmd_get_named_dev(name);\n+\tif (compressdev == NULL)\n+\t\treturn -ENODEV;\n+\n+\treturn rte_compressdev_pmd_destroy(compressdev);\n+}\n+\n+static struct rte_vdev_driver zlib_pmd_drv = {\n+\t.probe = zlib_probe,\n+\t.remove = zlib_remove\n+};\n+\n+RTE_PMD_REGISTER_VDEV(COMPRESSDEV_NAME_ZLIB_PMD, zlib_pmd_drv);\n+RTE_INIT(zlib_init_log);\n+\n+static void\n+zlib_init_log(void)\n+{\n+\tzlib_logtype_driver = rte_log_register(\"pmd.compress.zlib\");\n+\tif (zlib_logtype_driver >= 0)\n+\t\trte_log_set_level(zlib_logtype_driver, RTE_LOG_INFO);\n+}\ndiff --git a/drivers/compress/zlib/zlib_pmd_private.h b/drivers/compress/zlib/zlib_pmd_private.h\nnew file mode 100644\nindex 0000000..d26a740\n--- /dev/null\n+++ b/drivers/compress/zlib/zlib_pmd_private.h\n@@ -0,0 +1,32 @@\n+/* SPDX-License-Identifier: BSD-3-Clause\n+ * Copyright(c) 2018 Cavium Networks\n+ */\n+\n+#ifndef _RTE_ZLIB_PMD_PRIVATE_H_\n+#define _RTE_ZLIB_PMD_PRIVATE_H_\n+\n+#include <zlib.h>\n+#include <rte_compressdev.h>\n+#include <rte_compressdev_pmd.h>\n+\n+#define COMPRESSDEV_NAME_ZLIB_PMD\tcompress_zlib\n+/**< ZLIB PMD device name */\n+\n+#define DEF_MEM_LEVEL\t\t\t8\n+\n+int zlib_logtype_driver;\n+#define ZLIB_PMD_LOG(level, fmt, args...) \\\n+\trte_log(RTE_LOG_ ## level, zlib_logtype_driver, \"%s(): \"fmt \"\\n\", \\\n+\t\t\t__func__, ##args)\n+\n+#define ZLIB_PMD_INFO(fmt, args...) \\\n+\tZLIB_PMD_LOG(INFO, fmt, ## args)\n+#define ZLIB_PMD_ERR(fmt, args...) \\\n+\tZLIB_PMD_LOG(ERR, fmt, ## args)\n+#define ZLIB_PMD_WARN(fmt, args...) \\\n+\tZLIB_PMD_LOG(WARNING, fmt, ## args)\n+\n+struct zlib_private {\n+};\n+\n+#endif /* _RTE_ZLIB_PMD_PRIVATE_H_ */\ndiff --git a/mk/rte.app.mk b/mk/rte.app.mk\nindex 1590838..5b7c684 100644\n--- a/mk/rte.app.mk\n+++ b/mk/rte.app.mk\n@@ -228,6 +228,8 @@ _LDLIBS-$(CONFIG_RTE_LIBRTE_PMD_ISAL) += -lisal\n ifeq ($(CONFIG_RTE_LIBRTE_PMD_QAT_SYM),n)\n _LDLIBS-$(CONFIG_RTE_LIBRTE_PMD_QAT)  += -lrte_pmd_qat\n endif # CONFIG_RTE_LIBRTE_PMD_QAT_SYM\n+_LDLIBS-$(CONFIG_RTE_LIBRTE_PMD_ZLIB) += -lrte_pmd_zlib\n+_LDLIBS-$(CONFIG_RTE_LIBRTE_PMD_ZLIB) += -lz\n endif # CONFIG_RTE_LIBRTE_COMPRESSDEV\n \n ifeq ($(CONFIG_RTE_LIBRTE_EVENTDEV),y)\n",
    "prefixes": [
        "v4",
        "1/5"
    ]
}