mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-11-02 07:17:36 +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:
@@ -349,6 +349,8 @@ protected:
|
||||
|
||||
/// List of target independent CodeGen pass IDs.
|
||||
namespace llvm {
|
||||
FunctionPass *createAtomicExpandLoadLinkedPass(const TargetMachine *TM);
|
||||
|
||||
/// \brief Create a basic TargetTransformInfo analysis pass.
|
||||
///
|
||||
/// This pass implements the target transform info analysis using the target
|
||||
@@ -374,6 +376,9 @@ namespace llvm {
|
||||
/// matching during instruction selection.
|
||||
FunctionPass *createCodeGenPreparePass(const TargetMachine *TM = nullptr);
|
||||
|
||||
/// AtomicExpandLoadLinkedID -- FIXME
|
||||
extern char &AtomicExpandLoadLinkedID;
|
||||
|
||||
/// MachineLoopInfo - This pass is a loop analysis pass.
|
||||
extern char &MachineLoopInfoID;
|
||||
|
||||
|
||||
@@ -71,6 +71,7 @@ void initializeAliasDebuggerPass(PassRegistry&);
|
||||
void initializeAliasSetPrinterPass(PassRegistry&);
|
||||
void initializeAlwaysInlinerPass(PassRegistry&);
|
||||
void initializeArgPromotionPass(PassRegistry&);
|
||||
void initializeAtomicExpandLoadLinkedPass(PassRegistry&);
|
||||
void initializeSampleProfileLoaderPass(PassRegistry&);
|
||||
void initializeBarrierNoopPass(PassRegistry&);
|
||||
void initializeBasicAliasAnalysisPass(PassRegistry&);
|
||||
|
||||
@@ -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