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 06B8D433FD; Tue, 5 Dec 2023 03:56:16 +0100 (CET) Received: from mails.dpdk.org (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id E173A42DF0; Tue, 5 Dec 2023 03:55:34 +0100 (CET) Received: from NAM12-BN8-obe.outbound.protection.outlook.com (mail-bn8nam12on2116.outbound.protection.outlook.com [40.107.237.116]) by mails.dpdk.org (Postfix) with ESMTP id E8F1142DBB for ; Tue, 5 Dec 2023 03:55:31 +0100 (CET) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=MFljSxGt5q8hRq5m98wbMpoDekZRTapCyBju4OJgwjfnDBFHNoFWsAfVbCB0YhmTtCgEQykWso1yd96k4Efcvm2jCTrNm/ivUJumW9u3f1uj8AosKJB9wSk21NgYSo6LQRsqIAqQUlui6egBhqgOb9xHx4JUsBycL5Ynr/skWXjlKubSlOVzV4URykxOwzlvOsaLtUAEWFwlXGQD+TIlI8s5xHK2AOViu3dVv2VgBs/Hpm2MxHgafITxP3V3B5FuMEt6/Huz9tjI9aAt+zgNQy2KA9WmXwIG2cNsIGh/huikqmTUKURGA4rwd+DacqMdNULFeJN7yvORpCWplepedg== 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=/vNUyXZP4+b0jvR3PLDL1/tQSlF8pVwoPVJJUFthq98=; b=I4XewHXIW1hMTcVCrtPvux37r5IQT5fD9nn30JAe+tM9AuUdWkSt1uWwyQObpR+Jld32j0fAVCuUv7RTx5LPLqNqwLfLWx3C9AaFN7wmehBi4fAdmwsZgpPdaiDuZIaJr5beLhPh63foEHN03bOVbKxrVdNm9i6LmSE/RcVSuMoIJc2iLBwxzkiXcVYu6Qpd3zlrzqe8JdLhdfTTNzRKqOLMN9xWRHaiptKaOalB8jnpsguPKCajWAcoso2wDM5zrkmkgZauu23sjO4Vac1GNLjZ0PCHHxpl9UeXPA29j+H8YY2DpBFlO7bFmmBSYoY+8+VE0wKxIsvMmmMHCCys8g== 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=/vNUyXZP4+b0jvR3PLDL1/tQSlF8pVwoPVJJUFthq98=; b=YGS/ob5uTDFseiWkdbmm8xVoyWDPoBiU2FOmCsnG5+t7ijGpvlHGMtrdah53wNRTAxK3nWaIXr4bROoouxI5omeTsCQX+exrwN0SYVADDzDUNzoa2RiUpM72sPZ+7qZhe5bMbfV2m3RCdZ1PEEO5TsZPypC42VCO3HlFhmiKMLY= 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 BY5PR13MB4439.namprd13.prod.outlook.com (2603:10b6:a03:1dd::13) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7046.34; Tue, 5 Dec 2023 02:55:30 +0000 Received: from SJ0PR13MB5545.namprd13.prod.outlook.com ([fe80::45b3:d83c:cff2:4a1b]) by SJ0PR13MB5545.namprd13.prod.outlook.com ([fe80::45b3:d83c:cff2:4a1b%6]) with mapi id 15.20.7046.033; Tue, 5 Dec 2023 02:55:30 +0000 From: Chaoyong He To: dev@dpdk.org Cc: oss-drivers@corigine.com, Chaoyong He , Long Wu , Peng Zhang Subject: [PATCH v2 07/11] net/nfp: support IPv4 flow item Date: Tue, 5 Dec 2023 10:54:53 +0800 Message-Id: <20231205025457.1067372-8-chaoyong.he@corigine.com> X-Mailer: git-send-email 2.39.1 In-Reply-To: <20231205025457.1067372-1-chaoyong.he@corigine.com> References: <20231103062606.2632012-1-chaoyong.he@corigine.com> <20231205025457.1067372-1-chaoyong.he@corigine.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-ClientProxiedBy: SJ0PR03CA0214.namprd03.prod.outlook.com (2603:10b6:a03:39f::9) To SJ0PR13MB5545.namprd13.prod.outlook.com (2603:10b6:a03:424::5) MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: SJ0PR13MB5545:EE_|BY5PR13MB4439:EE_ X-MS-Office365-Filtering-Correlation-Id: 15ca10d3-fa1f-4919-30b7-08dbf53da46b X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: 2arWrCKxNn8ElOnYcEOkbCuOyvQt95Jdv8EtshUAltBmeD69xLAy5pzVH+cMNxWvA7vrFwbqLyq0X1mf7N/FbKtLEWIkj5gwKCFGoEhWget2IPziAtjtwxtGdQalf9c6acD1dslWPbrhb6+FxLBD5JiBmLbJwS3HyVdtob90W4Goh54jRFZw9KC+ibdUFjn5EMvjd9n0XKpHOli5ugeUv+0/VnircYv/kc+a6YkAeNw3R515k1HJN+r4plu9zVN4CimvLx/egGwNdFJ0hnP/h5I/aIWPckYWIbj7N1udmYPQJQ42xzuGOWhmSs0MBLsTdK9d3U6WwhtibIVbvrn26bXvLsSU1n59B/YWgOhx6W8znaF7m3e8NmmugElQ0UElU+b2LA5LASBZqExMbjYMyadQ0ygZFaeyuHY/Yj+kftTmRbArbtagz72TKEbOUHzDObYall3nklVVzIedF2EChFpgmGFO2IIVVjDRomIIZOFRHsSpK5/pe/L9ZzlDjUfcRVboa2t//2ocnkxtb/5YIAGanMNNq1zzD3oJecptphdenbm6cAKxedOmmdqVHqTDZqTAzTw1WB7wh1yCz99gdtAXZIQt7/yQsNxrkcJgzGauzIk3BM+8epfnMnTwAoDBp6QvQSIxXaOWwONJXKaEmGdBKt+O9Lz38ZKkffynhmU= 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:(13230031)(366004)(136003)(396003)(346002)(376002)(39830400003)(230922051799003)(1800799012)(451199024)(186009)(64100799003)(6486002)(83380400001)(478600001)(6512007)(52116002)(2616005)(6506007)(26005)(6666004)(1076003)(107886003)(316002)(66476007)(54906003)(6916009)(66556008)(66946007)(86362001)(41300700001)(36756003)(8676002)(4326008)(8936002)(38350700005)(2906002)(44832011)(5660300002)(38100700002); DIR:OUT; SFP:1102; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: =?utf-8?B?azJ1dlkrOHJIUjBEb2VIb1VJQ1hUck5BMllJV1p1aDdxazRkdGUrMmxzYW1I?= =?utf-8?B?QkNDS0lpZGsyN1hhRzIrNVNWd3NvVkdudHduWGQvU2RDNC9ibEM2TDRCMkhK?= =?utf-8?B?YTZESXh5MXJxbmF3Mm5jcnNOaXJpWDlCMjV3aTNMaVcyNmRuelBPQWNCM3hi?= =?utf-8?B?cGVlWnE4L0RwWmRMbS9pSDRhWG45Z0MyaDJ2ZU1pYjloaVFMcmJsOTJ3OXV3?= =?utf-8?B?TzlzejZtamc5Q3JUdHlTSnUyVmgwUjZUd1lTY0xwMjMvVEpKOThwK0taT1pU?= =?utf-8?B?WFdzK3BON3BDdlA5VUtRVnc2aXBqamtQOVdwTFlNdGM2VndhTHJUU1A4WDNm?= =?utf-8?B?QU85ZzRSUkN3SVhWWGVZU0F5d1cwWE9ob2E1Mnc5K2RZU3NMLzcvZHVyMGdk?= =?utf-8?B?b2h6M2ttRVUwRkE0R3ZJZXJVdTBkQ0NxUUIwVnhBdzZ6bHRjWXVuTkJnTC9X?= =?utf-8?B?SklrQjh5dUF1ZWlTZ1pIdjFLUXk3ZnBSUXcwQ3lnOTdseHhhRlBWdnFoWmdU?= =?utf-8?B?WHB0LzJyZ21VUjRpa0RncXBIZjN2YUdsVFlIWHE3Y0FSTTRwbkVnaHljcm1z?= =?utf-8?B?dy9PUEdMVjhBZUFPVXFhTVJpV2FzbklFZzE0elg2NkxMREEzZHhMQkdlUWNE?= =?utf-8?B?aHdHbGo2UWx2UnpwU1pOa25BTGRqNmZQdGR5L2FmM2d6VWdEVkNheDROV0JL?= =?utf-8?B?aC84QWdtMkI2QVYvamxnMkprNjdETlcyRk5EMFlBSmF4MzRmK3gyQ1Z0TE1a?= =?utf-8?B?WTU2bGdKeDNidGFGUXM0WmIvdUNPa3F6MjNrSjd4RDNGUUFLcWN4TTdBN0VE?= =?utf-8?B?eUNIWitrenM2T3h2aHlqTnJqYXRENmlhRWVLRU4xTGY5V3RPd3ZmS3Z2NTU1?= =?utf-8?B?dnNBbk11OW9zbjFGR0JSTXVyUE9oaU5uUDFHOTRzK29iS240YnVlSHVsRk9E?= =?utf-8?B?RzF2YlhCNkFkOExUUGVWMzV4azdoM3piMFlESzYxeWo0WiszNnA4N0NvSEY2?= =?utf-8?B?REw3U015U3dGc3lMR2Y4UlUzcU4yTHlyemRXbHQ4MEZuOEFwNWJJK2ZLVlpr?= =?utf-8?B?Z0d0SmNhVWptRFRobzVRYzBlc2xScXFKVy9NREsyaUV6enRDT042bWZNRG9O?= =?utf-8?B?MisxZDAvUHR0TjEvVFdrajJuRENtRi90Nm5LQW8yRDJEdkRLd0lWa1JjVGNZ?= =?utf-8?B?SEFMNWF6M1dXTWJmcE5icjllRUJFRnRCZkZLbnBQSStUOFpPcTBHa0pxSDds?= =?utf-8?B?MEk2a1RnMWtCVC9xaVNxaEl0N2Vpbk9jWm1tWDVhS0NzOStoaWVmbG9CZUY0?= =?utf-8?B?ZEwyczQ5V2IvcmNhSlROejFXSVJBZ0FtcVZpYzRuR1VSTUhreEpsaFQ2YUV4?= =?utf-8?B?cTljUVlWUzBpOUp0TEY2WkxKMStkZE03d3pPOUJpR0E1c1hRT0RYUytwK1l1?= =?utf-8?B?YVNEUXVWNVRVK3NUc2lkWVBxaExsTWtaUUFtZXU4aXI5cUQ1S2piYXBRcVpN?= =?utf-8?B?VGpaWXJFaVI5TEVQd2RNMCtvL2JpelFoWlQ2cmdKeEdGTTNNM2Q2R1JudEtB?= =?utf-8?B?bWVxd1Zkekowa01Id1pZdFd1UXdJaXRpUGFrQWJ0ZHJ1dzEraDZvazdNcEQr?= =?utf-8?B?V01ZSkEwNi9RRXlUMWFsWHVpbkpmU3p2M05lZkI2dU1OcTd1U24yVlVsckU1?= =?utf-8?B?Y3JwMGRVRnZMY2JJU1p6eXQwM0hURXkzdjNRdWJlbm5mOEo0RnR0WEZ0dXkx?= =?utf-8?B?VjNkWUIrbW1zTGM2WlNsK3AxUExrL0FhWUplc3hxMEg2d01HVFNwN2NGbnpz?= =?utf-8?B?WTBQaHlueVRnSVNUTC94cTl5eXAxbHFzZWFpVmVPcFdTdWE3T2VVRHNZak9L?= =?utf-8?B?dVNBbXJDRFAvYVhYWTVmR2tubUtxTkJJUEFiWUcraG1IakZ0UVErNHVqZFhR?= =?utf-8?B?bXkveW8xVUJnR0lqRlJscVlSUVZ6Z1pWMmk1MXFhcGxiQlpXT1lFN1pJMG1z?= =?utf-8?B?czMwelEwZURWRURnMWJMSnlqWHpRMXEvMkR5UTV0M0Vpa2xNS1B5bjBDL2w5?= =?utf-8?B?UStpblFoRW5BNmcvbCt0ek9qeE1LTUFPdTNvb2dLeDZIR0lSWVNKdG5zUk9r?= =?utf-8?B?ays1YTVVYjVEKzBIdy9DWGNmSUlsM0NLSS91MUNDclY0b0dwRkgxTENwSzFm?= =?utf-8?B?TXc9PQ==?= X-OriginatorOrg: corigine.com X-MS-Exchange-CrossTenant-Network-Message-Id: 15ca10d3-fa1f-4919-30b7-08dbf53da46b X-MS-Exchange-CrossTenant-AuthSource: SJ0PR13MB5545.namprd13.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 05 Dec 2023 02:55:30.6156 (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: r7aegcRp6aL4X8Kis0a4Mp9ufRzmkmLMcHsIO4+M6UUW+IItHRprXCmg0AMl4X3Csrivsar+8+mBiAdPSGDFWGyNc5fY9ewJCl1GHQ0yAb0= X-MS-Exchange-Transport-CrossTenantHeadersStamped: BY5PR13MB4439 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 IPv4 item. Signed-off-by: Chaoyong He Reviewed-by: Long Wu Reviewed-by: Peng Zhang --- drivers/net/nfp/nfp_net_cmsg.h | 37 ++++++++++++++++++++++ drivers/net/nfp/nfp_net_flow.c | 58 ++++++++++++++++++++++++++++++++-- 2 files changed, 93 insertions(+), 2 deletions(-) diff --git a/drivers/net/nfp/nfp_net_cmsg.h b/drivers/net/nfp/nfp_net_cmsg.h index a95f4ef831..9bc064d9d7 100644 --- a/drivers/net/nfp/nfp_net_cmsg.h +++ b/drivers/net/nfp/nfp_net_cmsg.h @@ -21,6 +21,43 @@ struct nfp_net_cmsg_match_eth { uint16_t spare; }; +/** + * Match IPv4 data + * Bit 3 3 2 2 2 2 2 2 2 2 2 2 1 1 1 1 1 1 1 1 1 1 0 0 0 0 0 0 0 0 0 0 + * -----\ 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 + * Word +-----+-------------------------+---------------+---------------+ + * 0 | | Position | L4 Proto | L4 Proto Mask | + * +-----+-------------------------+---------------+---------------+ + * 1 | SIP4 | + * +---------------------------------------------------------------+ + * 2 | SIP4 Mask | + * +---------------------------------------------------------------+ + * 3 | DIP4 | + * +---------------------------------------------------------------+ + * 4 | DIP4 Mask | + * +-------------------------------+-------------------------------+ + * 5 | SPort | SPort Mask | + * +-------------------------------+-------------------------------+ + * 6 | DPort | DPort Mask | + * +-----------------+-------------+-------------------------------+ + * + * Position – Position index of the rule, 13bits. + * As priority, smaller value indicates higher priority. + */ +struct nfp_net_cmsg_match_v4 { + uint8_t l4_protocol_mask; + uint8_t l4_protocol; + uint16_t position; + uint32_t src_ipv4; + uint32_t src_ipv4_mask; + uint32_t dst_ipv4; + uint32_t dst_ipv4_mask; + uint16_t src_port; + uint16_t src_port_mask; + uint16_t dst_port; + uint16_t dst_port_mask; +}; + #define NFP_NET_CMSG_ACTION_DROP (0x1 << 0) /* Drop action */ #define NFP_NET_CMSG_ACTION_QUEUE (0x1 << 1) /* Queue action */ #define NFP_NET_CMSG_ACTION_MARK (0x1 << 2) /* Mark action */ diff --git a/drivers/net/nfp/nfp_net_flow.c b/drivers/net/nfp/nfp_net_flow.c index c8b6902bf1..6edb96c17a 100644 --- a/drivers/net/nfp/nfp_net_flow.c +++ b/drivers/net/nfp/nfp_net_flow.c @@ -188,6 +188,10 @@ nfp_net_flow_calculate_items(const struct rte_flow_item items[], PMD_DRV_LOG(DEBUG, "RTE_FLOW_ITEM_TYPE_ETH detected"); *match_len = sizeof(struct nfp_net_cmsg_match_eth); return 0; + case RTE_FLOW_ITEM_TYPE_IPV4: + PMD_DRV_LOG(DEBUG, "RTE_FLOW_ITEM_TYPE_IPV4 detected"); + *match_len = sizeof(struct nfp_net_cmsg_match_v4); + return 0; default: PMD_DRV_LOG(ERR, "Can't calculate match length"); *match_len = 0; @@ -220,14 +224,58 @@ nfp_net_flow_merge_eth(__rte_unused struct rte_flow *nfp_flow, return 0; } +static int +nfp_net_flow_merge_ipv4(struct rte_flow *nfp_flow, + const struct rte_flow_item *item, + const struct nfp_net_flow_item_proc *proc) +{ + struct nfp_net_cmsg_match_v4 *ipv4; + const struct rte_flow_item_ipv4 *mask; + const struct rte_flow_item_ipv4 *spec; + + spec = item->spec; + if (spec == NULL) { + PMD_DRV_LOG(DEBUG, "NFP flow merge ipv4: no item->spec!"); + return 0; + } + + mask = (item->mask != NULL) ? item->mask : proc->mask_default; + + nfp_flow->payload.cmsg_type = NFP_NET_CFG_MBOX_CMD_FS_ADD_V4; + ipv4 = (struct nfp_net_cmsg_match_v4 *)nfp_flow->payload.match_data; + + ipv4->l4_protocol_mask = mask->hdr.next_proto_id; + ipv4->src_ipv4_mask = rte_be_to_cpu_32(mask->hdr.src_addr); + ipv4->dst_ipv4_mask = rte_be_to_cpu_32(mask->hdr.dst_addr); + + ipv4->l4_protocol = spec->hdr.next_proto_id; + ipv4->src_ipv4 = rte_be_to_cpu_32(spec->hdr.src_addr); + ipv4->dst_ipv4 = rte_be_to_cpu_32(spec->hdr.dst_addr); + + return 0; +} + /* Graph of supported items and associated process function */ static const struct nfp_net_flow_item_proc nfp_net_flow_item_proc_list[] = { [RTE_FLOW_ITEM_TYPE_END] = { - .next_item = NEXT_ITEM(RTE_FLOW_ITEM_TYPE_ETH), + .next_item = NEXT_ITEM(RTE_FLOW_ITEM_TYPE_ETH, + RTE_FLOW_ITEM_TYPE_IPV4), }, [RTE_FLOW_ITEM_TYPE_ETH] = { .merge = nfp_net_flow_merge_eth, }, + [RTE_FLOW_ITEM_TYPE_IPV4] = { + .mask_support = &(const struct rte_flow_item_ipv4){ + .hdr = { + .next_proto_id = 0xff, + .src_addr = RTE_BE32(0xffffffff), + .dst_addr = RTE_BE32(0xffffffff), + }, + }, + .mask_default = &rte_flow_item_ipv4_mask, + .mask_sz = sizeof(struct rte_flow_item_ipv4), + .merge = nfp_net_flow_merge_ipv4, + }, }; static int @@ -367,10 +415,16 @@ nfp_net_flow_compile_actions(const struct rte_flow_action actions[], } static void -nfp_net_flow_process_priority(__rte_unused struct rte_flow *nfp_flow, +nfp_net_flow_process_priority(struct rte_flow *nfp_flow, uint32_t match_len) { + struct nfp_net_cmsg_match_v4 *ipv4; + switch (match_len) { + case sizeof(struct nfp_net_cmsg_match_v4): + ipv4 = (struct nfp_net_cmsg_match_v4 *)nfp_flow->payload.match_data; + ipv4->position = nfp_flow->position; + break; default: break; } -- 2.39.1