mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-02-25 03:30:37 +00:00
the comments in FastISelEmitter.cpp for details on what this is. This is currently experimental and unusable. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@54751 91177308-0d34-0410-b5e6-96231b3b80d8
72 lines
2.4 KiB
C++
72 lines
2.4 KiB
C++
//===-- FastISel.h - Definition of the FastISel class ---------------------===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This file defines the FastISel class.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_CODEGEN_FASTISEL_H
|
|
#define LLVM_CODEGEN_FASTISEL_H
|
|
|
|
#include "llvm/BasicBlock.h"
|
|
#include "llvm/ADT/DenseMap.h"
|
|
#include "llvm/CodeGen/SelectionDAGNodes.h"
|
|
|
|
namespace llvm {
|
|
|
|
class MachineBasicBlock;
|
|
class MachineFunction;
|
|
class TargetInstrInfo;
|
|
class TargetRegisterClass;
|
|
|
|
/// This file defines the FastISel class. This is a fast-path instruction
|
|
/// selection class that generates poor code and doesn't support illegal
|
|
/// types or non-trivial lowering, but runs quickly.
|
|
class FastISel {
|
|
MachineBasicBlock *MBB;
|
|
MachineFunction *MF;
|
|
const TargetInstrInfo *TII;
|
|
|
|
public:
|
|
FastISel(MachineBasicBlock *mbb, MachineFunction *mf,
|
|
const TargetInstrInfo *tii)
|
|
: MBB(mbb), MF(mf), TII(tii) {}
|
|
|
|
/// SelectInstructions - Do "fast" instruction selection over the
|
|
/// LLVM IR instructions in the range [Begin, N) where N is either
|
|
/// End or the first unsupported instruction. Return N.
|
|
/// ValueMap is filled in with a mapping of LLVM IR Values to
|
|
/// register numbers.
|
|
BasicBlock::iterator
|
|
SelectInstructions(BasicBlock::iterator Begin, BasicBlock::iterator End,
|
|
DenseMap<const Value*, unsigned> &ValueMap);
|
|
|
|
protected:
|
|
virtual unsigned FastEmit_(MVT::SimpleValueType VT,
|
|
ISD::NodeType Opcode);
|
|
virtual unsigned FastEmit_r(MVT::SimpleValueType VT,
|
|
ISD::NodeType Opcode, unsigned Op0);
|
|
virtual unsigned FastEmit_rr(MVT::SimpleValueType VT,
|
|
ISD::NodeType Opcode,
|
|
unsigned Op0, unsigned Op1);
|
|
|
|
unsigned FastEmitInst_(unsigned MachineInstOpcode,
|
|
const TargetRegisterClass *RC);
|
|
unsigned FastEmitInst_r(unsigned MachineInstOpcode,
|
|
const TargetRegisterClass *RC,
|
|
unsigned Op0);
|
|
unsigned FastEmitInst_rr(unsigned MachineInstOpcode,
|
|
const TargetRegisterClass *RC,
|
|
unsigned Op0, unsigned Op1);
|
|
};
|
|
|
|
}
|
|
|
|
#endif
|