aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/test/aes256cbc_decrypt_block.c
diff options
context:
space:
mode:
Diffstat (limited to 'test/aes256cbc_decrypt_block.c')
-rw-r--r--test/aes256cbc_decrypt_block.c27
1 files changed, 20 insertions, 7 deletions
diff --git a/test/aes256cbc_decrypt_block.c b/test/aes256cbc_decrypt_block.c
index 8a2cbe1..0021007 100644
--- a/test/aes256cbc_decrypt_block.c
+++ b/test/aes256cbc_decrypt_block.c
@@ -18,8 +18,15 @@ static void exit_with_usage()
exit(EXIT_FAILURE);
}
+static void print_error(AesNI_StatusCode status)
+{
+ fprintf(stderr, "AesNI error: %s\n", aesni_strerror(status));
+}
+
int main(int argc, char** argv)
{
+ AesNI_StatusCode status = AESNI_SUCCESS;
+
for (--argc, ++argv; argc > -1; --argc, ++argv)
{
AesNI_Block128 plaintext, ciphertext, iv;
@@ -29,15 +36,15 @@ int main(int argc, char** argv)
if (argc < 2)
exit_with_usage();
- if (aesni_is_error(aesni_aes256_parse_key(&key, *argv, NULL)))
+ if (aesni_is_error(status = aesni_aes256_parse_key(&key, *argv, NULL)))
{
- fprintf(stderr, "Invalid 256-bit AES block '%s'\n", *argv);
+ print_error(status);
exit_with_usage();
}
- if (aesni_is_error(aesni_aes_parse_block(&iv, argv[1], NULL)))
+ if (aesni_is_error(status = aesni_aes_parse_block(&iv, argv[1], NULL)))
{
- fprintf(stderr, "Invalid 128-bit AES block '%s'\n", argv[1]);
+ print_error(status);
exit_with_usage();
}
@@ -49,13 +56,19 @@ int main(int argc, char** argv)
if (strcmp("--", *argv) == 0)
break;
- if (aesni_is_error(aesni_aes_parse_block(&ciphertext, *argv, NULL)))
+ if (aesni_is_error(status = aesni_aes_parse_block(&ciphertext, *argv, NULL)))
{
- fprintf(stderr, "Invalid 128-bit AES block '%s'\n", *argv);
+ print_error(status);
continue;
}
+
plaintext = aesni_aes256_decrypt_block_cbc(ciphertext, &decryption_keys, iv, &iv);
- aesni_aes_print_block(&plaintext, NULL);
+
+ if (aesni_is_error(status = aesni_aes_print_block(&plaintext, NULL)))
+ {
+ print_error(status);
+ continue;
+ }
}
}