openssl/include/crypto
Xi Ruoyao c612289b77 vpaes: LoongArch: Use getauxval(AT_HWCAP) for LSX detection
Running LSX instructions requires both the hardware support and the
kernel support.  The `cpucfg` instruction only tests the hardware
support, causing a SIGILL if the hardware supports LSX but the kernel
does not.

Use `getauxval(AT_HWCAP)` as the ["Software Development and Build
Convention for LoongArch Architectures"][1] manual suggests.

The LOONGARCH_HWCAP_LSX and LOONGARCH_HWCAP_LASX bits are copied from
the manual too.  In Glibc 2.38 they'll be provided by <sys/auxv.h> as
well, but they are unavailable in earlier Glibc versions so we cannot
rely on it.

The getauxval syscall and Glibc wrapper are available since day one
(Linux-5.19 and Glibc-2.36) for LoongArch.

Fixes #21508.

[1]:https://github.com/loongson/la-softdev-convention/blob/master/la-softdev-convention.adoc#kernel-constraints

Reviewed-by: Tomas Mraz <tomas@openssl.org>
Reviewed-by: Tom Cosgrove <tom.cosgrove@arm.com>
Reviewed-by: Paul Dale <pauli@openssl.org>
(Merged from https://github.com/openssl/openssl/pull/21509)
2023-07-28 12:39:41 +10:00
..
__DECC_INCLUDE_EPILOGUE.H
__DECC_INCLUDE_PROLOGUE.H
aes_platform.h vpaes: LoongArch: Use getauxval(AT_HWCAP) for LSX detection 2023-07-28 12:39:41 +10:00
aria.h
asn1_dsa.h
asn1.h
asn1err.h
async.h
asyncerr.h
bioerr.h BIO_dgram support for BIO_sendmmsg/BIO_recvmmsg 2022-09-01 18:03:10 +10:00
bn_conf.h.in
bn_dh.h
bn_srp.h
bn.h Revert "Fix Timing Oracle in RSA decryption" 2023-04-04 12:13:27 +02:00
bnerr.h
buffererr.h
chacha.h
cmll_platform.h
cmperr.h CMP client: fix error response on -csr without private key, also in docs 2023-05-12 10:46:27 +02:00
cmserr.h
comperr.h
conferr.h
context.h Release the drbg in the global default context before engines 2022-11-02 11:01:20 +01:00
crmferr.h
cryptlib.h
cryptoerr.h
cterr.h
ctype.h
decoder.h Optimise PKEY decoders 2023-07-17 08:12:06 +10:00
decodererr.h
des_platform.h
dh.h
dherr.h Stop raising ERR_R_MALLOC_FAILURE in most places 2022-10-05 14:02:03 +02:00
dsa.h Implement deterministic ECDSA sign (RFC6979) 2022-11-30 07:31:53 +00:00
dsaerr.h Fix infinite loops in DSA sign code. 2023-03-01 09:20:49 +11:00
dso_conf.h.in
ec.h Implement deterministic ECDSA sign (RFC6979) 2022-11-30 07:31:53 +00:00
ecerr.h Fix potential infinite loops in ECDSA signing. 2023-03-01 09:20:49 +11:00
ecx.h ecx: update to structure based atomics 2023-07-01 21:18:25 +10:00
encoder.h
encodererr.h
engine.h
engineerr.h
err.h
ess.h
esserr.h
evp.h Remove unused internal functions 2023-07-07 13:01:50 +10:00
evperr.h
httperr.h
lhash.h
md32_common.h
modes.h providers: Add SM4 XTS implementation 2022-11-29 16:17:30 +01:00
objects.h
objectserr.h
ocsperr.h
pem.h
pemerr.h
pkcs7.h
pkcs7err.h
pkcs12err.h Allow PKCS12 export to set arbitrary bag attributes 2022-09-23 17:40:02 +01:00
poly1305.h
ppc_arch.h
punycode.h Add more punycode tests and remove ossl_a2ucompare() 2023-02-08 16:17:37 +01:00
rand_pool.h
rand.h
randerr.h
riscv_arch.def
riscv_arch.h riscv: Clean up extension test macros 2023-03-16 13:12:19 +11:00
rsa.h Remove ossl_rsa_pss_params_30_set_maskgenalg(). 2023-03-01 20:04:10 +11:00
rsaerr.h
security_bits.h
sha.h Add support for SHA256/192 2023-06-28 08:00:43 +10:00
siphash.h
siv.h
sm2.h
sm2err.h
sm4_platform.h SM4 check should be for __aarch64__, not __ARM_MAX_ARCH__ >= 8 2023-03-29 17:21:14 +02:00
sm4.h
sparc_arch.h
sparse_array.h
store.h
storeerr.h
tserr.h
types.h Internaly declare the DSA type for no-deprecated builds 2023-02-08 08:50:31 +01:00
uierr.h
x509.h RFC7250 (RPK) support 2023-03-28 13:49:54 -04:00
x509err.h
x509v3err.h