geopm 3.2.1.dev270+g28d5c27cd
GEOPM - Global Extensible Open Power Manager
Loading...
Searching...
No Matches
SysfsIOGroup.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 SYSFSIOGROUP_HPP_INCLUDE
7#define SYSFSIOGROUP_HPP_INCLUDE
8
9#include <functional>
10#include <memory>
11
12#include "geopm/IOGroup.hpp"
14
15#include "SysfsDriver.hpp"
16#include "Signal.hpp"
17#include "UniqueFd.hpp"
18#include "geopm_time.h"
19
20namespace geopm
21{
22
23 class SaveControl;
24 class IOUring;
25
26 class SysfsIOGroup : public IOGroup
27 {
28 public:
29 SysfsIOGroup() = delete;
30 SysfsIOGroup(std::shared_ptr<SysfsDriver> driver);
31 SysfsIOGroup(std::shared_ptr<SysfsDriver> driver,
32 const PlatformTopo &topo,
33 std::shared_ptr<SaveControl> control_saver,
34 std::shared_ptr<IOUring> batch_reader,
35 std::shared_ptr<IOUring> batch_writer);
36 virtual ~SysfsIOGroup();
37 std::set<std::string> signal_names(void) const override;
38 std::set<std::string> control_names(void) const override;
39 bool is_valid_signal(const std::string &signal_name) const override;
40 bool is_valid_signal_domain(const std::string &signal_name, int domain_idx) const;
41 bool is_valid_control(const std::string &control_name) const override;
42 bool is_valid_control_domain(const std::string &control_name, int domain_idx) const;
43 int signal_domain_type(const std::string &signal_name) const override;
44 int control_domain_type(const std::string &control_name) const override;
45 int push_signal(const std::string &signal_name, int domain_type, int domain_idx) override;
46 int push_control(const std::string &control_name, int domain_type, int domain_idx) override;
47 void read_batch(void) override;
48 void write_batch(void) override;
49 double sample(int batch_idx) override;
50 void adjust(int batch_idx, double setting) override;
51 double read_signal(const std::string &signal_name, int domain_type, int domain_idx) override;
52 void write_control(const std::string &control_name, int domain_type, int domain_idx, double setting) override;
53 void save_control(void) override;
54 void save_control(const std::string &save_path) override;
55 void restore_control(void) override;
56 void restore_control(const std::string &save_path) override;
57 std::function<double(const std::vector<double> &)> agg_function(const std::string &signal_name) const override;
58 std::function<std::string(double)> format_function(const std::string &signal_name) const override;
59 std::string signal_description(const std::string &signal_name) const override;
60 std::string control_description(const std::string &control_name) const override;
61 int signal_behavior(const std::string &signal_name) const override;
62 std::string name(void) const override;
63 private:
64 std::string canonical_name(const std::string &name) const;
65 std::string check_request(const std::string &method_name,
66 const std::string &signal_name,
67 const std::string &control_name,
68 int domain_type,
69 int domain_idx) const;
70 int push_driver_signal(const std::string &signal_name, int domain_type, int domain_idx);
71 int push_derived_signal(const std::string &signal_name,
73 int domain_type,
74 int domain_idx);
75 double read_driver_signal(const std::string &canonical_name, int domain_idx) const;
76 double read_derived_signal(const SysfsDriver::derived_signal_info_s &info,
77 int domain_type,
78 int domain_idx);
79 double signal_value_by_index(int idx) const;
80 bool write_batch_retry(bool isRetry);
81 std::shared_ptr<SysfsDriver> m_driver;
82 const geopm::PlatformTopo &m_platform_topo;
84 bool m_do_batch_read;
85 bool m_do_batch_write;
87 bool m_is_batch_read;
88 bool m_is_batch_write;
89 std::vector<double> m_control_value;
90 const std::map<std::string, SysfsDriver::properties_s> m_properties;
91 std::map<std::string, std::reference_wrapper<const SysfsDriver::properties_s> > m_signals;
92 std::map<std::string, std::reference_wrapper<const SysfsDriver::properties_s> > m_controls;
93 const std::map<std::string, SysfsDriver::derived_signal_info_s> m_derived_signals;
94 std::shared_ptr<geopm_time_s> m_time_zero;
95 std::shared_ptr<double> m_time_batch;
96 std::shared_ptr<Signal> m_time_signal;
97 int m_derivative_window;
98 double m_sleep_time;
99
100 // Information about a single pushed signal or control
101 struct m_pushed_info_s {
102 UniqueFd fd;
103 std::string name;
104 int domain_type;
105 int domain_idx;
106 double value;
107 bool do_write;
108 std::shared_ptr<int> last_io_return;
109 std::array<char, SysfsDriver::M_IO_BUFFER_SIZE> buf;
110 std::function<double(const std::string&)> parse;
111 std::function<std::string(double)> gen;
112 bool is_driver_signal;
113 bool is_derived_signal;
114 int backing_signal_idx;
115 std::shared_ptr<Signal> signal;
116 };
117
118 // Pushed signals
119 std::vector<m_pushed_info_s> m_pushed_info_signal;
120 std::vector<m_pushed_info_s> m_pushed_info_control;
121 std::shared_ptr<SaveControl> m_control_saver;
122 std::shared_ptr<IOUring> m_batch_reader;
123 std::shared_ptr<IOUring> m_batch_writer;
124 std::set<std::string> m_unsaved_controls;
125 };
126
127}
128
129#endif
Definition IOGroup.hpp:21
Definition PlatformTopo.hpp:28
Definition SysfsIOGroup.hpp:27
double sample(int batch_idx) override
Retrieve signal value from data read by last call to read_batch() for a particular signal previously ...
Definition SysfsIOGroup.cpp:577
void write_batch(void) override
Write all of the pushed controls so that values previously given to adjust() are written to the platf...
Definition SysfsIOGroup.cpp:522
bool is_valid_control(const std::string &control_name) const override
Test if control_name refers to a control supported by the group.
Definition SysfsIOGroup.cpp:255
void adjust(int batch_idx, double setting) override
Adjust a setting for a particular control that was previously pushed with push_control()....
Definition SysfsIOGroup.cpp:591
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 SysfsIOGroup.cpp:434
bool is_valid_signal_domain(const std::string &signal_name, int domain_idx) const
Definition SysfsIOGroup.cpp:224
void restore_control(void) override
Restore all controls to values recorded in previous call to the save() method.
Definition SysfsIOGroup.cpp:671
std::set< std::string > signal_names(void) const override
Returns the names of all signals provided by the IOGroup.
Definition SysfsIOGroup.cpp:177
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 SysfsIOGroup.cpp:711
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 SysfsIOGroup.cpp:690
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 SysfsIOGroup.cpp:759
int control_domain_type(const std::string &control_name) const override
Query the domain for a named control.
Definition SysfsIOGroup.cpp:295
void read_batch(void) override
Read all pushed signals from the platform so that the next call to sample() will reflect the updated ...
Definition SysfsIOGroup.cpp:481
bool is_valid_control_domain(const std::string &control_name, int domain_idx) const
Definition SysfsIOGroup.cpp:260
std::string name(void) const override
Get the IOGroup name.
Definition SysfsIOGroup.cpp:789
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 SysfsIOGroup.cpp:415
bool is_valid_signal(const std::string &signal_name) const override
Test if signal_name refers to a signal supported by the group.
Definition SysfsIOGroup.cpp:219
void save_control(void) override
Save the state of all controls so that any subsequent changes made through the IOGroup can be undone ...
Definition SysfsIOGroup.cpp:650
int signal_domain_type(const std::string &signal_name) const override
Query the domain for a named signal.
Definition SysfsIOGroup.cpp:277
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 SysfsIOGroup.cpp:769
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 SysfsIOGroup.cpp:604
virtual ~SysfsIOGroup()
Definition SysfsIOGroup.cpp:172
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 SysfsIOGroup.cpp:732
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 SysfsIOGroup.cpp:643
std::set< std::string > control_names(void) const override
Returns the names of all controls provided by the IOGroup.
Definition SysfsIOGroup.cpp:201
A wrapper to close a file descriptor when the descriptor goes out of scope.
Definition UniqueFd.hpp:13
Definition Agg.cpp:20
Definition SysfsDriver.hpp:44