X-Git-Url: https://git.distorted.org.uk/~mdw/catacomb/blobdiff_plain/98421fc1a6832ad5de4b3f6171852437aa3e0fb2..57496a500309c335ff9c60d3462757c0c5f04801:/symm/rijndael.c diff --git a/symm/rijndael.c b/symm/rijndael.c index 293f28da..4c8837d2 100644 --- a/symm/rijndael.c +++ b/symm/rijndael.c @@ -72,20 +72,22 @@ void rijndael_init(rijndael_ctx *k, const void *buf, size_t sz) * Use: Low-level block encryption and decryption. */ -CPU_DISPATCH(EMPTY, EMPTY, void, rijndael_eblk, (const rijndael_ctx *k, - const uint32 s[4], - uint32 d[4]), +CPU_DISPATCH(EMPTY, EMPTY, void, rijndael_eblk, + (const rijndael_ctx *k, const uint32 s[4], uint32 d[4]), (k, s, d), pick_eblk, simple_eblk) -CPU_DISPATCH(EMPTY, EMPTY, void, rijndael_dblk, (const rijndael_ctx *k, - const uint32 s[4], - uint32 d[4]), +CPU_DISPATCH(EMPTY, EMPTY, void, rijndael_dblk, + (const rijndael_ctx *k, const uint32 s[4], uint32 d[4]), (k, s, d), pick_dblk, simple_dblk) #if CPUFAM_X86 || CPUFAM_AMD64 extern rijndael_eblk__functype rijndael_eblk_x86ish_aesni; extern rijndael_dblk__functype rijndael_dblk_x86ish_aesni; #endif +#if CPUFAM_ARMEL && HAVE_AS_ARMV8_CRYPTO +extern rijndael_eblk__functype rijndael_eblk_arm_crypto; +extern rijndael_dblk__functype rijndael_dblk_arm_crypto; +#endif static rijndael_eblk__functype *pick_eblk(void) { @@ -93,6 +95,10 @@ static rijndael_eblk__functype *pick_eblk(void) DISPATCH_PICK_COND(rijndael_eblk, rijndael_eblk_x86ish_aesni, cpu_feature_p(CPUFEAT_X86_AESNI)); #endif +#if CPUFAM_ARMEL && HAVE_AS_ARMV8_CRYPTO + DISPATCH_PICK_COND(rijndael_eblk, rijndael_eblk_arm_crypto, + cpu_feature_p(CPUFEAT_ARM_AES)); +#endif DISPATCH_PICK_FALLBACK(rijndael_eblk, simple_eblk); } @@ -102,6 +108,10 @@ static rijndael_dblk__functype *pick_dblk(void) DISPATCH_PICK_COND(rijndael_dblk, rijndael_dblk_x86ish_aesni, cpu_feature_p(CPUFEAT_X86_AESNI)); #endif +#if CPUFAM_ARMEL && HAVE_AS_ARMV8_CRYPTO + DISPATCH_PICK_COND(rijndael_dblk, rijndael_dblk_arm_crypto, + cpu_feature_p(CPUFEAT_ARM_AES)); +#endif DISPATCH_PICK_FALLBACK(rijndael_dblk, simple_dblk); }