Blame lib/crypto-selftests.c

Packit Service 4684c1
/*
Packit Service 4684c1
 * Copyright (C) 2013-2018 Red Hat
Packit Service 4684c1
 *
Packit Service 4684c1
 * Author: Nikos Mavrogiannopoulos
Packit Service 4684c1
 *
Packit Service 4684c1
 * This file is part of GnuTLS.
Packit Service 4684c1
 *
Packit Service 4684c1
 * The GnuTLS is free software; you can redistribute it and/or
Packit Service 4684c1
 * modify it under the terms of the GNU Lesser General Public License
Packit Service 4684c1
 * as published by the Free Software Foundation; either version 2.1 of
Packit Service 4684c1
 * the License, or (at your option) any later version.
Packit Service 4684c1
 *
Packit Service 4684c1
 * This library is distributed in the hope that it will be useful, but
Packit Service 4684c1
 * WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service 4684c1
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit Service 4684c1
 * Lesser General Public License for more details.
Packit Service 4684c1
 *
Packit Service 4684c1
 * You should have received a copy of the GNU Lesser General Public License
Packit Service 4684c1
 * along with this program.  If not, see <https://www.gnu.org/licenses/>
Packit Service 4684c1
 *
Packit Service 4684c1
 */
Packit Service 4684c1
Packit Service 4684c1
#include "gnutls_int.h"
Packit Service 4684c1
#include "errors.h"
Packit Service 4684c1
#include <cipher_int.h>
Packit Service 4684c1
#include <datum.h>
Packit Service 4684c1
#include <gnutls/crypto.h>
Packit Service 4684c1
#include <gnutls/self-test.h>
Packit Service 4684c1
#include "errors.h"
Packit Service 4684c1
#include <random.h>
Packit Service 4684c1
#include <crypto.h>
Packit Service 4684c1
#include <nettle/sha3.h>
Packit Service 4684c1
Packit Service 4684c1
#define STR(tag, tag_size, val) \
Packit Service 4684c1
	.tag = (uint8_t*)val, \
Packit Service 4684c1
	.tag_size = (sizeof(val)-1)
Packit Service 4684c1
Packit Service 4684c1
#define V(x) (x), (sizeof(x)/sizeof(x[0]))
Packit Service 4684c1
Packit Service 4684c1
/* This does check the AES and SHA implementation against test vectors.
Packit Service 4684c1
 * This should not run under valgrind in order to use the native
Packit Service 4684c1
 * cpu instructions (AES-NI or padlock).
Packit Service 4684c1
 */
Packit Service 4684c1
Packit Service 4684c1
struct cipher_vectors_st {
Packit Service 4684c1
	const uint8_t *key;
Packit Service 4684c1
	unsigned int key_size;
Packit Service 4684c1
Packit Service 4684c1
	const uint8_t *plaintext;
Packit Service 4684c1
	unsigned int plaintext_size;
Packit Service 4684c1
	const uint8_t *ciphertext;	/* also of plaintext_size */
Packit Service 4684c1
Packit Service 4684c1
	const uint8_t *iv;
Packit Service 4684c1
	unsigned int iv_size;
Packit Service 4684c1
Packit Service 4684c1
	const uint8_t *internal_iv;
Packit Service 4684c1
	unsigned int internal_iv_size;
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
struct cipher_aead_vectors_st {
Packit Service 4684c1
	unsigned compat_apis;
Packit Service 4684c1
	const uint8_t *key;
Packit Service 4684c1
	unsigned int key_size;
Packit Service 4684c1
Packit Service 4684c1
	const uint8_t *auth;
Packit Service 4684c1
	unsigned int auth_size;
Packit Service 4684c1
Packit Service 4684c1
	const uint8_t *plaintext;
Packit Service 4684c1
	unsigned int plaintext_size;
Packit Service 4684c1
	const uint8_t *ciphertext;	/* also of plaintext_size */
Packit Service 4684c1
Packit Service 4684c1
	unsigned int iv_size;
Packit Service 4684c1
	const uint8_t *iv;
Packit Service 4684c1
	const uint8_t *tag;
Packit Service 4684c1
	unsigned tag_size;
Packit Service 4684c1
	unsigned tag_prepended;
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct cipher_aead_vectors_st chacha_poly1305_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 .compat_apis = 1,
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x1c\x92\x40\xa5\xeb\x55\xd3\x8a\xf3\x33\x88\x86\x04\xf6\xb5\xf0\x47\x39\x17\xc1\x40\x2b\x80\x09\x9d\xca\x5c\xbc\x20\x70\x75\xc0"),
Packit Service 4684c1
	 .auth = (void*)"\xf3\x33\x88\x86\x00\x00\x00\x00\x00\x00\x4e\x91",
Packit Service 4684c1
	 .auth_size = 12,
Packit Service 4684c1
	 .plaintext = (void*)"\x49\x6e\x74\x65\x72\x6e\x65\x74\x2d\x44\x72\x61\x66\x74\x73\x20\x61\x72\x65\x20\x64\x72\x61\x66\x74\x20\x64\x6f\x63\x75\x6d\x65\x6e\x74\x73\x20\x76\x61\x6c\x69\x64\x20\x66\x6f\x72\x20\x61\x20\x6d\x61\x78\x69\x6d\x75\x6d\x20\x6f\x66\x20\x73\x69\x78\x20\x6d\x6f\x6e\x74\x68\x73\x20\x61\x6e\x64\x20\x6d\x61\x79\x20\x62\x65\x20\x75\x70\x64\x61\x74\x65\x64\x2c\x20\x72\x65\x70\x6c\x61\x63\x65\x64\x2c\x20\x6f\x72\x20\x6f\x62\x73\x6f\x6c\x65\x74\x65\x64\x20\x62\x79\x20\x6f\x74\x68\x65\x72\x20\x64\x6f\x63\x75\x6d\x65\x6e\x74\x73\x20\x61\x74\x20\x61\x6e\x79\x20\x74\x69\x6d\x65\x2e\x20\x49\x74\x20\x69\x73\x20\x69\x6e\x61\x70\x70\x72\x6f\x70\x72\x69\x61\x74\x65\x20\x74\x6f\x20\x75\x73\x65\x20\x49\x6e\x74\x65\x72\x6e\x65\x74\x2d\x44\x72\x61\x66\x74\x73\x20\x61\x73\x20\x72\x65\x66\x65\x72\x65\x6e\x63\x65\x20\x6d\x61\x74\x65\x72\x69\x61\x6c\x20\x6f\x72\x20\x74\x6f\x20\x63\x69\x74\x65\x20\x74\x68\x65\x6d\x20\x6f\x74\x68\x65\x72\x20\x74\x68\x61\x6e\x20\x61\x73\x20\x2f\xe2\x80\x9c\x77\x6f\x72\x6b\x20\x69\x6e\x20\x70\x72\x6f\x67\x72\x65\x73\x73\x2e\x2f\xe2\x80\x9d",
Packit Service 4684c1
	 .plaintext_size = 265,
Packit Service 4684c1
	 .ciphertext = (void*)"\x64\xa0\x86\x15\x75\x86\x1a\xf4\x60\xf0\x62\xc7\x9b\xe6\x43\xbd\x5e\x80\x5c\xfd\x34\x5c\xf3\x89\xf1\x08\x67\x0a\xc7\x6c\x8c\xb2\x4c\x6c\xfc\x18\x75\x5d\x43\xee\xa0\x9e\xe9\x4e\x38\x2d\x26\xb0\xbd\xb7\xb7\x3c\x32\x1b\x01\x00\xd4\xf0\x3b\x7f\x35\x58\x94\xcf\x33\x2f\x83\x0e\x71\x0b\x97\xce\x98\xc8\xa8\x4a\xbd\x0b\x94\x81\x14\xad\x17\x6e\x00\x8d\x33\xbd\x60\xf9\x82\xb1\xff\x37\xc8\x55\x97\x97\xa0\x6e\xf4\xf0\xef\x61\xc1\x86\x32\x4e\x2b\x35\x06\x38\x36\x06\x90\x7b\x6a\x7c\x02\xb0\xf9\xf6\x15\x7b\x53\xc8\x67\xe4\xb9\x16\x6c\x76\x7b\x80\x4d\x46\xa5\x9b\x52\x16\xcd\xe7\xa4\xe9\x90\x40\xc5\xa4\x04\x33\x22\x5e\xe2\x82\xa1\xb0\xa0\x6c\x52\x3e\xaf\x45\x34\xd7\xf8\x3f\xa1\x15\x5b\x00\x47\x71\x8c\xbc\x54\x6a\x0d\x07\x2b\x04\xb3\x56\x4e\xea\x1b\x42\x22\x73\xf5\x48\x27\x1a\x0b\xb2\x31\x60\x53\xfa\x76\x99\x19\x55\xeb\xd6\x31\x59\x43\x4e\xce\xbb\x4e\x46\x6d\xae\x5a\x10\x73\xa6\x72\x76\x27\x09\x7a\x10\x49\xe6\x17\xd9\x1d\x36\x10\x94\xfa\x68\xf0\xff\x77\x98\x71\x30\x30\x5b\xea\xba\x2e\xda\x04\xdf\x99\x7b\x71\x4d\x6c\x6f\x2c\x29\xa6\xad\x5c\xb4\x02\x2b\x02\x70\x9b",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\x00\x00\x00\x00\x01\x02\x03\x04\x05\x06\x07\x08"),
Packit Service 4684c1
	 .tag_size = 16,
Packit Service 4684c1
	 .tag = (void *)
Packit Service 4684c1
	 "\xee\xad\x9d\x67\x89\x0c\xbb\x22\x39\x23\x36\xfe\xa1\x85\x1f\x38"},
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct cipher_aead_vectors_st aes128_gcm_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 .compat_apis = 1,
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00"),
Packit Service 4684c1
	 .auth = NULL,
Packit Service 4684c1
	 .auth_size = 0,
Packit Service 4684c1
	 .plaintext = NULL,
Packit Service 4684c1
	 .plaintext_size = 0,
Packit Service 4684c1
	 .ciphertext = NULL,
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00"),
Packit Service 4684c1
	 .tag_size = 16,
Packit Service 4684c1
	 .tag = (void *)
Packit Service 4684c1
	 "\x58\xe2\xfc\xce\xfa\x7e\x30\x61\x36\x7f\x1d\x57\xa4\xe7\x45\x5a"},
Packit Service 4684c1
	{
Packit Service 4684c1
	 .compat_apis = 1,
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00"),
Packit Service 4684c1
	 .auth = NULL,
Packit Service 4684c1
	 .auth_size = 0,
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00"),
Packit Service 4684c1
	 .ciphertext = (void *)
Packit Service 4684c1
	 "\x03\x88\xda\xce\x60\xb6\xa3\x92\xf3\x28\xc2\xb9\x71\xb2\xfe\x78",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00"),
Packit Service 4684c1
	 .tag_size = 16,
Packit Service 4684c1
	 .tag = (void *)
Packit Service 4684c1
	 "\xab\x6e\x47\xd4\x2c\xec\x13\xbd\xf5\x3a\x67\xb2\x12\x57\xbd\xdf"},
Packit Service 4684c1
	{
Packit Service 4684c1
	 .compat_apis = 1,
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\xfe\xff\xe9\x92\x86\x65\x73\x1c\x6d\x6a\x8f\x94\x67\x30\x83\x08"),
Packit Service 4684c1
	 .auth = (void *)
Packit Service 4684c1
	 "\xfe\xed\xfa\xce\xde\xad\xbe\xef\xfe\xed\xfa\xce\xde\xad\xbe\xef\xab\xad\xda\xd2",
Packit Service 4684c1
	 .auth_size = 20,
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\xd9\x31\x32\x25\xf8\x84\x06\xe5\xa5\x59\x09\xc5\xaf\xf5\x26\x9a\x86\xa7\xa9\x53\x15\x34\xf7\xda\x2e\x4c\x30\x3d\x8a\x31\x8a\x72\x1c\x3c\x0c\x95\x95\x68\x09\x53\x2f\xcf\x0e\x24\x49\xa6\xb5\x25\xb1\x6a\xed\xf5\xaa\x0d\xe6\x57\xba\x63\x7b\x39"),
Packit Service 4684c1
	 .ciphertext = (void *)
Packit Service 4684c1
	 "\x42\x83\x1e\xc2\x21\x77\x74\x24\x4b\x72\x21\xb7\x84\xd0\xd4\x9c\xe3\xaa\x21\x2f\x2c\x02\xa4\xe0\x35\xc1\x7e\x23\x29\xac\xa1\x2e\x21\xd5\x14\xb2\x54\x66\x93\x1c\x7d\x8f\x6a\x5a\xac\x84\xaa\x05\x1b\xa3\x0b\x39\x6a\x0a\xac\x97\x3d\x58\xe0\x91",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\xca\xfe\xba\xbe\xfa\xce\xdb\xad\xde\xca\xf8\x88"),
Packit Service 4684c1
	 .tag_size = 16,
Packit Service 4684c1
	 .tag = (void *)
Packit Service 4684c1
	 "\x5b\xc9\x4f\xbc\x32\x21\xa5\xdb\x94\xfa\xe9\x5a\xe7\x12\x1a\x47"}
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct cipher_aead_vectors_st aes192_gcm_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 .compat_apis = 1,
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\xfe\xff\xe9\x92\x86\x65\x73\x1c\x6d\x6a\x8f\x94\x67\x30\x83\x08\xfe\xff\xe9\x92\x86\x65\x73\x1c"),
Packit Service 4684c1
	 .auth = NULL,
Packit Service 4684c1
	 .auth_size = 0,
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\xd9\x31\x32\x25\xf8\x84\x06\xe5\xa5\x59\x09\xc5\xaf\xf5\x26\x9a\x86\xa7\xa9\x53\x15\x34\xf7\xda\x2e\x4c\x30\x3d\x8a\x31\x8a\x72\x1c\x3c\x0c\x95\x95\x68\x09\x53\x2f\xcf\x0e\x24\x49\xa6\xb5\x25\xb1\x6a\xed\xf5\xaa\x0d\xe6\x57\xba\x63\x7b\x39\x1a\xaf\xd2\x55"),
Packit Service 4684c1
	 .ciphertext =
Packit Service 4684c1
	 (uint8_t *)
Packit Service 4684c1
	 "\x39\x80\xca\x0b\x3c\x00\xe8\x41\xeb\x06\xfa\xc4\x87\x2a\x27\x57\x85\x9e\x1c\xea\xa6\xef\xd9\x84\x62\x85\x93\xb4\x0c\xa1\xe1\x9c\x7d\x77\x3d\x00\xc1\x44\xc5\x25\xac\x61\x9d\x18\xc8\x4a\x3f\x47\x18\xe2\x44\x8b\x2f\xe3\x24\xd9\xcc\xda\x27\x10\xac\xad\xe2\x56",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\xca\xfe\xba\xbe\xfa\xce\xdb\xad\xde\xca\xf8\x88"),
Packit Service 4684c1
	 .tag_size = 16,
Packit Service 4684c1
	 .tag =
Packit Service 4684c1
	 (void *)
Packit Service 4684c1
	 "\x99\x24\xa7\xc8\x58\x73\x36\xbf\xb1\x18\x02\x4d\xb8\x67\x4a\x14"},
Packit Service 4684c1
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct cipher_aead_vectors_st aes256_gcm_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 .compat_apis = 1,
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\xfe\xff\xe9\x92\x86\x65\x73\x1c\x6d\x6a\x8f\x94\x67\x30\x83\x08\xfe\xff\xe9\x92\x86\x65\x73\x1c\x6d\x6a\x8f\x94\x67\x30\x83\x08"),
Packit Service 4684c1
	 .auth = NULL,
Packit Service 4684c1
	 .auth_size = 0,
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\xd9\x31\x32\x25\xf8\x84\x06\xe5\xa5\x59\x09\xc5\xaf\xf5\x26\x9a\x86\xa7\xa9\x53\x15\x34\xf7\xda\x2e\x4c\x30\x3d\x8a\x31\x8a\x72\x1c\x3c\x0c\x95\x95\x68\x09\x53\x2f\xcf\x0e\x24\x49\xa6\xb5\x25\xb1\x6a\xed\xf5\xaa\x0d\xe6\x57\xba\x63\x7b\x39\x1a\xaf\xd2\x55"),
Packit Service 4684c1
	 .ciphertext =
Packit Service 4684c1
	 (uint8_t *)
Packit Service 4684c1
	 "\x52\x2d\xc1\xf0\x99\x56\x7d\x07\xf4\x7f\x37\xa3\x2a\x84\x42\x7d\x64\x3a\x8c\xdc\xbf\xe5\xc0\xc9\x75\x98\xa2\xbd\x25\x55\xd1\xaa\x8c\xb0\x8e\x48\x59\x0d\xbb\x3d\xa7\xb0\x8b\x10\x56\x82\x88\x38\xc5\xf6\x1e\x63\x93\xba\x7a\x0a\xbc\xc9\xf6\x62\x89\x80\x15\xad",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\xca\xfe\xba\xbe\xfa\xce\xdb\xad\xde\xca\xf8\x88"),
Packit Service 4684c1
	 .tag_size = 16,
Packit Service 4684c1
	 .tag =
Packit Service 4684c1
	 (void *)
Packit Service 4684c1
	 "\xb0\x94\xda\xc5\xd9\x34\x71\xbd\xec\x1a\x50\x22\x70\xe3\xcc\x6c"},
