blob: 5e048b2cac63e687e10f31264a6b17db94f58956 [file] [log] [blame]
Jason M. Billsd5577292022-08-29 13:35:57 -07001/*
2// Copyright (c) 2022 Intel 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#include <error_monitors/base_gpio_monitor.hpp>
18#include <host_error_monitor.hpp>
19#include <sdbusplus/asio/object_server.hpp>
20
21namespace host_error_monitor::cpu_early_error_monitor
22{
23class CPUEarlyErrorMonitor :
24 public host_error_monitor::base_gpio_monitor::BaseGPIOMonitor
25{
26 const static host_error_monitor::base_gpio_monitor::AssertValue
27 assertValue =
28 host_error_monitor::base_gpio_monitor::AssertValue::lowAssert;
29 size_t cpuNum;
30
31 void logEvent() override
32 {
33 std::string cpuNumber = "CPU " + std::to_string(cpuNum);
34 std::string msg = cpuNumber + " early error.";
35
36 sd_journal_send("MESSAGE=HostError: %s", msg.c_str(), "PRIORITY=%i",
37 LOG_ERR, "REDFISH_MESSAGE_ID=%s",
38 "OpenBMC.0.1.CPUError", "REDFISH_MESSAGE_ARGS=%s",
39 msg.c_str(), NULL);
40 }
41
42 public:
Ed Tanousee00ccc2023-03-01 10:37:43 -080043 CPUEarlyErrorMonitor(boost::asio::io_context& io,
Jason M. Billsd5577292022-08-29 13:35:57 -070044 std::shared_ptr<sdbusplus::asio::connection> conn,
45 const std::string& signalName, const size_t cpuNum) :
46 BaseGPIOMonitor(io, conn, signalName, assertValue),
47 cpuNum(cpuNum)
48 {
49 if (valid)
50 {
51 startMonitoring();
52 }
53 }
54};
55} // namespace host_error_monitor::cpu_early_error_monitor