Initial checkin of the InlineAsm class

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@25570 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Chris Lattner 2006-01-24 04:13:11 +00:00
parent 52060a0e71
commit cc041ba03a
7 changed files with 217 additions and 21 deletions

89
include/llvm/InlineAsm.h Normal file
View File

@ -0,0 +1,89 @@
//===-- llvm/InlineAsm.h - Class to represent inline asm strings-*- C++ -*-===//
//
// The LLVM Compiler Infrastructure
//
// This file was developed by Chris Lattner and is distributed under
// the University of Illinois Open Source License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
//
// This class represents the inline asm strings, which are Value*'s that are
// used as the callee operand of call instructions.
//
//===----------------------------------------------------------------------===//
#ifndef LLVM_INLINEASM_H
#define LLVM_INLINEASM_H
#include "llvm/Value.h"
namespace llvm {
class AssemblyAnnotationWriter;
class PointerType;
class FunctionType;
class Module;
template<typename SC> struct ilist_traits;
template<typename ValueSubClass, typename ItemParentClass, typename SymTabClass,
typename SubClass> class SymbolTableListTraits;
class InlineAsm : public Value {
friend class SymbolTableListTraits<InlineAsm, Module, Module,
ilist_traits<InlineAsm> >;
InlineAsm(const InlineAsm &); // do not implement
void operator=(const InlineAsm&); // do not implement
void setParent(Module *Parent);
InlineAsm *Prev, *Next;
void setNext(InlineAsm *N) { Next = N; }
void setPrev(InlineAsm *N) { Prev = N; }
InlineAsm *getNext() { return Next; }
const InlineAsm *getNext() const { return Next; }
InlineAsm *getPrev() { return Prev; }
const InlineAsm *getPrev() const { return Prev; }
Module *Parent;
std::string AsmString, Constraints;
bool AsmHasSideEffects;
public:
InlineAsm(const FunctionType *Ty, const std::string &AsmString,
const std::string &Constraints, bool hasSideEffects,
const std::string &Name = "", Module *ParentModule = 0);
bool getHasSideEffects() const { return AsmHasSideEffects; }
void setSideEffects(bool X) { AsmHasSideEffects = X; }
/// getType - InlineAsm's are always pointers.
///
const PointerType *getType() const {
return reinterpret_cast<const PointerType*>(Value::getType());
}
/// getFunctionType - InlineAsm's are always pointers to functions.
///
const FunctionType *getFunctionType() const;
/// getParent - Get the module that this global value is contained inside
/// of...
Module *getParent() { return Parent; }
const Module *getParent() const { return Parent; }
/// removeFromParent/eraseFromParent - Unlink and unlink/delete this object
/// from the module it is embedded into.
void removeFromParent();
void eraseFromParent();
virtual void print(std::ostream &O) const { print(O, 0); }
void print(std::ostream &OS, AssemblyAnnotationWriter *AAW) const;
// Methods for support type inquiry through isa, cast, and dyn_cast:
static inline bool classof(const InlineAsm *) { return true; }
static inline bool classof(const Value *V) {
return V->getValueType() == Value::InlineAsmVal;
}
};
} // End llvm namespace
#endif

View File

