12345678910111213141516171819202122232425262728293031323334 |
- /*
- * Copyright 2023 The OpenSSL Project Authors. All Rights Reserved.
- *
- * Licensed under the Apache License 2.0 (the "License"). You may not use
- * this file except in compliance with the License. You can obtain a copy
- * in the file LICENSE in the source distribution or at
- * https://www.openssl.org/source/license.html
- */
- /*
- * Crypto extension support for AES modes ecb, cbc, ofb, cfb, ctr.
- * This file is included by cipher_aes_hw.c
- */
- static int cipher_hw_aes_arm_initkey(PROV_CIPHER_CTX *dat,
- const unsigned char *key,
- size_t keylen)
- {
- int ret = cipher_hw_aes_initkey(dat, key, keylen);
- if (AES_UNROLL12_EOR3_CAPABLE && dat->mode == EVP_CIPH_CTR_MODE)
- dat->stream.ctr = (ctr128_f)HWAES_ctr32_encrypt_blocks_unroll12_eor3;
- return ret;
- }
- #define PROV_CIPHER_HW_declare(mode) \
- static const PROV_CIPHER_HW aes_arm_##mode = { \
- cipher_hw_aes_arm_initkey, \
- ossl_cipher_hw_generic_##mode, \
- cipher_hw_aes_copyctx \
- };
- #define PROV_CIPHER_HW_select(mode) \
- if (ARMv8_HWAES_CAPABLE) \
- return &aes_arm_##mode;
|