From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mails.dpdk.org (mails.dpdk.org [217.70.189.124]) by inbox.dpdk.org (Postfix) with ESMTP id 98D43A0544; Mon, 10 Oct 2022 08:10:06 +0200 (CEST) Received: from [217.70.189.124] (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id 8C67442B77; Mon, 10 Oct 2022 08:09:34 +0200 (CEST) Received: from NAM02-SN1-obe.outbound.protection.outlook.com (mail-sn1anam02on2105.outbound.protection.outlook.com [40.107.96.105]) by mails.dpdk.org (Postfix) with ESMTP id 7765142802 for ; Mon, 10 Oct 2022 08:09:33 +0200 (CEST) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=lU6Nq/2O9a5TJU0WzD1cKkMN8UgINjKeIyWar0Qt9UHUT5uPtWxsbImrNF+O3z4H5/0PhofBpg5O2qYlD7iY8F2RDoHx/2CT5XVEULNBBsBRdoh+ctHfQxFOAl5cuA7sGK27pMKzVYhoe7avUzPkFh6ggAp67juyHXzPCpLGyq1GqXppGQgXWrFvbwpIY7d9qXCs8Q9Ti88iyZzRyMJg5uCp+srxEzDiDDLHyn7mtyePShlbo2fjaYECiQ3L0kVinKfNkqANj5iWhw7RRaZgdu2seiqjRtKgYOhdbgeQznyAMM+fYdxm5jNmL8lQk1T0ULKe6kOeCqtfYIauZfLm7A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; 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; bh=7LkIFtusCPbFwt2HyDgUgwXIpX/U1OnWwMAj82998IY=; b=b3Wn4fZTWOLMIpN+kgteY8k6T/A/Dl8votZ8TqVxXRvYRYk+FDjGNA1VbFcnJ9f7pKoUKkhQ4IPqLtBb/8fig++0EIJR9OE7flE5QETqrHHoQocR+ICYlxneKTUOmpT00TU4y2TClhfYvb9w4RR2y3QSlhTF5aSL+5p/91wL0gsxa+yWw6Plz8CVa95O/Z6NyG7MkqK4umW74yGYDxFwKru2bwCQT2g34a2ikmyKBkBUqsgPM82+7xImrXx7u9QR8UkiPFk13DmqE5iak/MiEoS/fHh7QTMX4qwjZd1MmOZnxRV7SQUyVuhxXFPHUhKHFGI/U7mmKsQ0w6HKmI1u/Q== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=corigine.com; dmarc=pass action=none header.from=corigine.com; dkim=pass header.d=corigine.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=corigine.onmicrosoft.com; s=selector2-corigine-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=7LkIFtusCPbFwt2HyDgUgwXIpX/U1OnWwMAj82998IY=; b=UP36SKbvdxAtijwoSIrpLv8mKJS7ycC4G4ebU43XPeHdmq7tSdGxVAvu+M1mKfiazLwcXNP3dvjH2JoBKnxmByVBwAn852/LRIo8mg1gX27QPQH4CwLMYqtagyooAYA3rlUR+ENZO6/UZ+PXnwQnOBsgvUWeeimbBL1BLpDX4iQ= Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=corigine.com; Received: from SJ0PR13MB5545.namprd13.prod.outlook.com (2603:10b6:a03:424::5) by SN4PR13MB5296.namprd13.prod.outlook.com (2603:10b6:806:207::14) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5723.14; Mon, 10 Oct 2022 06:09:31 +0000 Received: from SJ0PR13MB5545.namprd13.prod.outlook.com ([fe80::7c26:1a0b:2825:6f4b]) by SJ0PR13MB5545.namprd13.prod.outlook.com ([fe80::7c26:1a0b:2825:6f4b%4]) with mapi id 15.20.5723.014; Mon, 10 Oct 2022 06:09:31 +0000 From: Chaoyong He To: dev@dpdk.org Cc: oss-drivers@corigine.com, niklas.soderlund@corigine.com, Chaoyong He Subject: [PATCH v2 06/24] net/nfp: add the offload support of VLAN item Date: Mon, 10 Oct 2022 14:08:44 +0800 Message-Id: <1665382142-21684-7-git-send-email-chaoyong.he@corigine.com> X-Mailer: git-send-email 1.8.3.1 In-Reply-To: <1665382142-21684-1-git-send-email-chaoyong.he@corigine.com> References: <1665382142-21684-1-git-send-email-chaoyong.he@corigine.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-ClientProxiedBy: SI2PR01CA0051.apcprd01.prod.exchangelabs.com (2603:1096:4:193::6) To SJ0PR13MB5545.namprd13.prod.outlook.com (2603:10b6:a03:424::5) MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: SJ0PR13MB5545:EE_|SN4PR13MB5296:EE_ X-MS-Office365-Filtering-Correlation-Id: 488e88c5-236c-464d-61f7-08daaa85feff X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: 1OpyddesqtxnFX7u29F7WhKbhmgG9ng8H6pYZXgchvrWrteRIxewkhe/HvmFVltJUbV3uegYFDfq63ioA2oLGXhOenvCgVI1uRH/FjZf331eYHe0Pdm9AoypYXPPSPVSzzIh8LR/HZDcCpjSuSt9OBXvAWbHYLYq5Q4Tlm5WojIEU3GBQV24PfPWrw//k36r1wW63o39hbM+bRpp2R/8ZmKLmgDk+qzGsIyNUHeJpiO21fGb+JMnVncGMr7gXVb5L94NB7EcjcIX9WiVxVqq+lAd8Am2MYgtBbuBFpLdCqhjWgnpFGFlpo3iIjJ7IXW4y/HgsdS8uHT00QcZaNmcr0DywDaPZ/xnIWO54zj0OGanAxzr6pUBViead7CEpk/MPfxnWSDTFgq7IaeGmB7y3KLMzA9TBjv+KVEGFm1ijkmrkJIOqoIAF3+U44o/Tb0uXsz6g8GZSW9+QSEuspojTw37YkKUvdNUOp8mRPOo99wphPnDKEz4oLNR5cYIVfiEVChlJM60rHtZOFWE0tgJ/kX7GGuApaRHCsVqt2dKSX2tF/9Ax7gLhNbC20d2ZYFFq4jppzfsJfvOm7CISZB/pX5Aumozbd9HNd70I40DjdMrRdX4lqRbq07uTLmw0pxBp9hBymzA3OrZn1sW6SarRno6UcJqXTG7hFbpC3LxtoE+TyS93reno08yhBsF4EmEjVB08UaT8xfnF0lgXIHGmf6vEBkQOSDL6Jb+7nrxMCTGhBPRLrA9XxPAPuzwd4cr9x2wWtUaWpDldwsGSM3vsECNar+NmD8mRY1BAlrgfVBBkGGx9edFqXRgIKyhLrHZ X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:SJ0PR13MB5545.namprd13.prod.outlook.com; PTR:; CAT:NONE; SFS:(13230022)(4636009)(366004)(396003)(346002)(376002)(136003)(39830400003)(451199015)(6916009)(316002)(2906002)(186003)(6486002)(2616005)(66476007)(6666004)(107886003)(66556008)(41300700001)(66946007)(83380400001)(8936002)(8676002)(4326008)(5660300002)(44832011)(26005)(6506007)(6512007)(52116002)(86362001)(478600001)(36756003)(38350700002)(38100700002); DIR:OUT; SFP:1102; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: =?utf-8?B?WXhYbkNKcjc4RWVtSUhuWjV2QUh3MjEyRitsdXUvakZkanN4T3h2bE00UXd0?= =?utf-8?B?bFM5Y3hzTUZiYW9kZ0dvWCtsNnNUMUtvaFdIM25IK0NzUVNBOHUzZFlOTlMv?= =?utf-8?B?dU5tNWpzOXgxZmtYckQ3ZkQ4bHNpQ2Zob2IrQ1hYWDl2SjdoVE50ajM1UHVu?= =?utf-8?B?bU43Y2IvMUlyUEZoWmNhTDFoZTQ2Skp4Qm5na1NNYjdBeEF0bE9YVysxckVH?= =?utf-8?B?emdFakcyTnhJeHNVaHhFL1RCNm05ckZRcEF6czlOY0Q3S1FOeTVQMGFZbjlx?= =?utf-8?B?NnFVY1hKTzFYZmJNdllHTkhNSEhmMDdJMzJIY1ZobXl5ZmRZQkhYZCs1RXNq?= =?utf-8?B?WjZ4cGtReHJya25vZ0pSRGwvWG1wODBON2FjNTE0ZFFEN2FrUGFEYlJSQ3V5?= =?utf-8?B?TDQvTmZYK2VkeVVITUxyYUpnRHorN0NkKzJ2U2tWNlF0dTNDQlJXendwR3NR?= =?utf-8?B?RXg4ZHZHWndyRUdUY2d6cndzeUQzbm9yWEltNkErRG9LVkVLNVIvR0s4czBI?= =?utf-8?B?THpPaXVMUEZoWWhNZUpITXNOa29GM3gyZTZZSVVjcmp5bFdodlZvdGJ1bTY3?= =?utf-8?B?K0kvZzlJcEdJWjk1QnBTNnFPUHBOSFZIQzZ1czFUbjRtelRua0NnaEZGZGRM?= =?utf-8?B?cGlhVk5hNnFPeEJ1TTdmdmhOV1FEa3dWOGZkNC9Ua0RYWXphVDJQQVNOc2Vo?= =?utf-8?B?VzlQeS9XK1BNK2tRS3RqSUFUSXFaSUhtNXA2RHZmS2l5ZTVmVUJZUUlYMHVE?= =?utf-8?B?QXlWejFrNExRaWMwQXIrSGladWx3OTg3ZnhodnhOTFc5SVJkOXl4RUFVdE9D?= =?utf-8?B?Kys2TDl1NEptcktVVzFLbzlyTjlkR1VzT3dkYWRWMUxzVFdvRnkxcmZZSzNX?= =?utf-8?B?cndtUElxS2lLNVcvM1VzV1ZPN2pRSG9RRWRLUFNJRk5FT2xkNEpwMXM5Uzcx?= =?utf-8?B?MzVoem5mRnJEM3lOdko0UU94eU9oYlV6bjRwbFJwM1gwWXU2MGVaMW1lTGdq?= =?utf-8?B?NUlyMld6aTIxYUQra1ozRkZHcllIL05NY1hpM2l3b1VmTmlqY09LbVhDMGpY?= =?utf-8?B?ZWhDY2lMRmhSa3ZnVG1ZcktjMkJ5SCs5am5CSUtPQWFSaEFsVDF4eUVrd0t2?= =?utf-8?B?dExzVEtjTHZQYnZ4bTBvZkVoU3JQS3ZPK3RhVVVBTUtPNUZabUhncnBwSy9Y?= =?utf-8?B?Z1FleUFuVDhDTzlvazhWRXhpNHFSOFo4Tzl0WjFiaUdhd0hRMDltZ00rcWti?= =?utf-8?B?djhGODJ5Vnh0MVMzeEs5cUtoVjd6UHhuZWlieTkrWDBYWUNtdDAwd2gwTTJP?= =?utf-8?B?eCtpT1BOTXFnaHkrSFprT2JCbi9ZRmhSaVNrUlNMeTMrR3BpWlRURndUWlVz?= =?utf-8?B?VWRNdm9pVTBQTnk5VFNTYlVXaG8yZjg1eEQ2WWR3UzgyNDByTUdlUkRWcVFS?= =?utf-8?B?QUJnRUx0RDRVclM1TEFRTWdtYXhaejdDK1IrZlQ2Q3VOUGEraktDQS95a3lK?= =?utf-8?B?bjJtV1BIb2FDVTU2MmF5L0Z2TVhRcUxmOHZhc1ptcXA3aTh4QXpZUlF3QXQx?= =?utf-8?B?NmxZRXJNb20xV3FIbDZLOGU3V3BzbTUySmhNK1NmMFNHaDlhYThYd1JiemNa?= =?utf-8?B?bkNpLzdNaGVRMmlPVUtDQ1A1MGtBNXhHT0JvWHYwbDhXc1FEVklBbGFNdllZ?= =?utf-8?B?bllzb3ZHNFBReENLUXNBVXRqQS8yVy83YWZUQi8wUUc3QWFhL0lzRFZmV2JR?= =?utf-8?B?SXBXaS9vMTVOMndYOCtJYS9DczI5R1FXU1JTWmlabnBrZlNycWkwVE5JN1Na?= =?utf-8?B?aUNPaWJxM0xKVWxsUER3TEZ4SXhpSXBtWHdGQ2V5TWdHUmhRUWt2Yi9tU1Nx?= =?utf-8?B?MzBUTzhVN1N0K0gyeXhtZXRiSmtpcUo3NHBlWVhEYTVnM2o1OE9oOElvSmVk?= =?utf-8?B?RWxpU3VnNmtoc2Npc3lMRElIanJuM01pOUtFYnNyb05nbW4ra2NxamwrT1VR?= =?utf-8?B?RzVFRnlMS0tJQnp0d2xCK3R1ejFVTjBKRVdzZVRsdm9yTEw3SnJUR1VtdDdH?= =?utf-8?B?OEM5dm5uYnVPZDNjY3lXNDBwR25SSzZxeEJSckVJZG5QcExoYStnVnZsaGdH?= =?utf-8?B?K1ZjK1FCMk5iYnVjTEttOThpZkZnQjRua3RJMnpqWlEzSW03ejg0aURkRHhF?= =?utf-8?B?TWc9PQ==?= X-OriginatorOrg: corigine.com X-MS-Exchange-CrossTenant-Network-Message-Id: 488e88c5-236c-464d-61f7-08daaa85feff X-MS-Exchange-CrossTenant-AuthSource: SJ0PR13MB5545.namprd13.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 10 Oct 2022 06:09:31.4992 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: fe128f2c-073b-4c20-818e-7246a585940c X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: 6L1v2NEU2Li96Dk46+gEoSQ/TJFv9iPov1BYUe3jTmupZy18P4kMf35aiBEnALgOf60mTh8vCeWtT32auw0l8jc81WWfykS2xzBMEtqejHk= X-MS-Exchange-Transport-CrossTenantHeadersStamped: SN4PR13MB5296 X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Add the corresponding data structure and logics, to support the offload of VLAN item. Signed-off-by: Chaoyong He Reviewed-by: Niklas Söderlund --- doc/guides/nics/features/nfp.ini | 1 + doc/guides/rel_notes/release_22_11.rst | 1 + drivers/net/nfp/nfp_flow.c | 46 ++++++++++++++++++++++++++++++++++ drivers/net/nfp/nfp_flow.h | 2 ++ 4 files changed, 50 insertions(+) diff --git a/doc/guides/nics/features/nfp.ini b/doc/guides/nics/features/nfp.ini index 194fe64..f0ecae2 100644 --- a/doc/guides/nics/features/nfp.ini +++ b/doc/guides/nics/features/nfp.ini @@ -29,6 +29,7 @@ Usage doc = Y [rte_flow items] eth = Y port_id = Y +vlan = Y [rte_flow actions] count = Y diff --git a/doc/guides/rel_notes/release_22_11.rst b/doc/guides/rel_notes/release_22_11.rst index ac0223f..9160cc6 100644 --- a/doc/guides/rel_notes/release_22_11.rst +++ b/doc/guides/rel_notes/release_22_11.rst @@ -154,6 +154,7 @@ New Features Add the support of rte_flow pattern items as follow: * Ethernet + * Single VLAN Add the support of rte_flow actions as follow: diff --git a/drivers/net/nfp/nfp_flow.c b/drivers/net/nfp/nfp_flow.c index ec021f0..b063b96 100644 --- a/drivers/net/nfp/nfp_flow.c +++ b/drivers/net/nfp/nfp_flow.c @@ -530,6 +530,10 @@ struct nfp_mask_id_entry { ethdev->data->dev_private; key_ls->port = rte_cpu_to_be_32(representor->port_id); break; + case RTE_FLOW_ITEM_TYPE_VLAN: + PMD_DRV_LOG(DEBUG, "RTE_FLOW_ITEM_TYPE_VLAN detected"); + key_ls->vlan = NFP_FLOWER_MASK_VLAN_CFI; + break; default: PMD_DRV_LOG(ERR, "Item type %d not supported.", item->type); return -ENOTSUP; @@ -641,12 +645,42 @@ struct nfp_mask_id_entry { return 0; } +static int +nfp_flow_merge_vlan(struct rte_flow *nfp_flow, + __rte_unused char **mbuf_off, + const struct rte_flow_item *item, + const struct nfp_flow_item_proc *proc, + bool is_mask) +{ + struct nfp_flower_meta_tci *meta_tci; + const struct rte_flow_item_vlan *spec; + const struct rte_flow_item_vlan *mask; + + spec = item->spec; + if (spec == NULL) { + PMD_DRV_LOG(DEBUG, "nfp flow merge vlan: no item->spec!"); + return 0; + } + + mask = item->mask ? item->mask : proc->mask_default; + if (is_mask) { + meta_tci = (struct nfp_flower_meta_tci *)nfp_flow->payload.mask_data; + meta_tci->tci |= mask->tci; + } else { + meta_tci = (struct nfp_flower_meta_tci *)nfp_flow->payload.unmasked_data; + meta_tci->tci |= spec->tci; + } + + return 0; +} + /* Graph of supported items and associated process function */ static const struct nfp_flow_item_proc nfp_flow_item_proc_list[] = { [RTE_FLOW_ITEM_TYPE_END] = { .next_item = NEXT_ITEM(RTE_FLOW_ITEM_TYPE_ETH), }, [RTE_FLOW_ITEM_TYPE_ETH] = { + .next_item = NEXT_ITEM(RTE_FLOW_ITEM_TYPE_VLAN), .mask_support = &(const struct rte_flow_item_eth){ .hdr = { .dst_addr.addr_bytes = "\xff\xff\xff\xff\xff\xff", @@ -659,6 +693,18 @@ struct nfp_mask_id_entry { .mask_sz = sizeof(struct rte_flow_item_eth), .merge = nfp_flow_merge_eth, }, + [RTE_FLOW_ITEM_TYPE_VLAN] = { + .mask_support = &(const struct rte_flow_item_vlan){ + .hdr = { + .vlan_tci = RTE_BE16(0xefff), + .eth_proto = RTE_BE16(0xffff), + }, + .has_more_vlan = 1, + }, + .mask_default = &rte_flow_item_vlan_mask, + .mask_sz = sizeof(struct rte_flow_item_vlan), + .merge = nfp_flow_merge_vlan, + }, }; static int diff --git a/drivers/net/nfp/nfp_flow.h b/drivers/net/nfp/nfp_flow.h index f1fbada..f6bd3e4 100644 --- a/drivers/net/nfp/nfp_flow.h +++ b/drivers/net/nfp/nfp_flow.h @@ -25,6 +25,8 @@ #define NFP_FL_META_FLAG_MANAGE_MASK (1 << 7) +#define NFP_FLOWER_MASK_VLAN_CFI (1 << 12) + #define NFP_MASK_TABLE_ENTRIES 1024 /* The maximum action list size (in bytes) supported by the NFP. */ -- 1.8.3.1