| //===- 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; | 
 | } |