xref: /openbmc/openpower-occ-control/occ_ffdc.hpp (revision 9789e71f254c4f543c5eabffb0c4ac963b605eb9)
1 #pragma once
2 
3 #include "config.h"
4 
5 #include "occ_errors.hpp"
6 
7 namespace open_power
8 {
9 namespace occ
10 {
11 
12 /** @class FFDC
13  *  @brief Monitors for SBE FFDC availability
14  */
15 class FFDC : public Error
16 {
17   public:
18     FFDC() = delete;
19     FFDC(const FFDC&) = delete;
20     FFDC& operator=(const FFDC&) = delete;
21     FFDC(FFDC&&) = default;
22     FFDC& operator=(FFDC&&) = default;
23 
24     /** @brief Constructs the FFDC object
25      *
26      *  @param[in] event    - reference to sd_event unique_ptr
27      *  @param[in] file     - File used by driver to communicate FFDC data
28      *  @param[in] instance - OCC instance number
29      */
30     FFDC(EventPtr& event, const fs::path& file, unsigned int instance) :
31         Error(event, file, nullptr), instance(instance)
32     {
33         // Nothing to do here.
34     }
35 
36     ~FFDC()
37     {
38         for (auto&& it : temporaryFiles)
39         {
40             close(it.second);
41             fs::remove(it.first);
42         }
43     }
44 
45     /** @brief Helper function to create a PEL with the OpenPower DBus
46      *         interface
47      *
48      * @param[in] path - the DBus error path
49      * @param[in] src6 - the SBE error SRC6 word
50      * @param[in] msg - the error message
51      * @param[in] fd - the file descriptor for any FFDC
52      */
53     static uint32_t createPEL(const char* path, uint32_t src6, const char* msg,
54                               int fd = -1);
55 
56     /** @brief Helper function to create a PEL for the OCC reset with the
57      * OpenPower DBus interface
58      *
59      * @param[in] instance - the OCC instance id
60      * @param[in] path - the DBus error path
61      * @param[in] err - the error return code
62      * @param[in] callout - the PEL callout path
63      */
64     static void createOCCResetPEL(unsigned int instance, const char* path,
65                                   int err, const char* callout);
66 
67   private:
68     /** @brief OCC instance number. Ex, 0,1, etc */
69     unsigned int instance;
70 
71     /** @brief Stores the temporary files and file descriptors
72      *         in usage. They will be cleaned up when the class
73      *         is destroyed (when the application exits).
74      */
75     std::vector<std::pair<fs::path, int>> temporaryFiles;
76 
77     /** @brief When the error event is received, analyzes it
78      *         and makes a callback to error handler if the
79      *         content denotes an error condition
80      */
81     void analyzeEvent() override;
82 };
83 
84 } // namespace occ
85 } // namespace open_power
86