2004-04-25 07:04:49 +00:00
|
|
|
//===-- SparcV9Internals.h --------------------------------------*- C++ -*-===//
|
2001-11-08 04:55:13 +00:00
|
|
|
//
|
2003-10-21 15:17:13 +00:00
|
|
|
// 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.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
2004-02-25 18:44:15 +00:00
|
|
|
// This file defines stuff that is to be private to the SparcV9 backend, but is
|
2002-08-09 20:08:06 +00:00
|
|
|
// shared among different portions of the backend.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
2001-09-14 03:56:45 +00:00
|
|
|
|
2004-04-25 07:04:49 +00:00
|
|
|
#ifndef SPARCV9INTERNALS_H
|
|
|
|
#define SPARCV9INTERNALS_H
|
2001-09-14 03:56:45 +00:00
|
|
|
|
2003-05-24 00:09:50 +00:00
|
|
|
#include "llvm/CodeGen/MachineInstrBuilder.h"
|
2001-09-18 22:52:44 +00:00
|
|
|
#include "llvm/Target/TargetMachine.h"
|
2002-12-29 03:13:05 +00:00
|
|
|
#include "llvm/Target/TargetSchedInfo.h"
|
2002-12-28 21:00:25 +00:00
|
|
|
#include "llvm/Target/TargetFrameInfo.h"
|
2004-04-23 18:15:47 +00:00
|
|
|
#include "SparcV9RegInfo.h"
|
2001-09-14 03:56:45 +00:00
|
|
|
#include "llvm/Type.h"
|
2004-02-25 18:44:15 +00:00
|
|
|
#include "SparcV9RegClassInfo.h"
|
2001-09-14 03:56:45 +00:00
|
|
|
|
2003-11-11 22:41:34 +00:00
|
|
|
namespace llvm {
|
|
|
|
|
2002-02-03 23:42:19 +00:00
|
|
|
class LiveRange;
|
2004-02-25 18:44:15 +00:00
|
|
|
class SparcV9TargetMachine;
|
2004-09-20 04:48:05 +00:00
|
|
|
class ModulePass;
|
2004-11-07 00:43:24 +00:00
|
|
|
class GetElementPtrInst;
|
2002-02-03 23:42:19 +00:00
|
|
|
|
2004-02-25 18:44:15 +00:00
|
|
|
enum SparcV9InstrSchedClass {
|
2001-09-14 03:56:45 +00:00
|
|
|
SPARC_NONE, /* Instructions with no scheduling restrictions */
|
|
|
|
SPARC_IEUN, /* Integer class that can use IEU0 or IEU1 */
|
|
|
|
SPARC_IEU0, /* Integer class IEU0 */
|
|
|
|
SPARC_IEU1, /* Integer class IEU1 */
|
|
|
|
SPARC_FPM, /* FP Multiply or Divide instructions */
|
|
|
|
SPARC_FPA, /* All other FP instructions */
|
|
|
|
SPARC_CTI, /* Control-transfer instructions */
|
|
|
|
SPARC_LD, /* Load instructions */
|
|
|
|
SPARC_ST, /* Store instructions */
|
|
|
|
SPARC_SINGLE, /* Instructions that must issue by themselves */
|
|
|
|
|
|
|
|
SPARC_INV, /* This should stay at the end for the next value */
|
|
|
|
SPARC_NUM_SCHED_CLASSES = SPARC_INV
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
2004-02-25 18:44:15 +00:00
|
|
|
// enum SparcV9MachineOpCode.
|
|
|
|
// const TargetInstrDescriptor SparcV9MachineInstrDesc[]
|
2001-09-14 03:56:45 +00:00
|
|
|
//
|
|
|
|
// Purpose:
|
2004-02-25 18:44:15 +00:00
|
|
|
// Description of UltraSparcV9 machine instructions.
|
2001-09-14 03:56:45 +00:00
|
|
|
//
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
2003-05-20 20:32:24 +00:00
|
|
|
namespace V9 {
|
2004-02-25 18:44:15 +00:00
|
|
|
enum SparcV9MachineOpCode {
|
2001-09-19 15:56:23 +00:00
|
|
|
#define I(ENUM, OPCODESTRING, NUMOPERANDS, RESULTPOS, MAXIMM, IMMSE, \
|
|
|
|
NUMDELAYSLOTS, LATENCY, SCHEDCLASS, INSTFLAGS) \
|
|
|
|
ENUM,
|
2004-02-25 18:44:15 +00:00
|
|
|
#include "SparcV9Instr.def"
|
2001-09-14 03:56:45 +00:00
|
|
|
|
2003-05-20 20:32:24 +00:00
|
|
|
// End-of-array marker
|
|
|
|
INVALID_OPCODE,
|
|
|
|
NUM_REAL_OPCODES = PHI, // number of valid opcodes
|
|
|
|
NUM_TOTAL_OPCODES = INVALID_OPCODE
|
|
|
|
};
|
|
|
|
}
|
2001-09-14 03:56:45 +00:00
|
|
|
|
2001-09-19 15:56:23 +00:00
|
|
|
// Array of machine instruction descriptions...
|
2004-02-25 18:44:15 +00:00
|
|
|
extern const TargetInstrDescriptor SparcV9MachineInstrDesc[];
|
2001-09-14 03:56:45 +00:00
|
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
2004-02-25 18:44:15 +00:00
|
|
|
// class SparcV9SchedInfo
|
2001-09-14 03:56:45 +00:00
|
|
|
//
|
|
|
|
// Purpose:
|
|
|
|
// Interface to instruction scheduling information for UltraSPARC.
|
|
|
|
// The parameter values above are based on UltraSPARC IIi.
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
2004-02-25 18:44:15 +00:00
|
|
|
class SparcV9SchedInfo: public TargetSchedInfo {
|
2001-09-14 03:56:45 +00:00
|
|
|
public:
|
2004-02-25 18:44:15 +00:00
|
|
|
SparcV9SchedInfo(const TargetMachine &tgt);
|
2001-09-14 03:56:45 +00:00
|
|
|
protected:
|
2002-02-04 05:59:25 +00:00
|
|
|
virtual void initializeResources();
|
2001-09-14 03:56:45 +00:00
|
|
|
};
|
|
|
|
|
2003-08-13 02:38:16 +00:00
|
|
|
/// createStackSlotsPass - External interface to stack-slots pass that enters 2
|
|
|
|
/// empty slots at the top of each function stack
|
2003-11-13 00:17:20 +00:00
|
|
|
///
|
2004-09-20 04:48:05 +00:00
|
|
|
FunctionPass *createStackSlotsPass(const TargetMachine &TM);
|
2003-08-13 02:38:16 +00:00
|
|
|
|
2003-11-13 00:17:20 +00:00
|
|
|
/// Specializes LLVM code for a target machine.
|
|
|
|
///
|
2003-11-07 17:43:43 +00:00
|
|
|
FunctionPass *createPreSelectionPass(const TargetMachine &TM);
|
2003-09-01 20:33:07 +00:00
|
|
|
|
2004-11-07 00:43:24 +00:00
|
|
|
// DecomposeMultiDimRefs - Convert multi-dimensional references consisting of
|
|
|
|
// any combination of 2 or more array and structure indices into a sequence of
|
|
|
|
// instructions (using getelementpr and cast) so that each instruction has at
|
|
|
|
// most one index (except structure references, which need an extra leading
|
|
|
|
// index of [0]).
|
|
|
|
// This pass decomposes all multi-dimensional references in a function.
|
|
|
|
FunctionPass *createDecomposeMultiDimRefsPass();
|
|
|
|
|
|
|
|
// This function decomposes a single instance of such a reference.
|
|
|
|
// Return value: true if the instruction was replaced; false otherwise.
|
|
|
|
//
|
|
|
|
bool DecomposeArrayRef(GetElementPtrInst* GEP);
|
|
|
|
|
2003-11-13 00:17:20 +00:00
|
|
|
/// Peephole optimization pass operating on machine code
|
|
|
|
///
|
2003-11-07 17:43:43 +00:00
|
|
|
FunctionPass *createPeepholeOptsPass(const TargetMachine &TM);
|
2003-09-01 20:33:07 +00:00
|
|
|
|
2003-11-13 00:17:20 +00:00
|
|
|
/// Writes out assembly code for the module, one function at a time
|
|
|
|
///
|
2004-08-18 05:29:08 +00:00
|
|
|
FunctionPass *createAsmPrinterPass(std::ostream &Out, TargetMachine &TM);
|
2003-11-13 00:17:20 +00:00
|
|
|
|
|
|
|
/// getPrologEpilogInsertionPass - Inserts prolog/epilog code.
|
|
|
|
///
|
|
|
|
FunctionPass* createPrologEpilogInsertionPass();
|
|
|
|
|
|
|
|
/// getBytecodeAsmPrinterPass - Emits final LLVM bytecode to assembly file.
|
|
|
|
///
|
2004-09-20 04:48:05 +00:00
|
|
|
ModulePass* createBytecodeAsmPrinterPass(std::ostream &Out);
|
2003-08-13 02:38:16 +00:00
|
|
|
|
2004-02-25 18:44:15 +00:00
|
|
|
FunctionPass *createSparcV9MachineCodeDestructionPass();
|
2003-12-20 09:17:40 +00:00
|
|
|
|
2003-11-11 22:41:34 +00:00
|
|
|
} // End llvm namespace
|
|
|
|
|
2001-09-14 03:56:45 +00:00
|
|
|
#endif
|