2012-02-28 15:46:26 +08:00
|
|
|
//===-- MipsSchedule.td - Mips Scheduling Definitions ------*- tablegen -*-===//
|
2007-08-18 09:46:44 +08:00
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
2007-12-30 04:36:04 +08:00
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
2007-08-18 09:46:44 +08:00
|
|
|
//
|
2011-04-16 05:51:11 +08:00
|
|
|
//===----------------------------------------------------------------------===//
|
2007-08-18 09:46:44 +08:00
|
|
|
|
2011-04-16 05:51:11 +08:00
|
|
|
//===----------------------------------------------------------------------===//
|
2007-08-18 09:46:44 +08:00
|
|
|
// Functional units across Mips chips sets. Based on GCC/Mips backend files.
|
2011-04-16 05:51:11 +08:00
|
|
|
//===----------------------------------------------------------------------===//
|
2007-08-18 09:46:44 +08:00
|
|
|
def ALU : FuncUnit;
|
|
|
|
def IMULDIV : FuncUnit;
|
|
|
|
|
2011-04-16 05:51:11 +08:00
|
|
|
//===----------------------------------------------------------------------===//
|
2011-03-05 01:51:39 +08:00
|
|
|
// Instruction Itinerary classes used for Mips
|
2011-04-16 05:51:11 +08:00
|
|
|
//===----------------------------------------------------------------------===//
|
2007-08-18 09:46:44 +08:00
|
|
|
def IIAlu : InstrItinClass;
|
|
|
|
def IILoad : InstrItinClass;
|
|
|
|
def IIStore : InstrItinClass;
|
|
|
|
def IIXfer : InstrItinClass;
|
|
|
|
def IIBranch : InstrItinClass;
|
|
|
|
def IIHiLo : InstrItinClass;
|
|
|
|
def IIImul : InstrItinClass;
|
|
|
|
def IIIdiv : InstrItinClass;
|
|
|
|
def IIFcvt : InstrItinClass;
|
|
|
|
def IIFmove : InstrItinClass;
|
|
|
|
def IIFcmp : InstrItinClass;
|
|
|
|
def IIFadd : InstrItinClass;
|
|
|
|
def IIFmulSingle : InstrItinClass;
|
|
|
|
def IIFmulDouble : InstrItinClass;
|
|
|
|
def IIFdivSingle : InstrItinClass;
|
|
|
|
def IIFdivDouble : InstrItinClass;
|
|
|
|
def IIFsqrtSingle : InstrItinClass;
|
|
|
|
def IIFsqrtDouble : InstrItinClass;
|
|
|
|
def IIFrecipFsqrtStep : InstrItinClass;
|
|
|
|
def IIPseudo : InstrItinClass;
|
|
|
|
|
2011-04-16 05:51:11 +08:00
|
|
|
//===----------------------------------------------------------------------===//
|
2007-08-18 09:46:44 +08:00
|
|
|
// Mips Generic instruction itineraries.
|
2011-04-16 05:51:11 +08:00
|
|
|
//===----------------------------------------------------------------------===//
|
2010-09-29 07:50:49 +08:00
|
|
|
def MipsGenericItineraries : ProcessorItineraries<[ALU, IMULDIV], [], [
|
2007-08-18 09:46:44 +08:00
|
|
|
InstrItinData<IIAlu , [InstrStage<1, [ALU]>]>,
|
|
|
|
InstrItinData<IILoad , [InstrStage<3, [ALU]>]>,
|
|
|
|
InstrItinData<IIStore , [InstrStage<1, [ALU]>]>,
|
|
|
|
InstrItinData<IIXfer , [InstrStage<2, [ALU]>]>,
|
|
|
|
InstrItinData<IIBranch , [InstrStage<1, [ALU]>]>,
|
|
|
|
InstrItinData<IIHiLo , [InstrStage<1, [IMULDIV]>]>,
|
|
|
|
InstrItinData<IIImul , [InstrStage<17, [IMULDIV]>]>,
|
|
|
|
InstrItinData<IIIdiv , [InstrStage<38, [IMULDIV]>]>,
|
|
|
|
InstrItinData<IIFcvt , [InstrStage<1, [ALU]>]>,
|
|
|
|
InstrItinData<IIFmove , [InstrStage<2, [ALU]>]>,
|
|
|
|
InstrItinData<IIFcmp , [InstrStage<3, [ALU]>]>,
|
|
|
|
InstrItinData<IIFadd , [InstrStage<4, [ALU]>]>,
|
|
|
|
InstrItinData<IIFmulSingle , [InstrStage<7, [ALU]>]>,
|
|
|
|
InstrItinData<IIFmulDouble , [InstrStage<8, [ALU]>]>,
|
|
|
|
InstrItinData<IIFdivSingle , [InstrStage<23, [ALU]>]>,
|
|
|
|
InstrItinData<IIFdivDouble , [InstrStage<36, [ALU]>]>,
|
|
|
|
InstrItinData<IIFsqrtSingle , [InstrStage<54, [ALU]>]>,
|
|
|
|
InstrItinData<IIFsqrtDouble , [InstrStage<12, [ALU]>]>,
|
|
|
|
InstrItinData<IIFrecipFsqrtStep , [InstrStage<5, [ALU]>]>
|
|
|
|
]>;
|