//===- SPU.td - Describe the STI Cell SPU Target Machine ----*- tablegen -*-===// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // // This is the top level entry point for the STI Cell SPU target machine. // //===----------------------------------------------------------------------===// // Get the target-independent interfaces which we are implementing. // include "llvm/Target/Target.td" // Holder of code fragments (you'd think this'd already be in // a td file somewhere... :-) class CodeFrag<dag frag> { dag Fragment = frag; } //===----------------------------------------------------------------------===// // Register File Description //===----------------------------------------------------------------------===// include "SPURegisterInfo.td" //===----------------------------------------------------------------------===// // Instruction formats, instructions //===----------------------------------------------------------------------===// include "SPUNodes.td" include "SPUOperands.td" include "SPUSchedule.td" include "SPUInstrFormats.td" include "SPUInstrInfo.td" //===----------------------------------------------------------------------===// // Subtarget features: //===----------------------------------------------------------------------===// def DefaultProc: SubtargetFeature<"", "ProcDirective", "SPU::DEFAULT_PROC", "">; def LargeMemFeature: SubtargetFeature<"large_mem","UseLargeMem", "true", "Use large (>256) LSA memory addressing [default = false]">; def SPURev0 : Processor<"v0", SPUItineraries, [DefaultProc]>; //===----------------------------------------------------------------------===// // Calling convention: //===----------------------------------------------------------------------===// include "SPUCallingConv.td" // Target: def SPUInstrInfo : InstrInfo { let isLittleEndianEncoding = 1; } def SPU : Target { let InstructionSet = SPUInstrInfo; }