get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

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

{
    "id": 122974,
    "url": "http://patches.dpdk.org/api/patches/122974/?format=api",
    "web_url": "http://patches.dpdk.org/project/dpdk/patch/20230202162537.1067595-5-michaelba@nvidia.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": "<20230202162537.1067595-5-michaelba@nvidia.com>",
    "list_archive_url": "https://inbox.dpdk.org/dev/20230202162537.1067595-5-michaelba@nvidia.com",
    "date": "2023-02-02T16:25:33",
    "name": "[v2,4/8] compress/mlx5: support new metadata layout added in BF3",
    "commit_ref": null,
    "pull_url": null,
    "state": "superseded",
    "archived": true,
    "hash": "cf2c9b26566b0698b3e75de6997f190a1d26e839",
    "submitter": {
        "id": 1949,
        "url": "http://patches.dpdk.org/api/people/1949/?format=api",
        "name": "Michael Baum",
        "email": "michaelba@nvidia.com"
    },
    "delegate": {
        "id": 6690,
        "url": "http://patches.dpdk.org/api/users/6690/?format=api",
        "username": "akhil",
        "first_name": "akhil",
        "last_name": "goyal",
        "email": "gakhil@marvell.com"
    },
    "mbox": "http://patches.dpdk.org/project/dpdk/patch/20230202162537.1067595-5-michaelba@nvidia.com/mbox/",
    "series": [
        {
            "id": 26766,
            "url": "http://patches.dpdk.org/api/series/26766/?format=api",
            "web_url": "http://patches.dpdk.org/project/dpdk/list/?series=26766",
            "date": "2023-02-02T16:25:29",
            "name": "compress/mlx5: add LZ4 support",
            "version": 2,
            "mbox": "http://patches.dpdk.org/series/26766/mbox/"
        }
    ],
    "comments": "http://patches.dpdk.org/api/patches/122974/comments/",
    "check": "warning",
    "checks": "http://patches.dpdk.org/api/patches/122974/checks/",
    "tags": {},
    "related": [],
    "headers": {
        "Return-Path": "<dev-bounces@dpdk.org>",
        "X-Original-To": "patchwork@inbox.dpdk.org",
        "Delivered-To": "patchwork@inbox.dpdk.org",
        "Received": [
            "from mails.dpdk.org (mails.dpdk.org [217.70.189.124])\n\tby inbox.dpdk.org (Postfix) with ESMTP id 3C4D941BAE;\n\tThu,  2 Feb 2023 17:26:25 +0100 (CET)",
            "from mails.dpdk.org (localhost [127.0.0.1])\n\tby mails.dpdk.org (Postfix) with ESMTP id 024ED43013;\n\tThu,  2 Feb 2023 17:26:04 +0100 (CET)",
            "from NAM11-CO1-obe.outbound.protection.outlook.com\n (mail-co1nam11on2063.outbound.protection.outlook.com [40.107.220.63])\n by mails.dpdk.org (Postfix) with ESMTP id 8CDB142FEA\n for <dev@dpdk.org>; Thu,  2 Feb 2023 17:26:02 +0100 (CET)",
            "from DM6PR03CA0051.namprd03.prod.outlook.com (2603:10b6:5:100::28)\n by DM4PR12MB7622.namprd12.prod.outlook.com (2603:10b6:8:109::18) with\n Microsoft SMTP Server (version=TLS1_2,\n cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6064.24; Thu, 2 Feb\n 2023 16:26:00 +0000",
            "from DM6NAM11FT052.eop-nam11.prod.protection.outlook.com\n (2603:10b6:5:100:cafe::4c) by DM6PR03CA0051.outlook.office365.com\n (2603:10b6:5:100::28) with Microsoft SMTP Server (version=TLS1_2,\n cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6064.25 via Frontend\n Transport; Thu, 2 Feb 2023 16:26:00 +0000",
            "from mail.nvidia.com (216.228.117.160) by\n DM6NAM11FT052.mail.protection.outlook.com (10.13.172.111) with Microsoft SMTP\n Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id\n 15.20.6064.25 via Frontend Transport; Thu, 2 Feb 2023 16:26:00 +0000",
            "from rnnvmail205.nvidia.com (10.129.68.10) by mail.nvidia.com\n (10.129.200.66) with Microsoft SMTP Server (version=TLS1_2,\n cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.36; Thu, 2 Feb 2023\n 08:25:53 -0800",
            "from rnnvmail205.nvidia.com (10.129.68.10) by rnnvmail205.nvidia.com\n (10.129.68.10) with Microsoft SMTP Server (version=TLS1_2,\n cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.36; Thu, 2 Feb 2023\n 08:25:52 -0800",
            "from nvidia.com (10.127.8.13) by mail.nvidia.com (10.129.68.10) with\n Microsoft SMTP Server (version=TLS1_2,\n cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.36 via Frontend\n Transport; Thu, 2 Feb 2023 08:25:51 -0800"
        ],
        "ARC-Seal": "i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none;\n b=lbLbLmRACMDu6rVH6iM79MeXYTRlcOXmKdQHd5AuGMph+AjMvkAr+MJiqN/qcuvNDFFpZaInATpr8O71p/I4llBkxatOLDB39Ipcg4pQnZZstbIOWlLM4b2TLebnP5uJFurQg1oeqKwexDWKGXeChyaq4/llERK6hm5rp4Fr1EtFdls9uld/eGA8yOOrfUr6bg+RYqW+6jgTyM3YRp8GGGghXscIrVQYjAx6bR8pmVnlgNUAwvFRBrKKXNiylVxdz5ILxyEZhCptyBQVOKcMT3a7mGK0gYhLeKwG9k0CrBOGrm5aKESHyqmxyNGeIYk7N9AjmCgqZQPNrqn3q49sJg==",
        "ARC-Message-Signature": "i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com;\n s=arcselector9901;\n h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1;\n bh=7gnu9wg5g4JgGKE9c7fFcualcOT1mCoy4xsEt0fBJZI=;\n b=dZpEZm2CCfYc2Os/X90M4B7AMz7lEZzEeh+DPyafHt/yJgtOYwjkA/yO0LYoazJ80AZPK9y0eWGdKRohAoYm3nqyaiRVbuDfUkoTBABuU8Z/5HQlxVon00YpVkDGEpaL55ZRBWMsidCR+aQsR0Ma4l+kPXoLLIz9pxYEe9+XjyuXtXq2DnMFW6h9aE9rjMHoyBlnvLHWXcuwE9YdcRjjWXlPkpF43htWn/jEtlyr/dOeenXfuKZRTh6Q5bUyfzvA93z1VEJaDHkTYwr3j1yagdTKbdQQ4LfXqlHTjxpG4dyQ187ELfHB4pb3LgBX/OCM0vQU4e0QfDW13aM6OhIV2g==",
        "ARC-Authentication-Results": "i=1; mx.microsoft.com 1; spf=pass (sender ip is\n 216.228.117.160) smtp.rcpttodomain=dpdk.org smtp.mailfrom=nvidia.com;\n dmarc=pass (p=reject sp=reject pct=100) action=none header.from=nvidia.com;\n dkim=none (message not signed); arc=none",
        "DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed; d=Nvidia.com;\n s=selector2;\n h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck;\n bh=7gnu9wg5g4JgGKE9c7fFcualcOT1mCoy4xsEt0fBJZI=;\n b=TXey6qlDo/U6aoq+axY6BQJlvuQFMpkGGY8K/QPSDpn0DGp2CdJNNG1m6Ndjz30EMPONUTBF9UqoUY/4TZJpaYL8Pd4SKdUyShshIQxt5yS6jyiQjZNQlZrEV9A1kEUf6W3TQ3JV1VIf9cYgCtUKaUe2erGOAgDJPbBDvGvdgd+auS4xCMF7Bxzu+tdmrCsy456QuzcKfn6LlSXX0KXLy6+JXCBcJt6I9on68JhP9Rf4En4dNTPgxsr0g7+Z3hO0km4dSYDzM5aj6A/mTzGw0HJIRDAHWXS3cSvFDB/Ji58hCd6AdZrnJ/NEswpMA9f+nmsUi+/vgceO0xQ3AA1fRg==",
        "X-MS-Exchange-Authentication-Results": "spf=pass (sender IP is 216.228.117.160)\n smtp.mailfrom=nvidia.com;\n dkim=none (message not signed)\n header.d=none;dmarc=pass action=none header.from=nvidia.com;",
        "Received-SPF": "Pass (protection.outlook.com: domain of nvidia.com designates\n 216.228.117.160 as permitted sender) receiver=protection.outlook.com;\n client-ip=216.228.117.160; helo=mail.nvidia.com; pr=C",
        "From": "Michael Baum <michaelba@nvidia.com>",
        "To": "<dev@dpdk.org>",
        "CC": "Matan Azrad <matan@nvidia.com>, Akhil Goyal <gakhil@marvell.com>, \"Thomas\n Monjalon\" <thomas@monjalon.net>",
        "Subject": "[PATCH v2 4/8] compress/mlx5: support new metadata layout added in\n BF3",
        "Date": "Thu, 2 Feb 2023 18:25:33 +0200",
        "Message-ID": "<20230202162537.1067595-5-michaelba@nvidia.com>",
        "X-Mailer": "git-send-email 2.25.1",
        "In-Reply-To": "<20230202162537.1067595-1-michaelba@nvidia.com>",
        "References": "<20230109075838.2508039-1-michaelba@nvidia.com>\n <20230202162537.1067595-1-michaelba@nvidia.com>",
        "MIME-Version": "1.0",
        "Content-Transfer-Encoding": "8bit",
        "Content-Type": "text/plain",
        "X-EOPAttributedMessage": "0",
        "X-MS-PublicTrafficType": "Email",
        "X-MS-TrafficTypeDiagnostic": "DM6NAM11FT052:EE_|DM4PR12MB7622:EE_",
        "X-MS-Office365-Filtering-Correlation-Id": "91d3c478-248d-4810-ff36-08db053a2bd8",
        "X-LD-Processed": "43083d15-7273-40c1-b7db-39efd9ccc17a,ExtAddr",
        "X-MS-Exchange-SenderADCheck": "1",
        "X-MS-Exchange-AntiSpam-Relay": "0",
        "X-Microsoft-Antispam": "BCL:0;",
        "X-Microsoft-Antispam-Message-Info": "\n hIC+Z8RpEwjhcdrOA02PdX66UPRoYBb/BkXwzrJGwqqlPopF0oLFat8aXWogz8uxmqEccYCYwTYuZ14ZSOijqKsFIvrASTKTLivWydvxFa9AESEoY9S6y32SW7izT63AlEyne9tm8/ET61pADdn80LDQx5poRo6La+Hn4CQwZxU5YUu+ukNy1hfWukFpNvkRyVMaqbzq84QxYn7YFDgbrhFRqJbjUHeBInxLdhQ93fk+RoUF8n+mheQBM79efHEUY7DdTsFG4hvpGZm8vIkd8bXVcrc6ddgFqIHJsZF3SablKcSEfMq4KthhkylGtOYKHFfxD34Lhh1Fuq2btXbopIJrlieZyf32/8Yqm9wKWCgh4H5MdWdvx2QPZWYiAhUHRpMSN897LCJPUPWtf+Am3DX0omBsxUIyDXzmuJJ4vqU8eCqhFz0jAcOdL4dlb1xGCctaroWphZNqiliCphw0yO/fiJUBZwzwFTw5uFOVOi9iPajs0w1mpN4eeqtbz+ITTGV1ghTZQZJxkeH/6qgOSNvUi5+xb8+yzl8tCs44tvVQZIRbui6IG6hDXTS1TxzrEymo647l5x65FN37l7Kjf9jCpPGchZxncSyJ2CrBjjWyy3sBYAda42jt3AIURV66CkucMYgSJAxFtxeTT6AkP0HeuAHogBTzAO0K67lpMhq0zKgpCicKeZwbYdAQIqriT8WTMqyy9YEqDAfmwiEbKg==",
        "X-Forefront-Antispam-Report": "CIP:216.228.117.160; CTRY:US; LANG:en; SCL:1;\n SRV:;\n IPV:NLI; SFV:NSPM; H:mail.nvidia.com; PTR:dc6edge1.nvidia.com; CAT:NONE;\n SFS:(13230025)(4636009)(396003)(136003)(39860400002)(346002)(376002)(451199018)(36840700001)(46966006)(40470700004)(336012)(83380400001)(6666004)(2616005)(54906003)(426003)(316002)(36756003)(82310400005)(2906002)(7636003)(82740400003)(36860700001)(1076003)(70586007)(70206006)(6916009)(4326008)(8676002)(7696005)(40460700003)(478600001)(186003)(6286002)(26005)(47076005)(55016003)(40480700001)(5660300002)(86362001)(41300700001)(356005)(8936002);\n DIR:OUT; SFP:1101;",
        "X-OriginatorOrg": "Nvidia.com",
        "X-MS-Exchange-CrossTenant-OriginalArrivalTime": "02 Feb 2023 16:26:00.3534 (UTC)",
        "X-MS-Exchange-CrossTenant-Network-Message-Id": "\n 91d3c478-248d-4810-ff36-08db053a2bd8",
        "X-MS-Exchange-CrossTenant-Id": "43083d15-7273-40c1-b7db-39efd9ccc17a",
        "X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp": "\n TenantId=43083d15-7273-40c1-b7db-39efd9ccc17a; Ip=[216.228.117.160];\n Helo=[mail.nvidia.com]",
        "X-MS-Exchange-CrossTenant-AuthSource": "\n DM6NAM11FT052.eop-nam11.prod.protection.outlook.com",
        "X-MS-Exchange-CrossTenant-AuthAs": "Anonymous",
        "X-MS-Exchange-CrossTenant-FromEntityHeader": "HybridOnPrem",
        "X-MS-Exchange-Transport-CrossTenantHeadersStamped": "DM4PR12MB7622",
        "X-BeenThere": "dev@dpdk.org",
        "X-Mailman-Version": "2.1.29",
        "Precedence": "list",
        "List-Id": "DPDK patches and discussions <dev.dpdk.org>",
        "List-Unsubscribe": "<https://mails.dpdk.org/options/dev>,\n <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 <mailto:dev-request@dpdk.org?subject=subscribe>",
        "Errors-To": "dev-bounces@dpdk.org"
    },
    "content": "Commit [1] add support in Bluefield-3, but Bluefield-3 has different\nGGA opaque structure than Bluefield-2.\n\nThis patch updates the PRM structure to include both versions, and\nculculate the relevant offset for each version in control path.\n\nCommit [1] 559014f232b4 (\"compress/mlx5: add Bluefield-3 device ID\")\n\nSigned-off-by: Michael Baum <michaelba@nvidia.com>\n---\n drivers/common/mlx5/mlx5_devx_cmds.c  |  6 ++--\n drivers/common/mlx5/mlx5_devx_cmds.h  |  3 +-\n drivers/common/mlx5/mlx5_prm.h        | 40 +++++++++++++++---------\n drivers/compress/mlx5/mlx5_compress.c | 45 +++++++++++++++++----------\n 4 files changed, 61 insertions(+), 33 deletions(-)",
    "diff": "diff --git a/drivers/common/mlx5/mlx5_devx_cmds.c b/drivers/common/mlx5/mlx5_devx_cmds.c\nindex 59cebb530f..dfec4dcf1b 100644\n--- a/drivers/common/mlx5/mlx5_devx_cmds.c\n+++ b/drivers/common/mlx5/mlx5_devx_cmds.c\n@@ -978,8 +978,10 @@ mlx5_devx_cmd_query_hca_attr(void *ctx,\n \tattr->mmo_dma_qp_en = MLX5_GET(cmd_hca_cap, hcattr, dma_mmo_qp);\n \tattr->mmo_compress_qp_en = MLX5_GET(cmd_hca_cap, hcattr,\n \t\t\tcompress_mmo_qp);\n-\tattr->mmo_decompress_qp_en = MLX5_GET(cmd_hca_cap, hcattr,\n-\t\t\tdecompress_mmo_qp);\n+\tattr->decomp_deflate_v1_en = MLX5_GET(cmd_hca_cap, hcattr,\n+\t\t\t\t\t      decompress_deflate_v1);\n+\tattr->decomp_deflate_v2_en = MLX5_GET(cmd_hca_cap, hcattr,\n+\t\t\t\t\t      decompress_deflate_v2);\n \tattr->compress_min_block_size = MLX5_GET(cmd_hca_cap, hcattr,\n \t\t\t\t\t\t compress_min_block_size);\n \tattr->log_max_mmo_dma = MLX5_GET(cmd_hca_cap, hcattr, log_dma_mmo_size);\ndiff --git a/drivers/common/mlx5/mlx5_devx_cmds.h b/drivers/common/mlx5/mlx5_devx_cmds.h\nindex c94b9eac06..edb387e272 100644\n--- a/drivers/common/mlx5/mlx5_devx_cmds.h\n+++ b/drivers/common/mlx5/mlx5_devx_cmds.h\n@@ -259,7 +259,8 @@ struct mlx5_hca_attr {\n \tuint32_t mmo_decompress_sq_en:1;\n \tuint32_t mmo_dma_qp_en:1;\n \tuint32_t mmo_compress_qp_en:1;\n-\tuint32_t mmo_decompress_qp_en:1;\n+\tuint32_t decomp_deflate_v1_en:1;\n+\tuint32_t decomp_deflate_v2_en:1;\n \tuint32_t mmo_regex_qp_en:1;\n \tuint32_t mmo_regex_sq_en:1;\n \tuint32_t compress_min_block_size:4;\ndiff --git a/drivers/common/mlx5/mlx5_prm.h b/drivers/common/mlx5/mlx5_prm.h\nindex 2b5c43ee6e..377cbfab87 100644\n--- a/drivers/common/mlx5/mlx5_prm.h\n+++ b/drivers/common/mlx5/mlx5_prm.h\n@@ -607,17 +607,27 @@ struct mlx5_gga_wqe {\n \tstruct mlx5_wqe_dseg scatter;\n } __rte_packed;\n \n-struct mlx5_gga_compress_opaque {\n-\tuint32_t syndrom;\n-\tuint32_t reserved0;\n-\tuint32_t scattered_length;\n-\tuint32_t gathered_length;\n-\tuint64_t scatter_crc;\n-\tuint64_t gather_crc;\n-\tuint32_t crc32;\n-\tuint32_t adler32;\n-\tuint8_t reserved1[216];\n-} __rte_packed;\n+union mlx5_gga_compress_opaque {\n+\tstruct {\n+\t\tuint32_t syndrome;\n+\t\tuint32_t reserved0;\n+\t\tuint32_t scattered_length;\n+\t\tunion {\n+\t\t\tstruct {\n+\t\t\t\tuint32_t reserved1[5];\n+\t\t\t\tuint32_t crc32;\n+\t\t\t\tuint32_t adler32;\n+\t\t\t} v1 __rte_packed;\n+\t\t\tstruct {\n+\t\t\t\tuint32_t crc32;\n+\t\t\t\tuint32_t adler32;\n+\t\t\t\tuint32_t crc32c;\n+\t\t\t\tuint32_t xxh32;\n+\t\t\t} v2 __rte_packed;\n+\t\t};\n+\t} __rte_packed;\n+\tuint32_t data[64];\n+};\n \n struct mlx5_ifc_regexp_mmo_control_bits {\n \tuint8_t reserved_at_31[0x2];\n@@ -1463,7 +1473,7 @@ struct mlx5_ifc_cmd_hca_cap_bits {\n \tu8 log_max_bsf_list_size[0x6];\n \tu8 umr_extended_translation_offset[0x1];\n \tu8 null_mkey[0x1];\n-\tu8 log_max_klm_list_size[0x6];\n+\tu8 log_maxklm_list_size[0x6];\n \tu8 non_wire_sq[0x1];\n \tu8 reserved_at_121[0x9];\n \tu8 log_max_ra_req_dc[0x6];\n@@ -1749,8 +1759,10 @@ struct mlx5_ifc_cmd_hca_cap_bits {\n \tu8 dma_mmo_qp[0x1];\n \tu8 regexp_mmo_qp[0x1];\n \tu8 compress_mmo_qp[0x1];\n-\tu8 decompress_mmo_qp[0x1];\n-\tu8 reserved_at_74c[0x14];\n+\tu8 decompress_deflate_v1[0x1];\n+\tu8 reserved_at_74c[0x4];\n+\tu8 decompress_deflate_v2[0x1];\n+\tu8 reserved_at_751[0xf];\n \tu8 reserved_at_760[0x3];\n \tu8 log_max_num_header_modify_argument[0x5];\n \tu8 log_header_modify_argument_granularity_offset[0x4];\ndiff --git a/drivers/compress/mlx5/mlx5_compress.c b/drivers/compress/mlx5/mlx5_compress.c\nindex c4bf62ed41..11fad72a4f 100644\n--- a/drivers/compress/mlx5/mlx5_compress.c\n+++ b/drivers/compress/mlx5/mlx5_compress.c\n@@ -55,6 +55,7 @@ struct mlx5_compress_priv {\n \tuint32_t mmo_dma_sq:1;\n \tuint32_t mmo_dma_qp:1;\n \tuint32_t log_block_sz;\n+\tuint32_t crc32_opaq_offs;\n };\n \n struct mlx5_compress_qp {\n@@ -157,7 +158,7 @@ mlx5_compress_init_qp(struct mlx5_compress_qp *qp)\n {\n \tvolatile struct mlx5_gga_wqe *restrict wqe =\n \t\t\t\t    (volatile struct mlx5_gga_wqe *)qp->qp.wqes;\n-\tvolatile struct mlx5_gga_compress_opaque *opaq = qp->opaque_mr.addr;\n+\tvolatile union mlx5_gga_compress_opaque *opaq = qp->opaque_mr.addr;\n \tconst uint32_t sq_ds = rte_cpu_to_be_32((qp->qp.qp->id << 8) | 4u);\n \tconst uint32_t flags = RTE_BE32(MLX5_COMP_ALWAYS <<\n \t\t\t\t\tMLX5_COMP_MODE_OFFSET);\n@@ -211,8 +212,8 @@ mlx5_compress_qp_setup(struct rte_compressdev *dev, uint16_t qp_id,\n \t\tgoto err;\n \t}\n \topaq_buf = rte_calloc(__func__, (size_t)1 << log_ops_n,\n-\t\t\t      sizeof(struct mlx5_gga_compress_opaque),\n-\t\t\t      sizeof(struct mlx5_gga_compress_opaque));\n+\t\t\t      sizeof(union mlx5_gga_compress_opaque),\n+\t\t\t      sizeof(union mlx5_gga_compress_opaque));\n \tif (opaq_buf == NULL) {\n \t\tDRV_LOG(ERR, \"Failed to allocate opaque memory.\");\n \t\trte_errno = ENOMEM;\n@@ -225,7 +226,7 @@ mlx5_compress_qp_setup(struct rte_compressdev *dev, uint16_t qp_id,\n \tqp->ops = (struct rte_comp_op **)RTE_ALIGN((uintptr_t)(qp + 1),\n \t\t\t\t\t\t   RTE_CACHE_LINE_SIZE);\n \tif (mlx5_common_verbs_reg_mr(priv->cdev->pd, opaq_buf, qp->entries_n *\n-\t\t\t\t\tsizeof(struct mlx5_gga_compress_opaque),\n+\t\t\t\t\tsizeof(union mlx5_gga_compress_opaque),\n \t\t\t\t\t\t\t &qp->opaque_mr) != 0) {\n \t\trte_free(opaq_buf);\n \t\tDRV_LOG(ERR, \"Failed to register opaque MR.\");\n@@ -544,7 +545,7 @@ mlx5_compress_dump_err_objs(volatile uint32_t *cqe, volatile uint32_t *wqe,\n \t\tDRV_LOG(ERR, \"%08X %08X %08X %08X\", wqe[i], wqe[i + 1],\n \t\t\twqe[i + 2], wqe[i + 3]);\n \tDRV_LOG(ERR, \"\\nError opaq:\");\n-\tfor (i = 0; i < sizeof(struct mlx5_gga_compress_opaque) >> 2; i += 4)\n+\tfor (i = 0; i < sizeof(union mlx5_gga_compress_opaque) >> 2; i += 4)\n \t\tDRV_LOG(ERR, \"%08X %08X %08X %08X\", opaq[i], opaq[i + 1],\n \t\t\topaq[i + 2], opaq[i + 3]);\n }\n@@ -558,7 +559,7 @@ mlx5_compress_cqe_err_handle(struct mlx5_compress_qp *qp,\n \t\t\t\t\t\t\t      &qp->cq.cqes[idx];\n \tvolatile struct mlx5_gga_wqe *wqes = (volatile struct mlx5_gga_wqe *)\n \t\t\t\t\t\t\t\t    qp->qp.wqes;\n-\tvolatile struct mlx5_gga_compress_opaque *opaq = qp->opaque_mr.addr;\n+\tvolatile union mlx5_gga_compress_opaque *opaq = qp->opaque_mr.addr;\n \n \tvolatile uint32_t *synd_word = RTE_PTR_ADD(cqe, MLX5_ERROR_CQE_SYNDROME_OFFSET);\n \tswitch (*synd_word) {\n@@ -575,7 +576,7 @@ mlx5_compress_cqe_err_handle(struct mlx5_compress_qp *qp,\n \top->consumed = 0;\n \top->produced = 0;\n \top->output_chksum = 0;\n-\top->debug_status = rte_be_to_cpu_32(opaq[idx].syndrom) |\n+\top->debug_status = rte_be_to_cpu_32(opaq[idx].syndrome) |\n \t\t\t      ((uint64_t)rte_be_to_cpu_32(cqe->syndrome) << 32);\n \tmlx5_compress_dump_err_objs((volatile uint32_t *)cqe,\n \t\t\t\t (volatile uint32_t *)&wqes[idx],\n@@ -590,13 +591,14 @@ mlx5_compress_dequeue_burst(void *queue_pair, struct rte_comp_op **ops,\n \tstruct mlx5_compress_qp *qp = queue_pair;\n \tvolatile struct mlx5_compress_xform *restrict xform;\n \tvolatile struct mlx5_cqe *restrict cqe;\n-\tvolatile struct mlx5_gga_compress_opaque *opaq = qp->opaque_mr.addr;\n+\tvolatile union mlx5_gga_compress_opaque *opaq = qp->opaque_mr.addr;\n \tstruct rte_comp_op *restrict op;\n \tconst unsigned int cq_size = qp->entries_n;\n \tconst unsigned int mask = cq_size - 1;\n \tuint32_t idx;\n \tuint32_t next_idx = qp->ci & mask;\n \tconst uint16_t max = RTE_MIN((uint16_t)(qp->pi - qp->ci), nb_ops);\n+\tuint32_t crc32_idx = qp->priv->crc32_opaq_offs;\n \tuint16_t i = 0;\n \tint ret;\n \n@@ -629,17 +631,17 @@ mlx5_compress_dequeue_burst(void *queue_pair, struct rte_comp_op **ops,\n \t\t\tswitch (xform->csum_type) {\n \t\t\tcase RTE_COMP_CHECKSUM_CRC32:\n \t\t\t\top->output_chksum = (uint64_t)rte_be_to_cpu_32\n-\t\t\t\t\t\t    (opaq[idx].crc32);\n+\t\t\t\t\t\t    (opaq[idx].data[crc32_idx]);\n \t\t\t\tbreak;\n \t\t\tcase RTE_COMP_CHECKSUM_ADLER32:\n \t\t\t\top->output_chksum = (uint64_t)rte_be_to_cpu_32\n-\t\t\t\t\t\t    (opaq[idx].adler32);\n+\t\t\t\t\t\t(opaq[idx].data[crc32_idx + 1]);\n \t\t\t\tbreak;\n \t\t\tcase RTE_COMP_CHECKSUM_CRC32_ADLER32:\n \t\t\t\top->output_chksum = (uint64_t)rte_be_to_cpu_32\n-\t\t\t\t\t\t\t     (opaq[idx].crc32) |\n+\t\t\t\t\t\t   (opaq[idx].data[crc32_idx]) |\n \t\t\t\t\t\t     ((uint64_t)rte_be_to_cpu_32\n-\t\t\t\t\t\t     (opaq[idx].adler32) << 32);\n+\t\t\t\t\t (opaq[idx].data[crc32_idx + 1]) << 32);\n \t\t\t\tbreak;\n \t\t\tdefault:\n \t\t\t\tbreak;\n@@ -717,15 +719,17 @@ mlx5_compress_dev_probe(struct mlx5_common_device *cdev,\n \t\t.socket_id = cdev->dev->numa_node,\n \t};\n \tconst char *ibdev_name = mlx5_os_get_ctx_device_name(cdev->ctx);\n+\tuint32_t crc32_opaq_offset;\n \n \tif (rte_eal_process_type() != RTE_PROC_PRIMARY) {\n \t\tDRV_LOG(ERR, \"Non-primary process type is not supported.\");\n \t\trte_errno = ENOTSUP;\n \t\treturn -rte_errno;\n \t}\n-\tif (!attr->mmo_decompress_qp_en && !attr->mmo_decompress_sq_en\n-\t\t&& !attr->mmo_compress_qp_en && !attr->mmo_compress_sq_en\n-\t\t&& !attr->mmo_dma_qp_en && !attr->mmo_dma_sq_en) {\n+\tif (!attr->decomp_deflate_v1_en && !attr->decomp_deflate_v2_en &&\n+\t    !attr->mmo_decompress_sq_en && !attr->mmo_compress_qp_en &&\n+\t    !attr->mmo_compress_sq_en && !attr->mmo_dma_qp_en &&\n+\t    !attr->mmo_dma_sq_en) {\n \t\tDRV_LOG(ERR, \"Not enough capabilities to support compress operations, maybe old FW/OFED version?\");\n \t\trte_errno = ENOTSUP;\n \t\treturn -ENOTSUP;\n@@ -746,11 +750,20 @@ mlx5_compress_dev_probe(struct mlx5_common_device *cdev,\n \tpriv = compressdev->data->dev_private;\n \tpriv->log_block_sz = devarg_prms.log_block_sz;\n \tpriv->mmo_decomp_sq = attr->mmo_decompress_sq_en;\n-\tpriv->mmo_decomp_qp = attr->mmo_decompress_qp_en;\n+\tpriv->mmo_decomp_qp =\n+\t\t\tattr->decomp_deflate_v1_en | attr->decomp_deflate_v2_en;\n \tpriv->mmo_comp_sq = attr->mmo_compress_sq_en;\n \tpriv->mmo_comp_qp = attr->mmo_compress_qp_en;\n \tpriv->mmo_dma_sq = attr->mmo_dma_sq_en;\n \tpriv->mmo_dma_qp = attr->mmo_dma_qp_en;\n+\tif (attr->decomp_deflate_v2_en)\n+\t\tcrc32_opaq_offset = offsetof(union mlx5_gga_compress_opaque,\n+\t\t\t\t\t     v2.crc32);\n+\telse\n+\t\tcrc32_opaq_offset = offsetof(union mlx5_gga_compress_opaque,\n+\t\t\t\t\t     v1.crc32);\n+\tMLX5_ASSERT((crc32_opaq_offset % 4) == 0);\n+\tpriv->crc32_opaq_offs = crc32_opaq_offset / 4;\n \tpriv->cdev = cdev;\n \tpriv->compressdev = compressdev;\n \tpriv->min_block_size = attr->compress_min_block_size;\n",
    "prefixes": [
        "v2",
        "4/8"
    ]
}