From patchwork Mon Jul 23 14:51:10 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Shally Verma X-Patchwork-Id: 43277 X-Patchwork-Delegate: pablo.de.lara.guarch@intel.com Return-Path: X-Original-To: patchwork@dpdk.org Delivered-To: patchwork@dpdk.org Received: from [92.243.14.124] (localhost [127.0.0.1]) by dpdk.org (Postfix) with ESMTP id 7B99C3257; Mon, 23 Jul 2018 16:51:49 +0200 (CEST) Received: from NAM05-DM3-obe.outbound.protection.outlook.com (mail-dm3nam05hn0205.outbound.protection.outlook.com [104.47.49.205]) by dpdk.org (Postfix) with ESMTP id 5AD943195 for ; Mon, 23 Jul 2018 16:51:47 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=CAVIUMNETWORKS.onmicrosoft.com; s=selector1-cavium-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=lptheu4xQsj+zjJRKDw/HqbzEw7JrJWMkCo5E0xBlNA=; b=If5ElUh0i4yvNa/OSfducXh5c02rcIcbmBRMasKFMF2y/PwelPB1v1bNhNFvN+G3cNCk8hCfXVlrA1g8r8VQZfxDeJiDqcRJA4uZI8e3e/DUn2C0gChHqfCDD0i+sUWHsDAhxhx4UQkhuwH1AzPBddrjyJcr/ttwyZj/j4fKCJs= Authentication-Results: spf=none (sender IP is ) smtp.mailfrom=Shally.Verma@cavium.com; Received: from hyd1sverma-dt.caveonetworks.com (115.113.156.2) by MWHPR0701MB3641.namprd07.prod.outlook.com (2603:10b6:301:7d::34) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.973.16; Mon, 23 Jul 2018 14:51:44 +0000 From: Shally Verma To: pablo.de.lara.guarch@intel.com Cc: dev@dpdk.org, pathreya@caviumnetworks.com, mchalla@caviumnetworks.com, Ashish Gupta , Sunila Sahu 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 X-Originating-IP: [115.113.156.2] X-ClientProxiedBy: PN1PR0101CA0041.INDPRD01.PROD.OUTLOOK.COM (2603:1096:c00:c::27) To MWHPR0701MB3641.namprd07.prod.outlook.com (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; RULEID:(7020095)(4652040)(8989117)(5600073)(711020)(4534165)(7168020)(4627221)(201703031133081)(201702281549075)(8990107)(2017052603328)(7153060)(7193020); SRVR:MWHPR0701MB3641; X-Microsoft-Exchange-Diagnostics: 1; MWHPR0701MB3641; 3:OADOCDp2LkGJ7uF/K7ShWq9FajMs5I9JbnaseJrNu9S+4eRPQPo6R6N4OC+QbbNZ3vha9qJvG/+H+jwSidUFhYkQHu6eqpxvbHCkaWgYdXVd5wpDL+CP0OIB6vhdvAW2rYy8O3LY+s0GoBzIyYQRjdX5or1sSZJ6F6Iu3ylG0SSbYc6Yq2QVfIaFeZHCaT5r0k+YF1VqyEUin+FH/K5pXTCKbjB8Fr76yxaybjLrWRJCVGkJa9/mky9PELIiwioL; 25:JbxY5uRF1PXhLhC0VFRSoLlUugY8ffzOD8FYWATupCQbUgN0ZOcirCITvaIK82Xl5V5m/NrzPE+dNSLg3CkY+qJyfzEnlYYUzmrBc4+Jm/LLwgL6J4Sz/qWF1Q+gKxiqDwJ6BlS66QEGl4+3d8BugqjLYriJCH1Wa4p5lCGNL5IHYHA/AoePz+7d9W7BWEBziWJRF+MJPYQliKDOkZMkSUgU5fUJGJB1CRw6fm002kpZBDN5RXNnpNnxqy8BFcdHz3FDhbi+MzI1Hc5oCje3Tm1WRn7F5ExFZBSKWd9GzIByjsR4nDFHj+5EydTXm3o2wOAsnQt5b6zMZgvKDtZNCA==; 31:OU4kaowy/WqCzKFCXGLGcGvLPBgotKBSbAJBAZzDIVHnkhkZh/DsV2Iqw5YZTrZ6DTCCueHftqsEjS1N94niswDa4MKO9Bp/ed9sixHwJ4vxx82QScrvJCSPO3yNDVERTSTGFkIyXORTw4XIDMy/k91MLEmFaSOpyn/VKOzj2ekMGpbjG+FGr0r6151+uCM0AbU4j4HCIu79PXnoMmVB2JfIaEhHrSzUkz7XVM/cz34= X-MS-TrafficTypeDiagnostic: MWHPR0701MB3641: X-Microsoft-Exchange-Diagnostics: 1; MWHPR0701MB3641; 20:NzKjG+rj8eHc56YX1OSlTfzgk1yLZ+0T6OL/JM7k99C6sADO1tCgcUrCOYETlagfat8I6Vptwy03PbHZBSQkiSqDDy2oDhbfJAjm1r00HMWJiU0k3tyDkP6foIXLeeYmezeQGmmiwGE22OhgpjAMYQumgu0wOWaWZqo+r2+pquOPLozEMRSizCuK4RwQuKUCS4c16AMH+ql6taGPVqbVq8V8y51RpOVWBQ6jvcmOKb/NmMQOqK1tVEoxJxIzC3irjx1HrSBJRsPQgtNmSSA8egwd6mgFMtmKxr3waEeNyBdJ0+FpZ7uN/WUdI8CvPC9S1j+FBGPfZ1lhLqog8mueaiyv8gJ/YB9C4IuCLWQlJaPzb2RclT9gB4jv1B7zJZ6Yxmrjh/zdtmaqD7QZo6FwxthqbdqNnGIWsDMvgPfhvUIznlS5Haka+nIman0tn4P2DstrvIZ0lFChVLFlkL6sytI0wLVw/AyIW6msSo3XW6GgntvoTpiSjc7mV+ElrVsXvoDo40GUozwbLZvj+skaFe4/pVRsh8QyYlvSiqp4K0P5Low8MO+K5GLiFF0+HeZ1Fc5rA6ODSIrRwlvor22hGhNENAXo2NjtT8gUtLq+IvA= X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:(66839620246622)(228905959029699); X-MS-Exchange-SenderADCheck: 1 X-Exchange-Antispam-Report-CFA-Test: BCL:0; PCL:0; RULEID:(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); SRVR:MWHPR0701MB3641; BCL:0; PCL:0; RULEID:; SRVR:MWHPR0701MB3641; X-Microsoft-Exchange-Diagnostics: 1; MWHPR0701MB3641; 4:1fPCvDUu2VYmGjPnMU1lM8HAvUT8MI52zbYPPHnEUIe0Ez0O34HiKn5OziwvRwEDc5tBwVkA0GlWTuQsUBQNru6EwFoiqIyvg5Ov/3DXCTJrQq03ag6Q7OP26R1NHJ1Lj4FhMc0UJJwld9LYh+MuZVKRVO5xOOgn4ZQEc4pX3EEUY3InR5AwEeY2v/MVcRP10CROgvaM1c1/6WpmBVtq1ADc8P/EhM85eAJqKNSik523zKWNB9J9rcRahYyS4+Ge/C3dL09YxvXlkOCMcKHIP7fHPs5D0X3iv9SQnYRd8q7BuWZw5QqqTJF+DuING3fd3GM6+P6M29e0rRX/ev7mjp5Wl02LwxH0eUBsi2D67Sc= X-Forefront-PRVS: 0742443479 X-Forefront-Antispam-Report: SFV:SPM; SFS:(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); DIR:OUT; SFP:1501; SCL:5; SRVR:MWHPR0701MB3641; H:hyd1sverma-dt.caveonetworks.com; FPR:; SPF:None; LANG:en; PTR:InfoNoRecords; A:1; MX:1; Received-SPF: None (protection.outlook.com: cavium.com does not designate permitted sender hosts) X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; MWHPR0701MB3641; 23:mzhQDaTTdoptEkXBeOFBhb361MRw/TBb+UFYIND?= 51W+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 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== X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; MWHPR0701MB3641; 6:16Zh5b6exDO8UcpPlB1J7xNYEN7085fvhVJLWnOj?= chRyrTHc+MevMLcMlRzOy8SAgI92vMoQjT6x2rvmR+ElksHr3t+AZ5zMhyCad2t1+QFR9ArXlVGrVa1a1wxUKg7PrGZ4QjY9og5QstBU6AWGlO/3I9lxOvRVpLwIdkJIqM2xOd1cWwXN6SCn2v93Q3sdgVqEQ5YpgGF/eKZC1h5oc0loxdf1HoZVrfiOVPqvGG/U57VvlkWUemrO+YhvkJ+HGAXILiNQUO4N1tcA21aiNP7tb4OKWKMkMNu3A7gaBVPPW6lHC6zreVdcEkfWrJ09+2gEd7jWA3qXpabduyXfe+pgAoOb9btwGteXh+DcwVln2TNEe1F5N0WoFBfKfN97qVvn3d3jL5YdrQpYHn0xOJ+cSuK4/wbNpadwAuuLkJhKwnWJSD0pyXhZES30dVmmyZTE2rrcyRQ65NdIfAwSovUjUqYk9aVB/tuP1pfthfhFb93N26zfohpQM+AktQ2a; 5:cXAnWzkkA+99GeW7xywh27fXlvskzX7f3Mwc2xT6S/YEL+/6or45uoxqHYECVEs+p1793ga9xql7AJR3RCTJ4MqLIzMLWTP+nn2RbdSPvJfCGUDaWnzawZ4sxkXExLWsbYpuMUPtAQq9Xa8o5nMnRNhUP/bMPPL8gFsVKm2NaII=; 7:Kju48pRz8sJ4CT6YNVN09cxInoVsiveni/hoo6z6xOkTSqhPiJTqex4vlicNXExUvf/7TlDZp6SATosaXgcqIvvzw3mUA7TYScEK0F2D0NCNJnPtg35bQnxeD+yyQxRl1pZ0kvvSZhZmVBGBBst61/TemL8roz+VB3cFflRZfW0IMfCNn6NyJEaRiVsTdYrMiaHbevNbz8TcKsvfvxt+T6O+wKeQX6hct6QGECOjZ0bA9V9Y05rNf9UkpSY8FUk6 SpamDiagnosticOutput: 1:22 X-OriginatorOrg: caviumnetworks.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 23 Jul 2018 14:51:44.0560 (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 List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Sender: "dev" From: Ashish Gupta Add initial PMD setup routines in compressdev framework. ZLIB PMD appears as virtual compression device. User would need to install zlib prior to enabling this PMD. Signed-off-by: Sunila Sahu Signed-off-by: Shally Verma Signed-off-by: Ashish Gupta --- MAINTAINERS | 3 + config/common_base | 5 ++ drivers/compress/Makefile | 1 + drivers/compress/meson.build | 2 +- drivers/compress/zlib/Makefile | 28 +++++++++ drivers/compress/zlib/meson.build | 14 +++++ drivers/compress/zlib/rte_pmd_zlib_version.map | 3 + drivers/compress/zlib/zlib_pmd.c | 78 ++++++++++++++++++++++++++ drivers/compress/zlib/zlib_pmd_private.h | 32 +++++++++++ mk/rte.app.mk | 2 + 10 files changed, 167 insertions(+), 1 deletion(-) diff --git a/MAINTAINERS b/MAINTAINERS index 7b2414d..ca27c6f 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -872,6 +872,9 @@ M: Fiona Trahe F: drivers/compress/qat/ F: drivers/common/qat/ +ZLIB +M: Sunila Sahu +F: drivers/compress/zlib/ Eventdev Drivers ---------------- diff --git a/config/common_base b/config/common_base index a061c21..d9b238c 100644 --- a/config/common_base +++ b/config/common_base @@ -582,6 +582,11 @@ CONFIG_RTE_COMPRESSDEV_TEST=n CONFIG_RTE_LIBRTE_PMD_ISAL=n # +# Compile PMD for ZLIB compression device +# +CONFIG_RTE_LIBRTE_PMD_ZLIB=n + +# # Compile generic event device library # CONFIG_RTE_LIBRTE_EVENTDEV=y diff --git a/drivers/compress/Makefile b/drivers/compress/Makefile index 592497f..1f159a5 100644 --- a/drivers/compress/Makefile +++ b/drivers/compress/Makefile @@ -4,5 +4,6 @@ include $(RTE_SDK)/mk/rte.vars.mk DIRS-$(CONFIG_RTE_LIBRTE_PMD_ISAL) += isal +DIRS-$(CONFIG_RTE_LIBRTE_PMD_ZLIB) += zlib include $(RTE_SDK)/mk/rte.subdir.mk diff --git a/drivers/compress/meson.build b/drivers/compress/meson.build index 2352ad5..d2ca8fc 100644 --- a/drivers/compress/meson.build +++ b/drivers/compress/meson.build @@ -1,7 +1,7 @@ # SPDX-License-Identifier: BSD-3-Clause # Copyright(c) 2018 Intel Corporation -drivers = ['isal', 'qat'] +drivers = ['isal', 'qat', 'zlib'] std_deps = ['compressdev'] # compressdev pulls in all other needed deps config_flag_fmt = 'RTE_LIBRTE_@0@_PMD' diff --git a/drivers/compress/zlib/Makefile b/drivers/compress/zlib/Makefile new file mode 100644 index 0000000..bd322c9 --- /dev/null +++ b/drivers/compress/zlib/Makefile @@ -0,0 +1,28 @@ +# SPDX-License-Identifier: BSD-3-Clause +# Copyright(c) 2018 Cavium Networks + +include $(RTE_SDK)/mk/rte.vars.mk + +# library name +LIB = librte_pmd_zlib.a + +# build flags +CFLAGS += -O3 +CFLAGS += $(WERROR_FLAGS) +CFLAGS += -DALLOW_EXPERIMENTAL_API + +# library version +LIBABIVER := 1 + +# versioning export map +EXPORT_MAP := rte_pmd_zlib_version.map + +# external library dependencies +LDLIBS += -lrte_eal -lrte_mbuf -lrte_mempool -lrte_ring -lz +LDLIBS += -lrte_compressdev +LDLIBS += -lrte_bus_vdev + +# library source files +SRCS-$(CONFIG_RTE_LIBRTE_PMD_ZLIB) += zlib_pmd.c + +include $(RTE_SDK)/mk/rte.lib.mk diff --git a/drivers/compress/zlib/meson.build b/drivers/compress/zlib/meson.build new file mode 100644 index 0000000..3f0a77b --- /dev/null +++ b/drivers/compress/zlib/meson.build @@ -0,0 +1,14 @@ +# SPDX-License-Identifier: BSD-3-Clause +# Copyright(c) 2018 Cavium Networks + +dep = dependency('zlib', required: false) +if not dep.found() + build = false +endif + +deps += 'bus_vdev' +sources = files('zlib_pmd.c') +ext_deps += dep +pkgconfig_extra_libs += '-lz' + +allow_experimental_apis = true diff --git a/drivers/compress/zlib/rte_pmd_zlib_version.map b/drivers/compress/zlib/rte_pmd_zlib_version.map new file mode 100644 index 0000000..ad6e191 --- /dev/null +++ b/drivers/compress/zlib/rte_pmd_zlib_version.map @@ -0,0 +1,3 @@ +DPDK_18.08 { + local: *; +}; diff --git a/drivers/compress/zlib/zlib_pmd.c b/drivers/compress/zlib/zlib_pmd.c new file mode 100644 index 0000000..39d3628 --- /dev/null +++ b/drivers/compress/zlib/zlib_pmd.c @@ -0,0 +1,78 @@ +/* SPDX-License-Identifier: BSD-3-Clause + * Copyright(c) 2018 Cavium Networks + */ + +#include +#include + +#include "zlib_pmd_private.h" + +static int +zlib_create(const char *name, + struct rte_vdev_device *vdev, + struct rte_compressdev_pmd_init_params *init_params) +{ + struct rte_compressdev *dev; + + dev = rte_compressdev_pmd_create(name, &vdev->device, + sizeof(struct zlib_private), init_params); + if (dev == NULL) { + ZLIB_PMD_ERR("driver %s: create failed", init_params->name); + return -ENODEV; + } + + return 0; +} + +static int +zlib_probe(struct rte_vdev_device *vdev) +{ + struct rte_compressdev_pmd_init_params init_params = { + "", + rte_socket_id() + }; + const char *name; + const char *input_args; + + name = rte_vdev_device_name(vdev); + + if (name == NULL) + return -EINVAL; + input_args = rte_vdev_device_args(vdev); + rte_compressdev_pmd_parse_input_args(&init_params, input_args); + + return zlib_create(name, vdev, &init_params); +} + +static int +zlib_remove(struct rte_vdev_device *vdev) +{ + struct rte_compressdev *compressdev; + const char *name; + + name = rte_vdev_device_name(vdev); + if (name == NULL) + return -EINVAL; + + compressdev = rte_compressdev_pmd_get_named_dev(name); + if (compressdev == NULL) + return -ENODEV; + + return rte_compressdev_pmd_destroy(compressdev); +} + +static struct rte_vdev_driver zlib_pmd_drv = { + .probe = zlib_probe, + .remove = zlib_remove +}; + +RTE_PMD_REGISTER_VDEV(COMPRESSDEV_NAME_ZLIB_PMD, zlib_pmd_drv); +RTE_INIT(zlib_init_log); + +static void +zlib_init_log(void) +{ + zlib_logtype_driver = rte_log_register("pmd.compress.zlib"); + if (zlib_logtype_driver >= 0) + rte_log_set_level(zlib_logtype_driver, RTE_LOG_INFO); +} diff --git a/drivers/compress/zlib/zlib_pmd_private.h b/drivers/compress/zlib/zlib_pmd_private.h new file mode 100644 index 0000000..d26a740 --- /dev/null +++ b/drivers/compress/zlib/zlib_pmd_private.h @@ -0,0 +1,32 @@ +/* SPDX-License-Identifier: BSD-3-Clause + * Copyright(c) 2018 Cavium Networks + */ + +#ifndef _RTE_ZLIB_PMD_PRIVATE_H_ +#define _RTE_ZLIB_PMD_PRIVATE_H_ + +#include +#include +#include + +#define COMPRESSDEV_NAME_ZLIB_PMD compress_zlib +/**< ZLIB PMD device name */ + +#define DEF_MEM_LEVEL 8 + +int zlib_logtype_driver; +#define ZLIB_PMD_LOG(level, fmt, args...) \ + rte_log(RTE_LOG_ ## level, zlib_logtype_driver, "%s(): "fmt "\n", \ + __func__, ##args) + +#define ZLIB_PMD_INFO(fmt, args...) \ + ZLIB_PMD_LOG(INFO, fmt, ## args) +#define ZLIB_PMD_ERR(fmt, args...) \ + ZLIB_PMD_LOG(ERR, fmt, ## args) +#define ZLIB_PMD_WARN(fmt, args...) \ + ZLIB_PMD_LOG(WARNING, fmt, ## args) + +struct zlib_private { +}; + +#endif /* _RTE_ZLIB_PMD_PRIVATE_H_ */ diff --git a/mk/rte.app.mk b/mk/rte.app.mk index 1590838..5b7c684 100644 --- a/mk/rte.app.mk +++ b/mk/rte.app.mk @@ -228,6 +228,8 @@ _LDLIBS-$(CONFIG_RTE_LIBRTE_PMD_ISAL) += -lisal ifeq ($(CONFIG_RTE_LIBRTE_PMD_QAT_SYM),n) _LDLIBS-$(CONFIG_RTE_LIBRTE_PMD_QAT) += -lrte_pmd_qat endif # CONFIG_RTE_LIBRTE_PMD_QAT_SYM +_LDLIBS-$(CONFIG_RTE_LIBRTE_PMD_ZLIB) += -lrte_pmd_zlib +_LDLIBS-$(CONFIG_RTE_LIBRTE_PMD_ZLIB) += -lz endif # CONFIG_RTE_LIBRTE_COMPRESSDEV ifeq ($(CONFIG_RTE_LIBRTE_EVENTDEV),y) From patchwork Mon Jul 23 14:51:11 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Shally Verma X-Patchwork-Id: 43278 X-Patchwork-Delegate: pablo.de.lara.guarch@intel.com Return-Path: X-Original-To: patchwork@dpdk.org Delivered-To: patchwork@dpdk.org Received: from [92.243.14.124] (localhost [127.0.0.1]) by dpdk.org (Postfix) with ESMTP id A5D9C378B; Mon, 23 Jul 2018 16:51:51 +0200 (CEST) Received: from NAM05-DM3-obe.outbound.protection.outlook.com (mail-eopbgr730052.outbound.protection.outlook.com [40.107.73.52]) by dpdk.org (Postfix) with ESMTP id E139C32A5 for ; Mon, 23 Jul 2018 16:51:49 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=CAVIUMNETWORKS.onmicrosoft.com; s=selector1-cavium-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=ZApVFzksUhUlbS3rT9WCLYs17mKXNJrjA2t6/MC4R+c=; b=dsoTbEw5QKeIsGp9qOl9je0uKPu/JFjWcTr4OtU3AECwoDvhHvgbeLGp+cnMlAwPvytILCQPZryM/+W+N5u/Uj29otLuidzF8cw1RzMfZuFL+M71HjCljL0zgRJLhCUGDd0WkwJVvsriQTAhIqeBNDG94DgEHdxCsFuSszlkPH0= Authentication-Results: spf=none (sender IP is ) smtp.mailfrom=Shally.Verma@cavium.com; Received: from hyd1sverma-dt.caveonetworks.com (115.113.156.2) by MWHPR0701MB3641.namprd07.prod.outlook.com (2603:10b6:301:7d::34) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.973.16; Mon, 23 Jul 2018 14:51:46 +0000 From: Shally Verma To: pablo.de.lara.guarch@intel.com Cc: dev@dpdk.org, pathreya@caviumnetworks.com, mchalla@caviumnetworks.com, Ashish Gupta , Sunila Sahu Date: Mon, 23 Jul 2018 20:21:11 +0530 Message-Id: <1532357474-9544-3-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 X-Originating-IP: [115.113.156.2] X-ClientProxiedBy: PN1PR0101CA0041.INDPRD01.PROD.OUTLOOK.COM (2603:1096:c00:c::27) To MWHPR0701MB3641.namprd07.prod.outlook.com (2603:10b6:301:7d::34) X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 5a200d01-bd57-49e3-6178-08d5f0abd16b X-Microsoft-Antispam: BCL:0; PCL:0; RULEID:(7020095)(4652040)(8989117)(5600073)(711020)(4534165)(7168020)(4627221)(201703031133081)(201702281549075)(8990107)(2017052603328)(7153060)(7193020); SRVR:MWHPR0701MB3641; X-Microsoft-Exchange-Diagnostics: 1; MWHPR0701MB3641; 3:WhZaAsM1sBMrfgWeXWSDYE4KitkZ8hgRFX1WassfSHDGp+iLVqEFxIaGCfwAdfH5Z+kMDA4TRbBHOcTUtVgEF3t7+WjmTVk316sjQDbVsWMoi9PsdN2cCIOkftG6sMnZgu3552ZM3WlidzZ9M6om3bIicAXRsthFs/gI10PBboDExBI1wpzT/2km1FC1PO5W2ffibskVQ3DyH2uqsHgk2fpXhZOKlh9rB2jb3r8fkpNME9Sd4TIPQUJe/TOWiFUc; 25:ZfLQcOihZRPI0Bbd+zmNsLGoN3ALthaa76XftxvNH2+AxR3fkBmrGDamoMQyyO7FX7fiJbbrRj+yJXdcpK7Us7H6mwqGTDz0NV1m6zJ7qbWziGE6diP0W+AGR8YFaPLIoh7T6DiEQPKzYCO/uLnnlLe9de/o0HDz7rJJ4a2gWmqGJTJxRGnIEk3FSGT/SrovPcs6GPQrAngaOOoh3Ja0tsCHyr6CRpQEh01AWCqB/98LhZgYkc+DNuH9fF/uJi0GBj6TCiRgfDDuuREzM7rc7H7kTOpGdxY16P/b4tAXoEtv48/oj/TdqjvkD4Cuuzko9EZwukJH3XVyr8lk8QI6jg==; 31:6PIASkXPE2Mcvt74BFOz9yrv8soGFPULcFzppzoru+l7qOoP5R0532X/nuRSgUpQCWWGC7OBlM1J86j+7riswyKZYV4A27kK0orv10NzzTRxw7Yc6zHd4C8WolgcihYKha4WV+NFqydOG1Xc/CfZJEpPdvGzqEd9uG83efH5N/nPYBIt9+xhA81HIk5DflY54mBOkT7W761SlMjw+n9r5Vtm1hQb4pq6mLzDefkyYfw= X-MS-TrafficTypeDiagnostic: MWHPR0701MB3641: X-Microsoft-Exchange-Diagnostics: 1; MWHPR0701MB3641; 20:ygrzKGrIssiXS/vliZb580Yw2jtrt4/C6lYi+V6NLwLPQqhw6Q2XrHyqtgLPjGHVXEV9BKowXMJcg/jpvVUEA/gtQnBk+S0SJ8ZF0K6BocZaTuiUH5/g0TpViGxnxLSni34dQy1Acu8kjcJhCkdaQRKhb0um8/V2AcrFReNz5465futm/MLvFuTXjCcjNO6AMvjaaug2tifPwYF1cn5b7gYzMy39jQwDxFGrpxF4z/n0Mv0KXkzTbLfXzSSVbvPgY5+PEtdZjYtZNjBvic/30LhrhJxhJyC1XNF8KswcSoR8AR7o8xnOR0QPZs103y0ZIXfRwTZXuBt7sTuZoufO0JWUgFcL70KMGOM+VQliJGM+0ZkkIJUnGtQWccTeHCc9k+J78cmLg8f+31XPkELQEQsGg8WNUKg6h+q99EAtNkFeHwGuvmcJNCjMVC7V6sTlN40/TLNx4n4Lkt4+4dd8jm3N+VR0LD5y5rzyrbAeysweQ61/y4YSXxTVoJF4a/n/m5azRuE2wlVXawVoYjBfMoIXmzROSjbZDwxB3UCV0rikntKmU/q/fQPKXuZgpS2MkbxK1kvnEFEynujOndXubw52kTNq6Cb0yYauRWiI88E=; 4:caQsEKIphqen6tBEcsT29cz9TgplND9nLFNDlzjVM0l2lkBcHHhUEkJUZjyM6DtkdAU2QhNjYTy+9GQlJ7wSX3ClqSuWNz/xI29OFylyuzjMt4ihiURGKnD2hq0PX+GQJzDJSsOxWerCR1QX/JC2PGnh5879ICIkD3vkUqNWZUzw4MR3Kvbl3rePcHelt79zWY1gZCidV99l862a9kFJluvJsNYKCnbypaJ1i0udVmuwnMETRRNY7e54yEpfXK9+NWJZSGpkRHahrVQcnaHN1A== X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:; X-MS-Exchange-SenderADCheck: 1 X-Exchange-Antispam-Report-CFA-Test: BCL:0; PCL:0; RULEID:(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); SRVR:MWHPR0701MB3641; BCL:0; PCL:0; RULEID:; SRVR:MWHPR0701MB3641; X-Forefront-PRVS: 0742443479 X-Forefront-Antispam-Report: SFV:NSPM; SFS:(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); DIR:OUT; SFP:1101; SCL:1; SRVR:MWHPR0701MB3641; H:hyd1sverma-dt.caveonetworks.com; FPR:; SPF:None; LANG:en; PTR:InfoNoRecords; A:1; MX:1; Received-SPF: None (protection.outlook.com: cavium.com does not designate permitted sender hosts) X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; MWHPR0701MB3641; 23:tvkPO28IlmaOKDUiiHDtSG8UPZCmqswq+D/OkMy?= SkkH10UkPHDRO5n+3VUuk70ACVk2puogNtMIhh3J8FAQKMgKso8FARRfBM2uxFmP9qsN/FEzWq/tBLfUoxa1wjbo4steAHdYPT8qiNH4u9NEe0fbDve6EzJGpvjxPB2yFZbf8UPxGJs6myMrNJtTJl+//d2EQaFmlT38/rd+GA8b8I9WgUfzTVi0iqy6rOERGE/BcMcz1ZIH3jjNBvc2FOWuFp6Xh3qmBMoDeS2b8gfcR0y7p8NqZiPZptdSra9zOlAgK72Vx94M7WIzp6tiyvJhl8sFq4tc0aI2mLfrfas8ggciHVEFHNTSwoCFo2LZvmcY2FavS/s1C8/uCkamy9mjXzbbZ5ZZ/xNrBcm1gk/eqQ9YDFoimtiho07BMNvEV63dypxn/FiLHqpNHRUSiYi7WQcNNGH9Y4DUiFjTh5fUr8BxelRKf3oxhUpLrPstRogicr9OJGYfn1m9rp34dPqHd5t/NyhxA5QMez+nHOaHMNCWEiiFy2O3RDWkoZ96b+RwC0KnWv81QL/fAawla3x6DPbbr4FI2645/7m/DiJ/2S40r7SXq7yqkCIuS3jkCJ1sljN++meJsxsbeWytU2BG82vgbTNiQcWRPbaLx+qEik8iZqmJSHh+jHESc0j57JxdcRtlrtaYTK/vf4yI9PJWCRYoVrntHTk0wo82uR/Rb60jn4v9/mj77DaGuMgQE3ykonGFeWT8yNQvHunKbtCdOEGaW6dtLpe7WWZOeQJf4CQGvkHslLi8RFQqEO3Sf9DBEHXOMWrk3BaYN1iD7jj/2D+lS0bXTahpkJeRpnaQiOtaKsPM7+XGpEyWfSxtXlFSnG4zDHRCFf9p++b0PquER2AuwW5XnDyXJkrKuAtxwRrdKOwX5XJPXCdXIt0eScpmyJYWXmqaU/QANGCAhqxoLENlSh/lbDYkbiAwnjyTaX7wb0u/8IwUNFfep/MPZYfQSxWQM4IJs+i01Vv5T8WOKS6iP+4LBXp+sxmydr4raP52U+VeaPcQToGrr4WvdnF1l92gkzVVWDSgSyMpYoN0LJblnjdyPuzI9VM2tcxGljyAYaHSVgueZFrz462wv5t3tNomPQu7zsNe78xnhCS3pmrzjWByJ0BXCHR0dIF9y78hLIseBgaHU61P6fbbl2F/qrFd+lKhy4b9gk+WAvNb8vTowfTrf8SgSWGLEBC/Ti4Rdy5JoY9GterIvZSfIfbgCnCRk2lHqy+r6wYLmYPbndz5S+n4LAiKSvZNepvaT4XEvorkn2uYnnY72a7NZnVKtJPacs6LkcKEQANbdZvidEacxXNxrxBk8iRmlIOR5hvUzsxnMDlnLP0Dw8TTKYufbNw5IQ2y3VR1u4dTUMxrF X-Microsoft-Antispam-Message-Info: UoU73ebUIz6GCBSXmRbLv5qXIOAmVT+uZL+9qfuk2A6q4dh3dlbNBKZjUMSpyGz/lqrZFzfZVfJJMahUkd2mOM3MaWBTrvdHNsYr27nMKClEaFjP8FGUJmFquSuYSg0PEBYP75TSkoZo99aGZRD09HrqKG4E404NKGvEQhYYEcy/LlMPXG+HNAZVTimL6UohRe2RfKjKHZpPOZVhyUJDl+6xz1Kw6jtXoKVWBuMA62Uzwe9/7uBs6h2CUY5KR3cKobS7DDPskH5Fdv3sRlLA2JoM88qG3TY6zlV0TAGMR4pdBTfETzRBJq85Sd7ltDD5sLQXAfqbIv5eyFbhDs4+eiw4g3DFQ6b3XQ37yXyrKkY= X-Microsoft-Exchange-Diagnostics: 1; MWHPR0701MB3641; 6:aMeZvftb5VN+XWBCZSdBuneAwSJCwZsvcW9vYB8fgq9PweJ058oLru/YvFo/fWkFAvtu3M+LjljeWwrt1Q0OHVC7qmv4InI4dfJ8o+4bGnHe43SP+ziE2NdGBINTRszkTKzp9SFrDNoYjm/R35hk34G16ABszqmqJxsQ01/2QZT4zuVvI2sHncU7DDwhxyBtw8OEllHp5iPM1frg7xla4fftwxvjmz9dRK90dPl0ScBBmW0VqTjGrsRUOt0YLNUiqIgjc0H53QXBHk/E3Qq7HUM9Ok/Ph9ln6B6e2/hGnhxZ9lOe2mnK/FrJcKmt2rCekXgo85xkNr6QBiPRvDW8QyKmocBci/N+2kxlzVsbiwddsVVcDmoJ/JkwZNjcZMi60Ps0YTOxULwwFLUza0YgR0QzViY1rWOHkL5AJl2qkwR2JekjLvRG2HSdwMo43nonszAP7YDBoWLRDsPU7UUN8g==; 5:7XaG2FpFbgyo6GlfWPJfP2xoi1P9qldeS65+x0+X5UUmxkPj5FQXKzdNUZLSk4Qqn4PkIWbWgVWcogWcOC/HoxI7iBCmvk26zKmTlrfLZDOaJZcG1wlb6cGENGnidozXAg61CGVCPjqy78fMgrUKNKZEX3+whz4O9xPREFF2tuk=; 7:i973YorrKkQYy6QOqUG80rlqt48NJjrcBu9S25Uu1sNLzBuQGgAS2YMZoo5NWxVZMWvDhbCw/3/9VHMxIogmomynT2O0Mz3DuaMFdy/RSqQlrWOebAYd9PPfDVUu/aqnNJh8eHzhZV01b8l53SAhBm9y/j1p3bTtIajpmjtFs69Yo20VTKbhoRorqmS2Y7Eeqdnwe/JNSrDMIVt4mnS/JYcX3zqhqrqz5qotwXyfmEn0wiHDS6R+YHaEuEHKt2D1 SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-OriginatorOrg: caviumnetworks.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 23 Jul 2018 14:51:46.6342 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 5a200d01-bd57-49e3-6178-08d5f0abd16b 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 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 List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Sender: "dev" From: Ashish Gupta Implement device configure and queue pair setup PMD ops Signed-off-by: Sunila Sahu Signed-off-by: Shally Verma Signed-off-by: Ashish Gupta --- drivers/compress/zlib/Makefile | 1 + drivers/compress/zlib/meson.build | 2 +- drivers/compress/zlib/zlib_pmd.c | 2 + drivers/compress/zlib/zlib_pmd_ops.c | 238 +++++++++++++++++++++++++++++++ drivers/compress/zlib/zlib_pmd_private.h | 35 +++++ 5 files changed, 277 insertions(+), 1 deletion(-) diff --git a/drivers/compress/zlib/Makefile b/drivers/compress/zlib/Makefile index bd322c9..5cf8de6 100644 --- a/drivers/compress/zlib/Makefile +++ b/drivers/compress/zlib/Makefile @@ -24,5 +24,6 @@ LDLIBS += -lrte_bus_vdev # library source files SRCS-$(CONFIG_RTE_LIBRTE_PMD_ZLIB) += zlib_pmd.c +SRCS-$(CONFIG_RTE_LIBRTE_PMD_ZLIB) += zlib_pmd_ops.c include $(RTE_SDK)/mk/rte.lib.mk diff --git a/drivers/compress/zlib/meson.build b/drivers/compress/zlib/meson.build index 3f0a77b..7748de2 100644 --- a/drivers/compress/zlib/meson.build +++ b/drivers/compress/zlib/meson.build @@ -7,7 +7,7 @@ if not dep.found() endif deps += 'bus_vdev' -sources = files('zlib_pmd.c') +sources = files('zlib_pmd.c', 'zlib_pmd_ops.c') ext_deps += dep pkgconfig_extra_libs += '-lz' diff --git a/drivers/compress/zlib/zlib_pmd.c b/drivers/compress/zlib/zlib_pmd.c index 39d3628..9363808 100644 --- a/drivers/compress/zlib/zlib_pmd.c +++ b/drivers/compress/zlib/zlib_pmd.c @@ -21,6 +21,8 @@ zlib_create(const char *name, return -ENODEV; } + dev->dev_ops = rte_zlib_pmd_ops; + return 0; } diff --git a/drivers/compress/zlib/zlib_pmd_ops.c b/drivers/compress/zlib/zlib_pmd_ops.c new file mode 100644 index 0000000..645c5b1 --- /dev/null +++ b/drivers/compress/zlib/zlib_pmd_ops.c @@ -0,0 +1,238 @@ +/* SPDX-License-Identifier: BSD-3-Clause + * Copyright(c) 2018 Cavium Networks + */ + +#include + +#include +#include + +#include "zlib_pmd_private.h" + +static const struct rte_compressdev_capabilities zlib_pmd_capabilities[] = { + { /* Deflate */ + .algo = RTE_COMP_ALGO_DEFLATE, + .comp_feature_flags = (RTE_COMP_FF_NONCOMPRESSED_BLOCKS | + RTE_COMP_FF_HUFFMAN_FIXED | + RTE_COMP_FF_HUFFMAN_DYNAMIC | + RTE_COMP_FF_OOP_SGL_IN_SGL_OUT), + .window_size = { + .min = 8, + .max = 15, + .increment = 1 + }, + }, + + RTE_COMP_END_OF_CAPABILITIES_LIST() + +}; + +/** Configure device */ +static int +zlib_pmd_config(struct rte_compressdev *dev, + struct rte_compressdev_config *config) +{ + struct rte_mempool *mp; + char mp_name[RTE_MEMPOOL_NAMESIZE]; + struct zlib_private *internals = dev->data->dev_private; + + snprintf(mp_name, RTE_MEMPOOL_NAMESIZE, + "stream_mp_%u", dev->data->dev_id); + mp = internals->mp; + if (mp == NULL) { + mp = rte_mempool_create(mp_name, + config->max_nb_priv_xforms + + config->max_nb_streams, + sizeof(struct zlib_priv_xform), + 0, 0, NULL, NULL, NULL, + NULL, config->socket_id, + 0); + if (mp == NULL) { + ZLIB_PMD_ERR("Cannot create private xform pool on " + "socket %d\n", config->socket_id); + return -ENOMEM; + } + internals->mp = mp; + } + return 0; +} + +/** Start device */ +static int +zlib_pmd_start(__rte_unused struct rte_compressdev *dev) +{ + return 0; +} + +/** Stop device */ +static void +zlib_pmd_stop(__rte_unused struct rte_compressdev *dev) +{ +} + +/** Close device */ +static int +zlib_pmd_close(struct rte_compressdev *dev) +{ + struct zlib_private *internals = dev->data->dev_private; + rte_mempool_free(internals->mp); + internals->mp = NULL; + return 0; +} + +/** Get device statistics */ +static void +zlib_pmd_stats_get(struct rte_compressdev *dev, + struct rte_compressdev_stats *stats) +{ + int qp_id; + + for (qp_id = 0; qp_id < dev->data->nb_queue_pairs; qp_id++) { + struct zlib_qp *qp = dev->data->queue_pairs[qp_id]; + + stats->enqueued_count += qp->qp_stats.enqueued_count; + stats->dequeued_count += qp->qp_stats.dequeued_count; + + stats->enqueue_err_count += qp->qp_stats.enqueue_err_count; + stats->dequeue_err_count += qp->qp_stats.dequeue_err_count; + } +} + +/** Reset device statistics */ +static void +zlib_pmd_stats_reset(struct rte_compressdev *dev) +{ + int qp_id; + + for (qp_id = 0; qp_id < dev->data->nb_queue_pairs; qp_id++) { + struct zlib_qp *qp = dev->data->queue_pairs[qp_id]; + + memset(&qp->qp_stats, 0, sizeof(qp->qp_stats)); + } +} + +/** Get device info */ +static void +zlib_pmd_info_get(struct rte_compressdev *dev, + struct rte_compressdev_info *dev_info) +{ + if (dev_info != NULL) { + dev_info->driver_name = dev->device->name; + dev_info->feature_flags = dev->feature_flags; + dev_info->capabilities = zlib_pmd_capabilities; + } +} + +/** Release queue pair */ +static int +zlib_pmd_qp_release(struct rte_compressdev *dev, uint16_t qp_id) +{ + struct zlib_qp *qp = dev->data->queue_pairs[qp_id]; + + if (qp != NULL) { + rte_ring_free(qp->processed_pkts); + rte_free(qp); + dev->data->queue_pairs[qp_id] = NULL; + } + return 0; +} + +/** set a unique name for the queue pair based on its name, dev_id and qp_id */ +static int +zlib_pmd_qp_set_unique_name(struct rte_compressdev *dev, + struct zlib_qp *qp) +{ + unsigned int n = snprintf(qp->name, sizeof(qp->name), + "zlib_pmd_%u_qp_%u", + dev->data->dev_id, qp->id); + + if (n >= sizeof(qp->name)) + return -1; + + return 0; +} + +/** Create a ring to place process packets on */ +static struct rte_ring * +zlib_pmd_qp_create_processed_pkts_ring(struct zlib_qp *qp, + unsigned int ring_size, int socket_id) +{ + struct rte_ring *r = qp->processed_pkts; + + if (r) { + if (rte_ring_get_size(r) >= ring_size) { + ZLIB_PMD_INFO("Reusing existing ring %s for processed" + " packets", qp->name); + return r; + } + + ZLIB_PMD_ERR("Unable to reuse existing ring %s for processed" + " packets", qp->name); + return NULL; + } + + return rte_ring_create(qp->name, ring_size, socket_id, + RING_F_EXACT_SZ); +} + +/** Setup a queue pair */ +static int +zlib_pmd_qp_setup(struct rte_compressdev *dev, uint16_t qp_id, + uint32_t max_inflight_ops, int socket_id) +{ + struct zlib_qp *qp = NULL; + + /* Free memory prior to re-allocation if needed. */ + if (dev->data->queue_pairs[qp_id] != NULL) + zlib_pmd_qp_release(dev, qp_id); + + /* Allocate the queue pair data structure. */ + qp = rte_zmalloc_socket("ZLIB PMD Queue Pair", sizeof(*qp), + RTE_CACHE_LINE_SIZE, socket_id); + if (qp == NULL) + return (-ENOMEM); + + qp->id = qp_id; + dev->data->queue_pairs[qp_id] = qp; + + if (zlib_pmd_qp_set_unique_name(dev, qp)) + goto qp_setup_cleanup; + + qp->processed_pkts = zlib_pmd_qp_create_processed_pkts_ring(qp, + max_inflight_ops, socket_id); + if (qp->processed_pkts == NULL) + goto qp_setup_cleanup; + + memset(&qp->qp_stats, 0, sizeof(qp->qp_stats)); + return 0; + +qp_setup_cleanup: + if (qp) { + rte_free(qp); + qp = NULL; + } + return -1; +} + +struct rte_compressdev_ops zlib_pmd_ops = { + .dev_configure = zlib_pmd_config, + .dev_start = zlib_pmd_start, + .dev_stop = zlib_pmd_stop, + .dev_close = zlib_pmd_close, + + .stats_get = zlib_pmd_stats_get, + .stats_reset = zlib_pmd_stats_reset, + + .dev_infos_get = zlib_pmd_info_get, + + .queue_pair_setup = zlib_pmd_qp_setup, + .queue_pair_release = zlib_pmd_qp_release, + + .private_xform_create = NULL, + .private_xform_free = NULL, + + .stream_create = NULL, + .stream_free = NULL +}; + +struct rte_compressdev_ops *rte_zlib_pmd_ops = &zlib_pmd_ops; diff --git a/drivers/compress/zlib/zlib_pmd_private.h b/drivers/compress/zlib/zlib_pmd_private.h index d26a740..0e391a4 100644 --- a/drivers/compress/zlib/zlib_pmd_private.h +++ b/drivers/compress/zlib/zlib_pmd_private.h @@ -27,6 +27,41 @@ int zlib_logtype_driver; ZLIB_PMD_LOG(WARNING, fmt, ## args) struct zlib_private { + struct rte_mempool *mp; }; +struct zlib_qp { + struct rte_ring *processed_pkts; + /**< Ring for placing process packets */ + struct rte_compressdev_stats qp_stats; + /**< Queue pair statistics */ + uint16_t id; + /**< Queue Pair Identifier */ + char name[RTE_COMPRESSDEV_NAME_MAX_LEN]; + /**< Unique Queue Pair Name */ +} __rte_cache_aligned; + +/* Algorithm handler function prototype */ +typedef void (*comp_func_t)(struct rte_comp_op *op, z_stream *strm); + +typedef int (*comp_free_t)(z_stream *strm); + +/** ZLIB Stream structure */ +struct zlib_stream { + z_stream strm; + /**< zlib stream structure */ + comp_func_t comp; + /**< Operation (compression/decompression) */ + comp_free_t free; + /**< Free Operation (compression/decompression) */ +} __rte_cache_aligned; + +/** ZLIB private xform structure */ +struct zlib_priv_xform { + struct zlib_stream stream; +} __rte_cache_aligned; + +/** Device specific operations function pointer structure */ +extern struct rte_compressdev_ops *rte_zlib_pmd_ops; + #endif /* _RTE_ZLIB_PMD_PRIVATE_H_ */ From patchwork Mon Jul 23 14:51:12 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Shally Verma X-Patchwork-Id: 43279 X-Patchwork-Delegate: pablo.de.lara.guarch@intel.com Return-Path: X-Original-To: patchwork@dpdk.org Delivered-To: patchwork@dpdk.org Received: from [92.243.14.124] (localhost [127.0.0.1]) by dpdk.org (Postfix) with ESMTP id 74E0C49E1; Mon, 23 Jul 2018 16:51:54 +0200 (CEST) Received: from NAM05-DM3-obe.outbound.protection.outlook.com (mail-eopbgr730041.outbound.protection.outlook.com [40.107.73.41]) by dpdk.org (Postfix) with ESMTP id AFC4D44BE for ; Mon, 23 Jul 2018 16:51:52 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=CAVIUMNETWORKS.onmicrosoft.com; s=selector1-cavium-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=SqzztgmEMyMMCgnwFzvIUfJOOLDcg3Wwo9sXLK4Dxvs=; b=Dfs0k1JKI3mG66Mii+wjkicq7wbfj8PJf4tWLq0OOtZlArl8PT7haOnu9em89vJiOXUbGcQz2bbA+LPPd/dSl1cTvhfZ9KHmKWBUNpbPiQH8UJ1O1h8cmSwtnLQsoQclqs0mhA4aQKP8givH8/SIrsVBYgBR9rfARUjpHoFX3JY= Authentication-Results: spf=none (sender IP is ) smtp.mailfrom=Shally.Verma@cavium.com; Received: from hyd1sverma-dt.caveonetworks.com (115.113.156.2) by MWHPR0701MB3641.namprd07.prod.outlook.com (2603:10b6:301:7d::34) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.973.16; Mon, 23 Jul 2018 14:51:49 +0000 From: Shally Verma To: pablo.de.lara.guarch@intel.com Cc: dev@dpdk.org, pathreya@caviumnetworks.com, mchalla@caviumnetworks.com, Sunila Sahu , Sunila Sahu , Ashish Gupta Date: Mon, 23 Jul 2018 20:21:12 +0530 Message-Id: <1532357474-9544-4-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 X-Originating-IP: [115.113.156.2] X-ClientProxiedBy: PN1PR0101CA0041.INDPRD01.PROD.OUTLOOK.COM (2603:1096:c00:c::27) To MWHPR0701MB3641.namprd07.prod.outlook.com (2603:10b6:301:7d::34) X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: f20f5541-c4e8-4435-280f-08d5f0abd316 X-Microsoft-Antispam: BCL:0; PCL:0; RULEID:(7020095)(4652040)(8989117)(5600073)(711020)(4534165)(7168020)(4627221)(201703031133081)(201702281549075)(8990107)(2017052603328)(7153060)(7193020); SRVR:MWHPR0701MB3641; X-Microsoft-Exchange-Diagnostics: 1; MWHPR0701MB3641; 3:VDQqge3IzLvCFG9zoFMOrSaXdhASkFzvyiQX8hdHdvMIJntPK1wzFRP8O7OeWyD/NU4w9EJk+9aFqyf8WwsWgtQzfv7w5ToCCltuQ2maCI4++Q38++ww12f/BBJw/5lO7JSzfJd3rplPI3PQNe4vlDtsLzCKvx6RNQknwhF1r1bKdEa+D07EM/oy1OX0IIP7jec/fIUSwIHefVYRntBseO3Xkc5FjCnO4wx4D8IIh4TUplhVrIIQq/M5oA6tSrAZ; 25:iV7pBzAxiAiLZpeAVrc6FI1oJFdCBZvR87ppeVdwoc40ZZgUnM/ys178IrBoi/CgHXbwZHUKuVd84IOHEQjHq20RSjGrWMG0FoC4Hem9128aBuYmAqWZIzecU2af7MJcQvuPrAQtLArPIs59eAy0KWRuZHcW7jKvdSNVbsDv/Dh0KvnxUOjXvDz/lfsZ7X0mV5xB9i0vLQDJzBrYoSUMlb9IlbA8xMI6RRZHCSirKgUk8LQ2MZF2gZM9dl/+S+czhUUpJRtir8qSI0smyWJZhDi46VBvpp9RAE3r8IPGbwYT+TIgkLLSoOYQYxQyeWsKF2H/5nwoSvAf1aNeC/c9xA==; 31:M4lkoE4AxilN7TnSPv3NLhM4vjAASCdhvADHRvZfdsWtLUaeduCxXK4PzNHDDYZ+LGTvLi94GawOJnMFN6YYBnuhD2h/RttqWZe7XmaeelrHPiXkVXEqXhJC3Wo/hx5L/UHYnGLLzQri1yp6bwizCrzAJXNFSwM6jK9xHM3tD9BBmsHf04134Kg98mrdgskM3+zUpYJE4RjPk5MqNEXK8a7MCLTYuWDRM+vp//4m3mE= X-MS-TrafficTypeDiagnostic: MWHPR0701MB3641: X-Microsoft-Exchange-Diagnostics: 1; MWHPR0701MB3641; 20:1ixsjNVo4KaDeaFurLDy5zF+4EbhyIMaXGh3HjIISQqZAM1aFeaWxMzzBcZdPAkSKhABW2jcDsAuyNv00gCkGHQTBKiiZp0i7GaJS1k4PvDPT1t8J09lnY1tPuV4htG+3HtqPiz38ULkY5gPSW9x5Vu5dGz8yTm66VS6kvUyecaE7VM8mt8YSVGpPzrXIN7zyP4FmmO7UtDFzXYMVl/gEx4CjBKCTl1PjDuYm+Vjt5PBNWcBFvszs3cmce7yXzo4hbtzkvk4D3ZRbhG+9OE+4Kd3ZNmGXD4iuqAusOg4XoQc/Erc+/L+kmSnwTyuEZX5xzVQJCr4KHKYDdZ9fzGG7boxs/8T/ecuvSveNyt/DbSvS0hS1IOB4/ILKBnlCgacEX9+0iYjmxpO6xgCR1MYpug49EnCo5CyDweP9O6QSXamEk7rw02XxOSnlLFbtXSc6Ez1oKuSGI9YXsLWNQQ0FxfKgerBcnBGmvoSLep1kPJ15DXMxHFu3x+isC0shqgpT8FRFDHNrAKlxVV2yib3NGjJynfMXFcUoxoqfD5vMg0vpZI3RxyM5tt47wI1XBymhBqxd9/P9D0EKRCFSsOjrv4wRhpqOraggdsTBCYCcZw=; 4:V9LdI2SmOt9p2GmFBvEUsghugt1aj4e3ki0CHcB4WoY/Pmp8/xJcaGsMU+/wFw9uoKUlXx8DYhUzXJfnt4bhKzlsj+wFUQ1Z4oV1Fdo2TRlgekMV6OwvI3TRH2ZfilH2+76x0Z0MoLGR8rFZ0qAIbaCrkITwBZAusjtS1yJoe7GD+5aF0KyZlqLFR+oi+wCYenI4v2LTskDF1yGnQCduQWPqhtbi9ngQJISePeIEonXeNT8DlvwJw00keol3QzpWXcsVqMzzZcPAPHgCfxvtfQ== X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:; X-MS-Exchange-SenderADCheck: 1 X-Exchange-Antispam-Report-CFA-Test: BCL:0; PCL:0; RULEID:(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); SRVR:MWHPR0701MB3641; BCL:0; PCL:0; RULEID:; SRVR:MWHPR0701MB3641; X-Forefront-PRVS: 0742443479 X-Forefront-Antispam-Report: SFV:NSPM; SFS:(10009020)(396003)(366004)(39860400002)(136003)(346002)(376002)(199004)(189003)(6512007)(25786009)(53936002)(48376002)(107886003)(47776003)(66066001)(50466002)(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); DIR:OUT; SFP:1101; SCL:1; SRVR:MWHPR0701MB3641; H:hyd1sverma-dt.caveonetworks.com; FPR:; SPF:None; LANG:en; PTR:InfoNoRecords; A:1; MX:1; Received-SPF: None (protection.outlook.com: cavium.com does not designate permitted sender hosts) X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; MWHPR0701MB3641; 23:FFNHPOq4oE+GK1hlKNNggiTn4WjPUSVd5UPyAKm?= e8VOONYa/lwluGTgBO33DkFkfFTZAxbQ7uhZ69JtIcY8naURvew2emOefRkIXd+DHKFxV4iktV8mJfWRqKgCUPrgwbsjswNmvAGBFaKK1/jR/8P69ETvdFTTeiPsmucK7yyFvxZ1yTy/wgaxAnzPvvxELlN7d34N12/x12BYh2t5RDksgruWkfO2Jc7GnZgdFtPxPjIWpURGkIhJXhkRrd8ZtYf3CtanAxC73nI1xhFNhZW2+Q7GShPcZzx2JmV2bulV91kOfkeTc8hBAJqX3ZXk7wTvXuETloXLzyEeFPqi5TpkHVvpzP2YzXa58ksdwYZeDX4gJYe4qkjFnDRz7Q09v2LkPWMCnbFhyA7uY/BHOk7/cJyq/rfrzv5tIiFa3CaOQXxlrFFx95dN1XjAl17REVB0zqXDeAUmEYtcQb8OaQLmbtY3Uw/Nu+HBkpSjETaONA7XObroqMXxHCiFMacN7ZgJF/8TZsv/ij89gFj+8Jc+SMNOtzIIjECwksodKbQjT45E1PU3x5IlOv9C9WRZd2C9aflJ22kMLbBRg0kS5SZeV9N7hsGuvCtbpDuy8eIwp5fjLS5/5KnVzBtMZN+PjzD8R1DH6pV7fj1qJRLU4TwGglopUA7/Rkt1zq+qspI5cxJakP1IIa4G6OS8BayYjrSPci0Xw08wAygwjnvn1+mqPSdNqNhDTAglor/l1EW4oFqtMQU/B/HW+RlZGmE/SubaMyJbb8kFY8DCHLAHTYaoHdv0Q4b5rBo2+CMlQjQK0rEWKBKvnlejgpVjsPCPI5XXIytA+5abbecP8V9gtq0oJso5SnxuuDdOIlk9CBMhthyGZbjK+1aDaPlHcoIOo6ZPOyzzrYW2lPSZ07Yqu6NOwQRKOqAU7TgbYA1q/49xZVw6Gs3qFxLeQ8ARFGUj95SkX3ZEvmSUar3aceYTpRl5YnVIXOpKrs7bKDdvv6+0Uxc50hbgDNBMGHPLpaMrDTql9zWlb/9hnsEI18u4eOSQIE9d70CcNWbTL4FVwJdonsnORMn9eGtKdDzB4cJ4CiTm9FAZOO/0GqjQPa8NCh/mHvrbUbJWfSEdRzy131q5gjZqtRjsUB9MWPbCRQrvta1li32fGR2apbe8068Rbjh6amH6gnPPjtatudxYvK0MTquSaNW4qwGlh7FcrPMyXSKGMzedr79Rdeqw0DErUnZojh/d/u/7kb76qvb8BE6i1PBZHokBm39ptt5hoJq+9jAU6shqKoa0nMiaSKzpCynFc/ELww0+mwo3T56Lgji9Rnxg39CPcBtuRK8uTDQIbsaL8fDm74cB+H05o5SZ9Xg== X-Microsoft-Antispam-Message-Info: z9ToYLGuu2mBqK89YVJ9dvFoOsOQigquBnoXRnUpzGxHp4Oyj8dwdk2UyFkNCvG/KHdqzDddzcQrAi4U0l7Nl95BxH9mhLah6R+g0RK8vmRtOCsfLxPfwtBSmtbZ3S6M5RmX5JDutQxrgVvH6dzvGhQellD+tbhRv/uDsMElQ4NzfWJKCXdne2DNWj6edP0x1kCGU6k5kUcmbFDgXi5R8Cb8yOSUZoxNuDyC1wAXULewNG4AkCPGV5v/I71KUQWgBBAqznFX9ztD/TKcxsSo7vf4CXAi3HVQ0Ejdz4D6IYL+YQFyn7oV//93KTKwbcSEeTVmngMlS9f1TdgVVo2vdoaI+GwA/0ZIj2LnTDMIfc8= X-Microsoft-Exchange-Diagnostics: 1; MWHPR0701MB3641; 6:Wt1wog+ioE2KP4q1IgSvd5r6Tlb9oJY0YYz+MW7ZgQGdOXZTpPA1zXRYXrxMNq0rqfI54MkK2YhltVFTH6VGHWXj0DVRHU6jROLgRKS/q8bhqffjokY1b8X2CL32F58PBd4ItknTn9/ejfPul1RcaRRyycBXolJOx8dust8iL+7klIETQPJSykoDiTQ33Vz7RYoT99XpltlUGPYfZN5sK6TnSbfni3c0nPXy9349GmZCalPt4Gf9MLgzkAQt8c5+Tm0eP894NwDgYmqaXHIQSnsOuBkUS57ljg8HIzz7lKG9BQ0rWUAEUGAWpbIMH7GYwc/kmZKFeWDslcFtXNgFcMzwbK1v01SZ96eVDrvL0TkFxWjOa3JbiGKcGmt4GgdKUUfKajVa6z3xlMRzxcYCNEf3w6pOWcAEVjVPz7xRug/OCdi3RVQsV7Zp/T+msLfPfH6Mi8u1obSqNgKLhRgM6Q==; 5:hYG4lXGCkXNn3oNRA6boSkvxundf9cMTZgU75u3QP6X8cm4sWo2mJOeJzZc9grODebfQfYppi9trtmNJhihcnWWiD0k8qdLLvDxoGikC0PEsSPzX+imVEKZXvV9NoWUnUmmxV3QihvKIIbN1/B2NRJTpcl4E7Tkia6E5jPQzBjw=; 7:kocfP9mkqR6HtlnOccaAls69E8CscTNrIQg4eg3VpspKpJlcnXGmyDArGtcv5LMb2OjvZx2FJnAlkA5sCPQy/4MRx3/J9lrzEFi0VWYdW4GR5YBkWMhFk3wKDjFQJN5WHZbWB13v/0bIaQ6DxyRtv0AhYD8XxaSrWi+BBrmTw55gV4zhvhjNd1cCc7FoK8E4wr/LIBbzWLhZ58qQmOizh3+obL6E/hVocLO3XuZTsiEF5WOVatgKJ4dZEn6arReC SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-OriginatorOrg: caviumnetworks.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 23 Jul 2018 14:51:49.1811 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: f20f5541-c4e8-4435-280f-08d5f0abd316 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 3/5] compress/zlib: create private xform X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Sender: "dev" From: Sunila Sahu Create non-shareable private xform for stateless operation processing Signed-off-by: Sunila Sahu Signed-off-by: Shally Verma Signed-off-by: Ashish Gupta --- drivers/compress/zlib/zlib_pmd.c | 94 ++++++++++++++++++++++++++++++++ drivers/compress/zlib/zlib_pmd_ops.c | 74 ++++++++++++++++++++++++- drivers/compress/zlib/zlib_pmd_private.h | 4 ++ 3 files changed, 170 insertions(+), 2 deletions(-) diff --git a/drivers/compress/zlib/zlib_pmd.c b/drivers/compress/zlib/zlib_pmd.c index 9363808..47bc73d 100644 --- a/drivers/compress/zlib/zlib_pmd.c +++ b/drivers/compress/zlib/zlib_pmd.c @@ -7,6 +7,100 @@ #include "zlib_pmd_private.h" +/** Parse comp xform and set private xform/stream parameters */ +int +zlib_set_stream_parameters(const struct rte_comp_xform *xform, + struct zlib_stream *stream) +{ + int strategy, level, wbits; + z_stream *strm = &stream->strm; + + /* allocate deflate state */ + strm->zalloc = Z_NULL; + strm->zfree = Z_NULL; + strm->opaque = Z_NULL; + + switch (xform->type) { + case RTE_COMP_COMPRESS: + /** Compression window bits */ + switch (xform->compress.algo) { + case RTE_COMP_ALGO_DEFLATE: + wbits = -(xform->compress.window_size); + break; + default: + ZLIB_PMD_ERR("Compression algorithm not supported\n"); + return -1; + } + /** Compression Level */ + switch (xform->compress.level) { + case RTE_COMP_LEVEL_PMD_DEFAULT: + level = Z_DEFAULT_COMPRESSION; + break; + case RTE_COMP_LEVEL_NONE: + level = Z_NO_COMPRESSION; + break; + case RTE_COMP_LEVEL_MIN: + level = Z_BEST_SPEED; + break; + case RTE_COMP_LEVEL_MAX: + level = Z_BEST_COMPRESSION; + break; + default: + level = xform->compress.level; + if (level < RTE_COMP_LEVEL_MIN || + level > RTE_COMP_LEVEL_MAX) { + ZLIB_PMD_ERR("Compression level %d " + "not supported\n", + level); + return -1; + } + break; + } + /** Compression strategy */ + switch (xform->compress.deflate.huffman) { + case RTE_COMP_HUFFMAN_DEFAULT: + strategy = Z_DEFAULT_STRATEGY; + break; + case RTE_COMP_HUFFMAN_FIXED: + strategy = Z_FIXED; + break; + case RTE_COMP_HUFFMAN_DYNAMIC: + strategy = Z_DEFAULT_STRATEGY; + break; + default: + ZLIB_PMD_ERR("Compression strategy not supported\n"); + return -1; + } + if (deflateInit2(strm, level, + Z_DEFLATED, wbits, + DEF_MEM_LEVEL, strategy) != Z_OK) { + ZLIB_PMD_ERR("Deflate init failed\n"); + return -1; + } + break; + + case RTE_COMP_DECOMPRESS: + /** window bits */ + switch (xform->decompress.algo) { + case RTE_COMP_ALGO_DEFLATE: + wbits = -(xform->decompress.window_size); + break; + default: + ZLIB_PMD_ERR("Compression algorithm not supported\n"); + return -1; + } + + if (inflateInit2(strm, wbits) != Z_OK) { + ZLIB_PMD_ERR("Inflate init failed\n"); + return -1; + } + break; + default: + return -1; + } + return 0; +} + static int zlib_create(const char *name, struct rte_vdev_device *vdev, diff --git a/drivers/compress/zlib/zlib_pmd_ops.c b/drivers/compress/zlib/zlib_pmd_ops.c index 645c5b1..2fb6a85 100644 --- a/drivers/compress/zlib/zlib_pmd_ops.c +++ b/drivers/compress/zlib/zlib_pmd_ops.c @@ -214,6 +214,76 @@ zlib_pmd_qp_setup(struct rte_compressdev *dev, uint16_t qp_id, return -1; } +/** Configure stream */ +static int +zlib_pmd_stream_create(struct rte_compressdev *dev, + const struct rte_comp_xform *xform, + void **zstream) +{ + int ret = 0; + struct zlib_stream *stream; + struct zlib_private *internals = dev->data->dev_private; + + if (xform == NULL) { + ZLIB_PMD_ERR("invalid xform struct"); + return -EINVAL; + } + + if (rte_mempool_get(internals->mp, zstream)) { + ZLIB_PMD_ERR("Couldn't get object from session mempool"); + return -ENOMEM; + } + stream = *((struct zlib_stream **)zstream); + + ret = zlib_set_stream_parameters(xform, stream); + + if (ret < 0) { + ZLIB_PMD_ERR("failed configure session parameters"); + + memset(stream, 0, sizeof(struct zlib_stream)); + /* Return session to mempool */ + rte_mempool_put(internals->mp, stream); + return ret; + } + + return 0; +} + +/** Configure private xform */ +static int +zlib_pmd_private_xform_create(struct rte_compressdev *dev, + const struct rte_comp_xform *xform, + void **private_xform) +{ + return zlib_pmd_stream_create(dev, xform, private_xform); +} + +/** Clear the memory of stream so it doesn't leave key material behind */ +static int +zlib_pmd_stream_free(__rte_unused struct rte_compressdev *dev, + void *zstream) +{ + struct zlib_stream *stream = (struct zlib_stream *)zstream; + if (!stream) + return -EINVAL; + + stream->free(&stream->strm); + /* Zero out the whole structure */ + memset(stream, 0, sizeof(struct zlib_stream)); + struct rte_mempool *mp = rte_mempool_from_obj(stream); + rte_mempool_put(mp, stream); + + return 0; +} + +/** Clear the memory of stream so it doesn't leave key material behind */ +static int +zlib_pmd_private_xform_free(struct rte_compressdev *dev, + void *private_xform) +{ + return zlib_pmd_stream_free(dev, private_xform); +} + struct rte_compressdev_ops zlib_pmd_ops = { .dev_configure = zlib_pmd_config, .dev_start = zlib_pmd_start, @@ -228,8 +298,8 @@ struct rte_compressdev_ops zlib_pmd_ops = { .queue_pair_setup = zlib_pmd_qp_setup, .queue_pair_release = zlib_pmd_qp_release, - .private_xform_create = NULL, - .private_xform_free = NULL, + .private_xform_create = zlib_pmd_private_xform_create, + .private_xform_free = zlib_pmd_private_xform_free, .stream_create = NULL, .stream_free = NULL diff --git a/drivers/compress/zlib/zlib_pmd_private.h b/drivers/compress/zlib/zlib_pmd_private.h index 0e391a4..2c6e83d 100644 --- a/drivers/compress/zlib/zlib_pmd_private.h +++ b/drivers/compress/zlib/zlib_pmd_private.h @@ -61,6 +61,10 @@ struct zlib_priv_xform { struct zlib_stream stream; } __rte_cache_aligned; +int +zlib_set_stream_parameters(const struct rte_comp_xform *xform, + struct zlib_stream *stream); + /** Device specific operations function pointer structure */ extern struct rte_compressdev_ops *rte_zlib_pmd_ops; From patchwork Mon Jul 23 14:51:13 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Shally Verma X-Patchwork-Id: 43280 X-Patchwork-Delegate: pablo.de.lara.guarch@intel.com Return-Path: X-Original-To: patchwork@dpdk.org Delivered-To: patchwork@dpdk.org Received: from [92.243.14.124] (localhost [127.0.0.1]) by dpdk.org (Postfix) with ESMTP id 8236A4C8C; Mon, 23 Jul 2018 16:51:58 +0200 (CEST) Received: from NAM05-DM3-obe.outbound.protection.outlook.com (mail-eopbgr730077.outbound.protection.outlook.com [40.107.73.77]) by dpdk.org (Postfix) with ESMTP id 707074C8C for ; Mon, 23 Jul 2018 16:51:56 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=CAVIUMNETWORKS.onmicrosoft.com; s=selector1-cavium-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=jVA7qaTC5BFNmGR6JQVnGFhXALaf3FAQCSA0sndsOok=; b=VU7b56O0uGlI/oWzvD9/e6T9QPimiRHrr1n7a1+pCXdYLmwtg7FUhoYlkRbqr6mNheBvMghf8b+Fu/WQMGrvaZH0oebB+2SaLakpsuSiJFJL26uannrPCFOIwiDJAktze++wF8v+fmaQMEzuJIRHdAtTwHZ7EH3pvpS4msMPjg0= Authentication-Results: spf=none (sender IP is ) smtp.mailfrom=Shally.Verma@cavium.com; Received: from hyd1sverma-dt.caveonetworks.com (115.113.156.2) by MWHPR0701MB3641.namprd07.prod.outlook.com (2603:10b6:301:7d::34) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.973.16; Mon, 23 Jul 2018 14:51:51 +0000 From: Shally Verma To: pablo.de.lara.guarch@intel.com Cc: dev@dpdk.org, pathreya@caviumnetworks.com, mchalla@caviumnetworks.com, Sunila Sahu , Sunila Sahu , Ashish Gupta 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 X-Originating-IP: [115.113.156.2] X-ClientProxiedBy: PN1PR0101CA0041.INDPRD01.PROD.OUTLOOK.COM (2603:1096:c00:c::27) To MWHPR0701MB3641.namprd07.prod.outlook.com (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; RULEID:(7020095)(4652040)(8989117)(5600073)(711020)(4534165)(7168020)(4627221)(201703031133081)(201702281549075)(8990107)(2017052603328)(7153060)(7193020); SRVR:MWHPR0701MB3641; X-Microsoft-Exchange-Diagnostics: 1; MWHPR0701MB3641; 3:MG+MXwAtC24bytT0MZ5GHBP+uIqoaHymagKonp1SUK1uZ4Q1aAI66sYMfjgzbkz4m1M2hEYL0OOTI5Lx3TDHsN2CvPgBDoENNalZbT4WL5n8VwUbEQEWGefJN6hjnvfM1ZnbIvEpiBU22jlUrHYk+c0qMBV4emDl62J5/Rn7CyTExXmom2oHK5z5F6PyLOwVfZqtfxzy0u0Zk7MUOqUuHhw0qk9LR4ZmTVH8hikTM7zXAnrLYsyuNpw2yp8XHbde; 25:Za+Qe7+kykWgJ9FpJnnecbijFACHbx+7LiO6THTSHgErctA+evggkEwb302EJ0sund5MTPhu/FbL7mzE2K2BJMZWR2gnEHaw3ARDhqyTxADInf/q/BG9UOA94yfjQxUSCCnsx0aiMZ2L6IsRJch0OCwh11AIlpKUdWRxrVSbIIFPkJwlbwZCC9+ZAFesEILG+NNj1B6BQYAMtI6JPQqzQ0P2mY45hp7odT+b7GOmp3hoUc5En7wNY+8jVn+BKb7HZ/n3AVH4+dQWUGGxYVBKCDC7+g+FOINcT/RpTqI1lwGvy30NRLQxz54W/7KJs7eEvbDCs3R48cT0wbpyerpFlg==; 31:B3XzlWNOUCV5yImj86OhP7CZzJNnzb4TC50KFGPITqRscdtup+ho3AZOxvaYP0xM+CwfFZ50lP7+PRMU5FzqYadcdeYVwtg9VE24OP1V+8teurLGr8xOaMPKWBzPoka6kO1FlEwYxnwGSnyPavUU/vxcHCxgXqDJly99NIpVmsnD+gmu1nCFCGa3vvxfYUUf98pLgooymlFGLggcW/xUCRbvuReebeQc6mLHVNQCQIU= X-MS-TrafficTypeDiagnostic: MWHPR0701MB3641: X-Microsoft-Exchange-Diagnostics: 1; MWHPR0701MB3641; 20:0gdpAgjgiFo9WkdTyjML2I/xT6Ygm9CAGPHF2rDBBq1ECFtL8uLCcQWbzu6ZC1bd6fSMC3nwgupAIpkma3w/FoRJ7If2juVcSwOaYdrNnCme0EYkRwBgQDDEpwMD0MUZGzIEwAlnr7m43IHGBRV/34qU7XN0GVO6vpKrblhr8qkbEMGXpC8ATZtCy6ep2RW86i1ubhFQz0DbnfRNAjllJrLCKnGbH3MIwRsXbeIEhRUibtZe2Hl3nXGT4b5LHt0HJwGbYqlcQpisaFWZ3pW+xwuj+WGEIyA+/Dp/cDZAi+ILCcXOq6CYOOL5UjmIhhrauJNIu3JqlAP5ng4l8yw8fgBEBIzJkvq9vieUINlmS2SWJ6BrMwOXfISXsV5kflrMtzg4iJWiu9ZnbXMOAAphp6jnRJu27I6O5RUQ+z9DS8SGHT2LnX6QRRUjt/9AG5MFvqTIZNWbFwI7GYpyhub1bRNMQsJsIHqnKBDYTlylVF6RMj8EPPvqRrVXlqSvi4JZgK5zpwMz1xdSThncEgF0uLlLqF5F4lJZlDQUj52El0ApVxjt3+SdlPLsIQoZGg+iDCllf73Lt9gUZaLcItTMXoz8MeJbi5zdbUAv49TTgrk=; 4:gv0OI8Fa5kOD09EIf2lk2Id5dT86X3Req49yflSqFEboHhMA8fYT+dxHIfpDn4N8tObzNYmC+GFujiGW+gRoEkwfefVaRrSXCr0IZtpaXVD7LsB7pVcZ5b4bwHINKssG8HP40fH4sYEoby3T5bJoQ5rZOmLtVm1SE61QH2QZPIjP1EtEA8Y06WY4/i3Fhl/EL2qDR3Oc2/5m5onBZ6R0RjDgs1EdWjhadh6wVXZ+eIF4xj9XbW1n4SEI+Oe9Z9XYbXMfIC/ZJiQLqpEcF4FMlw== X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:; X-MS-Exchange-SenderADCheck: 1 X-Exchange-Antispam-Report-CFA-Test: BCL:0; PCL:0; RULEID:(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); SRVR:MWHPR0701MB3641; BCL:0; PCL:0; RULEID:; SRVR:MWHPR0701MB3641; X-Forefront-PRVS: 0742443479 X-Forefront-Antispam-Report: SFV:NSPM; SFS:(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); DIR:OUT; SFP:1101; SCL:1; SRVR:MWHPR0701MB3641; H:hyd1sverma-dt.caveonetworks.com; FPR:; SPF:None; LANG:en; PTR:InfoNoRecords; A:1; MX:1; Received-SPF: None (protection.outlook.com: cavium.com does not designate permitted sender hosts) X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; MWHPR0701MB3641; 23:I8hVEdCXpg7QNEwUBEOlnvG0v7EjnuSwIgy3XvH?= p1A0dwi5bC6nNqfr6QxWLZhgWqUq4XLUv8aLY6JikTPiAOMFCzJ3tSq4leHKr1gzCP1XuqMk6jUscS84GJHyjIndYvTFmJS5PLXuheD4GihOu9/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= X-Microsoft-Antispam-Message-Info: PclarRG2AarmhKuNqY+W28m/ndUl6Z0r8nvNZC+nurL8984QJZI+DxHP6HmEK6aSxlqr8zv7WLZnNPbVybB8CRf3QOX+E3PYnG+MjLnK51Ua4D7FHSss8QMmtwMRWy0Sda1ZAcyZejhyL/OYqJsMMXtGIlr0VKsgjgU/9uXSvieLDBygk2ZWZPB8GXyablebLUCxRzDsFfiz1EQSQ8qDk9acxC0BWd1NG7tvNA3wm944Yxn5br1cpHQLhc7Z0gn0/DSf95QRJk1KoUo/ZjKzToGu3MDIPM0AUYi/g987C5hdCWOYZDaNT2lWOKmmxoiQRCBj0WWm7ViOWRarnYNiQXp+v4b9eh1BZH7YEUd+heE= X-Microsoft-Exchange-Diagnostics: 1; MWHPR0701MB3641; 6:1zDE93XN3AtXwGdWQ9/e7kIRfatmvBQ1GOGIWkQb6GxRsIZqXlEiu+rZI2cceOuiJbfWASo7PuvU38YVH0eXvK8QD3r83LZyBySWZsfWTOiMaCigBAVHbO61OnEJiAa01jT6OdBB7hL3B4ueDFYdCKbPy6+G2HqAJqcR2iKZiRwr99+pQ1+bXVvT5oZnTjnXDR7SB14tb07L9Fd3b5l0/c/EADLwDzlh4D+9lTvEepbfUwKSAl3N5LJgipLSclnpjKn5WwkHzj+a16tlvWz3rnfPfrhNjXiXOfr169j6Un5oHbVBsKlyepr6NUYluaqFliBK2RIrjvKWDrnWPVpwe30hCKV/PIal0KD2QBWvZLI/1x68xSHlQVMSPWQZ/F6zdJ0ib0s+kZFm4A9j03bjIOpszk8G+ULAw/ugv1xeNV+/uhQfq/SyBNVcgjIU0annvC0zLtsXj2SJgX5WDKAF/w==; 5:uLt79azKbptZBqHeMdoXHFzUIq0+RH27/2rgTPwXvSWRTIIb2YhjoOBs3y5uFh/vBsPCMHZ1W3r9FhNaXBI/AkiL1wm1+W2HpKpwi6VmsTgESwzkI7GG9zsMDzM5uMrm9ZesNpZR0oJWWY5NuQep6KH7JvPhOQHt+KxpUaHy0Jk=; 7:H1bgwo6zm5sXACQUSb0ExkNwZO7q6kzxhtKt1bfNrw1vjxUL7p5v53XDwhzOHdTd7zACWUgPhqAGe+RXWbKM07spzw8Hz8g9+zGnCdrxdhwfCH1RSDTB9rYGXYn0Jya0Z7+1TusOlb9Q9BBwKC34nEughylGrjibUSFnwwqbeLVHW1Zr8e0ROc6duGnxIEt4FaFTGmCvrR39dPoqjXw3aYUMNSRiTzN6ON9+mBUqmykFfjAPVtiyS1HRHmSpJP1M SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-OriginatorOrg: caviumnetworks.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 23 Jul 2018 14:51:51.9936 (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 enqueue/dequeue X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Sender: "dev" From: Sunila Sahu Signed-off-by: Sunila Sahu Signed-off-by: Shally Verma Signed-off-by: Ashish Gupta --- drivers/compress/zlib/zlib_pmd.c | 255 ++++++++++++++++++++++++++++++++++++++- 1 file changed, 254 insertions(+), 1 deletion(-) diff --git a/drivers/compress/zlib/zlib_pmd.c b/drivers/compress/zlib/zlib_pmd.c index 47bc73d..dc1e230 100644 --- a/drivers/compress/zlib/zlib_pmd.c +++ b/drivers/compress/zlib/zlib_pmd.c @@ -7,7 +7,214 @@ #include "zlib_pmd_private.h" -/** Parse comp xform and set private xform/stream parameters */ +/** Compute next mbuf in the list, assign data buffer and length, + * returns 0 if mbuf is NULL + */ +#define COMPUTE_BUF(mbuf, data, len) \ + ((mbuf = mbuf->next) ? \ + (data = rte_pktmbuf_mtod(mbuf, uint8_t *)), \ + (len = rte_pktmbuf_data_len(mbuf)) : 0) + +static void +process_zlib_deflate(struct rte_comp_op *op, z_stream *strm) +{ + int ret, flush, fin_flush; + struct rte_mbuf *mbuf_src = op->m_src; + struct rte_mbuf *mbuf_dst = op->m_dst; + + switch (op->flush_flag) { + case RTE_COMP_FLUSH_FULL: + case RTE_COMP_FLUSH_FINAL: + fin_flush = Z_FINISH; + break; + default: + op->status = RTE_COMP_OP_STATUS_INVALID_ARGS; + ZLIB_PMD_ERR("Invalid flush value\n"); + } + + if (unlikely(!strm)) { + op->status = RTE_COMP_OP_STATUS_INVALID_ARGS; + ZLIB_PMD_ERR("Invalid z_stream\n"); + return; + } + /* Update z_stream with the inputs provided by application */ + strm->next_in = rte_pktmbuf_mtod_offset(mbuf_src, uint8_t *, + op->src.offset); + + strm->avail_in = rte_pktmbuf_data_len(mbuf_src) - op->src.offset; + + strm->next_out = rte_pktmbuf_mtod_offset(mbuf_dst, uint8_t *, + op->dst.offset); + + strm->avail_out = rte_pktmbuf_data_len(mbuf_dst) - op->dst.offset; + + /* Set flush value to NO_FLUSH unless it is last mbuf */ + flush = Z_NO_FLUSH; + /* Initialize status to SUCCESS */ + op->status = RTE_COMP_OP_STATUS_SUCCESS; + + do { + /* Set flush value to Z_FINISH for last block */ + if ((op->src.length - strm->total_in) <= strm->avail_in) { + strm->avail_in = (op->src.length - strm->total_in); + flush = fin_flush; + } + do { + ret = deflate(strm, flush); + if (unlikely(ret == Z_STREAM_ERROR)) { + /* error return, do not process further */ + op->status = RTE_COMP_OP_STATUS_ERROR; + goto def_end; + } + /* Break if Z_STREAM_END is encountered */ + if (ret == Z_STREAM_END) + goto def_end; + + /* Keep looping until input mbuf is consumed. + * Exit if destination mbuf gets exhausted. + */ + } while ((strm->avail_out == 0) && + COMPUTE_BUF(mbuf_dst, strm->next_out, strm->avail_out)); + + if (!strm->avail_out) { + /* there is no space for compressed output */ + op->status = RTE_COMP_OP_STATUS_OUT_OF_SPACE_TERMINATED; + break; + } + + /* Update source buffer to next mbuf + * Exit if input buffers are fully consumed + */ + } while (COMPUTE_BUF(mbuf_src, strm->next_in, strm->avail_in)); + +def_end: + /* Update op stats */ + switch (op->status) { + case RTE_COMP_OP_STATUS_SUCCESS: + op->consumed += strm->total_in; + /* Fall-through */ + case RTE_COMP_OP_STATUS_OUT_OF_SPACE_TERMINATED: + op->produced += strm->total_out; + break; + default: + ZLIB_PMD_ERR("stats not updated for status:%d\n", + op->status); + } + + deflateReset(strm); +} + +static void +process_zlib_inflate(struct rte_comp_op *op, z_stream *strm) +{ + int ret, flush; + struct rte_mbuf *mbuf_src = op->m_src; + struct rte_mbuf *mbuf_dst = op->m_dst; + + if (unlikely(!strm)) { + op->status = RTE_COMP_OP_STATUS_INVALID_ARGS; + ZLIB_PMD_ERR("Invalid z_stream\n"); + return; + } + strm->next_in = rte_pktmbuf_mtod_offset(mbuf_src, uint8_t *, + op->src.offset); + + strm->avail_in = rte_pktmbuf_data_len(mbuf_src) - op->src.offset; + + strm->next_out = rte_pktmbuf_mtod_offset(mbuf_dst, uint8_t *, + op->dst.offset); + + strm->avail_out = rte_pktmbuf_data_len(mbuf_dst) - op->dst.offset; + + /** Ignoring flush value provided from application for decompression */ + flush = Z_NO_FLUSH; + /* initialize status to SUCCESS */ + op->status = RTE_COMP_OP_STATUS_SUCCESS; + + do { + do { + ret = inflate(strm, flush); + + switch (ret) { + /* Fall-through */ + case Z_NEED_DICT: + ret = Z_DATA_ERROR; + /* Fall-through */ + case Z_DATA_ERROR: + /* Fall-through */ + case Z_MEM_ERROR: + /* Fall-through */ + case Z_STREAM_ERROR: + op->status = RTE_COMP_OP_STATUS_ERROR; + /* Fall-through */ + case Z_STREAM_END: + /* no further computation needed if + * Z_STREAM_END is encountered + */ + goto inf_end; + default: + /* success */ + break; + + } + /* Keep looping until input mbuf is consumed. + * Exit if destination mbuf gets exhausted. + */ + } while ((strm->avail_out == 0) && + COMPUTE_BUF(mbuf_dst, strm->next_out, strm->avail_out)); + + if (!strm->avail_out) { + /* there is no more space for decompressed output */ + op->status = RTE_COMP_OP_STATUS_OUT_OF_SPACE_TERMINATED; + break; + } + /* Read next input buffer to be processed, exit if compressed + * blocks are fully read + */ + } while (COMPUTE_BUF(mbuf_src, strm->next_in, strm->avail_in)); + +inf_end: + /* Update op stats */ + switch (op->status) { + case RTE_COMP_OP_STATUS_SUCCESS: + op->consumed += strm->total_in; + /* Fall-through */ + case RTE_COMP_OP_STATUS_OUT_OF_SPACE_TERMINATED: + op->produced += strm->total_out; + break; + default: + ZLIB_PMD_ERR("stats not produced for status:%d\n", + op->status); + } + + inflateReset(strm); +} + +/** Process comp operation for mbuf */ +static inline int +process_zlib_op(struct zlib_qp *qp, struct rte_comp_op *op) +{ + struct zlib_stream *stream; + struct zlib_priv_xform *private_xform; + + if ((op->op_type == RTE_COMP_OP_STATEFUL) || + (op->src.offset > rte_pktmbuf_data_len(op->m_src)) || + (op->dst.offset > rte_pktmbuf_data_len(op->m_dst))) { + op->status = RTE_COMP_OP_STATUS_INVALID_ARGS; + ZLIB_PMD_ERR("Invalid source or destination buffers or " + "invalid Operation requested\n"); + } else { + private_xform = (struct zlib_priv_xform *)op->private_xform; + stream = &private_xform->stream; + stream->comp(op, &stream->strm); + } + /* whatever is out of op, put it into completion queue with + * its status + */ + return rte_ring_enqueue(qp->processed_pkts, (void *)op); +} + +/** Parse comp xform and set private xform/Stream parameters */ int zlib_set_stream_parameters(const struct rte_comp_xform *xform, struct zlib_stream *stream) @@ -22,6 +229,8 @@ zlib_set_stream_parameters(const struct rte_comp_xform *xform, switch (xform->type) { case RTE_COMP_COMPRESS: + stream->comp = process_zlib_deflate; + stream->free = deflateEnd; /** Compression window bits */ switch (xform->compress.algo) { case RTE_COMP_ALGO_DEFLATE: @@ -80,6 +289,8 @@ zlib_set_stream_parameters(const struct rte_comp_xform *xform, break; case RTE_COMP_DECOMPRESS: + stream->comp = process_zlib_inflate; + stream->free = inflateEnd; /** window bits */ switch (xform->decompress.algo) { case RTE_COMP_ALGO_DEFLATE: @@ -101,6 +312,44 @@ zlib_set_stream_parameters(const struct rte_comp_xform *xform, return 0; } +static uint16_t +zlib_pmd_enqueue_burst(void *queue_pair, + struct rte_comp_op **ops, uint16_t nb_ops) +{ + struct zlib_qp *qp = queue_pair; + int ret; + uint16_t i; + uint16_t enqd = 0; + for (i = 0; i < nb_ops; i++) { + ret = process_zlib_op(qp, ops[i]); + if (unlikely(ret < 0)) { + /* increment count if failed to push to completion + * queue + */ + qp->qp_stats.enqueue_err_count++; + } else { + qp->qp_stats.enqueued_count++; + enqd++; + } + } + return enqd; +} + +static uint16_t +zlib_pmd_dequeue_burst(void *queue_pair, + struct rte_comp_op **ops, uint16_t nb_ops) +{ + struct zlib_qp *qp = queue_pair; + + unsigned int nb_dequeued = 0; + + nb_dequeued = rte_ring_dequeue_burst(qp->processed_pkts, + (void **)ops, nb_ops, NULL); + qp->qp_stats.dequeued_count += nb_dequeued; + + return nb_dequeued; +} + static int zlib_create(const char *name, struct rte_vdev_device *vdev, @@ -117,6 +366,10 @@ zlib_create(const char *name, dev->dev_ops = rte_zlib_pmd_ops; + /* register rx/tx burst functions for data path */ + dev->dequeue_burst = zlib_pmd_dequeue_burst; + dev->enqueue_burst = zlib_pmd_enqueue_burst; + return 0; } From patchwork Mon Jul 23 14:51:14 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Shally Verma X-Patchwork-Id: 43281 X-Patchwork-Delegate: pablo.de.lara.guarch@intel.com Return-Path: X-Original-To: patchwork@dpdk.org Delivered-To: patchwork@dpdk.org Received: from [92.243.14.124] (localhost [127.0.0.1]) by dpdk.org (Postfix) with ESMTP id 3A44F4C9B; Mon, 23 Jul 2018 16:52:01 +0200 (CEST) Received: from NAM05-DM3-obe.outbound.protection.outlook.com (mail-eopbgr730064.outbound.protection.outlook.com [40.107.73.64]) by dpdk.org (Postfix) with ESMTP id 051694C94 for ; Mon, 23 Jul 2018 16:51:58 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=CAVIUMNETWORKS.onmicrosoft.com; s=selector1-cavium-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=8bHIEcUViukDwMGWHiNOYwwgqTnJBZoLBu4BL8tM/OM=; b=Z8NRYmHvCVcnY3JGtrBpy8cDmkoJkALHYDzHH5jVDw+NBSMkxhQY8unEo0QHOeWBMT/X100mN8UomcjhS7A4RY2i+ZxbR1xAqg/dIre8EQc+4K57BHdAw5u5W44eX/G2ryux0MwTnzIasrUp+8CQdjktQv9QPll6kg6YDmPT7VM= Authentication-Results: spf=none (sender IP is ) smtp.mailfrom=Shally.Verma@cavium.com; Received: from hyd1sverma-dt.caveonetworks.com (115.113.156.2) by MWHPR0701MB3641.namprd07.prod.outlook.com (2603:10b6:301:7d::34) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.973.16; Mon, 23 Jul 2018 14:51:55 +0000 From: Shally Verma To: pablo.de.lara.guarch@intel.com Cc: dev@dpdk.org, pathreya@caviumnetworks.com, mchalla@caviumnetworks.com, Sunila Sahu , Ashish Gupta Date: Mon, 23 Jul 2018 20:21:14 +0530 Message-Id: <1532357474-9544-6-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 X-Originating-IP: [115.113.156.2] X-ClientProxiedBy: PN1PR0101CA0041.INDPRD01.PROD.OUTLOOK.COM (2603:1096:c00:c::27) To MWHPR0701MB3641.namprd07.prod.outlook.com (2603:10b6:301:7d::34) X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 38e31763-f4fb-4450-ef07-08d5f0abd685 X-Microsoft-Antispam: BCL:0; PCL:0; RULEID:(7020095)(4652040)(8989117)(5600073)(711020)(4534165)(7168020)(4627221)(201703031133081)(201702281549075)(8990107)(2017052603328)(7153060)(7193020); SRVR:MWHPR0701MB3641; X-Microsoft-Exchange-Diagnostics: 1; MWHPR0701MB3641; 3:gwMTvZr9ZKBy8C/LSWftqFlOhMI0f4QUztcIns9aOOQoBaACOkVs+VQNK8i/gjeKzeueAmvK9tj5mnvm1kQzu40YGaCeV7sW5exf10xmEyjPuJalu2EsBpWzsRonbUFR3w2ByurEWdcJW3gmW3FNq1ss0DZzATkzgicB4eHpDekwouGjOrCeD7tZZrM4+hBtvDFOOLsDN09WjfSlKl9ZOgA3yXwnudJaNmUVT2TVDOD/Z1xyZgZJ4whGdxjIDQHo; 25:pin3cYKjPncGMQ+suGX8Sqb6X97K9+h0R/YXlZDsglLc8upFe5KBByL0ZlbvM17bw26jy7w9T/epyxfoPXGEfDi3K8Dkcm8Yi6KgMajDPUdajhKYl05ajXNgjUwFaKukd3JazOHUa4H8MEOe1esfDsRyhcgTbDbQKKPu0Q97Dnby77+RnAixpFdgrXUxRRqHV8q1wiKnhNeK5YfynJlV3MrggPyiON18dRaKeYwMIkqR8DdMq6pP3kgHHfqtbFAFu9igwsCpUAtPs6WkDC3Sc/GSu6at2M9PPX7wR4zFl/FYlIn6u2XXP+cV42b1EZxDggGxhY4HwRGhGenRs7YRtw==; 31:QO/QhyQHvNxSD+uD8SMNjq/wUVviO+elRg0xBD28iS+txkzdduGmzBdlo1FA/cbPvX7Vpc9TJb57bIjEJRgg8LlU6k+asgHCUQvvf3GeU/S9VYbqC74sTi+B4L6cHSYj8Qy5FoSvokqXCXaARVAE7VcM7MVux2sfyoO73GXTA7JiiK2nboTuLSB0rTbPopmkQ/lznXx55POeijoiR6c/nDz2OWeQRQ1oZDtmutg/BIE= X-MS-TrafficTypeDiagnostic: MWHPR0701MB3641: X-Microsoft-Exchange-Diagnostics: 1; MWHPR0701MB3641; 20:AekDmcSkm9ee0GvDs17l6M1bzeSlAEs4FL+JytviiS+W2NGoO9d39j7BEyFR6f7iuTiteZ64MS2F+sMa9Z8hHkpQf1J9NEwNzqs/zxzsInCZoy6dtfoZoDtZ4rpJCILXiNU92MrsqANtxfs2vuU7oZrmb7u95SJ6GjL1Wu/lUQBxkIDnBEhn/vLiunxGxYNS/ZSGpkAML+KjLB5dBqvRCNgotUy3WE/SKqwvYhkZ5nUJZ040IgcmWkyxYzzchThySSlF2gP+7G4uFgSvC1dO8GMQZ36JtZ3U/jCEMQuQlANwRoppZonRehJTf1dpjm0CcR91Pk03+TfbAfEATHUzWgKt5tyyrtHqScbh+6bmbcAkJSv1EVnn02ScLRcgHnoVlWkTAt73KGTynuRqwNeexMcVvV0XpVYuQ4yvapKqTWKF30wtssGcJPLHQdmmIJbEwrSiiICO4Vq0RypZihzR+OO+kxN0qZB4Rg3VjxEugoUtOfj8JhfUmLiDpnwhh6fuNiPXFBNADd7UXmiHnwwltyNJ0+Diz9VjoQ9Lyw/tAISepn3G+faQeFaPdoSux/CX2qFeu0n2xzoEtabRLGMY8GAXx1Rd9lh/P0NrwOXqRyM=; 4:vL91fsZ6jSwPEXzz4j17L50Nvn/wUaAa2UhALXXtM1PS8srfMUgPg/b9i/nkFOsqmEi8LPUq+71a5bNFc4ue0rP8aUtHg/JWRt3Tprcz6cexYQvHR9x5wWzIfvgYkNnhuL6sGu/wtNPqIhkAYCp0Y+rKQj6dhFArhIqpSGhvENVX0BG7Z2IRx+PsKwPb5RYginYiQtL/MPMhuZc+ayoP6WZWiugHGClwBgPuLf2zp+zg0sRLf923Y+4l2IqHTtbpbVJ1kVly5+OQf19oLF7G9A== X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:; X-MS-Exchange-SenderADCheck: 1 X-Exchange-Antispam-Report-CFA-Test: BCL:0; PCL:0; RULEID:(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); SRVR:MWHPR0701MB3641; BCL:0; PCL:0; RULEID:; SRVR:MWHPR0701MB3641; X-Forefront-PRVS: 0742443479 X-Forefront-Antispam-Report: SFV:NSPM; SFS:(10009020)(396003)(366004)(39860400002)(136003)(346002)(376002)(199004)(189003)(6512007)(25786009)(53936002)(53376002)(48376002)(107886003)(47776003)(66066001)(50466002)(14444005)(50226002)(2351001)(69596002)(55236004)(4326008)(36756003)(446003)(42882007)(7736002)(305945005)(966005)(5660300001)(3846002)(478600001)(6116002)(72206003)(11346002)(316002)(8676002)(97736004)(44832011)(76176011)(16586007)(81156014)(68736007)(81166006)(52116002)(476003)(956004)(2616005)(486006)(217873002)(51416003)(26005)(2906002)(386003)(6506007)(2361001)(6486002)(105586002)(6306002)(6916009)(53416004)(186003)(6666003)(54906003)(16526019)(106356001)(8936002); DIR:OUT; SFP:1101; SCL:1; SRVR:MWHPR0701MB3641; H:hyd1sverma-dt.caveonetworks.com; FPR:; SPF:None; LANG:en; PTR:InfoNoRecords; A:1; MX:1; Received-SPF: None (protection.outlook.com: cavium.com does not designate permitted sender hosts) X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; MWHPR0701MB3641; 23:cTraQPtDrpuOvxDgHSj+lqT05I0xIf0g38Git8T?= Ol/HMJEUX76OlELXlwQYT5k0mAv9W/PmAaBaEmWFsh+09haTyeRaIfeUKmcg4Daj29v3x3pGWPSY+JAjwKTtWIaAG/2KZSADPbCjCbTrCOSEcPDFC56dQOv3VepzidpfM7WsuX8+ZPfSr85hxOWURluw/+oaR4/FcSl3al+KLwK0LKkiWdVNxVzhjVFJgE9mid5X+W/9rmb4Z3MQKSHHCHg3G3qjsemYX8z0GuTA+mnXgP6pU94DAfKYRuOWAo4CQo3PMeJrRhptA96Kg1mpA2WmriNyX9+o27r0mwTqOvGCNC+VxkOB43lEUndBsoskwQEpNIlGffI4C+FRG19fzVVATeyPKn+vxsZ1WYefn7Km9r8094BoA3MK3icegUb8XCS4SLZIbJAG2vgfVVDxvsObeQX1aldjZArPWbYTYEdWyukIcaKgwSsTuPDP7nObtElVg/o4lE27h6g44Whn/O77VBIcF7X77j52rEYV1oA+3ZfU9b1TVKQgb5Ac1JunMZGYYwQK2YD8lUOMKfSFqEP6sI8O61H0EzqCsWA1eL+J2jGQ15VwHxXy5HIPLAGTS4NBJtsZoXdC8nix6+ob8tlPwhsMrC6dvBMXbKuHkfb7CxUGDTU1b9IDlC5GlC0XpMJEF0CM6FmGfAcsZ7cIokSdy7dRZcYJdyKXlPNMixis/TcuKwKXl5MQrhRk/TmnoUEueLvpS06tefeqOgPZUf//aARZMnRG/f3G2V2zIkF/YD9k/lop3vbY7RxXKYaRE4joAI9v1amNSANfW6pEuiQDeW2Y1tnlGha+4fRzs1sRLcW7oReFCCDVdE3Nsx+h9PPhR8dDTIXEQaajwB75xzm1YRyrdSDhPCo5JhLNxVTGcIh+ggWrKA4DkAGA3PCvtAk4aS4GGFup16iV9eOssqJ1DMBeOnHRD4tKrCLxJmFLvtgS5v76WqgUC5nsddsWXiN/kb/AueujxZPdZDNHFE+U6IuItb0LyFW8meRoP5E/k1UtP32uuze6Zi0IuxMq0TzqYGWc7cUb2Xo52h0ojS3rD83hL/KRLoQXB4yGGwWIl6y8miPMgtxtLIXGsudfLxBYVztY7f+sAeEEAhmcFnRGCtcqDti75CeJxWm85zu54ruWxXYDKI6ZPceylY6x6jlwR/UpMVCycmjjz7CmObuI9tOBZg8o6VOmMNboxSPgoQVXWISrx6b/AMa8wlygjHc228zTjw+tUZETQoUsPAAkErLn4N0tC+R6pAUWsylYXEujKQdek+H8f7ZkToRS4G2ku1CtSOARoWh2neM7KGp7wfjprgvd+fdCS0O8KJBF1i3XczoPVdMd7zf7PmcRj1r+PdWoqSrE/IcyiEk5h35uzHP4HJcsScDSB4+2nDos+O/AhxP1cC4p18yYGjpjLzCU= X-Microsoft-Antispam-Message-Info: i2n+0c1FtE8KP9DnC4yJluH3GmC/4P+fVxQ2/ffcEWkyF7TOZAJef2+zse7T7p2A2IAhlrkmqCA3I5jC3o5XcyC/HA81NAQtc1KGb7TOYxRNB2/SkJMl5oXrm5cHrncC9/FpJO9xbsxWrp+qxVRFUNwBmSmZxe8EnjOhar8N0lWQM/OXLb3RZXKr3dbapfBGAHBSFv31kycZrkOXgm0pXocS2KBsJvjrFA+z0d+DlSvF1AQjiUjFL5tSiTeOEr5SJoRGwy+kYNcj+E+uDFK9LFBsIv64EQVZ8Pnw11kjgFuua0Y+9HWgJ0vwExqXBu8FaywY5JchFnNQekQOt381W/NAdY7XpCYKI3i3NA068vs= X-Microsoft-Exchange-Diagnostics: 1; MWHPR0701MB3641; 6:fAR3pbTc7eFxb9cIjobbML6B/oOmMWKHld5gJVLkwUqXiPfI8RYhu63HsEcQS/KMzu31hrqwVDrDqeaoEtuB3Z+H3bIc+LTw0at8W7qyDQJXMQvbtV3VG8310ExD/CUWUh4UwMTVngl27YTRvsO9e5q0wFWULK26+jQQtq5CY13EorT0DPxgG3Uy4HVz8TIrijB4OFCxk73teeT0+D+uSn8esDpkGLe/uf4+THV5dR7ubmb/ptoJikl9SwuND8i8/QTqLrAgR90x8KwsXKW5/1AJED09ieT2SPGzhSR/2DM6saOLQWEuUbPSz46W0wfaYjD/7+yQXPrC+8ecasNQzEhzqgOtGimpSLtLHuDH6YNiXqeMuyf24Pn4/TKcP1iTNTPeCe1/PBfdqr8AMl5bFkWqXak3PYKZ1wvoqKrdgwG/qbvNRZ9W8maAva7JOz3poNlJ7Koum2Xfl91l1fjejQ==; 5:i8kMbzlucufM6751+L7suQumtaKIHcFCcLANC7dZHa1l0eleZquDLraPPexSujiAwve6BGF2aQCc1NIo+CuIi7/t9IJCaYgVbo0FywlVfQ+oujFtW6RLbgHG1dRL6loceZCeXJKPPNh2rHn0bjcIaXu4AMi73edUlCN7yGLLfhU=; 7:8ObhGErUtix6MhLWGmgBiVCtfaGIyDqNJ14cokRr/3tYWzJwEzGfkiVNmcBEnLPMA3aUI8K5cSuupHrGgCOHF6Ipirf7ReX6M23W/dXzLcLEkrjt/8SQ56/jiA1J++tvl9gVBGm5xsbJl3RK92bv9Dxt4hpgAk2K38yhky8rjPOicjd8ezSXnVqpppILxUxis8Jy/lzJ0w4ADjyuPVSSIbQqpj0B4bJ7JKClmsIsnN09SiGn/Z0yeegfNvyGd1ES SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-OriginatorOrg: caviumnetworks.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 23 Jul 2018 14:51:55.1812 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 38e31763-f4fb-4450-ef07-08d5f0abd685 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 5/5] doc: add ZLIB PMD guide X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Sender: "dev" Add zlib pmd feature support and user guide with build and run instructions Signed-off-by: Sunila Sahu Signed-off-by: Shally Verma Signed-off-by: Ashish Gupta --- MAINTAINERS | 2 + doc/guides/compressdevs/features/zlib.ini | 11 +++++ doc/guides/compressdevs/index.rst | 1 + doc/guides/compressdevs/zlib.rst | 69 +++++++++++++++++++++++++++++++ 4 files changed, 83 insertions(+) diff --git a/MAINTAINERS b/MAINTAINERS index ca27c6f..7e3c450 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -875,6 +875,8 @@ F: drivers/common/qat/ ZLIB M: Sunila Sahu F: drivers/compress/zlib/ +F: doc/guides/compressdevs/zlib.rst +F: doc/guides/compressdevs/features/zlib.ini Eventdev Drivers ---------------- diff --git a/doc/guides/compressdevs/features/zlib.ini b/doc/guides/compressdevs/features/zlib.ini new file mode 100644 index 0000000..c794643 --- /dev/null +++ b/doc/guides/compressdevs/features/zlib.ini @@ -0,0 +1,11 @@ +; +; Refer to default.ini for the full list of available PMD features. +; +; Supported features of 'ZLIB' compression driver. +; +[Features] +Pass-through = Y +Deflate = Y +Fixed = Y +Dynamic = Y +OOP SGL In SGL Out = Y diff --git a/doc/guides/compressdevs/index.rst b/doc/guides/compressdevs/index.rst index 4228768..6ba6641 100644 --- a/doc/guides/compressdevs/index.rst +++ b/doc/guides/compressdevs/index.rst @@ -12,3 +12,4 @@ Compression Device Drivers overview isal qat_comp + zlib diff --git a/doc/guides/compressdevs/zlib.rst b/doc/guides/compressdevs/zlib.rst new file mode 100644 index 0000000..c020792 --- /dev/null +++ b/doc/guides/compressdevs/zlib.rst @@ -0,0 +1,69 @@ +.. SPDX-License-Identifier: BSD-3-Clause + Copyright(c) 2018 Cavium Networks. + +ZLIB Compression Poll Mode Driver +================================== + +The ZLIB PMD (**librte_pmd_zlib**) provides poll mode compression & +decompression driver based on SW zlib library, + +Features +-------- + +ZLIB PMD has support for: + +Compression/Decompression algorithm: + +* DEFLATE + +Huffman code type: + +* FIXED +* DYNAMIC + +Window size support: + +* Min - 256 bytes +* Max - 32K + +Limitations +----------- + +* Stateful not supported. + +Installation +------------ + +* To build DPDK with ZLIB library, the user is required to download the ``libz`` library. +* Use following command for installation. + +* For Fedora users:: + sudo yum install zlib-devel +* For Ubuntu users:: + sudo apt-get install zlib1g-dev + +* Once downloaded, the user needs to build the library. + +* To build from sources + download zlib sources from http://zlib.net/ and do following before building DPDK:: + + make + sudo make install + +Initialization +-------------- + +In order to enable this virtual compression PMD, user must: + +* Set ``CONFIG_RTE_LIBRTE_PMD_ZLIB=y`` in config/common_base. + +To use the PMD in an application, user must: + +* Call ``rte_vdev_init("compress_zlib")`` within the application. + +* Use ``--vdev="compress_zlib"`` in the EAL options, which will call ``rte_vdev_init()`` internally. + +The following parameter (optional) can be provided in the previous two calls: + +* ``socket_id:`` Specify the socket where the memory for the device is going to be allocated + (by default, socket_id will be the socket where the core that is creating the PMD is running on).