Zephyr API Documentation 4.4.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
espi.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2019 Intel Corporation.
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
12
13#ifndef ZEPHYR_INCLUDE_ESPI_H_
14#define ZEPHYR_INCLUDE_ESPI_H_
15
16#include <errno.h>
17
18#include <zephyr/sys/__assert.h>
19#include <zephyr/types.h>
20#include <zephyr/device.h>
21#include <zephyr/sys/slist.h>
22
23#ifdef __cplusplus
24extern "C" {
25#endif
26
34
46
96
113
151
163
168#define ESPI_PERIPHERAL_INDEX_0 0ul
169#define ESPI_PERIPHERAL_INDEX_1 1ul
170#define ESPI_PERIPHERAL_INDEX_2 2ul
171
172/* eSPI specification defines eSPI target and eSPI controller terms
173 * note that sometimes eSPI controller is also referred as eSPI host
174 */
175
176#define ESPI_TARGET_TO_CONTROLLER 0ul
177#define ESPI_CONTROLLER_TO_TARGET 1ul
178
179#define ESPI_VWIRE_SRC_ID0 0ul
180#define ESPI_VWIRE_SRC_ID1 1ul
181#define ESPI_VWIRE_SRC_ID2 2ul
182#define ESPI_VWIRE_SRC_ID3 3ul
183#define ESPI_VWIRE_SRC_ID_MAX 4ul
184
185#define ESPI_PERIPHERAL_NODATA 0ul
186
187#define E8042_START_OPCODE 0x50
188#define E8042_MAX_OPCODE 0x5F
189
190#define EACPI_START_OPCODE 0x60
191#define EACPI_MAX_OPCODE 0x6F
192
193#define ECUSTOM_START_OPCODE 0xF0
194#define ECUSTOM_MAX_OPCODE 0xFF
195
197
227
254
260#define ESPI_INT_ALL_MASK (ESPI_BUS_EVENTS | ESPI_VIRTUAL_WIRE_CHANNEL_EVENTS | \
261 ESPI_OOB_CHANNEL_EVENTS | ESPI_FLASH_CHANNEL_EVENTS | \
262 ESPI_PERIPHERAL_DEBUG_PORT80_EVENTS | ESPI_PERIPHERAL_8042_KBC_EVENTS | \
263 ESPI_PERIPHERAL_HOST_IO_EVENTS | ESPI_PERIPHERAL_SHARED_MEMORY_EVENTS)
264
266#define ESPI_INT_BUS_ONLY_MASK (ESPI_BUS_EVENTS | ESPI_VIRTUAL_WIRE_CHANNEL_EVENTS | \
267 ESPI_OOB_CHANNEL_EVENTS | ESPI_FLASH_CHANNEL_EVENTS)
268
270#define ESPI_INT_NONE_MASK 0U
271
272
296
302 /* Virtual wires that can only be send from controller to target */
319
320 /* Virtual wires that can only be sent from target to controller */
334
335 /*
336 * Virtual wire GPIOs that can be sent from target to controller for
337 * platform specific usage.
338 */
351
354};
355
361#define ESPI_VWIRE_SIGNAL_OCB_0 ESPI_VWIRE_SIGNAL_TARGET_GPIO_0
363#define ESPI_VWIRE_SIGNAL_OCB_1 ESPI_VWIRE_SIGNAL_TARGET_GPIO_1
365#define ESPI_VWIRE_SIGNAL_OCB_2 ESPI_VWIRE_SIGNAL_TARGET_GPIO_2
367#define ESPI_VWIRE_SIGNAL_OCB_3 ESPI_VWIRE_SIGNAL_TARGET_GPIO_3
369
377 /* Read transactions */
380 /* Write transactions */
383 /* Write transactions without input parameters */
387 /* Status transactions */
391 /* ACPI read transactions */
392 EACPI_OBF_HAS_CHAR = EACPI_START_OPCODE,
394 /* ACPI write transactions */
396 /* ACPI status transactions */
399#if defined(CONFIG_ESPI_PERIPHERAL_ACPI_SHM_REGION) || defined(__DOXYGEN__)
405#endif /* CONFIG_ESPI_PERIPHERAL_ACPI_SHM_REGION */
406#if defined(CONFIG_ESPI_PERIPHERAL_CUSTOM_OPCODE) || defined(__DOXYGEN__)
407 /* Other customized transactions */
413 ECUSTOM_HOST_SUBS_INTERRUPT_EN = ECUSTOM_START_OPCODE,
429#endif /* CONFIG_ESPI_PERIPHERAL_CUSTOM_OPCODE */
430};
431
433#define HOST_KBC_EVT_IBF BIT(0)
435#define HOST_KBC_EVT_OBE BIT(1)
436
453
468
483
508
520
539
558
573
584struct espi_callback;
585
594typedef void (*espi_callback_handler_t) (const struct device *dev,
595 struct espi_callback *cb,
596 struct espi_event espi_evt);
597
601struct espi_callback {
603 sys_snode_t node;
604
607
613 enum espi_bus_event evt_type;
614};
616
624typedef int (*espi_api_config)(const struct device *dev, struct espi_cfg *cfg);
625typedef bool (*espi_api_get_channel_status)(const struct device *dev,
626 enum espi_channel ch);
627/* Logical Channel 0 APIs */
628typedef int (*espi_api_read_request)(const struct device *dev,
629 struct espi_request_packet *req);
630typedef int (*espi_api_write_request)(const struct device *dev,
631 struct espi_request_packet *req);
632typedef int (*espi_api_lpc_read_request)(const struct device *dev,
633 enum lpc_peripheral_opcode op,
634 uint32_t *data);
635typedef int (*espi_api_lpc_write_request)(const struct device *dev,
636 enum lpc_peripheral_opcode op,
637 uint32_t *data);
638/* Logical Channel 1 APIs */
639typedef int (*espi_api_send_vwire)(const struct device *dev,
640 enum espi_vwire_signal vw,
641 uint8_t level);
642typedef int (*espi_api_receive_vwire)(const struct device *dev,
643 enum espi_vwire_signal vw,
644 uint8_t *level);
645/* Logical Channel 2 APIs */
646typedef int (*espi_api_send_oob)(const struct device *dev,
647 struct espi_oob_packet *pckt);
648typedef int (*espi_api_receive_oob)(const struct device *dev,
649 struct espi_oob_packet *pckt);
650/* Logical Channel 3 APIs */
651typedef int (*espi_api_flash_read)(const struct device *dev,
652 struct espi_flash_packet *pckt);
653typedef int (*espi_api_flash_write)(const struct device *dev,
654 struct espi_flash_packet *pckt);
655typedef int (*espi_api_flash_erase)(const struct device *dev,
656 struct espi_flash_packet *pckt);
657
658/* Callbacks and traffic intercept */
659typedef int (*espi_api_manage_callback)(const struct device *dev,
660 struct espi_callback *callback,
661 bool set);
662
663/* eSPI interrupt control */
664typedef int (*espi_api_interrupt_configure)(const struct device *dev,
666 uint32_t espi_interrupt_vendor);
667
668__subsystem struct espi_driver_api {
669 espi_api_config config;
670 espi_api_get_channel_status get_channel_status;
671 espi_api_read_request read_request;
672 espi_api_write_request write_request;
673 espi_api_lpc_read_request read_lpc_request;
674 espi_api_lpc_write_request write_lpc_request;
675 espi_api_send_vwire send_vwire;
676 espi_api_receive_vwire receive_vwire;
677 espi_api_send_oob send_oob;
678 espi_api_receive_oob receive_oob;
679 espi_api_flash_read flash_read;
680 espi_api_flash_write flash_write;
681 espi_api_flash_erase flash_erase;
682 espi_api_manage_callback manage_callback;
683 espi_api_interrupt_configure interrupt_config;
684};
685
689
738__syscall int espi_config(const struct device *dev, struct espi_cfg *cfg);
739
740static inline int z_impl_espi_config(const struct device *dev,
741 struct espi_cfg *cfg)
742{
743 return DEVICE_API_GET(espi, dev)->config(dev, cfg);
744}
745
758__syscall bool espi_get_channel_status(const struct device *dev,
759 enum espi_channel ch);
760
761static inline bool z_impl_espi_get_channel_status(const struct device *dev,
762 enum espi_channel ch)
763{
764 return DEVICE_API_GET(espi, dev)->get_channel_status(dev, ch);
765}
766
781__syscall int espi_read_request(const struct device *dev,
782 struct espi_request_packet *req);
783
784static inline int z_impl_espi_read_request(const struct device *dev,
785 struct espi_request_packet *req)
786{
787 const struct espi_driver_api *api = DEVICE_API_GET(espi, dev);
788
789 if (!api->read_request) {
790 return -ENOTSUP;
791 }
792
793 return api->read_request(dev, req);
794}
795
810__syscall int espi_write_request(const struct device *dev,
811 struct espi_request_packet *req);
812
813static inline int z_impl_espi_write_request(const struct device *dev,
814 struct espi_request_packet *req)
815{
816 const struct espi_driver_api *api = DEVICE_API_GET(espi, dev);
817
818 if (!api->write_request) {
819 return -ENOTSUP;
820 }
821
822 return api->write_request(dev, req);
823}
824
841__syscall int espi_read_lpc_request(const struct device *dev,
842 enum lpc_peripheral_opcode op,
843 uint32_t *data);
844
845static inline int z_impl_espi_read_lpc_request(const struct device *dev,
846 enum lpc_peripheral_opcode op,
847 uint32_t *data)
848{
849 const struct espi_driver_api *api = DEVICE_API_GET(espi, dev);
850
851 if (!api->read_lpc_request) {
852 return -ENOTSUP;
853 }
854
855 return api->read_lpc_request(dev, op, data);
856}
857
873__syscall int espi_write_lpc_request(const struct device *dev,
874 enum lpc_peripheral_opcode op,
875 uint32_t *data);
876
877static inline int z_impl_espi_write_lpc_request(const struct device *dev,
878 enum lpc_peripheral_opcode op,
879 uint32_t *data)
880{
881 const struct espi_driver_api *api = DEVICE_API_GET(espi, dev);
882
883 if (!api->write_lpc_request) {
884 return -ENOTSUP;
885 }
886
887 return api->write_lpc_request(dev, op, data);
888}
889
905__syscall int espi_send_vwire(const struct device *dev,
907 uint8_t level);
908
909static inline int z_impl_espi_send_vwire(const struct device *dev,
911 uint8_t level)
912{
913 return DEVICE_API_GET(espi, dev)->send_vwire(dev, signal, level);
914}
915
928__syscall int espi_receive_vwire(const struct device *dev,
930 uint8_t *level);
931
932static inline int z_impl_espi_receive_vwire(const struct device *dev,
934 uint8_t *level)
935{
936 return DEVICE_API_GET(espi, dev)->receive_vwire(dev, signal, level);
937}
938
950__syscall int espi_send_oob(const struct device *dev,
951 struct espi_oob_packet *pckt);
952
953static inline int z_impl_espi_send_oob(const struct device *dev,
954 struct espi_oob_packet *pckt)
955{
956 const struct espi_driver_api *api = DEVICE_API_GET(espi, dev);
957
958 if (!api->send_oob) {
959 return -ENOTSUP;
960 }
961
962 return api->send_oob(dev, pckt);
963}
964
976__syscall int espi_receive_oob(const struct device *dev,
977 struct espi_oob_packet *pckt);
978
979static inline int z_impl_espi_receive_oob(const struct device *dev,
980 struct espi_oob_packet *pckt)
981{
982 const struct espi_driver_api *api = DEVICE_API_GET(espi, dev);
983
984 if (!api->receive_oob) {
985 return -ENOTSUP;
986 }
987
988 return api->receive_oob(dev, pckt);
989}
990
1004__syscall int espi_read_flash(const struct device *dev,
1005 struct espi_flash_packet *pckt);
1006
1007static inline int z_impl_espi_read_flash(const struct device *dev,
1008 struct espi_flash_packet *pckt)
1009{
1010 const struct espi_driver_api *api = DEVICE_API_GET(espi, dev);
1011
1012 if (!api->flash_read) {
1013 return -ENOTSUP;
1014 }
1015
1016 return api->flash_read(dev, pckt);
1017}
1018
1032__syscall int espi_write_flash(const struct device *dev,
1033 struct espi_flash_packet *pckt);
1034
1035static inline int z_impl_espi_write_flash(const struct device *dev,
1036 struct espi_flash_packet *pckt)
1037{
1038 const struct espi_driver_api *api = DEVICE_API_GET(espi, dev);
1039
1040 if (!api->flash_write) {
1041 return -ENOTSUP;
1042 }
1043
1044 return api->flash_write(dev, pckt);
1045}
1046
1060__syscall int espi_flash_erase(const struct device *dev,
1061 struct espi_flash_packet *pckt);
1062
1063static inline int z_impl_espi_flash_erase(const struct device *dev,
1064 struct espi_flash_packet *pckt)
1065{
1066 const struct espi_driver_api *api = DEVICE_API_GET(espi, dev);
1067
1068 if (!api->flash_erase) {
1069 return -ENOTSUP;
1070 }
1071
1072 return api->flash_erase(dev, pckt);
1073}
1074
1137
1146static inline void espi_init_callback(struct espi_callback *callback,
1148 enum espi_bus_event evt_type)
1149{
1150 __ASSERT(callback, "Callback pointer should not be NULL");
1151 __ASSERT(handler, "Callback handler pointer should not be NULL");
1152
1153 callback->handler = handler;
1154 callback->evt_type = evt_type;
1155}
1156
1169static inline int espi_add_callback(const struct device *dev,
1170 struct espi_callback *callback)
1171{
1172 const struct espi_driver_api *api = DEVICE_API_GET(espi, dev);
1173
1174 if (!api->manage_callback) {
1175 return -ENOTSUP;
1176 }
1177
1178 return api->manage_callback(dev, callback, true);
1179}
1180
1197static inline int espi_remove_callback(const struct device *dev,
1198 struct espi_callback *callback)
1199{
1200 const struct espi_driver_api *api = DEVICE_API_GET(espi, dev);
1201
1202 if (!api->manage_callback) {
1203 return -ENOTSUP;
1204 }
1205
1206 return api->manage_callback(dev, callback, false);
1207}
1208
1263static inline int espi_interrupt_config(const struct device *dev, uint32_t espi_flags,
1264 uint32_t espi_vendor_flags)
1265{
1266 const struct espi_driver_api *api = DEVICE_API_GET(espi, dev);
1267
1268 if (!api->interrupt_config) {
1269 return -ENOTSUP;
1270 }
1271
1272 return api->interrupt_config(dev, espi_flags, espi_vendor_flags);
1273}
1274#ifdef __cplusplus
1275}
1276#endif
1277
1281#include <zephyr/syscalls/espi.h>
1282#endif /* ZEPHYR_INCLUDE_ESPI_H_ */
#define DEVICE_API_GET(_class, _dev)
Expands to the pointer of a device's API for a given class.
Definition device.h:1425
System error numbers.
int espi_read_flash(const struct device *dev, struct espi_flash_packet *pckt)
Sends a read request packet for shared flash.
espi_io_mode
eSPI I/O mode capabilities
Definition espi.h:38
int espi_read_request(const struct device *dev, struct espi_request_packet *req)
Sends memory, I/O or message read request over eSPI.
int espi_write_request(const struct device *dev, struct espi_request_packet *req)
Sends memory, I/O or message write request over eSPI.
static int espi_interrupt_config(const struct device *dev, uint32_t espi_flags, uint32_t espi_vendor_flags)
Control eSPI interrupts.
Definition espi.h:1263
int espi_send_oob(const struct device *dev, struct espi_oob_packet *pckt)
Sends SMBus transaction (out-of-band) packet over eSPI bus.
espi_virtual_peripheral
eSPI peripheral notification type.
Definition espi.h:204
espi_bus_event
eSPI bus event.
Definition espi.h:119
espi_cycle_type
eSPI cycle types supported over eSPI peripheral channel
Definition espi.h:276
int espi_receive_oob(const struct device *dev, struct espi_oob_packet *pckt)
Receives SMBus transaction (out-of-band) packet from eSPI bus.
espi_interrupt_flags
eSPI interrupt flags.
Definition espi.h:233
int espi_config(const struct device *dev, struct espi_cfg *cfg)
Configure operation of a eSPI hardware.
static int espi_remove_callback(const struct device *dev, struct espi_callback *callback)
Remove an application callback.
Definition espi.h:1197
bool espi_get_channel_status(const struct device *dev, enum espi_channel ch)
Query whether a logical channel is ready.
int espi_write_lpc_request(const struct device *dev, enum lpc_peripheral_opcode op, uint32_t *data)
Writes data to a LPC peripheral which generates an eSPI transaction.
static void espi_init_callback(struct espi_callback *callback, espi_callback_handler_t handler, enum espi_bus_event evt_type)
Callback model.
Definition espi.h:1146
void(* espi_callback_handler_t)(const struct device *dev, struct espi_callback *cb, struct espi_event espi_evt)
Define the application callback handler function signature.
Definition espi.h:594
int espi_receive_vwire(const struct device *dev, enum espi_vwire_signal signal, uint8_t *level)
Retrieves level status for a signal encapsulated in a virtual wire.
int espi_write_flash(const struct device *dev, struct espi_flash_packet *pckt)
Sends a write request packet for shared flash.
int espi_flash_erase(const struct device *dev, struct espi_flash_packet *pckt)
Sends a write request packet for shared flash.
espi_vwire_signal
eSPI system platform signals that can be sent or received through virtual wire channel
Definition espi.h:301
static int espi_add_callback(const struct device *dev, struct espi_callback *callback)
Add an application callback.
Definition espi.h:1169
espi_pc_event
eSPI peripheral channel events.
Definition espi.h:157
int espi_send_vwire(const struct device *dev, enum espi_vwire_signal signal, uint8_t level)
Sends system/platform signal as a virtual wire packet.
lpc_peripheral_opcode
eSPI LPC peripheral opcodes
Definition espi.h:376
int espi_read_lpc_request(const struct device *dev, enum lpc_peripheral_opcode op, uint32_t *data)
Reads SOC data from a LPC peripheral with information updated over eSPI.
espi_channel
eSPI channel.
Definition espi.h:107
@ ESPI_IO_MODE_QUAD_LINES
Quad data line mode.
Definition espi.h:44
@ ESPI_IO_MODE_SINGLE_LINE
Single data line mode (traditional SPI).
Definition espi.h:40
@ ESPI_IO_MODE_DUAL_LINES
Dual data line mode.
Definition espi.h:42
@ ESPI_PERIPHERAL_HOST_IO_PVT2
Private Host I/O peripheral 2.
Definition espi.h:216
@ ESPI_PERIPHERAL_UART
UART peripheral.
Definition espi.h:206
@ ESPI_PERIPHERAL_HOST_IO
Host I/O peripheral.
Definition espi.h:210
@ ESPI_PERIPHERAL_HOST_IO_PVT3
Private Host I/O peripheral 3.
Definition espi.h:218
@ ESPI_PERIPHERAL_HOST_IO_PVT
Private Host I/O peripheral.
Definition espi.h:214
@ ESPI_PERIPHERAL_8042_KBC
8042 Keyboard peripheral
Definition espi.h:208
@ ESPI_PERIPHERAL_EC_HOST_CMD
Embedded Controller Host Command peripheral.
Definition espi.h:224
@ ESPI_PERIPHERAL_DEBUG_PORT80
Debug Port 80 peripheral.
Definition espi.h:212
@ ESPI_BUS_EVENT_OOB_RECEIVED
Indicates the eSPI HW has received a Out-of-band packet from eSPI controller.
Definition espi.h:142
@ ESPI_BUS_EVENT_CHANNEL_READY
Indicates the eSPI HW has received channel enable notification from eSPI controller,...
Definition espi.h:133
@ ESPI_BUS_PERIPHERAL_NOTIFICATION
Indicates the eSPI HW has received a peripheral eSPI host controller.
Definition espi.h:147
@ ESPI_BUS_TAF_NOTIFICATION
Indicates the eSPI HW has received a Target Attached Flash (TAF) notification event.
Definition espi.h:149
@ ESPI_BUS_EVENT_VWIRE_RECEIVED
Indicates the eSPI HW has received a virtual wire message from eSPI controller.
Definition espi.h:138
@ ESPI_BUS_RESET
Indicates the eSPI bus was reset either via eSPI reset pin.
Definition espi.h:127
@ ESPI_CYCLE_OK_COMPLETION_NODATA
Successful completion with no data.
Definition espi.h:290
@ ESPI_CYCLE_NOK_COMPLETION_NODATA
Unsuccessful completion with no data.
Definition espi.h:294
@ ESPI_CYCLE_MEMORY_WRITE32
32-bit memory write cycle
Definition espi.h:282
@ ESPI_CYCLE_MESSAGE_DATA
Message cycle with data.
Definition espi.h:288
@ ESPI_CYCLE_MEMORY_WRITE64
64-bit memory write cycle
Definition espi.h:284
@ ESPI_CYCLE_MEMORY_READ32
32-bit memory read cycle
Definition espi.h:278
@ ESPI_CYCLE_MESSAGE_NODATA
Message cycle with no data.
Definition espi.h:286
@ ESPI_CYCLE_MEMORY_READ64
64-bit memory read cycle
Definition espi.h:280
@ ESPI_CYCLE_OKCOMPLETION_DATA
Successful completion with data.
Definition espi.h:292
@ ESPI_PERIPHERAL_UART_EVENTS
Enables UART interrupt if HW supports it.
Definition espi.h:244
@ ESPI_PERIPHERAL_8042_KBC_EVENTS
Enables 8042 interrupt if HW supports it.
Definition espi.h:248
@ ESPI_BUS_EVENTS
Enables eSPI bus reset interrupts and channel negotiation changes.
Definition espi.h:235
@ ESPI_PERIPHERAL_DEBUG_PORT80_EVENTS
Enables Port80 eSPI interrupt if HW supports it.
Definition espi.h:246
@ ESPI_FLASH_CHANNEL_EVENTS
Enables eSPI Flash operations interrupt.
Definition espi.h:241
@ ESPI_OOB_CHANNEL_EVENTS
Enables eSPI OOB received interrupt.
Definition espi.h:239
@ ESPI_VIRTUAL_WIRE_CHANNEL_EVENTS
Enables eSPI VW received interrupt.
Definition espi.h:237
@ ESPI_PERIPHERAL_SHARED_MEMORY_EVENTS
Enables eSPI shared memory interrupt if HW supports it.
Definition espi.h:252
@ ESPI_PERIPHERAL_HOST_IO_EVENTS
Enables all ACPI eSPI host interface interrupt if HW supports it.
Definition espi.h:250
@ ESPI_VWIRE_SIGNAL_TARGET_GPIO_11
Target GPIO 11 signal.
Definition espi.h:350
@ ESPI_VWIRE_SIGNAL_PLTRST
Platform reset signal.
Definition espi.h:307
@ ESPI_VWIRE_SIGNAL_SUS_STAT
Suspend status signal.
Definition espi.h:308
@ ESPI_VWIRE_SIGNAL_RST_CPU_INIT
Reset CPU initialization signal.
Definition espi.h:329
@ ESPI_VWIRE_SIGNAL_SMIOUT
SMI output signal.
Definition espi.h:310
@ ESPI_VWIRE_SIGNAL_TARGET_BOOT_STS
Target boot status signal.
Definition espi.h:324
@ ESPI_VWIRE_SIGNAL_SMI
System Management Interrupt signal.
Definition espi.h:330
@ ESPI_VWIRE_SIGNAL_OOB_RST_WARN
Out-of-band reset warning signal.
Definition espi.h:306
@ ESPI_VWIRE_SIGNAL_SLP_WLAN
Sleep WLAN signal.
Definition espi.h:315
@ ESPI_VWIRE_SIGNAL_SLP_S4
Sleep S4 state signal.
Definition espi.h:304
@ ESPI_VWIRE_SIGNAL_ERR_NON_FATAL
Non-fatal error signal.
Definition espi.h:325
@ ESPI_VWIRE_SIGNAL_DNX_ACK
DNX acknowledge signal.
Definition espi.h:332
@ ESPI_VWIRE_SIGNAL_TARGET_GPIO_2
Target GPIO 2 signal.
Definition espi.h:341
@ ESPI_VWIRE_SIGNAL_TARGET_GPIO_10
Target GPIO 10 signal.
Definition espi.h:349
@ ESPI_VWIRE_SIGNAL_WAKE
Wake signal.
Definition espi.h:322
@ ESPI_VWIRE_SIGNAL_HOST_RST_ACK
Host reset acknowledge signal.
Definition espi.h:328
@ ESPI_VWIRE_SIGNAL_TARGET_GPIO_8
Target GPIO 8 signal.
Definition espi.h:347
@ ESPI_VWIRE_SIGNAL_OOB_RST_ACK
Out-of-band reset acknowledge signal.
Definition espi.h:323
@ ESPI_VWIRE_SIGNAL_DNX_WARN
DNX (Debug and eXception) warning signal.
Definition espi.h:318
@ ESPI_VWIRE_SIGNAL_TARGET_GPIO_9
Target GPIO 9 signal.
Definition espi.h:348
@ ESPI_VWIRE_SIGNAL_SUS_WARN
Suspend warning signal.
Definition espi.h:314
@ ESPI_VWIRE_SIGNAL_TARGET_GPIO_0
Target GPIO 0 signal.
Definition espi.h:339
@ ESPI_VWIRE_SIGNAL_SLP_A
Sleep A state signal.
Definition espi.h:312
@ ESPI_VWIRE_SIGNAL_PME
Power Management Event signal.
Definition espi.h:321
@ ESPI_VWIRE_SIGNAL_ERR_FATAL
Fatal error signal.
Definition espi.h:326
@ ESPI_VWIRE_SIGNAL_TARGET_GPIO_1
Target GPIO 1 signal.
Definition espi.h:340
@ ESPI_VWIRE_SIGNAL_SUS_PWRDN_ACK
Suspend power down acknowledge signal.
Definition espi.h:313
@ ESPI_VWIRE_SIGNAL_SLP_S3
Sleep S3 state signal.
Definition espi.h:303
@ ESPI_VWIRE_SIGNAL_HOST_C10
Host C10 state signal.
Definition espi.h:317
@ ESPI_VWIRE_SIGNAL_SLP_LAN
Sleep LAN signal.
Definition espi.h:316
@ ESPI_VWIRE_SIGNAL_SUS_ACK
Suspend acknowledge signal.
Definition espi.h:333
@ ESPI_VWIRE_SIGNAL_SLP_S5
Sleep S5 state signal.
Definition espi.h:305
@ ESPI_VWIRE_SIGNAL_TARGET_GPIO_3
Target GPIO 3 signal.
Definition espi.h:342
@ ESPI_VWIRE_SIGNAL_NMIOUT
NMI output signal.
Definition espi.h:309
@ ESPI_VWIRE_SIGNAL_COUNT
Number of Virtual Wire signals.
Definition espi.h:353
@ ESPI_VWIRE_SIGNAL_TARGET_BOOT_DONE
Target boot done signal.
Definition espi.h:327
@ ESPI_VWIRE_SIGNAL_TARGET_GPIO_4
Target GPIO 4 signal.
Definition espi.h:343
@ ESPI_VWIRE_SIGNAL_TARGET_GPIO_7
Target GPIO 7 signal.
Definition espi.h:346
@ ESPI_VWIRE_SIGNAL_TARGET_GPIO_6
Target GPIO 6 signal.
Definition espi.h:345
@ ESPI_VWIRE_SIGNAL_TARGET_GPIO_5
Target GPIO 5 signal.
Definition espi.h:344
@ ESPI_VWIRE_SIGNAL_HOST_RST_WARN
Host reset warning signal.
Definition espi.h:311
@ ESPI_VWIRE_SIGNAL_SCI
System Control Interrupt signal.
Definition espi.h:331
@ ESPI_PC_EVT_BUS_MASTER_ENABLE
Bus master enable event.
Definition espi.h:161
@ ESPI_PC_EVT_BUS_CHANNEL_READY
Bus channel ready event.
Definition espi.h:159
@ EACPI_READ_STS
Read ACPI status.
Definition espi.h:397
@ EACPI_WRITE_STS
Write ACPI status.
Definition espi.h:398
@ EACPI_IBF_HAS_CHAR
Check if ACPI input buffer has character.
Definition espi.h:393
@ ECUSTOM_HOST_SUBS_INTERRUPT_EN
Enable host subsystem interrupt (custom).
Definition espi.h:413
@ EACPI_OBF_HAS_CHAR
Check if ACPI output buffer has character.
Definition espi.h:392
@ ECUSTOM_HOST_CMD_GET_PARAM_MEMORY
Get host command parameter memory (custom).
Definition espi.h:418
@ EACPI_GET_SHARED_MEMORY
Shared memory region support to return the ACPI response data.
Definition espi.h:404
@ E8042_CLEAR_FLAG
Clear 8042 flag.
Definition espi.h:390
@ E8042_PAUSE_IRQ
Pause 8042 interrupt processing.
Definition espi.h:385
@ EACPI_WRITE_CHAR
Write character to ACPI output buffer.
Definition espi.h:395
@ E8042_SET_FLAG
Set 8042 flag.
Definition espi.h:389
@ E8042_READ_KB_STS
Read 8042 keyboard status.
Definition espi.h:388
@ E8042_WRITE_KB_CHAR
Write character to 8042 keyboard buffer.
Definition espi.h:381
@ E8042_WRITE_MB_CHAR
Write character to 8042 mouse buffer.
Definition espi.h:382
@ E8042_IBF_HAS_CHAR
Check if 8042 input buffer has character.
Definition espi.h:379
@ E8042_OBF_HAS_CHAR
Check if 8042 output buffer has character.
Definition espi.h:378
@ E8042_RESUME_IRQ
Resume 8042 interrupt processing.
Definition espi.h:384
@ E8042_CLEAR_OBF
Clear 8042 output buffer.
Definition espi.h:386
@ ECUSTOM_HOST_CMD_GET_PARAM_MEMORY_SIZE
Get host command parameter memory size (custom).
Definition espi.h:423
@ ECUSTOM_HOST_CMD_SEND_RESULT
Send host command result (custom).
Definition espi.h:428
@ ESPI_CHANNEL_OOB
Out-of-Band channel (channel 2).
Definition espi.h:110
@ ESPI_CHANNEL_PERIPHERAL
Peripheral channel (channel 0).
Definition espi.h:108
@ ESPI_CHANNEL_FLASH
Flash Access channel (channel 3).
Definition espi.h:111
@ ESPI_CHANNEL_VWIRE
Virtual Wire channel (channel 1).
Definition espi.h:109
int flash_erase(const struct device *dev, off_t offset, size_t size)
Erase part or all of a flash memory.
int flash_write(const struct device *dev, off_t offset, const void *data, size_t len)
Write buffer into flash memory.
int flash_read(const struct device *dev, off_t offset, void *data, size_t len)
Read data from flash.
struct _snode sys_snode_t
Single-linked list node structure.
Definition slist.h:42
#define BIT(n)
Unsigned integer with bit position n set (signed in assembly language).
Definition util_macro.h:44
#define ENOTSUP
Unsupported value.
Definition errno.h:114
sighandler_t signal(int sig, sighandler_t handler)
Header file for the single-linked list API.
#define bool
Definition stdbool.h:13
__UINT32_TYPE__ uint32_t
Definition stdint.h:90
__UINT8_TYPE__ uint8_t
Definition stdint.h:88
__UINT16_TYPE__ uint16_t
Definition stdint.h:89
Runtime device structure (in ROM) per driver instance.
Definition device.h:513
void * data
Address of the device instance private data.
Definition device.h:523
eSPI bus configuration parameters
Definition espi.h:512
enum espi_io_mode io_caps
Supported I/O mode.
Definition espi.h:514
enum espi_channel channel_caps
Supported channels.
Definition espi.h:516
uint8_t max_freq
Maximum supported frequency in MHz.
Definition espi.h:518
eSPI event
Definition espi.h:490
uint32_t evt_data
Data associated with the event.
Definition espi.h:506
enum espi_bus_event evt_type
The type of event that occurred.
Definition espi.h:492
uint32_t evt_details
Additional details for the event.
Definition espi.h:498
Event data format for ACPI events.
Definition espi.h:460
uint32_t data
Event data payload.
Definition espi.h:464
uint32_t type
Event type identifier.
Definition espi.h:462
uint32_t reserved
Reserved field for future use.
Definition espi.h:466
Event data format for KBC events.
Definition espi.h:443
uint32_t reserved
Reserved field for future use.
Definition espi.h:451
uint32_t evt
Event flags.
Definition espi.h:449
uint32_t data
Event data payload.
Definition espi.h:447
uint32_t type
Event type identifier.
Definition espi.h:445
Event data format for Private Channel (PVT) events.
Definition espi.h:475
uint32_t data
Event data payload.
Definition espi.h:479
uint32_t type
Event type identifier.
Definition espi.h:477
uint32_t reserved
Reserved field for future use.
Definition espi.h:481
eSPI flash transactions packet format
Definition espi.h:562
uint8_t * buf
Pointer to the data buffer.
Definition espi.h:564
uint32_t flash_addr
Flash address to access.
Definition espi.h:566
uint16_t len
Length of the data in bytes for read/write, or the size of the sector/block for an erase operation.
Definition espi.h:571
eSPI out-of-band transaction packet format
Definition espi.h:549
uint8_t * buf
Pointer to the data buffer.
Definition espi.h:551
uint16_t len
Length of the data in bytes (excluding the 3-byte OOB header).
Definition espi.h:556
eSPI peripheral request packet.
Definition espi.h:527
uint8_t tag
Transaction tag for tracking.
Definition espi.h:531
uint32_t address
Target address for the transaction.
Definition espi.h:535
uint8_t * data
Pointer to the data buffer for read or write operations.
Definition espi.h:537
enum espi_cycle_type cycle_type
Type of eSPI cycle being performed.
Definition espi.h:529
uint16_t len
Length of the data payload in bytes.
Definition espi.h:533