1// SPDX-License-Identifier: GPL-2.0
2// Trace events for the ChromeOS Embedded Controller
3//
4// Copyright 2019 Google LLC.
5
6#define TRACE_SYMBOL(a) {a, #a}
7
8// Generate the list using the following script:
9// sed -n 's/^#define \(EC_CMD_[[:alnum:]_]*\)\s.*/\tTRACE_SYMBOL(\1), \\/p' include/linux/platform_data/cros_ec_commands.h
10#define EC_CMDS \
11 TRACE_SYMBOL(EC_CMD_ACPI_READ), \
12 TRACE_SYMBOL(EC_CMD_ACPI_WRITE), \
13 TRACE_SYMBOL(EC_CMD_ACPI_BURST_ENABLE), \
14 TRACE_SYMBOL(EC_CMD_ACPI_BURST_DISABLE), \
15 TRACE_SYMBOL(EC_CMD_ACPI_QUERY_EVENT), \
16 TRACE_SYMBOL(EC_CMD_PROTO_VERSION), \
17 TRACE_SYMBOL(EC_CMD_HELLO), \
18 TRACE_SYMBOL(EC_CMD_GET_VERSION), \
19 TRACE_SYMBOL(EC_CMD_READ_TEST), \
20 TRACE_SYMBOL(EC_CMD_GET_BUILD_INFO), \
21 TRACE_SYMBOL(EC_CMD_GET_CHIP_INFO), \
22 TRACE_SYMBOL(EC_CMD_GET_BOARD_VERSION), \
23 TRACE_SYMBOL(EC_CMD_READ_MEMMAP), \
24 TRACE_SYMBOL(EC_CMD_GET_CMD_VERSIONS), \
25 TRACE_SYMBOL(EC_CMD_GET_COMMS_STATUS), \
26 TRACE_SYMBOL(EC_CMD_TEST_PROTOCOL), \
27 TRACE_SYMBOL(EC_CMD_GET_PROTOCOL_INFO), \
28 TRACE_SYMBOL(EC_CMD_GSV_PAUSE_IN_S5), \
29 TRACE_SYMBOL(EC_CMD_GET_FEATURES), \
30 TRACE_SYMBOL(EC_CMD_GET_SKU_ID), \
31 TRACE_SYMBOL(EC_CMD_SET_SKU_ID), \
32 TRACE_SYMBOL(EC_CMD_FLASH_INFO), \
33 TRACE_SYMBOL(EC_CMD_FLASH_READ), \
34 TRACE_SYMBOL(EC_CMD_FLASH_WRITE), \
35 TRACE_SYMBOL(EC_CMD_FLASH_ERASE), \
36 TRACE_SYMBOL(EC_CMD_FLASH_PROTECT), \
37 TRACE_SYMBOL(EC_CMD_FLASH_REGION_INFO), \
38 TRACE_SYMBOL(EC_CMD_VBNV_CONTEXT), \
39 TRACE_SYMBOL(EC_CMD_FLASH_SPI_INFO), \
40 TRACE_SYMBOL(EC_CMD_FLASH_SELECT), \
41 TRACE_SYMBOL(EC_CMD_PWM_GET_FAN_TARGET_RPM), \
42 TRACE_SYMBOL(EC_CMD_PWM_SET_FAN_TARGET_RPM), \
43 TRACE_SYMBOL(EC_CMD_PWM_GET_KEYBOARD_BACKLIGHT), \
44 TRACE_SYMBOL(EC_CMD_PWM_SET_KEYBOARD_BACKLIGHT), \
45 TRACE_SYMBOL(EC_CMD_PWM_SET_FAN_DUTY), \
46 TRACE_SYMBOL(EC_CMD_PWM_SET_DUTY), \
47 TRACE_SYMBOL(EC_CMD_PWM_GET_DUTY), \
48 TRACE_SYMBOL(EC_CMD_LIGHTBAR_CMD), \
49 TRACE_SYMBOL(EC_CMD_LED_CONTROL), \
50 TRACE_SYMBOL(EC_CMD_VBOOT_HASH), \
51 TRACE_SYMBOL(EC_CMD_MOTION_SENSE_CMD), \
52 TRACE_SYMBOL(EC_CMD_FORCE_LID_OPEN), \
53 TRACE_SYMBOL(EC_CMD_CONFIG_POWER_BUTTON), \
54 TRACE_SYMBOL(EC_CMD_USB_CHARGE_SET_MODE), \
55 TRACE_SYMBOL(EC_CMD_PSTORE_INFO), \
56 TRACE_SYMBOL(EC_CMD_PSTORE_READ), \
57 TRACE_SYMBOL(EC_CMD_PSTORE_WRITE), \
58 TRACE_SYMBOL(EC_CMD_RTC_GET_VALUE), \
59 TRACE_SYMBOL(EC_CMD_RTC_GET_ALARM), \
60 TRACE_SYMBOL(EC_CMD_RTC_SET_VALUE), \
61 TRACE_SYMBOL(EC_CMD_RTC_SET_ALARM), \
62 TRACE_SYMBOL(EC_CMD_PORT80_LAST_BOOT), \
63 TRACE_SYMBOL(EC_CMD_PORT80_READ), \
64 TRACE_SYMBOL(EC_CMD_VSTORE_INFO), \
65 TRACE_SYMBOL(EC_CMD_VSTORE_READ), \
66 TRACE_SYMBOL(EC_CMD_VSTORE_WRITE), \
67 TRACE_SYMBOL(EC_CMD_THERMAL_SET_THRESHOLD), \
68 TRACE_SYMBOL(EC_CMD_THERMAL_GET_THRESHOLD), \
69 TRACE_SYMBOL(EC_CMD_THERMAL_AUTO_FAN_CTRL), \
70 TRACE_SYMBOL(EC_CMD_TMP006_GET_CALIBRATION), \
71 TRACE_SYMBOL(EC_CMD_TMP006_SET_CALIBRATION), \
72 TRACE_SYMBOL(EC_CMD_TMP006_GET_RAW), \
73 TRACE_SYMBOL(EC_CMD_MKBP_STATE), \
74 TRACE_SYMBOL(EC_CMD_MKBP_INFO), \
75 TRACE_SYMBOL(EC_CMD_MKBP_SIMULATE_KEY), \
76 TRACE_SYMBOL(EC_CMD_GET_KEYBOARD_ID), \
77 TRACE_SYMBOL(EC_CMD_MKBP_SET_CONFIG), \
78 TRACE_SYMBOL(EC_CMD_MKBP_GET_CONFIG), \
79 TRACE_SYMBOL(EC_CMD_KEYSCAN_SEQ_CTRL), \
80 TRACE_SYMBOL(EC_CMD_GET_NEXT_EVENT), \
81 TRACE_SYMBOL(EC_CMD_KEYBOARD_FACTORY_TEST), \
82 TRACE_SYMBOL(EC_CMD_TEMP_SENSOR_GET_INFO), \
83 TRACE_SYMBOL(EC_CMD_HOST_EVENT_GET_B), \
84 TRACE_SYMBOL(EC_CMD_HOST_EVENT_GET_SMI_MASK), \
85 TRACE_SYMBOL(EC_CMD_HOST_EVENT_GET_SCI_MASK), \
86 TRACE_SYMBOL(EC_CMD_HOST_EVENT_GET_WAKE_MASK), \
87 TRACE_SYMBOL(EC_CMD_HOST_EVENT_SET_SMI_MASK), \
88 TRACE_SYMBOL(EC_CMD_HOST_EVENT_SET_SCI_MASK), \
89 TRACE_SYMBOL(EC_CMD_HOST_EVENT_CLEAR), \
90 TRACE_SYMBOL(EC_CMD_HOST_EVENT_SET_WAKE_MASK), \
91 TRACE_SYMBOL(EC_CMD_HOST_EVENT_CLEAR_B), \
92 TRACE_SYMBOL(EC_CMD_HOST_EVENT), \
93 TRACE_SYMBOL(EC_CMD_SWITCH_ENABLE_BKLIGHT), \
94 TRACE_SYMBOL(EC_CMD_SWITCH_ENABLE_WIRELESS), \
95 TRACE_SYMBOL(EC_CMD_GPIO_SET), \
96 TRACE_SYMBOL(EC_CMD_GPIO_GET), \
97 TRACE_SYMBOL(EC_CMD_I2C_READ), \
98 TRACE_SYMBOL(EC_CMD_I2C_WRITE), \
99 TRACE_SYMBOL(EC_CMD_CHARGE_CONTROL), \
100 TRACE_SYMBOL(EC_CMD_CONSOLE_SNAPSHOT), \
101 TRACE_SYMBOL(EC_CMD_CONSOLE_READ), \
102 TRACE_SYMBOL(EC_CMD_BATTERY_CUT_OFF), \
103 TRACE_SYMBOL(EC_CMD_USB_MUX), \
104 TRACE_SYMBOL(EC_CMD_LDO_SET), \
105 TRACE_SYMBOL(EC_CMD_LDO_GET), \
106 TRACE_SYMBOL(EC_CMD_POWER_INFO), \
107 TRACE_SYMBOL(EC_CMD_I2C_PASSTHRU), \
108 TRACE_SYMBOL(EC_CMD_HANG_DETECT), \
109 TRACE_SYMBOL(EC_CMD_CHARGE_STATE), \
110 TRACE_SYMBOL(EC_CMD_CHARGE_CURRENT_LIMIT), \
111 TRACE_SYMBOL(EC_CMD_EXTERNAL_POWER_LIMIT), \
112 TRACE_SYMBOL(EC_CMD_OVERRIDE_DEDICATED_CHARGER_LIMIT), \
113 TRACE_SYMBOL(EC_CMD_HIBERNATION_DELAY), \
114 TRACE_SYMBOL(EC_CMD_HOST_SLEEP_EVENT), \
115 TRACE_SYMBOL(EC_CMD_DEVICE_EVENT), \
116 TRACE_SYMBOL(EC_CMD_SB_READ_WORD), \
117 TRACE_SYMBOL(EC_CMD_SB_WRITE_WORD), \
118 TRACE_SYMBOL(EC_CMD_SB_READ_BLOCK), \
119 TRACE_SYMBOL(EC_CMD_SB_WRITE_BLOCK), \
120 TRACE_SYMBOL(EC_CMD_BATTERY_VENDOR_PARAM), \
121 TRACE_SYMBOL(EC_CMD_SB_FW_UPDATE), \
122 TRACE_SYMBOL(EC_CMD_ENTERING_MODE), \
123 TRACE_SYMBOL(EC_CMD_I2C_PASSTHRU_PROTECT), \
124 TRACE_SYMBOL(EC_CMD_CEC_WRITE_MSG), \
125 TRACE_SYMBOL(EC_CMD_CEC_SET), \
126 TRACE_SYMBOL(EC_CMD_CEC_GET), \
127 TRACE_SYMBOL(EC_CMD_EC_CODEC), \
128 TRACE_SYMBOL(EC_CMD_EC_CODEC_DMIC), \
129 TRACE_SYMBOL(EC_CMD_EC_CODEC_I2S_RX), \
130 TRACE_SYMBOL(EC_CMD_EC_CODEC_WOV), \
131 TRACE_SYMBOL(EC_CMD_REBOOT_EC), \
132 TRACE_SYMBOL(EC_CMD_GET_PANIC_INFO), \
133 TRACE_SYMBOL(EC_CMD_REBOOT), \
134 TRACE_SYMBOL(EC_CMD_RESEND_RESPONSE), \
135 TRACE_SYMBOL(EC_CMD_VERSION0), \
136 TRACE_SYMBOL(EC_CMD_PD_EXCHANGE_STATUS), \
137 TRACE_SYMBOL(EC_CMD_PD_HOST_EVENT_STATUS), \
138 TRACE_SYMBOL(EC_CMD_USB_PD_CONTROL), \
139 TRACE_SYMBOL(EC_CMD_USB_PD_PORTS), \
140 TRACE_SYMBOL(EC_CMD_USB_PD_POWER_INFO), \
141 TRACE_SYMBOL(EC_CMD_CHARGE_PORT_COUNT), \
142 TRACE_SYMBOL(EC_CMD_USB_PD_FW_UPDATE), \
143 TRACE_SYMBOL(EC_CMD_USB_PD_RW_HASH_ENTRY), \
144 TRACE_SYMBOL(EC_CMD_USB_PD_DEV_INFO), \
145 TRACE_SYMBOL(EC_CMD_USB_PD_DISCOVERY), \
146 TRACE_SYMBOL(EC_CMD_PD_CHARGE_PORT_OVERRIDE), \
147 TRACE_SYMBOL(EC_CMD_PD_GET_LOG_ENTRY), \
148 TRACE_SYMBOL(EC_CMD_USB_PD_GET_AMODE), \
149 TRACE_SYMBOL(EC_CMD_USB_PD_SET_AMODE), \
150 TRACE_SYMBOL(EC_CMD_PD_WRITE_LOG_ENTRY), \
151 TRACE_SYMBOL(EC_CMD_PD_CONTROL), \
152 TRACE_SYMBOL(EC_CMD_USB_PD_MUX_INFO), \
153 TRACE_SYMBOL(EC_CMD_PD_CHIP_INFO), \
154 TRACE_SYMBOL(EC_CMD_RWSIG_CHECK_STATUS), \
155 TRACE_SYMBOL(EC_CMD_RWSIG_ACTION), \
156 TRACE_SYMBOL(EC_CMD_EFS_VERIFY), \
157 TRACE_SYMBOL(EC_CMD_GET_CROS_BOARD_INFO), \
158 TRACE_SYMBOL(EC_CMD_SET_CROS_BOARD_INFO), \
159 TRACE_SYMBOL(EC_CMD_GET_UPTIME_INFO), \
160 TRACE_SYMBOL(EC_CMD_ADD_ENTROPY), \
161 TRACE_SYMBOL(EC_CMD_ADC_READ), \
162 TRACE_SYMBOL(EC_CMD_ROLLBACK_INFO), \
163 TRACE_SYMBOL(EC_CMD_AP_RESET), \
164 TRACE_SYMBOL(EC_CMD_REGULATOR_GET_INFO), \
165 TRACE_SYMBOL(EC_CMD_REGULATOR_ENABLE), \
166 TRACE_SYMBOL(EC_CMD_REGULATOR_IS_ENABLED), \
167 TRACE_SYMBOL(EC_CMD_REGULATOR_SET_VOLTAGE), \
168 TRACE_SYMBOL(EC_CMD_REGULATOR_GET_VOLTAGE), \
169 TRACE_SYMBOL(EC_CMD_CR51_BASE), \
170 TRACE_SYMBOL(EC_CMD_CR51_LAST), \
171 TRACE_SYMBOL(EC_CMD_FP_PASSTHRU), \
172 TRACE_SYMBOL(EC_CMD_FP_MODE), \
173 TRACE_SYMBOL(EC_CMD_FP_INFO), \
174 TRACE_SYMBOL(EC_CMD_FP_FRAME), \
175 TRACE_SYMBOL(EC_CMD_FP_TEMPLATE), \
176 TRACE_SYMBOL(EC_CMD_FP_CONTEXT), \
177 TRACE_SYMBOL(EC_CMD_FP_STATS), \
178 TRACE_SYMBOL(EC_CMD_FP_SEED), \
179 TRACE_SYMBOL(EC_CMD_FP_ENC_STATUS), \
180 TRACE_SYMBOL(EC_CMD_TP_SELF_TEST), \
181 TRACE_SYMBOL(EC_CMD_TP_FRAME_INFO), \
182 TRACE_SYMBOL(EC_CMD_TP_FRAME_SNAPSHOT), \
183 TRACE_SYMBOL(EC_CMD_TP_FRAME_GET), \
184 TRACE_SYMBOL(EC_CMD_BATTERY_GET_STATIC), \
185 TRACE_SYMBOL(EC_CMD_BATTERY_GET_DYNAMIC), \
186 TRACE_SYMBOL(EC_CMD_CHARGER_CONTROL), \
187 TRACE_SYMBOL(EC_CMD_BOARD_SPECIFIC_BASE), \
188 TRACE_SYMBOL(EC_CMD_BOARD_SPECIFIC_LAST)
189
190/* See the enum ec_status in include/linux/platform_data/cros_ec_commands.h */
191#define EC_RESULT \
192 TRACE_SYMBOL(EC_RES_SUCCESS), \
193 TRACE_SYMBOL(EC_RES_INVALID_COMMAND), \
194 TRACE_SYMBOL(EC_RES_ERROR), \
195 TRACE_SYMBOL(EC_RES_INVALID_PARAM), \
196 TRACE_SYMBOL(EC_RES_ACCESS_DENIED), \
197 TRACE_SYMBOL(EC_RES_INVALID_RESPONSE), \
198 TRACE_SYMBOL(EC_RES_INVALID_VERSION), \
199 TRACE_SYMBOL(EC_RES_INVALID_CHECKSUM), \
200 TRACE_SYMBOL(EC_RES_IN_PROGRESS), \
201 TRACE_SYMBOL(EC_RES_UNAVAILABLE), \
202 TRACE_SYMBOL(EC_RES_TIMEOUT), \
203 TRACE_SYMBOL(EC_RES_OVERFLOW), \
204 TRACE_SYMBOL(EC_RES_INVALID_HEADER), \
205 TRACE_SYMBOL(EC_RES_REQUEST_TRUNCATED), \
206 TRACE_SYMBOL(EC_RES_RESPONSE_TOO_BIG), \
207 TRACE_SYMBOL(EC_RES_BUS_ERROR), \
208 TRACE_SYMBOL(EC_RES_BUSY), \
209 TRACE_SYMBOL(EC_RES_INVALID_HEADER_VERSION), \
210 TRACE_SYMBOL(EC_RES_INVALID_HEADER_CRC), \
211 TRACE_SYMBOL(EC_RES_INVALID_DATA_CRC), \
212 TRACE_SYMBOL(EC_RES_DUP_UNAVAILABLE)
213
214#define CREATE_TRACE_POINTS
215#include "cros_ec_trace.h"
216

source code of linux/drivers/platform/chrome/cros_ec_trace.c