| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981 | /* * Copyright (c) 2019 Intel Corporation. * * SPDX-License-Identifier: Apache-2.0 *//** * @file * @brief Public APIs for eSPI driver */#ifndef ZEPHYR_INCLUDE_ESPI_H_#define ZEPHYR_INCLUDE_ESPI_H_#include <sys/__assert.h>#include <zephyr/types.h>#include <device.h>#ifdef __cplusplusextern "C" {#endif/** * @brief eSPI Driver APIs * @defgroup espi_interface ESPI Driver APIs * @ingroup io_interfaces * @{ *//** * @brief eSPI I/O mode capabilities */enum espi_io_mode {	ESPI_IO_MODE_SINGLE_LINE = BIT(0),	ESPI_IO_MODE_DUAL_LINES = BIT(1),	ESPI_IO_MODE_QUAD_LINES = BIT(2),};/** *+----------------------------------------------------------------------+ *|                                                                      | *|  eSPI host                           +-------------+                 | *|                      +-----------+   |    Power    |   +----------+  | *|                      |Out of band|   |  management |   |   GPIO   |  | *|  +------------+      |processor  |   |  controller |   |  sources |  | *|  |  SPI flash |      +-----------+   +-------------+   +----------+  | *|  | controller |            |                |               |        | *|  +------------+            |                |               |        | *|   |  |    |                +--------+       +---------------+        | *|   |  |    |                         |               |                | *|   |  |    +-----+   +--------+   +----------+  +----v-----+          | *|   |  |          |   |  LPC   |   | Tunneled |  | Tunneled |          | *|   |  |          |   | bridge |   |  SMBus   |  |   GPIO   |          | *|   |  |          |   +--------+   +----------+  +----------+          | *|   |  |          |        |             |             |               | *|   |  |          |        ------+       |             |               | *|   |  |          |              |       |             |               | *|   |  |   +------v-----+    +---v-------v-------------v----+          | *|   |  |   | eSPI Flash |    |    eSPI protocol block       |          | *|   |  |   |   access   +--->+                              |          | *|   |  |   +------------+    +------------------------------+          | *|   |  |                             |                                 | *|   |  +-----------+                 |                                 | *|   |              v                 v                                 | *|   |           XXXXXXXXXXXXXXXXXXXXXXX                                | *|   |            XXXXXXXXXXXXXXXXXXXXX                                 | *|   |             XXXXXXXXXXXXXXXXXXX                                  | *+----------------------------------------------------------------------+ *   |                      | *   v             +-----------------+ * +---------+     |  |   |   |   |  | * |  Flash  |     |  |   |   |   |  | * +---------+     |  +   +   +   +  |    eSPI bus *                 | CH0 CH1 CH2 CH3 |    (logical channels) *                 |  +   +   +   +  | *                 |  |   |   |   |  | *                 +-----------------+ *                          | *+-----------------------------------------------------------------------+ *|  eSPI slave                                                           | *|                                                                       | *|       CH0         |     CH1      |      CH2      |    CH3             | *|   eSPI endpoint   |    VWIRE     |      OOB      |   Flash            | *+-----------------------------------------------------------------------+ * *//** * @brief eSPI channel. * * Identifies each eSPI logical channel supported by eSPI controller * Each channel allows independent traffic, but the assignment of channel * type to channel number is fixed. * * Note that generic commands are not associated with any channel, so traffic * over eSPI can occur if all channels are disabled or not ready */enum espi_channel {	ESPI_CHANNEL_PERIPHERAL = BIT(0),	ESPI_CHANNEL_VWIRE      = BIT(1),	ESPI_CHANNEL_OOB        = BIT(2),	ESPI_CHANNEL_FLASH      = BIT(3),};/** * @brief eSPI bus event. * * eSPI bus event to indicate events for which user can register callbacks */enum espi_bus_event {	ESPI_BUS_RESET                      = BIT(0),	ESPI_BUS_EVENT_CHANNEL_READY        = BIT(1),	ESPI_BUS_EVENT_VWIRE_RECEIVED       = BIT(2),	ESPI_BUS_EVENT_OOB_RECEIVED         = BIT(3),	ESPI_BUS_PERIPHERAL_NOTIFICATION    = BIT(4),};/** * @cond INTERNAL_HIDDEN * */#define ESPI_PERIPHERAL_INDEX_0  0ul#define ESPI_PERIPHERAL_INDEX_1  1ul#define ESPI_PERIPHERAL_INDEX_2  2ul#define ESPI_SLAVE_TO_MASTER     0ul#define ESPI_MASTER_TO_SLAVE     1ul#define ESPI_VWIRE_SRC_ID0       0ul#define ESPI_VWIRE_SRC_ID1       1ul#define ESPI_VWIRE_SRC_ID2       2ul#define ESPI_VWIRE_SRC_ID3       3ul#define ESPI_VWIRE_SRC_ID_MAX    4ul#define ESPI_PERIPHERAL_NODATA   0ul#define E8042_START_OPCODE      0x50#define E8042_MAX_OPCODE        0x5F#define EACPI_START_OPCODE      0x60#define EACPI_MAX_OPCODE        0x6F#define ECUSTOM_START_OPCODE    0xF0#define ECUSTOM_MAX_OPCODE      0xFF/** @endcond *//** * @brief eSPI peripheral notification type. * * eSPI peripheral notification event details to indicate which peripheral * trigger the eSPI callback */enum espi_virtual_peripheral {	ESPI_PERIPHERAL_UART,	ESPI_PERIPHERAL_8042_KBC,	ESPI_PERIPHERAL_HOST_IO,	ESPI_PERIPHERAL_DEBUG_PORT80,	ESPI_PERIPHERAL_HOST_IO_PVT,#if defined(CONFIG_ESPI_PERIPHERAL_EC_HOST_CMD)	ESPI_PERIPHERAL_EC_HOST_CMD,#endif /* CONFIG_ESPI_PERIPHERAL_EC_HOST_CMD */};/** * @brief eSPI cycle types supported over eSPI peripheral channel */enum espi_cycle_type {	ESPI_CYCLE_MEMORY_READ32,	ESPI_CYCLE_MEMORY_READ64,	ESPI_CYCLE_MEMORY_WRITE32,	ESPI_CYCLE_MEMORY_WRITE64,	ESPI_CYCLE_MESSAGE_NODATA,	ESPI_CYCLE_MESSAGE_DATA,	ESPI_CYCLE_OK_COMPLETION_NODATA,	ESPI_CYCLE_OKCOMPLETION_DATA,	ESPI_CYCLE_NOK_COMPLETION_NODATA,};/** * @brief eSPI system platform signals that can be send or receive through * virtual wire channel */enum espi_vwire_signal {	/* Virtual wires that can only be send from master to slave */	ESPI_VWIRE_SIGNAL_SLP_S3,	ESPI_VWIRE_SIGNAL_SLP_S4,	ESPI_VWIRE_SIGNAL_SLP_S5,	ESPI_VWIRE_SIGNAL_OOB_RST_WARN,	ESPI_VWIRE_SIGNAL_PLTRST,	ESPI_VWIRE_SIGNAL_SUS_STAT,	ESPI_VWIRE_SIGNAL_NMIOUT,	ESPI_VWIRE_SIGNAL_SMIOUT,	ESPI_VWIRE_SIGNAL_HOST_RST_WARN,	ESPI_VWIRE_SIGNAL_SLP_A,	ESPI_VWIRE_SIGNAL_SUS_PWRDN_ACK,	ESPI_VWIRE_SIGNAL_SUS_WARN,	ESPI_VWIRE_SIGNAL_SLP_WLAN,	ESPI_VWIRE_SIGNAL_SLP_LAN,	ESPI_VWIRE_SIGNAL_HOST_C10,	ESPI_VWIRE_SIGNAL_DNX_WARN,	/* Virtual wires that can only be send from slave to master */	ESPI_VWIRE_SIGNAL_PME,	ESPI_VWIRE_SIGNAL_WAKE,	ESPI_VWIRE_SIGNAL_OOB_RST_ACK,	ESPI_VWIRE_SIGNAL_SLV_BOOT_STS,	ESPI_VWIRE_SIGNAL_ERR_NON_FATAL,	ESPI_VWIRE_SIGNAL_ERR_FATAL,	ESPI_VWIRE_SIGNAL_SLV_BOOT_DONE,	ESPI_VWIRE_SIGNAL_HOST_RST_ACK,	ESPI_VWIRE_SIGNAL_RST_CPU_INIT,	/* System management interrupt */	ESPI_VWIRE_SIGNAL_SMI,	/* System control interrupt */	ESPI_VWIRE_SIGNAL_SCI,	ESPI_VWIRE_SIGNAL_DNX_ACK,	ESPI_VWIRE_SIGNAL_SUS_ACK,};/* eSPI LPC peripherals. */enum lpc_peripheral_opcode {	/* Read transactions */	E8042_OBF_HAS_CHAR = 0x50,	E8042_IBF_HAS_CHAR,	/* Write transactions */	E8042_WRITE_KB_CHAR,	E8042_WRITE_MB_CHAR,	/* Write transactions without input parameters */	E8042_RESUME_IRQ,	E8042_PAUSE_IRQ,	E8042_CLEAR_OBF,	/* Status transactions */	E8042_READ_KB_STS,	E8042_SET_FLAG,	E8042_CLEAR_FLAG,	/* ACPI read transactions */	EACPI_OBF_HAS_CHAR = EACPI_START_OPCODE,	EACPI_IBF_HAS_CHAR,	/* ACPI write transactions */	EACPI_WRITE_CHAR,	/* ACPI status transactions */	EACPI_READ_STS,	EACPI_WRITE_STS,#if defined(CONFIG_ESPI_PERIPHERAL_ACPI_SHM_REGION)	/* Shared memory region support to return the ACPI response data */	EACPI_GET_SHARED_MEMORY,#endif /* CONFIG_ESPI_PERIPHERAL_ACPI_SHM_REGION */#if defined(CONFIG_ESPI_PERIPHERAL_CUSTOM_OPCODE)	/* Other customized transactions */	ECUSTOM_HOST_SUBS_INTERRUPT_EN = ECUSTOM_START_OPCODE,	ECUSTOM_HOST_CMD_GET_PARAM_MEMORY,	ECUSTOM_HOST_CMD_SEND_RESULT,#endif /* CONFIG_ESPI_PERIPHERAL_CUSTOM_OPCODE */};/* KBC 8042 event: Input Buffer Full */#define HOST_KBC_EVT_IBF BIT(0)/* KBC 8042 event: Output Buffer Empty */#define HOST_KBC_EVT_OBE BIT(1)/** * @brief Bit field definition of evt_data in struct espi_event for KBC. */struct espi_evt_data_kbc {	uint32_t type:8;	uint32_t data:8;	uint32_t evt:8;	uint32_t reserved:8;};/** * @brief Bit field definition of evt_data in struct espi_event for ACPI. */struct espi_evt_data_acpi {	uint32_t type:8;	uint32_t data:8;	uint32_t reserved:16;};/** * @brief eSPI event */struct espi_event {	/** Event type */	enum espi_bus_event evt_type;	/** Additional details for bus event type */	uint32_t evt_details;	/** Data associated to the event */	uint32_t evt_data;};/** * @brief eSPI bus configuration parameters */struct espi_cfg {	/** Supported I/O mode */	enum espi_io_mode io_caps;	/** Supported channels */	enum espi_channel channel_caps;	/** Maximum supported frequency in MHz */	uint8_t max_freq;};/** * @brief eSPI peripheral request packet format */struct espi_request_packet {	enum espi_cycle_type cycle_type;	uint8_t tag;	uint16_t len;	uint32_t address;	uint8_t *data;};/** * @brief eSPI out-of-band transaction packet format */struct espi_oob_packet {	uint8_t *buf;	uint16_t len;};/** * @brief eSPI flash transactions packet format */struct espi_flash_packet {	uint8_t *buf;	uint32_t flash_addr;	uint16_t len;};struct espi_callback;/** * @typedef espi_callback_handler_t * @brief Define the application callback handler function signature. * * @param dev Device struct for the eSPI device. * @param cb Original struct espi_callback owning this handler. * @param espi_evt event details that trigger the callback handler. * */typedef void (*espi_callback_handler_t) (const struct device *dev,					 struct espi_callback *cb,					 struct espi_event espi_evt);/** * @cond INTERNAL_HIDDEN * * Used to register a callback in the driver instance callback list. * As many callbacks as needed can be added as long as each of them * are unique pointers of struct espi_callback. * Beware such structure should not be allocated on stack. * * Note: To help setting it, see espi_init_callback() below */struct espi_callback {	/** This is meant to be used in the driver only */	sys_snode_t node;	/** Actual callback function being called when relevant */	espi_callback_handler_t handler;	/** An event which user is interested in, if 0 the callback	 * will never be called. Such evt_mask can be modified whenever	 * necessary by the owner, and thus will affect the handler being	 * called or not.	 */	enum espi_bus_event evt_type;};/** @endcond *//** * @cond INTERNAL_HIDDEN * * eSPI driver API definition and system call entry points * * (Internal use only.) */typedef int (*espi_api_config)(const struct device *dev, struct espi_cfg *cfg);typedef bool (*espi_api_get_channel_status)(const struct device *dev,					    enum espi_channel ch);/* Logical Channel 0 APIs */typedef int (*espi_api_read_request)(const struct device *dev,				     struct espi_request_packet *req);typedef int (*espi_api_write_request)(const struct device *dev,				      struct espi_request_packet *req);typedef int (*espi_api_lpc_read_request)(const struct device *dev,					 enum lpc_peripheral_opcode op,					 uint32_t *data);typedef int (*espi_api_lpc_write_request)(const struct device *dev,					  enum lpc_peripheral_opcode op,					  uint32_t *data);/* Logical Channel 1 APIs */typedef int (*espi_api_send_vwire)(const struct device *dev,				   enum espi_vwire_signal vw,				   uint8_t level);typedef int (*espi_api_receive_vwire)(const struct device *dev,				      enum espi_vwire_signal vw,				      uint8_t *level);/* Logical Channel 2 APIs */typedef int (*espi_api_send_oob)(const struct device *dev,				 struct espi_oob_packet *pckt);typedef int (*espi_api_receive_oob)(const struct device *dev,				    struct espi_oob_packet *pckt);/* Logical Channel 3 APIs */typedef int (*espi_api_flash_read)(const struct device *dev,				   struct espi_flash_packet *pckt);typedef int (*espi_api_flash_write)(const struct device *dev,				    struct espi_flash_packet *pckt);typedef int (*espi_api_flash_erase)(const struct device *dev,				    struct espi_flash_packet *pckt);/* Callbacks and traffic intercept */typedef int (*espi_api_manage_callback)(const struct device *dev,					struct espi_callback *callback,					bool set);__subsystem struct espi_driver_api {	espi_api_config config;	espi_api_get_channel_status get_channel_status;	espi_api_read_request read_request;	espi_api_write_request write_request;	espi_api_lpc_read_request read_lpc_request;	espi_api_lpc_write_request write_lpc_request;	espi_api_send_vwire send_vwire;	espi_api_receive_vwire receive_vwire;	espi_api_send_oob send_oob;	espi_api_receive_oob receive_oob;	espi_api_flash_read flash_read;	espi_api_flash_write flash_write;	espi_api_flash_erase flash_erase;	espi_api_manage_callback manage_callback;};/** * @endcond *//** * @brief Configure operation of a eSPI controller. * * This routine provides a generic interface to override eSPI controller * capabilities. * * If this eSPI controller is acting as slave, the values set here * will be discovered as part through the GET_CONFIGURATION command * issued by the eSPI master during initialization. * * If this eSPI controller is acting as master, the values set here * will be used by eSPI master to determine minimum common capabilities with * eSPI slave then send via SET_CONFIGURATION command. * * +--------+   +---------+     +------+          +---------+   +---------+ * |  eSPI  |   |  eSPI   |     | eSPI |          |  eSPI   |   |  eSPI   | * |  slave |   | driver  |     |  bus |          |  driver |   |  host   | * +--------+   +---------+     +------+          +---------+   +---------+ *     |              |            |                   |             | *     | espi_config  | Set eSPI   |       Set eSPI    | espi_config | *     +--------------+ ctrl regs  |       cap ctrl reg| +-----------+ *     |              +-------+    |          +--------+             | *     |              |<------+    |          +------->|             | *     |              |            |                   |             | *     |              |            |                   |             | *     |              |            | GET_CONFIGURATION |             | *     |              |            +<------------------+             | *     |              |<-----------|                   |             | *     |              | eSPI caps  |                   |             | *     |              |----------->+    response       |             | *     |              |            |------------------>+             | *     |              |            |                   |             | *     |              |            | SET_CONFIGURATION |             | *     |              |            +<------------------+             | *     |              |            |  accept           |             | *     |              |            +------------------>+             | *     +              +            +                   +             + * * @param dev Pointer to the device structure for the driver instance. * @param cfg the device runtime configuration for the eSPI controller. * * @retval 0 If successful. * @retval -EIO General input / output error, failed to configure device. * @retval -EINVAL invalid capabilities, failed to configure device. * @retval -ENOTSUP capability not supported by eSPI slave. */__syscall int espi_config(const struct device *dev, struct espi_cfg *cfg);static inline int z_impl_espi_config(const struct device *dev,				     struct espi_cfg *cfg){	const struct espi_driver_api *api =		(const struct espi_driver_api *)dev->api;	return api->config(dev, cfg);}/** * @brief Query to see if it a channel is ready. * * This routine allows to check if logical channel is ready before use. * Note that queries for channels not supported will always return false. * * @param dev Pointer to the device structure for the driver instance. * @param ch the eSPI channel for which status is to be retrieved. * * @retval true If eSPI channel is ready. * @retval false otherwise. */__syscall bool espi_get_channel_status(const struct device *dev,				       enum espi_channel ch);static inline bool z_impl_espi_get_channel_status(const struct device *dev,						  enum espi_channel ch){	const struct espi_driver_api *api =		(const struct espi_driver_api *)dev->api;	return api->get_channel_status(dev, ch);}/** * @brief Sends memory, I/O or message read request over eSPI. * * This routines provides a generic interface to send a read request packet. * * @param dev Pointer to the device structure for the driver instance. * @param req Address of structure representing a memory, *            I/O or message read request. * * @retval 0 If successful. * @retval -ENOTSUP if eSPI controller doesn't support raw packets and instead *         low memory transactions are handled by controller hardware directly. * @retval -EIO General input / output error, failed to send over the bus. */__syscall int espi_read_request(const struct device *dev,				struct espi_request_packet *req);static inline int z_impl_espi_read_request(const struct device *dev,					   struct espi_request_packet *req){	const struct espi_driver_api *api =		(const struct espi_driver_api *)dev->api;	if (!api->read_request) {		return -ENOTSUP;	}	return api->read_request(dev, req);}/** * @brief Sends memory, I/O or message write request over eSPI. * * This routines provides a generic interface to send a write request packet. * * @param dev Pointer to the device structure for the driver instance. * @param req Address of structure representing a memory, I/O or *            message write request. * * @retval 0 If successful. * @retval -ENOTSUP if eSPI controller doesn't support raw packets and instead *         low memory transactions are handled by controller hardware directly. * @retval -EINVAL General input / output error, failed to send over the bus. */__syscall int espi_write_request(const struct device *dev,				 struct espi_request_packet *req);static inline int z_impl_espi_write_request(const struct device *dev,					    struct espi_request_packet *req){	const struct espi_driver_api *api =		(const struct espi_driver_api *)dev->api;	if (!api->write_request) {		return -ENOTSUP;	}	return api->write_request(dev, req);}/** * @brief Reads SOC data from a LPC peripheral with information * updated over eSPI. * * This routine provides a generic interface to read a block whose * information was updated by an eSPI transaction. Reading may trigger * a transaction. The eSPI packet is assembled by the HW block. * * @param dev Pointer to the device structure for the driver instance. * @param op Enum representing opcode for peripheral type and read request. * @param data Parameter to be read from to the LPC peripheral. * * @retval 0 If successful. * @retval -ENOTSUP if eSPI peripheral is off or not supported. * @retval -EINVAL for unimplemented lpc opcode, but in range. */__syscall int espi_read_lpc_request(const struct device *dev,				    enum lpc_peripheral_opcode op,				    uint32_t *data);static inline int z_impl_espi_read_lpc_request(const struct device *dev,					       enum lpc_peripheral_opcode op,					       uint32_t *data){	const struct espi_driver_api *api =		(const struct espi_driver_api *)dev->api;	if (!api->read_lpc_request) {		return -ENOTSUP;	}	return api->read_lpc_request(dev, op, data);}/** * @brief Writes data to a LPC peripheral which generates an eSPI transaction. * * This routine provides a generic interface to write data to a block which * triggers an eSPI transaction. The eSPI packet is assembled by the HW * block. * * @param dev Pointer to the device structure for the driver instance. * @param op Enum representing an opcode for peripheral type and write request. * @param data Represents the parameter passed to the LPC peripheral. * * @retval 0 If successful. * @retval -ENOTSUP if eSPI peripheral is off or not supported. * @retval -EINVAL for unimplemented lpc opcode, but in range. */__syscall int espi_write_lpc_request(const struct device *dev,				     enum lpc_peripheral_opcode op,				     uint32_t *data);static inline int z_impl_espi_write_lpc_request(const struct device *dev,						enum lpc_peripheral_opcode op,						uint32_t *data){	const struct espi_driver_api *api =		(const struct espi_driver_api *)dev->api;	if (!api->write_lpc_request) {		return -ENOTSUP;	}	return api->write_lpc_request(dev, op, data);}/** * @brief Sends system/platform signal as a virtual wire packet. * * This routines provides a generic interface to send a virtual wire packet * from slave to master. * * @param dev Pointer to the device structure for the driver instance. * @param signal The signal to be send to eSPI master. * @param level The level of signal requested LOW or HIGH. * * @retval 0 If successful. * @retval -EIO General input / output error, failed to send over the bus. */__syscall int espi_send_vwire(const struct device *dev,			      enum espi_vwire_signal signal,			      uint8_t level);static inline int z_impl_espi_send_vwire(const struct device *dev,					 enum espi_vwire_signal signal,					 uint8_t level){	const struct espi_driver_api *api =		(const struct espi_driver_api *)dev->api;	return api->send_vwire(dev, signal, level);}/** * @brief Retrieves level status for a signal encapsulated in a virtual wire. * * This routines provides a generic interface to request a virtual wire packet * from eSPI master and retrieve the signal level. * * @param dev Pointer to the device structure for the driver instance. * @param signal the signal to be requested from eSPI master. * @param level the level of signal requested 0b LOW, 1b HIGH. * * @retval -EIO General input / output error, failed request to master. */__syscall int espi_receive_vwire(const struct device *dev,				 enum espi_vwire_signal signal,				 uint8_t *level);static inline int z_impl_espi_receive_vwire(const struct device *dev,					    enum espi_vwire_signal signal,					    uint8_t *level){	const struct espi_driver_api *api =		(const struct espi_driver_api *)dev->api;	return api->receive_vwire(dev, signal, level);}/** * @brief Sends SMBus transaction (out-of-band) packet over eSPI bus. * * This routines provides an interface to encapsulate a SMBus transaction * and send into packet over eSPI bus * * @param dev Pointer to the device structure for the driver instance. * @param pckt Address of the packet representation of SMBus transaction. * * @retval -EIO General input / output error, failed request to master. */__syscall int espi_send_oob(const struct device *dev,			    struct espi_oob_packet *pckt);static inline int z_impl_espi_send_oob(const struct device *dev,				       struct espi_oob_packet *pckt){	const struct espi_driver_api *api =		(const struct espi_driver_api *)dev->api;	if (!api->send_oob) {		return -ENOTSUP;	}	return api->send_oob(dev, pckt);}/** * @brief Receives SMBus transaction (out-of-band) packet from eSPI bus. * * This routines provides an interface to receive and decoded a SMBus * transaction from eSPI bus * * @param dev Pointer to the device structure for the driver instance. * @param pckt Address of the packet representation of SMBus transaction. * * @retval -EIO General input / output error, failed request to master. */__syscall int espi_receive_oob(const struct device *dev,			       struct espi_oob_packet *pckt);static inline int z_impl_espi_receive_oob(const struct device *dev,					  struct espi_oob_packet *pckt){	const struct espi_driver_api *api =		(const struct espi_driver_api *)dev->api;	if (!api->receive_oob) {		return -ENOTSUP;	}	return api->receive_oob(dev, pckt);}/** * @brief Sends a read request packet for shared flash. * * This routines provides an interface to send a request to read the flash * component shared between the eSPI master and eSPI slaves. * * @param dev Pointer to the device structure for the driver instance. * @param pckt Adddress of the representation of read flash transaction. * * @retval -ENOTSUP eSPI flash logical channel transactions not supported. * @retval -EBUSY eSPI flash channel is not ready or disabled by master. * @retval -EIO General input / output error, failed request to master. */__syscall int espi_read_flash(const struct device *dev,			      struct espi_flash_packet *pckt);static inline int z_impl_espi_read_flash(const struct device *dev,					 struct espi_flash_packet *pckt){	const struct espi_driver_api *api =		(const struct espi_driver_api *)dev->api;	if (!api->flash_read) {		return -ENOTSUP;	}	return api->flash_read(dev, pckt);}/** * @brief Sends a write request packet for shared flash. * * This routines provides an interface to send a request to write to the flash * components shared between the eSPI master and eSPI slaves. * * @param dev Pointer to the device structure for the driver instance. * @param pckt Address of the representation of write flash transaction. * * @retval -ENOTSUP eSPI flash logical channel transactions not supported. * @retval -EBUSY eSPI flash channel is not ready or disabled by master. * @retval -EIO General input / output error, failed request to master. */__syscall int espi_write_flash(const struct device *dev,			       struct espi_flash_packet *pckt);static inline int z_impl_espi_write_flash(const struct device *dev,					  struct espi_flash_packet *pckt){	const struct espi_driver_api *api =		(const struct espi_driver_api *)dev->api;	if (!api->flash_write) {		return -ENOTSUP;	}	return api->flash_write(dev, pckt);}/** * @brief Sends a write request packet for shared flash. * * This routines provides an interface to send a request to write to the flash * components shared between the eSPI master and eSPI slaves. * * @param dev Pointer to the device structure for the driver instance. * @param pckt Address of the representation of write flash transaction. * * @retval -ENOTSUP eSPI flash logical channel transactions not supported. * @retval -EBUSY eSPI flash channel is not ready or disabled by master. * @retval -EIO General input / output error, failed request to master. */__syscall int espi_flash_erase(const struct device *dev,			       struct espi_flash_packet *pckt);static inline int z_impl_espi_flash_erase(const struct device *dev,					  struct espi_flash_packet *pckt){	const struct espi_driver_api *api =		(const struct espi_driver_api *)dev->api;	if (!api->flash_erase) {		return -ENOTSUP;	}	return api->flash_erase(dev, pckt);}/** * Callback model * *+-------+                  +-------------+   +------+     +---------+ *|  App  |                  | eSPI driver |   |  HW  |     |eSPI Host| *+---+---+                  +-------+-----+   +---+--+     +----+----+ *    |                              |             |             | *    |   espi_init_callback         |             |             | *    +----------------------------> |             |             | *    |   espi_add_callback          |             | *    +----------------------------->+             | *    |                              |             |  eSPI reset |  eSPI host *    |                              |    IRQ      +<------------+  resets the *    |                              | <-----------+             |  bus *    |                              |             |             | *    |                              | Processed   |             | *    |                              | within the  |             | *    |                              | driver      |             | *    |                              |             |             | *    |                              |             |  VW CH ready|  eSPI host *    |                              |    IRQ      +<------------+  enables VW *    |                              | <-----------+             |  channel *    |                              |             |             | *    |                              | Processed   |             | *    |                              | within the  |             | *    |                              | driver      |             | *    |                              |             |             | *    |                              |             | Memory I/O  |  Peripheral *    |                              |             <-------------+  event *    |                              +<------------+             | *    +<-----------------------------+ callback    |             | *    | Report peripheral event      |             |             | *    | and data for the event       |             |             | *    |                              |             |             | *    |                              |             | SLP_S5      |  eSPI host *    |                              |             <-------------+  send VWire *    |                              +<------------+             | *    +<-----------------------------+ callback    |             | *    | App enables/configures       |             |             | *    | discrete regulator           |             |             | *    |                              |             |             | *    |   espi_send_vwire_signal     |             |             | *    +------------------------------>------------>|------------>| *    |                              |             |             | *    |                              |             | HOST_RST    |  eSPI host *    |                              |             <-------------+  send VWire *    |                              +<------------+             | *    +<-----------------------------+ callback    |             | *    | App reset host-related       |             |             | *    | data structures              |             |             | *    |                              |             |             | *    |                              |             |   C10       |  eSPI host *    |                              |             +<------------+  send VWire *    |                              <-------------+             | *    <------------------------------+             |             | *    | App executes                 |             |             | *    + power mgmt policy            |             |             | *//** * @brief Helper to initialize a struct espi_callback properly. * * @param callback A valid Application's callback structure pointer. * @param handler A valid handler function pointer. * @param evt_type indicates the eSPI event relevant for the handler. * for VWIRE_RECEIVED event the data will indicate the new level asserted */static inline void espi_init_callback(struct espi_callback *callback,				      espi_callback_handler_t handler,				      enum espi_bus_event evt_type){	__ASSERT(callback, "Callback pointer should not be NULL");	__ASSERT(handler, "Callback handler pointer should not be NULL");	callback->handler = handler;	callback->evt_type = evt_type;}/** * @brief Add an application callback. * @param dev Pointer to the device structure for the driver instance. * @param callback A valid Application's callback structure pointer. * @return 0 if successful, negative errno code on failure. * * @note Callbacks may be added to the device from within a callback * handler invocation, but whether they are invoked for the current * eSPI event is not specified. * * Note: enables to add as many callback as needed on the same device. */static inline int espi_add_callback(const struct device *dev,				    struct espi_callback *callback){	const struct espi_driver_api *api =		(const struct espi_driver_api *)dev->api;	if (!api->manage_callback) {		return -ENOTSUP;	}	return api->manage_callback(dev, callback, true);}/** * @brief Remove an application callback. * @param dev Pointer to the device structure for the driver instance. * @param callback A valid application's callback structure pointer. * @return 0 if successful, negative errno code on failure. * * @warning It is explicitly permitted, within a callback handler, to * remove the registration for the callback that is running, i.e. @p * callback.  Attempts to remove other registrations on the same * device may result in undefined behavior, including failure to * invoke callbacks that remain registered and unintended invocation * of removed callbacks. * * Note: enables to remove as many callbacks as added through *       espi_add_callback(). */static inline int espi_remove_callback(const struct device *dev,				       struct espi_callback *callback){	const struct espi_driver_api *api =		(const struct espi_driver_api *)dev->api;	if (!api->manage_callback) {		return -ENOTSUP;	}	return api->manage_callback(dev, callback, false);}#ifdef __cplusplus}#endif/** * @} */#include <syscalls/espi.h>#endif /* ZEPHYR_INCLUDE_ESPI_H_ */
 |