diff options
-rw-r--r-- | src/sim/power/PowerModel.py | 8 | ||||
-rw-r--r-- | src/sim/power/power_model.cc | 13 | ||||
-rw-r--r-- | src/sim/power/power_model.hh | 6 |
3 files changed, 23 insertions, 4 deletions
diff --git a/src/sim/power/PowerModel.py b/src/sim/power/PowerModel.py index ecb45b442..342569013 100644 --- a/src/sim/power/PowerModel.py +++ b/src/sim/power/PowerModel.py @@ -1,4 +1,4 @@ -# Copyright (c) 2016 ARM Limited +# Copyright (c) 2016-2018 ARM Limited # All rights reserved. # # The license below extends only to copyright in the software and shall @@ -39,6 +39,9 @@ from m5.SimObject import * from m5.params import * from m5.proxy import Parent +# Enum for a type of power model +class PMType(Enum) : vals = ['All', 'Static', 'Dynamic'] + # Represents a power model for a simobj # The model itself is also a SimObject so we can make use some # nice features available such as Parent.any @@ -57,3 +60,6 @@ class PowerModel(SimObject): # Need a reference to the system so we can query the thermal domain # about temperature (temperature is needed for leakage calculation) subsystem = Param.SubSystem(Parent.any, "subsystem") + + # Type of power model + pm_type = Param.PMType("All", "Type of power model") diff --git a/src/sim/power/power_model.cc b/src/sim/power/power_model.cc index 5f810fe60..e8c522cad 100644 --- a/src/sim/power/power_model.cc +++ b/src/sim/power/power_model.cc @@ -1,5 +1,5 @@ /* - * Copyright (c) 2016 ARM Limited + * Copyright (c) 2016-2018 ARM Limited * All rights reserved * * The license below extends only to copyright in the software and shall @@ -52,7 +52,7 @@ PowerModelState::PowerModelState(const Params *p) PowerModel::PowerModel(const Params *p) : SimObject(p), states_pm(p->pm), subsystem(p->subsystem), - clocked_object(NULL) + clocked_object(NULL), power_model_type(p->pm_type) { panic_if(subsystem == NULL, "Subsystem is NULL! This is not acceptable for a PowerModel!\n"); @@ -94,6 +94,10 @@ PowerModel::getDynamicPower() const { assert(clocked_object); + if (power_model_type == Enums::PMType::Static) { + // This power model only collects static data + return 0; + } std::vector<double> w = clocked_object->pwrStateWeights(); // Same number of states (excluding UNDEFINED) @@ -118,6 +122,11 @@ PowerModel::getStaticPower() const std::vector<double> w = clocked_object->pwrStateWeights(); + if (power_model_type == Enums::PMType::Dynamic) { + // This power model only collects dynamic data + return 0; + } + // Same number of states (excluding UNDEFINED) assert(w.size() - 1 == states_pm.size()); diff --git a/src/sim/power/power_model.hh b/src/sim/power/power_model.hh index 976c0543f..e482b8005 100644 --- a/src/sim/power/power_model.hh +++ b/src/sim/power/power_model.hh @@ -1,5 +1,5 @@ /* - * Copyright (c) 2016 ARM Limited + * Copyright (c) 2016, 2018 ARM Limited * All rights reserved * * The license below extends only to copyright in the software and shall @@ -41,6 +41,7 @@ #define __SIM_POWER_POWER_MODEL_HH__ #include "base/statistics.hh" +#include "enums/PMType.hh" #include "params/PowerModel.hh" #include "params/PowerModelState.hh" #include "sim/probe/probe.hh" @@ -184,6 +185,9 @@ class PowerModel : public SimObject /** The clocked object we belong to */ ClockedObject * clocked_object; + + /** The type of power model - collects all power, static or dynamic only */ + Enums::PMType power_model_type; }; #endif |