@ -21,6 +21,7 @@
#include "llvm/Function.h" #include "llvm/Function.h"
#include "llvm/GlobalVariable.h" #include "llvm/GlobalVariable.h"
#include "llvm/InlineAsm.h"
#include "llvm/ADT/SetVector.h" #include "llvm/ADT/SetVector.h"
#include "llvm/Support/DataTypes.h" #include "llvm/Support/DataTypes.h"
@ -45,11 +46,19 @@ template<> struct ilist_traits<GlobalVariable>
static void destroySentinel(GlobalVariable *GV) { delete GV; } static void destroySentinel(GlobalVariable *GV) { delete GV; }
static iplist<GlobalVariable> &getList(Module *M); static iplist<GlobalVariable> &getList(Module *M);
}; };
template<> struct ilist_traits<InlineAsm>
: public SymbolTableListTraits<InlineAsm, Module, Module> {
// createSentinel is used to create a node that marks the end of the list.
static InlineAsm *createSentinel();
static void destroySentinel(InlineAsm *GV) { delete GV; }
static iplist<InlineAsm> &getList(Module *M);
};
class Module { class Module {
public: public:
typedef iplist<GlobalVariable> GlobalListType; typedef iplist<GlobalVariable> GlobalListType;
typedef iplist<Function> FunctionListType; typedef iplist<Function> FunctionListType;
typedef iplist<InlineAsm> InlineAsmListType;
typedef SetVector<std::string> LibraryListType; typedef SetVector<std::string> LibraryListType;
// Global Variable iterators. // Global Variable iterators.
@ -60,6 +69,10 @@ public:
typedef FunctionListType::iterator iterator; typedef FunctionListType::iterator iterator;
typedef FunctionListType::const_iterator const_iterator; typedef FunctionListType::const_iterator const_iterator;
// Inline Asm iterators.
typedef InlineAsmListType::iterator inlineasm_iterator;
typedef InlineAsmListType::const_iterator const_inlineasm_iterator;
// Library list iterators. // Library list iterators.
typedef LibraryListType::const_iterator lib_iterator; typedef LibraryListType::const_iterator lib_iterator;
@ -69,6 +82,7 @@ public:
private: private:
GlobalListType GlobalList; // The Global Variables in the module GlobalListType GlobalList; // The Global Variables in the module
FunctionListType FunctionList; // The Functions in the module FunctionListType FunctionList; // The Functions in the module
InlineAsmListType InlineAsmList; // The inline asm objects in the module.
LibraryListType LibraryList; // The Libraries needed by the module LibraryListType LibraryList; // The Libraries needed by the module
std::string GlobalScopeAsm; // Inline Asm at global scope. std::string GlobalScopeAsm; // Inline Asm at global scope.
SymbolTable *SymTab; // Symbol Table for the module SymbolTable *SymTab; // Symbol Table for the module
@ -98,8 +112,8 @@ public:
void setPointerSize(PointerSize PS) { PtrSize = PS; } void setPointerSize(PointerSize PS) { PtrSize = PS; }
// Access to any module-scope inline asm blocks. // Access to any module-scope inline asm blocks.
const std::string &getInlineAsm() const { return GlobalScopeAsm; } const std::string &getModuleInlineAsm() const { return GlobalScopeAsm; }
void setInlineAsm(const std::string &Asm) { GlobalScopeAsm = Asm; } void setModuleInlineAsm(const std::string &Asm) { GlobalScopeAsm = Asm; }
//===--------------------------------------------------------------------===// //===--------------------------------------------------------------------===//
// Methods for easy access to the functions in the module. // Methods for easy access to the functions in the module.
@ -174,17 +188,19 @@ public:
// table. // table.
// //
/// Get the underlying elements of the Module... // Get the underlying elements of the Module.
inline const GlobalListType &getGlobalList() const { return GlobalList; } const GlobalListType &getGlobalList() const { return GlobalList; }
inline GlobalListType &getGlobalList() { return GlobalList; } GlobalListType &getGlobalList() { return GlobalList; }
inline const FunctionListType &getFunctionList() const { return FunctionList;} const FunctionListType &getFunctionList() const { return FunctionList; }
inline FunctionListType &getFunctionList() { return FunctionList;} FunctionListType &getFunctionList() { return FunctionList; }
const InlineAsmListType &getInlineAsmList() const { return InlineAsmList; }
InlineAsmListType &getInlineAsmList() { return InlineAsmList; }
/// getSymbolTable() - Get access to the symbol table for the module, where /// getSymbolTable() - Get access to the symbol table for the module, where
/// global variables and functions are identified. /// global variables and functions are identified.
/// ///
inline SymbolTable &getSymbolTable() { return *SymTab; } SymbolTable &getSymbolTable() { return *SymTab; }
inline const SymbolTable &getSymbolTable() const { return *SymTab; } const SymbolTable &getSymbolTable() const { return *SymTab; }
//===--------------------------------------------------------------------===// //===--------------------------------------------------------------------===//
@ -198,14 +214,29 @@ public:
bool global_empty() const { return GlobalList.empty(); } bool global_empty() const { return GlobalList.empty(); }
// FunctionList interface // FunctionList interface
inline iterator begin() { return FunctionList.begin(); } iterator begin() { return FunctionList.begin(); }
inline const_iterator begin() const { return FunctionList.begin(); } const_iterator begin() const { return FunctionList.begin(); }
inline iterator end () { return FunctionList.end(); } iterator end () { return FunctionList.end(); }
inline const_iterator end () const { return FunctionList.end(); } const_iterator end () const { return FunctionList.end(); }
inline size_t size() const { return FunctionList.size(); } size_t size() const { return FunctionList.size(); }
inline bool empty() const { return FunctionList.empty(); } bool empty() const { return FunctionList.empty(); }
// Inline Asm list interface
inlineasm_iterator inlineasm_begin() {
return InlineAsmList.begin();
}
const_inlineasm_iterator inlineasm_begin() const {
return InlineAsmList.begin();
}
inlineasm_iterator inlineasm_end() {
return InlineAsmList.end();
}
const_inlineasm_iterator inlineasm_end() const {
return InlineAsmList.end();
}
bool inlineasm_empty() const { return InlineAsmList.empty(); }
//===--------------------------------------------------------------------===// //===--------------------------------------------------------------------===//
// List of dependent library access functions // List of dependent library access functions

View File

@ -155,6 +155,7 @@ public:
ConstantStructVal, // This is an instance of ConstantStruct ConstantStructVal, // This is an instance of ConstantStruct
ConstantPackedVal, // This is an instance of ConstantPacked ConstantPackedVal, // This is an instance of ConstantPacked
ConstantPointerNullVal, // This is an instance of ConstantPointerNull ConstantPointerNullVal, // This is an instance of ConstantPointerNull
InlineAsmVal, // This is an instance of InlineAsm
InstructionVal, // This is an instance of Instruction InstructionVal, // This is an instance of Instruction
// Markers: // Markers:
@ -166,7 +167,7 @@ public:
} }
// Methods for support type inquiry through isa, cast, and dyn_cast: // Methods for support type inquiry through isa, cast, and dyn_cast:
static inline bool classof(const Value * /*V*/) { static inline bool classof(const Value *) {
return true; // Values are always values. return true; // Values are always values.
} }

