blob: 7a44512854835a27c2c1d950e5e990724a2263eb [file] [log] [blame]
// 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 */