cpu: Move commit stats from simple to base cpu
Created stat group CommitCPUStats in BaseCPU and moved stats from the simple cpu model. The stats moved from SImpleCPU are numCondCtrlInsts, numFpInsts, numIntInsts, numLoadInsts, numStoreInsts, numVecInsts. Moved committedControl of MinorCPU to BaseCPU::CommittedCPUStats. In MinorCPU, this stat was a 2D vector, where the first dimension is the thread ID. In base it is now a 1D vector that is tied to a thread ID via the commitStats vector. The committedControl stat vector in CommitCPUStats is updated in the same way in all CPU models. The function updateComCtrlStats will update committedControl and the CPU models will call this function instead of updating committedControl directly. This function takes a StaticInstPtr as input, which Simple, Minor, and O3 CPU models are able to provide. Removed stat "branches" from O3 commit stage. This stat duplicates BaseCPU::CommittedCPUStats::committedControl::IsControl. O3 commit stats floating, integer, loads, memRefs, vectorInstructions are replaced by numFpInsts, numIntInsts, numLoadInsts, numMemRefs, numVecInsts from BaseCPU::CommitCPUStats respectively. Implemented numStoreInsts from BaseCPU::commitCPUStats for O3 commit stage. Change-Id: I362cec51513a404de56a02b450d7663327be20f5 Reviewed-on: https://gem5-review.googlesource.com/c/public/gem5/+/67391 Tested-by: kokoro <noreply+kokoro@google.com> Maintainer: Bobby Bruce <bbruce@ucdavis.edu> Reviewed-by: Bobby Bruce <bbruce@ucdavis.edu>
This commit is contained in:
committed by
Bobby Bruce
parent
fd2d80baa3
commit
e85cf4f717
@@ -160,21 +160,10 @@ Commit::CommitStats::CommitStats(CPU *cpu, Commit *commit)
|
||||
"Number of instructions committed"),
|
||||
ADD_STAT(opsCommitted, statistics::units::Count::get(),
|
||||
"Number of ops (including micro ops) committed"),
|
||||
ADD_STAT(memRefs, statistics::units::Count::get(),
|
||||
"Number of memory references committed"),
|
||||
ADD_STAT(loads, statistics::units::Count::get(), "Number of loads committed"),
|
||||
ADD_STAT(amos, statistics::units::Count::get(),
|
||||
"Number of atomic instructions committed"),
|
||||
ADD_STAT(membars, statistics::units::Count::get(),
|
||||
"Number of memory barriers committed"),
|
||||
ADD_STAT(branches, statistics::units::Count::get(),
|
||||
"Number of branches committed"),
|
||||
ADD_STAT(vectorInstructions, statistics::units::Count::get(),
|
||||
"Number of committed Vector instructions."),
|
||||
ADD_STAT(floating, statistics::units::Count::get(),
|
||||
"Number of committed floating point instructions."),
|
||||
ADD_STAT(integer, statistics::units::Count::get(),
|
||||
"Number of committed integer instructions."),
|
||||
ADD_STAT(functionCalls, statistics::units::Count::get(),
|
||||
"Number of function calls committed."),
|
||||
ADD_STAT(committedInstType, statistics::units::Count::get(),
|
||||
@@ -200,14 +189,6 @@ Commit::CommitStats::CommitStats(CPU *cpu, Commit *commit)
|
||||
.init(cpu->numThreads)
|
||||
.flags(total);
|
||||
|
||||
memRefs
|
||||
.init(cpu->numThreads)
|
||||
.flags(total);
|
||||
|
||||
loads
|
||||
.init(cpu->numThreads)
|
||||
.flags(total);
|
||||
|
||||
amos
|
||||
.init(cpu->numThreads)
|
||||
.flags(total);
|
||||
@@ -216,22 +197,6 @@ Commit::CommitStats::CommitStats(CPU *cpu, Commit *commit)
|
||||
.init(cpu->numThreads)
|
||||
.flags(total);
|
||||
|
||||
branches
|
||||
.init(cpu->numThreads)
|
||||
.flags(total);
|
||||
|
||||
vectorInstructions
|
||||
.init(cpu->numThreads)
|
||||
.flags(total);
|
||||
|
||||
floating
|
||||
.init(cpu->numThreads)
|
||||
.flags(total);
|
||||
|
||||
integer
|
||||
.init(cpu->numThreads)
|
||||
.flags(total);
|
||||
|
||||
functionCalls
|
||||
.init(commit->numThreads)
|
||||
.flags(total);
|
||||
@@ -1396,21 +1361,20 @@ Commit::updateComInstStats(const DynInstPtr &inst)
|
||||
//
|
||||
// Control Instructions
|
||||
//
|
||||
if (inst->isControl())
|
||||
stats.branches[tid]++;
|
||||
cpu->commitStats[tid]->updateComCtrlStats(inst->staticInst);
|
||||
|
||||
//
|
||||
// Memory references
|
||||
//
|
||||
if (inst->isMemRef()) {
|
||||
stats.memRefs[tid]++;
|
||||
cpu->commitStats[tid]->numMemRefs++;
|
||||
|
||||
if (inst->isLoad()) {
|
||||
stats.loads[tid]++;
|
||||
cpu->commitStats[tid]->numLoadInsts++;
|
||||
}
|
||||
|
||||
if (inst->isAtomic()) {
|
||||
stats.amos[tid]++;
|
||||
if (inst->isStore()) {
|
||||
cpu->commitStats[tid]->numStoreInsts++;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1420,14 +1384,14 @@ Commit::updateComInstStats(const DynInstPtr &inst)
|
||||
|
||||
// Integer Instruction
|
||||
if (inst->isInteger())
|
||||
stats.integer[tid]++;
|
||||
cpu->commitStats[tid]->numIntInsts++;
|
||||
|
||||
// Floating Point Instruction
|
||||
if (inst->isFloating())
|
||||
stats.floating[tid]++;
|
||||
cpu->commitStats[tid]->numFpInsts++;
|
||||
// Vector Instruction
|
||||
if (inst->isVector())
|
||||
stats.vectorInstructions[tid]++;
|
||||
cpu->commitStats[tid]->numVecInsts++;
|
||||
|
||||
// Function Calls
|
||||
if (inst->isCall())
|
||||
|
||||
Reference in New Issue
Block a user