forked from openbmc/phosphor-pid-control
-
Notifications
You must be signed in to change notification settings - Fork 0
/
conf.hpp
64 lines (55 loc) · 1.49 KB
/
conf.hpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
#pragma once
#include "pid/ec/pid.hpp"
#include "pid/ec/stepwise.hpp"
#include <map>
#include <string>
#include <vector>
namespace pid_control
{
namespace conf
{
/*
* General sensor structure used for configuration.
*/
struct SensorConfig
{
/* Used for listen if readPath is passive. */
std::string type;
/* Can be a sensor path or a dbus path. */
std::string readPath;
std::string writePath;
/* min/max values for writing a percentage or error checking. */
int64_t min;
int64_t max;
int64_t timeout;
bool ignoreDbusMinMax;
};
/*
* Structure for holding the configuration of a PID.
*/
struct ControllerInfo
{
std::string type; // fan or margin or temp?
std::vector<std::string> inputs; // one or more sensors.
double setpoint; // initial setpoint for thermal.
union
{
ec::pidinfo pidInfo; // pid details
ec::StepwiseInfo stepwiseInfo;
};
};
/*
* General zone structure used for configuration. A zone is a list of PIDs
* and a set of configuration settings. This structure gets filled out with
* the zone configuration settings and not the PID details.
*/
struct ZoneConfig
{
/* The minimum set-point value we would ever want (typically in RPM) */
double minThermalOutput;
/* If the sensors are in fail-safe mode, this is the percentage to use. */
double failsafePercent;
};
using PIDConf = std::map<std::string, struct ControllerInfo>;
} // namespace conf
} // namespace pid_control