Packit Service 4684c1
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct cipher_aead_vectors_st aes256_ccm_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 .compat_apis = 0,
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\xfb\x76\x15\xb2\x3d\x80\x89\x1d\xd4\x70\x98\x0b\xc7\x95\x84\xc8\xb2\xfb\x64\xce\x60\x97\x8f\x4d\x17\xfc\xe4\x5a\x49\xe8\x30\xb7"),
Packit Service 4684c1
	 .auth = NULL,
Packit Service 4684c1
	 .auth_size = 0,
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\xa8\x45\x34\x8e\xc8\xc5\xb5\xf1\x26\xf5\x0e\x76\xfe\xfd\x1b\x1e"),
Packit Service 4684c1
	 .ciphertext = (void *)
Packit Service 4684c1
	     "\xcc\x88\x12\x61\xc6\xa7\xfa\x72\xb9\x6a\x17\x39\x17\x6b\x27\x7f",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\xdb\xd1\xa3\x63\x60\x24\xb7\xb4\x02\xda\x7d\x6f"),
Packit Service 4684c1
	 .tag_size = 16,
Packit Service 4684c1
	 .tag = (void *)
Packit Service 4684c1
	     "\x34\x72\xe1\x14\x5f\x2c\x0c\xbe\x14\x63\x49\x06\x2c\xf0\xe4\x23"},
Packit Service 4684c1
	{
Packit Service 4684c1
	 .compat_apis = 0,
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\xfb\x76\x15\xb2\x3d\x80\x89\x1d\xd4\x70\x98\x0b\xc7\x95\x84\xc8\xb2\xfb\x64\xce\x60\x97\x87\x8d\x17\xfc\xe4\x5a\x49\xe8\x30\xb7"),
Packit Service 4684c1
	 STR(auth, auth_size, "\x36"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\xa9"),
Packit Service 4684c1
	 .ciphertext = (void *)
Packit Service 4684c1
	     "\x9d",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\xdb\xd1\xa3\x63\x60\x24\xb7\xb4\x02\xda\x7d\x6f"),
Packit Service 4684c1
	 .tag_size = 16,
Packit Service 4684c1
	 .tag = (void *)
Packit Service 4684c1
	     "\x32\x61\xb1\xcf\x93\x14\x31\xe9\x9a\x32\x80\x67\x38\xec\xbd\x2a"},
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct cipher_aead_vectors_st aes128_ccm_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 .compat_apis = 0,
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\xC0\xC1\xC2\xC3\xC4\xC5\xC6\xC7\xC8\xC9\xCA\xCB\xCC\xCD\xCE\xCF"),
Packit Service 4684c1
	 STR(auth, auth_size, "\x08\xD0\x84\x21\x43\x01\x00\x00\x00\x00\x48\xDE\xAC\x02\x05\x00\x00\x00\x55\xCF\x00\x00\x51\x52\x53\x54"),
Packit Service 4684c1
	 .plaintext = NULL,
Packit Service 4684c1
	 .plaintext_size = 0,
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\xAC\xDE\x48\x00\x00\x00\x00\x01\x00\x00\x00\x05\x02"),
Packit Service 4684c1
	 .tag_size = 8,
Packit Service 4684c1
	 .tag = (void *)
Packit Service 4684c1
	     "\x22\x3B\xC1\xEC\x84\x1A\xB5\x53"},
Packit Service 4684c1
	{
Packit Service 4684c1
	 .compat_apis = 0,
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x40\x41\x42\x43\x44\x45\x46\x47\x48\x49\x4a\x4b\x4c\x4d\x4e\x4f"),
Packit Service 4684c1
	 STR(auth, auth_size, "\x00\x01\x02\x03\x04\x05\x06\x07"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\x20\x21\x22\x23"),
Packit Service 4684c1
	 .ciphertext = (void *)
Packit Service 4684c1
	     "\x71\x62\x01\x5b",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\x10\x11\x12\x13\x14\x15\x16"),
Packit Service 4684c1
	 .tag_size = 4,
Packit Service 4684c1
	 .tag = (void *)
Packit Service 4684c1
	     "\x4d\xac\x25\x5d"},
Packit Service 4684c1
	/* from rfc3610 */
Packit Service 4684c1
	{
Packit Service 4684c1
	 .compat_apis = 0,
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\xC0\xC1\xC2\xC3\xC4\xC5\xC6\xC7\xC8\xC9\xCA\xCB\xCC\xCD\xCE\xCF"),
Packit Service 4684c1
	 STR(auth, auth_size, "\x00\x01\x02\x03\x04\x05\x06\x07"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\x08\x09\x0A\x0B\x0C\x0D\x0E\x0F\x10\x11\x12\x13\x14\x15\x16\x17\x18\x19\x1A\x1B\x1C\x1D\x1E"),
Packit Service 4684c1
	 .ciphertext = (void *)
Packit Service 4684c1
	     "\x01\x35\xD1\xB2\xC9\x5F\x41\xD5\xD1\xD4\xFE\xC1\x85\xD1\x66\xB8\x09\x4E\x99\x9D\xFE\xD9\x6C",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\x00\x00\x00\x09\x08\x07\x06\xA0\xA1\xA2\xA3\xA4\xA5"),
Packit Service 4684c1
	 .tag_size = 10,
Packit Service 4684c1
	 .tag = (void *)
Packit Service 4684c1
	     "\x04\x8C\x56\x60\x2C\x97\xAC\xBB\x74\x90"},
Packit Service 4684c1
	{
Packit Service 4684c1
	 .compat_apis = 0,
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\xC0\xC1\xC2\xC3\xC4\xC5\xC6\xC7\xC8\xC9\xCA\xCB\xCC\xCD\xCE\xCF"),
Packit Service 4684c1
	 STR(auth, auth_size, "\x00\x01\x02\x03\x04\x05\x06\x07"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\x08\x09\x0A\x0B\x0C\x0D\x0E\x0F\x10\x11\x12\x13\x14\x15\x16\x17\x18\x19\x1A\x1B\x1C\x1D\x1E"),
Packit Service 4684c1
	 .ciphertext = (void *)
Packit Service 4684c1
	     "\x58\x8C\x97\x9A\x61\xC6\x63\xD2\xF0\x66\xD0\xC2\xC0\xF9\x89\x80\x6D\x5F\x6B\x61\xDA\xC3\x84",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\x00\x00\x00\x03\x02\x01\x00\xA0\xA1\xA2\xA3\xA4\xA5"),
Packit Service 4684c1
	 .tag_size = 8,
Packit Service 4684c1
	 .tag = (void *)
Packit Service 4684c1
	     "\x17\xE8\xD1\x2C\xFD\xF9\x26\xE0"},
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct cipher_vectors_st aes128_cbc_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x2b\x7e\x15\x16\x28\xae\xd2\xa6\xab\xf7\x15\x88\x09\xcf\x4f\x3c"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\x6b\xc1\xbe\xe2\x2e\x40\x9f\x96\xe9\x3d\x7e\x11\x73\x93\x17\x2a"),
Packit Service 4684c1
	 .ciphertext = (uint8_t *)
Packit Service 4684c1
	 "\x76\x49\xab\xac\x81\x19\xb2\x46\xce\xe9\x8e\x9b\x12\xe9\x19\x7d",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\x00\x01\x02\x03\x04\x05\x06\x07\x08\x09\x0A\x0B\x0C\x0D\x0E\x0F"),
Packit Service 4684c1
	 },
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x2b\x7e\x15\x16\x28\xae\xd2\xa6\xab\xf7\x15\x88\x09\xcf\x4f\x3c"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\xae\x2d\x8a\x57\x1e\x03\xac\x9c\x9e\xb7\x6f\xac\x45\xaf\x8e\x51"),
Packit Service 4684c1
	 .ciphertext =
Packit Service 4684c1
	 (uint8_t *)
Packit Service 4684c1
	 "\x50\x86\xcb\x9b\x50\x72\x19\xee\x95\xdb\x11\x3a\x91\x76\x78\xb2",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\x76\x49\xab\xac\x81\x19\xb2\x46\xce\xe9\x8e\x9b\x12\xe9\x19\x7d"),
Packit Service 4684c1
	 },
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct cipher_vectors_st aes192_cbc_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x8e\x73\xb0\xf7\xda\x0e\x64\x52\xc8\x10\xf3\x2b\x80\x90\x79\xe5\x62\xf8\xea\xd2\x52\x2c\x6b\x7b"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\x6b\xc1\xbe\xe2\x2e\x40\x9f\x96\xe9\x3d\x7e\x11\x73\x93\x17\x2a"),
Packit Service 4684c1
	 .ciphertext = (uint8_t *)
Packit Service 4684c1
	 "\x4f\x02\x1d\xb2\x43\xbc\x63\x3d\x71\x78\x18\x3a\x9f\xa0\x71\xe8",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\x00\x01\x02\x03\x04\x05\x06\x07\x08\x09\x0A\x0B\x0C\x0D\x0E\x0F"),
Packit Service 4684c1
	 },
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x8e\x73\xb0\xf7\xda\x0e\x64\x52\xc8\x10\xf3\x2b\x80\x90\x79\xe5\x62\xf8\xea\xd2\x52\x2c\x6b\x7b"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\xae\x2d\x8a\x57\x1e\x03\xac\x9c\x9e\xb7\x6f\xac\x45\xaf\x8e\x51"),
Packit Service 4684c1
	 .ciphertext = (uint8_t *)
Packit Service 4684c1
	 "\xb4\xd9\xad\xa9\xad\x7d\xed\xf4\xe5\xe7\x38\x76\x3f\x69\x14\x5a",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\x4F\x02\x1D\xB2\x43\xBC\x63\x3D\x71\x78\x18\x3A\x9F\xA0\x71\xE8"),
Packit Service 4684c1
	 },
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct cipher_vectors_st aes256_cbc_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x60\x3d\xeb\x10\x15\xca\x71\xbe\x2b\x73\xae\xf0\x85\x7d\x77\x81\x1f\x35\x2c\x07\x3b\x61\x08\xd7\x2d\x98\x10\xa3\x09\x14\xdf\xf4"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\x6b\xc1\xbe\xe2\x2e\x40\x9f\x96\xe9\x3d\x7e\x11\x73\x93\x17\x2a"),
Packit Service 4684c1
	 .ciphertext = (uint8_t *)
Packit Service 4684c1
	 "\xF5\x8C\x4C\x04\xD6\xE5\xF1\xBA\x77\x9E\xAB\xFB\x5F\x7B\xFB\xD6",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\x00\x01\x02\x03\x04\x05\x06\x07\x08\x09\x0A\x0B\x0C\x0D\x0E\x0F"),
Packit Service 4684c1
	 },
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x60\x3d\xeb\x10\x15\xca\x71\xbe\x2b\x73\xae\xf0\x85\x7d\x77\x81\x1f\x35\x2c\x07\x3b\x61\x08\xd7\x2d\x98\x10\xa3\x09\x14\xdf\xf4"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\xae\x2d\x8a\x57\x1e\x03\xac\x9c\x9e\xb7\x6f\xac\x45\xaf\x8e\x51"),
Packit Service 4684c1
	 .ciphertext = (uint8_t *)
Packit Service 4684c1
	 "\x9c\xfc\x4e\x96\x7e\xdb\x80\x8d\x67\x9f\x77\x7b\xc6\x70\x2c\x7d",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\xF5\x8C\x4C\x04\xD6\xE5\xF1\xBA\x77\x9E\xAB\xFB\x5F\x7B\xFB\xD6"),
Packit Service 4684c1
	 },
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct cipher_vectors_st tdes_cbc_vectors[] = {
Packit Service 4684c1
/* First 2 from https://www.cosic.esat.kuleuven.be/nessie/testvectors/bc/des/Triple-Des-3-Key-192-64.unverified.test-vectors */
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x00\x01\x02\x03\x04\x05\x06\x07\x08\x09\x0A\x0B\x0C\x0D\x0E\x0F\x10\x11\x12\x13\x14\x15\x16\x17"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\x98\x26\x62\x60\x55\x53\x24\x4D"),
Packit Service 4684c1
	 .ciphertext = (uint8_t *)
Packit Service 4684c1
	 "\x00\x11\x22\x33\x44\x55\x66\x77",
Packit Service 4684c1
	 STR(iv, iv_size, "\x00\x00\x00\x00\x00\x00\x00\x00"),
Packit Service 4684c1
	 },
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x2B\xD6\x45\x9F\x82\xC5\xB3\x00\x95\x2C\x49\x10\x48\x81\xFF\x48\x2B\xD6\x45\x9F\x82\xC5\xB3\x00"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\x85\x98\x53\x8A\x8E\xCF\x11\x7D"),
Packit Service 4684c1
	 .ciphertext = (uint8_t *)
Packit Service 4684c1
	 "\xEA\x02\x47\x14\xAD\x5C\x4D\x84",
Packit Service 4684c1
	 STR(iv, iv_size, "\x00\x00\x00\x00\x00\x00\x00\x00"),
Packit Service 4684c1
	 },
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct cipher_vectors_st arcfour_vectors[] = { /* RFC6229 */
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x01\x02\x03\x04\x05\x06\x07\x08\x09\x0a\x0b\x0c\x0d\x0e\x0f\x10\x11\x12\x13\x14\x15\x16\x17\x18"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00"),
Packit Service 4684c1
	 .ciphertext = (uint8_t *)
Packit Service 4684c1
	     "\x05\x95\xe5\x7f\xe5\xf0\xbb\x3c\x70\x6e\xda\xc8\xa4\xb2\xdb\x11",
Packit Service 4684c1
	 .iv = NULL,
Packit Service 4684c1
	 .iv_size = 0
Packit Service 4684c1
	},
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x01\x02\x03\x04\x05\x06\x07\x08\x09\x0a\x0b\x0c\x0d\x0e\x0f\x10\x11\x12\x13\x14\x15\x16\x17\x18\x19\x1a\x1b\x1c\x1d\x1e\x1f\x20"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00"),
Packit Service 4684c1
	 .ciphertext = (uint8_t *)
Packit Service 4684c1
	     "\xea\xa6\xbd\x25\x88\x0b\xf9\x3d\x3f\x5d\x1e\x4c\xa2\x61\x1d\x91",
Packit Service 4684c1
	 .iv = NULL,
Packit Service 4684c1
	 .iv_size = 0
Packit Service 4684c1
	},
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x01\x02\x03\x04\x05\x06\x07\x08\x09\x0a\x0b\x0c\x0d\x0e\x0f\x10"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00"),
Packit Service 4684c1
	 .ciphertext = (uint8_t *)
Packit Service 4684c1
	 "\x9a\xc7\xcc\x9a\x60\x9d\x1e\xf7\xb2\x93\x28\x99\xcd\xe4\x1b\x97",
Packit Service 4684c1
	 .iv = NULL,
Packit Service 4684c1
	 .iv_size = 0
Packit Service 4684c1
	},
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct cipher_vectors_st aes128_cfb8_vectors[] = { /* NIST 800-38a */
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x2b\x7e\x15\x16\x28\xae\xd2\xa6\xab\xf7\x15\x88\x09\xcf\x4f\x3c"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\x6b\xc1\xbe\xe2\x2e\x40\x9f\x96\xe9\x3d\x7e\x11\x73\x93\x17\x2a"
Packit Service 4684c1
             "\xae\x2d"),
Packit Service 4684c1
	 .ciphertext = (uint8_t *)
Packit Service 4684c1
	     "\x3b\x79\x42\x4c\x9c\x0d\xd4\x36\xba\xce\x9e\x0e\xd4\x58\x6a\x4f"
Packit Service 4684c1
             "\x32\xb9",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\x00\x01\x02\x03\x04\x05\x06\x07\x08\x09\x0a\x0b\x0c\x0d\x0e\x0f"),
Packit Service 4684c1
	 /* the least significant 16 bytes of ciphertext */
Packit Service 4684c1
	 STR(internal_iv, internal_iv_size,
Packit Service 4684c1
	     "\x42\x4c\x9c\x0d\xd4\x36\xba\xce\x9e\x0e\xd4\x58\x6a\x4f\x32\xb9"),
Packit Service 4684c1
	 },
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct cipher_vectors_st aes192_cfb8_vectors[] = { /* NIST 800-38a */
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x8e\x73\xb0\xf7\xda\x0e\x64\x52\xc8\x10\xf3\x2b\x80\x90\x79\xe5"
Packit Service 4684c1
             "\x62\xf8\xea\xd2\x52\x2c\x6b\x7b"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\x6b\xc1\xbe\xe2\x2e\x40\x9f\x96\xe9\x3d\x7e\x11\x73\x93\x17\x2a"
Packit Service 4684c1
             "\xae\x2d"),
Packit Service 4684c1
	 .ciphertext = (uint8_t *)
Packit Service 4684c1
	     "\xcd\xa2\x52\x1e\xf0\xa9\x05\xca\x44\xcd\x05\x7c\xbf\x0d\x47\xa0"
Packit Service 4684c1
             "\x67\x8a",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\x00\x01\x02\x03\x04\x05\x06\x07\x08\x09\x0a\x0b\x0c\x0d\x0e\x0f"),
Packit Service 4684c1
	 /* the least significant 16 bytes of ciphertext */
Packit Service 4684c1
	 STR(internal_iv, internal_iv_size,
Packit Service 4684c1
	     "\x52\x1e\xf0\xa9\x05\xca\x44\xcd\x05\x7c\xbf\x0d\x47\xa0\x67\x8a"),
