From patchwork Fri Oct 6 18:11:45 2017 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Akhil Goyal X-Patchwork-Id: 29839 Return-Path: X-Original-To: patchwork@dpdk.org Delivered-To: patchwork@dpdk.org Received: from [92.243.14.124] (localhost [127.0.0.1]) by dpdk.org (Postfix) with ESMTP id 9C6FB1B286; Fri, 6 Oct 2017 20:15:11 +0200 (CEST) Received: from NAM01-SN1-obe.outbound.protection.outlook.com (mail-sn1nam01on0043.outbound.protection.outlook.com [104.47.32.43]) by dpdk.org (Postfix) with ESMTP id 8D8D11B286 for ; Fri, 6 Oct 2017 20:15:09 +0200 (CEST) Received: from MWHPR03CA0019.namprd03.prod.outlook.com (2603:10b6:300:117::29) by SN2PR03MB2365.namprd03.prod.outlook.com (2603:10b6:804:e::16) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P256) id 15.20.77.7; Fri, 6 Oct 2017 18:15:08 +0000 Received: from BN1BFFO11FD024.protection.gbl (2a01:111:f400:7c10::1:109) by MWHPR03CA0019.outlook.office365.com (2603:10b6:300:117::29) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P256) id 15.20.56.9 via Frontend Transport; Fri, 6 Oct 2017 18:15:08 +0000 Authentication-Results: spf=fail (sender IP is 192.88.158.2) smtp.mailfrom=nxp.com; NXP1.onmicrosoft.com; dkim=none (message not signed) header.d=none;NXP1.onmicrosoft.com; dmarc=fail action=none header.from=nxp.com; Received-SPF: Fail (protection.outlook.com: domain of nxp.com does not designate 192.88.158.2 as permitted sender) receiver=protection.outlook.com; client-ip=192.88.158.2; helo=az84smr01.freescale.net; Received: from az84smr01.freescale.net (192.88.158.2) by BN1BFFO11FD024.mail.protection.outlook.com (10.58.144.87) with Microsoft SMTP Server (version=TLS1_0, cipher=TLS_RSA_WITH_AES_256_CBC_SHA) id 15.20.77.10 via Frontend Transport; Fri, 6 Oct 2017 18:15:07 +0000 Received: from netperf2.ap.freescale.net ([10.232.133.164]) by az84smr01.freescale.net (8.14.3/8.14.0) with ESMTP id v96IERoe027297; Fri, 6 Oct 2017 11:15:01 -0700 From: Akhil Goyal To: CC: , , , , , , , , , , , , Date: Fri, 6 Oct 2017 23:41:45 +0530 Message-ID: <20171006181151.4758-7-akhil.goyal@nxp.com> X-Mailer: git-send-email 2.9.3 In-Reply-To: <20171006181151.4758-1-akhil.goyal@nxp.com> References: <20171003131413.23846-1-akhil.goyal@nxp.com> <20171006181151.4758-1-akhil.goyal@nxp.com> X-EOPAttributedMessage: 0 X-Matching-Connectors: 131517873080285380; (91ab9b29-cfa4-454e-5278-08d120cd25b8); () X-Forefront-Antispam-Report: CIP:192.88.158.2; IPV:NLI; CTRY:US; EFV:NLI; SFV:NSPM; SFS:(10009020)(6009001)(7966004)(336005)(39380400002)(346002)(39860400002)(376002)(2980300002)(1110001)(1109001)(339900001)(199003)(189002)(85426001)(2950100002)(6916009)(189998001)(104016004)(68736007)(6666003)(8656003)(77096006)(316002)(69596002)(5660300001)(48376002)(50466002)(54906003)(7416002)(356003)(305945005)(81156014)(498600001)(4326008)(2906002)(1076002)(47776003)(50986999)(8676002)(15650500001)(81166006)(97736004)(86362001)(5003940100001)(50226002)(76176999)(575784001)(36756003)(106466001)(8936002)(16586007)(53936002)(33646002)(2351001)(105606002); DIR:OUT; SFP:1101; SCL:1; SRVR:SN2PR03MB2365; H:az84smr01.freescale.net; FPR:; SPF:Fail; PTR:InfoDomainNonexistent; A:1; MX:1; LANG:en; X-Microsoft-Exchange-Diagnostics: 1; BN1BFFO11FD024; 1:gES9hyOF0qwCcqrty4Muqm6ZsUgHfnTpDsTXShTV2jm81YjIqpSEqt6XJyesMMDjZGTZ0i3ws09OSm7xKLXRYH4AiI7MryWmo7qHgZhJNUTB6uaGsEUM5npgh0SrVbpJ MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 2867ced8-8d53-40c2-5763-08d50ce62d05 X-Microsoft-Antispam: UriScan:; BCL:0; PCL:0; RULEID:(22001)(2017052603199)(201703131430075)(201703131517081); SRVR:SN2PR03MB2365; X-Microsoft-Exchange-Diagnostics: 1; SN2PR03MB2365; 3:K+/20MmDnr9HBpBtyyf5ANnliTQlvBk+pkEeO4hG25gXnE4munsjGv5b8KNNUwnkRF08ocXMuEqTV/A//vlk+4qWf8UvVEq8KyYSkuCSkYSQRZ0ORjQP3k3A1uSxdoZ8hDv+XIzJOHz2wJJHjqmzdGoS1E4QQCRJQBgK7kc5GYjHwqfqGj172Fu2J/bxoIOHx05o+l0DIQ58dsP4LBAlECmHZbVLyqcAPoNLNE1vjRPqBNuKi+5Sp/4xwRonoJgkjvSR5gfk5HoQWYOadCPczeDVJR8e40jz8hzRkgbV2BG9F3vYkBzERsrX7mq0i9JrHUV+FM5734UAQD0VsCOMVzw9E4DpYnEGyUFoqIjzV4w=; 25:8oy9XLrRAAdYOrQtb2DzNYMZal6duE85TRcMPUmD4h9n+zQOUdeRzScwqi+IGtn7BHGqgOHF+PODQ4RJ8VoCIdl5XYWRc3XQDMQ7+nux+ZDQw2JlQXJZNWYMh91yRxnsZ4ZS5wkAiWrFvKIa9zkijWY/MAg7zvGxLVgJ0o0dOnHwIQ2T5Lvc2VHidGmna1DxJbNClGHTHFizJ0GWwiiXeAGUnKZwdxU18ANSOzuJfiRdcQreWIaHIAFGhSFAL5wH/Ktldw4aFHpD4lYh+/4M53x84q1ygW+nGLRxGFB6DnKttMb+rPh4CFn+ISQM0S+GhDobiLaVQByq4eTN79c90w== X-MS-TrafficTypeDiagnostic: SN2PR03MB2365: X-Microsoft-Exchange-Diagnostics: 1; SN2PR03MB2365; 31:BxPAoUjd7vsBv1BgHlx7JdT4vdSQe6U3KhWjUWeqTsTCKhDZkGL8GvSQALJSjnfh9dz1GbLXRtYYKJIjXPDZsaJmP57TIE9ge68BvMlgiA1s/Bx8XFu5cuyTeai/uv4WOvrh5aWqXQREHpfknjzY08XapdEQZM3kibzYlUnApJH858gRYdaEabBdbKspwLqjvwuENSeKBq309SM1zNqRruWOq/voj5GAy7d9GiYVFBQ=; 4:zIUynAoAMLjCXjZCEQtWYceMx5Nwq4bmlnoQKgqXlZLwR2JWGL6029VOiLfoT++OKHnupRqEOHCexAeF+0I/I93HRwGaleIoTk5aM9goQA2pMgrhR7nTSXe4Vw/loG6ysBvmd9BAphc5/eZjm+xBpz3DEpeYwo1fUIY6+2sIsr7nWm1Xs2mbK4sgYx46wmySmsg9sywYVa26b5iFKPUZikbJ32xaBOUsAfABgBvLG8nP9+RDKry9xw0a1b+gZ5Hy0yhMFhDiX4rkPb8iVtFb7uxEHAjbRBDF7lkP4Sqk9zgP28iRLkxRMaTxSSKsnzmTju3lAfhDOsSOvsbTb4yOQA== X-Exchange-Antispam-Report-Test: UriScan:(192374486261705)(228905959029699); X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-CFA-Test: BCL:0; PCL:0; RULEID:(100000700101)(100105000095)(100000701101)(100105300095)(100000702101)(100105100095)(6095135)(2401047)(8121501046)(5005006)(10201501046)(100000703101)(100105400095)(3002001)(93006095)(93001095)(6055026)(6096035)(201703131430075)(201703131433075)(201703131441075)(201703131448075)(201703161259150)(20161123559100)(20161123565025)(20161123563025)(20161123556025)(20161123561025)(201708071742011)(100000704101)(100105200095)(100000705101)(100105500095); SRVR:SN2PR03MB2365; BCL:0; PCL:0; RULEID:(100000800101)(100110000095)(100000801101)(100110300095)(100000802101)(100110100095)(100000803101)(100110400095)(400006)(100000804101)(100110200095)(100000805101)(100110500095); SRVR:SN2PR03MB2365; X-Forefront-PRVS: 0452022BE1 X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; SN2PR03MB2365; 23:l6tOE3n+N/ihD/ofA1MZg0QjofbxI7nh/tyJTtBnW?= 15nvmMAAvQ/Ita+TM+AvmvHcjPhLgqd2wCm1wnK+gHJhwiUsmg4HoLDhu1eVVfgTvDPtfG/YdOP7JElBfQxKYWKVc1saio2xWDBFaJOdjA+PYKgAFua6Y5uqnK3R32AQgZm4gkeHJs1KyZBHA8rXXMU5b9PHyApNewFg+oCuS8ld81rKcXCjkqF/RxyaikyiQpqZzq4+tY0LWXOoDNP0QNnDQT4Zv+4euxC50DJJDaLcZT6q6hUJWJvaMIAwCIZysIKME4O+k34PnFy/aeikKHzDJvlpeaq4EjzadOKtajiOiRqCeY2NYOsB9lkIoBU46Z2Q0t6sasrjHdulm5t6P3ZaPBLJfl8pA2nYg4pf4+FdQnoPweQ4zrIelnOIMzNUIjY67z9Agy9kmBVVa6KMgfPQAq3wzqfL74hoRW96dtvmOh71nfdrqexPm9u5eAKuOBShPJf/emfqCPRxLxftwbUcpIuINcN7190Rzh6/JAFG0uuStL4iny09eqNv9C9rUkJQksn123M21yqfFL5h/wpqmThzrjluzMSYpOJ02thtn/ydalsu1CEFCwqxIVeb+eJDTQ/yuGfFaXqdp1lNmrAh1gjQPpxURykEXk9hRWf8D7bTtgUwrNFhgC03oy10ELsRjRamnkNHN1h3wmGomIqwZ5CuXGgli2y+3d1Gy1eTGqHQIEd3nvzBgO+WI/xPgSTzH475N3v2/csQgvJp8vpzLpvdPwFglw70cox2/G2cSeXkxRw6dY9LmW6vrlu5o0/4gCLOW8Ctgwl2MwdIqsZ2azWF2E7/ZJ/gJgm0dMw2HSEW7bK1QJz/1IUrStx/KhYIPfaIaJ7aG+DTGYa5LYMHi/omzR2ttI/5uF/pCIQNoh7ailTqzksE68JZWKRossA/81JGqssc5m17b9gNSO9eC50bCYs+jPlOfmvj993jYpRnBAGfbts79AF2hH0msf274x3q0S/Q0yEFs01y7GNE/z3gXBYQs+2eaV2QvtbLqyvPX2XUPbi9GWYK0W7MPOUx55ZYAdj4JLfHsNgwtzyBqGZ/h1kOal7Q3K1uYHdMyclJpMlh8v77ZkxOQFwtAddShI/bq4TCfZ8ltx9J1JNVoCvS850Zg2djy5xz1NELOPyYE8P0N1+PnYuQI2V5vdVlY3zB0LMSCoVWTEusMNnnaPA1hK+lpQ9TyX/nP2aIujNnHdCKFJDlUOM1h8hQY689G47UaZ+LT8fNk8LeKUbL+lxnwlUjIGwwRn9/iwndQ== X-Microsoft-Exchange-Diagnostics: 1; SN2PR03MB2365; 6:Ltt4DcH9cmPM1yV/Vzxj5UTxgjQihlxjbWb2aHBMM2TcCm1bf5t7A7b38EBwfDzzamklOtv9bQEfgIrhfpgb36HZks8DxWnTTb28IvyNlcUo67qfv4+7mF3xkhDiNGSFuVCfeWBdPOym6FFGw6XhlPXOXIEd93ge17jSGdtzWlYD7wm2BnXOJg5fCa37uW/Bfy0Iq92K/kY1V4ywN1qr1/eRhfO6l+eoavMBjxGU9tXUU8WYtboHQBIbNXgn7gk0nskAgjSm6aFcG7LFPuJxNiU5uBg1UHXIfICcHOCcGTGQtmxeEKBhe7XUV9+5GCJbuEtG+ksSwkLA1yTjyZuStA==; 5:6OO/YNMqBbZL6ZSrChKeDAtJLF1ss+J9em2eBCQF+AcxlDHmMthmW9vVkmJgXJXMY/C5hsXpeKQry/u51eYTuWQlqWkX7ETewsXPv1eHW+nD0LOzRNDjScVKaKKQxoD2xHWCsWRU4DsVz19IFbA55A==; 24:4LQxRYMCu2+5/PQBNGHW6bZoNIqmeXeuhnYJRBDTd5elU29NARJmUoX8QzukK1Kl3hdKA4sQcDvQhtX/Y9/bBJTPXPF0fFA3jtHpehBhRUc=; 7:I16A8olmCtlD9ImJeHQxmf9nveisa49MtR6nJpeWUEj9y28aXG91r6/rbut4o27iu62IQBIu3RmY0/0617JC2z3cakG3mw5jKeMrntzq56hPl5lFnSZLHkmoZrFgv1PhW5IegDdOPPqSrsYf7NxHeGT4TZsgA3nid1gIJGQiVaPiHj6zMWMlbE/CDjIwS2Z7M7/ol1cVbAR4QdQzztySb9WE26QdHZeNljBtkcourtY= SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-MS-Exchange-CrossTenant-OriginalArrivalTime: 06 Oct 2017 18:15:07.6541 (UTC) X-MS-Exchange-CrossTenant-Id: 5afe0b00-7697-4969-b663-5eab37d5f47e X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=5afe0b00-7697-4969-b663-5eab37d5f47e; Ip=[192.88.158.2]; Helo=[az84smr01.freescale.net] X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: SN2PR03MB2365 Subject: [dpdk-dev] [PATCH v3 06/12] ethdev: support security APIs X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Sender: "dev" From: Declan Doherty rte_flow_action type and ethdev updated to support rte_security sessions for crypto offload to ethernet device. Signed-off-by: Boris Pismenny Signed-off-by: Aviad Yehezkel Signed-off-by: Radu Nicolau Signed-off-by: Declan Doherty --- lib/librte_ether/rte_ethdev.c | 11 +++++++++++ lib/librte_ether/rte_ethdev.h | 19 +++++++++++++++++-- lib/librte_ether/rte_ethdev_version.map | 7 +++++++ 3 files changed, 35 insertions(+), 2 deletions(-) diff --git a/lib/librte_ether/rte_ethdev.c b/lib/librte_ether/rte_ethdev.c index 0597641..860eafa 100644 --- a/lib/librte_ether/rte_ethdev.c +++ b/lib/librte_ether/rte_ethdev.c @@ -302,6 +302,17 @@ rte_eth_dev_socket_id(uint8_t port_id) return rte_eth_devices[port_id].data->numa_node; } +uint16_t +rte_eth_dev_get_sec_id(uint8_t port_id) +{ + RTE_ETH_VALID_PORTID_OR_ERR_RET(port_id, -1); + + if (rte_eth_devices[port_id].data->dev_flags & RTE_ETH_DEV_SECURITY) + return rte_eth_devices[port_id].data->sec_id; + + return INVALID_SEC_ID; +} + uint8_t rte_eth_dev_count(void) { diff --git a/lib/librte_ether/rte_ethdev.h b/lib/librte_ether/rte_ethdev.h index 0adf327..cd0bb0c 100644 --- a/lib/librte_ether/rte_ethdev.h +++ b/lib/librte_ether/rte_ethdev.h @@ -180,6 +180,8 @@ extern "C" { #include #include #include +#include + #include "rte_ether.h" #include "rte_eth_ctrl.h" #include "rte_dev_info.h" @@ -357,7 +359,8 @@ struct rte_eth_rxmode { jumbo_frame : 1, /**< Jumbo Frame Receipt enable. */ hw_strip_crc : 1, /**< Enable CRC stripping by hardware. */ enable_scatter : 1, /**< Enable scatter packets rx handler */ - enable_lro : 1; /**< Enable LRO */ + enable_lro : 1, /**< Enable LRO */ + enable_sec : 1; /**< Enable security offload */ }; /** @@ -679,8 +682,10 @@ struct rte_eth_txmode { /**< If set, reject sending out tagged pkts */ hw_vlan_reject_untagged : 1, /**< If set, reject sending out untagged pkts */ - hw_vlan_insert_pvid : 1; + hw_vlan_insert_pvid : 1, /**< If set, enable port based VLAN insertion */ + enable_sec : 1; + /**< Enable security offload */ }; /** @@ -907,6 +912,7 @@ struct rte_eth_conf { #define DEV_RX_OFFLOAD_QINQ_STRIP 0x00000020 #define DEV_RX_OFFLOAD_OUTER_IPV4_CKSUM 0x00000040 #define DEV_RX_OFFLOAD_MACSEC_STRIP 0x00000080 +#define DEV_RX_OFFLOAD_SECURITY 0x00000100 /** * TX offload capabilities of a device. @@ -929,6 +935,7 @@ struct rte_eth_conf { /**< Multiple threads can invoke rte_eth_tx_burst() concurrently on the same * tx queue without SW lock. */ +#define DEV_TX_OFFLOAD_SECURITY 0x00008000 struct rte_pci_device; @@ -1651,6 +1658,10 @@ struct rte_eth_dev { enum rte_eth_dev_state state; /**< Flag indicating the port state */ } __rte_cache_aligned; +#define INVALID_SEC_ID 0xFFFF +uint16_t +rte_eth_dev_get_sec_id(uint8_t port_id); + struct rte_eth_dev_sriov { uint8_t active; /**< SRIOV is active with 16, 32 or 64 pools */ uint8_t nb_q_per_pool; /**< rx queue number per pool */ @@ -1711,6 +1722,8 @@ struct rte_eth_dev_data { int numa_node; /**< NUMA node connection */ struct rte_vlan_filter_conf vlan_filter_conf; /**< VLAN filter configuration. */ + uint16_t sec_id; + /**< security instance identifier */ }; /** Device supports hotplug detach */ @@ -1721,6 +1734,8 @@ struct rte_eth_dev_data { #define RTE_ETH_DEV_BONDED_SLAVE 0x0004 /** Device supports device removal interrupt */ #define RTE_ETH_DEV_INTR_RMV 0x0008 +/** Device supports inline security processing */ +#define RTE_ETH_DEV_SECURITY 0x0010 /** * @internal diff --git a/lib/librte_ether/rte_ethdev_version.map b/lib/librte_ether/rte_ethdev_version.map index 4283728..24cbd7d 100644 --- a/lib/librte_ether/rte_ethdev_version.map +++ b/lib/librte_ether/rte_ethdev_version.map @@ -187,3 +187,10 @@ DPDK_17.08 { rte_tm_wred_profile_delete; } DPDK_17.05; + +DPDK_17.11 { + global: + + rte_eth_dev_get_sec_id; + +} DPDK_17.08;