aboutsummaryrefslogtreecommitdiffstats
path: root/roms/skiboot/include/op-panel.h
diff options
context:
space:
mode:
Diffstat (limited to 'roms/skiboot/include/op-panel.h')
-rw-r--r--roms/skiboot/include/op-panel.h58
1 files changed, 58 insertions, 0 deletions
diff --git a/roms/skiboot/include/op-panel.h b/roms/skiboot/include/op-panel.h
new file mode 100644
index 000000000..7a4451285
--- /dev/null
+++ b/roms/skiboot/include/op-panel.h
@@ -0,0 +1,58 @@
+// SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later
+/* Copyright 2013-2019 IBM Corp. */
+
+#ifndef __OP_PANEL_H
+#define __OP_PANEL_H
+
+#include <stdint.h>
+
+/* Operator Panel Dimensions */
+#define OP_PANEL_NUM_LINES 2
+#define OP_PANEL_LINE_LEN 16
+
+/* Severity */
+enum op_severity {
+ OP_LOG = 0x4342, /* 'CB' - Progress info */
+ OP_WARN = 0x4542, /* 'EB' - Information condition */
+ OP_ERROR = 0x4442, /* 'DB' - Non fatal error */
+ OP_FATAL = 0x4242, /* 'BB' - Fatal error */
+};
+
+/* Module */
+enum op_module {
+ OP_MOD_CORE = 0x3030, /* '00' - Anything really */
+ OP_MOD_INIT = 0x3031, /* '01' - init */
+ OP_MOD_LOCK = 0x3032, /* '02' - spinlocks */
+ OP_MOD_FSP = 0x3033, /* '03' - FSP */
+ OP_MOD_FSPCON = 0x3034, /* '04' - FSPCON */
+ OP_MOD_CHIPTOD = 0x3035, /* '05' - ChipTOP */
+ OP_MOD_CPU = 0x3036, /* '06' - CPU bringup */
+ OP_MOD_MEM = 0x3037, /* '07' - Memory */
+};
+
+/* Common codes:
+ *
+ * 'BA010001' : Failed to load a kernel
+ * 'BA010002' : Failed to create a device-tree
+ * 'BA020000' : Locking already owned lock
+ * 'BA020001' : Unlocking unlocked lock
+ * 'BA020002' : Unlocking not-owned lock
+ * 'BA006666' : Abort
+ * 'BA050000' : Failed ChipTOD init/sync
+ * 'BA050001' : Failed to find a CPU on the master chip
+ * 'BA050002' : Master chip sync failed
+ * 'EA05xxx2' : Slave sync failed (xxx = PIR)
+ * 'BA070000' : Cannot find MS VPD or invalid
+ * 'BA070001' : MS VPD wrong size
+ * 'BA070002' : MS VPD doesn't have an MSAC
+ * 'BA070003' : MS VPD doesn't have a total config
+ */
+
+extern void op_display(enum op_severity, enum op_module, uint16_t code);
+extern void op_display_lpc(enum op_severity s, enum op_module m, uint16_t c);
+
+extern void op_panel_disable_src_echo(void);
+extern void op_panel_clear_src(void);
+extern void fsp_oppanel_init(void);
+
+#endif /* __OP_PANEL_H */