Patch Detail
get:
Show a patch.
patch:
Update a patch.
put:
Update a patch.
GET /api/patches/65043/?format=api
http://patchwork.dpdk.org/api/patches/65043/?format=api", "web_url": "http://patchwork.dpdk.org/project/dpdk/patch/56b43c8675246d3d66ea761b97f6dff8f8417390.1579703134.git.dekelp@mellanox.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": "<56b43c8675246d3d66ea761b97f6dff8f8417390.1579703134.git.dekelp@mellanox.com>", "list_archive_url": "https://inbox.dpdk.org/dev/56b43c8675246d3d66ea761b97f6dff8f8417390.1579703134.git.dekelp@mellanox.com", "date": "2020-01-22T14:27:21", "name": "[09/11] net/mlx5: fix the set VLAN VID action validation", "commit_ref": null, "pull_url": null, "state": "accepted", "archived": true, "hash": "59244939c0181fc1217a9d25eea3f5df8945f908", "submitter": { "id": 1082, "url": "http://patchwork.dpdk.org/api/people/1082/?format=api", "name": "Dekel Peled", "email": "dekelp@mellanox.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/56b43c8675246d3d66ea761b97f6dff8f8417390.1579703134.git.dekelp@mellanox.com/mbox/", "series": [ { "id": 8260, "url": "http://patchwork.dpdk.org/api/series/8260/?format=api", "web_url": "http://patchwork.dpdk.org/project/dpdk/list/?series=8260", "date": "2020-01-22T14:27:13", "name": "net/mlx5: vlan actions validation fixes", "version": 1, "mbox": "http://patchwork.dpdk.org/series/8260/mbox/" } ], "comments": "http://patchwork.dpdk.org/api/patches/65043/comments/", "check": "success", "checks": "http://patchwork.dpdk.org/api/patches/65043/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 dpdk.org (dpdk.org [92.243.14.124])\n\tby inbox.dpdk.org (Postfix) with ESMTP id B8083A0530;\n\tWed, 22 Jan 2020 15:31:32 +0100 (CET)", "from [92.243.14.124] (localhost [127.0.0.1])\n\tby dpdk.org (Postfix) with ESMTP id 690451BEA9;\n\tWed, 22 Jan 2020 15:30:18 +0100 (CET)", "from mellanox.co.il (mail-il-dmz.mellanox.com [193.47.165.129])\n by dpdk.org (Postfix) with ESMTP id 582993576\n for <dev@dpdk.org>; Wed, 22 Jan 2020 15:30:04 +0100 (CET)", "from Internal Mail-Server by MTLPINE1 (envelope-from\n dekelp@mellanox.com)\n with ESMTPS (AES256-SHA encrypted); 22 Jan 2020 16:30:02 +0200", "from mtl-vdi-280.wap.labs.mlnx. (mtl-vdi-280.wap.labs.mlnx\n [10.128.130.87])\n by labmailer.mlnx (8.13.8/8.13.8) with ESMTP id 00METnL7010555;\n Wed, 22 Jan 2020 16:30:02 +0200" ], "From": "Dekel Peled <dekelp@mellanox.com>", "To": "matan@mellanox.com, viacheslavo@mellanox.com", "Cc": "rasland@mellanox.com, orika@mellanox.com, dev@dpdk.org, stable@dpdk.org", "Date": "Wed, 22 Jan 2020 16:27:21 +0200", "Message-Id": "\n <56b43c8675246d3d66ea761b97f6dff8f8417390.1579703134.git.dekelp@mellanox.com>", "X-Mailer": "git-send-email 1.7.1", "In-Reply-To": "<cover.1579703134.git.dekelp@mellanox.com>", "References": "<cover.1579703134.git.dekelp@mellanox.com>", "Subject": "[dpdk-dev] [PATCH 09/11] net/mlx5: fix the set VLAN VID action\n\tvalidation", "X-BeenThere": "dev@dpdk.org", "X-Mailman-Version": "2.1.15", "Precedence": "list", "List-Id": "DPDK patches and discussions <dev.dpdk.org>", "List-Unsubscribe": "<https://mails.dpdk.org/options/dev>,\n <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", "Sender": "\"dev\" <dev-bounces@dpdk.org>" }, "content": "Validation function of 'set VLAN VID' action checks twice for existing\nsame action in flow rule.\n\nThis patch updates the validation function logic, to check the same\nrestrictions more efficiently.\n\nFixes: 5f163d520cff (\"net/mlx5: support modify VLAN ID on existing VLAN header\")\nFixes: b8c0372bc5ac (\"net/mlx5: fix set VLAN ID/PCP in new header\")\nCc: stable@dpdk.org\n\nSigned-off-by: Dekel Peled <dekelp@mellanox.com>\nAcked-by: Ori Kam <orika@mellanox.com>\n---\n drivers/net/mlx5/mlx5_flow_dv.c | 32 ++++++++------------------------\n 1 file changed, 8 insertions(+), 24 deletions(-)", "diff": "diff --git a/drivers/net/mlx5/mlx5_flow_dv.c b/drivers/net/mlx5/mlx5_flow_dv.c\nindex de4b765..4b6a92c 100644\n--- a/drivers/net/mlx5/mlx5_flow_dv.c\n+++ b/drivers/net/mlx5/mlx5_flow_dv.c\n@@ -1815,10 +1815,10 @@ struct field_modify_info modify_tcp[] = {\n *\n * @param[in] item_flags\n * Holds the items detected in this rule.\n+ * @param[in] action_flags\n+ * Holds the actions detected until now.\n * @param[in] actions\n * Pointer to the list of actions remaining in the flow rule.\n- * @param[in] attr\n- * Pointer to flow attributes\n * @param[out] error\n * Pointer to error structure.\n *\n@@ -1838,33 +1838,17 @@ struct field_modify_info modify_tcp[] = {\n \t\treturn rte_flow_error_set(error, EINVAL,\n \t\t\t\t\t RTE_FLOW_ERROR_TYPE_ACTION, action,\n \t\t\t\t\t \"VLAN VID value is too big\");\n-\t/* there is an of_push_vlan action before us */\n-\tif (action_flags & MLX5_FLOW_ACTION_OF_PUSH_VLAN) {\n-\t\tif (mlx5_flow_find_action(actions + 1,\n-\t\t\t\t\t RTE_FLOW_ACTION_TYPE_OF_SET_VLAN_VID))\n-\t\t\treturn rte_flow_error_set(error, ENOTSUP,\n-\t\t\t\t\tRTE_FLOW_ERROR_TYPE_ACTION, action,\n-\t\t\t\t\t\"Multiple VLAN VID modifications are \"\n-\t\t\t\t\t\"not supported\");\n-\t\telse\n-\t\t\treturn 0;\n-\t}\n-\n-\t/*\n-\t * Action is on an existing VLAN header:\n-\t * Need to verify this is a single modify CID action.\n-\t * Rule mast include a match on outer VLAN.\n-\t */\n+\tif (!(action_flags & MLX5_FLOW_ACTION_OF_PUSH_VLAN) &&\n+\t !(item_flags & MLX5_FLOW_LAYER_OUTER_VLAN))\n+\t\treturn rte_flow_error_set(error, ENOTSUP,\n+\t\t\t\t\t RTE_FLOW_ERROR_TYPE_ACTION, action,\n+\t\t\t\t\t \"set VLAN VID action must follow push\"\n+\t\t\t\t\t \" VLAN action or match on VLAN item\");\n \tif (action_flags & MLX5_FLOW_ACTION_OF_SET_VLAN_VID)\n \t\treturn rte_flow_error_set(error, ENOTSUP,\n \t\t\t\t\t RTE_FLOW_ERROR_TYPE_ACTION, action,\n \t\t\t\t\t \"Multiple VLAN VID modifications are \"\n \t\t\t\t\t \"not supported\");\n-\tif (!(item_flags & MLX5_FLOW_LAYER_OUTER_VLAN))\n-\t\treturn rte_flow_error_set(error, EINVAL,\n-\t\t\t\t\t RTE_FLOW_ERROR_TYPE_ACTION, action,\n-\t\t\t\t\t \"match on VLAN is required in order \"\n-\t\t\t\t\t \"to set VLAN VID\");\n \tif (action_flags & MLX5_FLOW_ACTION_PORT_ID)\n \t\treturn rte_flow_error_set(error, EINVAL,\n \t\t\t\t\t RTE_FLOW_ERROR_TYPE_ACTION, action,\n", "prefixes": [ "09/11" ] }{ "id": 65043, "url": "