mirror of
https://github.com/RPCS3/llvm.git
synced 2024-12-03 09:21:02 +00:00
Breaking out specialized classes.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@29470 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
686c4a18f1
commit
9b9528d8f6
64
include/llvm/CodeGen/RegAllocRegistry.h
Normal file
64
include/llvm/CodeGen/RegAllocRegistry.h
Normal file
@ -0,0 +1,64 @@
|
||||
//===-- llvm/CodeGen/RegAllocRegistry.h -------------------------*- C++ -*-===//
|
||||
//
|
||||
// The LLVM Compiler Infrastructure
|
||||
//
|
||||
// This file was developed by the James M. Laskey and is distributed under
|
||||
// the University of Illinois Open Source License. See LICENSE.TXT for details.
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
//
|
||||
// This file contains the implementation for register allocator function
|
||||
// pass registry (RegisterRegAlloc).
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#ifndef LLVM_CODEGENREGALLOCREGISTRY_H
|
||||
#define LLVM_CODEGENREGALLOCREGISTRY_H
|
||||
|
||||
#include "llvm/CodeGen/MachinePassRegistry.h"
|
||||
|
||||
namespace llvm {
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
///
|
||||
/// RegisterRegAlloc class - Track the registration of register allocators.
|
||||
///
|
||||
//===----------------------------------------------------------------------===//
|
||||
class RegisterRegAlloc : public MachinePassRegistryNode {
|
||||
|
||||
public:
|
||||
|
||||
typedef FunctionPass *(*FunctionPassCtor)();
|
||||
|
||||
static MachinePassRegistry Registry;
|
||||
|
||||
RegisterRegAlloc(const char *N, const char *D, FunctionPassCtor C)
|
||||
: MachinePassRegistryNode(N, D, (MachinePassCtor)C)
|
||||
{ Registry.Add(this); }
|
||||
~RegisterRegAlloc() { Registry.Remove(this); }
|
||||
|
||||
|
||||
// Accessors.
|
||||
//
|
||||
RegisterRegAlloc *getNext() const {
|
||||
return (RegisterRegAlloc *)MachinePassRegistryNode::getNext();
|
||||
}
|
||||
static RegisterRegAlloc *getList() {
|
||||
return (RegisterRegAlloc *)Registry.getList();
|
||||
}
|
||||
static FunctionPassCtor getDefault() {
|
||||
return (FunctionPassCtor)Registry.getDefault();
|
||||
}
|
||||
static void setDefault(FunctionPassCtor C) {
|
||||
Registry.setDefault((MachinePassCtor)C);
|
||||
}
|
||||
static void setListener(MachinePassRegistryListener *L) {
|
||||
Registry.setListener(L);
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
} // end namespace llvm
|
||||
|
||||
|
||||
#endif
|
71
include/llvm/CodeGen/SchedulerRegistry.h
Normal file
71
include/llvm/CodeGen/SchedulerRegistry.h
Normal file
@ -0,0 +1,71 @@
|
||||
//===-- llvm/CodeGen/SchedulerRegistry.h ------------------------*- C++ -*-===//
|
||||
//
|
||||
// The LLVM Compiler Infrastructure
|
||||
//
|
||||
// This file was developed by the James M. Laskey and is distributed under
|
||||
// the University of Illinois Open Source License. See LICENSE.TXT for details.
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
//
|
||||
// This file contains the implementation for instruction scheduler function
|
||||
// pass registry (RegisterScheduler).
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#ifndef LLVM_CODEGENSCHEDULERREGISTRY_H
|
||||
#define LLVM_CODEGENSCHEDULERREGISTRY_H
|
||||
|
||||
#include "llvm/CodeGen/MachinePassRegistry.h"
|
||||
|
||||
namespace llvm {
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
///
|
||||
/// RegisterScheduler class - Track the registration of instruction schedulers.
|
||||
///
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
class SelectionDAGISel;
|
||||
class ScheduleDAG;
|
||||
class SelectionDAG;
|
||||
class MachineBasicBlock;
|
||||
|
||||
class RegisterScheduler : public MachinePassRegistryNode {
|
||||
|
||||
public:
|
||||
|
||||
typedef ScheduleDAG *(*FunctionPassCtor)(SelectionDAGISel*, SelectionDAG*,
|
||||
MachineBasicBlock*);
|
||||
|
||||
static MachinePassRegistry Registry;
|
||||
|
||||
RegisterScheduler(const char *N, const char *D, FunctionPassCtor C)
|
||||
: MachinePassRegistryNode(N, D, (MachinePassCtor)C)
|
||||
{ Registry.Add(this); }
|
||||
~RegisterScheduler() { Registry.Remove(this); }
|
||||
|
||||
|
||||
// Accessors.
|
||||
//
|
||||
RegisterScheduler *getNext() const {
|
||||
return (RegisterScheduler *)MachinePassRegistryNode::getNext();
|
||||
}
|
||||
static RegisterScheduler *getList() {
|
||||
return (RegisterScheduler *)Registry.getList();
|
||||
}
|
||||
static FunctionPassCtor getDefault() {
|
||||
return (FunctionPassCtor)Registry.getDefault();
|
||||
}
|
||||
static void setDefault(FunctionPassCtor C) {
|
||||
Registry.setDefault((MachinePassCtor)C);
|
||||
}
|
||||
static void setListener(MachinePassRegistryListener *L) {
|
||||
Registry.setListener(L);
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
} // end namespace llvm
|
||||
|
||||
|
||||
#endif
|
Loading…
Reference in New Issue
Block a user