Packit Service 4684c1
	 },
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct cipher_vectors_st aes256_cfb8_vectors[] = { /* NIST 800-38a */
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x60\x3d\xeb\x10\x15\xca\x71\xbe\x2b\x73\xae\xf0\x85\x7d\x77\x81"
Packit Service 4684c1
             "\x1f\x35\x2c\x07\x3b\x61\x08\xd7\x2d\x98\x10\xa3\x09\x14\xdf\xf4"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\x6b\xc1\xbe\xe2\x2e\x40\x9f\x96\xe9\x3d\x7e\x11\x73\x93\x17\x2a"
Packit Service 4684c1
             "\xae\x2d"),
Packit Service 4684c1
	 .ciphertext = (uint8_t *)
Packit Service 4684c1
	     "\xdc\x1f\x1a\x85\x20\xa6\x4d\xb5\x5f\xcc\x8a\xc5\x54\x84\x4e\x88"
Packit Service 4684c1
             "\x97\x00",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\x00\x01\x02\x03\x04\x05\x06\x07\x08\x09\x0a\x0b\x0c\x0d\x0e\x0f"),
Packit Service 4684c1
	 /* the least significant 16 bytes of ciphertext */
Packit Service 4684c1
	 STR(internal_iv, internal_iv_size,
Packit Service 4684c1
	     "\x1a\x85\x20\xa6\x4d\xb5\x5f\xcc\x8a\xc5\x54\x84\x4e\x88\x97\x00"),
Packit Service 4684c1
	 },
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
/* GOST 28147-89 vectors come from the testsuite contributed to OpenSSL by
Packit Service 4684c1
 * Sergey E. Leontiev. CryptoPro-B test vector is just truncated.
Packit Service 4684c1
 * TC26Z is calculated using Nettle */
Packit Service 4684c1
const struct cipher_vectors_st gost28147_cpa_cfb_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x8d\x5a\x2c\x83\xa7\xc7\x0a\x61\xd6\x1b\x34\xb5\x1f\xdf\x42\x68"
Packit Service 4684c1
	     "\x66\x71\xa3\x5d\x87\x4c\xfd\x84\x99\x36\x63\xb6\x1e\xd6\x0d\xad"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\xd2\xfd\xf8\x3a\xc1\xb4\x39\x23\x2e\xaa\xcc\x98\x0a\x02\xda\x33"),
Packit Service 4684c1
	 .ciphertext = (uint8_t *)
Packit Service 4684c1
		 "\x88\xb7\x75\x16\x74\xa5\xee\x2d\x14\xfe\x91\x67\xd0\x5c\xcc\x40",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\x46\x60\x6f\x0d\x88\x34\x23\x5a"),
Packit Service 4684c1
	},
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct cipher_vectors_st gost28147_cpb_cfb_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x48\x0c\x74\x1b\x02\x6b\x55\xd5\xb6\x6d\xd7\x1d\x40\x48\x05\x6b"
Packit Service 4684c1
	     "\x6d\xeb\x3c\x29\x0f\x84\x80\x23\xee\x0d\x47\x77\xe3\xfe\x61\xc9"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\x8c\x9c\x44\x35\xfb\xe9\xa5\xa3\xa0\xae\x28\x56\x91\x10\x8e\x1e"
Packit Service 4684c1
	     "\xd2\xbb\x18\x53\x81\x27\x0d\xa6\x68\x59\x36\xc5\x81\x62\x9a\x8e"
Packit Service 4684c1
	     "\x7d\x50\xf1\x6f\x97\x62\x29\xec\x80\x51\xe3\x7d\x6c\xc4\x07\x95"
Packit Service 4684c1
	     "\x28\x63\xdc\xb4\xb9\x2d\xb8\x13\xb1\x05\xb5\xf9\xeb\x75\x37"),
Packit Service 4684c1
	 .ciphertext = (uint8_t *)
Packit Service 4684c1
		 "\x23\xc6\x7f\x20\xa1\x23\x58\xbc\x7b\x05\xdb\x21\x15\xcf\x96\x41"
Packit Service 4684c1
		 "\xc7\x88\xef\x76\x5c\x49\xdb\x42\xbf\xf3\xc0\xf5\xbd\x5d\xd9\x8e"
Packit Service 4684c1
		 "\xaf\x3d\xf4\xe4\xda\x88\xbd\xbc\x47\x5d\x76\x07\xc9\x5f\x54\x1d"
Packit Service 4684c1
		 "\x1d\x6a\xa1\x2e\x18\xd6\x60\x84\x02\x18\x37\x92\x92\x15\xab",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\x1f\x3f\x82\x1e\x0d\xd8\x1e\x22"),
Packit Service 4684c1
	},
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct cipher_vectors_st gost28147_cpc_cfb_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x77\xc3\x45\x8e\xf6\x42\xe7\x04\x8e\xfc\x08\xe4\x70\x96\xd6\x05"
Packit Service 4684c1
	     "\x93\x59\x02\x6d\x6f\x97\xca\xe9\xcf\x89\x44\x4b\xde\x6c\x22\x1d"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\x07\x9c\x91\xbe"),
Packit Service 4684c1
	 .ciphertext = (uint8_t *)
Packit Service 4684c1
		 "\x19\x35\x81\x34",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\x43\x7c\x3e\x8e\x2f\x2a\x00\x98"),
Packit Service 4684c1
	},
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct cipher_vectors_st gost28147_cpd_cfb_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x38\x9f\xe8\x37\xff\x9c\x5d\x29\xfc\x48\x55\xa0\x87\xea\xe8\x40"
Packit Service 4684c1
	     "\x20\x87\x5b\xb2\x01\x15\x55\xa7\xe3\x2d\xcb\x3d\xd6\x59\x04\x73"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\x2f\x31\xd8\x83\xb4\x20\xe8\x6e\xda"),
Packit Service 4684c1
	 .ciphertext = (uint8_t *)
Packit Service 4684c1
		 "\x6d\xa4\xed\x40\x08\x88\x71\xad\x16",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\xc5\xa2\xd2\x1f\x2f\xdf\xb8\xeb"),
Packit Service 4684c1
	},
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct cipher_vectors_st gost28147_tc26z_cfb_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x8d\x5a\x2c\x83\xa7\xc7\x0a\x61\xd6\x1b\x34\xb5\x1f\xdf\x42\x68"
Packit Service 4684c1
	     "\x66\x71\xa3\x5d\x87\x4c\xfd\x84\x99\x36\x63\xb6\x1e\xd6\x0d\xad"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\xd2\xfd\xf8\x3a\xc1\xb4\x39\x23\x2e\xaa\xcc\x98\x0a\x02\xda\x33"),
Packit Service 4684c1
	 .ciphertext = (uint8_t *)
Packit Service 4684c1
		 "\xed\xa7\xf1\x41\x01\x9c\xbd\xcd\x44\x6b\x00\x96\x87\xf7\xc7\xe6",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\x46\x60\x6f\x0d\x88\x34\x23\x5a"),
Packit Service 4684c1
	},
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct cipher_vectors_st gost28147_tc26z_cnt_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x59\x9f\x84\xba\xc3\xf3\xd2\xf1\x60\xe1\xe3\xf2\x6a\x96\x1a\xf9"
Packit Service 4684c1
	     "\x9c\x48\xb2\x4e\xbc\xbb\xbf\x7c\xd8\xf3\xac\xcd\x96\x8d\x28\x6a"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\x90\xa2\x39\x66\xae\x01\xb9\xa3\x52\x4e\xc8\xed\x6c\xdd\x88\x30"),
Packit Service 4684c1
	 .ciphertext = (uint8_t *)
Packit Service 4684c1
		 "\xe8\xb1\x4f\xc7\x30\xdc\x25\xbb\x36\xba\x64\x3c\x17\xdb\xff\x99",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\x8d\xaf\xa8\xd1\x58\xed\x05\x8d"),
Packit Service 4684c1
	}
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct cipher_vectors_st aes128_xts_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\xa1\xb9\x0c\xba\x3f\x06\xac\x35\x3b\x2c\x34\x38\x76\x08\x17\x62"
Packit Service 4684c1
             "\x09\x09\x23\x02\x6e\x91\x77\x18\x15\xf2\x9d\xab\x01\x93\x2f\x2f"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\xeb\xab\xce\x95\xb1\x4d\x3c\x8d\x6f\xb3\x50\x39\x07\x90\x31\x1c"),
Packit Service 4684c1
	 .ciphertext = (uint8_t *)
Packit Service 4684c1
	     "\x77\x8a\xe8\xb4\x3c\xb9\x8d\x5a\x82\x50\x81\xd5\xbe\x47\x1c\x63",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\x4f\xae\xf7\x11\x7c\xda\x59\xc6\x6e\x4b\x92\x01\x3e\x76\x8a\xd5"),
Packit Service 4684c1
	 },
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x75\x03\x72\xc3\xd8\x2f\x63\x38\x28\x67\xbe\x66\x62\xac\xfa\x4a"
Packit Service 4684c1
             "\x25\x9b\xe3\xfa\x9b\xc6\x62\xa1\x15\x4f\xfa\xae\xd8\xb4\x48\xa5"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\xd8\xe3\xa5\x65\x59\xa4\x36\xce\x0d\x8b\x21\x2c\x80\xa8\x8b\x23"
Packit Service 4684c1
             "\xaf\x62\xb0\xe5\x98\xf2\x08\xe0\x3c\x1f\x2e\x9f\xa5\x63\xa5\x4b"),
Packit Service 4684c1
	 .ciphertext = (uint8_t *)
Packit Service 4684c1
	     "\x49\x5f\x78\x55\x53\x5e\xfd\x13\x34\x64\xdc\x9a\x9a\xbf\x8a\x0f"
Packit Service 4684c1
             "\x28\xfa\xcb\xce\x21\xbd\x3c\x22\x17\x8e\xc4\x89\xb7\x99\xe4\x91",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\x93\xa2\x92\x54\xc4\x7e\x42\x60\x66\x96\x21\x30\x7d\x4f\x5c\xd3"),
Packit Service 4684c1
	 },
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct cipher_vectors_st aes256_xts_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
             "\x1e\xa6\x61\xc5\x8d\x94\x3a\x0e\x48\x01\xe4\x2f\x4b\x09\x47\x14"
Packit Service 4684c1
             "\x9e\x7f\x9f\x8e\x3e\x68\xd0\xc7\x50\x52\x10\xbd\x31\x1a\x0e\x7c"
Packit Service 4684c1
             "\xd6\xe1\x3f\xfd\xf2\x41\x8d\x8d\x19\x11\xc0\x04\xcd\xa5\x8d\xa3"
Packit Service 4684c1
             "\xd6\x19\xb7\xe2\xb9\x14\x1e\x58\x31\x8e\xea\x39\x2c\xf4\x1b\x08"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\x2e\xed\xea\x52\xcd\x82\x15\xe1\xac\xc6\x47\xe8\x10\xbb\xc3\x64"
Packit Service 4684c1
             "\x2e\x87\x28\x7f\x8d\x2e\x57\xe3\x6c\x0a\x24\xfb\xc1\x2a\x20\x2e"),
Packit Service 4684c1
	 .ciphertext = (uint8_t *)
Packit Service 4684c1
	     "\xcb\xaa\xd0\xe2\xf6\xce\xa3\xf5\x0b\x37\xf9\x34\xd4\x6a\x9b\x13"
Packit Service 4684c1
             "\x0b\x9d\x54\xf0\x7e\x34\xf3\x6a\xf7\x93\xe8\x6f\x73\xc6\xd7\xdb",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\xad\xf8\xd9\x26\x27\x46\x4a\xd2\xf0\x42\x8e\x84\xa9\xf8\x75\x64"),
Packit Service 4684c1
	 },
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct cipher_aead_vectors_st aes128_siv_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x7f\x7e\x7d\x7c\x7b\x7a\x79\x78\x77\x76\x75\x74\x73\x72\x71\x70"
Packit Service 4684c1
	     "\x40\x41\x42\x43\x44\x45\x46\x47\x48\x49\x4a\x4b\x4c\x4d\x4e\x4f"),
Packit Service 4684c1
	 STR(auth, auth_size,
Packit Service 4684c1
	     "\x00\x11\x22\x33\x44\x55\x66\x77\x88\x99\xaa\xbb\xcc\xdd\xee\xff"
Packit Service 4684c1
	     "\xde\xad\xda\xda\xde\xad\xda\xda\xff\xee\xdd\xcc\xbb\xaa\x99\x88"
Packit Service 4684c1
	     "\x77\x66\x55\x44\x33\x22\x11\x00"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\x74\x68\x69\x73\x20\x69\x73\x20\x73\x6f\x6d\x65\x20\x70\x6c\x61"
Packit Service 4684c1
	     "\x69\x6e\x74\x65\x78\x74\x20\x74\x6f\x20\x65\x6e\x63\x72\x79\x70"
Packit Service 4684c1
	     "\x74\x20\x75\x73\x69\x6e\x67\x20\x53\x49\x56\x2d\x41\x45\x53"),
Packit Service 4684c1
	 .ciphertext = (uint8_t *)
Packit Service 4684c1
	     "\xa4\xff\xb8\x7f\xdb\xa9\x7c\x89\x44\xa6\x23\x25\xf1\x33\xb4\xe0"
Packit Service 4684c1
	     "\x1c\xa5\x52\x76\xe2\x26\x1c\x1a\x1d\x1d\x42\x48\xd1\xda\x30\xba"
Packit Service 4684c1
	     "\x52\xb9\xc8\xd7\x95\x5d\x65\xc8\xd2\xce\x6e\xb7\xe3\x67\xd0",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\x02\x03\x04"),
Packit Service 4684c1
	 .tag_size = 16,
Packit Service 4684c1
	 .tag = (void *)
Packit Service 4684c1
	     "\xf1\xdb\xa3\x3d\xe5\xb3\x36\x9e\x88\x3f\x67\xb6\xfc\x82\x3c\xee",
Packit Service 4684c1
	 .tag_prepended = 1,
Packit Service 4684c1
	}
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct cipher_aead_vectors_st aes256_siv_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\xc2\x7d\xf2\xfd\xae\xc3\x5d\x4a\x2a\x41\x2a\x50\xc3\xe8\xc4\x7d"
Packit Service 4684c1
	     "\x2d\x56\x8e\x91\xa3\x8e\x54\x14\x8a\xbd\xc0\xb6\xe8\x6c\xaf\x87"
Packit Service 4684c1
	     "\x69\x5c\x0a\x8a\xdf\x4c\x5f\x8e\xb2\xc6\xc8\xb1\x36\x52\x98\x64"
Packit Service 4684c1
	     "\xf3\xb8\x4b\x3a\xe8\xe3\x67\x6c\xe7\x60\xc4\x61\xf3\xa1\x3e\x83"),
Packit Service 4684c1
	 STR(auth, auth_size,
Packit Service 4684c1
	     "\x00\x11\x22\x33\x44\x55\x66\x77\x88\x99\xaa\xbb\xcc\xdd\xee\xff"
Packit Service 4684c1
	     "\xde\xad\xda\xda\xde\xad\xda\xda\xff\xee\xdd\xcc\xbb\xaa\x99\x88"
Packit Service 4684c1
	     "\x77\x66\x55\x44\x33\x22\x11\x00"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\x74\x68\x69\x73\x20\x69\x73\x20\x73\x6f\x6d\x65\x20\x70\x6c\x61"
Packit Service 4684c1
	     "\x69\x6e\x74\x65\x78\x74\x20\x74\x6f\x20\x65\x6e\x63\x72\x79\x70"
Packit Service 4684c1
	     "\x74\x20\x75\x73\x69\x6e\x67\x20\x53\x49\x56\x2d\x41\x45\x53"),
Packit Service 4684c1
	 .ciphertext = (uint8_t *)
Packit Service 4684c1
	     "\x50\x93\x3d\xa8\x04\x7b\xc3\x06\xfa\xba\xf0\xc3\xd9\xfa\x84\x71"
Packit Service 4684c1
	 "\xc7\x0a\x7d\xef\x39\xa2\xf9\x1d\x68\xa2\x02\x1c\x99\xac\x7e\x2a\x24"
Packit Service 4684c1
	 "\x53\x5a\x13\x4b\xa2\x3e\xc1\x57\x87\xce\xbe\x5c\x53\xcc",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\x09\xf9\x11\x02\x9d\x74\xe3\x5b\xd8\x41\x56\xc5\x63\x56\x88\xc0"),
Packit Service 4684c1
	 .tag_size = 16,
Packit Service 4684c1
	 .tag = (void *)
Packit Service 4684c1
	     "\x5a\x97\x9b\x0d\xa5\x8f\xde\x80\x51\x62\x1a\xe6\xbf\x96\xfe\xda",
Packit Service 4684c1
	 .tag_prepended = 1,
Packit Service 4684c1
	}
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct cipher_vectors_st chacha20_32_vectors[] = { /* RFC8439 */
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x00\x01\x02\x03\x04\x05\x06\x07\x08\x09\x0a\x0b\x0c\x0d\x0e\x0f\x10\x11\x12\x13\x14\x15\x16\x17\x18\x19\x1a\x1b\x1c\x1d\x1e\x1f"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\x4c\x61\x64\x69\x65\x73\x20\x61\x6e\x64\x20\x47\x65\x6e\x74\x6c\x65\x6d\x65\x6e\x20\x6f\x66\x20\x74\x68\x65\x20\x63\x6c\x61\x73\x73\x20\x6f\x66\x20\x27\x39\x39\x3a\x20\x49\x66\x20\x49\x20\x63\x6f\x75\x6c\x64\x20\x6f\x66\x66\x65\x72\x20\x79\x6f\x75\x20\x6f\x6e\x6c\x79\x20\x6f\x6e\x65\x20\x74\x69\x70\x20\x66\x6f\x72\x20\x74\x68\x65\x20\x66\x75\x74\x75\x72\x65\x2c\x20\x73\x75\x6e\x73\x63\x72\x65\x65\x6e\x20\x77\x6f\x75\x6c\x64\x20\x62\x65\x20\x69\x74\x2e"),
Packit Service 4684c1
	 .ciphertext = (uint8_t *)
