From d7e3eac71887ec9c40bc7a283e05a7f9c952c719 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Fri, 16 Jul 2004 07:11:15 +0000 Subject: [PATCH] Initial checkin of the rest of the skeleton target llvm-svn: 14874 --- lib/Target/Skeleton/Makefile | 3 +- lib/Target/Skeleton/Skeleton.h | 33 +++++++ lib/Target/Skeleton/Skeleton.td | 4 +- lib/Target/Skeleton/SkeletonInstrInfo.cpp | 22 +++++ lib/Target/Skeleton/SkeletonInstrInfo.h | 36 +++++++ lib/Target/Skeleton/SkeletonInstrInfo.td | 2 +- lib/Target/Skeleton/SkeletonJITInfo.cpp | 37 ++++++++ lib/Target/Skeleton/SkeletonJITInfo.h | 49 ++++++++++ lib/Target/Skeleton/SkeletonRegisterInfo.cpp | 94 +++++++++++++++++++ lib/Target/Skeleton/SkeletonRegisterInfo.h | 56 +++++++++++ lib/Target/Skeleton/SkeletonTargetMachine.cpp | 58 ++++++++++++ lib/Target/Skeleton/SkeletonTargetMachine.h | 50 ++++++++++ 12 files changed, 440 insertions(+), 4 deletions(-) create mode 100644 lib/Target/Skeleton/Skeleton.h create mode 100644 lib/Target/Skeleton/SkeletonInstrInfo.cpp create mode 100644 lib/Target/Skeleton/SkeletonInstrInfo.h create mode 100644 lib/Target/Skeleton/SkeletonJITInfo.cpp create mode 100644 lib/Target/Skeleton/SkeletonJITInfo.h create mode 100644 lib/Target/Skeleton/SkeletonRegisterInfo.cpp create mode 100644 lib/Target/Skeleton/SkeletonRegisterInfo.h create mode 100644 lib/Target/Skeleton/SkeletonTargetMachine.cpp create mode 100644 lib/Target/Skeleton/SkeletonTargetMachine.h diff --git a/lib/Target/Skeleton/Makefile b/lib/Target/Skeleton/Makefile index 1b4691e10e1..725dcbad135 100644 --- a/lib/Target/Skeleton/Makefile +++ b/lib/Target/Skeleton/Makefile @@ -12,7 +12,8 @@ LIBRARYNAME = skeleton include $(LEVEL)/Makefile.common TARGET = Skeleton -TDFILES = $(wildcard $(SourceDir)/*.td) $(SourceDir)/../Target.td +TDFILES = $(SourceDir)/$(TARGET).td $(wildcard $(SourceDir)/*.td) \ + $(SourceDir)/../Target.td # Make sure that tblgen is run, first thing. diff --git a/lib/Target/Skeleton/Skeleton.h b/lib/Target/Skeleton/Skeleton.h new file mode 100644 index 00000000000..8177d9c064c --- /dev/null +++ b/lib/Target/Skeleton/Skeleton.h @@ -0,0 +1,33 @@ +//===-- Skeleton.h - Target private header file -----------------*- C++ -*-===// +// +// The LLVM Compiler Infrastructure +// +// This file was developed by the LLVM research group and is distributed under +// the University of Illinois Open Source License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// This file contains the definitions shared among the various components of the +// Skeleton backend. +// +//===----------------------------------------------------------------------===// + +#ifndef TARGET_SKELETON_H +#define TARGET_SKELETON_H + +#include + +/// Put prototypes here for functions used to create various passes. + + +// Defines symbolic enum names for target registers. This defines a mapping +// from register name to register number. These are generated by tblgen from +// your target file. +// +#include "SkeletonGenRegisterNames.inc" + +// Defines symbolic enum names for the target instructions. +// +#include "SkeletonGenInstrNames.inc" + +#endif diff --git a/lib/Target/Skeleton/Skeleton.td b/lib/Target/Skeleton/Skeleton.td index 2a5471ac165..93ae184062e 100644 --- a/lib/Target/Skeleton/Skeleton.td +++ b/lib/Target/Skeleton/Skeleton.td @@ -1,4 +1,4 @@ -//===- PowerPC.td - Describe the PowerPC Target Machine ---------*- C++ -*-===// +//===- Skeleton.td - Describe the Skeleton Target Machine -------*- C++ -*-===// // // The LLVM Compiler Infrastructure // @@ -25,7 +25,7 @@ def SkeletonInstrInfo : InstrInfo { let PHIInst = PHI; } -def PowerPC : Target { +def Skeleton : Target { // Pointers are 32-bits in size. let PointerType = i32; diff --git a/lib/Target/Skeleton/SkeletonInstrInfo.cpp b/lib/Target/Skeleton/SkeletonInstrInfo.cpp new file mode 100644 index 00000000000..e81f64f334f --- /dev/null +++ b/lib/Target/Skeleton/SkeletonInstrInfo.cpp @@ -0,0 +1,22 @@ +//===- SkeletonInstrInfo.cpp - Instruction Information ----------*- C++ -*-===// +// +// The LLVM Compiler Infrastructure +// +// This file was developed by the LLVM research group and is distributed under +// the University of Illinois Open Source License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// This is where you implement methods for the TargetInstrInfo class. +// +//===----------------------------------------------------------------------===// + +#include "SkeletonInstrInfo.h" +#include "llvm/CodeGen/MachineInstrBuilder.h" +#include "SkeletonGenInstrInfo.inc" // Get info from Tablegen +using namespace llvm; + +SkeletonInstrInfo::SkeletonInstrInfo() + : TargetInstrInfo(SkeletonInsts, + sizeof(SkeletonInsts)/sizeof(SkeletonInsts[0])){ +} diff --git a/lib/Target/Skeleton/SkeletonInstrInfo.h b/lib/Target/Skeleton/SkeletonInstrInfo.h new file mode 100644 index 00000000000..7a6d33f1232 --- /dev/null +++ b/lib/Target/Skeleton/SkeletonInstrInfo.h @@ -0,0 +1,36 @@ +//===- SkeletonInstrInfo.h - Instruction Information ------------*- C++ -*-===// +// +// The LLVM Compiler Infrastructure +// +// This file was developed by the LLVM research group and is distributed under +// the University of Illinois Open Source License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// This file is where the target-specific implementation of the TargetInstrInfo +// class goes. +// +//===----------------------------------------------------------------------===// + +#ifndef SKELETON_INSTRUCTIONINFO_H +#define SKELETON_INSTRUCTIONINFO_H + +#include "llvm/Target/TargetInstrInfo.h" +#include "SkeletonRegisterInfo.h" + +namespace llvm { + + class SkeletonInstrInfo : public TargetInstrInfo { + const SkeletonRegisterInfo RI; + public: + SkeletonInstrInfo(); + + /// getRegisterInfo - TargetInstrInfo is a superset of MRegister info. As + /// such, whenever a client has an instance of instruction info, it should + /// always be able to get register info as well (through this method). + /// + virtual const MRegisterInfo &getRegisterInfo() const { return RI; } + }; +} + +#endif diff --git a/lib/Target/Skeleton/SkeletonInstrInfo.td b/lib/Target/Skeleton/SkeletonInstrInfo.td index 4df3614f244..33902b57c1f 100644 --- a/lib/Target/Skeleton/SkeletonInstrInfo.td +++ b/lib/Target/Skeleton/SkeletonInstrInfo.td @@ -15,7 +15,7 @@ class Format val> { bits<4> Value = val; } -// All of the PowerPC instruction formats, plus a pseudo-instruction format: +// Some of the powerpc instruction formats, plus a pseudo-instruction format: def Pseudo : Format<0>; def IForm : Format<1>; def BForm : Format<2>; diff --git a/lib/Target/Skeleton/SkeletonJITInfo.cpp b/lib/Target/Skeleton/SkeletonJITInfo.cpp new file mode 100644 index 00000000000..b33a44bff3a --- /dev/null +++ b/lib/Target/Skeleton/SkeletonJITInfo.cpp @@ -0,0 +1,37 @@ +//===-- SkeletonCodeEmitter.cpp - JIT Code Emitter --------------*- C++ -*-===// +// +// The LLVM Compiler Infrastructure +// +// This file was developed by the LLVM research group and is distributed under +// the University of Illinois Open Source License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// This is a stub for a JIT code generator, which is obviously not implemented. +// +//===----------------------------------------------------------------------===// + +#include "SkeletonTargetMachine.h" +using namespace llvm; + +/// addPassesToEmitMachineCode - Add passes to the specified pass manager to get +/// machine code emitted. This uses a MachineCodeEmitter object to handle +/// actually outputting the machine code and resolving things like the address +/// of functions. This method should returns true if machine code emission is +/// not supported. +/// +bool SkeletonTargetMachine::addPassesToEmitMachineCode(FunctionPassManager &PM, + MachineCodeEmitter &MCE){ + return true; // Not implemented yet! +} + +void *SkeletonJITInfo::getJITStubForFunction(Function *F, + MachineCodeEmitter &MCE) { + assert (0 && "getJITStubForFunction not implemented"); + return 0; +} + +void SkeletonJITInfo::replaceMachineCodeForFunction (void *Old, void *New) { + assert (0 && "replaceMachineCodeForFunction not implemented"); +} + diff --git a/lib/Target/Skeleton/SkeletonJITInfo.h b/lib/Target/Skeleton/SkeletonJITInfo.h new file mode 100644 index 00000000000..6424b0e8929 --- /dev/null +++ b/lib/Target/Skeleton/SkeletonJITInfo.h @@ -0,0 +1,49 @@ +//===- SkeletonJITInfo.h - Skeleton impl of JIT interface -------*- C++ -*-===// +// +// The LLVM Compiler Infrastructure +// +// This file was developed by the LLVM research group and is distributed under +// the University of Illinois Open Source License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// This file contains the skeleton implementation of the TargetJITInfo class. +// +//===----------------------------------------------------------------------===// + +#ifndef SKELETONJITINFO_H +#define SKELETONJITINFO_H + +#include "llvm/Target/TargetJITInfo.h" + +namespace llvm { + class TargetMachine; + class IntrinsicLowering; + + class SkeletonJITInfo : public TargetJITInfo { + TargetMachine &TM; + public: + SkeletonJITInfo(TargetMachine &tm) : TM(tm) {} + + /// addPassesToJITCompile - Add passes to the specified pass manager to + /// implement a fast dynamic compiler for this target. Return true if this + /// is not supported for this target. + /// + virtual void addPassesToJITCompile(FunctionPassManager &PM); + + /// replaceMachineCodeForFunction - Make it so that calling the function + /// whose machine code is at OLD turns into a call to NEW, perhaps by + /// overwriting OLD with a branch to NEW. This is used for self-modifying + /// code. + /// + virtual void replaceMachineCodeForFunction(void *Old, void *New); + + /// getJITStubForFunction - Create or return a stub for the specified + /// function. This stub acts just like the specified function, except that + /// it allows the "address" of the function to be taken without having to + /// generate code for it. + virtual void *getJITStubForFunction(Function *F, MachineCodeEmitter &MCE); + }; +} + +#endif diff --git a/lib/Target/Skeleton/SkeletonRegisterInfo.cpp b/lib/Target/Skeleton/SkeletonRegisterInfo.cpp new file mode 100644 index 00000000000..e47354655de --- /dev/null +++ b/lib/Target/Skeleton/SkeletonRegisterInfo.cpp @@ -0,0 +1,94 @@ +//===- SkeletonRegisterInfo.cpp - Skeleton Register Information -*- C++ -*-===// +// +// The LLVM Compiler Infrastructure +// +// This file was developed by the LLVM research group and is distributed under +// the University of Illinois Open Source License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// This file contains the Skeleton implementation of the MRegisterInfo class. +// +//===----------------------------------------------------------------------===// + +#include "Skeleton.h" +#include "SkeletonRegisterInfo.h" +#include "llvm/Type.h" +using namespace llvm; + +SkeletonRegisterInfo::SkeletonRegisterInfo() + : SkeletonGenRegisterInfo(Skeleton::ADJCALLSTACKDOWN, + Skeleton::ADJCALLSTACKUP) {} + +int SkeletonRegisterInfo::storeRegToStackSlot(MachineBasicBlock &MBB, + MachineBasicBlock::iterator MBBI, + unsigned SrcReg, int FrameIdx, + const TargetRegisterClass *RC) const { + abort(); + return -1; +} + +int SkeletonRegisterInfo::loadRegFromStackSlot(MachineBasicBlock &MBB, + MachineBasicBlock::iterator MBBI, + unsigned DestReg, int FrameIdx, + const TargetRegisterClass *RC) const { + abort(); + return -1; +} + +int SkeletonRegisterInfo::copyRegToReg(MachineBasicBlock &MBB, + MachineBasicBlock::iterator MBBI, + unsigned DestReg, unsigned SrcReg, + const TargetRegisterClass *RC) const { + abort(); + return -1; +} + +void SkeletonRegisterInfo:: +eliminateCallFramePseudoInstr(MachineFunction &MF, MachineBasicBlock &MBB, + MachineBasicBlock::iterator I) const { + abort(); +} + +void SkeletonRegisterInfo::eliminateFrameIndex(MachineFunction &MF, + MachineBasicBlock::iterator II) const { + abort(); +} + +void SkeletonRegisterInfo:: +processFunctionBeforeFrameFinalized(MachineFunction &MF) const { + abort(); +} + +void SkeletonRegisterInfo::emitPrologue(MachineFunction &MF) const { + abort(); +} + +void SkeletonRegisterInfo::emitEpilogue(MachineFunction &MF, + MachineBasicBlock &MBB) const { + abort(); +} + + +#include "SkeletonGenRegisterInfo.inc" + +const TargetRegisterClass* +SkeletonRegisterInfo::getRegClassForType(const Type* Ty) const { + switch (Ty->getTypeID()) { + case Type::LongTyID: + case Type::ULongTyID: assert(0 && "Long values can't fit in registers!"); + default: assert(0 && "Invalid type to getClass!"); + case Type::BoolTyID: + case Type::SByteTyID: + case Type::UByteTyID: + case Type::ShortTyID: + case Type::UShortTyID: + case Type::IntTyID: + case Type::UIntTyID: + case Type::PointerTyID: return &GPRCInstance; + + case Type::FloatTyID: + case Type::DoubleTyID: return &FPRCInstance; + } +} + diff --git a/lib/Target/Skeleton/SkeletonRegisterInfo.h b/lib/Target/Skeleton/SkeletonRegisterInfo.h new file mode 100644 index 00000000000..b2d43abf395 --- /dev/null +++ b/lib/Target/Skeleton/SkeletonRegisterInfo.h @@ -0,0 +1,56 @@ +//===- SkeletonRegisterInfo.h - Skeleton Register Information Impl -*- C++ -*-==// +// +// The LLVM Compiler Infrastructure +// +// This file was developed by the LLVM research group and is distributed under +// the University of Illinois Open Source License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// This file contains the Skeleton implementation of the MRegisterInfo class. +// +//===----------------------------------------------------------------------===// + +#ifndef SKELETON_REGISTERINFO_H +#define SKELETON_REGISTERINFO_H + +#include "llvm/Target/MRegisterInfo.h" +#include "SkeletonGenRegisterInfo.h.inc" + +namespace llvm { + class Type; + + struct SkeletonRegisterInfo : public SkeletonGenRegisterInfo { + SkeletonRegisterInfo(); + const TargetRegisterClass* getRegClassForType(const Type* Ty) const; + + // See MRegisterInfo.h for information on these methods. + int storeRegToStackSlot(MachineBasicBlock &MBB, + MachineBasicBlock::iterator MBBI, + unsigned SrcReg, int FrameIndex, + const TargetRegisterClass *RC) const; + + int loadRegFromStackSlot(MachineBasicBlock &MBB, + MachineBasicBlock::iterator MBBI, + unsigned DestReg, int FrameIndex, + const TargetRegisterClass *RC) const; + + int copyRegToReg(MachineBasicBlock &MBB, MachineBasicBlock::iterator MBBI, + unsigned DestReg, unsigned SrcReg, + const TargetRegisterClass *RC) const; + + void eliminateCallFramePseudoInstr(MachineFunction &MF, + MachineBasicBlock &MBB, + MachineBasicBlock::iterator I) const; + + void eliminateFrameIndex(MachineFunction &MF, + MachineBasicBlock::iterator II) const; + + void processFunctionBeforeFrameFinalized(MachineFunction &MF) const; + + void emitPrologue(MachineFunction &MF) const; + void emitEpilogue(MachineFunction &MF, MachineBasicBlock &MBB) const; + }; +} // end namespace llvm + +#endif diff --git a/lib/Target/Skeleton/SkeletonTargetMachine.cpp b/lib/Target/Skeleton/SkeletonTargetMachine.cpp new file mode 100644 index 00000000000..3a09f2862ad --- /dev/null +++ b/lib/Target/Skeleton/SkeletonTargetMachine.cpp @@ -0,0 +1,58 @@ +//===-- SkeletonTargetMachine.cpp - Define TargetMachine for Skeleton -----===// +// +// The LLVM Compiler Infrastructure +// +// This file was developed by the LLVM research group and is distributed under +// the University of Illinois Open Source License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// +//===----------------------------------------------------------------------===// + +#include "SkeletonTargetMachine.h" +#include "Skeleton.h" +#include "llvm/Module.h" +#include "llvm/PassManager.h" +#include "llvm/Target/TargetOptions.h" +#include "llvm/Target/TargetMachineRegistry.h" +#include "llvm/CodeGen/MachineFunction.h" +#include "llvm/CodeGen/Passes.h" +using namespace llvm; + +namespace { + // Register the target. + RegisterTarget X("skeleton", + " Target Skeleton (unusable)"); +} + +/// SkeletonTargetMachine ctor - Create an ILP32 architecture model +/// +SkeletonTargetMachine::SkeletonTargetMachine(const Module &M, + IntrinsicLowering *IL) + : TargetMachine("Skeleton", IL, true, 4, 4, 4, 4, 4), + FrameInfo(TargetFrameInfo::StackGrowsDown, 8, -4), JITInfo(*this) { +} + +/// addPassesToEmitAssembly - Add passes to the specified pass manager +/// to implement a static compiler for this target. +/// +bool SkeletonTargetMachine::addPassesToEmitAssembly(PassManager &PM, + std::ostream &Out) { + // + PM.add(createRegisterAllocator()); + PM.add(createPrologEpilogCodeInserter()); + // + PM.add(createMachineCodeDeleter()); + return true; // change to `return false' when this actually works. +} + +/// addPassesToJITCompile - Add passes to the specified pass manager to +/// implement a fast dynamic compiler for this target. +/// +void SkeletonJITInfo::addPassesToJITCompile(FunctionPassManager &PM) { + // + PM.add(createRegisterAllocator()); + PM.add(createPrologEpilogCodeInserter()); +} + diff --git a/lib/Target/Skeleton/SkeletonTargetMachine.h b/lib/Target/Skeleton/SkeletonTargetMachine.h new file mode 100644 index 00000000000..2cf7b11f104 --- /dev/null +++ b/lib/Target/Skeleton/SkeletonTargetMachine.h @@ -0,0 +1,50 @@ +//===-- SkeletonTargetMachine.h - TargetMachine for Skeleton ----*- C++ -*-===// +// +// The LLVM Compiler Infrastructure +// +// This file was developed by the LLVM research group and is distributed under +// the University of Illinois Open Source License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// This file declares the Skeleton specific subclass of TargetMachine. +// +//===----------------------------------------------------------------------===// + +#ifndef SKELETONTARGETMACHINE_H +#define SKELETONTARGETMACHINE_H + +#include "llvm/Target/TargetMachine.h" +#include "llvm/Target/TargetFrameInfo.h" +#include "llvm/PassManager.h" +#include "SkeletonInstrInfo.h" +#include "SkeletonJITInfo.h" + +namespace llvm { + class IntrinsicLowering; + + class SkeletonTargetMachine : public TargetMachine { + SkeletonInstrInfo InstrInfo; + TargetFrameInfo FrameInfo; + SkeletonJITInfo JITInfo; + public: + SkeletonTargetMachine(const Module &M, IntrinsicLowering *IL); + + virtual const SkeletonInstrInfo *getInstrInfo() const { return &InstrInfo; } + virtual const TargetFrameInfo *getFrameInfo() const { return &FrameInfo; } + virtual const MRegisterInfo *getRegisterInfo() const { + return &InstrInfo.getRegisterInfo(); + } + virtual TargetJITInfo *getJITInfo() { + return &JITInfo; + } + + virtual bool addPassesToEmitMachineCode(FunctionPassManager &PM, + MachineCodeEmitter &MCE); + + virtual bool addPassesToEmitAssembly(PassManager &PM, std::ostream &Out); + }; + +} // end namespace llvm + +#endif