18d91e49dSJason King /*
28d91e49dSJason King  * This file and its contents are supplied under the terms of the
38d91e49dSJason King  * Common Development and Distribution License ("CDDL"), version 1.0.
48d91e49dSJason King  * You may only use this file in accordance with the terms of version
58d91e49dSJason King  * 1.0 of the CDDL.
68d91e49dSJason King  *
78d91e49dSJason King  * A full copy of the text of the CDDL should have accompanied this
88d91e49dSJason King  * source.  A copy of the CDDL is also available via the Internet at
98d91e49dSJason King  * http://www.illumos.org/license/CDDL.
108d91e49dSJason King  */
118d91e49dSJason King 
128d91e49dSJason King /*
138d91e49dSJason King  * Copyright 2016 Nexenta Systems, Inc.  All rights reserved.
148d91e49dSJason King  * Copyright 2019 Joyent, Inc.
158d91e49dSJason King  */
168d91e49dSJason King 
178d91e49dSJason King /*
188d91e49dSJason King  * The illumos KCF does not currently support CKM_AES_CBC_PAD (it
198d91e49dSJason King  * requires the consumer to explicitly add/remove padding), so there is
208d91e49dSJason King  * no SUN_CKM_xxx symbol.
218d91e49dSJason King  */
228d91e49dSJason King #define	CBC_PAD	"CKM_AES_CBC_PAD"
238d91e49dSJason King 
248d91e49dSJason King #include <aes/aes_impl.h>
258d91e49dSJason King #include <stdio.h>
26*77de87d2SJason King #include <sys/sysmacros.h>
278d91e49dSJason King 
288d91e49dSJason King #include "cryptotest.h"
298d91e49dSJason King #include "aes_cbc_pad.h"
308d91e49dSJason King 
31*77de87d2SJason King static size_t updatelens[] = {
32*77de87d2SJason King 	1, AES_BLOCK_LEN, AES_BLOCK_LEN + 1, 2*AES_BLOCK_LEN,
33*77de87d2SJason King 	CTEST_UPDATELEN_WHOLE, CTEST_UPDATELEN_END
34*77de87d2SJason King };
35*77de87d2SJason King 
368d91e49dSJason King int
main(void)378d91e49dSJason King main(void)
388d91e49dSJason King {
398d91e49dSJason King 	int errs = 0;
408d91e49dSJason King 	int i;
418d91e49dSJason King 	uint8_t N[1024];
42*77de87d2SJason King 	cryptotest_t args = {
43*77de87d2SJason King 		.out = N,
44*77de87d2SJason King 		.outlen = sizeof (N),
45*77de87d2SJason King 		.plen = AES_BLOCK_LEN,
46*77de87d2SJason King 		.mechname = CBC_PAD,
47*77de87d2SJason King 		.updatelens = updatelens
48*77de87d2SJason King 	};
49*77de87d2SJason King 
50*77de87d2SJason King 	for (i = 0; i < ARRAY_SIZE(RES); i++) {
518d91e49dSJason King 		args.in = DATA[i];
528d91e49dSJason King 		args.key = KEY[i];
538d91e49dSJason King 		args.param = IV[i];
548d91e49dSJason King 
558d91e49dSJason King 		args.inlen = DATALEN[i];
568d91e49dSJason King 		args.keylen = KEYLEN[i];
578d91e49dSJason King 
588d91e49dSJason King 		errs += run_test(&args, RES[i], RESLEN[i], ENCR_FG);
598d91e49dSJason King 		(void) fprintf(stderr, "----------\n");
608d91e49dSJason King 	}
618d91e49dSJason King 
628d91e49dSJason King 	(void) fprintf(stderr, "\t\t\t=== decrypt ===\n----------\n\n");
638d91e49dSJason King 
64*77de87d2SJason King 	for (i = 0; i < ARRAY_SIZE(RES); i++) {
658d91e49dSJason King 		args.in = RES[i];
668d91e49dSJason King 		args.key = KEY[i];
678d91e49dSJason King 		args.param = IV[i];
688d91e49dSJason King 
698d91e49dSJason King 		args.inlen = RESLEN[i];
708d91e49dSJason King 		args.keylen = KEYLEN[i];
718d91e49dSJason King 
728d91e49dSJason King 		errs += run_test(&args, DATA[i], DATALEN[i], DECR_FG);
738d91e49dSJason King 		(void) fprintf(stderr, "----------\n");
748d91e49dSJason King 	}
758d91e49dSJason King 
768d91e49dSJason King 	if (errs != 0)
778d91e49dSJason King 		(void) fprintf(stderr, "%d tests failed\n", errs);
788d91e49dSJason King 
798d91e49dSJason King 	return (errs);
808d91e49dSJason King }
81