2018-04-11 19:37:46 +08:00
|
|
|
//===--------------------- SchedulerStatistics.h ----------------*- C++ -*-===//
|
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
/// \file
|
|
|
|
///
|
|
|
|
/// This file defines class SchedulerStatistics. Class SchedulerStatistics is a
|
|
|
|
/// View that listens to instruction issue events in order to print general
|
|
|
|
/// statistics related to the hardware schedulers.
|
|
|
|
///
|
|
|
|
/// Example:
|
|
|
|
/// ========
|
|
|
|
///
|
|
|
|
/// Schedulers - number of cycles where we saw N instructions issued:
|
|
|
|
/// [# issued], [# cycles]
|
|
|
|
/// 0, 7 (5.4%)
|
|
|
|
/// 1, 4 (3.1%)
|
|
|
|
/// 2, 8 (6.2%)
|
|
|
|
///
|
|
|
|
/// Scheduler's queue usage:
|
|
|
|
/// JALU01, 0/20
|
|
|
|
/// JFPU01, 18/18
|
|
|
|
/// JLSAGU, 0/12
|
|
|
|
///
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#ifndef LLVM_TOOLS_LLVM_MCA_SCHEDULERSTATISTICS_H
|
|
|
|
#define LLVM_TOOLS_LLVM_MCA_SCHEDULERSTATISTICS_H
|
|
|
|
|
|
|
|
#include "View.h"
|
|
|
|
#include "llvm/ADT/SmallVector.h"
|
|
|
|
#include "llvm/ADT/DenseMap.h"
|
|
|
|
#include "llvm/MC/MCSubtargetInfo.h"
|
|
|
|
|
|
|
|
namespace mca {
|
|
|
|
|
|
|
|
class SchedulerStatistics : public View {
|
2018-04-11 20:31:44 +08:00
|
|
|
const llvm::MCSchedModel &SM;
|
2018-04-11 19:37:46 +08:00
|
|
|
|
|
|
|
using Histogram = llvm::DenseMap<unsigned, unsigned>;
|
|
|
|
Histogram IssuedPerCycle;
|
|
|
|
|
|
|
|
unsigned NumIssued;
|
|
|
|
unsigned NumCycles;
|
|
|
|
|
|
|
|
// Tracks the usage of a scheduler's queue.
|
|
|
|
struct BufferUsage {
|
|
|
|
unsigned SlotsInUse;
|
|
|
|
unsigned MaxUsedSlots;
|
|
|
|
};
|
|
|
|
|
|
|
|
llvm::DenseMap<unsigned, BufferUsage> BufferedResources;
|
|
|
|
|
|
|
|
void updateHistograms() {
|
|
|
|
IssuedPerCycle[NumIssued]++;
|
|
|
|
NumIssued = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void printSchedulerStatistics(llvm::raw_ostream &OS) const;
|
2018-04-11 20:31:44 +08:00
|
|
|
void printSchedulerUsage(llvm::raw_ostream &OS) const;
|
2018-04-11 19:37:46 +08:00
|
|
|
|
|
|
|
public:
|
2018-04-11 20:31:44 +08:00
|
|
|
SchedulerStatistics(const llvm::MCSubtargetInfo &STI)
|
|
|
|
: SM(STI.getSchedModel()), NumIssued(0), NumCycles(0) { }
|
2018-04-11 19:37:46 +08:00
|
|
|
|
|
|
|
void onInstructionEvent(const HWInstructionEvent &Event) override;
|
|
|
|
|
2018-04-12 18:49:40 +08:00
|
|
|
void onCycleBegin() override { NumCycles++; }
|
2018-04-11 19:37:46 +08:00
|
|
|
|
2018-04-12 18:49:40 +08:00
|
|
|
void onCycleEnd() override { updateHistograms(); }
|
2018-04-11 19:37:46 +08:00
|
|
|
|
|
|
|
// Increases the number of used scheduler queue slots of every buffered
|
|
|
|
// resource in the Buffers set.
|
|
|
|
void onReservedBuffers(llvm::ArrayRef<unsigned> Buffers) override;
|
|
|
|
|
|
|
|
// Decreases by one the number of used scheduler queue slots of every
|
|
|
|
// buffered resource in the Buffers set.
|
|
|
|
void onReleasedBuffers(llvm::ArrayRef<unsigned> Buffers) override;
|
|
|
|
|
|
|
|
void printView(llvm::raw_ostream &OS) const override {
|
|
|
|
printSchedulerStatistics(OS);
|
2018-04-11 20:31:44 +08:00
|
|
|
printSchedulerUsage(OS);
|
2018-04-11 19:37:46 +08:00
|
|
|
}
|
|
|
|
};
|
|
|
|
} // namespace mca
|
|
|
|
|
|
|
|
#endif
|