mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-07-25 13:24:46 +00:00
Atomics: promote ARM's IR-based atomics pass to CodeGen.
Still only 32-bit ARM using it at this stage, but the promotion allows direct testing via opt and is a reasonably self-contained patch on the way to switching ARM64. At this point, other targets should be able to make use of it without too much difficulty if they want. (See ARM64 commit coming soon for an example). git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@206485 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -31,6 +31,7 @@
|
||||
#include "llvm/IR/CallSite.h"
|
||||
#include "llvm/IR/CallingConv.h"
|
||||
#include "llvm/IR/InlineAsm.h"
|
||||
#include "llvm/IR/IRBuilder.h"
|
||||
#include "llvm/MC/MCRegisterInfo.h"
|
||||
#include "llvm/Target/TargetCallingConv.h"
|
||||
#include "llvm/Target/TargetMachine.h"
|
||||
@@ -896,6 +897,35 @@ public:
|
||||
|
||||
/// @}
|
||||
|
||||
//===--------------------------------------------------------------------===//
|
||||
/// \name Helpers for load-linked/store-conditional atomic expansion.
|
||||
/// @{
|
||||
|
||||
/// Perform a load-linked operation on Addr, returning a "Value *" with the
|
||||
/// corresponding pointee type. This may entail some non-trivial operations to
|
||||
/// truncate or reconstruct types that will be illegal in the backend. See
|
||||
/// ARMISelLowering for an example implementation.
|
||||
virtual Value *emitLoadLinked(IRBuilder<> &Builder, Value *Addr,
|
||||
AtomicOrdering Ord) const {
|
||||
llvm_unreachable("Load linked unimplemented on this target");
|
||||
}
|
||||
|
||||
/// Perform a store-conditional operation to Addr. Return the status of the
|
||||
/// store. This should be 0 if the store succeeded, non-zero otherwise.
|
||||
virtual Value *emitStoreConditional(IRBuilder<> &Builder, Value *Val,
|
||||
Value *Addr, AtomicOrdering Ord) const {
|
||||
llvm_unreachable("Store conditional unimplemented on this target");
|
||||
}
|
||||
|
||||
/// Return true if the given (atomic) instruction should be expanded by the
|
||||
/// IR-level AtomicExpandLoadLinked pass into a loop involving
|
||||
/// load-linked/store-conditional pairs. Atomic stores will be expanded in the
|
||||
/// same way as "atomic xchg" operations which ignore their output if needed.
|
||||
virtual bool shouldExpandAtomicInIR(Instruction *Inst) const {
|
||||
return false;
|
||||
}
|
||||
|
||||
|
||||
//===--------------------------------------------------------------------===//
|
||||
// TargetLowering Configuration Methods - These methods should be invoked by
|
||||
// the derived class constructor to configure this object for the target.
|
||||
|
Reference in New Issue
Block a user