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
<std::vector
<CodeTemplate
>>
30 generateCodeTemplates(const Instruction
&Instr
) const override
;
33 class LatencyBenchmarkRunner
: public BenchmarkRunner
{
35 LatencyBenchmarkRunner(const LLVMState
&State
)
36 : BenchmarkRunner(State
, InstructionBenchmark::Latency
) {}
37 ~LatencyBenchmarkRunner() override
;
40 std::vector
<BenchmarkMeasure
>
41 runMeasurements(const ExecutableFunction
&EF
,
42 ScratchSpace
&Scratch
) const override
;
44 virtual const char *getCounterName() const;
46 } // namespace exegesis
48 #endif // LLVM_TOOLS_LLVM_EXEGESIS_LATENCY_H