blob: 5d360817da027ed2404148c82c2bc943c0670c0d [file] [log] [blame]
Duncan Laurie7d2b81c2012-06-23 16:08:47 -07001/*
2 * This file is part of the coreboot project.
3 *
4 * Copyright (C) 2012 The ChromiumOS Authors. All rights reserved.
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; version 2 of the License.
9 *
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 *
15 * You should have received a copy of the GNU General Public License
16 * along with this program; if not, write to the Free Software
17 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA, 02110-1301 USA
18 */
19
20#ifndef ELOG_H_
21#define ELOG_H_
22
Duncan Laurie7d2b81c2012-06-23 16:08:47 -070023/* SMI command code for GSMI event logging */
24#define ELOG_GSMI_APM_CNT 0xEF
25
26#define MAX_EVENT_SIZE 0x7F
27
28/* End of log */
29#define ELOG_TYPE_EOL 0xFF
30
31/*
32 * Standard SMBIOS event log types below 0x80
33 */
34#define ELOG_TYPE_UNDEFINED_EVENT 0x00
35#define ELOG_TYPE_SINGLE_BIT_ECC_MEM_ERR 0x01
36#define ELOG_TYPE_MULTI_BIT_ECC_MEM_ERR 0x02
37#define ELOG_TYPE_MEM_PARITY_ERR 0x03
38#define ELOG_TYPE_BUS_TIMEOUT 0x04
39#define ELOG_TYPE_IO_CHECK 0x05
40#define ELOG_TYPE_SW_NMI 0x06
41#define ELOG_TYPE_POST_MEM_RESIZE 0x07
42#define ELOG_TYPE_POST_ERR 0x08
43#define ELOG_TYPE_PCI_PERR 0x09
44#define ELOG_TYPE_PCI_SERR 0x0A
45#define ELOG_TYPE_CPU_FAIL 0x0B
46#define ELOG_TYPE_EISA_TIMEOUT 0x0C
47#define ELOG_TYPE_CORRECTABLE_MEMLOG_DIS 0x0D
48#define ELOG_TYPE_LOG_DISABLED 0x0E
49#define ELOG_TYPE_UNDEFINED_EVENT2 0x0F
50#define ELOG_TYPE_SYS_LIMIT_EXCEED 0x10
51#define ELOG_TYPE_ASYNC_HW_TIMER_EXPIRED 0x11
52#define ELOG_TYPE_SYS_CONFIG_INFO 0x12
53#define ELOG_TYPE_HDD_INFO 0x13
54#define ELOG_TYPE_SYS_RECONFIG 0x14
55#define ELOG_TYPE_CPU_ERROR 0x15
56#define ELOG_TYPE_LOG_CLEAR 0x16
57#define ELOG_TYPE_BOOT 0x17
58
59/*
60 * Extended defined OEM event types start at 0x80
61 */
62
63/* OS/kernel events */
64#define ELOG_TYPE_OS_EVENT 0x81
65
66/* Last event from coreboot */
67#define ELOG_TYPE_OS_BOOT 0x90
68
69/* Embedded controller event */
70#define ELOG_TYPE_EC_EVENT 0x91
Duncan Laurie39f6bb62012-09-10 10:03:46 -070071#define EC_EVENT_LID_CLOSED 0x01
72#define EC_EVENT_LID_OPEN 0x02
73#define EC_EVENT_POWER_BUTTON 0x03
74#define EC_EVENT_AC_CONNECTED 0x04
75#define EC_EVENT_AC_DISCONNECTED 0x05
76#define EC_EVENT_BATTERY_LOW 0x06
77#define EC_EVENT_BATTERY_CRITICAL 0x07
78#define EC_EVENT_BATTERY 0x08
79#define EC_EVENT_THERMAL_THRESHOLD 0x09
80#define EC_EVENT_THERMAL_OVERLOAD 0x0a
81#define EC_EVENT_THERMAL 0x0b
82#define EC_EVENT_USB_CHARGER 0x0c
83#define EC_EVENT_KEY_PRESSED 0x0d
84#define EC_EVENT_INTERFACE_READY 0x0e
85#define EC_EVENT_KEYBOARD_RECOVERY 0x0f
86#define EC_EVENT_THERMAL_SHUTDOWN 0x10
87#define EC_EVENT_BATTERY_SHUTDOWN 0x11
Marc Jones35bd3fe2012-09-24 22:14:24 -060088#define EC_EVENT_FAN_ERROR 0x12
Duncan Laurie7d2b81c2012-06-23 16:08:47 -070089
90/* Power */
91#define ELOG_TYPE_POWER_FAIL 0x92
92#define ELOG_TYPE_SUS_POWER_FAIL 0x93
93#define ELOG_TYPE_PWROK_FAIL 0x94
94#define ELOG_TYPE_SYS_PWROK_FAIL 0x95
95#define ELOG_TYPE_POWER_ON 0x96
96#define ELOG_TYPE_POWER_BUTTON 0x97
97#define ELOG_TYPE_POWER_BUTTON_OVERRIDE 0x98
98
99/* Reset */
100#define ELOG_TYPE_RESET_BUTTON 0x99
101#define ELOG_TYPE_SYSTEM_RESET 0x9a
102#define ELOG_TYPE_RTC_RESET 0x9b
103#define ELOG_TYPE_TCO_RESET 0x9c
104
105/* Sleep/Wake */
106#define ELOG_TYPE_ACPI_ENTER 0x9d
107#define ELOG_TYPE_ACPI_WAKE 0x9e
108#define ELOG_TYPE_WAKE_SOURCE 0x9f
109#define ELOG_WAKE_SOURCE_PCIE 0x00
110#define ELOG_WAKE_SOURCE_PME 0x01
111#define ELOG_WAKE_SOURCE_PME_INTERNAL 0x02
112#define ELOG_WAKE_SOURCE_RTC 0x03
113#define ELOG_WAKE_SOURCE_GPIO 0x04
114#define ELOG_WAKE_SOURCE_SMBUS 0x05
Duncan Lauried6040902013-03-08 17:16:37 -0800115#define ELOG_WAKE_SOURCE_PWRBTN 0x06
Duncan Laurie7d2b81c2012-06-23 16:08:47 -0700116struct elog_event_data_wake {
117 u8 source;
118 u32 instance;
119} __attribute__ ((packed));
120
121/* Chrome OS related events */
122#define ELOG_TYPE_CROS_DEVELOPER_MODE 0xa0
123#define ELOG_TYPE_CROS_RECOVERY_MODE 0xa1
Duncan Laurie8de88442012-07-16 12:47:45 -0700124#define ELOG_CROS_RECOVERY_MODE_BUTTON 0x02
Duncan Laurie7d2b81c2012-06-23 16:08:47 -0700125
Duncan Lauriec1c94352012-07-13 10:11:54 -0700126/* Management Engine Events */
127#define ELOG_TYPE_MANAGEMENT_ENGINE 0xa2
Duncan Laurie5c88c6f2012-09-01 14:00:23 -0700128#define ELOG_TYPE_MANAGEMENT_ENGINE_EXT 0xa4
129struct elog_event_data_me_extended {
130 u8 current_working_state;
131 u8 operation_state;
132 u8 operation_mode;
133 u8 error_code;
134 u8 progress_code;
135 u8 current_pmevent;
136 u8 current_state;
137} __attribute__ ((packed));
Duncan Lauriec1c94352012-07-13 10:11:54 -0700138
Duncan Laurie4dceba22012-08-13 09:40:02 -0700139/* Last post code from previous boot */
140#define ELOG_TYPE_LAST_POST_CODE 0xa3
Duncan Lauried5686fe2013-06-10 10:21:41 -0700141#define ELOG_TYPE_POST_EXTRA 0xa6
Duncan Laurie4dceba22012-08-13 09:40:02 -0700142
Duncan Laurie19afe8d2012-11-26 14:53:42 -0800143/* EC Shutdown Reason */
144#define ELOG_TYPE_EC_SHUTDOWN 0xa5
145
Duncan Lauriedaecc442014-05-12 10:20:45 -0700146/* CPU Thermal Trip */
147#define ELOG_TYPE_THERM_TRIP 0xa7
148
David Hendricksd0d57a72014-05-08 20:04:02 -0700149#if CONFIG_ELOG
David Hendricks9acbd6f2014-04-13 16:45:31 -0700150/* Eventlog backing storage must be initialized before calling elog_init(). */
Duncan Laurie7d2b81c2012-06-23 16:08:47 -0700151extern int elog_init(void);
152extern int elog_clear(void);
153extern void elog_add_event_raw(u8 event_type, void *data, u8 data_size);
154extern void elog_add_event(u8 event_type);
155extern void elog_add_event_byte(u8 event_type, u8 data);
156extern void elog_add_event_word(u8 event_type, u16 data);
157extern void elog_add_event_dword(u8 event_type, u32 data);
158extern void elog_add_event_wake(u8 source, u32 instance);
Duncan Laurie472ec9c2012-06-23 16:13:42 -0700159extern int elog_smbios_write_type15(unsigned long *current, int handle);
David Hendricksd0d57a72014-05-08 20:04:02 -0700160#else
161/* Stubs to help avoid littering sources with #if CONFIG_ELOG */
162static inline int elog_init(void) { return -1; }
163static inline int elog_clear(void) { return -1; }
164static inline void elog_add_event_raw(void) { return; }
165static inline void elog_add_event(u8 event_type) { return; }
166static inline void elog_add_event_byte(u8 event_type, u8 data) { return; }
167static inline void elog_add_event_word(u8 event_type, u16 data) { return; }
168static inline void elog_add_event_dword(u8 event_type, u32 data) { return; }
169static inline void elog_add_event_wake(u8 source, u32 instance) { return; }
170static inline int elog_smbios_write_type15(unsigned long *current,
171 int handle) {
172 return 0;
173}
174#endif
Duncan Laurie7d2b81c2012-06-23 16:08:47 -0700175
Duncan Laurie79bbbd92012-06-23 16:48:38 -0700176#if CONFIG_ELOG_GSMI
177extern u32 gsmi_exec(u8 command, u32 *param);
178#endif
179
Duncan Laurief4d36232012-06-23 16:37:45 -0700180#if CONFIG_ELOG_BOOT_COUNT
181u32 boot_count_read(void);
182u32 boot_count_increment(void);
Edward O'Callaghan5c971422014-04-15 14:32:53 +1000183#else
184static inline u32 boot_count_read(void) { return 0; }
185#endif /* CONFIG_ELOG_BOOT_COUNT */
Duncan Laurief4d36232012-06-23 16:37:45 -0700186
Duncan Laurie7d2b81c2012-06-23 16:08:47 -0700187#endif /* ELOG_H_ */