blob: 3071271b3e164236df0467d0e3a282b9d70270da [file] [log] [blame]
Angel Pons32859fc2020-04-02 23:48:27 +02001/* SPDX-License-Identifier: GPL-2.0-only */
Duncan Laurie7d2b81c2012-06-23 16:08:47 -07002
3#ifndef ELOG_H_
4#define ELOG_H_
5
Elyes HAOUAS5817c562020-07-12 09:03:22 +02006#include <stdint.h>
7
Duncan Laurie7d2b81c2012-06-23 16:08:47 -07008#define MAX_EVENT_SIZE 0x7F
9
10/* End of log */
11#define ELOG_TYPE_EOL 0xFF
12
13/*
14 * Standard SMBIOS event log types below 0x80
15 */
16#define ELOG_TYPE_UNDEFINED_EVENT 0x00
17#define ELOG_TYPE_SINGLE_BIT_ECC_MEM_ERR 0x01
18#define ELOG_TYPE_MULTI_BIT_ECC_MEM_ERR 0x02
19#define ELOG_TYPE_MEM_PARITY_ERR 0x03
20#define ELOG_TYPE_BUS_TIMEOUT 0x04
21#define ELOG_TYPE_IO_CHECK 0x05
22#define ELOG_TYPE_SW_NMI 0x06
23#define ELOG_TYPE_POST_MEM_RESIZE 0x07
24#define ELOG_TYPE_POST_ERR 0x08
25#define ELOG_TYPE_PCI_PERR 0x09
26#define ELOG_TYPE_PCI_SERR 0x0A
27#define ELOG_TYPE_CPU_FAIL 0x0B
28#define ELOG_TYPE_EISA_TIMEOUT 0x0C
29#define ELOG_TYPE_CORRECTABLE_MEMLOG_DIS 0x0D
30#define ELOG_TYPE_LOG_DISABLED 0x0E
31#define ELOG_TYPE_UNDEFINED_EVENT2 0x0F
32#define ELOG_TYPE_SYS_LIMIT_EXCEED 0x10
33#define ELOG_TYPE_ASYNC_HW_TIMER_EXPIRED 0x11
34#define ELOG_TYPE_SYS_CONFIG_INFO 0x12
35#define ELOG_TYPE_HDD_INFO 0x13
36#define ELOG_TYPE_SYS_RECONFIG 0x14
37#define ELOG_TYPE_CPU_ERROR 0x15
38#define ELOG_TYPE_LOG_CLEAR 0x16
39#define ELOG_TYPE_BOOT 0x17
40
41/*
42 * Extended defined OEM event types start at 0x80
43 */
44
45/* OS/kernel events */
46#define ELOG_TYPE_OS_EVENT 0x81
47
48/* Last event from coreboot */
49#define ELOG_TYPE_OS_BOOT 0x90
50
51/* Embedded controller event */
52#define ELOG_TYPE_EC_EVENT 0x91
53
54/* Power */
55#define ELOG_TYPE_POWER_FAIL 0x92
56#define ELOG_TYPE_SUS_POWER_FAIL 0x93
57#define ELOG_TYPE_PWROK_FAIL 0x94
58#define ELOG_TYPE_SYS_PWROK_FAIL 0x95
59#define ELOG_TYPE_POWER_ON 0x96
60#define ELOG_TYPE_POWER_BUTTON 0x97
61#define ELOG_TYPE_POWER_BUTTON_OVERRIDE 0x98
62
63/* Reset */
64#define ELOG_TYPE_RESET_BUTTON 0x99
65#define ELOG_TYPE_SYSTEM_RESET 0x9a
66#define ELOG_TYPE_RTC_RESET 0x9b
67#define ELOG_TYPE_TCO_RESET 0x9c
68
69/* Sleep/Wake */
70#define ELOG_TYPE_ACPI_ENTER 0x9d
Richard Spiegele6809902018-08-20 13:51:30 -070071/*
72 * Deep Sx wake variant is provided below - 0xad
73 * Sleep/"wake pending" event log provided below - 0xb1 - 0x01/0x02
74 */
75
Duncan Laurie7d2b81c2012-06-23 16:08:47 -070076#define ELOG_TYPE_ACPI_WAKE 0x9e
77#define ELOG_TYPE_WAKE_SOURCE 0x9f
78#define ELOG_WAKE_SOURCE_PCIE 0x00
79#define ELOG_WAKE_SOURCE_PME 0x01
80#define ELOG_WAKE_SOURCE_PME_INTERNAL 0x02
81#define ELOG_WAKE_SOURCE_RTC 0x03
Aaron Durbinaa902032020-08-17 09:37:13 -060082#define ELOG_WAKE_SOURCE_GPE 0x04
Duncan Laurie7d2b81c2012-06-23 16:08:47 -070083#define ELOG_WAKE_SOURCE_SMBUS 0x05
Duncan Lauried6040902013-03-08 17:16:37 -080084#define ELOG_WAKE_SOURCE_PWRBTN 0x06
Furquan Shaikhb8581572017-05-25 00:13:01 -070085#define ELOG_WAKE_SOURCE_PME_HDA 0x07
86#define ELOG_WAKE_SOURCE_PME_GBE 0x08
87#define ELOG_WAKE_SOURCE_PME_EMMC 0x09
88#define ELOG_WAKE_SOURCE_PME_SDCARD 0x0a
89#define ELOG_WAKE_SOURCE_PME_PCIE1 0x0b
90#define ELOG_WAKE_SOURCE_PME_PCIE2 0x0c
91#define ELOG_WAKE_SOURCE_PME_PCIE3 0x0d
92#define ELOG_WAKE_SOURCE_PME_PCIE4 0x0e
93#define ELOG_WAKE_SOURCE_PME_PCIE5 0x0f
94#define ELOG_WAKE_SOURCE_PME_PCIE6 0x10
95#define ELOG_WAKE_SOURCE_PME_PCIE7 0x11
96#define ELOG_WAKE_SOURCE_PME_PCIE8 0x12
97#define ELOG_WAKE_SOURCE_PME_PCIE9 0x13
98#define ELOG_WAKE_SOURCE_PME_PCIE10 0x14
99#define ELOG_WAKE_SOURCE_PME_PCIE11 0x15
100#define ELOG_WAKE_SOURCE_PME_PCIE12 0x16
101#define ELOG_WAKE_SOURCE_PME_SATA 0x17
102#define ELOG_WAKE_SOURCE_PME_CSE 0x18
103#define ELOG_WAKE_SOURCE_PME_CSE2 0x19
104#define ELOG_WAKE_SOURCE_PME_CSE3 0x1a
105#define ELOG_WAKE_SOURCE_PME_XHCI 0x1b
106#define ELOG_WAKE_SOURCE_PME_XDCI 0x1c
Furquan Shaikh0f1dc0e2017-06-08 15:46:42 -0700107#define ELOG_WAKE_SOURCE_PME_XHCI_USB_2 0x1d
108#define ELOG_WAKE_SOURCE_PME_XHCI_USB_3 0x1e
Naresh G Solanki3c6377f2017-07-03 21:57:11 +0530109#define ELOG_WAKE_SOURCE_PME_WIFI 0x1f
Michael Niewöhnerbc36e292019-10-02 20:07:16 +0200110#define ELOG_WAKE_SOURCE_PME_PCIE13 0x20
111#define ELOG_WAKE_SOURCE_PME_PCIE14 0x21
112#define ELOG_WAKE_SOURCE_PME_PCIE15 0x22
113#define ELOG_WAKE_SOURCE_PME_PCIE16 0x23
114#define ELOG_WAKE_SOURCE_PME_PCIE17 0x24
115#define ELOG_WAKE_SOURCE_PME_PCIE18 0x25
116#define ELOG_WAKE_SOURCE_PME_PCIE19 0x26
117#define ELOG_WAKE_SOURCE_PME_PCIE20 0x27
118#define ELOG_WAKE_SOURCE_PME_PCIE21 0x28
119#define ELOG_WAKE_SOURCE_PME_PCIE22 0x29
120#define ELOG_WAKE_SOURCE_PME_PCIE23 0x2a
121#define ELOG_WAKE_SOURCE_PME_PCIE24 0x2b
Aaron Durbinb4e28df2020-08-17 16:27:27 -0600122#define ELOG_WAKE_SOURCE_GPIO 0x2c
Tim Wawrzynczakf1b4a7c2020-11-10 09:55:57 -0700123#define ELOG_WAKE_SOURCE_PME_TBT 0x2d
124#define ELOG_WAKE_SOURCE_PME_TCSS_XHCI 0x2e
125#define ELOG_WAKE_SOURCE_PME_TCSS_XDCI 0x2f
126#define ELOG_WAKE_SOURCE_PME_TCSS_DMA 0x30
Vadim Bendeburyb9126fe2017-03-22 16:16:34 -0700127
Duncan Laurie7d2b81c2012-06-23 16:08:47 -0700128struct elog_event_data_wake {
129 u8 source;
130 u32 instance;
Stefan Reinauer6a001132017-07-13 02:20:27 +0200131} __packed;
Duncan Laurie7d2b81c2012-06-23 16:08:47 -0700132
133/* Chrome OS related events */
134#define ELOG_TYPE_CROS_DEVELOPER_MODE 0xa0
135#define ELOG_TYPE_CROS_RECOVERY_MODE 0xa1
Duncan Laurie8de88442012-07-16 12:47:45 -0700136#define ELOG_CROS_RECOVERY_MODE_BUTTON 0x02
Duncan Laurie7d2b81c2012-06-23 16:08:47 -0700137
Duncan Lauriec1c94352012-07-13 10:11:54 -0700138/* Management Engine Events */
139#define ELOG_TYPE_MANAGEMENT_ENGINE 0xa2
Duncan Laurie5c88c6f2012-09-01 14:00:23 -0700140#define ELOG_TYPE_MANAGEMENT_ENGINE_EXT 0xa4
141struct elog_event_data_me_extended {
142 u8 current_working_state;
143 u8 operation_state;
144 u8 operation_mode;
145 u8 error_code;
146 u8 progress_code;
147 u8 current_pmevent;
148 u8 current_state;
Stefan Reinauer6a001132017-07-13 02:20:27 +0200149} __packed;
Duncan Lauriec1c94352012-07-13 10:11:54 -0700150
Duncan Laurie4dceba22012-08-13 09:40:02 -0700151/* Last post code from previous boot */
152#define ELOG_TYPE_LAST_POST_CODE 0xa3
Duncan Lauried5686fe2013-06-10 10:21:41 -0700153#define ELOG_TYPE_POST_EXTRA 0xa6
Duncan Laurie4dceba22012-08-13 09:40:02 -0700154
Duncan Laurie19afe8d2012-11-26 14:53:42 -0800155/* EC Shutdown Reason */
156#define ELOG_TYPE_EC_SHUTDOWN 0xa5
157
Aaron Durbind5be4e32016-11-04 10:53:43 -0500158/* ARM/generic versions of sleep/wake - These came from another firmware
159 * apparently, but not all the firmware sources were updated so that the
160 * elog namespace was coherent. */
161#define ELOG_TYPE_SLEEP 0xa7
162#define ELOG_TYPE_WAKE 0xa8
163#define ELOG_TYPE_FW_WAKE 0xa9
164
Aaron Durbin7d9068f2016-11-04 10:07:14 -0500165/* Memory Cache Update */
166#define ELOG_TYPE_MEM_CACHE_UPDATE 0xaa
167#define ELOG_MEM_CACHE_UPDATE_SLOT_NORMAL 0
Furquan Shaikhcab1c012016-11-05 23:57:02 -0700168#define ELOG_MEM_CACHE_UPDATE_SLOT_RECOVERY 1
Andrey Petrovef9a9ea2016-11-08 08:30:06 -0800169#define ELOG_MEM_CACHE_UPDATE_SLOT_VARIABLE 2
Aaron Durbin7d9068f2016-11-04 10:07:14 -0500170#define ELOG_MEM_CACHE_UPDATE_STATUS_SUCCESS 0
171#define ELOG_MEM_CACHE_UPDATE_STATUS_FAIL 1
172struct elog_event_mem_cache_update {
173 u8 slot;
174 u8 status;
Stefan Reinauer6a001132017-07-13 02:20:27 +0200175} __packed;
Aaron Durbin7d9068f2016-11-04 10:07:14 -0500176
Duncan Laurie6cbd3982017-03-05 14:35:57 -0800177/* CPU Thermal Trip */
178#define ELOG_TYPE_THERM_TRIP 0xab
179
Vadim Bendeburyb9126fe2017-03-22 16:16:34 -0700180/* Cr50 */
181#define ELOG_TYPE_CR50_UPDATE 0xac
182
Furquan Shaikh75ef6ec2017-05-19 10:50:02 -0700183/* Deep Sx wake variant */
184#define ELOG_TYPE_ACPI_DEEP_WAKE 0xad
185
Duncan Laurieb14aefe2017-06-29 23:53:48 -0700186/* EC Device Event */
187#define ELOG_TYPE_EC_DEVICE_EVENT 0xae
188#define ELOG_EC_DEVICE_EVENT_TRACKPAD 0x01
189#define ELOG_EC_DEVICE_EVENT_DSP 0x02
190#define ELOG_EC_DEVICE_EVENT_WIFI 0x03
191
Furquan Shaikh2dc5ead2017-10-14 18:12:25 -0700192/* S0ix sleep/wake */
193#define ELOG_TYPE_S0IX_ENTER 0xaf
194#define ELOG_TYPE_S0IX_EXIT 0xb0
195
Richard Spiegele6809902018-08-20 13:51:30 -0700196/* Extended events */
197#define ELOG_TYPE_EXTENDED_EVENT 0xb1
198#define ELOG_SLEEP_PENDING_PM1_WAKE 0x01
199#define ELOG_SLEEP_PENDING_GPE0_WAKE 0x02
200
Keith Shorte0f34002019-02-05 16:15:10 -0700201/* Cr50 reset to enable TPM */
202#define ELOG_TYPE_CR50_NEED_RESET 0xb2
203
derek.huang18e632f2020-04-24 17:35:59 +0800204/* CSME-Initiated Host Reset */
205#define ELOG_TYPE_MI_HRPD 0xb3
206#define ELOG_TYPE_MI_HRPC 0xb4
207#define ELOG_TYPE_MI_HR 0xb5
208
Richard Spiegele6809902018-08-20 13:51:30 -0700209struct elog_event_extended_event {
210 u8 event_type;
211 u32 event_complement;
212} __packed;
213
Julius Wernercd49cce2019-03-05 16:53:33 -0800214#if CONFIG(ELOG)
David Hendricks9acbd6f2014-04-13 16:45:31 -0700215/* Eventlog backing storage must be initialized before calling elog_init(). */
Duncan Laurie7d2b81c2012-06-23 16:08:47 -0700216extern int elog_init(void);
217extern int elog_clear(void);
Aaron Durbineec1c282016-08-06 10:02:37 -0500218/* Event addition functions return < 0 on failure and 0 on success. */
219extern int elog_add_event_raw(u8 event_type, void *data, u8 data_size);
220extern int elog_add_event(u8 event_type);
221extern int elog_add_event_byte(u8 event_type, u8 data);
222extern int elog_add_event_word(u8 event_type, u16 data);
223extern int elog_add_event_dword(u8 event_type, u32 data);
224extern int elog_add_event_wake(u8 source, u32 instance);
Duncan Laurie472ec9c2012-06-23 16:13:42 -0700225extern int elog_smbios_write_type15(unsigned long *current, int handle);
Richard Spiegele6809902018-08-20 13:51:30 -0700226extern int elog_add_extended_event(u8 type, u32 complement);
David Hendricksd0d57a72014-05-08 20:04:02 -0700227#else
228/* Stubs to help avoid littering sources with #if CONFIG_ELOG */
229static inline int elog_init(void) { return -1; }
230static inline int elog_clear(void) { return -1; }
Aaron Durbind9b10502016-11-04 11:17:54 -0500231static inline int elog_add_event_raw(u8 event_type, void *data,
232 u8 data_size) { return 0; }
Aaron Durbineec1c282016-08-06 10:02:37 -0500233static inline int elog_add_event(u8 event_type) { return 0; }
234static inline int elog_add_event_byte(u8 event_type, u8 data) { return 0; }
235static inline int elog_add_event_word(u8 event_type, u16 data) { return 0; }
236static inline int elog_add_event_dword(u8 event_type, u32 data) { return 0; }
237static inline int elog_add_event_wake(u8 source, u32 instance) { return 0; }
David Hendricksd0d57a72014-05-08 20:04:02 -0700238static inline int elog_smbios_write_type15(unsigned long *current,
239 int handle) {
240 return 0;
241}
Richard Spiegele6809902018-08-20 13:51:30 -0700242static inline int elog_add_extended_event(u8 type, u32 complement) { return 0; }
David Hendricksd0d57a72014-05-08 20:04:02 -0700243#endif
Duncan Laurie7d2b81c2012-06-23 16:08:47 -0700244
Kyösti Mälkki9dd1a122019-11-06 11:04:27 +0200245#if CONFIG(ELOG_GSMI)
246#define elog_gsmi_add_event elog_add_event
247#define elog_gsmi_add_event_byte elog_add_event_byte
248#define elog_gsmi_add_event_word elog_add_event_word
249#else
250static inline int elog_gsmi_add_event(u8 event_type) { return 0; }
251static inline int elog_gsmi_add_event_byte(u8 event_type, u8 data) { return 0; }
252static inline int elog_gsmi_add_event_word(u8 event_type, u16 data) { return 0; }
253#endif
254
Duncan Laurie79bbbd92012-06-23 16:48:38 -0700255extern u32 gsmi_exec(u8 command, u32 *param);
Duncan Laurie79bbbd92012-06-23 16:48:38 -0700256
Julius Wernercd49cce2019-03-05 16:53:33 -0800257#if CONFIG(ELOG_BOOT_COUNT)
Duncan Laurief4d36232012-06-23 16:37:45 -0700258u32 boot_count_read(void);
Daniel Kurtzf55c3c22018-05-24 18:00:45 -0600259#else
260static inline u32 boot_count_read(void)
261{
262 return 0;
263}
264#endif
Duncan Laurief4d36232012-06-23 16:37:45 -0700265u32 boot_count_increment(void);
Duncan Laurief4d36232012-06-23 16:37:45 -0700266
Kyösti Mälkki7f50afb2019-09-11 17:12:26 +0300267static inline void elog_boot_notify(int s3_resume)
268{
269 if (CONFIG(ELOG_BOOT_COUNT) && !s3_resume)
270 boot_count_increment();
271}
272
Furquan Shaikh2dc5ead2017-10-14 18:12:25 -0700273/*
274 * Callback from GSMI handler to allow platform to log any wake source
275 * information.
276 */
277void elog_gsmi_cb_platform_log_wake_source(void);
278
279/*
280 * Callback from GSMI handler to allow mainboard to log any wake source
281 * information.
282 */
283void elog_gsmi_cb_mainboard_log_wake_source(void);
284
Duncan Laurie7d2b81c2012-06-23 16:08:47 -0700285#endif /* ELOG_H_ */