diff options
author | Hongren (Zenithal) Zheng <i@zenithal.me> | 2022-05-11 18:09:46 +0800 |
---|---|---|
committer | Hugo Landau <hlandau@openssl.org> | 2022-07-13 18:15:12 +0100 |
commit | ca6286c382a7eb527fac9aba2a018354acb27b16 (patch) | |
tree | e65b1132d12c673e699ee1a1c2f2b9d84c4d439f /crypto/chacha | |
parent | cdf0a5c46032ba4c39d93a7bec52494b4808830f (diff) |
Add ROTATE inline RISC-V zbb/zbkb asm for chacha
Reviewed-by: Hugo Landau <hlandau@openssl.org>
Reviewed-by: Paul Dale <pauli@openssl.org>
(Merged from https://github.com/openssl/openssl/pull/18289)
Diffstat (limited to 'crypto/chacha')
-rw-r--r-- | crypto/chacha/chacha_enc.c | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/crypto/chacha/chacha_enc.c b/crypto/chacha/chacha_enc.c index c5d1d63d80..f8f1835906 100644 --- a/crypto/chacha/chacha_enc.c +++ b/crypto/chacha/chacha_enc.c @@ -24,6 +24,28 @@ typedef union { # define ROTATE(v, n) (((v) << (n)) | ((v) >> (32 - (n)))) +# ifndef PEDANTIC +# if defined(__GNUC__) && __GNUC__>=2 && \ + !defined(OPENSSL_NO_ASM) && !defined(OPENSSL_NO_INLINE_ASM) +# if defined(__riscv_zbb) || defined(__riscv_zbkb) +# if __riscv_xlen == 64 +# undef ROTATE +# define ROTATE(x, n) ({ u32 ret; \ + asm ("roriw %0, %1, %2" \ + : "=r"(ret) \ + : "r"(x), "i"(32 - (n))); ret;}) +# endif +# if __riscv_xlen == 32 +# undef ROTATE +# define ROTATE(x, n) ({ u32 ret; \ + asm ("rori %0, %1, %2" \ + : "=r"(ret) \ + : "r"(x), "i"(32 - (n))); ret;}) +# endif +# endif +# endif +# endif + # define U32TO8_LITTLE(p, v) do { \ (p)[0] = (u8)(v >> 0); \ (p)[1] = (u8)(v >> 8); \ |