Blame tests/slow/cipher-override2.c

Packit aea12f
#include <config.h>
Packit aea12f
#include <stdint.h>
Packit aea12f
#include <stdio.h>
Packit aea12f
#include <string.h>
Packit aea12f
#include <utils.h>
Packit aea12f
#include <stdlib.h>
Packit aea12f
#include <gnutls/gnutls.h>
Packit aea12f
#include <gnutls/crypto.h>
Packit aea12f
#include <gnutls/self-test.h>
Packit aea12f
Packit aea12f
/* this tests whether the API to override ciphers works sanely,
Packit aea12f
 * when GNUTLS_E_NEED_FALLBACK is used.
Packit aea12f
 */
Packit aea12f
static void tls_log_func(int level, const char *str)
Packit aea12f
{
Packit aea12f
	fprintf(stderr, "<%d>| %s", level, str);
Packit aea12f
}
Packit aea12f
Packit aea12f
struct myaes_ctx {
Packit aea12f
	unsigned char iv[16];
Packit aea12f
};
Packit aea12f
Packit aea12f
static int
Packit aea12f
myaes_init(gnutls_cipher_algorithm_t algorithm, void **_ctx, int enc)
Packit aea12f
{
Packit aea12f
	return GNUTLS_E_NEED_FALLBACK;
Packit aea12f
}
Packit aea12f
Packit aea12f
static int
Packit aea12f
myaes_setkey(void *_ctx, const void *userkey, size_t keysize)
Packit aea12f
{
Packit aea12f
	abort();
Packit aea12f
}
Packit aea12f
Packit aea12f
static int myaes_setiv(void *_ctx, const void *iv, size_t iv_size)
Packit aea12f
{
Packit aea12f
	abort();
Packit aea12f
}
Packit aea12f
Packit aea12f
static int
Packit aea12f
myaes_encrypt(void *_ctx, const void *src, size_t src_size,
Packit aea12f
	    void *dst, size_t dst_size)
Packit aea12f
{
Packit aea12f
	abort();
Packit aea12f
}
Packit aea12f
Packit aea12f
static int
Packit aea12f
myaes_decrypt(void *_ctx, const void *src, size_t src_size,
Packit aea12f
	    void *dst, size_t dst_size)
Packit aea12f
{
Packit aea12f
	abort();
Packit aea12f
}
Packit aea12f
Packit aea12f
static void myaes_deinit(void *_ctx)
Packit aea12f
{
Packit aea12f
	abort();
Packit aea12f
}
Packit aea12f
Packit aea12f
/* AES-GCM */
Packit aea12f
struct myaes_gcm_ctx {
Packit aea12f
	char xx[32];
Packit aea12f
};
Packit aea12f
Packit aea12f
static int
Packit aea12f
myaes_gcm_init(gnutls_cipher_algorithm_t algorithm, void **_ctx, int enc)
Packit aea12f
{
Packit aea12f
	return GNUTLS_E_NEED_FALLBACK;
Packit aea12f
}
Packit aea12f
Packit aea12f
static int
Packit aea12f
myaes_gcm_setkey(void *_ctx, const void *userkey, size_t keysize)
Packit aea12f
{
Packit aea12f
	abort();
Packit aea12f
}
Packit aea12f
Packit aea12f
static void myaes_gcm_deinit(void *_ctx)
Packit aea12f
{
Packit aea12f
	abort();
Packit aea12f
}
Packit aea12f
Packit aea12f
static int
Packit aea12f
myaes_gcm_encrypt(void *_ctx,
Packit aea12f
		  const void *nonce, size_t nonce_size,
Packit aea12f
		  const void *auth, size_t auth_size,
Packit aea12f
		  size_t tag_size,
Packit aea12f
		  const void *plain, size_t plain_size,
Packit aea12f
		  void *encr, size_t encr_size)
Packit aea12f
{
Packit aea12f
	abort();
Packit aea12f
}
Packit aea12f
Packit aea12f
static int
Packit aea12f
myaes_gcm_decrypt(void *_ctx,
Packit aea12f
		  const void *nonce, size_t nonce_size,
Packit aea12f
		  const void *auth, size_t auth_size,
Packit aea12f
		  size_t tag_size,
Packit aea12f
		  const void *encr, size_t encr_size,
Packit aea12f
		  void *plain, size_t plain_size)
Packit aea12f
{
Packit aea12f
	abort();
Packit aea12f
}
Packit aea12f
Packit aea12f
Packit aea12f
Packit aea12f
int main(int argc, char **argv)
Packit aea12f
{
Packit aea12f
	int ret;
Packit aea12f
Packit aea12f
	gnutls_global_set_log_function(tls_log_func);
Packit aea12f
	if (argc > 1)
Packit aea12f
		gnutls_global_set_log_level(4711);
Packit aea12f
Packit aea12f
	ret = gnutls_crypto_register_cipher(GNUTLS_CIPHER_AES_128_CBC, 1,
Packit aea12f
		myaes_init,
Packit aea12f
		myaes_setkey,
Packit aea12f
		myaes_setiv,
Packit aea12f
		myaes_encrypt,
Packit aea12f
		myaes_decrypt,
Packit aea12f
		myaes_deinit);
Packit aea12f
	if (ret < 0) {
Packit aea12f
		fprintf(stderr, "%d: cannot register cipher\n", __LINE__);
Packit aea12f
		exit(1);
Packit aea12f
	}
Packit aea12f
Packit aea12f
	ret = gnutls_crypto_register_aead_cipher(GNUTLS_CIPHER_AES_128_GCM, 1,
Packit aea12f
		myaes_gcm_init,
Packit aea12f
		myaes_gcm_setkey,
Packit aea12f
		myaes_gcm_encrypt,
Packit aea12f
		myaes_gcm_decrypt,
Packit aea12f
		myaes_gcm_deinit);
Packit aea12f
	if (ret < 0) {
Packit aea12f
		fprintf(stderr, "%d: cannot register cipher\n", __LINE__);
Packit aea12f
		exit(1);
Packit aea12f
	}
Packit aea12f
Packit aea12f
	global_init();
Packit aea12f
Packit aea12f
	if (gnutls_cipher_self_test(1, 0) < 0)
Packit aea12f
		return 1;
Packit aea12f
Packit aea12f
	gnutls_global_deinit();
Packit aea12f
	return 0;
Packit aea12f
}