mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-15 07:59:33 +00:00
214b27286d
CodeGenDAGPatterns, where it can be used in other tablegen backends. This allows the inference to be done for DAGISelEmitter so that it gets accurate mayLoad/mayStore/isSimpleLoad flags. This brings MemOperand functionality back to where it was before 48329. However, it doesn't solve the problem of anonymous patterns which expand to code that does loads or stores. llvm-svn: 49123
64 lines
1.9 KiB
C++
64 lines
1.9 KiB
C++
//===- InstrInfoEmitter.h - Generate a Instruction Set Desc. ----*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This tablegen backend is responsible for emitting a description of the target
|
|
// instruction set for the code generator.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef INSTRINFO_EMITTER_H
|
|
#define INSTRINFO_EMITTER_H
|
|
|
|
#include "TableGenBackend.h"
|
|
#include "CodeGenDAGPatterns.h"
|
|
#include <vector>
|
|
#include <map>
|
|
|
|
namespace llvm {
|
|
|
|
class StringInit;
|
|
class IntInit;
|
|
class ListInit;
|
|
class CodeGenInstruction;
|
|
|
|
class InstrInfoEmitter : public TableGenBackend {
|
|
RecordKeeper &Records;
|
|
CodeGenDAGPatterns CDP;
|
|
std::map<std::string, unsigned> ItinClassMap;
|
|
|
|
public:
|
|
InstrInfoEmitter(RecordKeeper &R) : Records(R), CDP(R) { }
|
|
|
|
// run - Output the instruction set description, returning true on failure.
|
|
void run(std::ostream &OS);
|
|
|
|
private:
|
|
typedef std::map<std::vector<std::string>, unsigned> OperandInfoMapTy;
|
|
|
|
void emitRecord(const CodeGenInstruction &Inst, unsigned Num,
|
|
Record *InstrInfo,
|
|
std::map<std::vector<Record*>, unsigned> &EL,
|
|
const OperandInfoMapTy &OpInfo,
|
|
std::ostream &OS);
|
|
void emitShiftedValue(Record *R, StringInit *Val, IntInit *Shift,
|
|
std::ostream &OS);
|
|
|
|
// Itinerary information.
|
|
void GatherItinClasses();
|
|
unsigned getItinClassNumber(const Record *InstRec);
|
|
|
|
// Operand information.
|
|
void EmitOperandInfo(std::ostream &OS, OperandInfoMapTy &OperandInfoIDs);
|
|
std::vector<std::string> GetOperandInfo(const CodeGenInstruction &Inst);
|
|
};
|
|
|
|
} // End llvm namespace
|
|
|
|
#endif
|