Packit Service 4684c1
	     "\x6e\x2e\x35\x9a\x25\x68\xf9\x80\x41\xba\x07\x28\xdd\x0d\x69\x81\xe9\x7e\x7a\xec\x1d\x43\x60\xc2\x0a\x27\xaf\xcc\xfd\x9f\xae\x0b\xf9\x1b\x65\xc5\x52\x47\x33\xab\x8f\x59\x3d\xab\xcd\x62\xb3\x57\x16\x39\xd6\x24\xe6\x51\x52\xab\x8f\x53\x0c\x35\x9f\x08\x61\xd8\x07\xca\x0d\xbf\x50\x0d\x6a\x61\x56\xa3\x8e\x08\x8a\x22\xb6\x5e\x52\xbc\x51\x4d\x16\xcc\xf8\x06\x81\x8c\xe9\x1a\xb7\x79\x37\x36\x5a\xf9\x0b\xbf\x74\xa3\x5b\xe6\xb4\x0b\x8e\xed\xf2\x78\x5e\x42\x87\x4d",
Packit Service 4684c1
	 STR(iv, iv_size,
Packit Service 4684c1
	     "\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x4a\x00\x00\x00\x00")
Packit Service 4684c1
	},
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
static int test_cipher(gnutls_cipher_algorithm_t cipher,
Packit Service 4684c1
		       const struct cipher_vectors_st *vectors,
Packit Service 4684c1
		       size_t vectors_size, unsigned flags)
