blob: 32aee2408c099a9f5c86a4954f1373e4c76348fa [file] [log] [blame]
Zane Shelley0b8368c2021-03-18 17:33:41 -05001#pragma once
2
3#include <analyzer/service_data.hpp>
4
5namespace analyzer
6{
7
8/** @brief An abstract class for service event resolutions. */
9class Resolution
10{
11 public:
12 /** @brief Pure virtual destructor. */
13 virtual ~Resolution() = 0;
14
15 public:
16 /**
17 * @brief Resolves the service actions required by this resolution.
18 * @param io_sd An object containing the service data collected during
19 * hardware error analysis.
20 */
21 virtual void resolve(ServiceData& io_sd) const = 0;
22};
23
24// Pure virtual destructor must be defined.
25inline Resolution::~Resolution() {}
26
27/** @brief Resolves a hardware callout service event. */
28class HardwareCalloutResolution : public Resolution
29{
30 public:
31 /**
32 * @brief Constructor from components.
33 * @param i_path The devtree path of a guardable unit relative to a
34 * chip. An empty string refers to the chip itself.
35 * @param i_priority The callout priority.
36 * @param i_guard The guard type for this callout.
37 */
38 HardwareCalloutResolution(const std::string& i_path,
39 Callout::Priority i_priority,
40 Guard::Type i_guard) :
41 iv_path(i_path),
42 iv_priority(i_priority), iv_guard(i_guard)
43 {}
44
45 private:
46 /** The devtree path of a guardable unit relative to a chip. An empty string
47 * refers to the chip itself. */
48 const std::string iv_path;
49
50 /** The callout priority. */
51 const Callout::Priority iv_priority;
52
53 /** The guard type for this callout. */
54 const Guard::Type iv_guard;
55
56 public:
57 void resolve(ServiceData& io_sd) const override;
58};
59
60/** @brief Resolves a procedure callout service event. */
61class ProcedureCalloutResolution : public Resolution
62{
63 public:
64 /**
65 * @brief Constructor from components.
66 * @param i_procedure The procedure callout type.
67 * @param i_priority The callout priority.
68 */
69 ProcedureCalloutResolution(ProcedureCallout::Type i_procedure,
70 Callout::Priority i_priority) :
71 iv_procedure(i_procedure),
72 iv_priority(i_priority)
73 {}
74
75 private:
76 /** The procedure callout type. */
77 const ProcedureCallout::Type iv_procedure;
78
79 /** The callout priority. */
80 const Callout::Priority iv_priority;
81
82 public:
83 void resolve(ServiceData& io_sd) const override
84 {
85 // Simply add the procedure to the callout list.
86 io_sd.addCallout(
87 std::make_shared<ProcedureCallout>(iv_procedure, iv_priority));
88 }
89};
90
91/**
Zane Shelley723fa232021-08-09 12:02:06 -050092 * @brief Contains a list of resolutions. This resolutions will be resolved the
93 * list in the order in which they were inputted into the constructor.
Zane Shelley0b8368c2021-03-18 17:33:41 -050094 */
Zane Shelley723fa232021-08-09 12:02:06 -050095class ResolutionList : public Resolution
Zane Shelley0b8368c2021-03-18 17:33:41 -050096{
97 public:
Zane Shelley723fa232021-08-09 12:02:06 -050098 /** @brief Default constructor. */
99 ResolutionList() = default;
Zane Shelley0b8368c2021-03-18 17:33:41 -0500100
101 private:
Zane Shelley723fa232021-08-09 12:02:06 -0500102 /** The resolution list. */
103 std::vector<std::shared_ptr<Resolution>> iv_list;
Zane Shelley0b8368c2021-03-18 17:33:41 -0500104
105 public:
Zane Shelley723fa232021-08-09 12:02:06 -0500106 /**
107 * @brief Adds a new resolution to the end of the list.
108 * @param i_resolution The new resolution
109 */
110 void push(const std::shared_ptr<Resolution>& i_resolution)
111 {
112 iv_list.push_back(i_resolution);
113 }
114
115 // Overloaded from parent.
Zane Shelley0b8368c2021-03-18 17:33:41 -0500116 void resolve(ServiceData& io_sd) const override
117 {
Zane Shelley723fa232021-08-09 12:02:06 -0500118 for (const auto& e : iv_list)
119 {
120 e->resolve(io_sd);
121 }
Zane Shelley0b8368c2021-03-18 17:33:41 -0500122 }
123};
124
125} // namespace analyzer