blob: 08c5174974d876df6d70aa54c0934aa2df6f611f [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 "device.hpp"
18
Shawn McCarneyeb7bec42020-04-14 09:38:15 -050019#include "chassis.hpp"
Shawn McCarney81a2f902021-03-23 21:41:34 -050020#include "error_logging_utils.hpp"
Shawn McCarneyb4d18a42020-06-02 10:27:05 -050021#include "exception_utils.hpp"
Shawn McCarneyeb7bec42020-04-14 09:38:15 -050022#include "system.hpp"
23
Shawn McCarneyb4d18a42020-06-02 10:27:05 -050024#include <exception>
25
Shawn McCarneydb0b8332020-04-06 14:13:04 -050026namespace phosphor::power::regulators
27{
28
29void Device::addToIDMap(IDMap& idMap)
30{
31 // Add this device to the map
32 idMap.addDevice(*this);
33
34 // Add rails to the map
35 for (std::unique_ptr<Rail>& rail : rails)
36 {
37 idMap.addRail(*rail);
38 }
39}
40
Shawn McCarney9bd94d32021-01-25 19:40:42 -060041void Device::clearCache()
42{
43 // If presence detection is defined for this device
44 if (presenceDetection)
45 {
46 // Clear cached presence data
47 presenceDetection->clearCache();
48 }
49}
50
Bob Kingd692d6d2020-09-14 13:42:57 +080051void Device::close(Services& services)
Shawn McCarneyb4d18a42020-06-02 10:27:05 -050052{
53 try
54 {
55 // Close I2C interface if it is open
56 if (i2cInterface->isOpen())
57 {
58 i2cInterface->close();
59 }
60 }
61 catch (const std::exception& e)
62 {
63 // Log error messages in journal
Bob Kingd692d6d2020-09-14 13:42:57 +080064 services.getJournal().logError(exception_utils::getMessages(e));
65 services.getJournal().logError("Unable to close device " + id);
Shawn McCarneyb4d18a42020-06-02 10:27:05 -050066
Shawn McCarney81a2f902021-03-23 21:41:34 -050067 // Create error log entry
68 error_logging_utils::logError(std::current_exception(),
69 Entry::Level::Notice, services);
Shawn McCarneyb4d18a42020-06-02 10:27:05 -050070 }
71}
72
Bob King23243f82020-07-29 10:38:57 +080073void Device::configure(Services& services, System& system, Chassis& chassis)
Shawn McCarneyeb7bec42020-04-14 09:38:15 -050074{
Shawn McCarney48033bf2021-01-27 17:56:49 -060075 // Verify device is present
76 if (isPresent(services, system, chassis))
Shawn McCarneyeb7bec42020-04-14 09:38:15 -050077 {
Shawn McCarney48033bf2021-01-27 17:56:49 -060078 // If configuration changes are defined for this device, apply them
79 if (configuration)
80 {
81 configuration->execute(services, system, chassis, *this);
82 }
Shawn McCarneyeb7bec42020-04-14 09:38:15 -050083
Shawn McCarney48033bf2021-01-27 17:56:49 -060084 // Configure rails
85 for (std::unique_ptr<Rail>& rail : rails)
86 {
87 rail->configure(services, system, chassis, *this);
88 }
Shawn McCarneyeb7bec42020-04-14 09:38:15 -050089 }
90}
91
Bob King8a552922020-08-05 17:02:31 +080092void Device::monitorSensors(Services& services, System& system,
93 Chassis& chassis)
Bob King8e1cd0b2020-07-08 13:30:27 +080094{
Shawn McCarney48033bf2021-01-27 17:56:49 -060095 // Verify device is present
96 if (isPresent(services, system, chassis))
Bob King8e1cd0b2020-07-08 13:30:27 +080097 {
Shawn McCarney48033bf2021-01-27 17:56:49 -060098 // Monitor sensors in each rail
99 for (std::unique_ptr<Rail>& rail : rails)
100 {
101 rail->monitorSensors(services, system, chassis, *this);
102 }
Bob King8e1cd0b2020-07-08 13:30:27 +0800103 }
104}
105
Shawn McCarneydb0b8332020-04-06 14:13:04 -0500106} // namespace phosphor::power::regulators