geopm 3.2.1.dev237+gbe30cff60
GEOPM - Global Extensible Open Power Manager
Loading...
Searching...
No Matches
MSRIOGroup.hpp
Go to the documentation of this file.
1/*
2 * Copyright (c) 2015 - 2025 Intel Corporation
3 * SPDX-License-Identifier: BSD-3-Clause
4 */
5
6#ifndef MSRIOGROUP_HPP_INCLUDE
7#define MSRIOGROUP_HPP_INCLUDE
8
9#include <functional>
10#include <map>
11#include <memory>
12#include <set>
13#include <string>
14#include <vector>
15
16#include "geopm/json11.hpp"
17
18#include "geopm/Cpuid.hpp"
19#include "geopm_time.h"
20#include "geopm_access.h"
21
22#include "geopm/IOGroup.hpp"
23
24namespace geopm
25{
26 class MSRIO;
27 class PlatformTopo;
28 class PlatformIO;
29 class Signal;
30 class Control;
31 class SaveControl;
32
34 class MSRIOGroup : public IOGroup
35 {
36 public:
37 enum m_cpuid_e {
38 M_CPUID_SNB = 0x62D,
39 M_CPUID_IVT = 0x63E,
40 M_CPUID_HSX = 0x63F,
41 M_CPUID_BDX = 0x64F,
42 M_CPUID_KNL = 0x657,
43 M_CPUID_SKX = 0x655,
44 M_CPUID_ICX = 0x66A,
45 M_CPUID_SPR = 0x68F,
48 };
49
50 MSRIOGroup() = delete;
51 MSRIOGroup(bool use_msr_safe);
53 std::shared_ptr<MSRIO> msrio,
54 std::shared_ptr<Cpuid> cpuid,
55 std::shared_ptr<SaveControl> save_control);
56 virtual ~MSRIOGroup() = default;
57 std::set<std::string> signal_names(void) const override;
58 std::set<std::string> control_names(void) const override;
59 bool is_valid_signal(const std::string &signal_name) const override;
60 bool is_valid_control(const std::string &control_name) const override;
61 int signal_domain_type(const std::string &signal_name) const override;
62 int control_domain_type(const std::string &control_name) const override;
63 int push_signal(const std::string &signal_name,
64 int domain_type,
65 int domain_idx) override;
66 int push_control(const std::string &control_name,
67 int domain_type,
68 int domain_idx) override;
69 void read_batch(void) override;
70 void write_batch(void) override;
71 double sample(int sample_idx) override;
72 void adjust(int control_idx,
73 double setting) override;
74 double read_signal(const std::string &signal_name,
75 int domain_type,
76 int domain_idx) override;
77 void write_control(const std::string &control_name,
78 int domain_type,
79 int domain_idx,
80 double setting) override;
81 void save_control(void) override;
82 void restore_control(void) override;
83 std::function<double(const std::vector<double> &)> agg_function(const std::string &signal_name) const override;
84 std::function<std::string(double)> format_function(const std::string &signal_name) const override;
85 std::string signal_description(const std::string &signal_name) const override;
86 std::string control_description(const std::string &control_name) const override;
87 int signal_behavior(const std::string &signal_name) const override;
88 void save_control(const std::string &save_path) override;
89 void restore_control(const std::string &save_path) override;
90 std::string name(void) const override;
91
94 void parse_json_msrs(const std::string &str);
101 static std::string msr_allowlist(int cpuid);
102 static std::string msr_allowlist(int cpuid,
103 const PlatformTopo &topo,
104 std::shared_ptr<MSRIO> msrio);
105
107 static int cpuid(void);
108 static std::string plugin_name(void);
109 static std::unique_ptr<IOGroup> make_plugin(void);
110 static std::unique_ptr<IOGroup> make_plugin_safe(void);
111 private:
114 static void parse_json_msrs_allowlist(const std::string &str,
115 std::map<uint64_t, std::pair<uint64_t, std::string> > &allowlist_data,
116 const PlatformTopo &topo,
117 std::shared_ptr<MSRIO> msrio);
124 static std::string format_allowlist(const std::map<uint64_t, std::pair<uint64_t, std::string> > &allowlist_data);
125
128 static std::string platform_data(int cpu_id);
129
130 enum MsrConfigWarningPreference_e {
131 SILENCE_CONFIG_DEPRECATION_WARNING,
132 EMIT_CONFIG_DEPRECATION_WARNING,
133 };
139 static std::set<std::string> msr_data_files(
140 MsrConfigWarningPreference_e warning_preference = SILENCE_CONFIG_DEPRECATION_WARNING);
143 void set_signal_description(const std::string &name, const std::string &description);
146 void set_control_description(const std::string &name, const std::string &description);
148 void register_signal_alias(const std::string &signal_name, const std::string &msr_field_name);
150 void register_control_alias(const std::string &control_name, const std::string &msr_field_name);
153 void register_temperature_signals(void);
156 void register_power_signals(void);
159 void register_pcnt_scalability_signals(void);
162 void register_rdt_signals(void);
165 void register_frequency_signals(void);
168 void register_frequency_controls(void);
171 void check_control(const std::string &control_name);
172
173 void check_control_pwrite(void);
174
176 void check_control_lock(const std::string &lock_name, const std::string &error);
177
179 static void check_top_level(const json11::Json &root);
180 static void check_msr_root(const json11::Json &msr_root,
181 const std::string &msr_name);
182 static void check_msr_field(const json11::Json &msr_field,
183 const std::string &msr_name,
184 const std::string &msr_field_name);
185 // Used to validate type and value of JSON objects
186 static bool json_check_null_func(const json11::Json &obj);
187 static bool json_check_is_hex_string(const json11::Json &obj);
188 static bool json_check_is_valid_offset(const json11::Json &obj);
189 static bool json_check_is_valid_domain(const json11::Json &domain);
190 static bool json_check_is_integer(const json11::Json &num);
191 static bool json_check_is_valid_aggregation(const json11::Json &obj);
192 // Add raw MSR as an available signal
193 void add_raw_msr_signal(const std::string &msr_name, int domain_type, uint64_t msr_offset);
194 // Add a bitfield of an MSR as an available signal
195 void add_msr_field_signal(const std::string &msr_name, const std::string &msr_field_name,
196 int domain_type, int begin_bit, int end_bit, int function,
197 double scalar, int units, const std::string &aggregation,
198 const std::string &description, int behavior,
199 const std::function<std::string(double)> &format_function);
200 // Add a bitfield of an MSR as an available control
201 void add_msr_field_control(const std::string &msr_field_name, int domain_type,
202 uint64_t msr_offset, int begin_bit, int end_bit,
203 int function, double scalar, int units,
204 const std::string &description);
205
206 static const std::string M_DEFAULT_DESCRIPTION;
207 static const std::string M_PLUGIN_NAME;
208 static const std::string M_NAME_PREFIX;
209 const PlatformTopo &m_platform_topo;
210 std::shared_ptr<MSRIO> m_msrio;
211 int m_save_restore_ctx;
212 std::shared_ptr<Cpuid> m_cpuid;
213 bool m_is_active;
214 bool m_is_read;
215 std::vector<bool> m_is_adjusted;
216
217 // time for derivative signals
218 std::shared_ptr<geopm_time_s> m_time_zero;
219 std::shared_ptr<double> m_time_batch;
220
221 bool m_is_hwp_enabled;
222
223 Cpuid::rdt_info_s m_rdt_info;
224
225 uint32_t m_pmc_bit_width;
226
227 int m_derivative_window;
228 double m_sleep_time;
229
230 // All available signals: map from name to signal_info.
231 // The signals vector is over the indices for the domain.
232 // The signals pointers should be copied when signal is
233 // pushed and used directly for read_signal.
234 struct signal_info
235 {
236 std::vector<std::shared_ptr<Signal> > signals;
237 int domain;
238 int units;
239 std::function<double(const std::vector<double> &)> agg_function;
240 std::string description;
241 int behavior;
242 std::function<std::string(double)> format_function;
243 };
244 std::map<std::string, signal_info> m_signal_available;
245
246 struct control_info
247 {
248 std::vector<std::shared_ptr<Control> > controls;
249 int domain;
250 int units;
251 std::string description;
252 };
253 std::map<std::string, control_info> m_control_available;
254
255 // Mapping of signal index to pushed signals.
256 std::vector<std::shared_ptr<Signal> > m_signal_pushed;
257 // Mapping of control index to pushed controls
258 std::vector<std::shared_ptr<Control> > m_control_pushed;
259
260 std::shared_ptr<SaveControl> m_mock_save_ctl;
261 // Mapping of control index to enable bit control index
262 std::map<int, int> m_power_control_enable_idx;
263 };
264}
265
266#endif
Definition IOGroup.hpp:21
IOGroup that provides signals and controls based on MSRs.
Definition MSRIOGroup.hpp:35
int control_domain_type(const std::string &control_name) const override
Query the domain for a named control.
Definition MSRIOGroup.cpp:736
void write_batch(void) override
Write all of the pushed controls so that values previously given to adjust() are written to the platf...
Definition MSRIOGroup.cpp:856
void adjust(int control_idx, double setting) override
Adjust a setting for a particular control that was previously pushed with push_control()....
Definition MSRIOGroup.cpp:882
int signal_domain_type(const std::string &signal_name) const override
Query the domain for a named signal.
Definition MSRIOGroup.cpp:726
std::set< std::string > signal_names(void) const override
Returns the names of all signals provided by the IOGroup.
Definition MSRIOGroup.cpp:698
void write_control(const std::string &control_name, int domain_type, int domain_idx, double setting) override
Interpret the setting and write setting to the platform. Does not modify the values stored by calling...
Definition MSRIOGroup.cpp:921
m_cpuid_e
Definition MSRIOGroup.hpp:37
@ M_CPUID_BDX
Definition MSRIOGroup.hpp:41
@ M_CPUID_GNRAP
Definition MSRIOGroup.hpp:47
@ M_CPUID_GNRSP
Definition MSRIOGroup.hpp:46
@ M_CPUID_SKX
Definition MSRIOGroup.hpp:43
@ M_CPUID_HSX
Definition MSRIOGroup.hpp:40
@ M_CPUID_SPR
Definition MSRIOGroup.hpp:45
@ M_CPUID_IVT
Definition MSRIOGroup.hpp:39
@ M_CPUID_KNL
Definition MSRIOGroup.hpp:42
@ M_CPUID_SNB
Definition MSRIOGroup.hpp:38
@ M_CPUID_ICX
Definition MSRIOGroup.hpp:44
static int cpuid(void)
DEPRECATED Get the cpuid of the current platform.
Definition MSRIOGroup.cpp:971
std::string control_description(const std::string &control_name) const override
Returns a description of the control. This string can be used by tools to generate help text for user...
Definition MSRIOGroup.cpp:1138
static std::string msr_allowlist(int cpuid)
Fill string with the msr-safe allowlist file contents reflecting all known MSRs for the specified pla...
Definition MSRIOGroup.cpp:1827
static std::unique_ptr< IOGroup > make_plugin(void)
Definition MSRIOGroup.cpp:1056
int signal_behavior(const std::string &signal_name) const override
Returns a hint about how a signal will change as a function of time.
Definition MSRIOGroup.cpp:1162
static std::string plugin_name(void)
Definition MSRIOGroup.cpp:1046
std::function< double(const std::vector< double > &)> agg_function(const std::string &signal_name) const override
Return a function that should be used when aggregating the given signal.
Definition MSRIOGroup.cpp:1081
void parse_json_msrs(const std::string &str)
Parse a JSON string and add any raw MSRs and fields as available signals and controls.
Definition MSRIOGroup.cpp:1612
bool is_valid_control(const std::string &control_name) const override
Test if control_name refers to a control supported by the group.
Definition MSRIOGroup.cpp:721
void restore_control(void) override
Restore all controls to values recorded in previous call to the save() method.
Definition MSRIOGroup.cpp:961
double sample(int sample_idx) override
Retrieve signal value from data read by last call to read_batch() for a particular signal previously ...
Definition MSRIOGroup.cpp:868
int push_control(const std::string &control_name, int domain_type, int domain_idx) override
Add a control to the list of controls that is written by write_batch() and configured with adjust().
Definition MSRIOGroup.cpp:790
virtual ~MSRIOGroup()=default
std::set< std::string > control_names(void) const override
Returns the names of all controls provided by the IOGroup.
Definition MSRIOGroup.cpp:707
std::string name(void) const override
Get the IOGroup name.
Definition MSRIOGroup.cpp:1051
int push_signal(const std::string &signal_name, int domain_type, int domain_idx) override
Add a signal to the list of signals that is read by read_batch() and sampled by sample().
Definition MSRIOGroup.cpp:746
void save_control(void) override
Save the state of all controls so that any subsequent changes made through the IOGroup can be undone ...
Definition MSRIOGroup.cpp:951
std::string signal_description(const std::string &signal_name) const override
Returns a description of the signal. This string can be used by tools to generate help text for users...
Definition MSRIOGroup.cpp:1113
double read_signal(const std::string &signal_name, int domain_type, int domain_idx) override
Read from platform and interpret into SI units a signal given its name and domain....
Definition MSRIOGroup.cpp:902
std::function< std::string(double)> format_function(const std::string &signal_name) const override
Returns a function that can be used to convert a signal of the given name into a printable string....
Definition MSRIOGroup.cpp:1091
bool is_valid_signal(const std::string &signal_name) const override
Test if signal_name refers to a signal supported by the group.
Definition MSRIOGroup.cpp:716
void read_batch(void) override
Read all pushed signals from the platform so that the next call to sample() will reflect the updated ...
Definition MSRIOGroup.cpp:844
static std::unique_ptr< IOGroup > make_plugin_safe(void)
Definition MSRIOGroup.cpp:1061
Definition PlatformTopo.hpp:28
Definition Agg.cpp:20
const PlatformTopo & platform_topo(void)
Definition PlatformTopo.cpp:97
Definition Cpuid.hpp:19