Zephyr API Documentation  2.7.0-rc2
A Scalable Open Source RTOS
espi_emul.h
Go to the documentation of this file.
1/*
2 * Copyright 2020 Google LLC
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
7#ifndef ZEPHYR_INCLUDE_DRIVERS_ESPI_SPI_EMUL_H_
8#define ZEPHYR_INCLUDE_DRIVERS_ESPI_SPI_EMUL_H_
9
16#include <zephyr/types.h>
17#include <device.h>
18
26#ifdef __cplusplus
27extern "C" {
28#endif
29
30#define EMUL_ESPI_HOST_CHIPSEL 0
31
32struct espi_emul;
33
45typedef int (*emul_espi_api_set_vw)(struct espi_emul *emul,
46 enum espi_vwire_signal vw,
47 uint8_t level);
48
60typedef int (*emul_espi_api_get_vw)(struct espi_emul *emul,
61 enum espi_vwire_signal vw,
62 uint8_t *level);
63
64#ifdef CONFIG_ESPI_PERIPHERAL_ACPI_SHM_REGION
72typedef uintptr_t (*emul_espi_api_get_acpi_shm)(struct espi_emul *emul);
73#endif
74
86typedef struct espi_emul *(*emul_find_emul)(const struct device *dev,
87 unsigned int chipsel);
88
99typedef int (*emul_trigger_event)(const struct device *dev,
100 struct espi_event *evt);
101
106#ifdef CONFIG_ESPI_PERIPHERAL_ACPI_SHM_REGION
107 emul_espi_api_get_acpi_shm get_acpi_shm;
108#endif
109};
110
112struct espi_emul {
114 /* API provided for this device */
116 /* eSPI chip-select of the emulated device */
118};
119
122 /* The struct espi_driver_api has to be first in
123 * struct emul_espi_driver_api to make pointer casting working
124 */
125 struct espi_driver_api espi_api;
126 /* The rest, emulator specific functions */
129};
130
139int espi_emul_register(const struct device *dev, const char *name,
140 struct espi_emul *emul);
141
153int emul_espi_host_send_vw(const struct device *espi_dev,
154 enum espi_vwire_signal vw, uint8_t level);
155
166int emul_espi_host_port80_write(const struct device *espi_dev, uint32_t data);
167
168#ifdef CONFIG_ESPI_PERIPHERAL_ACPI_SHM_REGION
176uintptr_t emul_espi_host_get_acpi_shm(const struct device *espi_dev);
177#endif
178
179
180#ifdef __cplusplus
181}
182#endif
183
188#endif /* ZEPHYR_INCLUDE_DRIVERS_ESPI_SPI_EMUL_H_ */
int espi_emul_register(const struct device *dev, const char *name, struct espi_emul *emul)
int emul_espi_host_port80_write(const struct device *espi_dev, uint32_t data)
int(* emul_espi_api_get_vw)(struct espi_emul *emul, enum espi_vwire_signal vw, uint8_t *level)
Definition: espi_emul.h:60
int(* emul_trigger_event)(const struct device *dev, struct espi_event *evt)
Definition: espi_emul.h:99
int emul_espi_host_send_vw(const struct device *espi_dev, enum espi_vwire_signal vw, uint8_t level)
struct espi_emul *(* emul_find_emul)(const struct device *dev, unsigned int chipsel)
Definition: espi_emul.h:86
int(* emul_espi_api_set_vw)(struct espi_emul *emul, enum espi_vwire_signal vw, uint8_t level)
Definition: espi_emul.h:45
espi_vwire_signal
eSPI system platform signals that can be send or receive through virtual wire channel
Definition: espi.h:184
struct _snode sys_snode_t
Definition: slist.h:33
__UINT32_TYPE__ uint32_t
Definition: stdint.h:60
__UINT8_TYPE__ uint8_t
Definition: stdint.h:58
__UINTPTR_TYPE__ uintptr_t
Definition: stdint.h:75
__UINT16_TYPE__ uint16_t
Definition: stdint.h:59
Runtime device structure (in ROM) per driver instance.
Definition: device.h:367
Definition: espi_emul.h:103
emul_espi_api_set_vw set_vw
Definition: espi_emul.h:104
emul_espi_api_get_vw get_vw
Definition: espi_emul.h:105
Definition: espi_emul.h:121
emul_trigger_event trigger_event
Definition: espi_emul.h:127
struct espi_driver_api espi_api
Definition: espi_emul.h:125
emul_find_emul find_emul
Definition: espi_emul.h:128
Definition: emul.h:52
Definition: espi_emul.h:112
const struct emul_espi_device_api * api
Definition: espi_emul.h:115
uint16_t chipsel
Definition: espi_emul.h:117
sys_snode_t node
Definition: espi_emul.h:113
eSPI event
Definition: espi.h:282
static fdata_t data[2]
Definition: test_fifo_contexts.c:15