Add new Lightning rbitr instruction. - lightning.git - Portable just-in-time compiler library

index : lightning.git
Portable just-in-time compiler library
summary refs log tree commit diff
path: root/lib/jit_aarch64-cpu.c
diff options
context:
space:
mode:
authorpcpa <paulo.cesar.pereira.de.andrade@gmail.com>2023年02月28日 17:47:20 -0300
committerpcpa <paulo.cesar.pereira.de.andrade@gmail.com>2023年02月28日 17:47:20 -0300
commitb71ab4f1b8fe533d943de7ea5ce4aa724cf10e7b (patch)
treecb9909113687e780528d8dc7036e66850fe65dd8 /lib/jit_aarch64-cpu.c
parent9ddb79b50e5cd401ee35c994a47986148e5dfb15 (diff)
downloadlightning-b71ab4f1b8fe533d943de7ea5ce4aa724cf10e7b.tar.gz
Add new Lightning rbitr instruction.
This instruction reverses the bits of a word. A possible extension could be a instruction that reverses the bits in every byte, and/or if there is valid high usage, have typed versions, like bswapr_T. This instruction is made available as it is used internally in some backends to implement count trailing ones or zeros.
Diffstat (limited to 'lib/jit_aarch64-cpu.c')
-rw-r--r--lib/jit_aarch64-cpu.c 1
1 files changed, 1 insertions, 0 deletions
diff --git a/lib/jit_aarch64-cpu.c b/lib/jit_aarch64-cpu.c
index d5e64ad..99d8756 100644
--- a/lib/jit_aarch64-cpu.c
+++ b/lib/jit_aarch64-cpu.c
@@ -598,6 +598,7 @@ static void _clzr(jit_state_t*, jit_int32_t, jit_int32_t);
static void _ctor(jit_state_t*, jit_int32_t, jit_int32_t);
# define ctzr(r0, r1) _ctzr(_jit, r0, r1)
static void _ctzr(jit_state_t*, jit_int32_t, jit_int32_t);
+# define rbitr(r0, r1) RBIT(r0, r1)
# define andr(r0,r1,r2) AND(r0,r1,r2)
# define andi(r0,r1,i0) _andi(_jit,r0,r1,i0)
static void _andi(jit_state_t*,jit_int32_t,jit_int32_t,jit_word_t);
generated by cgit v1.2.3 (git 2.39.1) at 2025年09月21日 07:20:24 +0000

AltStyle によって変換されたページ (->オリジナル) /