//===-- SparcSchedule.td - Describe the Sparc Itineries ----*- tablegen -*-===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// // // //===----------------------------------------------------------------------===// def IIC_iu_or_fpu_instr : InstrItinClass; def IIC_iu_instr : InstrItinClass; def IIC_fpu_normal_instr : InstrItinClass; def IIC_fpu_fast_instr : InstrItinClass; def IIC_jmp_or_call : InstrItinClass; def IIC_ldd : InstrItinClass; def IIC_st : InstrItinClass; def IIC_std : InstrItinClass; def IIC_iu_smul : InstrItinClass; def IIC_iu_umul : InstrItinClass; def IIC_iu_div : InstrItinClass; def IIC_ticc : InstrItinClass; def IIC_ldstub : InstrItinClass; def IIC_fpu_muls : InstrItinClass; def IIC_fpu_muld : InstrItinClass; def IIC_fpu_divs : InstrItinClass; def IIC_fpu_divd : InstrItinClass; def IIC_fpu_sqrts : InstrItinClass; def IIC_fpu_sqrtd : InstrItinClass; def IIC_fpu_abs : InstrItinClass; def IIC_fpu_movs : InstrItinClass; def IIC_fpu_negs : InstrItinClass; def IIC_smac_umac : InstrItinClass; def IIC_fpu_stod : InstrItinClass; def LEONIU : FuncUnit; // integer unit def LEONFPU : FuncUnit; // floating-point unit // Ref: http://www.atmel.com/Images/doc4226.pdf def LEON2Itineraries : ProcessorItineraries< [LEONIU, LEONFPU], [], [ InstrItinData], [1, 1]>, InstrItinData], [1, 1]>, InstrItinData], [7, 1]>, InstrItinData], [7, 1]>, InstrItinData], [2, 1]>, InstrItinData], [2, 1]>, InstrItinData], [2, 1]>, InstrItinData], [3, 1]>, InstrItinData], [5, 1]>, InstrItinData], [5, 1]>, InstrItinData], [35, 1]>, InstrItinData], [4, 1]>, InstrItinData], [3, 1]>, InstrItinData], [16, 1]>, InstrItinData], [21, 1]>, InstrItinData], [20, 1]>, InstrItinData], [36, 1]>, InstrItinData], [37, 1]>, InstrItinData], [65, 1]>, InstrItinData], [2, 1]>, InstrItinData], [2, 1]>, InstrItinData], [2, 1]>, InstrItinData], [2, 1]> ]>; def LEON3Itineraries : ProcessorItineraries< [LEONIU, LEONFPU], [], [ InstrItinData], [1, 1]>, InstrItinData], [1, 1]>, InstrItinData], [7, 1]>, InstrItinData], [4, 1]>, InstrItinData], [3, 1]>, InstrItinData], [2, 1]>, InstrItinData], [4, 1]>, InstrItinData], [5, 1]>, InstrItinData], [1, 1]>, InstrItinData], [4, 1]>, InstrItinData], [35, 1]>, InstrItinData], [2, 1]>, InstrItinData], [5, 1]>, InstrItinData], [3, 1]>, InstrItinData], [4, 1]>, InstrItinData], [4, 1]>, InstrItinData], [16, 1]>, InstrItinData], [17, 1]>, InstrItinData], [24, 1]>, InstrItinData], [25, 1]>, InstrItinData], [2, 1]>, InstrItinData], [2, 1]>, InstrItinData], [2, 1]>, InstrItinData], [4, 1]> ]>; def LEON4Itineraries : ProcessorItineraries< [LEONIU, LEONFPU], [], [ InstrItinData], [1, 1]>, InstrItinData], [1, 1]>, InstrItinData], [7, 1]>, InstrItinData], [4, 1]>, InstrItinData], [3, 1]>, InstrItinData], [1, 1]>, InstrItinData], [1, 1]>, InstrItinData], [1, 1]>, InstrItinData], [1, 1]>, InstrItinData], [4, 1]>, InstrItinData], [35, 1]>, InstrItinData], [2, 1]>, InstrItinData], [5, 1]>, InstrItinData], [3, 1]>, InstrItinData], [4, 1]>, InstrItinData], [4, 1]>, InstrItinData], [16, 1]>, InstrItinData], [17, 1]>, InstrItinData], [24, 1]>, InstrItinData], [25, 1]>, InstrItinData], [2, 1]>, InstrItinData], [2, 1]>, InstrItinData], [2, 1]>, InstrItinData], [4, 1]> ]>;