mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2025-01-05 23:52:45 +00:00
[docs][AtomicExpandPass] Document the alternate lowering strategy for part-word atomicrmw/cmpxchg
D47882, D48130 and D48131 introduce a new lowering strategy for part-word atomicrmw/cmpxchg and uses it to lower these operations for the RISC-V target. Rather than having AtomicExpandPass produce the LL/SC loop in the IR level, it instead calculates the necessary mask values and inserts a target-specific intrinsic, which is lowered at a much later stage (after register allocation). This ensures that architecture-specific restrictions for forward-progress in LL/SC loops can be guaranteed. This patch documents this new AtomicExpandPass functionality. See the previous llvm-dev RFC for more info <http://lists.llvm.org/pipermail/llvm-dev/2018-June/123993.html>. Differential Revision: https://reviews.llvm.org/D52234 llvm-svn: 347971
This commit is contained in:
parent
ceff730fef
commit
f612fadc51
@ -461,8 +461,24 @@ atomic constructs. Here are some lowerings it can do:
|
||||
* atomic rmw -> loop with cmpxchg or load-linked/store-conditional
|
||||
by overriding ``expandAtomicRMWInIR()``
|
||||
* expansion to __atomic_* libcalls for unsupported sizes.
|
||||
* part-word atomicrmw/cmpxchg -> target-specific intrinsic by overriding
|
||||
``shouldExpandAtomicRMWInIR``, ``emitMaskedAtomicRMWIntrinsic``,
|
||||
``shouldExpandAtomicCmpXchgInIR``, and ``emitMaskedAtomicCmpXchgIntrinsic``.
|
||||
|
||||
For an example of all of these, look at the ARM backend.
|
||||
For an example of these look at the ARM (first five lowerings) or RISC-V (last
|
||||
lowering) backend.
|
||||
|
||||
AtomicExpandPass supports two strategies for lowering atomicrmw/cmpxchg to
|
||||
load-linked/store-conditional (LL/SC) loops. The first expands the LL/SC loop
|
||||
in IR, calling target lowering hooks to emit intrinsics for the LL and SC
|
||||
operations. However, many architectures have strict requirements for LL/SC
|
||||
loops to ensure forward progress, such as restrictions on the number and type
|
||||
of instructions in the loop. It isn't possible to enforce these restrictions
|
||||
when the loop is expanded in LLVM IR, and so affected targets may prefer to
|
||||
expand to LL/SC loops at a very late stage (i.e. after register allocation).
|
||||
AtomicExpandPass can help support lowering of part-word atomicrmw or cmpxchg
|
||||
using this strategy by producing IR for any shifting and masking that can be
|
||||
performed outside of the LL/SC loop.
|
||||
|
||||
Libcalls: __atomic_*
|
||||
====================
|
||||
|
Loading…
Reference in New Issue
Block a user