View File

@ -775,9 +775,9 @@ void AssemblyWriter::printModule(const Module *M) {
if (!M->getTargetTriple().empty()) if (!M->getTargetTriple().empty())
Out << "target triple = \"" << M->getTargetTriple() << "\"\n"; Out << "target triple = \"" << M->getTargetTriple() << "\"\n";
if (!M->getInlineAsm().empty()) { if (!M->getModuleInlineAsm().empty()) {
// Split the string into lines, to make it easier to read the .ll file. // Split the string into lines, to make it easier to read the .ll file.
std::string Asm = M->getInlineAsm(); std::string Asm = M->getModuleInlineAsm();
size_t CurPos = 0; size_t CurPos = 0;
size_t NewLine = Asm.find_first_of('\n', CurPos); size_t NewLine = Asm.find_first_of('\n', CurPos);
while (NewLine != std::string::npos) { while (NewLine != std::string::npos) {
@ -1269,6 +1269,14 @@ void Function::print(std::ostream &o, AssemblyAnnotationWriter *AAW) const {
W.write(this); W.write(this);
} }
void InlineAsm::print(std::ostream &o, AssemblyAnnotationWriter *AAW) const {
SlotMachine SlotTable(getParent());
AssemblyWriter W(o, SlotTable, getParent(), AAW);
assert(0 && "Inline asm printing unimplemented!");
//W.write(this);
}
void BasicBlock::print(std::ostream &o, AssemblyAnnotationWriter *AAW) const { void BasicBlock::print(std::ostream &o, AssemblyAnnotationWriter *AAW) const {
SlotMachine SlotTable(getParent()); SlotMachine SlotTable(getParent());
AssemblyWriter W(o, SlotTable, AssemblyWriter W(o, SlotTable,

View File

@ -1,4 +1,4 @@
//===-- Globals.cpp - Implement the Global object classes -----------------===// //===-- Globals.cpp - Implement the GlobalValue & GlobalVariable class ----===//
// //
// The LLVM Compiler Infrastructure // The LLVM Compiler Infrastructure
// //
@ -12,8 +12,8 @@
// //
//===----------------------------------------------------------------------===// //===----------------------------------------------------------------------===//
#include "llvm/DerivedTypes.h"
#include "llvm/GlobalVariable.h" #include "llvm/GlobalVariable.h"
#include "llvm/DerivedTypes.h"
#include "llvm/Module.h" #include "llvm/Module.h"
#include "llvm/SymbolTable.h" #include "llvm/SymbolTable.h"
#include "llvm/Support/LeakDetector.h" #include "llvm/Support/LeakDetector.h"

50
lib/VMCore/InlineAsm.cpp Normal file
View File

@ -0,0 +1,50 @@
//===-- InlineAsm.cpp - Implement the InlineAsm class ---------------------===//
//
// The LLVM Compiler Infrastructure
//
// This file was developed by Chris Lattner and is distributed under the
// University of Illinois Open Source License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
//
// This file implements the InlineAsm class.
//
//===----------------------------------------------------------------------===//
#include "llvm/InlineAsm.h"
#include "llvm/DerivedTypes.h"
#include "llvm/Module.h"
#include "llvm/Support/LeakDetector.h"
using namespace llvm;
InlineAsm::InlineAsm(const FunctionType *Ty, const std::string &asmString,
const std::string &constraints, bool hasSideEffects,
const std::string &name, Module *ParentModule)
: Value(PointerType::get(Ty), Value::InlineAsmVal, name),
Parent(0), AsmString(asmString), Constraints(constraints),
AsmHasSideEffects(hasSideEffects) {
LeakDetector::addGarbageObject(this);
if (ParentModule)
ParentModule->getInlineAsmList().push_back(this);
}
const FunctionType *InlineAsm::getFunctionType() const {
return cast<FunctionType>(getType()->getElementType());
}
void InlineAsm::setParent(Module *parent) {
if (getParent())
LeakDetector::addGarbageObject(this);
Parent = parent;
if (getParent())
LeakDetector::removeGarbageObject(this);
}
void InlineAsm::removeFromParent() {
getParent()->getInlineAsmList().remove(this);
}
void InlineAsm::eraseFromParent() {
getParent()->getInlineAsmList().erase(this);
}

View File

@ -44,17 +44,30 @@ GlobalVariable *ilist_traits<GlobalVariable>::createSentinel() {
return Ret; return Ret;
} }
InlineAsm *ilist_traits<InlineAsm>::createSentinel() {
InlineAsm *Ret = new InlineAsm(FunctionType::get(Type::VoidTy,
std::vector<const Type*>(), false), "", "",
false);
// This should not be garbage monitored.
LeakDetector::removeGarbageObject(Ret);
return Ret;
}
iplist<Function> &ilist_traits<Function>::getList(Module *M) { iplist<Function> &ilist_traits<Function>::getList(Module *M) {
return M->getFunctionList(); return M->getFunctionList();
} }
iplist<GlobalVariable> &ilist_traits<GlobalVariable>::getList(Module *M) { iplist<GlobalVariable> &ilist_traits<GlobalVariable>::getList(Module *M) {
return M->getGlobalList(); return M->getGlobalList();
} }
iplist<InlineAsm> &ilist_traits<InlineAsm>::getList(Module *M) {
return M->getInlineAsmList();
}
// Explicit instantiations of SymbolTableListTraits since some of the methods // Explicit instantiations of SymbolTableListTraits since some of the methods
// are not in the public header file... // are not in the public header file.
template class SymbolTableListTraits<GlobalVariable, Module, Module>; template class SymbolTableListTraits<GlobalVariable, Module, Module>;
template class SymbolTableListTraits<Function, Module, Module>; template class SymbolTableListTraits<Function, Module, Module>;
template class SymbolTableListTraits<InlineAsm, Module, Module>;
//===----------------------------------------------------------------------===// //===----------------------------------------------------------------------===//
// Primitive Module methods. // Primitive Module methods.
@ -66,6 +79,8 @@ Module::Module(const std::string &MID)
FunctionList.setParent(this); FunctionList.setParent(this);
GlobalList.setItemParent(this); GlobalList.setItemParent(this);
GlobalList.setParent(this); GlobalList.setParent(this);
InlineAsmList.setItemParent(this);
InlineAsmList.setParent(this);
SymTab = new SymbolTable(); SymTab = new SymbolTable();
} }
@ -75,6 +90,8 @@ Module::~Module() {
GlobalList.setParent(0); GlobalList.setParent(0);
FunctionList.clear(); FunctionList.clear();
FunctionList.setParent(0); FunctionList.setParent(0);
InlineAsmList.clear();
InlineAsmList.setParent(0);
LibraryList.clear(); LibraryList.clear();
delete SymTab; delete SymTab;
} }