1 //===-- Latency.h -----------------------------------------------*- C++ -*-===//
3 // The LLVM Compiler Infrastructure
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
11 /// A BenchmarkRunner implementation to measure instruction latencies.
13 //===----------------------------------------------------------------------===//
15 #ifndef LLVM_TOOLS_LLVM_EXEGESIS_LATENCY_H
16 #define LLVM_TOOLS_LLVM_EXEGESIS_LATENCY_H
18 #include "BenchmarkRunner.h"
19 #include "MCInstrDescView.h"
20 #include "SnippetGenerator.h"
24 class LatencySnippetGenerator
: public SnippetGenerator
{
26 LatencySnippetGenerator(const LLVMState
&State
) : SnippetGenerator(State
) {}
27 ~LatencySnippetGenerator() override
;
29 llvm::Expected
<CodeTemplate
>
30 generateCodeTemplate(unsigned Opcode
) const override
;
33 llvm::Error
isInfeasible(const llvm::MCInstrDesc
&MCInstrDesc
) const;
35 llvm::Expected
<CodeTemplate
>
36 generateTwoInstructionPrototype(const Instruction
&Instr
) const;
39 class LatencyBenchmarkRunner
: public BenchmarkRunner
{
41 LatencyBenchmarkRunner(const LLVMState
&State
)
42 : BenchmarkRunner(State
, InstructionBenchmark::Latency
) {}
43 ~LatencyBenchmarkRunner() override
;
46 std::vector
<BenchmarkMeasure
>
47 runMeasurements(const ExecutableFunction
&EF
,
48 ScratchSpace
&Scratch
) const override
;
50 virtual const char *getCounterName() const;
52 } // namespace exegesis
54 #endif // LLVM_TOOLS_LLVM_EXEGESIS_LATENCY_H