[clang] [llvm] [BPF] Add load-acquire and store-release instructions under -mcpu=v4 (PR #108636)
via llvm-commits
llvm-commits at lists.llvm.org
Tue Oct 22 21:38:42 PDT 2024
yonghong-song wrote:
> > In the above, you will do unsigned load extension. But what about signed
> > extension load variant?
>
> @yonghong-song, if we ever need that, we can add a new flag to bit `0-3` of `imm` to indicate "this 8- or 16-bit load-acquire is sign-extending", just like `BPF_FETCH` for `BPF_XCHG` and `BPF_CMPXCHG`.
I think it is a reasonable idea to use 'imm' bit to indicate the atomic load variants (load_acquire + sign/unsigned).
You could use patterns for atomic_load_zext_{8,16} and atomic_load_sext_{8,16} instread of atomic_load_az_{8,16}.
This will make semantics much more clear. For example, atomic_load_az_8 means "Atomic load which zeroes or anyextends the high bits", what we really wants is zero extension.
https://github.com/llvm/llvm-project/pull/108636
More information about the llvm-commits
mailing list