Packit Service 4684c1
{
Packit Service 4684c1
	gnutls_cipher_hd_t hd;
Packit Service 4684c1
	int ret;
Packit Service 4684c1
	unsigned int i;
Packit Service 4684c1
	uint8_t tmp[384];
Packit Service 4684c1
	gnutls_datum_t key, iv = {NULL, 0};
Packit Service 4684c1
Packit Service 4684c1
	for (i = 0; i < vectors_size; i++) {
Packit Service 4684c1
		key.data = (void *) vectors[i].key;
Packit Service 4684c1
		key.size = vectors[i].key_size;
Packit Service 4684c1
Packit Service 4684c1
		if (vectors[i].iv != NULL) {
Packit Service 4684c1
			iv.data = (void *) vectors[i].iv;
Packit Service 4684c1
			iv.size = gnutls_cipher_get_iv_size(cipher);
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		if (iv.size != vectors[i].iv_size)
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
Packit Service 4684c1
		ret = gnutls_cipher_init(&hd, cipher, &key, &iv;;
Packit Service 4684c1
		if (ret < 0) {
Packit Service 4684c1
			_gnutls_debug_log("error initializing: %s\n",
Packit Service 4684c1
					  gnutls_cipher_get_name(cipher));
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		ret =
Packit Service 4684c1
		    gnutls_cipher_encrypt2(hd,
Packit Service 4684c1
					   vectors[i].plaintext,
Packit Service 4684c1
					   vectors[i].plaintext_size,
Packit Service 4684c1
					   tmp, sizeof(tmp));
Packit Service 4684c1
		if (ret < 0)
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
Packit Service 4684c1
		if (memcmp
Packit Service 4684c1
		    (tmp, vectors[i].ciphertext,
Packit Service 4684c1
		     vectors[i].plaintext_size) != 0) {
Packit Service 4684c1
			_gnutls_debug_log("%s test vector %d failed!\n",
Packit Service 4684c1
					  gnutls_cipher_get_name(cipher),
Packit Service 4684c1
					  i);
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		/* check in-place encryption */
Packit Service 4684c1
		if (cipher != GNUTLS_CIPHER_ARCFOUR_128) { /* arcfour is stream */
Packit Service 4684c1
			gnutls_cipher_set_iv(hd, (void*)vectors[i].iv, vectors[i].iv_size);
Packit Service 4684c1
Packit Service 4684c1
			memcpy(tmp, vectors[i].plaintext, vectors[i].plaintext_size);
Packit Service 4684c1
			ret = gnutls_cipher_encrypt(hd, tmp, vectors[i].plaintext_size);
Packit Service 4684c1
			if (ret < 0)
Packit Service 4684c1
				return
Packit Service 4684c1
				    gnutls_assert_val
Packit Service 4684c1
				    (GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
Packit Service 4684c1
			if (memcmp(tmp, vectors[i].ciphertext, vectors[i].plaintext_size) != 0) {
Packit Service 4684c1
				_gnutls_debug_log("%s vector %d in-place encryption failed!\n", gnutls_cipher_get_name(cipher), i);
Packit Service 4684c1
				return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
			}
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		/* check the internal IV */
Packit Service 4684c1
		if (vectors[i].internal_iv_size > 0) {
Packit Service 4684c1
			ret = _gnutls_cipher_get_iv(hd, tmp, sizeof(tmp));
Packit Service 4684c1
			if (ret < 0)
Packit Service 4684c1
				return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
Packit Service 4684c1
			if (memcmp(tmp, vectors[i].internal_iv, ret) != 0) {
Packit Service 4684c1
				_gnutls_debug_log("%s vector %d internal IV check failed!\n",
Packit Service 4684c1
						  gnutls_cipher_get_name(cipher),
Packit Service 4684c1
						  i);
Packit Service 4684c1
				return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
			}
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		gnutls_cipher_deinit(hd);
Packit Service 4684c1
	}
Packit Service 4684c1
Packit Service 4684c1
	iv.size = gnutls_cipher_get_iv_size(cipher);
Packit Service 4684c1
Packit Service 4684c1
	for (i = 0; i < vectors_size; i++) {
Packit Service 4684c1
		key.data = (void *) vectors[i].key;
Packit Service 4684c1
		key.size = vectors[i].key_size;
Packit Service 4684c1
Packit Service 4684c1
		iv.data = (void *) vectors[i].iv;
Packit Service 4684c1
Packit Service 4684c1
		ret = gnutls_cipher_init(&hd, cipher, &key, &iv;;
Packit Service 4684c1
		if (ret < 0)
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
Packit Service 4684c1
		ret =
Packit Service 4684c1
		    gnutls_cipher_decrypt2(hd,
Packit Service 4684c1
					   vectors[i].ciphertext,
Packit Service 4684c1
					   vectors[i].plaintext_size, tmp,
Packit Service 4684c1
					   sizeof(tmp));
Packit Service 4684c1
		if (ret < 0) {
Packit Service 4684c1
			_gnutls_debug_log
Packit Service 4684c1
			    ("%s decryption of test vector %d failed!\n",
Packit Service 4684c1
			     gnutls_cipher_get_name(cipher), i);
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		if (memcmp
Packit Service 4684c1
		    (tmp, vectors[i].plaintext,
Packit Service 4684c1
		     vectors[i].plaintext_size) != 0) {
Packit Service 4684c1
			_gnutls_debug_log("%s test vector %d failed!\n",
Packit Service 4684c1
					  gnutls_cipher_get_name(cipher),
Packit Service 4684c1
					  i);
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		/* check in-place decryption */
Packit Service 4684c1
		if (cipher != GNUTLS_CIPHER_ARCFOUR_128) { /* arcfour is stream */
Packit Service 4684c1
			gnutls_cipher_set_iv(hd, (void*)vectors[i].iv, vectors[i].iv_size);
Packit Service 4684c1
Packit Service 4684c1
			memcpy(tmp, vectors[i].ciphertext, vectors[i].plaintext_size);
Packit Service 4684c1
			ret = gnutls_cipher_decrypt(hd, tmp, vectors[i].plaintext_size);
Packit Service 4684c1
			if (ret < 0)
Packit Service 4684c1
				return
Packit Service 4684c1
				    gnutls_assert_val
Packit Service 4684c1
				    (GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
Packit Service 4684c1
			if (memcmp(tmp, vectors[i].plaintext, vectors[i].plaintext_size) != 0) {
Packit Service 4684c1
				_gnutls_debug_log("%s vector %d in-place decryption failed!\n", gnutls_cipher_get_name(cipher), i);
Packit Service 4684c1
				return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
			}
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		gnutls_cipher_deinit(hd);
Packit Service 4684c1
	}
Packit Service 4684c1
Packit Service 4684c1
	_gnutls_debug_log
Packit Service 4684c1
	    ("%s self check succeeded\n",
Packit Service 4684c1
	     gnutls_cipher_get_name(cipher));
Packit Service 4684c1
Packit Service 4684c1
	return 0;
Packit Service 4684c1
}
Packit Service 4684c1
Packit Service 4684c1
static int test_cipher_all_block_sizes(gnutls_cipher_algorithm_t cipher,
Packit Service 4684c1
				       const struct cipher_vectors_st *vectors,
Packit Service 4684c1
				       size_t vectors_size, unsigned flags)
Packit Service 4684c1
{
Packit Service 4684c1
	gnutls_cipher_hd_t hd;
Packit Service 4684c1
	int ret;
Packit Service 4684c1
	unsigned int i;
Packit Service 4684c1
	uint8_t tmp[384];
Packit Service 4684c1
	gnutls_datum_t key, iv = {NULL, 0};
Packit Service 4684c1
	size_t block;
Packit Service 4684c1
	size_t offset;
Packit Service 4684c1
Packit Service 4684c1
	for (i = 0; i < vectors_size; i++) {
Packit Service 4684c1
		for (block = 1; block <= vectors[i].plaintext_size; block++) {
Packit Service 4684c1
			key.data = (void *) vectors[i].key;
Packit Service 4684c1
			key.size = vectors[i].key_size;
Packit Service 4684c1
Packit Service 4684c1
			iv.data = (void *) vectors[i].iv;
Packit Service 4684c1
			iv.size = gnutls_cipher_get_iv_size(cipher);
Packit Service 4684c1
Packit Service 4684c1
			if (iv.size != vectors[i].iv_size)
Packit Service 4684c1
				return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
Packit Service 4684c1
			ret = gnutls_cipher_init(&hd, cipher, &key, &iv;;
Packit Service 4684c1
			if (ret < 0) {
Packit Service 4684c1
				_gnutls_debug_log("error initializing: %s\n",
Packit Service 4684c1
						  gnutls_cipher_get_name(cipher));
Packit Service 4684c1
				return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
			}
Packit Service 4684c1
Packit Service 4684c1
			for (offset = 0;
Packit Service 4684c1
			     offset < vectors[i].plaintext_size;
Packit Service 4684c1
			     offset += block) {
Packit Service 4684c1
				ret =
Packit Service 4684c1
				    gnutls_cipher_encrypt2(hd,
Packit Service 4684c1
							   vectors[i].plaintext + offset,
Packit Service 4684c1
							   MIN(block, vectors[i].plaintext_size - offset),
Packit Service 4684c1
							   tmp + offset,
Packit Service 4684c1
							   sizeof(tmp) - offset);
Packit Service 4684c1
				if (ret < 0)
Packit Service 4684c1
					return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
			}
Packit Service 4684c1
Packit Service 4684c1
			if (memcmp
Packit Service 4684c1
			    (tmp, vectors[i].ciphertext,
Packit Service 4684c1
			     vectors[i].plaintext_size) != 0) {
Packit Service 4684c1
				_gnutls_debug_log("%s encryption of test vector %d failed with block size %d/%d!\n",
Packit Service 4684c1
						  gnutls_cipher_get_name(cipher),
Packit Service 4684c1
						  i, (int)block, (int)vectors[i].plaintext_size);
Packit Service 4684c1
				return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
			}
Packit Service 4684c1
Packit Service 4684c1
			gnutls_cipher_deinit(hd);
Packit Service 4684c1
		}
Packit Service 4684c1
	}
Packit Service 4684c1
Packit Service 4684c1
	for (i = 0; i < vectors_size; i++) {
Packit Service 4684c1
		for (block = 1; block <= vectors[i].plaintext_size; block++) {
Packit Service 4684c1
			key.data = (void *) vectors[i].key;
Packit Service 4684c1
			key.size = vectors[i].key_size;
Packit Service 4684c1
Packit Service 4684c1
			iv.data = (void *) vectors[i].iv;
Packit Service 4684c1
			iv.size = gnutls_cipher_get_iv_size(cipher);
Packit Service 4684c1
Packit Service 4684c1
			ret = gnutls_cipher_init(&hd, cipher, &key, &iv;;
Packit Service 4684c1
			if (ret < 0)
Packit Service 4684c1
				return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
Packit Service 4684c1
			for (offset = 0;
Packit Service 4684c1
			     offset + block <= vectors[i].plaintext_size;
Packit Service 4684c1
			     offset += block) {
Packit Service 4684c1
				ret =
Packit Service 4684c1
				    gnutls_cipher_decrypt2(hd,
Packit Service 4684c1
							   vectors[i].ciphertext + offset,
Packit Service 4684c1
							   MIN(block, vectors[i].plaintext_size - offset),
Packit Service 4684c1
							   tmp + offset,
Packit Service 4684c1
							   sizeof(tmp) - offset);
Packit Service 4684c1
				if (ret < 0)
Packit Service 4684c1
					return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
			}
Packit Service 4684c1
Packit Service 4684c1
			if (memcmp
Packit Service 4684c1
			    (tmp, vectors[i].plaintext,
Packit Service 4684c1
			     vectors[i].plaintext_size) != 0) {
Packit Service 4684c1
				_gnutls_debug_log("%s decryption of test vector %d failed with block size %d!\n",
Packit Service 4684c1
						  gnutls_cipher_get_name(cipher),
Packit Service 4684c1
						  i, (int)block);
Packit Service 4684c1
				return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
			}
Packit Service 4684c1
Packit Service 4684c1
			gnutls_cipher_deinit(hd);
Packit Service 4684c1
		}
Packit Service 4684c1
	}
Packit Service 4684c1
Packit Service 4684c1
	_gnutls_debug_log
Packit Service 4684c1
	    ("%s self check succeeded\n",
Packit Service 4684c1
	     gnutls_cipher_get_name(cipher));
Packit Service 4684c1
Packit Service 4684c1
	return 0;
Packit Service 4684c1
}
Packit Service 4684c1
Packit Service 4684c1
/* AEAD modes (compat APIs) */
Packit Service 4684c1
static int test_cipher_aead_compat(gnutls_cipher_algorithm_t cipher,
Packit Service 4684c1
			    const struct cipher_aead_vectors_st *vectors,
Packit Service 4684c1
			    size_t vectors_size)
Packit Service 4684c1
{
Packit Service 4684c1
	gnutls_cipher_hd_t hd;
Packit Service 4684c1
	int ret;
Packit Service 4684c1
	unsigned int i;
Packit Service 4684c1
	uint8_t tmp[384];
Packit Service 4684c1
	uint8_t tmp2[384];
Packit Service 4684c1
	gnutls_datum_t key, iv;
Packit Service 4684c1
	unsigned tag_size;
Packit Service 4684c1
Packit Service 4684c1
	_gnutls_debug_log("compat: running tests for: %s\n",
Packit Service 4684c1
				  gnutls_cipher_get_name(cipher));
Packit Service 4684c1
Packit Service 4684c1
	for (i = 0; i < vectors_size; i++) {
Packit Service 4684c1
		memset(tmp, 0, sizeof(tmp));
Packit Service 4684c1
		key.data = (void *) vectors[i].key;
Packit Service 4684c1
		key.size = vectors[i].key_size;
Packit Service 4684c1
Packit Service 4684c1
		iv.data = (void *) vectors[i].iv;
Packit Service 4684c1
		iv.size = vectors[i].iv_size;
Packit Service 4684c1
		tag_size = vectors[i].tag_size;
Packit Service 4684c1
Packit Service 4684c1
Packit Service 4684c1
		if (tag_size > gnutls_cipher_get_tag_size(cipher)) {
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		ret = gnutls_cipher_init(&hd, cipher, &key, &iv;;
Packit Service 4684c1
		if (ret < 0) {
Packit Service 4684c1
			if (vectors[i].compat_apis == 0) {
Packit Service 4684c1
				return 0; /* expected */
Packit Service 4684c1
			} else {
Packit Service 4684c1
				_gnutls_debug_log("compat: error initializing: %s\n",
Packit Service 4684c1
					  gnutls_cipher_get_name(cipher));
Packit Service 4684c1
				return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
			}
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		if (vectors[i].compat_apis == 0) {
Packit Service 4684c1
			_gnutls_debug_log("compat: initialized but shouldn't: %s\n",
Packit Service 4684c1
				  gnutls_cipher_get_name(cipher));
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		if (vectors[i].auth_size) {
Packit Service 4684c1
			ret = gnutls_cipher_add_auth(hd, vectors[i].auth, vectors[i].auth_size);
Packit Service 4684c1
			if (ret < 0)
Packit Service 4684c1
				return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		ret = gnutls_cipher_encrypt2(hd, vectors[i].plaintext, vectors[i].plaintext_size,
Packit Service 4684c1
					     tmp, sizeof(tmp));
Packit Service 4684c1
		if (ret < 0)
Packit Service 4684c1
			return
Packit Service 4684c1
			    gnutls_assert_val
Packit Service 4684c1
			    (GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
Packit Service 4684c1
		ret = gnutls_cipher_tag(hd, tmp+vectors[i].plaintext_size, tag_size);
Packit Service 4684c1
		if (ret < 0)
Packit Service 4684c1
			return
Packit Service 4684c1
			    gnutls_assert_val
Packit Service 4684c1
			    (GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
Packit Service 4684c1
		if (memcmp(tmp+vectors[i].plaintext_size, vectors[i].tag, tag_size) != 0) {
Packit Service 4684c1
			_gnutls_debug_log
Packit Service 4684c1
			    ("compat: %s test vector %d failed (tag)!\n",
Packit Service 4684c1
			     gnutls_cipher_get_name(cipher), i);
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		if (vectors[i].plaintext_size > 0) {
Packit Service 4684c1
			if (memcmp
Packit Service 4684c1
			    (tmp, vectors[i].ciphertext,
Packit Service 4684c1
			     vectors[i].plaintext_size) != 0) {
Packit Service 4684c1
				_gnutls_debug_log
Packit Service 4684c1
				    ("compat: %s test vector %d failed!\n",
Packit Service 4684c1
				     gnutls_cipher_get_name(cipher), i);
Packit Service 4684c1
Packit Service 4684c1
				return
Packit Service 4684c1
				    gnutls_assert_val
Packit Service 4684c1
				    (GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
			}
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		if (vectors[i].plaintext_size > 0) {
Packit Service 4684c1
			/* check inplace encryption */
Packit Service 4684c1
			gnutls_cipher_set_iv(hd, (void*)vectors[i].iv, vectors[i].iv_size);
Packit Service 4684c1
			memcpy(tmp2, vectors[i].plaintext, vectors[i].plaintext_size);
Packit Service 4684c1
Packit Service 4684c1
			ret = gnutls_cipher_encrypt(hd, tmp2, vectors[i].plaintext_size);
Packit Service 4684c1
			if (ret < 0)
Packit Service 4684c1
				return
Packit Service 4684c1
				    gnutls_assert_val
Packit Service 4684c1
				    (GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
Packit Service 4684c1
			if (memcmp(tmp, tmp2, vectors[i].plaintext_size) != 0) {
Packit Service 4684c1
				_gnutls_debug_log("compat: %s vector %d in-place encryption failed!\n", gnutls_cipher_get_name(cipher), i);
Packit Service 4684c1
				return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
			}
Packit Service 4684c1
Packit Service 4684c1
			/* check decryption with separate buffers */
Packit Service 4684c1
			gnutls_cipher_set_iv(hd, (void*)vectors[i].iv, vectors[i].iv_size);
Packit Service 4684c1
Packit Service 4684c1
			if (vectors[i].auth_size) {
Packit Service 4684c1
				ret = gnutls_cipher_add_auth(hd, vectors[i].auth, vectors[i].auth_size);
Packit Service 4684c1
				if (ret < 0)
Packit Service 4684c1
					return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
			}
Packit Service 4684c1
Packit Service 4684c1
			ret =
Packit Service 4684c1
			    gnutls_cipher_decrypt2(hd, tmp, vectors[i].plaintext_size,
Packit Service 4684c1
						   tmp2, sizeof(tmp2));
Packit Service 4684c1
			if (ret < 0)
Packit Service 4684c1
				return
Packit Service 4684c1
				    gnutls_assert_val
Packit Service 4684c1
				    (GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
Packit Service 4684c1
			if (memcmp(tmp2, vectors[i].plaintext, vectors[i].plaintext_size) != 0) {
Packit Service 4684c1
				_gnutls_debug_log("compat: %s test vector %d failed (decryption)!\n",
Packit Service 4684c1
					gnutls_cipher_get_name(cipher), i);
Packit Service 4684c1
				return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
			}
Packit Service 4684c1
Packit Service 4684c1
			/* check in-place decryption */
Packit Service 4684c1
			if (vectors[i].plaintext_size > 0) {
Packit Service 4684c1
				gnutls_cipher_set_iv(hd, (void*)vectors[i].iv, vectors[i].iv_size);
Packit Service 4684c1
Packit Service 4684c1
				if (vectors[i].auth_size) {
Packit Service 4684c1
					ret = gnutls_cipher_add_auth(hd, vectors[i].auth, vectors[i].auth_size);
Packit Service 4684c1
					if (ret < 0)
Packit Service 4684c1
						return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
				}
Packit Service 4684c1
Packit Service 4684c1
				memcpy(tmp2, tmp, vectors[i].plaintext_size);
Packit Service 4684c1
				ret = gnutls_cipher_decrypt(hd, tmp2, vectors[i].plaintext_size);
Packit Service 4684c1
				if (ret < 0)
Packit Service 4684c1
					return
Packit Service 4684c1
					    gnutls_assert_val
Packit Service 4684c1
					    (GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
Packit Service 4684c1
				if (memcmp(tmp2, vectors[i].plaintext, vectors[i].plaintext_size) != 0) {
Packit Service 4684c1
					_gnutls_debug_log("compat: %s vector %d in-place decryption failed!\n", gnutls_cipher_get_name(cipher), i);
Packit Service 4684c1
					return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
				}
Packit Service 4684c1
			}
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		gnutls_cipher_deinit(hd);
Packit Service 4684c1
	}
Packit Service 4684c1
Packit Service 4684c1
	_gnutls_debug_log
Packit Service 4684c1
	    ("%s compat self check succeeded\n",
Packit Service 4684c1
	     gnutls_cipher_get_name(cipher));
Packit Service 4684c1
Packit Service 4684c1
	return 0;
Packit Service 4684c1
Packit Service 4684c1
}
Packit Service 4684c1
Packit Service 4684c1
#define IOV_PARTS 8
Packit Service 4684c1
/* AEAD modes - scatter read */
Packit Service 4684c1
static int test_cipher_aead_scatter(gnutls_cipher_algorithm_t cipher,
Packit Service 4684c1
				    const struct cipher_aead_vectors_st *vectors,
Packit Service 4684c1
				    size_t vectors_size, unsigned flags)
Packit Service 4684c1
{
Packit Service 4684c1
	gnutls_aead_cipher_hd_t hd;
Packit Service 4684c1
	int ret;
Packit Service 4684c1
	unsigned int i, z;
Packit Service 4684c1
	uint8_t tmp[384];
Packit Service 4684c1
	gnutls_datum_t key, iv;
Packit Service 4684c1
	size_t s;
Packit Service 4684c1
	unsigned tag_size;
Packit Service 4684c1
	giovec_t auth_iov[IOV_PARTS];
Packit Service 4684c1
	int auth_iov_len;
Packit Service 4684c1
	int iov_len;
Packit Service 4684c1
	giovec_t iov[IOV_PARTS];
Packit Service 4684c1
	const uint8_t *tag;
Packit Service 4684c1
	uint8_t *ciphertext;
Packit Service 4684c1
Packit Service 4684c1
	_gnutls_debug_log("running scatter (iovec) tests for: %s\n",
Packit Service 4684c1
				  gnutls_cipher_get_name(cipher));
Packit Service 4684c1
Packit Service 4684c1
	for (i = 0; i < vectors_size; i++) {
Packit Service 4684c1
		memset(tmp, 0, sizeof(tmp));
Packit Service 4684c1
		key.data = (void *) vectors[i].key;
Packit Service 4684c1
		key.size = vectors[i].key_size;
Packit Service 4684c1
Packit Service 4684c1
		iv.data = (void *) vectors[i].iv;
Packit Service 4684c1
		iv.size = vectors[i].iv_size;
Packit Service 4684c1
		tag_size = vectors[i].tag_size;
Packit Service 4684c1
Packit Service 4684c1
		if (tag_size > gnutls_cipher_get_tag_size(cipher)) {
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		ret = gnutls_aead_cipher_init(&hd, cipher, &key);
Packit Service 4684c1
		if (ret < 0) {
Packit Service 4684c1
			_gnutls_debug_log("error initializing: %s\n",
Packit Service 4684c1
					  gnutls_cipher_get_name(cipher));
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		s = sizeof(tmp);
Packit Service 4684c1
Packit Service 4684c1
		/* single vector */
Packit Service 4684c1
		auth_iov_len = 1;
Packit Service 4684c1
		auth_iov[0].iov_base = (void*)vectors[i].auth;
Packit Service 4684c1
		auth_iov[0].iov_len = vectors[i].auth_size;
Packit Service 4684c1
Packit Service 4684c1
		iov_len = 1;
Packit Service 4684c1
		iov[0].iov_base = (void*)vectors[i].plaintext;
Packit Service 4684c1
		iov[0].iov_len = vectors[i].plaintext_size;
Packit Service 4684c1
Packit Service 4684c1
		ret =
Packit Service 4684c1
		    gnutls_aead_cipher_encryptv(hd,
Packit Service 4684c1
						iv.data, iv.size,
Packit Service 4684c1
						auth_iov, auth_iov_len,
Packit Service 4684c1
						vectors[i].tag_size,
Packit Service 4684c1
						iov, iov_len,
Packit Service 4684c1
						tmp, &s);
Packit Service 4684c1
		if (ret < 0)
Packit Service 4684c1
			return
Packit Service 4684c1
			    gnutls_assert_val
Packit Service 4684c1
			    (GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
Packit Service 4684c1
		if (s != vectors[i].plaintext_size + tag_size) {
Packit Service 4684c1
			return
Packit Service 4684c1
			    gnutls_assert_val
Packit Service 4684c1
			    (GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		if (vectors[i].tag_prepended)
Packit Service 4684c1
			tag = tmp;
Packit Service 4684c1
		else
Packit Service 4684c1
			tag = tmp+vectors[i].plaintext_size;
Packit Service 4684c1
Packit Service 4684c1
		if (memcmp(tag, vectors[i].tag, tag_size) != 0) {
Packit Service 4684c1
			_gnutls_debug_log
Packit Service 4684c1
			    ("%s test vector %d failed (tag)!\n",
Packit Service 4684c1
			     gnutls_cipher_get_name(cipher), i);
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		if (vectors[i].tag_prepended)
Packit Service 4684c1
			ciphertext = tmp+vectors[i].tag_size;
Packit Service 4684c1
		else
Packit Service 4684c1
			ciphertext = tmp;
Packit Service 4684c1
Packit Service 4684c1
		if (vectors[i].plaintext_size > 0) {
Packit Service 4684c1
			if (memcmp
Packit Service 4684c1
			    (ciphertext, vectors[i].ciphertext,
Packit Service 4684c1
			     vectors[i].plaintext_size) != 0) {
Packit Service 4684c1
				_gnutls_debug_log
Packit Service 4684c1
				    ("%s test vector %d failed!\n",
Packit Service 4684c1
				     gnutls_cipher_get_name(cipher), i);
Packit Service 4684c1
Packit Service 4684c1
				return
Packit Service 4684c1
				    gnutls_assert_val
Packit Service 4684c1
				    (GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
			}
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		/* multi-vector */
Packit Service 4684c1
		auth_iov_len = 0;
Packit Service 4684c1
		if (vectors[i].auth_size > IOV_PARTS) {
Packit Service 4684c1
			unsigned split = vectors[i].auth_size / IOV_PARTS;
Packit Service 4684c1
			assert(split>0);
Packit Service 4684c1
			for (z=0;z
Packit Service 4684c1
				auth_iov[z].iov_base = (void*)(vectors[i].auth+(z*split));
Packit Service 4684c1
				if (z==IOV_PARTS-1)
Packit Service 4684c1
					auth_iov[z].iov_len = vectors[i].auth_size - z*split;
Packit Service 4684c1
				else
Packit Service 4684c1
					auth_iov[z].iov_len = split;
Packit Service 4684c1
				auth_iov_len++;
Packit Service 4684c1
			}
Packit Service 4684c1
		} else {
Packit Service 4684c1
			auth_iov_len = 1;
Packit Service 4684c1
			auth_iov[0].iov_base = (void*)vectors[i].auth;
Packit Service 4684c1
			auth_iov[0].iov_len = vectors[i].auth_size;
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		iov_len = 0;
Packit Service 4684c1
		if (vectors[i].plaintext_size > IOV_PARTS) {
Packit Service 4684c1
			unsigned split = vectors[i].plaintext_size / IOV_PARTS;
Packit Service 4684c1
			assert(split>0);
Packit Service 4684c1
Packit Service 4684c1
			for (z=0;z
Packit Service 4684c1
				iov[z].iov_base = (void*)(vectors[i].plaintext+(z*split));
Packit Service 4684c1
				if (z==IOV_PARTS-1)
Packit Service 4684c1
					iov[z].iov_len = vectors[i].plaintext_size - z*split;
Packit Service 4684c1
				else
Packit Service 4684c1
					iov[z].iov_len = split;
Packit Service 4684c1
				iov_len++;
Packit Service 4684c1
			}
Packit Service 4684c1
		} else {
Packit Service 4684c1
			iov_len = 1;
Packit Service 4684c1
			iov[0].iov_base = (void*)vectors[i].plaintext;
Packit Service 4684c1
			iov[0].iov_len = vectors[i].plaintext_size;
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		s = sizeof(tmp);
Packit Service 4684c1
Packit Service 4684c1
		ret =
Packit Service 4684c1
		    gnutls_aead_cipher_encryptv(hd,
Packit Service 4684c1
						iv.data, iv.size,
Packit Service 4684c1
						auth_iov, auth_iov_len,
Packit Service 4684c1
						vectors[i].tag_size,
Packit Service 4684c1
						iov, iov_len,
Packit Service 4684c1
						tmp, &s);
Packit Service 4684c1
		if (ret < 0)
Packit Service 4684c1
			return
Packit Service 4684c1
			    gnutls_assert_val
Packit Service 4684c1
			    (GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
Packit Service 4684c1
		if (s != vectors[i].plaintext_size + tag_size) {
Packit Service 4684c1
			return
Packit Service 4684c1
			    gnutls_assert_val
Packit Service 4684c1
			    (GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		if (vectors[i].tag_prepended)
Packit Service 4684c1
			tag = tmp;
Packit Service 4684c1
		else
Packit Service 4684c1
			tag = tmp+vectors[i].plaintext_size;
Packit Service 4684c1
Packit Service 4684c1
		if (memcmp(tag, vectors[i].tag, tag_size) != 0) {
Packit Service 4684c1
			_gnutls_debug_log
Packit Service 4684c1
			    ("%s test vector %d failed (tag)!\n",
Packit Service 4684c1
			     gnutls_cipher_get_name(cipher), i);
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		if (vectors[i].tag_prepended)
Packit Service 4684c1
			ciphertext = tmp+vectors[i].tag_size;
Packit Service 4684c1
		else
Packit Service 4684c1
			ciphertext = tmp;
Packit Service 4684c1
Packit Service 4684c1
		if (vectors[i].plaintext_size > 0) {
Packit Service 4684c1
			if (memcmp
Packit Service 4684c1
			    (ciphertext, vectors[i].ciphertext,
Packit Service 4684c1
			     vectors[i].plaintext_size) != 0) {
Packit Service 4684c1
				_gnutls_debug_log
Packit Service 4684c1
				    ("%s test vector %d failed!\n",
Packit Service 4684c1
				     gnutls_cipher_get_name(cipher), i);
Packit Service 4684c1
Packit Service 4684c1
				return
Packit Service 4684c1
				    gnutls_assert_val
Packit Service 4684c1
				    (GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
			}
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
Packit Service 4684c1
Packit Service 4684c1
		gnutls_aead_cipher_deinit(hd);
Packit Service 4684c1
	}
Packit Service 4684c1
Packit Service 4684c1
	_gnutls_debug_log
Packit Service 4684c1
	    ("%s scatter self check succeeded\n",
Packit Service 4684c1
	     gnutls_cipher_get_name(cipher));
Packit Service 4684c1
Packit Service 4684c1
	if (flags & GNUTLS_SELF_TEST_FLAG_NO_COMPAT)
Packit Service 4684c1
		return 0;
Packit Service 4684c1
	else
Packit Service 4684c1
		return test_cipher_aead_compat(cipher, vectors, vectors_size);
Packit Service 4684c1
}
Packit Service 4684c1
Packit Service 4684c1
/* AEAD modes */
Packit Service 4684c1
static int test_cipher_aead(gnutls_cipher_algorithm_t cipher,
Packit Service 4684c1
			    const struct cipher_aead_vectors_st *vectors,
Packit Service 4684c1
			    size_t vectors_size, unsigned flags)
Packit Service 4684c1
{
Packit Service 4684c1
	gnutls_aead_cipher_hd_t hd;
Packit Service 4684c1
	int ret;
Packit Service 4684c1
	unsigned int i;
Packit Service 4684c1
	uint8_t tmp[384];
Packit Service 4684c1
	uint8_t tmp2[384];
Packit Service 4684c1
	gnutls_datum_t key, iv;
Packit Service 4684c1
	size_t s, s2;
Packit Service 4684c1
	const uint8_t *tag;
Packit Service 4684c1
	unsigned tag_size;
Packit Service 4684c1
	uint8_t *ciphertext;
Packit Service 4684c1
Packit Service 4684c1
	_gnutls_debug_log("running tests for: %s\n",
Packit Service 4684c1
				  gnutls_cipher_get_name(cipher));
Packit Service 4684c1
Packit Service 4684c1
	for (i = 0; i < vectors_size; i++) {
Packit Service 4684c1
		memset(tmp, 0, sizeof(tmp));
Packit Service 4684c1
		key.data = (void *) vectors[i].key;
Packit Service 4684c1
		key.size = vectors[i].key_size;
Packit Service 4684c1
Packit Service 4684c1
		iv.data = (void *) vectors[i].iv;
Packit Service 4684c1
		iv.size = vectors[i].iv_size;
Packit Service 4684c1
		tag_size = vectors[i].tag_size;
Packit Service 4684c1
Packit Service 4684c1
		if (tag_size > gnutls_cipher_get_tag_size(cipher)) {
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
		}
Packit Service 4684c1
#if 0
Packit Service 4684c1
		if (iv.size != vectors[i].iv_size)
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
#endif
Packit Service 4684c1
		ret = gnutls_aead_cipher_init(&hd, cipher, &key);
Packit Service 4684c1
		if (ret < 0) {
Packit Service 4684c1
			_gnutls_debug_log("error initializing: %s\n",
Packit Service 4684c1
					  gnutls_cipher_get_name(cipher));
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		s = sizeof(tmp);
Packit Service 4684c1
Packit Service 4684c1
		ret =
Packit Service 4684c1
		    gnutls_aead_cipher_encrypt(hd,
Packit Service 4684c1
					   iv.data, iv.size,
Packit Service 4684c1
					   vectors[i].auth, vectors[i].auth_size,
Packit Service 4684c1
					   vectors[i].tag_size,
Packit Service 4684c1
					   vectors[i].plaintext,
Packit Service 4684c1
					   vectors[i].plaintext_size,
Packit Service 4684c1
					   tmp, &s);
Packit Service 4684c1
		if (ret < 0)
Packit Service 4684c1
			return
Packit Service 4684c1
			    gnutls_assert_val
Packit Service 4684c1
			    (GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
Packit Service 4684c1
		if (s != vectors[i].plaintext_size + tag_size) {
Packit Service 4684c1
			return
Packit Service 4684c1
			    gnutls_assert_val
Packit Service 4684c1
			    (GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		if (vectors[i].tag_prepended)
Packit Service 4684c1
			tag = tmp;
Packit Service 4684c1
		else
Packit Service 4684c1
			tag = tmp+vectors[i].plaintext_size;
Packit Service 4684c1
Packit Service 4684c1
		if (memcmp(tag, vectors[i].tag, tag_size) != 0) {
Packit Service 4684c1
			_gnutls_debug_log
Packit Service 4684c1
			    ("%s test vector %d failed (tag)!\n",
Packit Service 4684c1
			     gnutls_cipher_get_name(cipher), i);
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		if (vectors[i].tag_prepended)
Packit Service 4684c1
			ciphertext = tmp+vectors[i].tag_size;
Packit Service 4684c1
		else
Packit Service 4684c1
			ciphertext = tmp;
Packit Service 4684c1
Packit Service 4684c1
		if (vectors[i].plaintext_size > 0) {
Packit Service 4684c1
			if (memcmp
Packit Service 4684c1
			    (ciphertext, vectors[i].ciphertext,
Packit Service 4684c1
			     vectors[i].plaintext_size) != 0) {
Packit Service 4684c1
				_gnutls_debug_log
Packit Service 4684c1
				    ("%s test vector %d failed!\n",
Packit Service 4684c1
				     gnutls_cipher_get_name(cipher), i);
Packit Service 4684c1
Packit Service 4684c1
				return
Packit Service 4684c1
				    gnutls_assert_val
Packit Service 4684c1
				    (GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
			}
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		/* check decryption */
Packit Service 4684c1
		{
Packit Service 4684c1
			s2 = sizeof(tmp2);
Packit Service 4684c1
			ret =
Packit Service 4684c1
			    gnutls_aead_cipher_decrypt(hd,
Packit Service 4684c1
						   iv.data, iv.size,
Packit Service 4684c1
						   vectors[i].auth, vectors[i].auth_size,
Packit Service 4684c1
						   vectors[i].tag_size,
Packit Service 4684c1
						   tmp, s,
Packit Service 4684c1
						   tmp2, &s2;;
Packit Service 4684c1
			if (ret < 0)
Packit Service 4684c1
				return
Packit Service 4684c1
				    gnutls_assert_val
Packit Service 4684c1
				    (GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
Packit Service 4684c1
			if (s2 != vectors[i].plaintext_size && memcmp(tmp, vectors[i].plaintext, vectors[i].plaintext_size) != 0) {
Packit Service 4684c1
				_gnutls_debug_log("%s test vector %d failed (decryption)!\n",
Packit Service 4684c1
					gnutls_cipher_get_name(cipher), i);
Packit Service 4684c1
				return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
			}
Packit Service 4684c1
Packit Service 4684c1
			/* test tag verification */
Packit Service 4684c1
			if (s > 0) {
Packit Service 4684c1
				(*ciphertext)++;
Packit Service 4684c1
Packit Service 4684c1
				s2 = sizeof(tmp2);
Packit Service 4684c1
				ret =
Packit Service 4684c1
				    gnutls_aead_cipher_decrypt(hd,
Packit Service 4684c1
							   iv.data, iv.size,
Packit Service 4684c1
							   vectors[i].auth, vectors[i].auth_size,
Packit Service 4684c1
							   vectors[i].tag_size,
Packit Service 4684c1
							   tmp, s,
Packit Service 4684c1
							   tmp2, &s2;;
Packit Service 4684c1
Packit Service 4684c1
				if (ret >= 0) {
Packit Service 4684c1
					_gnutls_debug_log("%s: tag check failed\n", gnutls_cipher_get_name(cipher));
Packit Service 4684c1
					return
Packit Service 4684c1
					    gnutls_assert_val
Packit Service 4684c1
					    (GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
				}
Packit Service 4684c1
			}
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		gnutls_aead_cipher_deinit(hd);
Packit Service 4684c1
	}
Packit Service 4684c1
Packit Service 4684c1
	_gnutls_debug_log
Packit Service 4684c1
	    ("%s self check succeeded\n",
Packit Service 4684c1
	     gnutls_cipher_get_name(cipher));
Packit Service 4684c1
Packit Service 4684c1
	return test_cipher_aead_scatter(cipher, vectors, vectors_size, flags);
Packit Service 4684c1
}
Packit Service 4684c1
Packit Service 4684c1
Packit Service 4684c1
Packit Service 4684c1
struct hash_vectors_st {
Packit Service 4684c1
	const uint8_t *plaintext;
Packit Service 4684c1
	unsigned int plaintext_size;
Packit Service 4684c1
	const uint8_t *output;
Packit Service 4684c1
	unsigned int output_size;
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct hash_vectors_st md5_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(plaintext, plaintext_size, "abcdefghijklmnopqrstuvwxyz"),
Packit Service 4684c1
	 STR(output, output_size,
Packit Service 4684c1
	     "\xc3\xfc\xd3\xd7\x61\x92\xe4\x00\x7d\xfb\x49\x6c\xca\x67\xe1\x3b"),
Packit Service 4684c1
	 },
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct hash_vectors_st sha1_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(plaintext, plaintext_size, "what do ya want for nothing?"),
Packit Service 4684c1
	 STR(output, output_size,
Packit Service 4684c1
	     "\x8f\x82\x03\x94\xf9\x53\x35\x18\x20\x45\xda\x24\xf3\x4d\xe5\x2b\xf8\xbc\x34\x32"),
Packit Service 4684c1
	 },
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopqabcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopqabcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq"),
Packit Service 4684c1
	 STR(output, output_size,
Packit Service 4684c1
	     "\xbe\xae\xd1\x6d\x65\x8e\xc7\x92\x9e\xdf\xd6\x2b\xfa\xfe\xac\x29\x9f\x0d\x74\x4d"),
Packit Service 4684c1
	 },
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct hash_vectors_st sha224_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "The quick brown fox jumps over the lazy dog"),
Packit Service 4684c1
	 STR(output, output_size,
Packit Service 4684c1
	     "\x73\x0e\x10\x9b\xd7\xa8\xa3\x2b\x1c\xb9\xd9\xa0\x9a\xa2\x32\x5d\x24\x30\x58\x7d\xdb\xc0\xc3\x8b\xad\x91\x15\x25"),
Packit Service 4684c1
	 },
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct hash_vectors_st sha256_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq"),
Packit Service 4684c1
	 STR(output, output_size,
Packit Service 4684c1
	     "\x24\x8d\x6a\x61\xd2\x06\x38\xb8\xe5\xc0\x26\x93\x0c\x3e\x60\x39\xa3\x3c\xe4\x59\x64\xff\x21\x67\xf6\xec\xed\xd4\x19\xdb\x06\xc1"),
Packit Service 4684c1
	 },
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopqabcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopqabcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq"),
Packit Service 4684c1
	 STR(output, output_size,
Packit Service 4684c1
	     "\x50\xea\x82\x5d\x96\x84\xf4\x22\x9c\xa2\x9f\x1f\xec\x51\x15\x93\xe2\x81\xe4\x6a\x14\x0d\x81\xe0\x00\x5f\x8f\x68\x86\x69\xa0\x6c"),
Packit Service 4684c1
	 },
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct hash_vectors_st sha384_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "The quick brown fox jumps over the lazy dog"),
Packit Service 4684c1
	 STR(output, output_size,
Packit Service 4684c1
	     "\xca\x73\x7f\x10\x14\xa4\x8f\x4c\x0b\x6d\xd4\x3c\xb1\x77\xb0\xaf\xd9\xe5\x16\x93\x67\x54\x4c\x49\x40\x11\xe3\x31\x7d\xbf\x9a\x50\x9c\xb1\xe5\xdc\x1e\x85\xa9\x41\xbb\xee\x3d\x7f\x2a\xfb\xc9\xb1"),
Packit Service 4684c1
	 },
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct hash_vectors_st sha512_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "abcdefghbcdefghicdefghijdefghijkefghijklfghijklmghijklmnhijklmnoijklmnopjklmnopqklmnopqrlmnopqrsmnopqrstnopqrstu"),
Packit Service 4684c1
	 STR(output, output_size,
Packit Service 4684c1
	     "\x8e\x95\x9b\x75\xda\xe3\x13\xda\x8c\xf4\xf7\x28\x14\xfc\x14\x3f\x8f\x77\x79\xc6\xeb\x9f\x7f\xa1\x72\x99\xae\xad\xb6\x88\x90\x18\x50\x1d\x28\x9e\x49\x00\xf7\xe4\x33\x1b\x99\xde\xc4\xb5\x43\x3a\xc7\xd3\x29\xee\xb6\xdd\x26\x54\x5e\x96\xe5\x5b\x87\x4b\xe9\x09"),
Packit Service 4684c1
	 },
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct hash_vectors_st sha3_224_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\xC1\xEC\xFD\xFC"),
Packit Service 4684c1
	 STR(output, output_size,
Packit Service 4684c1
	     "\xA3\x3C\x58\xDF\x8A\x80\x26\xF0\xF9\x59\x19\x66\xBD\x6D\x00\xEE\xD3\xB1\xE8\x29\x58\x0A\xB9\xBE\x26\x8C\xAF\x39"),
Packit Service 4684c1
	 },
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct hash_vectors_st sha3_256_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\xC1\xEC\xFD\xFC"),
Packit Service 4684c1
	 STR(output, output_size,
Packit Service 4684c1
	     "\xC5\x85\x9B\xE8\x25\x60\xCC\x87\x89\x13\x3F\x7C\x83\x4A\x6E\xE6\x28\xE3\x51\xE5\x04\xE6\x01\xE8\x05\x9A\x06\x67\xFF\x62\xC1\x24"),
Packit Service 4684c1
	 }
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct hash_vectors_st sha3_384_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\x4A\x4F\x20\x24\x84\x51\x25\x26"),
Packit Service 4684c1
	 STR(output, output_size,
Packit Service 4684c1
	     "\x89\xDB\xF4\xC3\x9B\x8F\xB4\x6F\xDF\x0A\x69\x26\xCE\xC0\x35\x5A\x4B\xDB\xF9\xC6\xA4\x46\xE1\x40\xB7\xC8\xBD\x08\xFF\x6F\x48\x9F\x20\x5D\xAF\x8E\xFF\xE1\x60\xF4\x37\xF6\x74\x91\xEF\x89\x7C\x23"),
Packit Service 4684c1
	 },
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct hash_vectors_st sha3_512_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\x82\xE1\x92\xE4\x04\x3D\xDC\xD1\x2E\xCF\x52\x96\x9D\x0F\x80\x7E\xED"),
Packit Service 4684c1
	 STR(output, output_size,
Packit Service 4684c1
	     "\x96\x44\xE3\xC9\x0B\x67\xE2\x21\x24\xE9\x6D\xFE\xDC\xE5\x3D\x33\xC4\x60\xF1\x32\x86\x8F\x09\x75\xD1\x8B\x22\xCF\xD5\x9F\x63\x7D\xD8\x5A\xA4\x05\xE3\x98\x08\xA4\x55\x70\xA4\x98\xC0\xB8\xF2\xCB\xA5\x9F\x8E\x14\x37\xEA\xEF\x89\xF2\x0B\x88\x29\x8A\xDF\xA2\xDE"),
Packit Service 4684c1
	 },
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct hash_vectors_st gostr_94_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "The quick brown fox jumps over the lazy dog"),
Packit Service 4684c1
	 STR(output, output_size,
Packit Service 4684c1
	     "\x90\x04\x29\x4a\x36\x1a\x50\x8c\x58\x6f\xe5\x3d\x1f\x1b\x02\x74\x67\x65\xe7\x1b\x76\x54\x72\x78\x6e\x47\x70\xd5\x65\x83\x0a\x76"),
Packit Service 4684c1
	},
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
/* GOST R 34.11-2012 */
Packit Service 4684c1
const struct hash_vectors_st streebog_512_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
            STR(plaintext, plaintext_size,
Packit Service 4684c1
		"\xd1\xe5\x20\xe2\xe5\xf2\xf0\xe8\x2c\x20\xd1\xf2\xf0\xe8\xe1\xee"
Packit Service 4684c1
		"\xe6\xe8\x20\xe2\xed\xf3\xf6\xe8\x2c\x20\xe2\xe5\xfe\xf2\xfa\x20"
Packit Service 4684c1
		"\xf1\x20\xec\xee\xf0\xff\x20\xf1\xf2\xf0\xe5\xeb\xe0\xec\xe8\x20"
Packit Service 4684c1
		"\xed\xe0\x20\xf5\xf0\xe0\xe1\xf0\xfb\xff\x20\xef\xeb\xfa\xea\xfb"
Packit Service 4684c1
		"\x20\xc8\xe3\xee\xf0\xe5\xe2\xfb"),
Packit Service 4684c1
            STR(output, output_size,
Packit Service 4684c1
		"\x1e\x88\xe6\x22\x26\xbf\xca\x6f\x99\x94\xf1\xf2\xd5\x15\x69\xe0"
Packit Service 4684c1
		"\xda\xf8\x47\x5a\x3b\x0f\xe6\x1a\x53\x00\xee\xe4\x6d\x96\x13\x76"
Packit Service 4684c1
		"\x03\x5f\xe8\x35\x49\xad\xa2\xb8\x62\x0f\xcd\x7c\x49\x6c\xe5\xb3"
Packit Service 4684c1
		"\x3f\x0c\xb9\xdd\xdc\x2b\x64\x60\x14\x3b\x03\xda\xba\xc9\xfb\x28"),
Packit Service 4684c1
	},
Packit Service 4684c1
	{
Packit Service 4684c1
            STR(plaintext, plaintext_size,
Packit Service 4684c1
		"\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff"
Packit Service 4684c1
		"\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff"
Packit Service 4684c1
		"\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff"
Packit Service 4684c1
		"\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff"
Packit Service 4684c1
		"\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff"
Packit Service 4684c1
		"\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff"
Packit Service 4684c1
		"\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff"
Packit Service 4684c1
		"\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff"),
Packit Service 4684c1
            STR(output, output_size,
Packit Service 4684c1
		"\x90\xa1\x61\xd1\x2a\xd3\x09\x49\x8d\x3f\xe5\xd4\x82\x02\xd8\xa4"
Packit Service 4684c1
		"\xe9\xc4\x06\xd6\xa2\x64\xae\xab\x25\x8a\xc5\xec\xc3\x7a\x79\x62"
Packit Service 4684c1
		"\xaa\xf9\x58\x7a\x5a\xbb\x09\xb6\xbb\x81\xec\x4b\x37\x52\xa3\xff"
Packit Service 4684c1
		"\x5a\x83\x8e\xf1\x75\xbe\x57\x72\x05\x6b\xc5\xfe\x54\xfc\xfc\x7e"),
Packit Service 4684c1
	},
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
/* GOST R 34.11-2012 */
Packit Service 4684c1
const struct hash_vectors_st streebog_256_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
            STR(plaintext, plaintext_size,
Packit Service 4684c1
		"\xd1\xe5\x20\xe2\xe5\xf2\xf0\xe8\x2c\x20\xd1\xf2\xf0\xe8\xe1\xee"
Packit Service 4684c1
		"\xe6\xe8\x20\xe2\xed\xf3\xf6\xe8\x2c\x20\xe2\xe5\xfe\xf2\xfa\x20"
Packit Service 4684c1
		"\xf1\x20\xec\xee\xf0\xff\x20\xf1\xf2\xf0\xe5\xeb\xe0\xec\xe8\x20"
Packit Service 4684c1
		"\xed\xe0\x20\xf5\xf0\xe0\xe1\xf0\xfb\xff\x20\xef\xeb\xfa\xea\xfb"
Packit Service 4684c1
		"\x20\xc8\xe3\xee\xf0\xe5\xe2\xfb"),
Packit Service 4684c1
            STR(output, output_size,
Packit Service 4684c1
		"\x9d\xd2\xfe\x4e\x90\x40\x9e\x5d\xa8\x7f\x53\x97\x6d\x74\x05\xb0"
Packit Service 4684c1
		"\xc0\xca\xc6\x28\xfc\x66\x9a\x74\x1d\x50\x06\x3c\x55\x7e\x8f\x50"),
Packit Service 4684c1
	},
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
#define HASH_DATA_SIZE 64
Packit Service 4684c1
Packit Service 4684c1
/* SHA1 and other hashes */
Packit Service 4684c1
static int test_digest(gnutls_digest_algorithm_t dig,
Packit Service 4684c1
		       const struct hash_vectors_st *vectors,
Packit Service 4684c1
		       size_t vectors_size, unsigned flags)
Packit Service 4684c1
{
Packit Service 4684c1
	uint8_t data[HASH_DATA_SIZE];
Packit Service 4684c1
	unsigned int i;
Packit Service 4684c1
	int ret;
Packit Service 4684c1
	size_t data_size;
Packit Service 4684c1
	gnutls_hash_hd_t hd;
Packit Service 4684c1
	gnutls_hash_hd_t copy;
Packit Service 4684c1
Packit Service 4684c1
	if (_gnutls_digest_exists(dig) == 0)
Packit Service 4684c1
		return 0;
Packit Service 4684c1
Packit Service 4684c1
	for (i = 0; i < vectors_size; i++) {
Packit Service 4684c1
		ret = gnutls_hash_init(&hd, dig);
Packit Service 4684c1
		if (ret < 0) {
Packit Service 4684c1
			_gnutls_debug_log("error initializing: %s\n",
Packit Service 4684c1
					  gnutls_digest_get_name(dig));
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		ret = gnutls_hash(hd, vectors[i].plaintext, 1);
Packit Service 4684c1
		if (ret < 0)
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
Packit Service 4684c1
		copy = gnutls_hash_copy(hd);
Packit Service 4684c1
		/* Returning NULL is not an error here for the time being, but
Packit Service 4684c1
		 * it might become one later */
Packit Service 4684c1
		if (!copy && secure_getenv("GNUTLS_TEST_SUITE_RUN"))
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
Packit Service 4684c1
		ret = gnutls_hash(hd,
Packit Service 4684c1
				  &vectors[i].plaintext[1],
Packit Service 4684c1
				  vectors[i].plaintext_size - 1);
Packit Service 4684c1
		if (ret < 0)
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
Packit Service 4684c1
		gnutls_hash_deinit(hd, data);
Packit Service 4684c1
Packit Service 4684c1
		data_size = gnutls_hash_get_len(dig);
Packit Service 4684c1
		if (data_size <= 0)
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
Packit Service 4684c1
		if (data_size != vectors[i].output_size ||
Packit Service 4684c1
		    memcmp(data, vectors[i].output,
Packit Service 4684c1
			   vectors[i].output_size) != 0) {
Packit Service 4684c1
			_gnutls_debug_log("%s test vector %d failed!\n",
Packit Service 4684c1
					  gnutls_digest_get_name(dig), i);
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		if (copy != NULL) {
Packit Service 4684c1
			ret = gnutls_hash(copy,
Packit Service 4684c1
					  &vectors[i].plaintext[1],
Packit Service 4684c1
					  vectors[i].plaintext_size - 1);
Packit Service 4684c1
			if (ret < 0)
Packit Service 4684c1
				return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
Packit Service 4684c1
			memset(data, 0xaa, data_size);
Packit Service 4684c1
			gnutls_hash_deinit(copy, data);
Packit Service 4684c1
Packit Service 4684c1
			if (memcmp(data, vectors[i].output,
Packit Service 4684c1
			    vectors[i].output_size) != 0) {
Packit Service 4684c1
				_gnutls_debug_log("%s copy test vector %d failed!\n",
Packit Service 4684c1
						  gnutls_digest_get_name(dig), i);
Packit Service 4684c1
				return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
			}
Packit Service 4684c1
		}
Packit Service 4684c1
	}
Packit Service 4684c1
Packit Service 4684c1
	_gnutls_debug_log("%s self check succeeded\n",
Packit Service 4684c1
			  gnutls_digest_get_name(dig));
Packit Service 4684c1
Packit Service 4684c1
	return 0;
Packit Service 4684c1
}
Packit Service 4684c1
Packit Service 4684c1
Packit Service 4684c1
struct mac_vectors_st {
Packit Service 4684c1
	const uint8_t *key;
Packit Service 4684c1
	unsigned int key_size;
Packit Service 4684c1
	const uint8_t *nonce;
Packit Service 4684c1
	unsigned int nonce_size;
Packit Service 4684c1
	const uint8_t *plaintext;
Packit Service 4684c1
	unsigned int plaintext_size;
Packit Service 4684c1
	const uint8_t *output;
Packit Service 4684c1
	unsigned int output_size;
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct mac_vectors_st hmac_md5_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size, "Jefe"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size, "what do ya want for nothing?"),
Packit Service 4684c1
	 STR(output, output_size,
Packit Service 4684c1
	     "\x75\x0c\x78\x3e\x6a\xb0\xb5\x03\xea\xa8\x6e\x31\x0a\x5d\xb7\x38"),
Packit Service 4684c1
	 },
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct mac_vectors_st hmac_sha1_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size, "Hi There"),
Packit Service 4684c1
	 STR(output, output_size,
Packit Service 4684c1
	     "\x67\x5b\x0b\x3a\x1b\x4d\xdf\x4e\x12\x48\x72\xda\x6c\x2f\x63\x2b\xfe\xd9\x57\xe9"),
Packit Service 4684c1
	 },
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
	    /* from rfc4231 */
Packit Service 4684c1
const struct mac_vectors_st hmac_sha224_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size, "Hi There"),
Packit Service 4684c1
	 STR(output, output_size,
Packit Service 4684c1
	     "\x89\x6f\xb1\x12\x8a\xbb\xdf\x19\x68\x32\x10\x7c\xd4\x9d\xf3\x3f\x47\xb4\xb1\x16\x99\x12\xba\x4f\x53\x68\x4b\x22"),
Packit Service 4684c1
	 },
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct mac_vectors_st hmac_sha256_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size, "Hi There"),
Packit Service 4684c1
	 STR(output, output_size,
Packit Service 4684c1
	     "\xb0\x34\x4c\x61\xd8\xdb\x38\x53\x5c\xa8\xaf\xce\xaf\x0b\xf1\x2b\x88\x1d\xc2\x00\xc9\x83\x3d\xa7\x26\xe9\x37\x6c\x2e\x32\xcf\xf7"),
Packit Service 4684c1
	 },
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct mac_vectors_st hmac_sha384_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size, "Hi There"),
Packit Service 4684c1
	 STR(output, output_size,
Packit Service 4684c1
	     "\xaf\xd0\x39\x44\xd8\x48\x95\x62\x6b\x08\x25\xf4\xab\x46\x90\x7f\x15\xf9\xda\xdb\xe4\x10\x1e\xc6\x82\xaa\x03\x4c\x7c\xeb\xc5\x9c\xfa\xea\x9e\xa9\x07\x6e\xde\x7f\x4a\xf1\x52\xe8\xb2\xfa\x9c\xb6"),
Packit Service 4684c1
	 },
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct mac_vectors_st hmac_sha512_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size, "Hi There"),
Packit Service 4684c1
	 STR(output, output_size,
Packit Service 4684c1
	     "\x87\xaa\x7c\xde\xa5\xef\x61\x9d\x4f\xf0\xb4\x24\x1a\x1d\x6c\xb0\x23\x79\xf4\xe2\xce\x4e\xc2\x78\x7a\xd0\xb3\x05\x45\xe1\x7c\xde\xda\xa8\x33\xb7\xd6\xb8\xa7\x02\x03\x8b\x27\x4e\xae\xa3\xf4\xe4\xbe\x9d\x91\x4e\xeb\x61\xf1\x70\x2e\x69\x6c\x20\x3a\x12\x68\x54"),
Packit Service 4684c1
	 },
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
/* Calculated */
Packit Service 4684c1
const struct mac_vectors_st hmac_gostr_94_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x00\x01\x02\x03\x04\x05\x06\x07\x08\x09\x0a\x0b\x0c\x0d\x0e\x0f"
Packit Service 4684c1
	     "\x10\x11\x12\x13\x14\x15\x16\x17\x18\x19\x1a\x1b\x1c\x1d\x1e\x1f"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\x01\x26\xbd\xb8\x78\x00\xaf\x21\x43\x41\x45\x65\x63\x78\x01\x00"),
Packit Service 4684c1
	 STR(output, output_size,
Packit Service 4684c1
	     "\xba\xd7\x0b\x61\xc4\x10\x95\xbc\x47\xe1\x14\x1c\xfa\xed\x42\x72"
Packit Service 4684c1
	     "\x6a\x5c\xee\xbd\x62\xce\x75\xdb\xbb\x9a\xd7\x6c\xda\x9f\x72\xf7"),
Packit Service 4684c1
	},
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
/* RFC 7836 */
Packit Service 4684c1
const struct mac_vectors_st hmac_streebog_512_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x00\x01\x02\x03\x04\x05\x06\x07\x08\x09\x0a\x0b\x0c\x0d\x0e\x0f"
Packit Service 4684c1
	     "\x10\x11\x12\x13\x14\x15\x16\x17\x18\x19\x1a\x1b\x1c\x1d\x1e\x1f"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\x01\x26\xbd\xb8\x78\x00\xaf\x21\x43\x41\x45\x65\x63\x78\x01\x00"),
Packit Service 4684c1
	 STR(output, output_size,
Packit Service 4684c1
	     "\xa5\x9b\xab\x22\xec\xae\x19\xc6\x5f\xbd\xe6\xe5\xf4\xe9\xf5\xd8"
Packit Service 4684c1
	     "\x54\x9d\x31\xf0\x37\xf9\xdf\x9b\x90\x55\x00\xe1\x71\x92\x3a\x77"
Packit Service 4684c1
	     "\x3d\x5f\x15\x30\xf2\xed\x7e\x96\x4c\xb2\xee\xdc\x29\xe9\xad\x2f"
Packit Service 4684c1
	     "\x3a\xfe\x93\xb2\x81\x4f\x79\xf5\x00\x0f\xfc\x03\x66\xc2\x51\xe6"),
Packit Service 4684c1
	},
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
/* RFC 7836 */
Packit Service 4684c1
const struct mac_vectors_st hmac_streebog_256_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x00\x01\x02\x03\x04\x05\x06\x07\x08\x09\x0a\x0b\x0c\x0d\x0e\x0f"
Packit Service 4684c1
	     "\x10\x11\x12\x13\x14\x15\x16\x17\x18\x19\x1a\x1b\x1c\x1d\x1e\x1f"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\x01\x26\xbd\xb8\x78\x00\xaf\x21\x43\x41\x45\x65\x63\x78\x01\x00"),
Packit Service 4684c1
	 STR(output, output_size,
Packit Service 4684c1
	     "\xa1\xaa\x5f\x7d\xe4\x02\xd7\xb3\xd3\x23\xf2\x99\x1c\x8d\x45\x34"
Packit Service 4684c1
	     "\x01\x31\x37\x01\x0a\x83\x75\x4f\xd0\xaf\x6d\x7c\xd4\x92\x2e\xd9"),
Packit Service 4684c1
	},
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct mac_vectors_st aes_cmac_128_vectors[] = { /* NIST SP800-38A */
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x2b\x7e\x15\x16\x28\xae\xd2\xa6\xab\xf7\x15\x88\x09\xcf\x4f\x3c"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
             "\x6b\xc1\xbe\xe2\x2e\x40\x9f\x96\xe9\x3d\x7e\x11\x73\x93\x17\x2a"),
Packit Service 4684c1
	 STR(output, output_size,
Packit Service 4684c1
	     "\x07\x0a\x16\xb4\x6b\x4d\x41\x44\xf7\x9b\xdd\x9d\xd0\x4a\x28\x7c"),
Packit Service 4684c1
	 },
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct mac_vectors_st aes_cmac_256_vectors[] = { /* NIST SP800-38A */
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x60\x3d\xeb\x10\x15\xca\x71\xbe\x2b\x73\xae\xf0\x85\x7d\x77\x81"
Packit Service 4684c1
             "\x1f\x35\x2c\x07\x3b\x61\x08\xd7\x2d\x98\x10\xa3\x09\x14\xdf\xf4"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
             "\x6b\xc1\xbe\xe2\x2e\x40\x9f\x96\xe9\x3d\x7e\x11\x73\x93\x17\x2a"),
Packit Service 4684c1
	 STR(output, output_size,
Packit Service 4684c1
	     "\x28\xa7\x02\x3f\x45\x2e\x8f\x82\xbd\x4b\xf2\x8d\x8c\x37\xc3\x5c"),
Packit Service 4684c1
	 },
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct mac_vectors_st aes_gmac_128_vectors[] = { /* NIST test vectors */
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x23\x70\xe3\x20\xd4\x34\x42\x08\xe0\xff\x56\x83\xf2\x43\xb2\x13"),
Packit Service 4684c1
	 STR(nonce, nonce_size,
Packit Service 4684c1
	     "\x04\xdb\xb8\x2f\x04\x4d\x30\x83\x1c\x44\x12\x28"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\xd4\x3a\x8e\x50\x89\xee\xa0\xd0\x26\xc0\x3a\x85\x17\x8b\x27\xda"),
Packit Service 4684c1
	 STR(output, output_size,
Packit Service 4684c1
	     "\x2a\x04\x9c\x04\x9d\x25\xaa\x95\x96\x9b\x45\x1d\x93\xc3\x1c\x6e"),
Packit Service 4684c1
	},
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct mac_vectors_st aes_gmac_192_vectors[] = { /* NIST test vectors */
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\xaa\x92\x1c\xb5\xa2\x43\xab\x08\x91\x1f\x32\x89\x26\x6b\x39\xda"
Packit Service 4684c1
	     "\xb1\x33\xf5\xc4\x20\xa6\xc5\xcd"),
Packit Service 4684c1
	 STR(nonce, nonce_size,
Packit Service 4684c1
	     "\x8f\x73\xdb\x68\xda\xee\xed\x2d\x15\x5f\xb1\xa0"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\x48\x74\x43\xc7\xc1\x4c\xe4\x74\xcb\x3d\x29\x1f\x25\x70\x70\xa2"),
Packit Service 4684c1
	 STR(output, output_size,
Packit Service 4684c1
	     "\xb1\x26\x74\xfb\xea\xc6\x88\x9a\x24\x94\x8f\x27\x92\xe3\x0a\x50"),
Packit Service 4684c1
	},
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct mac_vectors_st aes_gmac_256_vectors[] = { /* NIST test vectors */
Packit Service 4684c1
	{
Packit Service 4684c1
	 STR(key, key_size,
Packit Service 4684c1
	     "\x6d\xfd\xaf\xd6\x70\x3c\x28\x5c\x01\xf1\x4f\xd1\x0a\x60\x12\x86"
Packit Service 4684c1
	     "\x2b\x2a\xf9\x50\xd4\x73\x3a\xbb\x40\x3b\x2e\x74\x5b\x26\x94\x5d"),
Packit Service 4684c1
	 STR(nonce, nonce_size,
Packit Service 4684c1
	     "\x37\x49\xd0\xb3\xd5\xba\xcb\x71\xbe\x06\xad\xe6"),
Packit Service 4684c1
	 STR(plaintext, plaintext_size,
Packit Service 4684c1
	     "\xc0\xd2\x49\x87\x19\x92\xe7\x03\x02\xae\x00\x81\x93\xd1\xe8\x9f"),
Packit Service 4684c1
	 STR(output, output_size,
Packit Service 4684c1
	     "\x4a\xa4\xcc\x69\xf8\x4e\xe6\xac\x16\xd9\xbf\xb4\xe0\x5d\xe5\x00"),
Packit Service 4684c1
	},
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
const struct mac_vectors_st gost28147_tc26z_imit_vectors[] = {
Packit Service 4684c1
	{
Packit Service 4684c1
		STR(key, key_size,
Packit Service 4684c1
		    "\x9d\x05\xb7\x9e\x90\xca\xd0\x0a\x2c\xda\xd2\x2e\xf4\xe8\x6f\x5c"
Packit Service 4684c1
		    "\xf5\xdc\x37\x68\x19\x85\xb3\xbf\xaa\x18\xc1\xc3\x05\x0a\x91\xa2"),
Packit Service 4684c1
		STR(plaintext, plaintext_size,
Packit Service 4684c1
		    "\xb5\xa1\xf0\xe3\xce\x2f\x02\x1d\x67\x61\x94\x34\x5c\x41\xe3\x6e"),
Packit Service 4684c1
		STR(output, output_size,
Packit Service 4684c1
		    "\x03\xe5\x67\x66"),
Packit Service 4684c1
	},
Packit Service 4684c1
};
Packit Service 4684c1
Packit Service 4684c1
static int test_mac(gnutls_mac_algorithm_t mac,
Packit Service 4684c1
		    const struct mac_vectors_st *vectors,
Packit Service 4684c1
		    size_t vectors_size, unsigned flags)
Packit Service 4684c1
{
Packit Service 4684c1
	uint8_t data[HASH_DATA_SIZE];
Packit Service 4684c1
	unsigned int i;
Packit Service 4684c1
	int ret;
Packit Service 4684c1
	size_t data_size;
Packit Service 4684c1
	gnutls_hmac_hd_t hd;
Packit Service 4684c1
	gnutls_hmac_hd_t copy;
Packit Service 4684c1
Packit Service 4684c1
	for (i = 0; i < vectors_size; i++) {
Packit Service 4684c1
		ret = gnutls_hmac_init(&hd,
Packit Service 4684c1
				       mac, vectors[i].key,
Packit Service 4684c1
				       vectors[i].key_size);
Packit Service 4684c1
Packit Service 4684c1
		if (ret < 0) {
Packit Service 4684c1
			_gnutls_debug_log("error initializing: MAC-%s\n",
Packit Service 4684c1
					  gnutls_mac_get_name(mac));
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		if (vectors[i].nonce_size)
Packit Service 4684c1
			gnutls_hmac_set_nonce(hd,
Packit Service 4684c1
					      vectors[i].nonce,
Packit Service 4684c1
					      vectors[i].nonce_size);
Packit Service 4684c1
Packit Service 4684c1
		ret = gnutls_hmac(hd, vectors[i].plaintext, 1);
Packit Service 4684c1
		if (ret < 0)
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
Packit Service 4684c1
		copy = gnutls_hmac_copy(hd);
Packit Service 4684c1
		/* Returning NULL is not an error here for the time being, but
Packit Service 4684c1
		 * it might become one later */
Packit Service 4684c1
		if (!copy && secure_getenv("GNUTLS_TEST_SUITE_RUN"))
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
Packit Service 4684c1
		ret = gnutls_hmac(hd,
Packit Service 4684c1
				  &vectors[i].plaintext[1],
Packit Service 4684c1
				  vectors[i].plaintext_size - 1);
Packit Service 4684c1
		if (ret < 0)
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
Packit Service 4684c1
		gnutls_hmac_deinit(hd, data);
Packit Service 4684c1
Packit Service 4684c1
		data_size = gnutls_hmac_get_len(mac);
Packit Service 4684c1
		if (data_size <= 0)
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
Packit Service 4684c1
		if (data_size != vectors[i].output_size ||
Packit Service 4684c1
		    memcmp(data, vectors[i].output,
Packit Service 4684c1
			   vectors[i].output_size) != 0) {
Packit Service 4684c1
Packit Service 4684c1
			_gnutls_debug_log
Packit Service 4684c1
			    ("MAC-%s test vector %d failed!\n",
Packit Service 4684c1
			     gnutls_mac_get_name(mac), i);
Packit Service 4684c1
Packit Service 4684c1
			return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
		}
Packit Service 4684c1
Packit Service 4684c1
		if (copy != NULL) {
Packit Service 4684c1
			ret = gnutls_hmac(copy,
Packit Service 4684c1
					  &vectors[i].plaintext[1],
Packit Service 4684c1
					  vectors[i].plaintext_size - 1);
Packit Service 4684c1
			if (ret < 0)
Packit Service 4684c1
				return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
Packit Service 4684c1
			memset(data, 0xaa, data_size);
Packit Service 4684c1
			gnutls_hmac_deinit(copy, data);
Packit Service 4684c1
Packit Service 4684c1
			if (memcmp(data, vectors[i].output,
Packit Service 4684c1
			    vectors[i].output_size) != 0) {
Packit Service 4684c1
				_gnutls_debug_log
Packit Service 4684c1
					("MAC-%s copy test vector %d failed!\n",
Packit Service 4684c1
					 gnutls_mac_get_name(mac), i);
Packit Service 4684c1
				return gnutls_assert_val(GNUTLS_E_SELF_TEST_ERROR);
Packit Service 4684c1
			}
Packit Service 4684c1
		}
Packit Service 4684c1
	}
Packit Service 4684c1
Packit Service 4684c1
	_gnutls_debug_log
Packit Service 4684c1
	    ("MAC-%s self check succeeded\n",
Packit Service 4684c1
	     gnutls_mac_get_name(mac));
Packit Service 4684c1
Packit Service 4684c1
	return 0;
Packit Service 4684c1
}
Packit Service 4684c1
Packit Service 4684c1
#define CASE(x, func, vectors) case x: \
Packit Service 4684c1
			ret = func(x, V(vectors), flags); \
Packit Service 4684c1
			if (!(flags & GNUTLS_SELF_TEST_FLAG_ALL) || ret < 0) \
Packit Service 4684c1
				return ret
Packit Service 4684c1
Packit Service 4684c1
#define CASE2(x, func, func2, vectors) case x:	  \
Packit Service 4684c1
			ret = func(x, V(vectors), flags); \
Packit Service 4684c1
			if (!(flags & GNUTLS_SELF_TEST_FLAG_ALL) || ret < 0) \
Packit Service 4684c1
				return ret; \
Packit Service 4684c1
			ret = func2(x, V(vectors), flags); \
Packit Service 4684c1
			if (!(flags & GNUTLS_SELF_TEST_FLAG_ALL) || ret < 0) \
Packit Service 4684c1
				return ret
Packit Service 4684c1
Packit Service 4684c1
#define NON_FIPS_CASE(x, func, vectors) case x: \
Packit Service 4684c1
			if (_gnutls_fips_mode_enabled() == 0) { \
Packit Service 4684c1
				ret = func(x, V(vectors), flags); \
Packit Service 4684c1
				if (!(flags & GNUTLS_SELF_TEST_FLAG_ALL) || ret < 0) \
Packit Service 4684c1
					return ret; \
Packit Service 4684c1
			}
Packit Service 4684c1
Packit Service 4684c1
/*-
Packit Service 4684c1
 * gnutls_cipher_self_test:
Packit Service 4684c1
 * @flags: GNUTLS_SELF_TEST_FLAG flags
Packit Service 4684c1
 * @cipher: the encryption algorithm to use
Packit Service 4684c1
 *
Packit Service 4684c1
 * This function will run self tests on the provided cipher or all
Packit Service 4684c1
 * available ciphers if @flags is %GNUTLS_SELF_TEST_FLAG_ALL.
Packit Service 4684c1
 *
Packit Service 4684c1
 * Returns: Zero or a negative error code on error.
Packit Service 4684c1
 *
Packit Service 4684c1
 * Since: 3.3.0-FIPS140
Packit Service 4684c1
 -*/
Packit Service 4684c1
int gnutls_cipher_self_test(unsigned flags, gnutls_cipher_algorithm_t cipher)
Packit Service 4684c1
{
Packit Service 4684c1
	int ret;
Packit Service 4684c1
Packit Service 4684c1
	if (flags & GNUTLS_SELF_TEST_FLAG_ALL)
Packit Service 4684c1
		cipher = GNUTLS_CIPHER_UNKNOWN;
Packit Service 4684c1
Packit Service 4684c1
	switch (cipher) {
Packit Service 4684c1
	case GNUTLS_CIPHER_UNKNOWN:
Packit Service 4684c1
		CASE(GNUTLS_CIPHER_AES_128_CCM, test_cipher_aead,
Packit Service 4684c1
		     aes128_ccm_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE(GNUTLS_CIPHER_AES_256_CCM, test_cipher_aead,
Packit Service 4684c1
		     aes256_ccm_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE(GNUTLS_CIPHER_AES_128_CBC, test_cipher,
Packit Service 4684c1
		     aes128_cbc_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE(GNUTLS_CIPHER_AES_192_CBC, test_cipher,
Packit Service 4684c1
		     aes192_cbc_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE(GNUTLS_CIPHER_AES_256_CBC, test_cipher,
Packit Service 4684c1
		     aes256_cbc_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE(GNUTLS_CIPHER_3DES_CBC, test_cipher,
Packit Service 4684c1
		     tdes_cbc_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		NON_FIPS_CASE(GNUTLS_CIPHER_ARCFOUR_128, test_cipher,
Packit Service 4684c1
		     arcfour_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE(GNUTLS_CIPHER_AES_128_GCM, test_cipher_aead,
Packit Service 4684c1
		     aes128_gcm_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE(GNUTLS_CIPHER_AES_192_GCM, test_cipher_aead,
Packit Service 4684c1
		     aes192_gcm_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE(GNUTLS_CIPHER_AES_256_GCM, test_cipher_aead,
Packit Service 4684c1
		     aes256_gcm_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		NON_FIPS_CASE(GNUTLS_CIPHER_CHACHA20_POLY1305, test_cipher_aead,
Packit Service 4684c1
		     chacha_poly1305_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE2(GNUTLS_CIPHER_AES_128_CFB8, test_cipher,
Packit Service 4684c1
		      test_cipher_all_block_sizes,
Packit Service 4684c1
		      aes128_cfb8_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE2(GNUTLS_CIPHER_AES_192_CFB8, test_cipher,
Packit Service 4684c1
		      test_cipher_all_block_sizes,
Packit Service 4684c1
		      aes192_cfb8_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE2(GNUTLS_CIPHER_AES_256_CFB8, test_cipher,
Packit Service 4684c1
		      test_cipher_all_block_sizes,
Packit Service 4684c1
		      aes256_cfb8_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE(GNUTLS_CIPHER_AES_128_XTS, test_cipher,
Packit Service 4684c1
		     aes128_xts_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE(GNUTLS_CIPHER_AES_256_XTS, test_cipher,
Packit Service 4684c1
		     aes256_xts_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		NON_FIPS_CASE(GNUTLS_CIPHER_AES_128_SIV, test_cipher_aead,
Packit Service 4684c1
		     aes128_siv_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		NON_FIPS_CASE(GNUTLS_CIPHER_AES_256_SIV, test_cipher_aead,
Packit Service 4684c1
		     aes256_siv_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		NON_FIPS_CASE(GNUTLS_CIPHER_CHACHA20_32, test_cipher,
Packit Service 4684c1
		     chacha20_32_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		/* The same test vector for _32 variant should work */
Packit Service 4684c1
		NON_FIPS_CASE(GNUTLS_CIPHER_CHACHA20_64, test_cipher,
Packit Service 4684c1
		     chacha20_32_vectors);
Packit Service 4684c1
#if ENABLE_GOST
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		NON_FIPS_CASE(GNUTLS_CIPHER_GOST28147_CPA_CFB, test_cipher,
Packit Service 4684c1
			      gost28147_cpa_cfb_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		NON_FIPS_CASE(GNUTLS_CIPHER_GOST28147_CPB_CFB, test_cipher,
Packit Service 4684c1
			      gost28147_cpb_cfb_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		NON_FIPS_CASE(GNUTLS_CIPHER_GOST28147_CPC_CFB, test_cipher,
Packit Service 4684c1
			      gost28147_cpc_cfb_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		NON_FIPS_CASE(GNUTLS_CIPHER_GOST28147_CPD_CFB, test_cipher,
Packit Service 4684c1
			      gost28147_cpd_cfb_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		NON_FIPS_CASE(GNUTLS_CIPHER_GOST28147_TC26Z_CFB, test_cipher,
Packit Service 4684c1
			      gost28147_tc26z_cfb_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		NON_FIPS_CASE(GNUTLS_CIPHER_GOST28147_TC26Z_CNT, test_cipher,
Packit Service 4684c1
			      gost28147_tc26z_cnt_vectors);
Packit Service 4684c1
#endif
Packit Service 4684c1
		break;
Packit Service 4684c1
	default:
Packit Service 4684c1
		return gnutls_assert_val(GNUTLS_E_NO_SELF_TEST);
Packit Service 4684c1
	}
Packit Service 4684c1
Packit Service 4684c1
	return 0;
Packit Service 4684c1
}
Packit Service 4684c1
Packit Service 4684c1
/*-
Packit Service 4684c1
 * gnutls_mac_self_test:
Packit Service 4684c1
 * @flags: GNUTLS_SELF_TEST_FLAG flags
Packit Service 4684c1
 * @mac: the message authentication algorithm to use
Packit Service 4684c1
 *
Packit Service 4684c1
 * This function will run self tests on the provided mac.
Packit Service 4684c1
 *
Packit Service 4684c1
 * Returns: Zero or a negative error code on error.
Packit Service 4684c1
 *
Packit Service 4684c1
 * Since: 3.3.0-FIPS140
Packit Service 4684c1
 -*/
Packit Service 4684c1
int gnutls_mac_self_test(unsigned flags, gnutls_mac_algorithm_t mac)
Packit Service 4684c1
{
Packit Service 4684c1
	int ret;
Packit Service 4684c1
Packit Service 4684c1
	if (flags & GNUTLS_SELF_TEST_FLAG_ALL)
Packit Service 4684c1
		mac = GNUTLS_MAC_UNKNOWN;
Packit Service 4684c1
Packit Service 4684c1
	switch (mac) {
Packit Service 4684c1
	case GNUTLS_MAC_UNKNOWN:
Packit Service 4684c1
		NON_FIPS_CASE(GNUTLS_MAC_MD5, test_mac, hmac_md5_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE(GNUTLS_MAC_SHA1, test_mac, hmac_sha1_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE(GNUTLS_MAC_SHA224, test_mac, hmac_sha224_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE(GNUTLS_MAC_SHA256, test_mac, hmac_sha256_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE(GNUTLS_MAC_SHA384, test_mac, hmac_sha384_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE(GNUTLS_MAC_SHA512, test_mac, hmac_sha512_vectors);
Packit Service 4684c1
#if ENABLE_GOST
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		NON_FIPS_CASE(GNUTLS_MAC_GOSTR_94, test_mac, hmac_gostr_94_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		NON_FIPS_CASE(GNUTLS_MAC_STREEBOG_512, test_mac, hmac_streebog_512_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		NON_FIPS_CASE(GNUTLS_MAC_STREEBOG_256, test_mac, hmac_streebog_256_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		NON_FIPS_CASE(GNUTLS_MAC_GOST28147_TC26Z_IMIT, test_mac, gost28147_tc26z_imit_vectors);
Packit Service 4684c1
#endif
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE(GNUTLS_MAC_AES_CMAC_128, test_mac, aes_cmac_128_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE(GNUTLS_MAC_AES_CMAC_256, test_mac, aes_cmac_256_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE(GNUTLS_MAC_AES_GMAC_128, test_mac, aes_gmac_128_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE(GNUTLS_MAC_AES_GMAC_192, test_mac, aes_gmac_192_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE(GNUTLS_MAC_AES_GMAC_256, test_mac, aes_gmac_256_vectors);
Packit Service 4684c1
Packit Service 4684c1
		break;
Packit Service 4684c1
	default:
Packit Service 4684c1
		return gnutls_assert_val(GNUTLS_E_NO_SELF_TEST);
Packit Service 4684c1
	}
Packit Service 4684c1
Packit Service 4684c1
	return 0;
Packit Service 4684c1
}
Packit Service 4684c1
Packit Service 4684c1
/*-
Packit Service 4684c1
 * gnutls_digest_self_test:
Packit Service 4684c1
 * @flags: GNUTLS_SELF_TEST_FLAG flags
Packit Service 4684c1
 * @digest: the digest algorithm to use
Packit Service 4684c1
 *
Packit Service 4684c1
 * This function will run self tests on the provided digest.
Packit Service 4684c1
 *
Packit Service 4684c1
 * Returns: Zero or a negative error code on error.
Packit Service 4684c1
 *
Packit Service 4684c1
 * Since: 3.3.0-FIPS140
Packit Service 4684c1
 -*/
Packit Service 4684c1
int gnutls_digest_self_test(unsigned flags, gnutls_digest_algorithm_t digest)
Packit Service 4684c1
{
Packit Service 4684c1
	int ret;
Packit Service 4684c1
Packit Service 4684c1
	if (flags & GNUTLS_SELF_TEST_FLAG_ALL)
Packit Service 4684c1
		digest = GNUTLS_DIG_UNKNOWN;
Packit Service 4684c1
Packit Service 4684c1
	switch (digest) {
Packit Service 4684c1
	case GNUTLS_DIG_UNKNOWN:
Packit Service 4684c1
		NON_FIPS_CASE(GNUTLS_DIG_MD5, test_digest, md5_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE(GNUTLS_DIG_SHA1, test_digest, sha1_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE(GNUTLS_DIG_SHA224, test_digest, sha224_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE(GNUTLS_DIG_SHA256, test_digest, sha256_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE(GNUTLS_DIG_SHA384, test_digest, sha384_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE(GNUTLS_DIG_SHA512, test_digest, sha512_vectors);
Packit Service 4684c1
#ifdef NETTLE_SHA3_FIPS202
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE(GNUTLS_DIG_SHA3_224, test_digest, sha3_224_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE(GNUTLS_DIG_SHA3_256, test_digest, sha3_256_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE(GNUTLS_DIG_SHA3_384, test_digest, sha3_384_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		CASE(GNUTLS_DIG_SHA3_512, test_digest, sha3_512_vectors);
Packit Service 4684c1
#endif
Packit Service 4684c1
#if ENABLE_GOST
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		NON_FIPS_CASE(GNUTLS_DIG_GOSTR_94, test_digest, gostr_94_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		NON_FIPS_CASE(GNUTLS_DIG_STREEBOG_512, test_digest, streebog_512_vectors);
Packit Service 4684c1
		FALLTHROUGH;
Packit Service 4684c1
		NON_FIPS_CASE(GNUTLS_DIG_STREEBOG_256, test_digest, streebog_256_vectors);
Packit Service 4684c1
#endif
Packit Service 4684c1
		break;
Packit Service 4684c1
	default:
Packit Service 4684c1
		return gnutls_assert_val(GNUTLS_E_NO_SELF_TEST);
Packit Service 4684c1
	}
Packit Service 4684c1
Packit Service 4684c1
	return 0;
Packit Service 4684c1
}