| Jayanth Othayoth | cb65ffc | 2018-10-16 08:29:32 -0500 | [diff] [blame] | 1 | #include "config.h" | 
|  | 2 |  | 
|  | 3 | #include "elog_watch.hpp" | 
|  | 4 |  | 
|  | 5 | #include "dump_internal.hpp" | 
|  | 6 | #include "dump_serialize.hpp" | 
| Marri Devender Rao | 0deb287 | 2018-11-12 07:45:54 -0600 | [diff] [blame] | 7 | #include "errors_map.hpp" | 
| Jayanth Othayoth | cb65ffc | 2018-10-16 08:29:32 -0500 | [diff] [blame] | 8 | #include "xyz/openbmc_project/Dump/Create/error.hpp" | 
|  | 9 |  | 
| George Liu | 858fbb2 | 2021-07-01 12:25:44 +0800 | [diff] [blame] | 10 | #include <fmt/core.h> | 
|  | 11 |  | 
| Vishwanatha Subbanna | 3108597 | 2017-10-05 17:06:37 +0530 | [diff] [blame] | 12 | #include <cereal/cereal.hpp> | 
| Jayanth Othayoth | d0f0064 | 2017-09-04 06:26:30 -0500 | [diff] [blame] | 13 | #include <phosphor-logging/elog.hpp> | 
| William A. Kennington III | 15cd3ce | 2018-05-15 11:34:44 -0700 | [diff] [blame] | 14 | #include <sdbusplus/exception.hpp> | 
| Jayanth Othayoth | d0f0064 | 2017-09-04 06:26:30 -0500 | [diff] [blame] | 15 |  | 
| Jayanth Othayoth | 0af74a5 | 2021-04-08 03:55:21 -0500 | [diff] [blame] | 16 | #include <fstream> | 
|  | 17 |  | 
| Vishwanatha Subbanna | 3108597 | 2017-10-05 17:06:37 +0530 | [diff] [blame] | 18 | // Register class version with Cereal | 
| Ramesh Iyyar | bb410df | 2020-08-03 03:13:04 -0500 | [diff] [blame] | 19 | CEREAL_CLASS_VERSION(phosphor::dump::elog::Watch, CLASS_VERSION) | 
| Jayanth Othayoth | d0f0064 | 2017-09-04 06:26:30 -0500 | [diff] [blame] | 20 |  | 
|  | 21 | namespace phosphor | 
|  | 22 | { | 
|  | 23 | namespace dump | 
|  | 24 | { | 
|  | 25 | namespace elog | 
|  | 26 | { | 
|  | 27 |  | 
|  | 28 | using namespace phosphor::logging; | 
|  | 29 | constexpr auto LOG_PATH = "/xyz/openbmc_project/logging"; | 
| Jayanth Othayoth | d0f0064 | 2017-09-04 06:26:30 -0500 | [diff] [blame] | 30 | using Message = std::string; | 
| Patrick Williams | 984a98f | 2020-05-13 17:53:32 -0500 | [diff] [blame] | 31 | using Attributes = std::variant<Message>; | 
| Jayanth Othayoth | d0f0064 | 2017-09-04 06:26:30 -0500 | [diff] [blame] | 32 | using AttributeName = std::string; | 
|  | 33 | using AttributeMap = std::map<AttributeName, Attributes>; | 
|  | 34 | using PropertyName = std::string; | 
|  | 35 | using PropertyMap = std::map<PropertyName, AttributeMap>; | 
| Jayanth Othayoth | d0f0064 | 2017-09-04 06:26:30 -0500 | [diff] [blame] | 36 |  | 
| Patrick Williams | 9b18bf2 | 2022-07-22 19:26:55 -0500 | [diff] [blame] | 37 | Watch::Watch(sdbusplus::bus_t& bus, IMgr& iMgr) : | 
| Jayanth Othayoth | 2496482 | 2017-09-04 22:07:06 -0500 | [diff] [blame] | 38 | iMgr(iMgr), | 
| Jayanth Othayoth | cb65ffc | 2018-10-16 08:29:32 -0500 | [diff] [blame] | 39 | addMatch(bus, | 
|  | 40 | sdbusplus::bus::match::rules::interfacesAdded() + | 
|  | 41 | sdbusplus::bus::match::rules::path_namespace(OBJ_LOGGING), | 
|  | 42 | std::bind(std::mem_fn(&Watch::addCallback), this, | 
|  | 43 | std::placeholders::_1)), | 
|  | 44 | delMatch(bus, | 
|  | 45 | sdbusplus::bus::match::rules::interfacesRemoved() + | 
|  | 46 | sdbusplus::bus::match::rules::path_namespace(OBJ_LOGGING), | 
|  | 47 | std::bind(std::mem_fn(&Watch::delCallback), this, | 
|  | 48 | std::placeholders::_1)) | 
| Jayanth Othayoth | 2496482 | 2017-09-04 22:07:06 -0500 | [diff] [blame] | 49 | { | 
| Jayanth Othayoth | 3fc6df4 | 2021-04-08 03:45:24 -0500 | [diff] [blame] | 50 | std::filesystem::path file(ELOG_ID_PERSIST_PATH); | 
|  | 51 | if (std::filesystem::exists(file)) | 
| Jayanth Othayoth | 2496482 | 2017-09-04 22:07:06 -0500 | [diff] [blame] | 52 | { | 
|  | 53 | if (!deserialize(ELOG_ID_PERSIST_PATH, elogList)) | 
|  | 54 | { | 
|  | 55 | log<level::ERR>("Error occurred during error id deserialize"); | 
|  | 56 | } | 
|  | 57 | } | 
|  | 58 | } | 
|  | 59 |  | 
| Patrick Williams | 9b18bf2 | 2022-07-22 19:26:55 -0500 | [diff] [blame] | 60 | void Watch::addCallback(sdbusplus::message_t& msg) | 
| Jayanth Othayoth | d0f0064 | 2017-09-04 06:26:30 -0500 | [diff] [blame] | 61 | { | 
| Jayanth Othayoth | d0f0064 | 2017-09-04 06:26:30 -0500 | [diff] [blame] | 62 | using QuotaExceeded = | 
|  | 63 | sdbusplus::xyz::openbmc_project::Dump::Create::Error::QuotaExceeded; | 
|  | 64 |  | 
| William A. Kennington III | 90d147a | 2018-06-12 16:42:33 -0700 | [diff] [blame] | 65 | sdbusplus::message::object_path objectPath; | 
|  | 66 | PropertyMap propertyMap; | 
| William A. Kennington III | 15cd3ce | 2018-05-15 11:34:44 -0700 | [diff] [blame] | 67 | try | 
|  | 68 | { | 
| William A. Kennington III | 90d147a | 2018-06-12 16:42:33 -0700 | [diff] [blame] | 69 | msg.read(objectPath, propertyMap); | 
| William A. Kennington III | 15cd3ce | 2018-05-15 11:34:44 -0700 | [diff] [blame] | 70 | } | 
| Patrick Williams | 9b18bf2 | 2022-07-22 19:26:55 -0500 | [diff] [blame] | 71 | catch (const sdbusplus::exception_t& e) | 
| William A. Kennington III | 15cd3ce | 2018-05-15 11:34:44 -0700 | [diff] [blame] | 72 | { | 
| George Liu | 858fbb2 | 2021-07-01 12:25:44 +0800 | [diff] [blame] | 73 | log<level::ERR>( | 
|  | 74 | fmt::format( | 
|  | 75 | "Failed to parse elog add signal, errormsg({}), REPLY_SIG({})", | 
|  | 76 | e.what(), msg.get_signature()) | 
|  | 77 | .c_str()); | 
| William A. Kennington III | 15cd3ce | 2018-05-15 11:34:44 -0700 | [diff] [blame] | 78 | return; | 
|  | 79 | } | 
| Jayanth Othayoth | d0f0064 | 2017-09-04 06:26:30 -0500 | [diff] [blame] | 80 |  | 
| William A. Kennington III | 90d147a | 2018-06-12 16:42:33 -0700 | [diff] [blame] | 81 | std::size_t found = objectPath.str.find("entry"); | 
| Jayanth Othayoth | d0f0064 | 2017-09-04 06:26:30 -0500 | [diff] [blame] | 82 | if (found == std::string::npos) | 
|  | 83 | { | 
| Jayanth Othayoth | cb65ffc | 2018-10-16 08:29:32 -0500 | [diff] [blame] | 84 | // Not a new error entry skip | 
| Jayanth Othayoth | d0f0064 | 2017-09-04 06:26:30 -0500 | [diff] [blame] | 85 | return; | 
|  | 86 | } | 
|  | 87 |  | 
| Jayanth Othayoth | 2496482 | 2017-09-04 22:07:06 -0500 | [diff] [blame] | 88 | auto eId = getEid(objectPath); | 
|  | 89 |  | 
|  | 90 | auto search = elogList.find(eId); | 
|  | 91 | if (search != elogList.end()) | 
|  | 92 | { | 
| Jayanth Othayoth | cb65ffc | 2018-10-16 08:29:32 -0500 | [diff] [blame] | 93 | // elog exists in the list, Skip the dump | 
| Jayanth Othayoth | 2496482 | 2017-09-04 22:07:06 -0500 | [diff] [blame] | 94 | return; | 
|  | 95 | } | 
|  | 96 |  | 
| William A. Kennington III | 90d147a | 2018-06-12 16:42:33 -0700 | [diff] [blame] | 97 | auto iter = propertyMap.find("xyz.openbmc_project.Logging.Entry"); | 
|  | 98 | if (iter == propertyMap.end()) | 
| Jayanth Othayoth | d0f0064 | 2017-09-04 06:26:30 -0500 | [diff] [blame] | 99 | { | 
|  | 100 | return; | 
|  | 101 | } | 
|  | 102 |  | 
|  | 103 | auto attr = iter->second.find("Message"); | 
|  | 104 | if (attr == iter->second.end()) | 
|  | 105 | { | 
|  | 106 | return; | 
|  | 107 | } | 
|  | 108 |  | 
| Patrick Williams | 07f0f46 | 2020-05-13 11:58:11 -0500 | [diff] [blame] | 109 | auto& data = std::get<PropertyName>(attr->second); | 
| Jayanth Othayoth | d0f0064 | 2017-09-04 06:26:30 -0500 | [diff] [blame] | 110 | if (data.empty()) | 
|  | 111 | { | 
| Jayanth Othayoth | cb65ffc | 2018-10-16 08:29:32 -0500 | [diff] [blame] | 112 | // No Message skip | 
| Jayanth Othayoth | d0f0064 | 2017-09-04 06:26:30 -0500 | [diff] [blame] | 113 | return; | 
|  | 114 | } | 
|  | 115 |  | 
| Marri Devender Rao | 0deb287 | 2018-11-12 07:45:54 -0600 | [diff] [blame] | 116 | EType errorType; | 
|  | 117 | for (const auto& [type, errorList] : errorMap) | 
| Jayanth Othayoth | d0f0064 | 2017-09-04 06:26:30 -0500 | [diff] [blame] | 118 | { | 
| Marri Devender Rao | 0deb287 | 2018-11-12 07:45:54 -0600 | [diff] [blame] | 119 | auto error = std::find(errorList.begin(), errorList.end(), data); | 
|  | 120 | if (error != errorList.end()) | 
|  | 121 | { | 
|  | 122 | errorType = type; | 
|  | 123 | break; | 
|  | 124 | } | 
|  | 125 | } | 
|  | 126 |  | 
|  | 127 | // error not supported in the configuration | 
|  | 128 | if (errorType.empty()) | 
|  | 129 | { | 
| Jayanth Othayoth | d0f0064 | 2017-09-04 06:26:30 -0500 | [diff] [blame] | 130 | return; | 
|  | 131 | } | 
|  | 132 |  | 
|  | 133 | std::vector<std::string> fullPaths; | 
|  | 134 | fullPaths.push_back(objectPath); | 
|  | 135 |  | 
|  | 136 | try | 
|  | 137 | { | 
| Jayanth Othayoth | cb65ffc | 2018-10-16 08:29:32 -0500 | [diff] [blame] | 138 | // Save the elog information. This is to avoid dump requests | 
|  | 139 | // in elog restore path. | 
| Jayanth Othayoth | 2496482 | 2017-09-04 22:07:06 -0500 | [diff] [blame] | 140 | elogList.insert(eId); | 
|  | 141 |  | 
|  | 142 | phosphor::dump::elog::serialize(elogList); | 
|  | 143 |  | 
| Patrick Williams | 78e8840 | 2023-05-10 07:50:48 -0500 | [diff] [blame] | 144 | auto item = std::find_if(phosphor::dump::bmc::TypeMap.begin(), | 
|  | 145 | phosphor::dump::bmc::TypeMap.end(), | 
|  | 146 | [errorType](const auto& err) { | 
|  | 147 | return (err.second == errorType); | 
|  | 148 | }); | 
| Dhruvaraj Subhashchandran | fef66a9 | 2020-09-06 13:10:59 -0500 | [diff] [blame] | 149 | if (item != phosphor::dump::bmc::TypeMap.end()) | 
| Marri Devender Rao | 0deb287 | 2018-11-12 07:45:54 -0600 | [diff] [blame] | 150 | { | 
|  | 151 | iMgr.IMgr::create((*item).first, fullPaths); | 
|  | 152 | } | 
| Jayanth Othayoth | d0f0064 | 2017-09-04 06:26:30 -0500 | [diff] [blame] | 153 | } | 
| Patrick Williams | 9d2d722 | 2021-10-06 12:44:44 -0500 | [diff] [blame] | 154 | catch (const QuotaExceeded& e) | 
| Jayanth Othayoth | d0f0064 | 2017-09-04 06:26:30 -0500 | [diff] [blame] | 155 | { | 
| Jayanth Othayoth | cb65ffc | 2018-10-16 08:29:32 -0500 | [diff] [blame] | 156 | // No action now | 
| Jayanth Othayoth | d0f0064 | 2017-09-04 06:26:30 -0500 | [diff] [blame] | 157 | } | 
|  | 158 | return; | 
|  | 159 | } | 
|  | 160 |  | 
| Patrick Williams | 9b18bf2 | 2022-07-22 19:26:55 -0500 | [diff] [blame] | 161 | void Watch::delCallback(sdbusplus::message_t& msg) | 
| Jayanth Othayoth | 2496482 | 2017-09-04 22:07:06 -0500 | [diff] [blame] | 162 | { | 
| William A. Kennington III | 90d147a | 2018-06-12 16:42:33 -0700 | [diff] [blame] | 163 | sdbusplus::message::object_path objectPath; | 
| William A. Kennington III | 15cd3ce | 2018-05-15 11:34:44 -0700 | [diff] [blame] | 164 | try | 
|  | 165 | { | 
| William A. Kennington III | 90d147a | 2018-06-12 16:42:33 -0700 | [diff] [blame] | 166 | msg.read(objectPath); | 
| William A. Kennington III | 15cd3ce | 2018-05-15 11:34:44 -0700 | [diff] [blame] | 167 | } | 
| Patrick Williams | 9b18bf2 | 2022-07-22 19:26:55 -0500 | [diff] [blame] | 168 | catch (const sdbusplus::exception_t& e) | 
| William A. Kennington III | 15cd3ce | 2018-05-15 11:34:44 -0700 | [diff] [blame] | 169 | { | 
| George Liu | 858fbb2 | 2021-07-01 12:25:44 +0800 | [diff] [blame] | 170 | log<level::ERR>( | 
|  | 171 | fmt::format( | 
|  | 172 | "Failed to parse elog del signal, errormsg({}), REPLY_SIG({})", | 
|  | 173 | e.what(), msg.get_signature()) | 
|  | 174 | .c_str()); | 
| William A. Kennington III | 15cd3ce | 2018-05-15 11:34:44 -0700 | [diff] [blame] | 175 | return; | 
|  | 176 | } | 
| Jayanth Othayoth | 2496482 | 2017-09-04 22:07:06 -0500 | [diff] [blame] | 177 |  | 
| Andrew Geissler | 638b43f | 2020-04-16 13:33:33 -0500 | [diff] [blame] | 178 | std::size_t found = objectPath.str.find("entry"); | 
|  | 179 | if (found == std::string::npos) | 
|  | 180 | { | 
|  | 181 | // Not a error entry so skip | 
|  | 182 | return; | 
|  | 183 | } | 
|  | 184 |  | 
| Jayanth Othayoth | cb65ffc | 2018-10-16 08:29:32 -0500 | [diff] [blame] | 185 | // Get elog id | 
| Jayanth Othayoth | 2496482 | 2017-09-04 22:07:06 -0500 | [diff] [blame] | 186 | auto eId = getEid(objectPath); | 
|  | 187 |  | 
| Jayanth Othayoth | cb65ffc | 2018-10-16 08:29:32 -0500 | [diff] [blame] | 188 | // Delete the elog entry from the list and serialize | 
| Jayanth Othayoth | 2496482 | 2017-09-04 22:07:06 -0500 | [diff] [blame] | 189 | auto search = elogList.find(eId); | 
|  | 190 | if (search != elogList.end()) | 
|  | 191 | { | 
|  | 192 | elogList.erase(search); | 
|  | 193 | phosphor::dump::elog::serialize(elogList); | 
|  | 194 | } | 
|  | 195 | } | 
|  | 196 |  | 
| Jayanth Othayoth | cb65ffc | 2018-10-16 08:29:32 -0500 | [diff] [blame] | 197 | } // namespace elog | 
|  | 198 | } // namespace dump | 
|  | 199 | } // namespace phosphor |