Patch Detail
get:
Show a patch.
patch:
Update a patch.
put:
Update a patch.
GET /api/patches/136413/?format=api
http://patches.dpdk.org/api/patches/136413/?format=api", "web_url": "http://patches.dpdk.org/project/dpdk/patch/20240206020626.545946-3-suanmingm@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": "<20240206020626.545946-3-suanmingm@nvidia.com>", "list_archive_url": "https://inbox.dpdk.org/dev/20240206020626.545946-3-suanmingm@nvidia.com", "date": "2024-02-06T02:06:23", "name": "[v7,2/4] ethdev: move flow field data structures", "commit_ref": null, "pull_url": null, "state": "accepted", "archived": true, "hash": "5bb4538b4d78d480a69e7b15a6fcf1f7ea7b6c9d", "submitter": { "id": 1887, "url": "http://patches.dpdk.org/api/people/1887/?format=api", "name": "Suanming Mou", "email": "suanmingm@nvidia.com" }, "delegate": { "id": 319, "url": "http://patches.dpdk.org/api/users/319/?format=api", "username": "fyigit", "first_name": "Ferruh", "last_name": "Yigit", "email": "ferruh.yigit@amd.com" }, "mbox": "http://patches.dpdk.org/project/dpdk/patch/20240206020626.545946-3-suanmingm@nvidia.com/mbox/", "series": [ { "id": 31005, "url": "http://patches.dpdk.org/api/series/31005/?format=api", "web_url": "http://patches.dpdk.org/project/dpdk/list/?series=31005", "date": "2024-02-06T02:06:21", "name": "ethdev: add RTE_FLOW_ITEM_TYPE_COMPARE", "version": 7, "mbox": "http://patches.dpdk.org/series/31005/mbox/" } ], "comments": "http://patches.dpdk.org/api/patches/136413/comments/", "check": "success", "checks": "http://patches.dpdk.org/api/patches/136413/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 0EEE743A94;\n\tTue, 6 Feb 2024 03:07:08 +0100 (CET)", "from mails.dpdk.org (localhost [127.0.0.1])\n\tby mails.dpdk.org (Postfix) with ESMTP id 8191E40ECF;\n\tTue, 6 Feb 2024 03:07:00 +0100 (CET)", "from NAM10-BN7-obe.outbound.protection.outlook.com\n (mail-bn7nam10on2058.outbound.protection.outlook.com [40.107.92.58])\n by mails.dpdk.org (Postfix) with ESMTP id C93EB40E7C\n for <dev@dpdk.org>; Tue, 6 Feb 2024 03:06:59 +0100 (CET)", "from DM6PR06CA0053.namprd06.prod.outlook.com (2603:10b6:5:54::30) by\n DS0PR12MB9321.namprd12.prod.outlook.com (2603:10b6:8:1b8::13) with\n Microsoft\n SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id\n 15.20.7270.17; Tue, 6 Feb 2024 02:06:57 +0000", "from DS1PEPF0001708E.namprd03.prod.outlook.com\n (2603:10b6:5:54:cafe::90) by DM6PR06CA0053.outlook.office365.com\n (2603:10b6:5:54::30) with Microsoft SMTP Server (version=TLS1_2,\n cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7249.36 via Frontend\n Transport; Tue, 6 Feb 2024 02:06:57 +0000", "from mail.nvidia.com (216.228.117.161) by\n DS1PEPF0001708E.mail.protection.outlook.com (10.167.17.134) with Microsoft\n SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id\n 15.20.7249.19 via Frontend Transport; Tue, 6 Feb 2024 02:06:57 +0000", "from rnnvmail201.nvidia.com (10.129.68.8) by mail.nvidia.com\n (10.129.200.67) with Microsoft SMTP Server (version=TLS1_2,\n cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.41; Mon, 5 Feb 2024\n 18:06:50 -0800", "from nvidia.com (10.126.230.35) 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.1258.12; Mon, 5 Feb\n 2024 18:06:48 -0800" ], "ARC-Seal": "i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none;\n b=nLJGhMGXycf8QgyO1XMmTPdR8Q3Smzi2ovFoSde0zLKqJpdgOYOlMPzf3XgIxYEduMar72xqTXOOyV6COu5/e7eeI6bpFvBWlnLJ3DEXBqY+g0b+K0o3KwcStaj06l/mVw4FNQ7u31uw5/2O0B4T7GLkdkaDHMUY668M27hsaoSev4ZsgRwLGgTm9S31//qe2b5QsXXfeUEWusN5sBNtXvJM8G9AfWfZIRAUiAokNZLS9TVDrjaVzsrac9EWXsrXCk5vhGkUhEAjncvAKHun5LOacoWSQRAn7v/xkvE9yhgT/toLPNG76zbWkFYqWBNpTQ+e1TuPNX1/UJWI6eowmA==", "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=PaRkvZPUibxwGIHlNKJyfZriqjD+FHoeBWVBzVCERbk=;\n b=fOj6muAE3QStcTCjWX9ppHRQF7TPpbHOTeY97QP08K7QpmJwsLLF0mWkm3ZIxM1NMUMlS49bqmQo0lbaKqbhpQGnx3XkEJTlPFtP3e9D6a3IAaVVFKVvwP9DWVGuvcIt+Om0LmTMhRHitcGQhYAJ26kIyHs8QA2Q0f00OXofWNrXly1iZIH1uEiPsko1OZ4XJOFI4y22lKZ9HYF8SesLiVOD2BRBkOStPrppuqkPAopYAHQiQAYhWGRk2S3pPQeoTKlzCXxL1IqyRtQHCoCxU5drJ2w6jLezETHKtY18iLPm4k6Fuum7a1QfTaYN3lOoqItpSaYmy9wci5Yp2G9vnw==", "ARC-Authentication-Results": "i=1; mx.microsoft.com 1; spf=pass (sender ip is\n 216.228.117.161) 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 (0)", "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=PaRkvZPUibxwGIHlNKJyfZriqjD+FHoeBWVBzVCERbk=;\n b=RPjrEjdi2b1t08afjt47DC+1RJdZYiy7ZdQVMS1I0B5qnLFoocMWfVRGQ6LFum5BvaD3/8PfYG1n11t55NZ+aLqEz7GbVsb0NMADxMIuxKC+hR3MSzg43c4ae7cBcknExxMAI0I2qsUYyKzYvekSAhcHWq45bb9FL40U8+PMycHx6/Ev9ZNKNABmx2N5GJab+JOWedaMPdxGnzaJC0jI9a99CqsTZ31enAz3/SRd/2coMaz6wDeB+HylNOKX6uVP+oJGpo7CfHKaamNmVvz1vlATZMtub99oP+PJ4N4CMEsT9HVWcQaZOFpZB1Cw/dTN74nD+DxfDlBiQc6bANr9Cw==", "X-MS-Exchange-Authentication-Results": "spf=pass (sender IP is 216.228.117.161)\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.161 as permitted sender) receiver=protection.outlook.com;\n client-ip=216.228.117.161; helo=mail.nvidia.com; pr=C", "From": "Suanming Mou <suanmingm@nvidia.com>", "To": "<thomas@monjalon.net>, <ferruh.yigit@amd.com>, Ori Kam <orika@nvidia.com>,\n Andrew Rybchenko <andrew.rybchenko@oktetlabs.ru>", "CC": "<dev@dpdk.org>", "Subject": "[PATCH v7 2/4] ethdev: move flow field data structures", "Date": "Tue, 6 Feb 2024 10:06:23 +0800", "Message-ID": "<20240206020626.545946-3-suanmingm@nvidia.com>", "X-Mailer": "git-send-email 2.34.1", "In-Reply-To": "<20240206020626.545946-1-suanmingm@nvidia.com>", "References": "<20231214031227.363911-1-suanmingm@nvidia.com>\n <20240206020626.545946-1-suanmingm@nvidia.com>", "MIME-Version": "1.0", "Content-Transfer-Encoding": "8bit", "Content-Type": "text/plain", "X-Originating-IP": "[10.126.230.35]", "X-ClientProxiedBy": "rnnvmail203.nvidia.com (10.129.68.9) To\n rnnvmail201.nvidia.com (10.129.68.8)", "X-EOPAttributedMessage": "0", "X-MS-PublicTrafficType": "Email", "X-MS-TrafficTypeDiagnostic": "DS1PEPF0001708E:EE_|DS0PR12MB9321:EE_", "X-MS-Office365-Filtering-Correlation-Id": "589e2e36-0290-4042-4232-08dc26b84c26", "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 f+yMAZKwQ46el9eKnlUeeFzJfw4FOvmPa+vYQv1BMxog0qPIBUmYtCdmZg6/z3M6P5Fptc3Nv8hCMq1fW1I2fXeUv/pNgIGjl2m680+wwct6Yc52cCkECUAAI+qxUqOwrhV3UZn7gDp9dMENv+cohRhEV9KZWkjLaT2UX/WGbQEV7Busb70fOwNCVbbUSwurrlLs+wwX36ZufUsOGIlVuTezU3E57HoC+BEGKexFSqL3lTmptaUPfPkxyRn/A3eQXK3NbedCYdCtPTvsBDHgIYeQMk42TaSNtlNby6XAfH1Q+cJ3w+v/lMDgh1DkiQgeODl0UQMJxRxGBvrSZ8GgiXwZnvXu2nVJNnBlZq219saFTi9K/7mnM0DpDws4bBclrD401/WFuOs79ZzsRNzTci+CDj5OXHBsG1I285cTeoCSC7ireBA7xOf9uRpvZvOhz0mWfah0Nk2KdiUChNtPoidcDG0vNLD0jCu4pm7FtJxqrDcB7ihqv0SPSYC/6bxEA7kUg/LtO6UYH+3SVCn0HaiJcSj3BsE/I3BsK9SG1p1eFXu1DzCpufTxVfv5a3NNEZ3gAu+lCb39zx1VdbZce4aI52okL06UJUnsByapmOPdhYjB7MJptRHIvaWNdwfDkE1GOFCLBN3nsRf/6f5fwsgR38VFQbzGpft51FdEnCC9ZMN+OEqUPV2q3iumjCEVBBeWZ6OJaug4WWUHPMIl+KCUQLtmNfHgDuPbqkYf4rzl2OdMCRh4qgtxR+Z+jvrF", "X-Forefront-Antispam-Report": "CIP:216.228.117.161; CTRY:US; LANG:en; SCL:1;\n SRV:;\n IPV:NLI; SFV:NSPM; H:mail.nvidia.com; PTR:dc6edge2.nvidia.com; CAT:NONE;\n SFS:(13230031)(4636009)(346002)(376002)(39860400002)(396003)(136003)(230922051799003)(230273577357003)(82310400011)(186009)(1800799012)(64100799003)(451199024)(36840700001)(40470700004)(46966006)(40460700003)(83380400001)(1076003)(6286002)(26005)(47076005)(426003)(40480700001)(16526019)(336012)(7696005)(2616005)(6666004)(41300700001)(110136005)(36756003)(70206006)(70586007)(478600001)(316002)(82740400003)(55016003)(7636003)(356005)(36860700001)(4326008)(8676002)(30864003)(2906002)(8936002)(5660300002)(86362001);\n DIR:OUT; SFP:1101;", "X-OriginatorOrg": "Nvidia.com", "X-MS-Exchange-CrossTenant-OriginalArrivalTime": "06 Feb 2024 02:06:57.1619 (UTC)", "X-MS-Exchange-CrossTenant-Network-Message-Id": "\n 589e2e36-0290-4042-4232-08dc26b84c26", "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.161];\n Helo=[mail.nvidia.com]", "X-MS-Exchange-CrossTenant-AuthSource": "\n DS1PEPF0001708E.namprd03.prod.outlook.com", "X-MS-Exchange-CrossTenant-AuthAs": "Anonymous", "X-MS-Exchange-CrossTenant-FromEntityHeader": "HybridOnPrem", "X-MS-Exchange-Transport-CrossTenantHeadersStamped": "DS0PR12MB9321", "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": "As flow field relevant data structures will be used by both actions and\nitems, this commit moves the relevant data structures up to item parts.\n\nSigned-off-by: Suanming Mou <suanmingm@nvidia.com>\n---\n lib/ethdev/rte_flow.h | 290 +++++++++++++++++++++---------------------\n 1 file changed, 145 insertions(+), 145 deletions(-)", "diff": "diff --git a/lib/ethdev/rte_flow.h b/lib/ethdev/rte_flow.h\nindex eb46cfe09e..958eb01a80 100644\n--- a/lib/ethdev/rte_flow.h\n+++ b/lib/ethdev/rte_flow.h\n@@ -2365,6 +2365,151 @@ static const struct rte_flow_item_ptype rte_flow_item_ptype_mask = {\n };\n #endif\n \n+/**\n+ * Packet header field IDs, used by RTE_FLOW_ACTION_TYPE_MODIFY_FIELD.\n+ */\n+enum rte_flow_field_id {\n+\tRTE_FLOW_FIELD_START = 0, /**< Start of a packet. */\n+\tRTE_FLOW_FIELD_MAC_DST, /**< Destination MAC Address. */\n+\tRTE_FLOW_FIELD_MAC_SRC, /**< Source MAC Address. */\n+\tRTE_FLOW_FIELD_VLAN_TYPE, /**< VLAN Tag Identifier. */\n+\tRTE_FLOW_FIELD_VLAN_ID, /**< VLAN Identifier. */\n+\tRTE_FLOW_FIELD_MAC_TYPE, /**< EtherType. */\n+\tRTE_FLOW_FIELD_IPV4_DSCP, /**< IPv4 DSCP. */\n+\tRTE_FLOW_FIELD_IPV4_TTL, /**< IPv4 Time To Live. */\n+\tRTE_FLOW_FIELD_IPV4_SRC, /**< IPv4 Source Address. */\n+\tRTE_FLOW_FIELD_IPV4_DST, /**< IPv4 Destination Address. */\n+\tRTE_FLOW_FIELD_IPV6_DSCP, /**< IPv6 DSCP. */\n+\tRTE_FLOW_FIELD_IPV6_HOPLIMIT, /**< IPv6 Hop Limit. */\n+\tRTE_FLOW_FIELD_IPV6_SRC, /**< IPv6 Source Address. */\n+\tRTE_FLOW_FIELD_IPV6_DST, /**< IPv6 Destination Address. */\n+\tRTE_FLOW_FIELD_TCP_PORT_SRC, /**< TCP Source Port Number. */\n+\tRTE_FLOW_FIELD_TCP_PORT_DST, /**< TCP Destination Port Number. */\n+\tRTE_FLOW_FIELD_TCP_SEQ_NUM, /**< TCP Sequence Number. */\n+\tRTE_FLOW_FIELD_TCP_ACK_NUM, /**< TCP Acknowledgment Number. */\n+\tRTE_FLOW_FIELD_TCP_FLAGS, /**< TCP Flags. */\n+\tRTE_FLOW_FIELD_UDP_PORT_SRC, /**< UDP Source Port Number. */\n+\tRTE_FLOW_FIELD_UDP_PORT_DST, /**< UDP Destination Port Number. */\n+\tRTE_FLOW_FIELD_VXLAN_VNI, /**< VXLAN Network Identifier. */\n+\tRTE_FLOW_FIELD_GENEVE_VNI, /**< GENEVE Network Identifier. */\n+\tRTE_FLOW_FIELD_GTP_TEID, /**< GTP Tunnel Endpoint Identifier. */\n+\tRTE_FLOW_FIELD_TAG, /**< Tag value. */\n+\tRTE_FLOW_FIELD_MARK, /**< Mark value. */\n+\tRTE_FLOW_FIELD_META, /**< Metadata value. */\n+\tRTE_FLOW_FIELD_POINTER, /**< Memory pointer. */\n+\tRTE_FLOW_FIELD_VALUE, /**< Immediate value. */\n+\tRTE_FLOW_FIELD_IPV4_ECN, /**< IPv4 ECN. */\n+\tRTE_FLOW_FIELD_IPV6_ECN, /**< IPv6 ECN. */\n+\tRTE_FLOW_FIELD_GTP_PSC_QFI, /**< GTP QFI. */\n+\tRTE_FLOW_FIELD_METER_COLOR, /**< Meter color marker. */\n+\tRTE_FLOW_FIELD_IPV6_PROTO, /**< IPv6 next header. */\n+\tRTE_FLOW_FIELD_FLEX_ITEM, /**< Flex item. */\n+\tRTE_FLOW_FIELD_HASH_RESULT, /**< Hash result. */\n+\tRTE_FLOW_FIELD_GENEVE_OPT_TYPE, /**< GENEVE option type. */\n+\tRTE_FLOW_FIELD_GENEVE_OPT_CLASS,/**< GENEVE option class. */\n+\tRTE_FLOW_FIELD_GENEVE_OPT_DATA, /**< GENEVE option data. */\n+\tRTE_FLOW_FIELD_MPLS, /**< MPLS header. */\n+\tRTE_FLOW_FIELD_TCP_DATA_OFFSET, /**< TCP data offset. */\n+\tRTE_FLOW_FIELD_IPV4_IHL, /**< IPv4 IHL. */\n+\tRTE_FLOW_FIELD_IPV4_TOTAL_LEN, /**< IPv4 total length. */\n+\tRTE_FLOW_FIELD_IPV6_PAYLOAD_LEN,/**< IPv6 payload length. */\n+\tRTE_FLOW_FIELD_RANDOM /**< Random value. */\n+};\n+\n+/**\n+ * @warning\n+ * @b EXPERIMENTAL: this structure may change without prior notice\n+ *\n+ * Packet header field descriptions, used by RTE_FLOW_ACTION_TYPE_MODIFY_FIELD.\n+ */\n+struct rte_flow_field_data {\n+\tenum rte_flow_field_id field; /**< Field or memory type ID. */\n+\tunion {\n+\t\tstruct {\n+\t\t\t/** Encapsulation level and tag index or flex item handle. */\n+\t\t\tunion {\n+\t\t\t\tstruct {\n+\t\t\t\t\t/**\n+\t\t\t\t\t * Packet encapsulation level containing\n+\t\t\t\t\t * the field to modify.\n+\t\t\t\t\t *\n+\t\t\t\t\t * - @p 0 requests the default behavior.\n+\t\t\t\t\t * Depending on the packet type, it\n+\t\t\t\t\t * can mean outermost, innermost or\n+\t\t\t\t\t * anything in between.\n+\t\t\t\t\t *\n+\t\t\t\t\t * It basically stands for the\n+\t\t\t\t\t * innermost encapsulation level.\n+\t\t\t\t\t * Modification can be performed\n+\t\t\t\t\t * according to PMD and device\n+\t\t\t\t\t * capabilities.\n+\t\t\t\t\t *\n+\t\t\t\t\t * - @p 1 requests modification to be\n+\t\t\t\t\t * performed on the outermost packet\n+\t\t\t\t\t * encapsulation level.\n+\t\t\t\t\t *\n+\t\t\t\t\t * - @p 2 and subsequent values request\n+\t\t\t\t\t * modification to be performed on\n+\t\t\t\t\t * the specified inner packet\n+\t\t\t\t\t * encapsulation level, from\n+\t\t\t\t\t * outermost to innermost (lower to\n+\t\t\t\t\t * higher values).\n+\t\t\t\t\t *\n+\t\t\t\t\t * Values other than @p 0 are not\n+\t\t\t\t\t * necessarily supported.\n+\t\t\t\t\t *\n+\t\t\t\t\t * @note that for MPLS field,\n+\t\t\t\t\t * encapsulation level also include\n+\t\t\t\t\t * tunnel since MPLS may appear in\n+\t\t\t\t\t * outer, inner or tunnel.\n+\t\t\t\t\t */\n+\t\t\t\t\tuint8_t level;\n+\t\t\t\t\tunion {\n+\t\t\t\t\t\t/**\n+\t\t\t\t\t\t * Tag index array inside\n+\t\t\t\t\t\t * encapsulation level.\n+\t\t\t\t\t\t * Used for VLAN, MPLS or TAG types.\n+\t\t\t\t\t\t */\n+\t\t\t\t\t\tuint8_t tag_index;\n+\t\t\t\t\t\t/**\n+\t\t\t\t\t\t * Geneve option identifier.\n+\t\t\t\t\t\t * Relevant only for\n+\t\t\t\t\t\t * RTE_FLOW_FIELD_GENEVE_OPT_XXXX\n+\t\t\t\t\t\t * modification type.\n+\t\t\t\t\t\t */\n+\t\t\t\t\t\tstruct {\n+\t\t\t\t\t\t\t/**\n+\t\t\t\t\t\t\t * Geneve option type.\n+\t\t\t\t\t\t\t */\n+\t\t\t\t\t\t\tuint8_t type;\n+\t\t\t\t\t\t\t/**\n+\t\t\t\t\t\t\t * Geneve option class.\n+\t\t\t\t\t\t\t */\n+\t\t\t\t\t\t\trte_be16_t class_id;\n+\t\t\t\t\t\t};\n+\t\t\t\t\t};\n+\t\t\t\t};\n+\t\t\t\tstruct rte_flow_item_flex_handle *flex_handle;\n+\t\t\t};\n+\t\t\t/** Number of bits to skip from a field. */\n+\t\t\tuint32_t offset;\n+\t\t};\n+\t\t/**\n+\t\t * Immediate value for RTE_FLOW_FIELD_VALUE, presented in the\n+\t\t * same byte order and length as in relevant rte_flow_item_xxx.\n+\t\t * The immediate source bitfield offset is inherited from\n+\t\t * the destination's one.\n+\t\t */\n+\t\tuint8_t value[16];\n+\t\t/**\n+\t\t * Memory address for RTE_FLOW_FIELD_POINTER, memory layout\n+\t\t * should be the same as for relevant field in the\n+\t\t * rte_flow_item_xxx structure.\n+\t\t */\n+\t\tvoid *pvalue;\n+\t};\n+};\n+\n /**\n * Action types.\n *\n@@ -3892,151 +4037,6 @@ struct rte_flow_action_ethdev {\n \tuint16_t port_id; /**< ethdev port ID */\n };\n \n-/**\n- * Packet header field IDs, used by RTE_FLOW_ACTION_TYPE_MODIFY_FIELD.\n- */\n-enum rte_flow_field_id {\n-\tRTE_FLOW_FIELD_START = 0,\t/**< Start of a packet. */\n-\tRTE_FLOW_FIELD_MAC_DST,\t\t/**< Destination MAC Address. */\n-\tRTE_FLOW_FIELD_MAC_SRC,\t\t/**< Source MAC Address. */\n-\tRTE_FLOW_FIELD_VLAN_TYPE,\t/**< VLAN Tag Identifier. */\n-\tRTE_FLOW_FIELD_VLAN_ID,\t\t/**< VLAN Identifier. */\n-\tRTE_FLOW_FIELD_MAC_TYPE,\t/**< EtherType. */\n-\tRTE_FLOW_FIELD_IPV4_DSCP,\t/**< IPv4 DSCP. */\n-\tRTE_FLOW_FIELD_IPV4_TTL,\t/**< IPv4 Time To Live. */\n-\tRTE_FLOW_FIELD_IPV4_SRC,\t/**< IPv4 Source Address. */\n-\tRTE_FLOW_FIELD_IPV4_DST,\t/**< IPv4 Destination Address. */\n-\tRTE_FLOW_FIELD_IPV6_DSCP,\t/**< IPv6 DSCP. */\n-\tRTE_FLOW_FIELD_IPV6_HOPLIMIT,\t/**< IPv6 Hop Limit. */\n-\tRTE_FLOW_FIELD_IPV6_SRC,\t/**< IPv6 Source Address. */\n-\tRTE_FLOW_FIELD_IPV6_DST,\t/**< IPv6 Destination Address. */\n-\tRTE_FLOW_FIELD_TCP_PORT_SRC,\t/**< TCP Source Port Number. */\n-\tRTE_FLOW_FIELD_TCP_PORT_DST,\t/**< TCP Destination Port Number. */\n-\tRTE_FLOW_FIELD_TCP_SEQ_NUM,\t/**< TCP Sequence Number. */\n-\tRTE_FLOW_FIELD_TCP_ACK_NUM,\t/**< TCP Acknowledgment Number. */\n-\tRTE_FLOW_FIELD_TCP_FLAGS,\t/**< TCP Flags. */\n-\tRTE_FLOW_FIELD_UDP_PORT_SRC,\t/**< UDP Source Port Number. */\n-\tRTE_FLOW_FIELD_UDP_PORT_DST,\t/**< UDP Destination Port Number. */\n-\tRTE_FLOW_FIELD_VXLAN_VNI,\t/**< VXLAN Network Identifier. */\n-\tRTE_FLOW_FIELD_GENEVE_VNI,\t/**< GENEVE Network Identifier. */\n-\tRTE_FLOW_FIELD_GTP_TEID,\t/**< GTP Tunnel Endpoint Identifier. */\n-\tRTE_FLOW_FIELD_TAG,\t\t/**< Tag value. */\n-\tRTE_FLOW_FIELD_MARK,\t\t/**< Mark value. */\n-\tRTE_FLOW_FIELD_META,\t\t/**< Metadata value. */\n-\tRTE_FLOW_FIELD_POINTER,\t\t/**< Memory pointer. */\n-\tRTE_FLOW_FIELD_VALUE,\t\t/**< Immediate value. */\n-\tRTE_FLOW_FIELD_IPV4_ECN,\t/**< IPv4 ECN. */\n-\tRTE_FLOW_FIELD_IPV6_ECN,\t/**< IPv6 ECN. */\n-\tRTE_FLOW_FIELD_GTP_PSC_QFI,\t/**< GTP QFI. */\n-\tRTE_FLOW_FIELD_METER_COLOR,\t/**< Meter color marker. */\n-\tRTE_FLOW_FIELD_IPV6_PROTO,\t/**< IPv6 next header. */\n-\tRTE_FLOW_FIELD_FLEX_ITEM,\t/**< Flex item. */\n-\tRTE_FLOW_FIELD_HASH_RESULT,\t/**< Hash result. */\n-\tRTE_FLOW_FIELD_GENEVE_OPT_TYPE,\t/**< GENEVE option type. */\n-\tRTE_FLOW_FIELD_GENEVE_OPT_CLASS,/**< GENEVE option class. */\n-\tRTE_FLOW_FIELD_GENEVE_OPT_DATA,\t/**< GENEVE option data. */\n-\tRTE_FLOW_FIELD_MPLS,\t\t/**< MPLS header. */\n-\tRTE_FLOW_FIELD_TCP_DATA_OFFSET,\t/**< TCP data offset. */\n-\tRTE_FLOW_FIELD_IPV4_IHL,\t/**< IPv4 IHL. */\n-\tRTE_FLOW_FIELD_IPV4_TOTAL_LEN,\t/**< IPv4 total length. */\n-\tRTE_FLOW_FIELD_IPV6_PAYLOAD_LEN,/**< IPv6 payload length. */\n-\tRTE_FLOW_FIELD_RANDOM\t\t/**< Random value. */\n-};\n-\n-/**\n- * @warning\n- * @b EXPERIMENTAL: this structure may change without prior notice\n- *\n- * Packet header field descriptions, used by RTE_FLOW_ACTION_TYPE_MODIFY_FIELD.\n- */\n-struct rte_flow_field_data {\n-\tenum rte_flow_field_id field; /**< Field or memory type ID. */\n-\tunion {\n-\t\tstruct {\n-\t\t\t/** Encapsulation level and tag index or flex item handle. */\n-\t\t\tunion {\n-\t\t\t\tstruct {\n-\t\t\t\t\t/**\n-\t\t\t\t\t * Packet encapsulation level containing\n-\t\t\t\t\t * the field to modify.\n-\t\t\t\t\t *\n-\t\t\t\t\t * - @p 0 requests the default behavior.\n-\t\t\t\t\t * Depending on the packet type, it\n-\t\t\t\t\t * can mean outermost, innermost or\n-\t\t\t\t\t * anything in between.\n-\t\t\t\t\t *\n-\t\t\t\t\t * It basically stands for the\n-\t\t\t\t\t * innermost encapsulation level.\n-\t\t\t\t\t * Modification can be performed\n-\t\t\t\t\t * according to PMD and device\n-\t\t\t\t\t * capabilities.\n-\t\t\t\t\t *\n-\t\t\t\t\t * - @p 1 requests modification to be\n-\t\t\t\t\t * performed on the outermost packet\n-\t\t\t\t\t * encapsulation level.\n-\t\t\t\t\t *\n-\t\t\t\t\t * - @p 2 and subsequent values request\n-\t\t\t\t\t * modification to be performed on\n-\t\t\t\t\t * the specified inner packet\n-\t\t\t\t\t * encapsulation level, from\n-\t\t\t\t\t * outermost to innermost (lower to\n-\t\t\t\t\t * higher values).\n-\t\t\t\t\t *\n-\t\t\t\t\t * Values other than @p 0 are not\n-\t\t\t\t\t * necessarily supported.\n-\t\t\t\t\t *\n-\t\t\t\t\t * @note that for MPLS field,\n-\t\t\t\t\t * encapsulation level also include\n-\t\t\t\t\t * tunnel since MPLS may appear in\n-\t\t\t\t\t * outer, inner or tunnel.\n-\t\t\t\t\t */\n-\t\t\t\t\tuint8_t level;\n-\t\t\t\t\tunion {\n-\t\t\t\t\t\t/**\n-\t\t\t\t\t\t * Tag index array inside\n-\t\t\t\t\t\t * encapsulation level.\n-\t\t\t\t\t\t * Used for VLAN, MPLS or TAG types.\n-\t\t\t\t\t\t */\n-\t\t\t\t\t\tuint8_t tag_index;\n-\t\t\t\t\t\t/**\n-\t\t\t\t\t\t * Geneve option identifier.\n-\t\t\t\t\t\t * Relevant only for\n-\t\t\t\t\t\t * RTE_FLOW_FIELD_GENEVE_OPT_XXXX\n-\t\t\t\t\t\t * modification type.\n-\t\t\t\t\t\t */\n-\t\t\t\t\t\tstruct {\n-\t\t\t\t\t\t\t/**\n-\t\t\t\t\t\t\t * Geneve option type.\n-\t\t\t\t\t\t\t */\n-\t\t\t\t\t\t\tuint8_t type;\n-\t\t\t\t\t\t\t/**\n-\t\t\t\t\t\t\t * Geneve option class.\n-\t\t\t\t\t\t\t */\n-\t\t\t\t\t\t\trte_be16_t class_id;\n-\t\t\t\t\t\t};\n-\t\t\t\t\t};\n-\t\t\t\t};\n-\t\t\t\tstruct rte_flow_item_flex_handle *flex_handle;\n-\t\t\t};\n-\t\t\t/** Number of bits to skip from a field. */\n-\t\t\tuint32_t offset;\n-\t\t};\n-\t\t/**\n-\t\t * Immediate value for RTE_FLOW_FIELD_VALUE, presented in the\n-\t\t * same byte order and length as in relevant rte_flow_item_xxx.\n-\t\t * The immediate source bitfield offset is inherited from\n-\t\t * the destination's one.\n-\t\t */\n-\t\tuint8_t value[16];\n-\t\t/**\n-\t\t * Memory address for RTE_FLOW_FIELD_POINTER, memory layout\n-\t\t * should be the same as for relevant field in the\n-\t\t * rte_flow_item_xxx structure.\n-\t\t */\n-\t\tvoid *pvalue;\n-\t};\n-};\n-\n /**\n * Operation types for MODIFY_FIELD action.\n */\n", "prefixes": [ "v7", "2/4" ] }{ "id": 136413, "url": "