1 //=-HexagonScheduleV4.td - HexagonV4 Scheduling Definitions --*- tablegen -*-=// 2 // 3 // The LLVM Compiler Infrastructure 4 // 5 // This file is distributed under the University of Illinois Open Source 6 // License. See LICENSE.TXT for details. 7 // 8 //===----------------------------------------------------------------------===// 9 10 // There are four SLOTS (four parallel pipelines) in Hexagon V4 machine. 11 // This file describes that machine information. 12 13 // 14 // |===========|==================================================| 15 // | PIPELINE | Instruction Classes | 16 // |===========|==================================================| 17 // | SLOT0 | LD ST ALU32 MEMOP NV SYSTEM | 18 // |-----------|--------------------------------------------------| 19 // | SLOT1 | LD ST ALU32 | 20 // |-----------|--------------------------------------------------| 21 // | SLOT2 | XTYPE ALU32 J JR | 22 // |-----------|--------------------------------------------------| 23 // | SLOT3 | XTYPE ALU32 J CR | 24 // |===========|==================================================| 25 26 def CJ_tc_1_SLOT23 : InstrItinClass; 27 def CJ_tc_2early_SLOT23 : InstrItinClass; 28 def COPROC_VMEM_vtc_long_SLOT01 : InstrItinClass; 29 def COPROC_VX_vtc_long_SLOT23 : InstrItinClass; 30 def COPROC_VX_vtc_SLOT23 : InstrItinClass; 31 def J_tc_3stall_SLOT2 : InstrItinClass; 32 def MAPPING_tc_1_SLOT0123 : InstrItinClass; 33 def M_tc_3stall_SLOT23 : InstrItinClass; 34 def SUBINSN_tc_1_SLOT01 : InstrItinClass; 35 def SUBINSN_tc_2early_SLOT0 : InstrItinClass; 36 def SUBINSN_tc_2early_SLOT01 : InstrItinClass; 37 def SUBINSN_tc_3stall_SLOT0 : InstrItinClass; 38 def SUBINSN_tc_ld_SLOT0 : InstrItinClass; 39 def SUBINSN_tc_ld_SLOT01 : InstrItinClass; 40 def SUBINSN_tc_st_SLOT01 : InstrItinClass; 41 42 def HexagonItinerariesV55 : 43 ProcessorItineraries<[SLOT0, SLOT1, SLOT2, SLOT3, SLOT_ENDLOOP], [], [ 44 // ALU32 45 InstrItinData<ALU32_2op_tc_1_SLOT0123 , 46 [InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>]>, 47 InstrItinData<ALU32_2op_tc_2early_SLOT0123, 48 [InstrStage<2, [SLOT0, SLOT1, SLOT2, SLOT3]>]>, 49 InstrItinData<ALU32_3op_tc_1_SLOT0123 , 50 [InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>]>, 51 InstrItinData<ALU32_3op_tc_2_SLOT0123 , 52 [InstrStage<2, [SLOT0, SLOT1, SLOT2, SLOT3]>]>, 53 InstrItinData<ALU32_3op_tc_2early_SLOT0123, 54 [InstrStage<2, [SLOT0, SLOT1, SLOT2, SLOT3]>]>, 55 InstrItinData<ALU32_ADDI_tc_1_SLOT0123 , 56 [InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>]>, 57 58 // ALU64 59 InstrItinData<ALU64_tc_1_SLOT23 , [InstrStage<1, [SLOT2, SLOT3]>]>, 60 InstrItinData<ALU64_tc_2_SLOT23 , [InstrStage<2, [SLOT2, SLOT3]>]>, 61 InstrItinData<ALU64_tc_2early_SLOT23, [InstrStage<2, [SLOT2, SLOT3]>]>, 62 InstrItinData<ALU64_tc_3x_SLOT23 , [InstrStage<3, [SLOT2, SLOT3]>]>, 63 64 // CR -> System 65 InstrItinData<CR_tc_2_SLOT3 , [InstrStage<2, [SLOT3]>]>, 66 InstrItinData<CR_tc_2early_SLOT3 , [InstrStage<2, [SLOT3]>]>, 67 InstrItinData<CR_tc_3x_SLOT3 , [InstrStage<3, [SLOT3]>]>, 68 69 // Jump (conditional/unconditional/return etc) 70 InstrItinData<CR_tc_2early_SLOT23, [InstrStage<2, [SLOT2, SLOT3]>]>, 71 InstrItinData<CR_tc_3x_SLOT23 , [InstrStage<3, [SLOT2, SLOT3]>]>, 72 InstrItinData<CJ_tc_1_SLOT23 , [InstrStage<1, [SLOT2, SLOT3]>]>, 73 InstrItinData<CJ_tc_2early_SLOT23, [InstrStage<2, [SLOT2, SLOT3]>]>, 74 InstrItinData<J_tc_2early_SLOT23 , [InstrStage<2, [SLOT2, SLOT3]>]>, 75 InstrItinData<J_tc_2early_CJUMP_UCJUMP_ARCHDEPSLOT , [InstrStage<1, [SLOT2, SLOT3]>]>, 76 77 // JR 78 InstrItinData<J_tc_2early_SLOT2 , [InstrStage<2, [SLOT2]>]>, 79 InstrItinData<J_tc_3stall_SLOT2 , [InstrStage<3, [SLOT2]>]>, 80 81 // Extender 82 InstrItinData<EXTENDER_tc_1_SLOT0123, 83 [InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>]>, 84 85 // Load 86 InstrItinData<LD_tc_ld_SLOT01 , [InstrStage<3, [SLOT0, SLOT1]>]>, 87 InstrItinData<LD_tc_3or4stall_SLOT0, [InstrStage<3, [SLOT0]>]>, 88 InstrItinData<LD_tc_ld_SLOT0 , [InstrStage<3, [SLOT0]>]>, 89 90 // M 91 InstrItinData<M_tc_1_SLOT23 , [InstrStage<1, [SLOT2, SLOT3]>]>, 92 InstrItinData<M_tc_2_SLOT23 , [InstrStage<2, [SLOT2, SLOT3]>]>, 93 InstrItinData<M_tc_3_SLOT23 , [InstrStage<3, [SLOT2, SLOT3]>]>, 94 InstrItinData<M_tc_3x_SLOT23 , [InstrStage<3, [SLOT2, SLOT3]>]>, 95 InstrItinData<M_tc_3or4x_SLOT23 , [InstrStage<3, [SLOT2, SLOT3]>]>, 96 InstrItinData<M_tc_3stall_SLOT23, [InstrStage<3, [SLOT2, SLOT3]>]>, 97 98 // Store 99 InstrItinData<ST_tc_st_SLOT01 , [InstrStage<1, [SLOT0, SLOT1]>]>, 100 InstrItinData<ST_tc_3stall_SLOT0, [InstrStage<3, [SLOT0]>]>, 101 InstrItinData<ST_tc_ld_SLOT0 , [InstrStage<3, [SLOT0]>]>, 102 InstrItinData<ST_tc_st_SLOT0 , [InstrStage<1, [SLOT0]>]>, 103 104 // Subinsn 105 InstrItinData<SUBINSN_tc_2early_SLOT0, [InstrStage<2, [SLOT0]>]>, 106 InstrItinData<SUBINSN_tc_3stall_SLOT0, [InstrStage<3, [SLOT0]>]>, 107 InstrItinData<SUBINSN_tc_ld_SLOT0 , [InstrStage<3, [SLOT0]>]>, 108 InstrItinData<SUBINSN_tc_1_SLOT01 , [InstrStage<1, [SLOT0, SLOT1]>]>, 109 InstrItinData<SUBINSN_tc_2early_SLOT01, 110 [InstrStage<2, [SLOT0, SLOT1]>]>, 111 InstrItinData<SUBINSN_tc_ld_SLOT01 , [InstrStage<3, [SLOT0, SLOT1]>]>, 112 InstrItinData<SUBINSN_tc_st_SLOT01 , [InstrStage<1, [SLOT0, SLOT1]>]>, 113 114 // S 115 InstrItinData<S_2op_tc_1_SLOT23 , [InstrStage<1, [SLOT2, SLOT3]>]>, 116 InstrItinData<S_2op_tc_2_SLOT23 , [InstrStage<2, [SLOT2, SLOT3]>]>, 117 InstrItinData<S_2op_tc_2early_SLOT23, [InstrStage<2, [SLOT2, SLOT3]>]>, 118 InstrItinData<S_2op_tc_3or4x_SLOT23 , [InstrStage<3, [SLOT2, SLOT3]>]>, 119 InstrItinData<S_3op_tc_1_SLOT23 , [InstrStage<1, [SLOT2, SLOT3]>]>, 120 InstrItinData<S_3op_tc_2_SLOT23 , [InstrStage<2, [SLOT2, SLOT3]>]>, 121 InstrItinData<S_3op_tc_2early_SLOT23, [InstrStage<2, [SLOT2, SLOT3]>]>, 122 InstrItinData<S_3op_tc_3_SLOT23 , [InstrStage<3, [SLOT2, SLOT3]>]>, 123 InstrItinData<S_3op_tc_3stall_SLOT23, [InstrStage<3, [SLOT2, SLOT3]>]>, 124 InstrItinData<S_3op_tc_3x_SLOT23 , [InstrStage<3, [SLOT2, SLOT3]>]>, 125 126 // New Value Compare Jump 127 InstrItinData<NCJ_tc_3or4stall_SLOT0, [InstrStage<3, [SLOT0]>]>, 128 129 // Mem ops 130 InstrItinData<V2LDST_tc_st_SLOT0 , [InstrStage<1, [SLOT0]>]>, 131 InstrItinData<V2LDST_tc_ld_SLOT01 , [InstrStage<2, [SLOT0, SLOT1]>]>, 132 InstrItinData<V2LDST_tc_st_SLOT01 , [InstrStage<1, [SLOT0, SLOT1]>]>, 133 InstrItinData<V4LDST_tc_st_SLOT0 , [InstrStage<1, [SLOT0]>]>, 134 InstrItinData<V4LDST_tc_ld_SLOT01 , [InstrStage<3, [SLOT0, SLOT1]>]>, 135 InstrItinData<V4LDST_tc_st_SLOT01 , [InstrStage<1, [SLOT0, SLOT1]>]>, 136 137 // Endloop 138 InstrItinData<J_tc_2early_SLOT0123, [InstrStage<2, [SLOT_ENDLOOP]>]>, 139 140 // Vector 141 InstrItinData<COPROC_VMEM_vtc_long_SLOT01, 142 [InstrStage<3, [SLOT0, SLOT1]>]>, 143 InstrItinData<COPROC_VX_vtc_long_SLOT23 , 144 [InstrStage<3, [SLOT2, SLOT3]>]>, 145 InstrItinData<COPROC_VX_vtc_SLOT23 , 146 [InstrStage<3, [SLOT2, SLOT3]>]>, 147 InstrItinData<MAPPING_tc_1_SLOT0123 , 148 [InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>]>, 149 150 // Misc 151 InstrItinData<COMPOUND_CJ_ARCHDEPSLOT , [InstrStage<1, [SLOT2, SLOT3]>]>, 152 InstrItinData<COMPOUND , [InstrStage<1, [SLOT2, SLOT3]>]>, 153 InstrItinData<DUPLEX , [InstrStage<1, [SLOT0]>]>, 154 InstrItinData<PREFIX , [InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>]>, 155 InstrItinData<PSEUDO , [InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>]>, 156 InstrItinData<PSEUDOM, [InstrStage<1, [SLOT2, SLOT3], 0>, 157 InstrStage<1, [SLOT2, SLOT3]>]> 158 159 ]>; 160 161 def HexagonModelV55 : SchedMachineModel { 162 // Max issue per cycle == bundle width. 163 let IssueWidth = 4; 164 let Itineraries = HexagonItinerariesV55; 165 let LoadLatency = 1; 166 let CompleteModel = 0; 167 } 168 169 //===----------------------------------------------------------------------===// 170 // Hexagon V4 Resource Definitions - 171 //===----------------------------------------------------------------------===// 172