blob: f84540d5aaed8afbf4728160d613c8517b3777cb [file] [log] [blame]
Shawn McCarneydb0b8332020-04-06 14:13:04 -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
17#include "chassis.hpp"
18
Shawn McCarney525e20c2020-04-14 11:05:39 -050019#include "system.hpp"
20
Shawn McCarneydb0b8332020-04-06 14:13:04 -050021namespace phosphor::power::regulators
22{
23
24void Chassis::addToIDMap(IDMap& idMap)
25{
26 // Add devices and their rails to the map
27 for (std::unique_ptr<Device>& device : devices)
28 {
29 device->addToIDMap(idMap);
30 }
31}
32
Shawn McCarney9bd94d32021-01-25 19:40:42 -060033void Chassis::clearCache()
34{
35 // Clear any cached data in each device
36 for (std::unique_ptr<Device>& device : devices)
37 {
38 device->clearCache();
39 }
40}
41
Bob Kingd692d6d2020-09-14 13:42:57 +080042void Chassis::closeDevices(Services& services)
Shawn McCarney050531f2020-06-02 14:17:12 -050043{
44 // Log debug message in journal
Bob Kingd692d6d2020-09-14 13:42:57 +080045 services.getJournal().logDebug("Closing devices in chassis " +
46 std::to_string(number));
Shawn McCarney050531f2020-06-02 14:17:12 -050047
48 // Close devices
49 for (std::unique_ptr<Device>& device : devices)
50 {
Bob Kingd692d6d2020-09-14 13:42:57 +080051 device->close(services);
Shawn McCarney050531f2020-06-02 14:17:12 -050052 }
53}
54
Bob King23243f82020-07-29 10:38:57 +080055void Chassis::configure(Services& services, System& system)
Shawn McCarney525e20c2020-04-14 11:05:39 -050056{
57 // Log info message in journal; important for verifying success of boot
Bob King5cfe5102020-07-30 16:26:18 +080058 services.getJournal().logInfo("Configuring chassis " +
59 std::to_string(number));
Shawn McCarney525e20c2020-04-14 11:05:39 -050060
61 // Configure devices
62 for (std::unique_ptr<Device>& device : devices)
63 {
Bob King23243f82020-07-29 10:38:57 +080064 device->configure(services, system, *this);
Shawn McCarney525e20c2020-04-14 11:05:39 -050065 }
66}
67
Bob King8a552922020-08-05 17:02:31 +080068void Chassis::monitorSensors(Services& services, System& system)
Bob Kinga2c81a62020-07-08 13:31:16 +080069{
70 // Monitor sensors in each device
71 for (std::unique_ptr<Device>& device : devices)
72 {
Bob King8a552922020-08-05 17:02:31 +080073 device->monitorSensors(services, system, *this);
Bob Kinga2c81a62020-07-08 13:31:16 +080074 }
75}
76
Shawn McCarneydb0b8332020-04-06 14:13:04 -050077} // namespace phosphor::power::regulators