blob: 37b49ea7c72d7941ad2cc6369ef1bbd05200cebc [file] [log] [blame]
Patrick Ventured8012182018-03-08 08:21:38 -08001#pragma once
2
Patrick Ventureda4a5dd2018-08-31 09:42:48 -07003#include "conf.hpp"
4#include "controller.hpp"
James Feist22c257a2018-08-31 14:07:12 -07005#include "pidcontroller.hpp"
Patrick Ventureda4a5dd2018-08-31 09:42:48 -07006#include "sensors/manager.hpp"
7#include "sensors/sensor.hpp"
Patrick Venturec32e3fc2019-02-28 10:01:11 -08008#include "tuning.hpp"
Patrick Venture1a153792020-08-11 08:41:47 -07009#include "zone_interface.hpp"
Patrick Ventureda4a5dd2018-08-31 09:42:48 -070010
Patrick Venturea83a3ec2020-08-04 09:52:05 -070011#include <sdbusplus/bus.hpp>
12#include <sdbusplus/server.hpp>
13#include <xyz/openbmc_project/Control/Mode/server.hpp>
14
Patrick Ventured8012182018-03-08 08:21:38 -080015#include <fstream>
16#include <map>
17#include <memory>
18#include <set>
19#include <string>
20#include <vector>
21
Patrick Ventured8012182018-03-08 08:21:38 -080022template <typename... T>
23using ServerObject = typename sdbusplus::server::object::object<T...>;
Patrick Ventureda4a5dd2018-08-31 09:42:48 -070024using ModeInterface = sdbusplus::xyz::openbmc_project::Control::server::Mode;
Patrick Ventured8012182018-03-08 08:21:38 -080025using ModeObject = ServerObject<ModeInterface>;
26
Patrick Venturea0764872020-08-08 07:48:43 -070027namespace pid_control
28{
29
Patrick Ventured8012182018-03-08 08:21:38 -080030/*
Patrick Venture597ebd62020-08-11 08:48:19 -070031 * The DbusPidZone inherits from the Mode object so that it can listen for
32 * control mode changes. It primarily holds all PID loops and holds the sensor
33 * value cache that's used per iteration of the PID loops.
Patrick Ventured8012182018-03-08 08:21:38 -080034 */
Patrick Venture597ebd62020-08-11 08:48:19 -070035class DbusPidZone : public ZoneInterface, public ModeObject
Patrick Ventured8012182018-03-08 08:21:38 -080036{
Patrick Ventureda4a5dd2018-08-31 09:42:48 -070037 public:
Patrick Venture597ebd62020-08-11 08:48:19 -070038 DbusPidZone(int64_t zone, double minThermalOutput, double failSafePercent,
39 const SensorManager& mgr, sdbusplus::bus::bus& bus,
40 const char* objPath, bool defer) :
Patrick Ventureda4a5dd2018-08-31 09:42:48 -070041 ModeObject(bus, objPath, defer),
Patrick Venturef7a2dd52019-07-16 14:31:13 -070042 _zoneId(zone), _maximumSetPoint(),
James Feist3484bed2019-02-25 13:28:18 -080043 _minThermalOutputSetPt(minThermalOutput),
Patrick Ventureda4a5dd2018-08-31 09:42:48 -070044 _failSafePercent(failSafePercent), _mgr(mgr)
45 {
Patrick Venturede79ee02019-05-08 14:50:00 -070046 if (loggingEnabled)
Patrick Venturec32e3fc2019-02-28 10:01:11 -080047 {
Patrick Venture89002db2019-05-08 15:02:55 -070048 _log.open(loggingPath + "/zone_" + std::to_string(zone) + ".log");
Patrick Venturec32e3fc2019-02-28 10:01:11 -080049 }
Patrick Ventureda4a5dd2018-08-31 09:42:48 -070050 }
Patrick Ventured8012182018-03-08 08:21:38 -080051
Patrick Venture7a98c192020-08-12 08:35:16 -070052 bool getManualMode(void) const override;
Patrick Ventureda4a5dd2018-08-31 09:42:48 -070053 /* Could put lock around this since it's accessed from two threads, but
54 * only one reader/one writer.
55 */
Josh Lehana4146eb2020-10-01 11:49:09 -070056
57 bool getRedundantWrite(void) const override;
Patrick Ventureda4a5dd2018-08-31 09:42:48 -070058 void setManualMode(bool mode);
59 bool getFailSafeMode(void) const override;
Patrick Venture7a98c192020-08-12 08:35:16 -070060
Patrick Venture0bbeaf82018-10-30 18:50:31 -070061 int64_t getZoneID(void) const;
Patrick Venture9bbf3332019-07-16 10:50:37 -070062 void addSetPoint(double setpoint) override;
Patrick Venture7a98c192020-08-12 08:35:16 -070063 double getMaxSetPointRequest(void) const override;
James Feist608304d2019-02-25 10:01:42 -080064 void addRPMCeiling(double ceiling) override;
Patrick Venture7a98c192020-08-12 08:35:16 -070065 void clearSetPoints(void) override;
66 void clearRPMCeilings(void) override;
Patrick Venture5f59c0f2018-11-11 12:55:14 -080067 double getFailSafePercent(void) const override;
Patrick Venturef7a2dd52019-07-16 14:31:13 -070068 double getMinThermalSetpoint(void) const;
Patrick Ventured8012182018-03-08 08:21:38 -080069
Patrick Venture2d8e7852018-10-30 19:14:07 -070070 Sensor* getSensor(const std::string& name) override;
Patrick Venture7a98c192020-08-12 08:35:16 -070071 void determineMaxSetPointRequest(void) override;
72 void updateFanTelemetry(void) override;
73 void updateSensors(void) override;
74 void initializeCache(void) override;
Patrick Ventureda4a5dd2018-08-31 09:42:48 -070075 void dumpCache(void);
Josh Lehana4146eb2020-10-01 11:49:09 -070076
Patrick Venture7a98c192020-08-12 08:35:16 -070077 void processFans(void) override;
78 void processThermals(void) override;
Patrick Ventured8012182018-03-08 08:21:38 -080079
James Feist22c257a2018-08-31 14:07:12 -070080 void addFanPID(std::unique_ptr<Controller> pid);
81 void addThermalPID(std::unique_ptr<Controller> pid);
Patrick Ventureda4a5dd2018-08-31 09:42:48 -070082 double getCachedValue(const std::string& name) override;
Patrick Venturec399f6f2018-10-30 19:24:47 -070083 void addFanInput(const std::string& fan);
84 void addThermalInput(const std::string& therm);
Patrick Ventured8012182018-03-08 08:21:38 -080085
Patrick Venture7a98c192020-08-12 08:35:16 -070086 void initializeLog(void) override;
87 void writeLog(const std::string& value) override;
Patrick Ventured8012182018-03-08 08:21:38 -080088
Patrick Ventureda4a5dd2018-08-31 09:42:48 -070089 /* Method for setting the manual mode over dbus */
90 bool manual(bool value) override;
91 /* Method for reading whether in fail-safe mode over dbus */
92 bool failSafe() const override;
Patrick Ventured8012182018-03-08 08:21:38 -080093
Patrick Ventureda4a5dd2018-08-31 09:42:48 -070094 private:
Patrick Ventureda4a5dd2018-08-31 09:42:48 -070095 std::ofstream _log;
Patrick Ventured8012182018-03-08 08:21:38 -080096
Patrick Ventureda4a5dd2018-08-31 09:42:48 -070097 const int64_t _zoneId;
Patrick Venturef7a2dd52019-07-16 14:31:13 -070098 double _maximumSetPoint = 0;
Patrick Ventureda4a5dd2018-08-31 09:42:48 -070099 bool _manualMode = false;
Josh Lehana4146eb2020-10-01 11:49:09 -0700100 bool _redundantWrite = false;
James Feist3484bed2019-02-25 13:28:18 -0800101 const double _minThermalOutputSetPt;
Patrick Venture5f59c0f2018-11-11 12:55:14 -0800102 const double _failSafePercent;
Patrick Ventured8012182018-03-08 08:21:38 -0800103
Patrick Ventureda4a5dd2018-08-31 09:42:48 -0700104 std::set<std::string> _failSafeSensors;
Patrick Ventured8012182018-03-08 08:21:38 -0800105
Patrick Venture9bbf3332019-07-16 10:50:37 -0700106 std::vector<double> _SetPoints;
James Feist608304d2019-02-25 10:01:42 -0800107 std::vector<double> _RPMCeilings;
Patrick Ventureda4a5dd2018-08-31 09:42:48 -0700108 std::vector<std::string> _fanInputs;
109 std::vector<std::string> _thermalInputs;
110 std::map<std::string, double> _cachedValuesByName;
111 const SensorManager& _mgr;
Patrick Ventured8012182018-03-08 08:21:38 -0800112
James Feist22c257a2018-08-31 14:07:12 -0700113 std::vector<std::unique_ptr<Controller>> _fans;
114 std::vector<std::unique_ptr<Controller>> _thermals;
Patrick Ventured8012182018-03-08 08:21:38 -0800115};
Patrick Venturea0764872020-08-08 07:48:43 -0700116
117} // namespace pid_control