geopm  3.1.1.dev214+gba4f9f6d
GEOPM - Global Extensible Open Power Manager
PlatformIO.hpp
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2015 - 2024 Intel Corporation
3  * SPDX-License-Identifier: BSD-3-Clause
4  */
5 
6 #ifndef PLATFORMIO_HPP_INCLUDE
7 #define PLATFORMIO_HPP_INCLUDE
8 
9 #include <climits>
10 #include <functional>
11 #include <memory>
12 #include <set>
13 #include <string>
14 #include <vector>
15 
16 #include "geopm_pio.h"
17 #include "geopm_public.h"
18 
22  char name[NAME_MAX];
23 };
24 
25 namespace geopm
26 {
27  class IOGroup;
28  class ProfileIOGroup;
29 
33  {
34  public:
35  PlatformIO() = default;
36  virtual ~PlatformIO() = default;
46  virtual void register_iogroup(std::shared_ptr<IOGroup> iogroup) = 0;
51  virtual std::set<std::string> signal_names(void) const = 0;
56  virtual std::set<std::string> control_names(void) const = 0;
65  virtual int signal_domain_type(const std::string &signal_name) const = 0;
75  virtual int control_domain_type(const std::string &control_name) const = 0;
93  virtual int push_signal(const std::string &signal_name,
94  int domain_type,
95  int domain_idx) = 0;
112  virtual int push_control(const std::string &control_name,
113  int domain_type,
114  int domain_idx) = 0;
124  virtual double sample(int signal_idx) = 0;
134  virtual void adjust(int control_idx,
135  double setting) = 0;
138  virtual void read_batch(void) = 0;
142  virtual void write_batch(void) = 0;
159  virtual double read_signal(const std::string &signal_name,
160  int domain_type,
161  int domain_idx) = 0;
178  virtual void write_control(const std::string &control_name,
179  int domain_type,
180  int domain_idx,
181  double setting) = 0;
186  virtual void save_control(void) = 0;
189  virtual void restore_control(void) = 0;
197  virtual std::function<double(const std::vector<double> &)> agg_function(const std::string &signal_name) const = 0;
205  virtual std::function<std::string(double)> format_function(const std::string &signal_name) const = 0;
209  virtual std::string signal_description(const std::string &signal_name) const = 0;
213  virtual std::string control_description(const std::string &control_name) const = 0;
225  virtual int signal_behavior(const std::string &signal_name) const = 0;
236  virtual void save_control(const std::string &save_dir) = 0;
244  virtual void restore_control(const std::string &save_dir) = 0;
246  virtual void start_batch_server(int client_pid,
247  const std::vector<geopm_request_s> &signal_config,
248  const std::vector<geopm_request_s> &control_config,
249  int &server_pid,
250  std::string &server_key) = 0;
251  virtual void stop_batch_server(int server_pid) = 0;
252 
256  static bool is_valid_value(double value);
257  };
258 
260  platform_io(void);
261 }
262 
263 #endif
Class which is a collection of all valid control and signal objects for a platform.
Definition: PlatformIO.hpp:33
virtual void restore_control(void)=0
Restore all controls to values recorded in previous call to the save_control() method.
virtual void start_batch_server(int client_pid, const std::vector< geopm_request_s > &signal_config, const std::vector< geopm_request_s > &control_config, int &server_pid, std::string &server_key)=0
virtual void save_control(const std::string &save_dir)=0
Save the state of all controls so that any subsequent changes made through PlatformIO can be undone w...
virtual void register_iogroup(std::shared_ptr< IOGroup > iogroup)=0
Registers an IOGroup with the PlatformIO so that its signals and controls are available through the P...
virtual void write_batch(void)=0
Write all of the pushed controls so that values previously given to adjust() are written to the platf...
virtual int control_domain_type(const std::string &control_name) const =0
Query the domain for a named control.
virtual std::set< std::string > signal_names(void) const =0
Returns the names of all available signals. This includes all signals and aliases provided by IOGroup...
virtual int push_signal(const std::string &signal_name, int domain_type, int domain_idx)=0
Push a signal onto the end of the vector that can be sampled.
virtual void read_batch(void)=0
Read all pushed signals so that the next call to sample() will reflect the updated data.
virtual std::string control_description(const std::string &control_name) const =0
Returns a description of the control. This string can be used by tools to generate help text for user...
virtual double sample(int signal_idx)=0
Sample a single signal that has been pushed on to the signal stack. Must be called after a call to re...
virtual std::function< double(const std::vector< double > &)> agg_function(const std::string &signal_name) const =0
Returns a function appropriate for aggregating multiple values of the given signal into a single valu...
virtual double read_signal(const std::string &signal_name, int domain_type, int domain_idx)=0
Read from platform and interpret into SI units a signal given its name and domain....
virtual void adjust(int control_idx, double setting)=0
Adjust a single control that has been pushed on to the control stack. This control will not take effe...
virtual ~PlatformIO()=default
virtual std::string signal_description(const std::string &signal_name) const =0
Returns a description of the signal. This string can be used by tools to generate help text for users...
virtual void restore_control(const std::string &save_dir)=0
Restore all controls to values recorded in previous call to the save_control(save_dir) method....
virtual int push_control(const std::string &control_name, int domain_type, int domain_idx)=0
Push a control onto the end of the vector that can be adjusted.
virtual std::set< std::string > control_names(void) const =0
Returns the names of all available controls. This includes all controls and aliases provided by IOGro...
virtual int signal_behavior(const std::string &signal_name) const =0
Returns a hint about how a signal will change as a function of time.
virtual std::function< std::string(double)> format_function(const std::string &signal_name) const =0
Returns a function that can be used to convert a signal of the given name into a printable string.
virtual void stop_batch_server(int server_pid)=0
PlatformIO()=default
virtual void write_control(const std::string &control_name, int domain_type, int domain_idx, double setting)=0
Interpret the setting and write setting to the platform. Does not modify the values stored by calling...
virtual void save_control(void)=0
Save the state of all controls so that any subsequent changes made through PlatformIO can be undone w...
virtual int signal_domain_type(const std::string &signal_name) const =0
Query the domain for a named signal.
#define GEOPM_PUBLIC
Definition: geopm_public.h:10
Definition: Agg.cpp:20
PlatformIO & platform_io(void)
Definition: PlatformIO.cpp:41
Definition: PlatformIO.hpp:19
int domain_idx
Definition: PlatformIO.hpp:21
int domain_type
Definition: PlatformIO.hpp:20