1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-10 01:48:00 +00:00

Make NEON AES build in 32-bit VS.

I had another look just now at the mysterious AES intrinsics in
VS2017's arm_neon.h that have the wrong number of operands, and this
time I noticed that they're in one branch of an #ifdef whose other
branch looks a lot more sensible. Enabled the #define that switches to
the working branch.
This commit is contained in:
Simon Tatham 2019-04-16 20:31:55 +01:00
parent 97a1021202
commit ca6d278c10

View File

@ -52,15 +52,17 @@
# define USE_CLANG_ATTR_TARGET_AARCH64 # define USE_CLANG_ATTR_TARGET_AARCH64
# endif # endif
#elif defined _MSC_VER #elif defined _MSC_VER
/* Visual Studio supports the crypto extension when targeting
* AArch64, but as of VS2017, the AArch32 header doesn't quite
* manage it (declaring the aese/aesd intrinsics without a round
* key operand). */
# if defined _M_ARM64 # if defined _M_ARM64
# define HW_AES HW_AES_NEON # define HW_AES HW_AES_NEON
# if defined _M_ARM64 /* 64-bit Visual Studio uses the header <arm64_neon.h> in place
# define USE_ARM64_NEON_H /* unusual header name in this case */ * of the standard <arm_neon.h> */
# endif # define USE_ARM64_NEON_H
# elif defined _M_ARM
# define HW_AES HW_AES_NEON
/* 32-bit Visual Studio uses the right header name, but requires
* this #define to enable a set of intrinsic definitions that
* do not omit one of the parameters for vaes[ed]q_u8 */
# define _ARM_USE_NEW_NEON_INTRINSICS
# endif # endif
#endif #endif