From 43a97878ce14b72f0981164f87f2e35e14151312 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sun, 7 Apr 2024 11:22:09 +0200 Subject: Adding upstream version 110.0.1. Signed-off-by: Daniel Baumann --- .../gtests/common/testvectors_base/test-structs.h | 155 +++++++++++++++++++++ 1 file changed, 155 insertions(+) create mode 100644 security/nss/gtests/common/testvectors_base/test-structs.h (limited to 'security/nss/gtests/common/testvectors_base/test-structs.h') diff --git a/security/nss/gtests/common/testvectors_base/test-structs.h b/security/nss/gtests/common/testvectors_base/test-structs.h new file mode 100644 index 0000000000..2d3d981639 --- /dev/null +++ b/security/nss/gtests/common/testvectors_base/test-structs.h @@ -0,0 +1,155 @@ +/* vim: set ts=2 et sw=2 tw=80: */ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this file, + * You can obtain one at http://mozilla.org/MPL/2.0/. */ + +/* This file is generated from sources in nss/gtests/common/wycheproof + * automatically and should not be touched manually. + * Generation is trigged by calling ./mach wycheproof */ + +#ifndef test_structs_h__ +#define test_structs_h__ + +#include +#include +#include "secoidt.h" +#include "pkcs11t.h" + +typedef struct AesCbcTestVectorStr { + uint32_t id; + std::string key; + std::string msg; + std::string iv; + std::string ciphertext; + bool valid; +} AesCbcTestVector; + +typedef struct AesCmacTestVectorStr { + uint32_t id; + std::string comment; + std::string key; + std::string msg; + std::string tag; + bool invalid; +} AesCmacTestVector; +typedef AesCmacTestVector HmacTestVector; + +typedef struct AesGcmKatValueStr { + uint32_t id; + std::string key; + std::string plaintext; + std::string additional_data; + std::string iv; + std::string hash_key; + std::string ghash; + std::string result; + bool invalid_ct; + bool invalid_iv; +} AesGcmKatValue; + +typedef struct ChaChaTestVectorStr { + uint32_t id; + std::vector plaintext; + std::vector aad; + std::vector key; + std::vector iv; + std::vector ciphertext; + bool invalid_tag; + bool invalid_iv; +} ChaChaTestVector; + +typedef struct EcdsaTestVectorStr { + SECOidTag hash_oid; + uint32_t id; + std::vector sig; + std::vector public_key; + std::vector msg; + bool valid; +} EcdsaTestVector; + +typedef EcdsaTestVector DsaTestVector; + +typedef struct EcdhTestVectorStr { + uint32_t id; + std::vector private_key; + std::vector public_key; + std::vector secret; + bool invalid_asn; + bool valid; +} EcdhTestVector; + +typedef struct HkdfTestVectorStr { + uint32_t id; + std::string ikm; + std::string salt; + std::string info; + std::string okm; + uint32_t size; + bool valid; +} HkdfTestVector; + +enum class IkeTestType { + ikeGxy, /* CKM_NSS_IKE_PRF_DERIVE case 1 */ + ikeV1Psk, /* CKM_NSS_IKE_PRF_DERIVE case 2 */ + ikeV2Rekey, /* CKM_NSS_IKE_PRF_DERIVE case 3 */ + ikeV1, /* CKM_NSS_IKE1_PRF_DERIVE */ + ikeV1AppB, /* CKM_NSS_IKE1_PRF_APP_B_DERIVE base mode */ + ikeV1AppBQuick, /* CKM_NSS_IKE1_PRF_APP_B_DERIVE quick mode */ + ikePlus /* CKM_NSS_IKE_PRF_DERIVE */ +}; + +typedef struct IkeTestVectorStr { + uint32_t id; + IkeTestType test_type; + std::string ikm; + std::string gxykm; + std::string prevkm; + std::string okm; + std::string Ni; + std::string Nr; + std::string seed_data; + uint8_t key_number; + uint32_t size; + bool valid; +} IkeTestVector; + +typedef struct RsaSignatureTestVectorStr { + SECOidTag hash_oid; + uint32_t id; + std::vector sig; + std::vector public_key; + std::vector msg; + bool valid; +} RsaSignatureTestVector; + +typedef struct RsaDecryptTestVectorStr { + uint32_t id; + std::vector msg; + std::vector ct; + std::vector priv_key; + bool valid; +} RsaDecryptTestVector; + +typedef struct RsaOaepTestVectorStr { + SECOidTag hash_oid; + CK_RSA_PKCS_MGF_TYPE mgf_hash; + uint32_t id; + std::vector msg; + std::vector ct; + std::vector label; + std::vector priv_key; + bool valid; +} RsaOaepTestVector; + +typedef struct RsaPssTestVectorStr { + SECOidTag hash_oid; + CK_RSA_PKCS_MGF_TYPE mgf_hash; + uint32_t id; + unsigned long sLen; + std::vector sig; + std::vector public_key; + std::vector msg; + bool valid; +} RsaPssTestVector; + +#endif // test_structs_h__ -- cgit v1.2.3