get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

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

{
    "id": 129257,
    "url": "http://patchwork.dpdk.org/api/patches/129257/?format=api",
    "web_url": "http://patchwork.dpdk.org/project/dpdk/patch/20230704160454.4187-5-igozlan@nvidia.com/",
    "project": {
        "id": 1,
        "url": "http://patchwork.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": "<20230704160454.4187-5-igozlan@nvidia.com>",
    "list_archive_url": "https://inbox.dpdk.org/dev/20230704160454.4187-5-igozlan@nvidia.com",
    "date": "2023-07-04T16:04:53",
    "name": "[v3,5/5] net/mlx5/hws: support default miss action on FDB",
    "commit_ref": null,
    "pull_url": null,
    "state": "accepted",
    "archived": true,
    "hash": "e9dd28fc19bd9672151bb5a892c9276939621055",
    "submitter": {
        "id": 3118,
        "url": "http://patchwork.dpdk.org/api/people/3118/?format=api",
        "name": "Itamar Gozlan",
        "email": "igozlan@nvidia.com"
    },
    "delegate": {
        "id": 3268,
        "url": "http://patchwork.dpdk.org/api/users/3268/?format=api",
        "username": "rasland",
        "first_name": "Raslan",
        "last_name": "Darawsheh",
        "email": "rasland@nvidia.com"
    },
    "mbox": "http://patchwork.dpdk.org/project/dpdk/patch/20230704160454.4187-5-igozlan@nvidia.com/mbox/",
    "series": [
        {
            "id": 28810,
            "url": "http://patchwork.dpdk.org/api/series/28810/?format=api",
            "web_url": "http://patchwork.dpdk.org/project/dpdk/list/?series=28810",
            "date": "2023-07-04T16:04:49",
            "name": "[v3,1/5] net/mlx5/hws: remove unneeded new line for DR_LOG",
            "version": 3,
            "mbox": "http://patchwork.dpdk.org/series/28810/mbox/"
        }
    ],
    "comments": "http://patchwork.dpdk.org/api/patches/129257/comments/",
    "check": "success",
    "checks": "http://patchwork.dpdk.org/api/patches/129257/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 6698D42DAE;\n\tTue,  4 Jul 2023 18:06:38 +0200 (CEST)",
            "from mails.dpdk.org (localhost [127.0.0.1])\n\tby mails.dpdk.org (Postfix) with ESMTP id B16B242C54;\n\tTue,  4 Jul 2023 18:06:34 +0200 (CEST)",
            "from NAM12-MW2-obe.outbound.protection.outlook.com\n (mail-mw2nam12on2068.outbound.protection.outlook.com [40.107.244.68])\n by mails.dpdk.org (Postfix) with ESMTP id 6A87542D31\n for <dev@dpdk.org>; Tue,  4 Jul 2023 18:06:32 +0200 (CEST)",
            "from DS7PR03CA0173.namprd03.prod.outlook.com (2603:10b6:5:3b2::28)\n by DS7PR12MB5981.namprd12.prod.outlook.com (2603:10b6:8:7c::18) with\n Microsoft SMTP Server (version=TLS1_2,\n cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6544.24; Tue, 4 Jul\n 2023 16:06:30 +0000",
            "from DM6NAM11FT077.eop-nam11.prod.protection.outlook.com\n (2603:10b6:5:3b2:cafe::ba) by DS7PR03CA0173.outlook.office365.com\n (2603:10b6:5:3b2::28) with Microsoft SMTP Server (version=TLS1_2,\n cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6565.18 via Frontend\n Transport; Tue, 4 Jul 2023 16:06:30 +0000",
            "from mail.nvidia.com (216.228.117.160) by\n DM6NAM11FT077.mail.protection.outlook.com (10.13.173.147) with Microsoft SMTP\n Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id\n 15.20.6521.44 via Frontend Transport; Tue, 4 Jul 2023 16:06:30 +0000",
            "from rnnvmail201.nvidia.com (10.129.68.8) 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.5; Tue, 4 Jul 2023\n 09:06:20 -0700",
            "from rnnvmail201.nvidia.com (10.129.68.8) by rnnvmail201.nvidia.com\n (10.129.68.8) with Microsoft SMTP Server (version=TLS1_2,\n cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.37; Tue, 4 Jul 2023\n 09:06:20 -0700",
            "from nvidia.com (10.127.8.12) by mail.nvidia.com (10.129.68.8) with\n Microsoft SMTP Server (version=TLS1_2,\n cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.37 via Frontend\n Transport; Tue, 4 Jul 2023 09:06:18 -0700"
        ],
        "ARC-Seal": "i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none;\n b=PG6mP4k526y15In7rpg0v8VM7Z2kjBRMpssVS39+5mN90so9wps1c8lceidJfsz+jqFfemPW+qMDOcoKJ2sjXeXrta1hTpm6J1f7hOwe0+/0eeCVz7EsuHdvL5Qtz0AWHQjtFXDidB+CfzB3ijWbgfGQiLp36xnyv72XmXPLWZvuQKCXpeKfUySETf0X+ko2cfEhW/r/0m/xQD46rvjKWX131JeHyTj7zeuGW8aUDQ06Z5I14X8IrR5n/ExYPUaUQoNVHVDOSj3yUmBe1KvDom3dA+XZUsRb5iUPZmAdBCBhl1MYobzeOh9Ce34l/2pg64nndt5pihTy4eZszSp63Q==",
        "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=+VoFDzi8ASKM6OvldCv5dyKY3OEw7zHyhhYx6lchfJ0=;\n b=KBAnVtvf8K1L2/HmrycFblvnNyR2dNrvmBNgj1Mm6RMIQ427ytgWWlG4Vx2kZ63YkpxCeHOrwQYgwTvgw4LlL7aB+5OoiFvIG0dkXPxDbN/KNfhmw+IQLJgyejGzoylEmXAs4bJqa2Ey67pSGG4KTvzoI6+ZATpUTOLPPN2wIqFqHjK7D9lTsjYrapv6B0RxhPCY3fsPgrr7cIePfrYskoe5vRyvlWZ9rNSWKHO7Jowk1hbyeV9EI6lBwjMWRuZpfL2GXUuUNUwemnpl0ujlXmOONPItBApizRWhCbOplk2wQQ+oNyIyORY5MiXcpUSmpKZN7xT8yVHtfex/tO6luQ==",
        "ARC-Authentication-Results": "i=1; mx.microsoft.com 1; spf=pass (sender ip is\n 216.228.117.160) smtp.rcpttodomain=monjalon.net 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=+VoFDzi8ASKM6OvldCv5dyKY3OEw7zHyhhYx6lchfJ0=;\n b=S/WHwkX7KA5umhhPLReuyM9tkK/mRZbijwzV38loQR+4fao2R27Sg2zzNhaBLxe0ovNAJuJROx1giFtija1khRXAg0sTANjtt1w/LmNKFmv52sukN9L4sJwgvBrv0eQcIbZGTHq43eaawUdG3Ec9+SYc0CLjWHha6017dog0tJ7q8PVR+jCvYxOO/nL3dgn0XBvLaK1wHTlIiucmsdtzmp57ovsiNT2zVHwwfYC9kjG5YJH1uKIf9iqSN/+bwIEYzhKXqEzDtKA6uJXcxTgX97z5uEqegQ5RyCeoyea3iJHF/LQjM6L6E+I9KCVJMM0WBBDOPygBUiw60uFoKh9mhQ==",
        "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": "Itamar Gozlan <igozlan@nvidia.com>",
        "To": "<valex@nvidia.com>, <viacheslavo@nvidia.com>, <matan@nvidia.com>,\n <thomas@monjalon.net>, <suanmingm@nvidia.com>, Ori Kam <orika@nvidia.com>",
        "CC": "<dev@dpdk.org>",
        "Subject": "[v3 5/5] net/mlx5/hws: support default miss action on FDB",
        "Date": "Tue, 4 Jul 2023 19:04:53 +0300",
        "Message-ID": "<20230704160454.4187-5-igozlan@nvidia.com>",
        "X-Mailer": "git-send-email 2.18.1",
        "In-Reply-To": "<20230704160454.4187-1-igozlan@nvidia.com>",
        "References": "<20230704104645.19800-5-igozlan@nvidia.com>\n <20230704160454.4187-1-igozlan@nvidia.com>",
        "MIME-Version": "1.0",
        "Content-Type": "text/plain",
        "X-NV-OnPremToCloud": "ExternallySecured",
        "X-EOPAttributedMessage": "0",
        "X-MS-PublicTrafficType": "Email",
        "X-MS-TrafficTypeDiagnostic": "DM6NAM11FT077:EE_|DS7PR12MB5981:EE_",
        "X-MS-Office365-Filtering-Correlation-Id": "db8049c8-a888-4ff4-ca0e-08db7ca8a130",
        "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 /+b+dAh0bkfz4jDGkfg3XTkXlyHmqMgNQffoyCO75NvNZz9XX5oQvq1whGidoMwGnBKBdSVhNTQ8JKsEOEEiGtSDeXBHRf6T6Zpj5XoAkaxvE/DECIb1z0CUOfLkQN1Zsw51nO7OQiqX3AubH216e5v6B6FFpw+xp78WIBPxow7Tdk3f3Djw9XnV/NhL1Ai7oRMMlpuI5aOqJV+dX46vXmnncGBfmUJo7vQgATQSNnVqwqFz62OEWZPYVloKqowCBSKjmrlpL3kfyFnJ61XXeK0DvOZN8zh5fr0T4dKRIVYYUUsT5zwC7XdWBEGqc7YycJ/ackk3MzKyDLhMKNU3W3qAaWV8rFwmAkpYHu9YHLsRv4MkUVri/qIpekii5ZQnuDBPRGkZk9p4nbviFeAMJfHFqohDfGF0yW4mM0mrpWGt1+zVvtgUV7RY++Q+B9MMl5w3iDzAxrrMzHABfS48A86k6P5t9ZS6bukD/BKgH51sze6HL5k7f759ksuxocOhhFlgpXfMUIaoar6sO/R/XciGtS0eAjP+PJVgcJMi5qxFW4KL/gkXn5dkpWU6ZQsuR8OeudYcSqITH/NJcba6QlkfZSkevmZz7N38pQL2+ufi7RAK6LOHO8qGkmYVsMqtgG+zlNeTSVb/6CwD1wRE+LvYtwgcsbai08ZOupVOtx4TnvLjNFuwpS+SfLL/0DtN+eSwBZSIeMWO+F8oeKD0Muehf8YaDE5fpbHhfLCTd9VIP9gDO4IVUohutEqzZ3mT",
        "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:(13230028)(4636009)(39860400002)(136003)(346002)(396003)(376002)(451199021)(46966006)(40470700004)(36840700001)(8676002)(110136005)(8936002)(478600001)(26005)(6666004)(41300700001)(36756003)(5660300002)(2906002)(7696005)(86362001)(4326008)(316002)(40460700003)(55016003)(6636002)(70206006)(70586007)(82740400003)(7636003)(40480700001)(356005)(47076005)(2616005)(6286002)(186003)(83380400001)(82310400005)(336012)(426003)(1076003)(36860700001);\n DIR:OUT; SFP:1101;",
        "X-OriginatorOrg": "Nvidia.com",
        "X-MS-Exchange-CrossTenant-OriginalArrivalTime": "04 Jul 2023 16:06:30.2173 (UTC)",
        "X-MS-Exchange-CrossTenant-Network-Message-Id": "\n db8049c8-a888-4ff4-ca0e-08db7ca8a130",
        "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 DM6NAM11FT077.eop-nam11.prod.protection.outlook.com",
        "X-MS-Exchange-CrossTenant-AuthAs": "Anonymous",
        "X-MS-Exchange-CrossTenant-FromEntityHeader": "HybridOnPrem",
        "X-MS-Exchange-Transport-CrossTenantHeadersStamped": "DS7PR12MB5981",
        "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": "From: Alex Vesker <valex@nvidia.com>\n\nAdd the support for default miss on HWS FDB, this implementation\nwas missing until now. Default miss can be used for more efficient\nmiss flow instead of going to an empty matcher or some defecated\nempty table.\n\nSigned-off-by: Alex Vesker <valex@nvidia.com>\nAcked-by: Matan Azrad <matan@nvidia.com>\n---\n drivers/net/mlx5/hws/mlx5dr_action.c | 27 ++++++++++++++++++++-------\n drivers/net/mlx5/hws/mlx5dr_table.c  |  6 +-----\n 2 files changed, 21 insertions(+), 12 deletions(-)",
    "diff": "diff --git a/drivers/net/mlx5/hws/mlx5dr_action.c b/drivers/net/mlx5/hws/mlx5dr_action.c\nindex 74f4e60863..920099ba5b 100644\n--- a/drivers/net/mlx5/hws/mlx5dr_action.c\n+++ b/drivers/net/mlx5/hws/mlx5dr_action.c\n@@ -322,10 +322,12 @@ int mlx5dr_action_root_build_attr(struct mlx5dr_rule_action rule_actions[],\n \treturn 0;\n }\n \n-static bool mlx5dr_action_fixup_stc_attr(struct mlx5dr_cmd_stc_modify_attr *stc_attr,\n-\t\t\t\t\t struct mlx5dr_cmd_stc_modify_attr *fixup_stc_attr,\n-\t\t\t\t\t enum mlx5dr_table_type table_type,\n-\t\t\t\t\t bool is_mirror)\n+static bool\n+mlx5dr_action_fixup_stc_attr(struct mlx5dr_context *ctx,\n+\t\t\t     struct mlx5dr_cmd_stc_modify_attr *stc_attr,\n+\t\t\t     struct mlx5dr_cmd_stc_modify_attr *fixup_stc_attr,\n+\t\t\t     enum mlx5dr_table_type table_type,\n+\t\t\t     bool is_mirror)\n {\n \tstruct mlx5dr_devx_obj *devx_obj;\n \tbool use_fixup = false;\n@@ -348,6 +350,17 @@ static bool mlx5dr_action_fixup_stc_attr(struct mlx5dr_cmd_stc_modify_attr *stc_\n \t\tuse_fixup = true;\n \t\tbreak;\n \n+\tcase MLX5_IFC_STC_ACTION_TYPE_ALLOW:\n+\t\tif (fw_tbl_type == FS_FT_FDB_TX || fw_tbl_type == FS_FT_FDB_RX) {\n+\t\t\tfixup_stc_attr->action_type = MLX5_IFC_STC_ACTION_TYPE_JUMP_TO_VPORT;\n+\t\t\tfixup_stc_attr->action_offset = stc_attr->action_offset;\n+\t\t\tfixup_stc_attr->stc_offset = stc_attr->stc_offset;\n+\t\t\tfixup_stc_attr->vport.esw_owner_vhca_id = ctx->caps->vhca_id;\n+\t\t\tfixup_stc_attr->vport.vport_num = ctx->caps->eswitch_manager_vport_number;\n+\t\t\tuse_fixup = true;\n+\t\t}\n+\t\tbreak;\n+\n \tcase MLX5_IFC_STC_ACTION_TYPE_JUMP_TO_VPORT:\n \t\tif (stc_attr->vport.vport_num != WIRE_PORT)\n \t\t\tbreak;\n@@ -397,7 +410,7 @@ int mlx5dr_action_alloc_single_stc(struct mlx5dr_context *ctx,\n \tdevx_obj_0 = mlx5dr_pool_chunk_get_base_devx_obj(stc_pool, stc);\n \n \t/* According to table/action limitation change the stc_attr */\n-\tuse_fixup = mlx5dr_action_fixup_stc_attr(stc_attr, &fixup_stc_attr, table_type, false);\n+\tuse_fixup = mlx5dr_action_fixup_stc_attr(ctx, stc_attr, &fixup_stc_attr, table_type, false);\n \tret = mlx5dr_cmd_stc_modify(devx_obj_0, use_fixup ? &fixup_stc_attr : stc_attr);\n \tif (ret) {\n \t\tDR_LOG(ERR, \"Failed to modify STC action_type %d tbl_type %d\",\n@@ -411,7 +424,8 @@ int mlx5dr_action_alloc_single_stc(struct mlx5dr_context *ctx,\n \n \t\tdevx_obj_1 = mlx5dr_pool_chunk_get_base_devx_obj_mirror(stc_pool, stc);\n \n-\t\tuse_fixup = mlx5dr_action_fixup_stc_attr(stc_attr, &fixup_stc_attr,\n+\t\tuse_fixup = mlx5dr_action_fixup_stc_attr(ctx, stc_attr,\n+\t\t\t\t\t\t\t &fixup_stc_attr,\n \t\t\t\t\t\t\t table_type, true);\n \t\tret = mlx5dr_cmd_stc_modify(devx_obj_1, use_fixup ? &fixup_stc_attr : stc_attr);\n \t\tif (ret) {\n@@ -491,7 +505,6 @@ static void mlx5dr_action_fill_stc_attr(struct mlx5dr_action *action,\n \tcase MLX5DR_ACTION_TYP_MISS:\n \t\tattr->action_type = MLX5_IFC_STC_ACTION_TYPE_ALLOW;\n \t\tattr->action_offset = MLX5DR_ACTION_OFFSET_HIT;\n-\t\t/* TODO Need to support default miss for FDB */\n \t\tbreak;\n \tcase MLX5DR_ACTION_TYP_CTR:\n \t\tattr->id = obj->id;\ndiff --git a/drivers/net/mlx5/hws/mlx5dr_table.c b/drivers/net/mlx5/hws/mlx5dr_table.c\nindex c18ee7c552..f91f04d924 100644\n--- a/drivers/net/mlx5/hws/mlx5dr_table.c\n+++ b/drivers/net/mlx5/hws/mlx5dr_table.c\n@@ -24,7 +24,6 @@ mlx5dr_table_up_default_fdb_miss_tbl(struct mlx5dr_table *tbl)\n \tstruct mlx5dr_cmd_forward_tbl *default_miss;\n \tstruct mlx5dr_context *ctx = tbl->ctx;\n \tuint8_t tbl_type = tbl->type;\n-\tuint32_t vport;\n \n \tif (tbl->type != MLX5DR_TABLE_TYPE_FDB)\n \t\treturn 0;\n@@ -38,12 +37,9 @@ mlx5dr_table_up_default_fdb_miss_tbl(struct mlx5dr_table *tbl)\n \tft_attr.level = tbl->ctx->caps->fdb_ft.max_level; /* The last level */\n \tft_attr.rtc_valid = false;\n \n-\tassert(ctx->caps->eswitch_manager);\n-\tvport = ctx->caps->eswitch_manager_vport_number;\n-\n \tfte_attr.action_flags = MLX5_FLOW_CONTEXT_ACTION_FWD_DEST;\n \tfte_attr.destination_type = MLX5_FLOW_DESTINATION_TYPE_VPORT;\n-\tfte_attr.destination_id = vport;\n+\tfte_attr.destination_id = ctx->caps->eswitch_manager_vport_number;\n \n \tdefault_miss = mlx5dr_cmd_forward_tbl_create(mlx5dr_context_get_local_ibv(ctx),\n \t\t\t\t\t\t     &ft_attr, &fte_attr);\n",
    "prefixes": [
        "v3",
        "5/5"
    ]
}