From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from dpdk.org (dpdk.org [92.243.14.124]) by inbox.dpdk.org (Postfix) with ESMTP id 06ECAA04B5; Thu, 10 Sep 2020 00:49:04 +0200 (CEST) Received: from [92.243.14.124] (localhost [127.0.0.1]) by dpdk.org (Postfix) with ESMTP id 7B3B81BE0C; Thu, 10 Sep 2020 00:49:03 +0200 (CEST) Received: from EUR02-VE1-obe.outbound.protection.outlook.com (mail-eopbgr20057.outbound.protection.outlook.com [40.107.2.57]) by dpdk.org (Postfix) with ESMTP id 961281B9B7 for ; Thu, 10 Sep 2020 00:49:02 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=armh.onmicrosoft.com; s=selector2-armh-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=2NZcV20qlphxjTed+9UP22N8zwSigedS3rgzlvUdsjo=; b=s/TVqCGstLXQwMbtVT7wHed/yuNmQtr8/TDvby/kDf3mrv9eIcxGABg4/+1clv/hp5xVDRG4QFUV1aLd8A1q1lrpngJ2tb8K74I28W2NPErcXpTU3rwDqzRhXnh+PCrRgVMRbd5N+QD3K5A6D/t6iszGCgqwogrpzHvX3J2/GAU= Received: from DB8PR03CA0028.eurprd03.prod.outlook.com (2603:10a6:10:be::41) by VI1PR0801MB1711.eurprd08.prod.outlook.com (2603:10a6:800:4e::8) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3370.16; Wed, 9 Sep 2020 22:49:00 +0000 Received: from DB5EUR03FT003.eop-EUR03.prod.protection.outlook.com (2603:10a6:10:be:cafe::14) by DB8PR03CA0028.outlook.office365.com (2603:10a6:10:be::41) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3370.16 via Frontend Transport; Wed, 9 Sep 2020 22:49:00 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 63.35.35.123) smtp.mailfrom=arm.com; dpdk.org; dkim=pass (signature was verified) header.d=armh.onmicrosoft.com;dpdk.org; dmarc=bestguesspass action=none header.from=arm.com; Received-SPF: Pass (protection.outlook.com: domain of arm.com designates 63.35.35.123 as permitted sender) receiver=protection.outlook.com; client-ip=63.35.35.123; helo=64aa7808-outbound-1.mta.getcheckrecipient.com; Received: from 64aa7808-outbound-1.mta.getcheckrecipient.com (63.35.35.123) by DB5EUR03FT003.mail.protection.outlook.com (10.152.20.157) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3370.16 via Frontend Transport; Wed, 9 Sep 2020 22:49:00 +0000 Received: ("Tessian outbound e8cdb8c6f386:v64"); Wed, 09 Sep 2020 22:49:00 +0000 X-CR-MTA-TID: 64aa7808 Received: from a0a258180c92.2 by 64aa7808-outbound-1.mta.getcheckrecipient.com id 96113764-7EE2-4500-8497-5960D55FDD5D.1; Wed, 09 Sep 2020 22:48:55 +0000 Received: from EUR05-VI1-obe.outbound.protection.outlook.com by 64aa7808-outbound-1.mta.getcheckrecipient.com with ESMTPS id a0a258180c92.2 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384); Wed, 09 Sep 2020 22:48:55 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=EpMahOBsiIYXDkjOHUTpPvwFdUffeHaGKGjgSs48lveIROgJ9gIyZyz9z73iRF6rDkEC1eMPEjHcTbyaR/wOymHNqzacE058DZcVrTiXfd4vqjcIJ/H/WCn4Bua6o1rg/aHOhb8pn2sfcGfLB7ifb7rYRxnZ4igCMfE/JxUUQWqH7W851yXyFF5e6x/cCadGboB/To5c7J6aLr2x+OW3G1nYNlIDAWjPYpf51pHM06rBVrFz/rWcIAxK7/n3cAzK+i/0WsOOGBJJPZFN5//DWgeN4d50dI4PrzfEpPioz3cBBGWC9prO0duabQg7h0JVPKaoOiI7RymmSxJ/yCQzng== 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-SenderADCheck; bh=2NZcV20qlphxjTed+9UP22N8zwSigedS3rgzlvUdsjo=; b=YnSn4DX0p8FL3p8ZN1k4v5Uo860oJSogEqizTZl7h2ZI8b7N6xJ3eAmIfttp/wQZMp67Eg0jlXvG/ZIf0eBxFMSdSItwKCJEKnsnNFSc9bY4zy3Tc3decaspoxnQR8bwifLaqNcly3/BkLpw+bFjMsayvOsPraE0aXoXegMTMpYeof17ZQDAXLUarz6ktg99jl3IapCgjmbd/hJvDc+PY/jfr2fO3Kl/3qwoGRTTvfrmQeMH67ZqrHRF8b6Zy96Y8c+ibaoXzn9EnSKH5K2h8zqPVUQM8K9IDSBF/5Eg1GeirMTCCfS+fof1vucP+SCOpLsfqQtwqDtww3FnXO+TeQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=arm.com; dmarc=pass action=none header.from=arm.com; dkim=pass header.d=arm.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=armh.onmicrosoft.com; s=selector2-armh-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=2NZcV20qlphxjTed+9UP22N8zwSigedS3rgzlvUdsjo=; b=s/TVqCGstLXQwMbtVT7wHed/yuNmQtr8/TDvby/kDf3mrv9eIcxGABg4/+1clv/hp5xVDRG4QFUV1aLd8A1q1lrpngJ2tb8K74I28W2NPErcXpTU3rwDqzRhXnh+PCrRgVMRbd5N+QD3K5A6D/t6iszGCgqwogrpzHvX3J2/GAU= Received: from DBAPR08MB5814.eurprd08.prod.outlook.com (2603:10a6:10:1b1::6) by DB8PR08MB4956.eurprd08.prod.outlook.com (2603:10a6:10:e0::25) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3348.15; Wed, 9 Sep 2020 22:48:53 +0000 Received: from DBAPR08MB5814.eurprd08.prod.outlook.com ([fe80::408a:40fb:7402:c805]) by DBAPR08MB5814.eurprd08.prod.outlook.com ([fe80::408a:40fb:7402:c805%6]) with mapi id 15.20.3348.019; Wed, 9 Sep 2020 22:48:53 +0000 From: Honnappa Nagarahalli To: "Gujjar, Abhinandan S" , "dev@dpdk.org" CC: "Doherty, Declan" , "jerinj@marvell.com" , "Akhil.goyal@nxp.com" , "Vangati, Narender" , "Ananyev, Konstantin" , nd , Honnappa Nagarahalli , nd Thread-Topic: [v2 1/2] cryptodev: support enqueue callback functions Thread-Index: AQHWhsTNpueHJn2Z1E+jIJevuNB9zqlgfJJwgABACuA= Date: Wed, 9 Sep 2020 22:48:53 +0000 Message-ID: References: <1599549024-195051-1-git-send-email-abhinandan.gujjar@intel.com> In-Reply-To: Accept-Language: en-US Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: x-ts-tracking-id: 55E913E3E51B57439D8BB4ADA04F770D.0 x-checkrecipientchecked: true Authentication-Results-Original: intel.com; dkim=none (message not signed) header.d=none;intel.com; dmarc=none action=none header.from=arm.com; x-originating-ip: [107.77.221.165] x-ms-publictraffictype: Email X-MS-Office365-Filtering-HT: Tenant X-MS-Office365-Filtering-Correlation-Id: e4c931df-0d12-4c52-b0f8-08d855128b3d x-ms-traffictypediagnostic: DB8PR08MB4956:|VI1PR0801MB1711: x-ld-processed: f34e5979-57d9-4aaa-ad4d-b122a662184d,ExtAddr x-ms-exchange-transport-forked: True X-Microsoft-Antispam-PRVS: x-checkrecipientrouted: true nodisclaimer: true x-ms-oob-tlc-oobclassifiers: OLM:10000;OLM:10000; X-MS-Exchange-SenderADCheck: 1 X-Microsoft-Antispam-Untrusted: BCL:0; X-Microsoft-Antispam-Message-Info-Original: jlipTDtuTS+3DTcNbCmW9HGUcm8RWDH4gWM/3RlTKj8xdoHm6EyNFUpVikwFkLiahkMp6gIVWFB6mGjKdzhlQEq2loYDvwj7ZXGfu0u1qSyBa7xKfDS0CzJBgxvPaGuvjmXaA7ypiRmEnTQCs7/lLEMu8zjZzyJudtQgMxdPucF+81sWu/Xz7ITE/qiOX20vx5P0hCfpF+GlMHV/BGzhqPBSCU5+7P2tns0NNY5G8f9omefkCrRsJ2Y9QTYhgk1rLK3mQFLxzacySb49FJiSHmTkEh+dS+cptdLRr7oLm3lsxAhMxg40hwfG6QB8saAp/LjSMaAosl+TzIRGji5rZA== X-Forefront-Antispam-Report-Untrusted: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:DBAPR08MB5814.eurprd08.prod.outlook.com; PTR:; CAT:NONE; SFS:(4636009)(39860400002)(366004)(136003)(346002)(376002)(396003)(316002)(83380400001)(76116006)(2906002)(7696005)(26005)(5660300002)(6506007)(55016002)(186003)(66556008)(8676002)(66476007)(66446008)(30864003)(52536014)(64756008)(86362001)(110136005)(66946007)(8936002)(33656002)(478600001)(9686003)(54906003)(71200400001)(4326008); DIR:OUT; SFP:1101; x-ms-exchange-antispam-messagedata: rX8StpJ9H2r5ewXkpK7Cv2PjBcdLJOe24UdVakPqRJo31hfzYEiWHB4h0TudnfaLD9w/8xd2TarTwMQ2xNcDmuJVCVqX+yjY4u20ULT1ndByBfqVEe1KLVRqyjKVi57WJxb8KJC90Yp3QEQi4qOSA8aa+x7SZqUqgsURpWMZRXqI72Wv/BemRBBbV/LgFsDh6j2jIOJkTCKCXiavjQYVbVjE84s6GWfF+acYPu4mSOzRTOWu7XNVzaDzTEbtz5W85DHvTc+1wFx78KJEGx4NczzAudSK3tU+5RWYlYrOBC2oiQ/wwmjmh0+1zJiMSuqToODw7m+R22OqbIOfW5vvCC4GgZ/4qUJY0BLrT84sSo0eQgt7PJVugO1vD4Vh6Qfqo80Wz7ByaE47qmpVqgJpmWlaz6B0lsk7Quau69kaiHeMOrYL8nAdctek4UY52xgFpSvKfEiXdStavWBn36p2gva5qQytk4VjR5mKKmDtNgdRIwfcjAyXZXxFYF/uekeo+1pvawkpnxyn1J78dVf3jaUjR1oyR2sPfY7+6c8h/rfDMUpv+Esd1D33buPI5YXkqZub2T5CuiqqHm+0uw6uWX8pJD32ZwLQPh1hSw+3r0iUTtmjPiEq1J98Tx43BT6/H9dAiImlK/vuot5cn/Z2sw== Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 X-MS-Exchange-Transport-CrossTenantHeadersStamped: DB8PR08MB4956 Original-Authentication-Results: intel.com; dkim=none (message not signed) header.d=none;intel.com; dmarc=none action=none header.from=arm.com; X-EOPAttributedMessage: 0 X-MS-Exchange-Transport-CrossTenantHeadersStripped: DB5EUR03FT003.eop-EUR03.prod.protection.outlook.com X-MS-Office365-Filtering-Correlation-Id-Prvs: 9bdabfad-6a94-46c0-2c77-08d8551286f2 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: 4XEXs+OhknUlxVnNZlzVaewJUZv1NInku+uWDmxbF/DYAruogKFgCS7lY2qNKuNTRoKOWJrEjKKyevFH9mR7kuo9je3mXZX6QWT2DPhMU3SK4BldpGFftfu0Ch48P/eDyk9kQalwsKgcMUTAsC4p/xCO0j10US/tEtZaCWxDorSh2hvrQIKxI+2NKGa6J2Hl7dzmDf+Iv2dkp3wNiZ/FSVwxnyC8r1NHg02+kdlDTTsiJlutLrT06ZUyqrGJOpV1ew97S9LCNPV6SuSjbtzfU3cwV1ehG8JUqM05xIMugl11lyeOS7EzrLMyxmKaf+oiv30avklo5uzbgterYt8uwbzEv2LOYR6CUiQgDJsL/2ROM8irJezFb8+m+lSdF3XYX9KZrkXHWo412yWx8T6PpQ== X-Forefront-Antispam-Report: CIP:63.35.35.123; CTRY:IE; LANG:en; SCL:1; SRV:; IPV:CAL; SFV:NSPM; H:64aa7808-outbound-1.mta.getcheckrecipient.com; PTR:ec2-63-35-35-123.eu-west-1.compute.amazonaws.com; CAT:NONE; SFS:(4636009)(396003)(136003)(346002)(39860400002)(376002)(46966005)(316002)(30864003)(7696005)(336012)(8676002)(26005)(81166007)(55016002)(5660300002)(6506007)(52536014)(82740400003)(478600001)(83380400001)(33656002)(47076004)(9686003)(356005)(54906003)(4326008)(86362001)(8936002)(2906002)(110136005)(186003)(70206006)(70586007)(82310400003); DIR:OUT; SFP:1101; X-OriginatorOrg: arm.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 09 Sep 2020 22:49:00.6483 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: e4c931df-0d12-4c52-b0f8-08d855128b3d X-MS-Exchange-CrossTenant-Id: f34e5979-57d9-4aaa-ad4d-b122a662184d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=f34e5979-57d9-4aaa-ad4d-b122a662184d; Ip=[63.35.35.123]; Helo=[64aa7808-outbound-1.mta.getcheckrecipient.com] X-MS-Exchange-CrossTenant-AuthSource: DB5EUR03FT003.eop-EUR03.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: VI1PR0801MB1711 Subject: Re: [dpdk-dev] [v2 1/2] cryptodev: support enqueue callback functions 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" > > > > In an eventdev world, multiple workers (with ordered queue) will be > > working on IPsec ESP processing. The ESP header's sequence number is > > unique and has to be sequentially incremented in an orderly manner. > > This rises a need for incrementing sequence number in crypto stage > > especially in event crypto adapter. By adding a user callback to > > cryptodev at enqueue burst, the user callback will get executed in the > > context of event crypto adapter. This helps the application to > > increment the ESP sequence number atomically and orderly manner. > > > > This patch adds APIs to add/remove callback functions. The callback > > function will be called for each burst of crypto ops received on a > > given crypto device queue pair. > > > > v1->v2: > > Moved callback related members to the end of cryptodev struct Added > > support for RCU > > > > Signed-off-by: Abhinandan Gujjar > > --- > > config/common_base | 1 + > > lib/librte_cryptodev/Makefile | 2 +- > > lib/librte_cryptodev/rte_cryptodev.c | 157 > > +++++++++++++++++++++++++ > > lib/librte_cryptodev/rte_cryptodev.h | 154 > > +++++++++++++++++++++++- > > lib/librte_cryptodev/rte_cryptodev_version.map | 6 + > > 5 files changed, 318 insertions(+), 2 deletions(-) > > > > diff --git a/config/common_base b/config/common_base index > > fbf0ee7..f5ebde4 100644 > > --- a/config/common_base > > +++ b/config/common_base > > @@ -599,6 +599,7 @@ > > CONFIG_RTE_LIBRTE_PMD_BBDEV_FPGA_5GNR_FEC=3Dy > > # > > CONFIG_RTE_LIBRTE_CRYPTODEV=3Dy > > CONFIG_RTE_CRYPTO_MAX_DEVS=3D64 > > +CONFIG_RTE_CRYPTODEV_CALLBACKS=3Dy > > > > # > > # Compile PMD for ARMv8 Crypto device diff --git > > a/lib/librte_cryptodev/Makefile b/lib/librte_cryptodev/Makefile index > > 73e77a2..514d552 100644 > > --- a/lib/librte_cryptodev/Makefile > > +++ b/lib/librte_cryptodev/Makefile > > @@ -10,7 +10,7 @@ LIB =3D librte_cryptodev.a CFLAGS +=3D -O3 CFLAGS += =3D > > $(WERROR_FLAGS) LDLIBS +=3D -lrte_eal -lrte_mempool -lrte_ring > > -lrte_mbuf -LDLIBS +=3D -lrte_kvargs > > +LDLIBS +=3D -lrte_kvargs -lrte_rcu > > > > # library source files > > SRCS-y +=3D rte_cryptodev.c rte_cryptodev_pmd.c > > cryptodev_trace_points.c diff --git > > a/lib/librte_cryptodev/rte_cryptodev.c > > b/lib/librte_cryptodev/rte_cryptodev.c > > index 1dd795b..2fb3e35 100644 > > --- a/lib/librte_cryptodev/rte_cryptodev.c > > +++ b/lib/librte_cryptodev/rte_cryptodev.c > > @@ -38,6 +38,7 @@ > > #include > > #include > > #include > > +#include > > > > #include "rte_crypto.h" > > #include "rte_cryptodev.h" > > @@ -499,6 +500,10 @@ struct > > rte_cryptodev_sym_session_pool_private_data { > > return 0; > > } > > > > +#ifdef RTE_CRYPTODEV_CALLBACKS > > +/* spinlock for crypto device enq callbacks */ static rte_spinlock_t > > +rte_cryptodev_enq_cb_lock =3D RTE_SPINLOCK_INITIALIZER; #endif Are we claiming the APIs to be thread safe? Is the spinlock required? > > > > const char * > > rte_cryptodev_get_feature_name(uint64_t flag) @@ -1449,6 +1454,158 > @@ > > struct rte_cryptodev * > > rte_spinlock_unlock(&rte_cryptodev_cb_lock); > > } > > > > +#ifdef RTE_CRYPTODEV_CALLBACKS > > +int > > +rte_cryptodev_rcu_qsbr_add(uint8_t dev_id, struct rte_rcu_qsbr *qsbr) Suggest moving this API outside of RTE_CRYPTODEV_CALLBACKS as it can be use= d for other RCU related features in the future. > > +{ > > + > > + struct rte_cryptodev *dev; > > + > > + if (!rte_cryptodev_pmd_is_valid_dev(dev_id)) { > > + CDEV_LOG_ERR("Invalid dev_id=3D%" PRIu8, dev_id); > > + return -EINVAL; > > + } > > + > > + dev =3D &rte_crypto_devices[dev_id]; > > + dev->qsbr =3D qsbr; > > + return 0; > > +} > > + > > +struct rte_cryptodev_enq_callback * > > +rte_cryptodev_add_enq_callback(uint8_t dev_id, > > + uint16_t qp_id, > > + rte_cryptodev_enq_cb_fn cb_fn, > > + void *cb_arg) > > +{ > > + struct rte_cryptodev *dev; > > + struct rte_cryptodev_enq_callback *cb, *tail; > > + > > + if (!cb_fn) > > + return NULL; > > + > > + if (!rte_cryptodev_pmd_is_valid_dev(dev_id)) { > > + CDEV_LOG_ERR("Invalid dev_id=3D%" PRIu8, dev_id); > > + return NULL; > > + } > > + > > + dev =3D &rte_crypto_devices[dev_id]; > > + if (qp_id >=3D dev->data->nb_queue_pairs) { > > + CDEV_LOG_ERR("Invalid queue_pair_id=3D%d", qp_id); > > + return NULL; > > + } > > + > > + cb =3D rte_zmalloc(NULL, sizeof(*cb), 0); > > + if (cb =3D=3D NULL) { > > + CDEV_LOG_ERR("Failed to allocate memory for callback on " > > + "dev=3D%d, queue_pair_id=3D%d", dev_id, qp_id); > > + rte_errno =3D ENOMEM; > > + return NULL; > > + } > > + > > + cb->fn =3D cb_fn; > > + cb->arg =3D cb_arg; > > + > > + rte_spinlock_lock(&rte_cryptodev_enq_cb_lock); > > + if (dev->enq_cbs =3D=3D NULL) { > > + dev->enq_cbs =3D rte_zmalloc(NULL, sizeof(cb) * > > + dev->data->nb_queue_pairs, 0); > > + if (dev->enq_cbs =3D=3D NULL) { > > + CDEV_LOG_ERR("Failed to allocate memory for > > callbacks"); > > + rte_errno =3D ENOMEM; > > + rte_free(cb); Add unlock here. > > + return NULL; > > + } > > + } > > + > > + /* Add the callbacks in fifo order. */ > > + tail =3D dev->enq_cbs[qp_id]; > > + if (tail) { > > + while (tail->next) > > + tail =3D tail->next; > > + tail->next =3D cb; > > + } else > > + dev->enq_cbs[qp_id] =3D cb; > > + > > + rte_spinlock_unlock(&rte_cryptodev_enq_cb_lock); > > + > > + return cb; > > +} > > + > > +int > > +rte_cryptodev_remove_enq_callback(uint8_t dev_id, > > + uint16_t qp_id, > > + struct rte_cryptodev_enq_callback *cb) { > > + struct rte_cryptodev *dev; > > + struct rte_cryptodev_enq_callback **prev_cb, *curr_cb; > > + uint16_t qp; > > + int free_mem; > > + int ret; > > + > > + free_mem =3D 1; > > + > > + if (!cb) { > > + CDEV_LOG_ERR("cb is NULL"); > > + return -EINVAL; > > + } > > + > > + if (!rte_cryptodev_pmd_is_valid_dev(dev_id)) { > > + CDEV_LOG_ERR("Invalid dev_id=3D%" PRIu8, dev_id); > > + return -EINVAL; > > + } > > + > > + dev =3D &rte_crypto_devices[dev_id]; > > + if (qp_id >=3D dev->data->nb_queue_pairs) { > > + CDEV_LOG_ERR("Invalid queue_pair_id=3D%d", qp_id); > > + return -EINVAL; > > + } > > + > > + if (!dev->qsbr) { > > + CDEV_LOG_ERR("Rcu qsbr is NULL"); > > + return -EINVAL; > > + } I see that this check is not done in 'rte_cryptodev_add_enq_callback'. I th= ink this is ok, it avoids enforcing an order for API calls. > > + > > + rte_spinlock_lock(&rte_cryptodev_enq_cb_lock); > > + if (dev->enq_cbs =3D=3D NULL) { > > + rte_spinlock_unlock(&rte_cryptodev_enq_cb_lock); > > + return -EINVAL; > > + } > > + > > + prev_cb =3D &dev->enq_cbs[qp_id]; > > + for (; *prev_cb !=3D NULL; prev_cb =3D &curr_cb->next) { > > + curr_cb =3D *prev_cb; > > + if (curr_cb =3D=3D cb) { > > + /* Remove the user cb from the callback list. */ > > + *prev_cb =3D curr_cb->next; > > + ret =3D 0; > > + break; > > + } > > + } > > + > > + if (!ret) { > > + /* Call sync with invalid thread id as this is part of > > + * control plane API */ > > + rte_rcu_qsbr_synchronize(dev->qsbr, > > + RTE_QSBR_THRID_INVALID); > > + rte_free(cb); > > + } > > + Nit, IMO, it is more readable if 'free_mem =3D 1' is moved here. > > + for (qp =3D 0; qp < dev->data->nb_queue_pairs; qp++) > > + if (dev->enq_cbs[qp] !=3D NULL) { > > + free_mem =3D 0; > > + break; > > + } > > + > > + if (free_mem) { > > + rte_free(dev->enq_cbs); > > + dev->enq_cbs =3D NULL; > > + } > > + > > + rte_spinlock_unlock(&rte_cryptodev_enq_cb_lock); > > + > > + return ret; > > +} > > +#endif > > > > int > > rte_cryptodev_sym_session_init(uint8_t dev_id, diff --git > > a/lib/librte_cryptodev/rte_cryptodev.h > > b/lib/librte_cryptodev/rte_cryptodev.h > > index 7b3ebc2..2c7a47b 100644 > > --- a/lib/librte_cryptodev/rte_cryptodev.h > > +++ b/lib/librte_cryptodev/rte_cryptodev.h > > @@ -530,6 +530,32 @@ struct rte_cryptodev_qp_conf { }; > > > > /** > > + * Function type used for pre processing crypto ops when enqueue > > +burst is > > + * called. > > + * > > + * The callback function is called on enqueue burst immediately > > + * before the crypto ops are put onto the hardware queue for processin= g. > > + * > > + * @param dev_id The identifier of the device. > > + * @param qp_id The index of the queue pair in which ops are > > + * to be enqueued for processing. The value > > + * must be in the range [0, nb_queue_pairs - 1] > > + * previously supplied to > > + * *rte_cryptodev_configure*. > > + * @param ops The address of an array of *nb_ops* pointers > > + * to *rte_crypto_op* structures which contain > > + * the crypto operations to be processed. > > + * @param nb_ops The number of operations to process. > > + * @param user_param The arbitrary user parameter passed in by the > > + * application when the callback was originally > > + * registered. > > + * @return The number of ops to be enqueued to the > > + * crypto device. > > + */ > > +typedef uint16_t (*rte_cryptodev_enq_cb_fn)(uint16_t dev_id, uint16_t > > qp_id, > > + struct rte_crypto_op **ops, uint16_t nb_ops, void > > *user_param); > > + > > +/** > > * Typedef for application callback function to be registered by appli= cation > > * software for notification of device events > > * > > @@ -853,7 +879,6 @@ struct rte_cryptodev_config { > > enum rte_cryptodev_event_type event, > > rte_cryptodev_cb_fn cb_fn, void *cb_arg); > > > > - > > typedef uint16_t (*dequeue_pkt_burst_t)(void *qp, > > struct rte_crypto_op **ops, uint16_t nb_ops); > > /**< Dequeue processed packets from queue pair of a device. */ @@ > > -870,6 > > +895,17 @@ typedef uint16_t (*enqueue_pkt_burst_t)(void *qp, > > /** Structure to keep track of registered callbacks */ > > TAILQ_HEAD(rte_cryptodev_cb_list, rte_cryptodev_callback); > > > > +/** > > + * @internal > > + * Structure used to hold information about the callbacks to be > > +called for a > > + * queue pair on enqueue. > > + */ > > +struct rte_cryptodev_enq_callback { > > + struct rte_cryptodev_enq_callback *next; > > + rte_cryptodev_enq_cb_fn fn; > > + void *arg; > > +}; > > + > > /** The data structure associated with each crypto device. */ struct > > rte_cryptodev { > > dequeue_pkt_burst_t dequeue_burst; > > @@ -898,6 +934,14 @@ struct rte_cryptodev { > > __extension__ > > uint8_t attached : 1; > > /**< Flag indicating the device is attached */ > > + > > +#ifdef RTE_CRYPTODEV_CALLBACKS > > + struct rte_cryptodev_enq_callback **enq_cbs; > > + /**< User application callback for pre enqueue processing */ > > + > > + struct rte_rcu_qsbr *qsbr; Would be good to move this out of RTE_CRYPTODEV_CALLBACKS so that it can be= used for other features in the future. > > + /** < RCU QSBR variable for rte_cryptodev_enq_callback */ #endif > > } __rte_cache_aligned; > > > > void * > > @@ -1019,6 +1063,18 @@ struct rte_cryptodev_data { > > struct rte_crypto_op **ops, uint16_t nb_ops) { > > struct rte_cryptodev *dev =3D &rte_cryptodevs[dev_id]; > > +#ifdef RTE_CRYPTODEV_CALLBACKS > > + if (unlikely(dev->enq_cbs !=3D NULL && dev->enq_cbs[qp_id] !=3D > > NULL)) { > > + struct rte_cryptodev_enq_callback *cb =3D > > + dev->enq_cbs[qp_id]; > > + > > + do { > > + nb_ops =3D cb->fn(dev_id, qp_id, ops, nb_ops, > > + cb->arg); > > + cb =3D cb->next; > > + } while (cb !=3D NULL); > > + } > > +#endif > > > > rte_cryptodev_trace_enqueue_burst(dev_id, qp_id, (void **)ops, > > nb_ops); > > return (*dev->enqueue_burst)( > > @@ -1351,6 +1407,102 @@ struct rte_cryptodev_asym_session * > > struct rte_cryptodev_sym_session *sess, union rte_crypto_sym_ofs > > ofs, > > struct rte_crypto_sym_vec *vec); > > > > +#ifdef RTE_CRYPTODEV_CALLBACKS > > +/** > > + * @warning > > + * @b EXPERIMENTAL: this API may change without prior notice > > + * > > + * Add a user callback for a given crypto device and queue pair which > > +will be > > + * called on crypto ops enqueue. > > + * > > + * This API configures a function to be called for each burst of > > +crypto ops > > + * received on a given crypto device queue pair. The return value is > > +a pointer > > + * that can be used later to remove the callback using > > + * rte_cryptodev_remove_enq_callback(). > > + * > > + * Multiple functions are called in the order that they are added. > > + * > > + * @param dev_id The identifier of the device. > > + * @param qp_id The index of the queue pair in which ops are > > + * to be enqueued for processing. The value > > + * must be in the range [0, nb_queue_pairs - 1] > > + * previously supplied to > > + * *rte_cryptodev_configure*. > > + * @param cb_fn The callback function > > + * @param cb_arg A generic pointer parameter which will be > > passed > > + * to each invocation of the callback function on > > + * this crypto device and queue pair. > > + * > > + * @return > > + * NULL on error. > > + * On success, a pointer value which can later be used to remove the > > callback. > > + */ > > + > > +__rte_experimental > > +struct rte_cryptodev_enq_callback * > > +rte_cryptodev_add_enq_callback(uint8_t dev_id, > > + uint16_t qp_id, > > + rte_cryptodev_enq_cb_fn cb_fn, > > + void *cb_arg); > > + > > + > > +/** > > + * @warning > > + * @b EXPERIMENTAL: this API may change without prior notice > > + * > > + * Remove a user callback function for given crypto device and queue p= air. > > + * > > + * This function is used to removed callbacks that were added to a > > +crypto > > + * device queue pair using rte_cryptodev_add_enq_callback(). > > + * > > + * Note: The callback expects a RCU QSBR to be configured to > > +synchronize > > + * to free the memory. Application is expected to configure RCU QSBR > > +after > > + * adding an enqueue callback. The application could configure RCU QSBR any time before 'rte_cryptodev_rem= ove_enq_callback' is called. It has no relation to 'rte_cryptodev_add_enq_c= allback' > > + * > > + * > > + * @param dev_id The identifier of the device. > > + * @param qp_id The index of the queue pair in which ops are > > + * to be enqueued for processing. The value > > + * must be in the range [0, nb_queue_pairs - 1] > > + * previously supplied to > > + * *rte_cryptodev_configure*. > > + * @param cb Pointer to user supplied callback created via > > + * rte_cryptodev_add_enq_callback(). > > + * > > + * @return > > + * - 0: Success. Callback was removed. > > + * - -EINVAL: The dev_id or the qp_id is out of range, or the callb= ack > > + * is NULL or not found for the crypto device queue pair= . Add RCU variable not configured. > > + */ > > + > > +__rte_experimental > > +int rte_cryptodev_remove_enq_callback(uint8_t dev_id, > > + uint16_t qp_id, > > + struct rte_cryptodev_enq_callback *cb); > > + > > + > > +/** > > + * @warning > > + * @b EXPERIMENTAL: this API may change without prior notice > > + * > > + * Associate RCU QSBR variable with a cryptodev. > > + * > > + * This function is used to add RCU QSBR to a crypto device. > > + * The purpose of RCU is to help multiple threads to synchronize > > + * with each other before initiating adding/removing callback > > + * while dataplane threads are running enqueue callbacks. How about the following to replace the last sentence above? "RCU is used to safely reclaim the memory shared with the data plane thread= s." > > + * > > + * @param dev_id The identifier of the device. > > + * @param qsr RCU QSBR configuration ^^^ qsbr ^^^^^= ^^^^^^ 'variable' is a better choice > > + * @return > > + * On success - 0 > > + * On error - EINVAL. > > + */ > > + > > +__rte_experimental > > +int rte_cryptodev_rcu_qsbr_add(uint8_t dev_id, struct rte_rcu_qsbr > > +*qsbr); #endif > > + > > #ifdef __cplusplus > > } > > #endif > > diff --git a/lib/librte_cryptodev/rte_cryptodev_version.map > > b/lib/librte_cryptodev/rte_cryptodev_version.map > > index 02f6dcf..46de3ca 100644 > > --- a/lib/librte_cryptodev/rte_cryptodev_version.map > > +++ b/lib/librte_cryptodev/rte_cryptodev_version.map > > @@ -64,6 +64,7 @@ DPDK_20.0 { > > rte_cryptodev_sym_capability_get; > > }; > > > > + > > EXPERIMENTAL { > > global: > > > > @@ -105,4 +106,9 @@ EXPERIMENTAL { > > > > # added in 20.08 > > rte_cryptodev_get_qp_status; > > + > > + # added in 20.11 > > + rte_cryptodev_add_enq_callback; > > + rte_cryptodev_remove_enq_callback; > > + rte_cryptodev_rcu_qsbr_add; > > }; > > -- > > 1.9.1