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