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:
parent
97a1021202
commit
ca6d278c10
16
sshaes.c
16
sshaes.c
@ -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
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user