Home
last modified time | relevance | path

Searched refs:ProcResource (Results 1 – 25 of 62) sorted by relevance

123

/openbsd-src/gnu/llvm/llvm/tools/llvm-mca/Views/
H A DResourcePressureView.cpp29 const MCProcResourceDesc &ProcResource = *SM.getProcResource(I); in ResourcePressureView() local
30 unsigned NumUnits = ProcResource.NumUnits; in ResourcePressureView()
32 if (ProcResource.SubUnitsIdxBegin || !NumUnits) in ResourcePressureView()
36 R2VIndex += ProcResource.NumUnits; in ResourcePressureView()
73 const MCProcResourceDesc &ProcResource = *SM.getProcResource(I); in printColumnNames() local
74 unsigned NumUnits = ProcResource.NumUnits; in printColumnNames()
76 if (ProcResource.SubUnitsIdxBegin || !NumUnits) in printColumnNames()
112 const MCProcResourceDesc &ProcResource = *SM.getProcResource(I); in printResourcePressurePerIter() local
113 unsigned NumUnits = ProcResource.NumUnits; in printResourcePressurePerIter()
115 if (ProcResource.SubUnitsIdxBegin || !NumUnits) in printResourcePressurePerIter()
[all …]
H A DSchedulerStatistics.cpp141 const MCProcResourceDesc &ProcResource = *SM.getProcResource(I); in printSchedulerUsage() local
142 if (ProcResource.BufferSize <= 0) in printSchedulerUsage()
147 double AlmostFullThreshold = (double)(ProcResource.BufferSize * 4) / 5; in printSchedulerUsage()
151 FOS << ProcResource.Name; in printSchedulerUsage()
160 BU.MaxUsedSlots == static_cast<unsigned>(ProcResource.BufferSize)) in printSchedulerUsage()
166 FOS << ProcResource.BufferSize << '\n'; in printSchedulerUsage()
/openbsd-src/gnu/llvm/llvm/lib/Target/AArch64/
H A DAArch64SchedFalkor.td39 def FalkorUnitB : ProcResource<1>; // Branch
40 def FalkorUnitLD : ProcResource<1>; // Load pipe
41 def FalkorUnitSD : ProcResource<1>; // Store data
42 def FalkorUnitST : ProcResource<1>; // Store pipe
43 def FalkorUnitX : ProcResource<1>; // Complex arithmetic
44 def FalkorUnitY : ProcResource<1>; // Simple arithmetic
45 def FalkorUnitZ : ProcResource<1>; // Simple arithmetic
47 def FalkorUnitVSD : ProcResource<1>; // Vector store data
48 def FalkorUnitVX : ProcResource<1>; // Vector X-pipe
49 def FalkorUnitVY : ProcResource<1>; // Vector Y-pipe
[all …]
H A DAArch64SchedExynosM5.td38 def M5UnitA : ProcResource<2>; // Simple integer
39 def M5UnitC : ProcResource<2>; // Simple and complex integer
41 def M5UnitD : ProcResource<1>; // Integer division (inside C0, serialized)
42 def M5UnitE : ProcResource<2>; // Simple 32-bit integer
44 def M5UnitF : ProcResource<2>; // CRC (inside C)
45 def M5UnitB : ProcResource<1>; // Branch
46 def M5UnitL0 : ProcResource<1>; // Load
47 def M5UnitS0 : ProcResource<1>; // Store
48 def M5PipeLS : ProcResource<1>; // Load/Store
50 def M5UnitL1 : ProcResource<1>;
[all …]
H A DAArch64SchedExynosM3.td39 def M3UnitA : ProcResource<2>; // Simple integer
40 def M3UnitC : ProcResource<2>; // Simple and complex integer
41 def M3UnitD : ProcResource<1>; // Integer division (inside C0, serialized)
42 def M3UnitB : ProcResource<2>; // Branch
43 def M3UnitL : ProcResource<2>; // Load
44 def M3UnitS : ProcResource<1>; // Store
45 def M3PipeF0 : ProcResource<1>; // FP #0
47 def M3UnitFMAC0 : ProcResource<1>; // FP multiplication
48 def M3UnitFADD0 : ProcResource<1>; // Simple FP
49 def M3UnitFCVT0 : ProcResource<1>; // FP conversion
[all …]
H A DAArch64SchedExynosM4.td38 def M4UnitA : ProcResource<2>; // Simple integer
39 def M4UnitC : ProcResource<2>; // Simple and complex integer
41 def M4UnitD : ProcResource<1>; // Integer division (inside C0, serialized)
43 def M4UnitE : ProcResource<1>; // CRC (inside C0)
44 def M4UnitB : ProcResource<2>; // Branch
45 def M4UnitL0 : ProcResource<1>; // Load
46 def M4UnitS0 : ProcResource<1>; // Store
47 def M4PipeLS : ProcResource<1>; // Load/Store
49 def M4UnitL1 : ProcResource<1>;
50 def M4UnitS1 : ProcResource<1>;
[all …]
H A DAArch64SchedKryo.td42 def KryoUnitXA : ProcResource<1>; // Type X(A) micro-ops
43 def KryoUnitXB : ProcResource<1>; // Type X(B) micro-ops
44 def KryoUnitYA : ProcResource<1>; // Type Y(A) micro-ops
45 def KryoUnitYB : ProcResource<1>; // Type Y(B) micro-ops
54 def KryoUnitLSA : ProcResource<1>; // Type LS(A) micro-ops
55 def KryoUnitLSB : ProcResource<1>; // Type LS(B) micro-ops
H A DAArch64SchedA53.td39 // Modeling each pipeline as a ProcResource using the BufferSize = 0 since
42 def A53UnitALU : ProcResource<2> { let BufferSize = 0; } // Int ALU
43 def A53UnitMAC : ProcResource<1> { let BufferSize = 0; } // Int MAC
44 def A53UnitDiv : ProcResource<1> { let BufferSize = 0; } // Int Division
45 def A53UnitLdSt : ProcResource<1> { let BufferSize = 0; } // Load/Store
46 def A53UnitB : ProcResource<1> { let BufferSize = 0; } // Branch
47 def A53UnitFPALU : ProcResource<1> { let BufferSize = 0; } // FP ALU
48 def A53UnitFPMDS : ProcResource<1> { let BufferSize = 0; } // FP Mult/Div/Sqrt
H A DAArch64SchedThunderX.td37 def THXT8XUnitALU : ProcResource<2> { let BufferSize = 0; } // Int ALU
38 def THXT8XUnitMAC : ProcResource<1> { let BufferSize = 0; } // Int MAC
39 def THXT8XUnitDiv : ProcResource<1> { let BufferSize = 0; } // Int Division
40 def THXT8XUnitLdSt : ProcResource<1> { let BufferSize = 0; } // Load/Store
41 def THXT8XUnitBr : ProcResource<1> { let BufferSize = 0; } // Branch
42 def THXT8XUnitFPALU : ProcResource<1> { let BufferSize = 0; } // FP ALU
43 def THXT8XUnitFPMDS : ProcResource<1> { let BufferSize = 0; } // FP Mul/Div/Sqrt
H A DAArch64SchedCyclone.td31 def CyUnitI : ProcResource<4> {
36 def CyUnitB : ProcResource<2> {
42 def CyUnitBR : ProcResource<1> {
48 def CyUnitIS : ProcResource<2> {
54 def CyUnitIM : ProcResource<1> {
60 def CyUnitID : ProcResource<1> {
67 def CyUnitIntDiv : ProcResource<1>;
70 def CyUnitLS : ProcResource<2> {
75 def CyUnitV : ProcResource<3> {
79 def CyUnitVM : ProcResource<2> {
[all …]
/openbsd-src/gnu/llvm/llvm/lib/Target/PowerPC/
H A DPPCScheduleP9.td56 def DISPx02 : ProcResource<2>;
57 def DISPx13 : ProcResource<2>;
60 def DISPxab : ProcResource<2>;
62 def DISPb01 : ProcResource<2>;
76 def IP_AGEN : ProcResource<4>;
77 def IP_EXEC : ProcResource<4>;
78 def IP_EXECE : ProcResource<2> {
82 def IP_EXECO : ProcResource<2> {
89 def ALU : ProcResource<4>;
90 def ALUE : ProcResource<2> {
[all …]
H A DPPCScheduleP10.td48 def P10_BF : ProcResource<4>; // Four Binary Floating Point pipelines.
49 def P10_BR : ProcResource<2>; // Two Branch pipelines.
50 def P10_CY : ProcResource<4>; // Four Crypto pipelines.
51 def P10_DF : ProcResource<1>; // One Decimal Floating Point pipelines.
52 def P10_DV : ProcResource<2>; // Two Fixed-point divide (DIV) pipelines.
53 def P10_DX : ProcResource<2>; // Two 128-bit fixed-point and BCD pipelines.
54 def P10_FX : ProcResource<4>; // Four ALU pipelines.
55 def P10_LD : ProcResource<2>; // Two Load pipelines.
56 def P10_MM : ProcResource<2>; // Two 512-bit SIMD matrix multiply engine pipelines.
57 def P10_PM : ProcResource<4>; // Four 128-bit permute (PM) pipelines.
[all …]
/openbsd-src/gnu/llvm/llvm/lib/MCA/Stages/
H A DInstructionTables.cpp34 const MCProcResourceDesc &ProcResource = *SM.getProcResource(Index); in execute() local
35 unsigned NumUnits = ProcResource.NumUnits; in execute()
36 if (!ProcResource.SubUnitsIdxBegin) { in execute()
50 unsigned SubUnitIdx = ProcResource.SubUnitsIdxBegin[I1]; in execute()
/openbsd-src/gnu/llvm/llvm/tools/llvm-mca/
H A DPipelinePrinter.cpp86 const MCProcResourceDesc &ProcResource = *SM.getProcResource(I); in getJSONTargetInfo() local
87 unsigned NumUnits = ProcResource.NumUnits; in getJSONTargetInfo()
88 if (ProcResource.SubUnitsIdxBegin || !NumUnits) in getJSONTargetInfo()
92 std::string ResourceName = ProcResource.Name; in getJSONTargetInfo()
/openbsd-src/gnu/llvm/llvm/lib/Target/RISCV/
H A DRISCVSchedRocket.td29 // Modeling each pipeline as a ProcResource using the BufferSize = 0 since
33 def RocketUnitALU : ProcResource<1>; // Int ALU
34 def RocketUnitIMul : ProcResource<1>; // Int Multiply
35 def RocketUnitMem : ProcResource<1>; // Load/Store
36 def RocketUnitB : ProcResource<1>; // Branch
38 def RocketUnitFPALU : ProcResource<1>; // FP ALU
42 def RocketUnitIDiv : ProcResource<1>; // Int Division
43 def RocketUnitFPDivSqrt : ProcResource<1>; // FP Divide/Sqrt
H A DRISCVSchedSyntacoreSCR1.td33 def SCR1_ALU : ProcResource<1>;
34 def SCR1_LSU : ProcResource<1>;
35 def SCR1_MUL : ProcResource<1>;
36 def SCR1_DIV : ProcResource<1>;
37 def SCR1_CFU : ProcResource<1>;
H A DRISCVSchedSiFive7.td30 def SiFive7PipeA : ProcResource<1>;
31 def SiFive7PipeB : ProcResource<1>;
35 def SiFive7IDiv : ProcResource<1> { let Super = SiFive7PipeB; } // Int Division
36 def SiFive7FDiv : ProcResource<1> { let Super = SiFive7PipeB; } // FP Division/Sqrt
/openbsd-src/gnu/llvm/llvm/lib/Target/AMDGPU/
H A DSISchedule.td95 def HWBranch : ProcResource<1> {
98 def HWExport : ProcResource<1> {
101 def HWLGKM : ProcResource<1> {
104 def HWSALU : ProcResource<1> {
107 def HWVMEM : ProcResource<1> {
110 def HWVALU : ProcResource<1> {
113 def HWTransVALU : ProcResource<1> { // Transcendental VALU
116 def HWRC : ProcResource<1> { // Register destination cache
119 def HWXDL : ProcResource<1> { // MFMA CU
/openbsd-src/gnu/llvm/llvm/include/llvm/Target/
H A DTargetPfmCounters.td21 // Issue counters can be tied to a ProcResource
24 // The name of the ProcResource on which uops are issued. This is used by
27 // ProcResource.
/openbsd-src/gnu/llvm/llvm/lib/Target/ARM/
H A DARMScheduleM7.td38 def M7UnitLoadL : ProcResource<1> { let BufferSize = 0; }
39 def M7UnitLoadH : ProcResource<1> { let BufferSize = 0; }
41 def M7UnitStore : ProcResource<1> { let BufferSize = 0; }
42 def M7UnitALU : ProcResource<2>;
43 def M7UnitShift1 : ProcResource<1> { let BufferSize = 0; }
44 def M7UnitShift2 : ProcResource<1> { let BufferSize = 0; }
45 def M7UnitMAC : ProcResource<1> { let BufferSize = 0; }
46 def M7UnitBranch : ProcResource<1> { let BufferSize = 0; }
47 def M7UnitVFP : ProcResource<1> { let BufferSize = 0; }
48 def M7UnitVPortL : ProcResource<1> { let BufferSize = 0; }
[all …]
/openbsd-src/gnu/llvm/llvm/lib/Target/Mips/
H A DMipsScheduleP5600.td32 def P5600ALQ : ProcResource<1> { let BufferSize = 16; }
33 def P5600IssueALU : ProcResource<1> { let Super = P5600ALQ; }
47 def P5600AGQ : ProcResource<3> { let BufferSize = 16; }
48 def P5600IssueAL2 : ProcResource<1> { let Super = P5600AGQ; }
49 def P5600IssueCTISTD : ProcResource<1> { let Super = P5600AGQ; }
50 def P5600IssueLDST : ProcResource<1> { let Super = P5600AGQ; }
52 def P5600AL2Div : ProcResource<1>;
54 def P5600CTISTD : ProcResource<1>;
231 def P5600FPQ : ProcResource<3> { let BufferSize = 16; }
232 def P5600IssueFPUS : ProcResource<1> { let Super = P5600FPQ; }
[all …]
/openbsd-src/gnu/llvm/llvm/lib/Target/Lanai/
H A DLanaiSchedule.td54 def ALU : ProcResource<1> { let BufferSize = 0; }
55 def LdSt : ProcResource<1> { let BufferSize = 0; }
/openbsd-src/gnu/llvm/llvm/lib/Target/X86/
H A DX86ScheduleBdVer2.td50 def PdEX0 : ProcResource<1>; // ALU, Integer Pipe0
51 def PdEX1 : ProcResource<1>; // ALU, Integer Pipe1
55 def PdAGLU01 : ProcResource<2>; // AGU, Integer Pipe[23]
63 def PdFPU0 : ProcResource<1>; // Vector/FPU Pipe0
64 def PdFPU1 : ProcResource<1>; // Vector/FPU Pipe1
65 def PdFPU2 : ProcResource<1>; // Vector/FPU Pipe2
66 def PdFPU3 : ProcResource<1>; // Vector/FPU Pipe3
133 def PdLoad : ProcResource<2> {
141 def PdStore : ProcResource<1> {
152 def PdDiv : ProcResource<1>; // PdEX0; unpipelined integer division
[all …]
H A DX86ScheduleSLM.td34 def SLM_IEC_RSV0 : ProcResource<1>;
35 def SLM_IEC_RSV1 : ProcResource<1>;
36 def SLM_FPC_RSV0 : ProcResource<1> { let BufferSize = 1; }
37 def SLM_FPC_RSV1 : ProcResource<1> { let BufferSize = 1; }
38 def SLM_MEC_RSV : ProcResource<1>;
44 def SLMDivider : ProcResource<1>;
45 def SLMFPMultiplier : ProcResource<1>;
46 def SLMFPDivider : ProcResource<1>;
H A DX86ScheduleBtVer2.td33 def JALU0 : ProcResource<1>; // Integer Pipe0: integer ALU0 (also handle FP->INT jam)
34 def JALU1 : ProcResource<1>; // Integer Pipe1: integer ALU1/MUL/DIV
35 def JLAGU : ProcResource<1>; // Integer Pipe2: LAGU
36 def JSAGU : ProcResource<1>; // Integer Pipe3: SAGU (also handles 3-operand LEA)
37 def JFPU0 : ProcResource<1>; // Vector/FPU Pipe0: VALU0/VIMUL/FPA
38 def JFPU1 : ProcResource<1>; // Vector/FPU Pipe1: VALU1/STC/FPM
88 def JDiv : ProcResource<1>; // integer division
89 def JMul : ProcResource<1>; // integer multiplication
90 def JVALU0 : ProcResource<1>; // vector integer
91 def JVALU1 : ProcResource<1>; // vector integer
[all …]

123