blob: 770f6e925b4986a76e09f48102239449755af974 [file] [log] [blame]
Ben Tyneref320152020-01-09 10:31:23 -06001#pragma once
2
Ben Tyner3fb52e52020-03-31 10:10:07 -05003#include <attn/attn_config.hpp>
4
Ben Tyner73ac3682020-01-09 10:46:47 -06005namespace attn
6{
7
Ben Tynerdbeaf792020-05-14 08:27:18 -05008/** @brief Attention handler return codes */
9enum ReturnCodes
10{
Ben Tyner4bbcb382021-02-22 09:29:00 -060011 RC_SUCCESS = 0,
12 RC_NOT_HANDLED = 1,
13 RC_ANALYZER_ERROR = 2,
14 RC_CFAM_ERROR = 3,
15 RC_DBUS_ERROR = 4
Ben Tynerdbeaf792020-05-14 08:27:18 -050016};
17
Ben Tyner7a0dd542021-02-12 09:33:44 -060018/** @brief Code seciton for error reporing */
19enum class AttnSection
20{
21 reserved = 0x0000,
22 attnHandler = 0x0100,
23 tiHandler = 0x0200,
24 handlePhypTi = 0x0300,
25 handleHbTi = 0x0400
26};
27
28/** @brief Attention handler error reason codes */
Ben Tyner29651ef2021-02-08 10:51:03 -060029enum AttnCodes
30{
31 ATTN_NO_ERROR = 0,
Ben Tyner7a0dd542021-02-12 09:33:44 -060032 ATTN_INFO_NULL = 1,
33 ATTN_PDBG_CFAM = 2
Ben Tyner29651ef2021-02-08 10:51:03 -060034};
35
Ben Tynerfb190542020-11-06 09:27:56 -060036/** @brief Attention global status bits */
37constexpr uint32_t SBE_ATTN = 0x00000002;
38constexpr uint32_t CHECKSTOP_ATTN = 0x40000000;
39constexpr uint32_t SPECIAL_ATTN = 0x20000000;
40
Ben Tynerb24b2202021-02-08 09:06:10 -060041// Need to add defaultOpalTiInfo with SRC BB821410 (ascii)
42
43constexpr uint8_t defaultPhypTiInfo[0x58] = {
44 0x01, 0xa1, 0x02, 0xa8, 0x00, 0x00, 0x00, 0x01, 0x02, 0x00, 0x00,
45 0x09, 0x00, 0x00, 0x00, 0x48, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
46 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
47 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
48 0x00, 0x00, 0x00, 0x00, 0x42, 0x37, 0x30, 0x30, 0x46, 0x46, 0x46,
49 0x46, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20,
50 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20,
51 0x20, 0x20, 0x20, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
52
Ben Tyner4bbcb382021-02-22 09:29:00 -060053constexpr uint8_t defaultHbTiInfo[0x58] = {
54 0x01, 0xa1, 0x02, 0xa8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
55 0x09, 0x01, 0x00, 0x00, 0x00, 0xbc, 0x80, 0x1b, 0x99, 0x00, 0x00,
56 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
57 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
58 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
59 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
60 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
61 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
62
Ben Tyneref320152020-01-09 10:31:23 -060063/**
64 * @brief The main attention handler logic
65 *
66 * Check each processor for active attentions of type SBE Vital (vital),
Ben Tyner7a0dd542021-02-12 09:33:44 -060067 * System Checkstop (checkstop) and Special Attention (special) and handle
68 * each as follows:
Ben Tyneref320152020-01-09 10:31:23 -060069 *
Ben Tyner3fb52e52020-03-31 10:10:07 -050070 * checkstop: Call hardware error analyzer
Ben Tyneref320152020-01-09 10:31:23 -060071 * vital: TBD
72 * special: Determine if the special attention is a Breakpoint (BP),
Ben Tyner7a0dd542021-02-12 09:33:44 -060073 * Terminate Immediately (TI) or CoreCodeToSp (corecode). For each
74 * special attention type, do the following:
Ben Tyneref320152020-01-09 10:31:23 -060075 *
76 * BP: Notify Cronus
Ben Tyner3fb52e52020-03-31 10:10:07 -050077 * TI: Start host diagnostics mode systemd unit
Ben Tyneref320152020-01-09 10:31:23 -060078 * Corecode: TBD
Ben Tyner970fd4f2020-02-19 13:46:42 -060079 *
Ben Tyner3fb52e52020-03-31 10:10:07 -050080 * @param i_config pointer to attention handler configuration object
Ben Tyneref320152020-01-09 10:31:23 -060081 */
Ben Tyner3fb52e52020-03-31 10:10:07 -050082void attnHandler(Config* i_config);
Ben Tyner73ac3682020-01-09 10:46:47 -060083
84} // namespace attn