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 558FEA00C3; Fri, 17 Jun 2022 19:05:10 +0200 (CEST) Received: from [217.70.189.124] (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id 085A642905; Fri, 17 Jun 2022 19:05:04 +0200 (CEST) Received: from mga17.intel.com (mga17.intel.com [192.55.52.151]) by mails.dpdk.org (Postfix) with ESMTP id E079041148 for ; Fri, 17 Jun 2022 19:05:01 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1655485502; x=1687021502; h=from:to:cc:subject:date:message-id:references: in-reply-to:content-transfer-encoding:mime-version; bh=sX/cSAjmDDYOn4KBXLK47vT4aItAGHvdWHXu4X6PoZY=; b=h0h4mTlq8FF/wx6O5gh2PMDZUMi/IQY128w0ZPuao9r5kcfoXL/XJRNV VhdWO7aqPLFWE/mYwUhQrUFobXnPvNL+7/hWqxonDjQUoeddOGK1MskZv 8CA5c283c3NgNqASF8LJoz2d2kpL0a56juxYlwb6NBJoWamzBELZJVUYu k/SKXGHjqgop5UygnjGzdRfqNfgFvmGSFsivG9fDnn4QfewP3BoLQRggS NZdSEh2EC5bF8JyMHL8vkUcb/l964+GspKOTNHYv8JB1DhT1/UbueVvV0 ufQx2dS4z90Tn7SoR1RfK9oDZ4Ckevt+JUPUuMrWPaYmyLHxYc5+UByBk Q==; X-IronPort-AV: E=McAfee;i="6400,9594,10380"; a="259937947" X-IronPort-AV: E=Sophos;i="5.92,306,1650956400"; d="scan'208";a="259937947" Received: from orsmga002.jf.intel.com ([10.7.209.21]) by fmsmga107.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 17 Jun 2022 05:35:30 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.92,306,1650956400"; d="scan'208";a="577830126" Received: from orsmsx604.amr.corp.intel.com ([10.22.229.17]) by orsmga002.jf.intel.com with ESMTP; 17 Jun 2022 05:35:30 -0700 Received: from orsmsx611.amr.corp.intel.com (10.22.229.24) by ORSMSX604.amr.corp.intel.com (10.22.229.17) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2308.27; Fri, 17 Jun 2022 05:35:30 -0700 Received: from orsmsx603.amr.corp.intel.com (10.22.229.16) by ORSMSX611.amr.corp.intel.com (10.22.229.24) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2308.27; Fri, 17 Jun 2022 05:35:29 -0700 Received: from ORSEDG601.ED.cps.intel.com (10.7.248.6) by orsmsx603.amr.corp.intel.com (10.22.229.16) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2308.27 via Frontend Transport; Fri, 17 Jun 2022 05:35:29 -0700 Received: from NAM02-BN1-obe.outbound.protection.outlook.com (104.47.51.41) by edgegateway.intel.com (134.134.137.102) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.1.2308.27; Fri, 17 Jun 2022 05:35:29 -0700 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=V0e/9zX5KZWopn29zyvUSekRx+be5rCcDfnJgjW0Q9UNU/fgWSjYRn6cRrip/UChsIxkj2uELK/h5QtA6O6+bM4z9mLy5iZ407nXOyhB7N6QMOHTpfOEBIxIfqBZ6pfADSrufqfqN21vxunkW5MTOted3TLutxNrsYaNseqXZIy7vMGQCxbLfHHDZWSUgvHqOkb7IdSIrDBVSFrkkhrHhQEYVe7j4h1j6MVRh/2XH9zSGaVlUKie5UWNtv4gLhg6CHoeFRMEbskr7kQPylFDIXZwg6lHTeVtoDvFnaBHGdQpALMslIOZLest65YUiRr2eiLjPm2gWHJIvmzmwJqtGw== 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=EEjcmn62q3rHlueQUPpCwXew5NLLAWNjNJzpvYWMnsM=; b=aGsN778IeOggmq8ePoaDhYDsKxS0ewdBMxgQDE2j/gZ+J3iKJ6HHLAufQSUxhqCmQLnnZ2r9P89NSJfNHQvG7VFri37nW3sqlumf3j5lC6uI8X1Xldi/IpESaAZpWjApPBAbKh2ibiXGlteGAE2bTidVKlRID9tknCuZSGVqDAO8z/TJv5yQoWmke2yQCaMcELGa3Xa67pnKgA5mk14BGqYp0F7XwkgtMdT27yC0iN6Epdgbe6/UByZlPmU0SiUi9V/QFL2w231yVrllm+EoW4Jw2vXfe/xK3VLR0oBvSrCAYTkGGLovProba/DUXbA9qmrv0aG0qz3nwhjGTwqwRA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=intel.com; dmarc=pass action=none header.from=intel.com; dkim=pass header.d=intel.com; arc=none Received: from PH7PR11MB5817.namprd11.prod.outlook.com (2603:10b6:510:13a::14) by BYAPR11MB3704.namprd11.prod.outlook.com (2603:10b6:a03:f9::29) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5332.15; Fri, 17 Jun 2022 12:35:27 +0000 Received: from PH7PR11MB5817.namprd11.prod.outlook.com ([fe80::6024:7f58:ffc6:64ce]) by PH7PR11MB5817.namprd11.prod.outlook.com ([fe80::6024:7f58:ffc6:64ce%2]) with mapi id 15.20.5332.020; Fri, 17 Jun 2022 12:35:26 +0000 From: "Zhang, Roy Fan" To: "Kusztal, ArkadiuszX" , "dev@dpdk.org" CC: "gakhil@marvell.com" Subject: RE: [PATCH] test/crypto: add key exchange dh tests Thread-Topic: [PATCH] test/crypto: add key exchange dh tests Thread-Index: AQHYSlaKheoS8Xs5uUCJ4vJrEZWscq1T+J3A Date: Fri, 17 Jun 2022 12:35:26 +0000 Message-ID: References: <20220407080722.18697-1-arkadiuszx.kusztal@intel.com> In-Reply-To: <20220407080722.18697-1-arkadiuszx.kusztal@intel.com> Accept-Language: zh-Hans-HK, en-US Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: dlp-version: 11.6.500.17 dlp-reaction: no-action dlp-product: dlpe-windows authentication-results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=intel.com; x-ms-publictraffictype: Email x-ms-office365-filtering-correlation-id: 466ae498-4f8e-4f98-ae80-08da505ddb5d x-ms-traffictypediagnostic: BYAPR11MB3704:EE_ x-microsoft-antispam-prvs: x-ms-exchange-senderadcheck: 1 x-ms-exchange-antispam-relay: 0 x-microsoft-antispam: BCL:0; x-microsoft-antispam-message-info: OW014YrsAmeF2ucuNOtWvBoEGyXhQvhOJSEL6ICRglsB+m2sjxAmOKSOFssbNyNnA9E8ar+g2abEgOKxz4hZXpHt7mAwKnSdQgo+KlxVkQkK5P9ouof+fQs7/Q8k1Pl58g0NJ0hFmK4RyEPySGx0eIPShUztYc17QeLhaBPvOeKN0p3Gt5mspFuNU7d1I66mlFUehBwz9QDm2EAV0rBxGNun3gtS2CiTltUiFCox7VeowRnCb53N9SAP1kOC7DPLk3CS8FOBkqyDIt/kdnkE+c/rzZkt2N2loKQbbEowOVY53SZF34Ch+Gq6381S9t08M05cDcvoSGm3TP/MOSC4P51sgioFBpv9YLfMtdWeRcgTWoCVonoxCDX9Xplqmrl7rTRMlSkeI5VcpAqqSdGPLPXqWCjZurtKgipEEt8SerVmWYtHnD+o7YGzH1iPT82bWeXWZ0eZ4jWJJYKrTtlWqMzmEOZDVoD0MjQa9m9OwpwhUVllcuxNU6OZ7dNlLCIsXZWMHknpx/G15rehAQAxh4w5U2eUgEe9jVPMegrYKOGQfZqJF9tbtdEtdDO/Iwv8iyERch2GWypdRjzMFOg2DOCq7yrB8BkztaNi9C+9JiU9b17+rZT4cFYinicENkBnVu/Gx8PmV2skNlfZcOhYpMoK5mHGmw3pnKbXDfWe9yQ78boJph/62dvcVAK9KX7Adu9kDffoXSx7JhuSv1PZtQ== x-forefront-antispam-report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:PH7PR11MB5817.namprd11.prod.outlook.com; PTR:; CAT:NONE; SFS:(13230016)(366004)(7696005)(122000001)(26005)(66946007)(8676002)(82960400001)(9686003)(186003)(76116006)(66476007)(8936002)(5660300002)(2906002)(53546011)(66556008)(64756008)(66446008)(38070700005)(52536014)(6506007)(55016003)(33656002)(86362001)(4326008)(83380400001)(38100700002)(30864003)(316002)(498600001)(71200400001)(110136005)(559001)(579004); DIR:OUT; SFP:1102; x-ms-exchange-antispam-messagedata-chunkcount: 1 x-ms-exchange-antispam-messagedata-0: =?Windows-1252?Q?sgm0Hb+qL7xYUnETkKj0XqGzS5tz65ElxfMZFR/3kXM+odGA7B8+tQyH?= =?Windows-1252?Q?0p+x74ovowZd+3u1tGrpZx+IxBIrP5L1/jcahyBAkmlZygnOidUiRPKx?= =?Windows-1252?Q?dFMvOR89DMAHXnv9MW16ShOOImZO90AKS5Dlucljg8GKG9nqpNmz9vSr?= =?Windows-1252?Q?GC+H2yfI1rZkYWC2/5Odaut1ZogQfBhKRcmDsoGO0FSF1CK0LmqQXle0?= =?Windows-1252?Q?6fQD6MeIW818G+g7bsIOCySGDAi/GxaZGEz8vw3Rk2U8apd/TR2QANKK?= =?Windows-1252?Q?uYtzLcnAyjTYtmINooEIfaWe6grsbAH47Z4m8JYWjKnfqlkBvDfd3RuZ?= =?Windows-1252?Q?nPinCN0MPigJjzlh8RHe0box2UEmVM6xYvSTJtkO28fhfbGMy87K399y?= =?Windows-1252?Q?oPJ+/VTvyGru6W7XDZKikruOwW088AIgwk3P8pGjFGgcRXyW0ImMTXDZ?= =?Windows-1252?Q?hbPct0V7J5ETF3nZCr3s9fmFY/M8525zcMDPpsKZoUbpBaRnh6ZulbzD?= =?Windows-1252?Q?PjXDlbz6yfYEUMA1TdJPsCw/A4JGYLLF6sJKAtTaJS8LJtkBStPF8f2E?= =?Windows-1252?Q?m3bvLmrd5o3/c0v34lFQjffBZ3oLbBZCmJlg0pzzWR91E0ggMlAM04Z+?= =?Windows-1252?Q?yczfid1kJ8gCzQsmD4t/X78dC3PHQ10Ba5K21BNn9u0Jsv+6MaP1zMcG?= =?Windows-1252?Q?wt7V2AWCw7b3s/xRu9dd/nRM842fsR1raubCtwKN/vhjlbcRxLDTFvnz?= =?Windows-1252?Q?yYQaKJoJcZyVWInvJgjj/deLVS93kGyUOPTpfbZwZBqls68IWZ9+XdOD?= =?Windows-1252?Q?h30k63ZUW9Q7SsxY0TCiPKznGQqxwNYam4y9pnXQhW2hWA+YFLwaEhyf?= =?Windows-1252?Q?cfJ6OQ9i7BkFVTijTIWEnpLSSMZz4rGkHzKSTbLh+w/jJixtVTA+Gikr?= =?Windows-1252?Q?iirK7AUggVx9RqT89qnTDHFXRJ7MQkM4Et2r8Bzrl4RAXukhpZFHf9KX?= =?Windows-1252?Q?8CmttVrxpJOyJ7XkcuZwnPt5yyYU4EQloIPJ7zXINR367mPipYTy3kno?= =?Windows-1252?Q?q5k7sQWOa5ePVIHFm8k+rABN99SWcyf7nZmIbhSgzMfg16Ap8B4BHmSo?= =?Windows-1252?Q?uVd16by/XKTeJftWJQC6t9v5gCWgn1fwHNWyltqD7zKX0Z84L986122x?= =?Windows-1252?Q?bQ1LlLqw+5UdxBQ2/ajPjCdWRm5rQ2x6EV2+lD1uVjo0iq5LzPSsn5kc?= =?Windows-1252?Q?o3cUfSTmg5/uNUv9qR8hPU436BNjM5xGofZUvJrl7x43QUlxd1tbNWKY?= =?Windows-1252?Q?gHzmuAeCJVxNHyK49cgL4uH9nEqGo+xRN0KCeEwfL14rn9hy8gLr+US+?= =?Windows-1252?Q?JP5IcT7kuFLbWYde4mygmM7qAd+4fL3EpFONXNC7naFVgd3BDfB/82kj?= =?Windows-1252?Q?FMyWc7qdGQDbW3WcTi5s7i01nVF7tOUWh0mHCvnqzcpDDCxmOh3rTgrs?= =?Windows-1252?Q?zRq3v0Hb602yULP+d+NVF2A6VN5gk+ZedUD9hiTk9rP+To7zeONKlR7J?= =?Windows-1252?Q?vArO+UyGJN6NnyB4vcK9bBGe7vH5YuVAq2tHy3w68tiIH4x10T4Cl+60?= =?Windows-1252?Q?/d7FeTYhqgVKY3pEZloHsjSJjSP/mziF0emXMxQtguaKYD/Ln+qFIZey?= =?Windows-1252?Q?83bKBV1cbnuLNs4nhZ5JZIcZCe64HOwCrS5v3G5Ymk64Ugq3cDYaT/Ys?= =?Windows-1252?Q?8wtCLll0Q0uSwIQGNszMOgMRH8o7i/XrkJye/PXSCbRPXMkEoV3R1jRT?= =?Windows-1252?Q?KsDdoIp+wgHqjN7qf+PMr7n+Bf3exoNQzNBpnzhbx+nosPC+PyeoywzD?= =?Windows-1252?Q?RnDeJ3hG9klQsg=3D=3D?= Content-Type: text/plain; charset="Windows-1252" Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-AuthSource: PH7PR11MB5817.namprd11.prod.outlook.com X-MS-Exchange-CrossTenant-Network-Message-Id: 466ae498-4f8e-4f98-ae80-08da505ddb5d X-MS-Exchange-CrossTenant-originalarrivaltime: 17 Jun 2022 12:35:26.8720 (UTC) X-MS-Exchange-CrossTenant-fromentityheader: Hosted X-MS-Exchange-CrossTenant-id: 46c98d88-e344-4ed4-8496-4ed7712e255d X-MS-Exchange-CrossTenant-mailboxtype: HOSTED X-MS-Exchange-CrossTenant-userprincipalname: fnLUZevaIjPJ/atvQFWzdv4y+hXOIfGAn8T5v6PrdtFw9HzI7tPgD+Fs6s/KtKxajXeRRQ2Iq9VMBBakguJdcA== X-MS-Exchange-Transport-CrossTenantHeadersStamped: BYAPR11MB3704 X-OriginatorOrg: intel.com 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 Hi Arek, The patch cannot compile.=20 Looks like there are some inconsistency between the merged asym crypto chan= ge and your test code. Can you rebase? Regards, Fan > -----Original Message----- > From: Kusztal, ArkadiuszX > Sent: Thursday, April 7, 2022 9:07 AM > To: dev@dpdk.org > Cc: gakhil@marvell.com; Zhang, Roy Fan ; Kusztal= , > ArkadiuszX > Subject: [PATCH] test/crypto: add key exchange dh tests >=20 > This patch adds Diffie-Hellman key exchange tests. > Alice's and Bob's private keys are generated in tests, > public keys are then generated followed by shared secret. > Alice's and Bob's shared secret are then compared to obtain > result of the test. >=20 > This test should be easy to extend to use ECDH. >=20 > Signed-off-by: Arek Kusztal > --- > app/test/test_cryptodev_asym.c | 266 ++++++++++++++++++++++++= ++ > app/test/test_cryptodev_dh_test_vectors.h | 305 > ++++++++++++++++++++++++++++++ > 2 files changed, 571 insertions(+) >=20 > diff --git a/app/test/test_cryptodev_asym.c b/app/test/test_cryptodev_asy= m.c > index 573af2a537..1665709469 100644 > --- a/app/test/test_cryptodev_asym.c > +++ b/app/test/test_cryptodev_asym.c > @@ -5,6 +5,9 @@ >=20 > #ifndef RTE_EXEC_ENV_WINDOWS >=20 > +#include > +#include > + > #include > #include > #include > @@ -35,6 +38,29 @@ > #define ASYM_TEST_MSG_LEN 256 > #define TEST_VECTOR_SIZE 256 >=20 > +#define TEST_CRYPTO_ASYM_NULL_RETURN(p, str) \ > + do { \ > + if (p =3D=3D NULL) { \ > + RTE_LOG(ERR, USER1, "line %u FAILED: %s", \ > + __LINE__, str); \ > + status =3D (ret =3D=3D -ENOTSUP) ? \ > + TEST_SKIPPED : TEST_FAILED; \ > + goto error_exit; \ > + } \ > + } while (0) > + > +#define TEST_CRYPTO_ASYM_NEG_RETURN(p, str) \ > + do { \ > + if (p) { \ > + RTE_LOG(ERR, USER1, \ > + "line %u FAILED: %s", \ > + __LINE__, str); \ > + status =3D (ret =3D=3D -ENOTSUP) ? \ > + TEST_SKIPPED : TEST_FAILED; \ > + goto error_exit; \ > + } \ > + } while (0) > + > static int gbl_driver_id; > struct crypto_testsuite_params_asym { > struct rte_mempool *op_mpool; > @@ -66,6 +92,39 @@ static uint32_t test_index; >=20 > static struct crypto_testsuite_params_asym testsuite_params =3D { NULL }= ; >=20 > +static void > +test_crypto_rand(int len, uint8_t *buffer) > +{ > + int i; > + > + for (i =3D 0; i < len; ++i) > + buffer[i] =3D (uint8_t)(rand() % ((uint8_t)-1)) | 1; > +} > + > +static int > +process_crypto_request(uint8_t dev_id, struct rte_crypto_op **op, > + struct rte_crypto_op **result_op) > +{ > + /* Process crypto operation */ > + if (rte_cryptodev_enqueue_burst(dev_id, 0, op, 1) !=3D 1) { > + RTE_LOG(ERR, USER1, > + "line %u FAILED: %s", > + __LINE__, "Error sending packet for operation"); > + return -1; > + } > + > + while (rte_cryptodev_dequeue_burst(dev_id, 0, result_op, 1) =3D=3D 0) > + rte_pause(); > + > + if (*result_op =3D=3D NULL) { > + RTE_LOG(ERR, USER1, > + "line %u FAILED: %s", > + __LINE__, "Failed to process asym crypto op"); > + return -1; > + } > + return 0; > +} > + > static int > queue_ops_rsa_sign_verify(void *sess) > { > @@ -809,6 +868,7 @@ testsuite_setup(void) >=20 > memset(ts_params, 0, sizeof(*ts_params)); >=20 > + srand(time(NULL)); > test_vector.size =3D 0; > load_test_vectors(); >=20 > @@ -2136,6 +2196,196 @@ test_ecpm_all_curve(void) > return overall_status; > } >=20 > +static int > +test_dh_set_session(uint8_t dev_id, void **sess, > + struct rte_crypto_op *op, struct rte_crypto_asym_xform > *xform, > + const struct test_dh_group *group, > + enum rte_crypto_asym_op_type type) > +{ > + int ret =3D 0; > + > + xform->xform_type =3D RTE_CRYPTO_ASYM_XFORM_DH; > + xform->dh.g.data =3D group->g.data; > + xform->dh.g.length =3D group->g.bytesize; > + xform->dh.p.data =3D group->p.data; > + xform->dh.p.length =3D group->p.bytesize; > + xform->dh.type =3D type; > + ret =3D rte_cryptodev_asym_session_create(dev_id, xform, > + testsuite_params.session_mpool, sess); > + if (ret) > + return -1; > + rte_crypto_op_attach_asym_session(op, *sess); > + > + return 0; > +} > + > +static int > +test_dh_pub_compute(const char *str, uint8_t dev_id, struct rte_crypto_o= p > **op, > + int priv_size, uint8_t *private, > + int result_size, uint8_t *result) > +{ > + struct rte_crypto_op *result_op; > + struct rte_crypto_asym_op *asym_op =3D (*op)->asym; > + > + asym_op->dh.priv_key.data =3D private; > + asym_op->dh.priv_key.length =3D priv_size; > + asym_op->dh.pub_key.data =3D result; > + asym_op->dh.pub_key.length =3D result_size; > + > + if (process_crypto_request(dev_id, op, &result_op)) > + return -1; > + > + result_size =3D asym_op->dh.pub_key.length; > + debug_hexdump(stdout, str, > + asym_op->dh.pub_key.data, > + result_size); > + return result_size; > +} > + > +static int > +test_dh_shared_compute(const char *str, > + uint8_t dev_id, struct rte_crypto_op **op, > + int priv_size, uint8_t *private, int pub_size, uint8_t *public, > + int result_size, uint8_t *result) > +{ > + struct rte_crypto_op *result_op; > + struct rte_crypto_asym_op *asym_op =3D (*op)->asym; > + > + asym_op->dh.priv_key.data =3D private; > + asym_op->dh.priv_key.length =3D priv_size; > + asym_op->dh.pub_key.data =3D public; > + asym_op->dh.pub_key.length =3D pub_size; > + asym_op->dh.shared_secret.data =3D result; > + asym_op->dh.shared_secret.length =3D result_size; > + > + if (process_crypto_request(dev_id, op, &result_op)) > + return -1; > + > + result_size =3D asym_op->dh.shared_secret.length; > + debug_hexdump(stdout, str, > + asym_op->dh.shared_secret.data, > + result_size); > + return result_size; > +} > + > +static int > +test_dh_alice_and_bob_loop(const struct test_dh_group *test_dh_group, > + uint32_t divisor) > +{ > + uint8_t alice_private[test_dh_group->priv_ff_size]; > + uint8_t bob_private[test_dh_group->priv_ff_size]; > + uint8_t pub_key_alice[TEST_DH_MOD_LEN] =3D { }; > + uint8_t pub_key_bob[TEST_DH_MOD_LEN] =3D { }; > + uint8_t shared_secret_alice[TEST_DH_MOD_LEN] =3D { }; > + uint8_t shared_secret_bob[TEST_DH_MOD_LEN] =3D { }; > + struct rte_crypto_asym_xform xform; > + struct rte_crypto_asym_op *asym_op =3D NULL; > + struct rte_crypto_op *op =3D NULL; > + void *sess =3D NULL; > + int alice_pub_len =3D 0, bob_pub_len =3D 0, > + alice_shared_len =3D 0, bob_shared_len =3D 0; > + int alice_private_size =3D 0, bob_private_size =3D 0; > + int ret =3D 0, status =3D TEST_SUCCESS; > + uint8_t dev_id =3D testsuite_params.valid_devs[0]; > + > + TEST_CRYPTO_ASYM_NEG_RETURN(test_dh_group->p.data[0] =3D=3D 0, > + "Incorrect DH group."); > + > + alice_private_size =3D bob_private_size =3D > + test_dh_group->priv_ff_size / divisor; > + /* Generate private keys */ > + test_crypto_rand(alice_private_size, alice_private); > + if (alice_private[0] > test_dh_group->p.data[0]) > + alice_private[0] =3D test_dh_group->p.data[0] - 1; > + > + debug_hexdump(stdout, "Alice's private", alice_private, > + alice_private_size); > + test_crypto_rand(bob_private_size, bob_private); > + if (bob_private[0] > test_dh_group->p.data[0]) > + bob_private[0] =3D test_dh_group->p.data[0] - 1; > + > + debug_hexdump(stdout, "Bob's private", bob_private, > + bob_private_size); > + > + /* set up crypto op data structure */ > + op =3D rte_crypto_op_alloc(testsuite_params.op_mpool, > + RTE_CRYPTO_OP_TYPE_ASYMMETRIC); > + TEST_CRYPTO_ASYM_NULL_RETURN(op, > + "Failed to allocate asymmetric crypto operation struct"); > + > + op->sess_type =3D RTE_CRYPTO_OP_WITH_SESSION; > + asym_op =3D op->asym; > + > + /* Generate public keys of Alice and Bob */ > + ret =3D test_dh_set_session(dev_id, &sess, op, &xform, > + test_dh_group, > RTE_CRYPTO_ASYM_OP_PUBLIC_KEY_GENERATE); > + TEST_CRYPTO_ASYM_NEG_RETURN(ret, "Session creation failed."); > + > + alice_pub_len =3D test_dh_pub_compute("Alice's public key", dev_id, > &op, > + alice_private_size, alice_private, > + sizeof(pub_key_alice), pub_key_alice); > + bob_pub_len =3D test_dh_pub_compute("Bob's public key", dev_id, &op, > + bob_private_size, bob_private, > + sizeof(pub_key_bob), pub_key_bob); > + rte_cryptodev_asym_session_free(dev_id, sess); > + > + /* Generate shared secrets */ > + ret =3D test_dh_set_session(dev_id, &sess, op, &xform, > + test_dh_group, > RTE_CRYPTO_ASYM_OP_SHARED_SECRET_COMPUTE); > + TEST_CRYPTO_ASYM_NEG_RETURN(ret, "Session creation failed."); > + > + alice_shared_len =3D test_dh_shared_compute("Alice's shared key", > dev_id, > + &op, alice_private_size, alice_private, > + bob_pub_len, pub_key_bob, > + sizeof(shared_secret_alice), shared_secret_alice); > + > + bob_shared_len =3D test_dh_shared_compute("Bob's shared key", dev_id, > + &op, bob_private_size, bob_private, > + alice_pub_len, pub_key_alice, > + sizeof(shared_secret_bob), shared_secret_bob); > + > + /* Check results */ > + ret =3D (alice_shared_len =3D=3D bob_shared_len); > + TEST_CRYPTO_ASYM_NEG_RETURN(!ret, > + "Alice's and Bob's shared secret length do not match."); > + ret =3D memcmp(shared_secret_alice, shared_secret_bob, > + asym_op->dh.shared_secret.length); > + TEST_CRYPTO_ASYM_NEG_RETURN(ret, > + "Alice's and Bob's shared secret do not match."); > + > +error_exit: > + if (sess !=3D NULL) > + rte_cryptodev_asym_session_free(dev_id, sess); > + if (op !=3D NULL) > + rte_crypto_op_free(op); > + return status; > +} > + > +static int > +test_dh_alice_and_bob(const void *test_data) > +{ > + const struct test_dh_group *test_dh_group =3D test_data; > + uint32_t i =3D 0; > + int ret =3D 1; > + > + uint32_t divisor[] =3D { 64, 32, 16, 4, 2, 1 }; > + > + for (i =3D 0; i < RTE_DIM(divisor); i++) { > + if (divisor[i] >=3D test_dh_group->priv_ff_size) > + continue; > + > + ret =3D test_dh_alice_and_bob_loop(test_dh_group, divisor[i]); > + > + if (ret) { > + RTE_LOG(ERR, USER1, "line %u FAILED: %s", __LINE__, > + "Diffie-Hellman error"); > + return TEST_FAILED; > + } > + } > + return ret; > +} > + > + > static struct unit_test_suite cryptodev_openssl_asym_testsuite =3D { > .suite_name =3D "Crypto Device OPENSSL ASYM Unit Test Suite", > .setup =3D testsuite_setup, > @@ -2155,6 +2405,22 @@ static struct unit_test_suite > cryptodev_openssl_asym_testsuite =3D { > TEST_CASE_ST(ut_setup_asym, ut_teardown_asym, > test_mod_inv), > TEST_CASE_ST(ut_setup_asym, ut_teardown_asym, > test_mod_exp), > TEST_CASE_ST(ut_setup_asym, ut_teardown_asym, > test_one_by_one), > + TEST_CASE_NAMED_WITH_DATA( > + "Diffie-Hellman Alice and Bob group 14 ikev2 > test", > + ut_setup_asym, ut_teardown_asym, > + test_dh_alice_and_bob, > &test_dh_ikev2group_14), > + TEST_CASE_NAMED_WITH_DATA( > + "Diffie-Hellman Alice and Bob group 15 ikev2 > test", > + ut_setup_asym, ut_teardown_asym, > + test_dh_alice_and_bob, > &test_dh_ikev2group_15), > + TEST_CASE_NAMED_WITH_DATA( > + "Diffie-Hellman Alice and Bob group 16 ikev2 > test", > + ut_setup_asym, ut_teardown_asym, > + test_dh_alice_and_bob, > &test_dh_ikev2group_16), > + TEST_CASE_NAMED_WITH_DATA( > + "Diffie-Hellman Alice and Bob group 24 ikev2 > test", > + ut_setup_asym, ut_teardown_asym, > + test_dh_alice_and_bob, > &test_dh_ikev2group_24), > TEST_CASES_END() /**< NULL terminate unit test array */ > } > }; > diff --git a/app/test/test_cryptodev_dh_test_vectors.h > b/app/test/test_cryptodev_dh_test_vectors.h > index fe7510dcd3..8910919461 100644 > --- a/app/test/test_cryptodev_dh_test_vectors.h > +++ b/app/test/test_cryptodev_dh_test_vectors.h > @@ -10,11 +10,316 @@ > #define TEST_DATA_SIZE 4096 > #define TEST_DH_MOD_LEN 1024 >=20 > +struct test_dh_group { > + int id; > + struct { > + uint8_t *data; > + uint32_t bytesize; > + } g; > + struct { > + uint8_t *data; > + uint32_t bytesize; > + } p; > + uint32_t priv_ff_size; > +}; >=20 > struct dh_test_param { > rte_crypto_param priv_key; > }; >=20 > +static uint8_t test_dh_gen_2[] =3D { > + 0x2, > +}; > + > +static uint8_t test_dh_ikev2group14_p[] =3D { > + 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, > + 0xC9, 0x0F, 0xDA, 0xA2, 0x21, 0x68, 0xC2, 0x34, > + 0xC4, 0xC6, 0x62, 0x8B, 0x80, 0xDC, 0x1C, 0xD1, > + 0x29, 0x02, 0x4E, 0x08, 0x8A, 0x67, 0xCC, 0x74, > + 0x02, 0x0B, 0xBE, 0xA6, 0x3B, 0x13, 0x9B, 0x22, > + 0x51, 0x4A, 0x08, 0x79, 0x8E, 0x34, 0x04, 0xDD, > + 0xEF, 0x95, 0x19, 0xB3, 0xCD, 0x3A, 0x43, 0x1B, > + 0x30, 0x2B, 0x0A, 0x6D, 0xF2, 0x5F, 0x14, 0x37, > + 0x4F, 0xE1, 0x35, 0x6D, 0x6D, 0x51, 0xC2, 0x45, > + 0xE4, 0x85, 0xB5, 0x76, 0x62, 0x5E, 0x7E, 0xC6, > + 0xF4, 0x4C, 0x42, 0xE9, 0xA6, 0x37, 0xED, 0x6B, > + 0x0B, 0xFF, 0x5C, 0xB6, 0xF4, 0x06, 0xB7, 0xED, > + 0xEE, 0x38, 0x6B, 0xFB, 0x5A, 0x89, 0x9F, 0xA5, > + 0xAE, 0x9F, 0x24, 0x11, 0x7C, 0x4B, 0x1F, 0xE6, > + 0x49, 0x28, 0x66, 0x51, 0xEC, 0xE4, 0x5B, 0x3D, > + 0xC2, 0x00, 0x7C, 0xB8, 0xA1, 0x63, 0xBF, 0x05, > + 0x98, 0xDA, 0x48, 0x36, 0x1C, 0x55, 0xD3, 0x9A, > + 0x69, 0x16, 0x3F, 0xA8, 0xFD, 0x24, 0xCF, 0x5F, > + 0x83, 0x65, 0x5D, 0x23, 0xDC, 0xA3, 0xAD, 0x96, > + 0x1C, 0x62, 0xF3, 0x56, 0x20, 0x85, 0x52, 0xBB, > + 0x9E, 0xD5, 0x29, 0x07, 0x70, 0x96, 0x96, 0x6D, > + 0x67, 0x0C, 0x35, 0x4E, 0x4A, 0xBC, 0x98, 0x04, > + 0xF1, 0x74, 0x6C, 0x08, 0xCA, 0x18, 0x21, 0x7C, > + 0x32, 0x90, 0x5E, 0x46, 0x2E, 0x36, 0xCE, 0x3B, > + 0xE3, 0x9E, 0x77, 0x2C, 0x18, 0x0E, 0x86, 0x03, > + 0x9B, 0x27, 0x83, 0xA2, 0xEC, 0x07, 0xA2, 0x8F, > + 0xB5, 0xC5, 0x5D, 0xF0, 0x6F, 0x4C, 0x52, 0xC9, > + 0xDE, 0x2B, 0xCB, 0xF6, 0x95, 0x58, 0x17, 0x18, > + 0x39, 0x95, 0x49, 0x7C, 0xEA, 0x95, 0x6A, 0xE5, > + 0x15, 0xD2, 0x26, 0x18, 0x98, 0xFA, 0x05, 0x10, > + 0x15, 0x72, 0x8E, 0x5A, 0x8A, 0xAC, 0xAA, 0x68, > + 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, > +}; > + > +static uint8_t test_dh_ikev2group15_p[] =3D { > + 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, > + 0xC9, 0x0F, 0xDA, 0xA2, 0x21, 0x68, 0xC2, 0x34, > + 0xC4, 0xC6, 0x62, 0x8B, 0x80, 0xDC, 0x1C, 0xD1, > + 0x29, 0x02, 0x4E, 0x08, 0x8A, 0x67, 0xCC, 0x74, > + 0x02, 0x0B, 0xBE, 0xA6, 0x3B, 0x13, 0x9B, 0x22, > + 0x51, 0x4A, 0x08, 0x79, 0x8E, 0x34, 0x04, 0xDD, > + 0xEF, 0x95, 0x19, 0xB3, 0xCD, 0x3A, 0x43, 0x1B, > + 0x30, 0x2B, 0x0A, 0x6D, 0xF2, 0x5F, 0x14, 0x37, > + 0x4F, 0xE1, 0x35, 0x6D, 0x6D, 0x51, 0xC2, 0x45, > + 0xE4, 0x85, 0xB5, 0x76, 0x62, 0x5E, 0x7E, 0xC6, > + 0xF4, 0x4C, 0x42, 0xE9, 0xA6, 0x37, 0xED, 0x6B, > + 0x0B, 0xFF, 0x5C, 0xB6, 0xF4, 0x06, 0xB7, 0xED, > + 0xEE, 0x38, 0x6B, 0xFB, 0x5A, 0x89, 0x9F, 0xA5, > + 0xAE, 0x9F, 0x24, 0x11, 0x7C, 0x4B, 0x1F, 0xE6, > + 0x49, 0x28, 0x66, 0x51, 0xEC, 0xE4, 0x5B, 0x3D, > + 0xC2, 0x00, 0x7C, 0xB8, 0xA1, 0x63, 0xBF, 0x05, > + 0x98, 0xDA, 0x48, 0x36, 0x1C, 0x55, 0xD3, 0x9A, > + 0x69, 0x16, 0x3F, 0xA8, 0xFD, 0x24, 0xCF, 0x5F, > + 0x83, 0x65, 0x5D, 0x23, 0xDC, 0xA3, 0xAD, 0x96, > + 0x1C, 0x62, 0xF3, 0x56, 0x20, 0x85, 0x52, 0xBB, > + 0x9E, 0xD5, 0x29, 0x07, 0x70, 0x96, 0x96, 0x6D, > + 0x67, 0x0C, 0x35, 0x4E, 0x4A, 0xBC, 0x98, 0x04, > + 0xF1, 0x74, 0x6C, 0x08, 0xCA, 0x18, 0x21, 0x7C, > + 0x32, 0x90, 0x5E, 0x46, 0x2E, 0x36, 0xCE, 0x3B, > + 0xE3, 0x9E, 0x77, 0x2C, 0x18, 0x0E, 0x86, 0x03, > + 0x9B, 0x27, 0x83, 0xA2, 0xEC, 0x07, 0xA2, 0x8F, > + 0xB5, 0xC5, 0x5D, 0xF0, 0x6F, 0x4C, 0x52, 0xC9, > + 0xDE, 0x2B, 0xCB, 0xF6, 0x95, 0x58, 0x17, 0x18, > + 0x39, 0x95, 0x49, 0x7C, 0xEA, 0x95, 0x6A, 0xE5, > + 0x15, 0xD2, 0x26, 0x18, 0x98, 0xFA, 0x05, 0x10, > + 0x15, 0x72, 0x8E, 0x5A, 0x8A, 0xAA, 0xC4, 0x2D, > + 0xAD, 0x33, 0x17, 0x0D, 0x04, 0x50, 0x7A, 0x33, > + 0xA8, 0x55, 0x21, 0xAB, 0xDF, 0x1C, 0xBA, 0x64, > + 0xEC, 0xFB, 0x85, 0x04, 0x58, 0xDB, 0xEF, 0x0A, > + 0x8A, 0xEA, 0x71, 0x57, 0x5D, 0x06, 0x0C, 0x7D, > + 0xB3, 0x97, 0x0F, 0x85, 0xA6, 0xE1, 0xE4, 0xC7, > + 0xAB, 0xF5, 0xAE, 0x8C, 0xDB, 0x09, 0x33, 0xD7, > + 0x1E, 0x8C, 0x94, 0xE0, 0x4A, 0x25, 0x61, 0x9D, > + 0xCE, 0xE3, 0xD2, 0x26, 0x1A, 0xD2, 0xEE, 0x6B, > + 0xF1, 0x2F, 0xFA, 0x06, 0xD9, 0x8A, 0x08, 0x64, > + 0xD8, 0x76, 0x02, 0x73, 0x3E, 0xC8, 0x6A, 0x64, > + 0x52, 0x1F, 0x2B, 0x18, 0x17, 0x7B, 0x20, 0x0C, > + 0xBB, 0xE1, 0x17, 0x57, 0x7A, 0x61, 0x5D, 0x6C, > + 0x77, 0x09, 0x88, 0xC0, 0xBA, 0xD9, 0x46, 0xE2, > + 0x08, 0xE2, 0x4F, 0xA0, 0x74, 0xE5, 0xAB, 0x31, > + 0x43, 0xDB, 0x5B, 0xFC, 0xE0, 0xFD, 0x10, 0x8E, > + 0x4B, 0x82, 0xD1, 0x20, 0xA9, 0x3A, 0xD2, 0xCA, > + 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, > +}; > + > +static uint8_t test_dh_ikev2group16_p[] =3D { > + 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, > + 0xC9, 0x0F, 0xDA, 0xA2, 0x21, 0x68, 0xC2, 0x34, > + 0xC4, 0xC6, 0x62, 0x8B, 0x80, 0xDC, 0x1C, 0xD1, > + 0x29, 0x02, 0x4E, 0x08, 0x8A, 0x67, 0xCC, 0x74, > + 0x02, 0x0B, 0xBE, 0xA6, 0x3B, 0x13, 0x9B, 0x22, > + 0x51, 0x4A, 0x08, 0x79, 0x8E, 0x34, 0x04, 0xDD, > + 0xEF, 0x95, 0x19, 0xB3, 0xCD, 0x3A, 0x43, 0x1B, > + 0x30, 0x2B, 0x0A, 0x6D, 0xF2, 0x5F, 0x14, 0x37, > + 0x4F, 0xE1, 0x35, 0x6D, 0x6D, 0x51, 0xC2, 0x45, > + 0xE4, 0x85, 0xB5, 0x76, 0x62, 0x5E, 0x7E, 0xC6, > + 0xF4, 0x4C, 0x42, 0xE9, 0xA6, 0x37, 0xED, 0x6B, > + 0x0B, 0xFF, 0x5C, 0xB6, 0xF4, 0x06, 0xB7, 0xED, > + 0xEE, 0x38, 0x6B, 0xFB, 0x5A, 0x89, 0x9F, 0xA5, > + 0xAE, 0x9F, 0x24, 0x11, 0x7C, 0x4B, 0x1F, 0xE6, > + 0x49, 0x28, 0x66, 0x51, 0xEC, 0xE4, 0x5B, 0x3D, > + 0xC2, 0x00, 0x7C, 0xB8, 0xA1, 0x63, 0xBF, 0x05, > + 0x98, 0xDA, 0x48, 0x36, 0x1C, 0x55, 0xD3, 0x9A, > + 0x69, 0x16, 0x3F, 0xA8, 0xFD, 0x24, 0xCF, 0x5F, > + 0x83, 0x65, 0x5D, 0x23, 0xDC, 0xA3, 0xAD, 0x96, > + 0x1C, 0x62, 0xF3, 0x56, 0x20, 0x85, 0x52, 0xBB, > + 0x9E, 0xD5, 0x29, 0x07, 0x70, 0x96, 0x96, 0x6D, > + 0x67, 0x0C, 0x35, 0x4E, 0x4A, 0xBC, 0x98, 0x04, > + 0xF1, 0x74, 0x6C, 0x08, 0xCA, 0x18, 0x21, 0x7C, > + 0x32, 0x90, 0x5E, 0x46, 0x2E, 0x36, 0xCE, 0x3B, > + 0xE3, 0x9E, 0x77, 0x2C, 0x18, 0x0E, 0x86, 0x03, > + 0x9B, 0x27, 0x83, 0xA2, 0xEC, 0x07, 0xA2, 0x8F, > + 0xB5, 0xC5, 0x5D, 0xF0, 0x6F, 0x4C, 0x52, 0xC9, > + 0xDE, 0x2B, 0xCB, 0xF6, 0x95, 0x58, 0x17, 0x18, > + 0x39, 0x95, 0x49, 0x7C, 0xEA, 0x95, 0x6A, 0xE5, > + 0x15, 0xD2, 0x26, 0x18, 0x98, 0xFA, 0x05, 0x10, > + 0x15, 0x72, 0x8E, 0x5A, 0x8A, 0xAA, 0xC4, 0x2D, > + 0xAD, 0x33, 0x17, 0x0D, 0x04, 0x50, 0x7A, 0x33, > + 0xA8, 0x55, 0x21, 0xAB, 0xDF, 0x1C, 0xBA, 0x64, > + 0xEC, 0xFB, 0x85, 0x04, 0x58, 0xDB, 0xEF, 0x0A, > + 0x8A, 0xEA, 0x71, 0x57, 0x5D, 0x06, 0x0C, 0x7D, > + 0xB3, 0x97, 0x0F, 0x85, 0xA6, 0xE1, 0xE4, 0xC7, > + 0xAB, 0xF5, 0xAE, 0x8C, 0xDB, 0x09, 0x33, 0xD7, > + 0x1E, 0x8C, 0x94, 0xE0, 0x4A, 0x25, 0x61, 0x9D, > + 0xCE, 0xE3, 0xD2, 0x26, 0x1A, 0xD2, 0xEE, 0x6B, > + 0xF1, 0x2F, 0xFA, 0x06, 0xD9, 0x8A, 0x08, 0x64, > + 0xD8, 0x76, 0x02, 0x73, 0x3E, 0xC8, 0x6A, 0x64, > + 0x52, 0x1F, 0x2B, 0x18, 0x17, 0x7B, 0x20, 0x0C, > + 0xBB, 0xE1, 0x17, 0x57, 0x7A, 0x61, 0x5D, 0x6C, > + 0x77, 0x09, 0x88, 0xC0, 0xBA, 0xD9, 0x46, 0xE2, > + 0x08, 0xE2, 0x4F, 0xA0, 0x74, 0xE5, 0xAB, 0x31, > + 0x43, 0xDB, 0x5B, 0xFC, 0xE0, 0xFD, 0x10, 0x8E, > + 0x4B, 0x82, 0xD1, 0x20, 0xA9, 0x21, 0x08, 0x01, > + 0x1A, 0x72, 0x3C, 0x12, 0xA7, 0x87, 0xE6, 0xD7, > + 0x88, 0x71, 0x9A, 0x10, 0xBD, 0xBA, 0x5B, 0x26, > + 0x99, 0xC3, 0x27, 0x18, 0x6A, 0xF4, 0xE2, 0x3C, > + 0x1A, 0x94, 0x68, 0x34, 0xB6, 0x15, 0x0B, 0xDA, > + 0x25, 0x83, 0xE9, 0xCA, 0x2A, 0xD4, 0x4C, 0xE8, > + 0xDB, 0xBB, 0xC2, 0xDB, 0x04, 0xDE, 0x8E, 0xF9, > + 0x2E, 0x8E, 0xFC, 0x14, 0x1F, 0xBE, 0xCA, 0xA6, > + 0x28, 0x7C, 0x59, 0x47, 0x4E, 0x6B, 0xC0, 0x5D, > + 0x99, 0xB2, 0x96, 0x4F, 0xA0, 0x90, 0xC3, 0xA2, > + 0x23, 0x3B, 0xA1, 0x86, 0x51, 0x5B, 0xE7, 0xED, > + 0x1F, 0x61, 0x29, 0x70, 0xCE, 0xE2, 0xD7, 0xAF, > + 0xB8, 0x1B, 0xDD, 0x76, 0x21, 0x70, 0x48, 0x1C, > + 0xD0, 0x06, 0x91, 0x27, 0xD5, 0xB0, 0x5A, 0xA9, > + 0x93, 0xB4, 0xEA, 0x98, 0x8D, 0x8F, 0xDD, 0xC1, > + 0x86, 0xFF, 0xB7, 0xDC, 0x90, 0xA6, 0xC0, 0x8F, > + 0x4D, 0xF4, 0x35, 0xC9, 0x34, 0x06, 0x31, 0x99, > + 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, > +}; > + > +static uint8_t test_dh_ikev2group24_p[] =3D { > + 0x87, 0xA8, 0xE6, 0x1D, 0xB4, 0xB6, 0x66, 0x3C, > + 0xFF, 0xBB, 0xD1, 0x9C, 0x65, 0x19, 0x59, 0x99, > + 0x8C, 0xEE, 0xF6, 0x08, 0x66, 0x0D, 0xD0, 0xF2, > + 0x5D, 0x2C, 0xEE, 0xD4, 0x43, 0x5E, 0x3B, 0x00, > + 0xE0, 0x0D, 0xF8, 0xF1, 0xD6, 0x19, 0x57, 0xD4, > + 0xFA, 0xF7, 0xDF, 0x45, 0x61, 0xB2, 0xAA, 0x30, > + 0x16, 0xC3, 0xD9, 0x11, 0x34, 0x09, 0x6F, 0xAA, > + 0x3B, 0xF4, 0x29, 0x6D, 0x83, 0x0E, 0x9A, 0x7C, > + 0x20, 0x9E, 0x0C, 0x64, 0x97, 0x51, 0x7A, 0xBD, > + 0x5A, 0x8A, 0x9D, 0x30, 0x6B, 0xCF, 0x67, 0xED, > + 0x91, 0xF9, 0xE6, 0x72, 0x5B, 0x47, 0x58, 0xC0, > + 0x22, 0xE0, 0xB1, 0xEF, 0x42, 0x75, 0xBF, 0x7B, > + 0x6C, 0x5B, 0xFC, 0x11, 0xD4, 0x5F, 0x90, 0x88, > + 0xB9, 0x41, 0xF5, 0x4E, 0xB1, 0xE5, 0x9B, 0xB8, > + 0xBC, 0x39, 0xA0, 0xBF, 0x12, 0x30, 0x7F, 0x5C, > + 0x4F, 0xDB, 0x70, 0xC5, 0x81, 0xB2, 0x3F, 0x76, > + 0xB6, 0x3A, 0xCA, 0xE1, 0xCA, 0xA6, 0xB7, 0x90, > + 0x2D, 0x52, 0x52, 0x67, 0x35, 0x48, 0x8A, 0x0E, > + 0xF1, 0x3C, 0x6D, 0x9A, 0x51, 0xBF, 0xA4, 0xAB, > + 0x3A, 0xD8, 0x34, 0x77, 0x96, 0x52, 0x4D, 0x8E, > + 0xF6, 0xA1, 0x67, 0xB5, 0xA4, 0x18, 0x25, 0xD9, > + 0x67, 0xE1, 0x44, 0xE5, 0x14, 0x05, 0x64, 0x25, > + 0x1C, 0xCA, 0xCB, 0x83, 0xE6, 0xB4, 0x86, 0xF6, > + 0xB3, 0xCA, 0x3F, 0x79, 0x71, 0x50, 0x60, 0x26, > + 0xC0, 0xB8, 0x57, 0xF6, 0x89, 0x96, 0x28, 0x56, > + 0xDE, 0xD4, 0x01, 0x0A, 0xBD, 0x0B, 0xE6, 0x21, > + 0xC3, 0xA3, 0x96, 0x0A, 0x54, 0xE7, 0x10, 0xC3, > + 0x75, 0xF2, 0x63, 0x75, 0xD7, 0x01, 0x41, 0x03, > + 0xA4, 0xB5, 0x43, 0x30, 0xC1, 0x98, 0xAF, 0x12, > + 0x61, 0x16, 0xD2, 0x27, 0x6E, 0x11, 0x71, 0x5F, > + 0x69, 0x38, 0x77, 0xFA, 0xD7, 0xEF, 0x09, 0xCA, > + 0xDB, 0x09, 0x4A, 0xE9, 0x1E, 0x1A, 0x15, 0x97, > +}; > + > + > +static uint8_t test_dh_ikev2group24_g[] =3D { > + 0x3F, 0xB3, 0x2C, 0x9B, 0x73, 0x13, 0x4D, 0x0B, > + 0x2E, 0x77, 0x50, 0x66, 0x60, 0xED, 0xBD, 0x48, > + 0x4C, 0xA7, 0xB1, 0x8F, 0x21, 0xEF, 0x20, 0x54, > + 0x07, 0xF4, 0x79, 0x3A, 0x1A, 0x0B, 0xA1, 0x25, > + 0x10, 0xDB, 0xC1, 0x50, 0x77, 0xBE, 0x46, 0x3F, > + 0xFF, 0x4F, 0xED, 0x4A, 0xAC, 0x0B, 0xB5, 0x55, > + 0xBE, 0x3A, 0x6C, 0x1B, 0x0C, 0x6B, 0x47, 0xB1, > + 0xBC, 0x37, 0x73, 0xBF, 0x7E, 0x8C, 0x6F, 0x62, > + 0x90, 0x12, 0x28, 0xF8, 0xC2, 0x8C, 0xBB, 0x18, > + 0xA5, 0x5A, 0xE3, 0x13, 0x41, 0x00, 0x0A, 0x65, > + 0x01, 0x96, 0xF9, 0x31, 0xC7, 0x7A, 0x57, 0xF2, > + 0xDD, 0xF4, 0x63, 0xE5, 0xE9, 0xEC, 0x14, 0x4B, > + 0x77, 0x7D, 0xE6, 0x2A, 0xAA, 0xB8, 0xA8, 0x62, > + 0x8A, 0xC3, 0x76, 0xD2, 0x82, 0xD6, 0xED, 0x38, > + 0x64, 0xE6, 0x79, 0x82, 0x42, 0x8E, 0xBC, 0x83, > + 0x1D, 0x14, 0x34, 0x8F, 0x6F, 0x2F, 0x91, 0x93, > + 0xB5, 0x04, 0x5A, 0xF2, 0x76, 0x71, 0x64, 0xE1, > + 0xDF, 0xC9, 0x67, 0xC1, 0xFB, 0x3F, 0x2E, 0x55, > + 0xA4, 0xBD, 0x1B, 0xFF, 0xE8, 0x3B, 0x9C, 0x80, > + 0xD0, 0x52, 0xB9, 0x85, 0xD1, 0x82, 0xEA, 0x0A, > + 0xDB, 0x2A, 0x3B, 0x73, 0x13, 0xD3, 0xFE, 0x14, > + 0xC8, 0x48, 0x4B, 0x1E, 0x05, 0x25, 0x88, 0xB9, > + 0xB7, 0xD2, 0xBB, 0xD2, 0xDF, 0x01, 0x61, 0x99, > + 0xEC, 0xD0, 0x6E, 0x15, 0x57, 0xCD, 0x09, 0x15, > + 0xB3, 0x35, 0x3B, 0xBB, 0x64, 0xE0, 0xEC, 0x37, > + 0x7F, 0xD0, 0x28, 0x37, 0x0D, 0xF9, 0x2B, 0x52, > + 0xC7, 0x89, 0x14, 0x28, 0xCD, 0xC6, 0x7E, 0xB6, > + 0x18, 0x4B, 0x52, 0x3D, 0x1D, 0xB2, 0x46, 0xC3, > + 0x2F, 0x63, 0x07, 0x84, 0x90, 0xF0, 0x0E, 0xF8, > + 0xD6, 0x47, 0xD1, 0x48, 0xD4, 0x79, 0x54, 0x51, > + 0x5E, 0x23, 0x27, 0xCF, 0xEF, 0x98, 0xC5, 0x82, > + 0x66, 0x4B, 0x4C, 0x0F, 0x6C, 0xC4, 0x16, 0x59, > +}; > + > +const struct test_dh_group test_dh_ikev2group_14 =3D { > + .id =3D 0, > + /* > + * Officially 14, ikev2 > + */ > + .g =3D { > + .data =3D test_dh_gen_2, > + .bytesize =3D sizeof(test_dh_gen_2), > + }, > + .p =3D { > + .data =3D test_dh_ikev2group14_p, > + .bytesize =3D sizeof(test_dh_ikev2group14_p), > + }, > + .priv_ff_size =3D 256, > +}; > + > +const struct test_dh_group test_dh_ikev2group_15 =3D { > + .id =3D 0, > + /* > + * Officially 15, ikev2 > + */ > + .g =3D { > + .data =3D test_dh_gen_2, > + .bytesize =3D sizeof(test_dh_gen_2), > + }, > + .p =3D { > + .data =3D test_dh_ikev2group15_p, > + .bytesize =3D sizeof(test_dh_ikev2group15_p), > + }, > + .priv_ff_size =3D 384, > +}; > + > +const struct test_dh_group test_dh_ikev2group_16 =3D { > + .id =3D 0, > + /* > + * Officially 16, ikev2 > +. > + */ > + .g =3D { > + .data =3D test_dh_gen_2, > + .bytesize =3D sizeof(test_dh_gen_2), > + }, > + .p =3D { > + .data =3D test_dh_ikev2group16_p, > + .bytesize =3D sizeof(test_dh_ikev2group16_p), > + }, > + .priv_ff_size =3D 512, > +}; > + > +const struct test_dh_group test_dh_ikev2group_24 =3D { > + .id =3D 0, > + /* > + * Officially 24, ikev2 > + */ > + .g =3D { > + .data =3D test_dh_ikev2group24_g, > + .bytesize =3D sizeof(test_dh_ikev2group24_g), > + }, > + .p =3D { > + .data =3D test_dh_ikev2group24_p, > + .bytesize =3D sizeof(test_dh_ikev2group24_p), > + }, > + .priv_ff_size =3D 32, > +}; > + > uint8_t dh_priv[] =3D { > 0x46, 0x3c, 0x7b, 0x43, 0xd1, 0xb8, 0xd4, 0x7a, > 0x56, 0x28, 0x85, 0x79, 0xcc, 0xd8, 0x90, 0x03, > -- > 2.13.6