blob: bd1c0d84e7ec1263c6e3cfacd57152f0ad2cd622 [file] [log] [blame]
Naveen Mosesd219fa32022-07-20 00:01:46 +05301#include "serial_uart_mux.hpp"
2
Naveen Mosesd219fa32022-07-20 00:01:46 +05303#include "xyz/openbmc_project/Chassis/Buttons/HostSelector/server.hpp"
4
5#include <error.h>
6
7#include <phosphor-logging/lg2.hpp>
8namespace sdbusRule = sdbusplus::bus::match::rules;
9// add the button iface class to registry
10static ButtonIFRegister<SerialUartMux> buttonRegister;
Patrick Williams0d6d74c2023-08-17 17:41:01 -050011using HostSelectorServerObj =
12 sdbusplus::server::xyz::openbmc_project::chassis::buttons::HostSelector;
13using HostSelectorClientObj =
14 sdbusplus::common::xyz::openbmc_project::chassis::buttons::HostSelector;
Naveen Mosesd219fa32022-07-20 00:01:46 +053015
16constexpr std::string_view SERIAL_UART_RX_GPIO = "serial_uart_rx";
17void SerialUartMux::init()
18{
19 try
20 {
21 // when Host Selector Position is changed call the handler
22
23 std::string matchPattern = sdbusRule::propertiesChanged(
24 HS_DBUS_OBJECT_NAME, HostSelectorClientObj::interface);
25
26 hostPositionChanged = std::make_unique<sdbusplus::bus::match_t>(
27 bus, matchPattern,
28 std::bind(std::mem_fn(&SerialUartMux::hostSelectorPositionChanged),
29 this, std::placeholders::_1));
30 }
31 catch (const std::exception& e)
32 {
33 lg2::error(
34 "Failed binding to matching function : {BUTTON_TYPE},Exception : {ERROR}",
35 "BUTTON_TYPE", getFormFactorName(), "ERROR", e);
36 throw sdbusplus::xyz::openbmc_project::Chassis::Common::Error::
37 IOError();
38 }
39}
40// check the debug card present pin
41bool SerialUartMux::isOCPDebugCardPresent()
42{
Patrick Williams0d038f52023-05-10 07:50:40 -050043 auto gpioState = getGpioState(debugCardPresentGpio.fd,
44 debugCardPresentGpio.polarity);
Naveen Mosesd219fa32022-07-20 00:01:46 +053045 return (gpioState == GpioState::assert);
46}
47// set the serial uart MUX to select the console w.r.t host selector position
48void SerialUartMux::configSerialConsoleMux(size_t position)
49{
50 auto debugCardPresent = isOCPDebugCardPresent();
51
52 if (debugCardPresent)
53 {
54 lg2::info("Debug card is present ");
55 }
56 else
57 {
58 lg2::info("Debug card not present ");
59 }
60
61 for (size_t uartMuxSel = 0; uartMuxSel < gpioLineCount; uartMuxSel++)
62 {
63 auto gpioState = GpioState::invalid;
Delphine CC Chiuccd7db02023-02-09 14:48:53 +080064 GpioInfo gpioConfig = config.gpios[uartMuxSel];
Naveen Mosesd219fa32022-07-20 00:01:46 +053065
66 if (gpioConfig.name == SERIAL_UART_RX_GPIO)
67 {
Patrick Williams0d038f52023-05-10 07:50:40 -050068 gpioState = debugCardPresent ? GpioState::assert
69 : GpioState::deassert;
Naveen Mosesd219fa32022-07-20 00:01:46 +053070 }
71 else
72 {
73 gpioState = (serialUartMuxMap[position] & (0x1 << uartMuxSel))
74 ? GpioState::assert
75 : GpioState::deassert;
76 }
77 setGpioState(gpioConfig.fd, gpioConfig.polarity, gpioState);
78 }
79}
80
81void SerialUartMux::hostSelectorPositionChanged(sdbusplus::message_t& msg)
82{
83 std::string interface;
Patrick Williams0d6d74c2023-08-17 17:41:01 -050084 std::map<std::string, HostSelectorServerObj::PropertiesVariant>
Naveen Mosesd219fa32022-07-20 00:01:46 +053085 propertiesChanged;
86 lg2::info("hostSelectorPositionChanged callback : {BUTTON_TYPE}",
87 "BUTTON_TYPE", getFormFactorName());
88
89 try
90 {
91 msg.read(interface, propertiesChanged);
92 for (auto& property : propertiesChanged)
93 {
94 auto propertyName = property.first;
95 if (propertyName == "Position")
96 {
97 size_t hostPosition = std::get<size_t>(property.second);
98 lg2::debug("property changed : {VALUE}", "VALUE", hostPosition);
99 configSerialConsoleMux(hostPosition);
100 return;
101 }
102 }
103 }
104 catch (const std::exception& e)
105 {
106 lg2::error("exception while reading dbus property : {ERROR}", "ERROR",
107 e.what());
108 return;
109 }
110}