blob: 16e55b48baead2af1be64ca8bd6868f12c9e6873 [file] [log] [blame]
Shawn McCarneyc3991f12020-04-05 13:16:06 -05001/**
2 * Copyright © 2020 IBM Corporation
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16#pragma once
17
18#include "chassis.hpp"
19#include "id_map.hpp"
20#include "rule.hpp"
21
22#include <memory>
23#include <utility>
24#include <vector>
25
26namespace phosphor::power::regulators
27{
28
29/**
30 * @class System
31 *
32 * The computer system being controlled and monitored by the BMC.
33 *
34 * The system contains one or more chassis. Chassis are large enclosures that
35 * can be independently powered off and on by the BMC.
36 */
37class System
38{
39 public:
40 // Specify which compiler-generated methods we want
41 System() = delete;
42 System(const System&) = delete;
43 System(System&&) = delete;
44 System& operator=(const System&) = delete;
45 System& operator=(System&&) = delete;
46 ~System() = default;
47
48 /**
49 * Constructor.
50 *
51 * @param rules rules used to monitor and control regulators in the system
52 * @param chassis chassis in the system
53 */
54 explicit System(std::vector<std::unique_ptr<Rule>> rules,
55 std::vector<std::unique_ptr<Chassis>> chassis) :
56 rules{std::move(rules)},
57 chassis{std::move(chassis)}
58 {
Shawn McCarneydb0b8332020-04-06 14:13:04 -050059 buildIDMap();
Shawn McCarneyc3991f12020-04-05 13:16:06 -050060 }
61
62 /**
Shawn McCarney2af52892020-04-14 11:54:45 -050063 * Configure the regulator devices in the system.
64 *
65 * This method should be called during the boot before regulators are
66 * enabled.
67 */
68 void configure();
69
70 /**
Shawn McCarneyc3991f12020-04-05 13:16:06 -050071 * Returns the chassis in the system.
72 *
73 * @return chassis
74 */
75 const std::vector<std::unique_ptr<Chassis>>& getChassis() const
76 {
77 return chassis;
78 }
79
80 /**
81 * Returns the IDMap for the system.
82 *
83 * The IDMap provides a mapping from string IDs to the associated Device,
84 * Rail, and Rule objects.
85 *
86 * @return IDMap
87 */
88 const IDMap& getIDMap() const
89 {
90 return idMap;
91 }
92
93 /**
94 * Returns the rules used to monitor and control regulators in the system.
95 *
96 * @return rules
97 */
98 const std::vector<std::unique_ptr<Rule>>& getRules() const
99 {
100 return rules;
101 }
102
103 private:
104 /**
Shawn McCarneydb0b8332020-04-06 14:13:04 -0500105 * Builds the IDMap for the system.
106 *
107 * Adds the Device, Rail, and Rule objects in the system to the map.
108 */
109 void buildIDMap();
110
111 /**
Shawn McCarneyc3991f12020-04-05 13:16:06 -0500112 * Rules used to monitor and control regulators in the system.
113 */
114 std::vector<std::unique_ptr<Rule>> rules{};
115
116 /**
117 * Chassis in the system.
118 */
119 std::vector<std::unique_ptr<Chassis>> chassis{};
120
121 /**
122 * Mapping from string IDs to the associated Device, Rail, and Rule objects.
123 */
124 IDMap idMap{};
125};
126
127} // namespace phosphor::power::regulators