get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

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

{
    "id": 43280,
    "url": "http://patches.dpdk.org/api/patches/43280/?format=api",
    "web_url": "http://patches.dpdk.org/project/dpdk/patch/1532357474-9544-5-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-5-git-send-email-shally.verma@caviumnetworks.com>",
    "list_archive_url": "https://inbox.dpdk.org/dev/1532357474-9544-5-git-send-email-shally.verma@caviumnetworks.com",
    "date": "2018-07-23T14:51:13",
    "name": "[v4,4/5] compress/zlib: support burst enqueue/dequeue",
    "commit_ref": null,
    "pull_url": null,
    "state": "superseded",
    "archived": true,
    "hash": "6e74165685027926283125f8aa21f26c2c4d9e55",
    "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-5-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/43280/comments/",
    "check": "success",
    "checks": "http://patches.dpdk.org/api/patches/43280/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 8236A4C8C;\n\tMon, 23 Jul 2018 16:51:58 +0200 (CEST)",
            "from NAM05-DM3-obe.outbound.protection.outlook.com\n\t(mail-eopbgr730077.outbound.protection.outlook.com [40.107.73.77])\n\tby dpdk.org (Postfix) with ESMTP id 707074C8C\n\tfor <dev@dpdk.org>; Mon, 23 Jul 2018 16:51:56 +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:51 +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=jVA7qaTC5BFNmGR6JQVnGFhXALaf3FAQCSA0sndsOok=;\n\tb=VU7b56O0uGlI/oWzvD9/e6T9QPimiRHrr1n7a1+pCXdYLmwtg7FUhoYlkRbqr6mNheBvMghf8b+Fu/WQMGrvaZH0oebB+2SaLakpsuSiJFJL26uannrPCFOIwiDJAktze++wF8v+fmaQMEzuJIRHdAtTwHZ7EH3pvpS4msMPjg0=",
        "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\tSunila Sahu <ssahu@caviumnetworks.com>,\n\tSunila Sahu <sunila.sahu@caviumnetworks.com>,\n\tAshish Gupta <ashish.gupta@caviumnetworks.com>",
        "Date": "Mon, 23 Jul 2018 20:21:13 +0530",
        "Message-Id": "<1532357474-9544-5-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": "97715fb2-8aa4-40e7-b348-08d5f0abd4c5",
        "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:MG+MXwAtC24bytT0MZ5GHBP+uIqoaHymagKonp1SUK1uZ4Q1aAI66sYMfjgzbkz4m1M2hEYL0OOTI5Lx3TDHsN2CvPgBDoENNalZbT4WL5n8VwUbEQEWGefJN6hjnvfM1ZnbIvEpiBU22jlUrHYk+c0qMBV4emDl62J5/Rn7CyTExXmom2oHK5z5F6PyLOwVfZqtfxzy0u0Zk7MUOqUuHhw0qk9LR4ZmTVH8hikTM7zXAnrLYsyuNpw2yp8XHbde;\n\t25:Za+Qe7+kykWgJ9FpJnnecbijFACHbx+7LiO6THTSHgErctA+evggkEwb302EJ0sund5MTPhu/FbL7mzE2K2BJMZWR2gnEHaw3ARDhqyTxADInf/q/BG9UOA94yfjQxUSCCnsx0aiMZ2L6IsRJch0OCwh11AIlpKUdWRxrVSbIIFPkJwlbwZCC9+ZAFesEILG+NNj1B6BQYAMtI6JPQqzQ0P2mY45hp7odT+b7GOmp3hoUc5En7wNY+8jVn+BKb7HZ/n3AVH4+dQWUGGxYVBKCDC7+g+FOINcT/RpTqI1lwGvy30NRLQxz54W/7KJs7eEvbDCs3R48cT0wbpyerpFlg==;\n\t31:B3XzlWNOUCV5yImj86OhP7CZzJNnzb4TC50KFGPITqRscdtup+ho3AZOxvaYP0xM+CwfFZ50lP7+PRMU5FzqYadcdeYVwtg9VE24OP1V+8teurLGr8xOaMPKWBzPoka6kO1FlEwYxnwGSnyPavUU/vxcHCxgXqDJly99NIpVmsnD+gmu1nCFCGa3vvxfYUUf98pLgooymlFGLggcW/xUCRbvuReebeQc6mLHVNQCQIU=",
            "1; MWHPR0701MB3641;\n\t20:0gdpAgjgiFo9WkdTyjML2I/xT6Ygm9CAGPHF2rDBBq1ECFtL8uLCcQWbzu6ZC1bd6fSMC3nwgupAIpkma3w/FoRJ7If2juVcSwOaYdrNnCme0EYkRwBgQDDEpwMD0MUZGzIEwAlnr7m43IHGBRV/34qU7XN0GVO6vpKrblhr8qkbEMGXpC8ATZtCy6ep2RW86i1ubhFQz0DbnfRNAjllJrLCKnGbH3MIwRsXbeIEhRUibtZe2Hl3nXGT4b5LHt0HJwGbYqlcQpisaFWZ3pW+xwuj+WGEIyA+/Dp/cDZAi+ILCcXOq6CYOOL5UjmIhhrauJNIu3JqlAP5ng4l8yw8fgBEBIzJkvq9vieUINlmS2SWJ6BrMwOXfISXsV5kflrMtzg4iJWiu9ZnbXMOAAphp6jnRJu27I6O5RUQ+z9DS8SGHT2LnX6QRRUjt/9AG5MFvqTIZNWbFwI7GYpyhub1bRNMQsJsIHqnKBDYTlylVF6RMj8EPPvqRrVXlqSvi4JZgK5zpwMz1xdSThncEgF0uLlLqF5F4lJZlDQUj52El0ApVxjt3+SdlPLsIQoZGg+iDCllf73Lt9gUZaLcItTMXoz8MeJbi5zdbUAv49TTgrk=;\n\t4:gv0OI8Fa5kOD09EIf2lk2Id5dT86X3Req49yflSqFEboHhMA8fYT+dxHIfpDn4N8tObzNYmC+GFujiGW+gRoEkwfefVaRrSXCr0IZtpaXVD7LsB7pVcZ5b4bwHINKssG8HP40fH4sYEoby3T5bJoQ5rZOmLtVm1SE61QH2QZPIjP1EtEA8Y06WY4/i3Fhl/EL2qDR3Oc2/5m5onBZ6R0RjDgs1EdWjhadh6wVXZ+eIF4xj9XbW1n4SEI+Oe9Z9XYbXMfIC/ZJiQLqpEcF4FMlw==",
            "=?us-ascii?Q?1; MWHPR0701MB3641;\n\t23:I8hVEdCXpg7QNEwUBEOlnvG0v7EjnuSwIgy3XvH?=\n\tp1A0dwi5bC6nNqfr6QxWLZhgWqUq4XLUv8aLY6JikTPiAOMFCzJ3tSq4leHKr1gzCP1XuqMk6jUscS84GJHyjIndYvTFmJS5PLXuheD4GihOu9/FIU8PQiWGx0UL2h32aRotnzHiw+E6DIF9/5yyy/pp059FTnDgs4SxdwN0PfLXsPd2Bpuw4c41sGx1WJw9jdPyLRCee8zLyow/y+xGF+d3AFWNMEis//ypenHQ89bNofdZzPj6RkpAnXHCFVDqDtnNeKEDf6syq8se3mnMVrVdSK/W/bGo5Xv6R9SQJPErWBbNyX2GJlxRQItAlHNn6gVvnPR9r5hI+OYOe8RHRa4xg6GSaEMr3gCD2TVNsn1+A9FwrrxZXEAg/GHA3qXX9brohnU1KaoXeJJFZ53Rx48LelwQqwR6XTuehgGdSad2os8Jxd06oWVprIfQHQ+ybepR8dFnPjxzMA5vx53eEcccqCZKOFrowqDOlw/nlg1cYUhqRjPwpAy3It9wq4ryRhHH5GbwqIrK0A1ylkYUQ1qrlabtFbSDOm30ELwqXYytz8CK7oFNLqjy0RWM/EBgnRb4zOtkdgfAFG0X6w12rN7GWiyrzHn3kBQLoo82Vfmu4TAhxaX/YTySrtcPBvrt2bSziV14gI1+tcz3JxwasbKMQVRWhFXYtkH3vs06UnOazjiwKY8PKt7q9KRWpwCyLZycQlWB7ufw5qkTMrYL8L+HAf7jko1Ic1ZE8r1csGCs+8SHjx60W4ehKF0qqlKYYGRbujCIHIg6xEyVpq8DSj3kGwGvvVysgHPAmQ4J0RKsoJTRdsI7LsurEKeiCO/75Qe2LFFWROyNW2bS5SrQG27TYIWPCaJhrcOF8TtbxRi6C+wjhUsFj9hZnLOcphyUTOgf3sFm7rZiLatLVQrhoJRTm2Ab4gt0p13lRe2Fd7oORxddzijb0UmYsYpl++5FXEQ30jsFD/4SjeP6WawaQptIGOJ5x/lOS6T1fOjasY5k3FNd85NqZEuHmbZC0OEhL9sox2/jRkx+h1zWu0aZjODa6wvQC0S7+Oz6fGwROHxjfyWiRrH6Qx55yRKIa/Z3aJ3u43MM/YTA4Z3QelDQTHdZnIQbf4t6MME2GaXHPAP/I9N7D1Dvg/DaT8wnD6/gC0RzuttY5CRRqoWiTF8TChgf8rei21Q18LDvbvG5t1Ok49ZMs8nXvbwsK+cBiNY4JbpXJ2LAbRgR7MI3Imtxf6sqFNxRIv6VKigFeSotW/Utlsy/pLUDBUiF8Mz3CQiqZ6kMriA/bLA/pFjuAgJ6zk0kcJPc/Q5nWnfp7Y7bgB+kK2waWigALcw0TEZIxur0xICM=",
            "1; MWHPR0701MB3641;\n\t6:1zDE93XN3AtXwGdWQ9/e7kIRfatmvBQ1GOGIWkQb6GxRsIZqXlEiu+rZI2cceOuiJbfWASo7PuvU38YVH0eXvK8QD3r83LZyBySWZsfWTOiMaCigBAVHbO61OnEJiAa01jT6OdBB7hL3B4ueDFYdCKbPy6+G2HqAJqcR2iKZiRwr99+pQ1+bXVvT5oZnTjnXDR7SB14tb07L9Fd3b5l0/c/EADLwDzlh4D+9lTvEepbfUwKSAl3N5LJgipLSclnpjKn5WwkHzj+a16tlvWz3rnfPfrhNjXiXOfr169j6Un5oHbVBsKlyepr6NUYluaqFliBK2RIrjvKWDrnWPVpwe30hCKV/PIal0KD2QBWvZLI/1x68xSHlQVMSPWQZ/F6zdJ0ib0s+kZFm4A9j03bjIOpszk8G+ULAw/ugv1xeNV+/uhQfq/SyBNVcgjIU0annvC0zLtsXj2SJgX5WDKAF/w==;\n\t5:uLt79azKbptZBqHeMdoXHFzUIq0+RH27/2rgTPwXvSWRTIIb2YhjoOBs3y5uFh/vBsPCMHZ1W3r9FhNaXBI/AkiL1wm1+W2HpKpwi6VmsTgESwzkI7GG9zsMDzM5uMrm9ZesNpZR0oJWWY5NuQep6KH7JvPhOQHt+KxpUaHy0Jk=;\n\t7:H1bgwo6zm5sXACQUSb0ExkNwZO7q6kzxhtKt1bfNrw1vjxUL7p5v53XDwhzOHdTd7zACWUgPhqAGe+RXWbKM07spzw8Hz8g9+zGnCdrxdhwfCH1RSDTB9rYGXYn0Jya0Z7+1TusOlb9Q9BBwKC34nEughylGrjibUSFnwwqbeLVHW1Zr8e0ROc6duGnxIEt4FaFTGmCvrR39dPoqjXw3aYUMNSRiTzN6ON9+mBUqmykFfjAPVtiyS1HRHmSpJP1M"
        ],
        "X-MS-TrafficTypeDiagnostic": "MWHPR0701MB3641:",
        "X-Microsoft-Antispam-PRVS": "<MWHPR0701MB3641BDC82FFC64290C1341F5F0560@MWHPR0701MB3641.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)(5005006)(8121501046)(3231311)(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:NSPM;\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)(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);\n\tDIR:OUT; SFP:1101; SCL:1; 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": "PclarRG2AarmhKuNqY+W28m/ndUl6Z0r8nvNZC+nurL8984QJZI+DxHP6HmEK6aSxlqr8zv7WLZnNPbVybB8CRf3QOX+E3PYnG+MjLnK51Ua4D7FHSss8QMmtwMRWy0Sda1ZAcyZejhyL/OYqJsMMXtGIlr0VKsgjgU/9uXSvieLDBygk2ZWZPB8GXyablebLUCxRzDsFfiz1EQSQ8qDk9acxC0BWd1NG7tvNA3wm944Yxn5br1cpHQLhc7Z0gn0/DSf95QRJk1KoUo/ZjKzToGu3MDIPM0AUYi/g987C5hdCWOYZDaNT2lWOKmmxoiQRCBj0WWm7ViOWRarnYNiQXp+v4b9eh1BZH7YEUd+heE=",
        "SpamDiagnosticOutput": "1:99",
        "SpamDiagnosticMetadata": "NSPM",
        "X-OriginatorOrg": "caviumnetworks.com",
        "X-MS-Exchange-CrossTenant-OriginalArrivalTime": "23 Jul 2018 14:51:51.9936\n\t(UTC)",
        "X-MS-Exchange-CrossTenant-Network-Message-Id": "97715fb2-8aa4-40e7-b348-08d5f0abd4c5",
        "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 4/5] compress/zlib: support burst\n\tenqueue/dequeue",
        "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: Sunila Sahu <ssahu@caviumnetworks.com>\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/zlib_pmd.c | 255 ++++++++++++++++++++++++++++++++++++++-\n 1 file changed, 254 insertions(+), 1 deletion(-)",
    "diff": "diff --git a/drivers/compress/zlib/zlib_pmd.c b/drivers/compress/zlib/zlib_pmd.c\nindex 47bc73d..dc1e230 100644\n--- a/drivers/compress/zlib/zlib_pmd.c\n+++ b/drivers/compress/zlib/zlib_pmd.c\n@@ -7,7 +7,214 @@\n \n #include \"zlib_pmd_private.h\"\n \n-/** Parse comp xform and set private xform/stream parameters */\n+/** Compute next mbuf in the list, assign data buffer and length,\n+ *  returns 0 if mbuf is NULL\n+ */\n+#define COMPUTE_BUF(mbuf, data, len)\t\t\\\n+\t\t((mbuf = mbuf->next) ?\t\t\\\n+\t\t(data = rte_pktmbuf_mtod(mbuf, uint8_t *)),\t\\\n+\t\t(len = rte_pktmbuf_data_len(mbuf)) : 0)\n+\n+static void\n+process_zlib_deflate(struct rte_comp_op *op, z_stream *strm)\n+{\n+\tint ret, flush, fin_flush;\n+\tstruct rte_mbuf *mbuf_src = op->m_src;\n+\tstruct rte_mbuf *mbuf_dst = op->m_dst;\n+\n+\tswitch (op->flush_flag) {\n+\tcase RTE_COMP_FLUSH_FULL:\n+\tcase RTE_COMP_FLUSH_FINAL:\n+\t\tfin_flush = Z_FINISH;\n+\t\tbreak;\n+\tdefault:\n+\t\top->status = RTE_COMP_OP_STATUS_INVALID_ARGS;\n+\t\tZLIB_PMD_ERR(\"Invalid flush value\\n\");\n+\t}\n+\n+\tif (unlikely(!strm)) {\n+\t\top->status = RTE_COMP_OP_STATUS_INVALID_ARGS;\n+\t\tZLIB_PMD_ERR(\"Invalid z_stream\\n\");\n+\t\treturn;\n+\t}\n+\t/* Update z_stream with the inputs provided by application */\n+\tstrm->next_in = rte_pktmbuf_mtod_offset(mbuf_src, uint8_t *,\n+\t\t\top->src.offset);\n+\n+\tstrm->avail_in = rte_pktmbuf_data_len(mbuf_src) - op->src.offset;\n+\n+\tstrm->next_out = rte_pktmbuf_mtod_offset(mbuf_dst, uint8_t *,\n+\t\t\top->dst.offset);\n+\n+\tstrm->avail_out = rte_pktmbuf_data_len(mbuf_dst) - op->dst.offset;\n+\n+\t/* Set flush value to NO_FLUSH unless it is last mbuf */\n+\tflush = Z_NO_FLUSH;\n+\t/* Initialize status to SUCCESS */\n+\top->status = RTE_COMP_OP_STATUS_SUCCESS;\n+\n+\tdo {\n+\t\t/* Set flush value to Z_FINISH for last block */\n+\t\tif ((op->src.length - strm->total_in) <= strm->avail_in) {\n+\t\t\tstrm->avail_in = (op->src.length - strm->total_in);\n+\t\t\tflush = fin_flush;\n+\t\t}\n+\t\tdo {\n+\t\t\tret = deflate(strm, flush);\n+\t\t\tif (unlikely(ret == Z_STREAM_ERROR)) {\n+\t\t\t\t/* error return, do not process further */\n+\t\t\t\top->status =  RTE_COMP_OP_STATUS_ERROR;\n+\t\t\t\tgoto def_end;\n+\t\t\t}\n+\t\t\t/* Break if Z_STREAM_END is encountered */\n+\t\t\tif (ret == Z_STREAM_END)\n+\t\t\t\tgoto def_end;\n+\n+\t\t/* Keep looping until input mbuf is consumed.\n+\t\t * Exit if destination mbuf gets exhausted.\n+\t\t */\n+\t\t} while ((strm->avail_out == 0) &&\n+\t\t\tCOMPUTE_BUF(mbuf_dst, strm->next_out, strm->avail_out));\n+\n+\t\tif (!strm->avail_out) {\n+\t\t\t/* there is no space for compressed output */\n+\t\t\top->status = RTE_COMP_OP_STATUS_OUT_OF_SPACE_TERMINATED;\n+\t\t\tbreak;\n+\t\t}\n+\n+\t/* Update source buffer to next mbuf\n+\t * Exit if input buffers are fully consumed\n+\t */\n+\t} while (COMPUTE_BUF(mbuf_src, strm->next_in, strm->avail_in));\n+\n+def_end:\n+\t/* Update op stats */\n+\tswitch (op->status) {\n+\tcase RTE_COMP_OP_STATUS_SUCCESS:\n+\t\top->consumed += strm->total_in;\n+\t/* Fall-through */\n+\tcase RTE_COMP_OP_STATUS_OUT_OF_SPACE_TERMINATED:\n+\t\top->produced += strm->total_out;\n+\t\tbreak;\n+\tdefault:\n+\t\tZLIB_PMD_ERR(\"stats not updated for status:%d\\n\",\n+\t\t\t\top->status);\n+\t}\n+\n+\tdeflateReset(strm);\n+}\n+\n+static void\n+process_zlib_inflate(struct rte_comp_op *op, z_stream *strm)\n+{\n+\tint ret, flush;\n+\tstruct rte_mbuf *mbuf_src = op->m_src;\n+\tstruct rte_mbuf *mbuf_dst = op->m_dst;\n+\n+\tif (unlikely(!strm)) {\n+\t\top->status = RTE_COMP_OP_STATUS_INVALID_ARGS;\n+\t\tZLIB_PMD_ERR(\"Invalid z_stream\\n\");\n+\t\treturn;\n+\t}\n+\tstrm->next_in = rte_pktmbuf_mtod_offset(mbuf_src, uint8_t *,\n+\t\t\top->src.offset);\n+\n+\tstrm->avail_in = rte_pktmbuf_data_len(mbuf_src) - op->src.offset;\n+\n+\tstrm->next_out = rte_pktmbuf_mtod_offset(mbuf_dst, uint8_t *,\n+\t\t\top->dst.offset);\n+\n+\tstrm->avail_out = rte_pktmbuf_data_len(mbuf_dst) - op->dst.offset;\n+\n+\t/** Ignoring flush value provided from application for decompression */\n+\tflush = Z_NO_FLUSH;\n+\t/* initialize status to SUCCESS */\n+\top->status = RTE_COMP_OP_STATUS_SUCCESS;\n+\n+\tdo {\n+\t\tdo {\n+\t\t\tret = inflate(strm, flush);\n+\n+\t\t\tswitch (ret) {\n+\t\t\t/* Fall-through */\n+\t\t\tcase Z_NEED_DICT:\n+\t\t\t\tret = Z_DATA_ERROR;\n+\t\t\t/* Fall-through */\n+\t\t\tcase Z_DATA_ERROR:\n+\t\t\t/* Fall-through */\n+\t\t\tcase Z_MEM_ERROR:\n+\t\t\t/* Fall-through */\n+\t\t\tcase Z_STREAM_ERROR:\n+\t\t\t\top->status = RTE_COMP_OP_STATUS_ERROR;\n+\t\t\t/* Fall-through */\n+\t\t\tcase Z_STREAM_END:\n+\t\t\t\t/* no further computation needed if\n+\t\t\t\t * Z_STREAM_END is encountered\n+\t\t\t\t */\n+\t\t\t\tgoto inf_end;\n+\t\t\tdefault:\n+\t\t\t\t/* success */\n+\t\t\t\tbreak;\n+\n+\t\t\t}\n+\t\t/* Keep looping until input mbuf is consumed.\n+\t\t * Exit if destination mbuf gets exhausted.\n+\t\t */\n+\t\t} while ((strm->avail_out == 0) &&\n+\t\t\tCOMPUTE_BUF(mbuf_dst, strm->next_out, strm->avail_out));\n+\n+\t\tif (!strm->avail_out) {\n+\t\t\t/* there is no more space for decompressed output */\n+\t\t\top->status = RTE_COMP_OP_STATUS_OUT_OF_SPACE_TERMINATED;\n+\t\t\tbreak;\n+\t\t}\n+\t/* Read next input buffer to be processed, exit if compressed\n+\t * blocks are fully read\n+\t */\n+\t} while (COMPUTE_BUF(mbuf_src, strm->next_in, strm->avail_in));\n+\n+inf_end:\n+\t/* Update op stats */\n+\tswitch (op->status) {\n+\tcase RTE_COMP_OP_STATUS_SUCCESS:\n+\t\top->consumed += strm->total_in;\n+\t/* Fall-through */\n+\tcase RTE_COMP_OP_STATUS_OUT_OF_SPACE_TERMINATED:\n+\t\top->produced += strm->total_out;\n+\t\tbreak;\n+\tdefault:\n+\t\tZLIB_PMD_ERR(\"stats not produced for status:%d\\n\",\n+\t\t\t\top->status);\n+\t}\n+\n+\tinflateReset(strm);\n+}\n+\n+/** Process comp operation for mbuf */\n+static inline int\n+process_zlib_op(struct zlib_qp *qp, struct rte_comp_op *op)\n+{\n+\tstruct zlib_stream *stream;\n+\tstruct zlib_priv_xform *private_xform;\n+\n+\tif ((op->op_type == RTE_COMP_OP_STATEFUL) ||\n+\t    (op->src.offset > rte_pktmbuf_data_len(op->m_src)) ||\n+\t    (op->dst.offset > rte_pktmbuf_data_len(op->m_dst))) {\n+\t\top->status = RTE_COMP_OP_STATUS_INVALID_ARGS;\n+\t\tZLIB_PMD_ERR(\"Invalid source or destination buffers or \"\n+\t\t\t     \"invalid Operation requested\\n\");\n+\t} else {\n+\t\tprivate_xform = (struct zlib_priv_xform *)op->private_xform;\n+\t\tstream = &private_xform->stream;\n+\t\tstream->comp(op, &stream->strm);\n+\t}\n+\t/* whatever is out of op, put it into completion queue with\n+\t * its status\n+\t */\n+\treturn rte_ring_enqueue(qp->processed_pkts, (void *)op);\n+}\n+\n+/** Parse comp xform and set private xform/Stream parameters */\n int\n zlib_set_stream_parameters(const struct rte_comp_xform *xform,\n \t\tstruct zlib_stream *stream)\n@@ -22,6 +229,8 @@ zlib_set_stream_parameters(const struct rte_comp_xform *xform,\n \n \tswitch (xform->type) {\n \tcase RTE_COMP_COMPRESS:\n+\t\tstream->comp = process_zlib_deflate;\n+\t\tstream->free = deflateEnd;\n \t\t/** Compression window bits */\n \t\tswitch (xform->compress.algo) {\n \t\tcase RTE_COMP_ALGO_DEFLATE:\n@@ -80,6 +289,8 @@ zlib_set_stream_parameters(const struct rte_comp_xform *xform,\n \t\tbreak;\n \n \tcase RTE_COMP_DECOMPRESS:\n+\t\tstream->comp = process_zlib_inflate;\n+\t\tstream->free = inflateEnd;\n \t\t/** window bits */\n \t\tswitch (xform->decompress.algo) {\n \t\tcase RTE_COMP_ALGO_DEFLATE:\n@@ -101,6 +312,44 @@ zlib_set_stream_parameters(const struct rte_comp_xform *xform,\n \treturn 0;\n }\n \n+static uint16_t\n+zlib_pmd_enqueue_burst(void *queue_pair,\n+\t\t\tstruct rte_comp_op **ops, uint16_t nb_ops)\n+{\n+\tstruct zlib_qp *qp = queue_pair;\n+\tint ret;\n+\tuint16_t i;\n+\tuint16_t enqd = 0;\n+\tfor (i = 0; i < nb_ops; i++) {\n+\t\tret = process_zlib_op(qp, ops[i]);\n+\t\tif (unlikely(ret < 0)) {\n+\t\t\t/* increment count if failed to push to completion\n+\t\t\t * queue\n+\t\t\t */\n+\t\t\tqp->qp_stats.enqueue_err_count++;\n+\t\t} else {\n+\t\t\tqp->qp_stats.enqueued_count++;\n+\t\t\tenqd++;\n+\t\t}\n+\t}\n+\treturn enqd;\n+}\n+\n+static uint16_t\n+zlib_pmd_dequeue_burst(void *queue_pair,\n+\t\t\tstruct rte_comp_op **ops, uint16_t nb_ops)\n+{\n+\tstruct zlib_qp *qp = queue_pair;\n+\n+\tunsigned int nb_dequeued = 0;\n+\n+\tnb_dequeued = rte_ring_dequeue_burst(qp->processed_pkts,\n+\t\t\t(void **)ops, nb_ops, NULL);\n+\tqp->qp_stats.dequeued_count += nb_dequeued;\n+\n+\treturn nb_dequeued;\n+}\n+\n static int\n zlib_create(const char *name,\n \t\tstruct rte_vdev_device *vdev,\n@@ -117,6 +366,10 @@ zlib_create(const char *name,\n \n \tdev->dev_ops = rte_zlib_pmd_ops;\n \n+\t/* register rx/tx burst functions for data path */\n+\tdev->dequeue_burst = zlib_pmd_dequeue_burst;\n+\tdev->enqueue_burst = zlib_pmd_enqueue_burst;\n+\n \treturn 0;\n }\n \n",
    "prefixes": [
        "v4",
        "4/5"
    ]
}