| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109 | 
							- /*
 
-  * Copyright (c) 2020 Nordic Semiconductor ASA
 
-  * Copyright 2020 Google LLC
 
-  *
 
-  * SPDX-License-Identifier: Apache-2.0
 
-  */
 
- #ifndef ZEPHYR_INCLUDE_DRIVERS_EMUL_H_
 
- #define ZEPHYR_INCLUDE_DRIVERS_EMUL_H_
 
- /**
 
-  * @brief Emulators used to test drivers and higher-level code that uses them
 
-  * @defgroup io_emulators Emulator interface
 
-  * @{
 
-  */
 
- #ifdef __cplusplus
 
- extern "C" {
 
- #endif /* __cplusplus */
 
- struct device;
 
- struct emul;
 
- /**
 
-  * Structure uniquely identifying a device to be emulated
 
-  *
 
-  * Currently this uses the device node label, but that will go away by 2.5.
 
-  */
 
- struct emul_link_for_bus {
 
- 	const char *label;
 
- };
 
- /** List of emulators attached to a bus */
 
- struct emul_list_for_bus {
 
- 	/** Identifiers for children of the node */
 
- 	const struct emul_link_for_bus *children;
 
- 	/** Number of children of the node */
 
- 	unsigned int num_children;
 
- };
 
- /**
 
-  * Standard callback for emulator initialisation providing the initialiser
 
-  * record and the device that calls the emulator functions.
 
-  *
 
-  * @param emul Emulator to init
 
-  * @param parent Parent device that is using the emulator
 
-  */
 
- typedef int (*emul_init_t)(const struct emul *emul,
 
- 			   const struct device *parent);
 
- /** An emulator instance */
 
- struct emul {
 
- 	/** function used to initialise the emulator state */
 
- 	emul_init_t init;
 
- 	/** handle to the device for which this provides low-level emulation */
 
- 	const char *dev_label;
 
- 	/** Emulator-specific configuration data */
 
- 	const void *cfg;
 
- };
 
- /**
 
-  * Emulators are aggregated into an array at link time, from which emulating
 
-  * devices can find the emulators that they are to use.
 
-  */
 
- extern const struct emul __emul_list_start[];
 
- extern const struct emul __emul_list_end[];
 
- /* Use the devicetree node identifier as a unique name. */
 
- #define EMUL_REG_NAME(node_id) (_CONCAT(__emulreg_, node_id))
 
- /**
 
-  * Define a new emulator
 
-  *
 
-  * This adds a new struct emul to the linker list of emulations. This is
 
-  * typically used in your emulator's DT_INST_FOREACH_STATUS_OKAY() clause.
 
-  *
 
-  * @param init_ptr function to call to initialise the emulator (see emul_init
 
-  *	typedef)
 
-  * @param node_id Node ID of the driver to emulate (e.g. DT_DRV_INST(n))
 
-  * @param cfg_ptr emulator-specific configuration data
 
-  */
 
- #define EMUL_DEFINE(init_ptr, node_id, cfg_ptr)			\
 
- 	static struct emul EMUL_REG_NAME(node_id)		\
 
- 	__attribute__((__section__(".emulators"))) __used = {	\
 
- 		.init = (init_ptr),				\
 
- 		.dev_label = DT_LABEL(node_id),			\
 
- 		.cfg = (cfg_ptr),				\
 
- 	};
 
- /**
 
-  * Set up a list of emulators
 
-  *
 
-  * @param dev Device the emulators are attached to (e.g. an I2C controller)
 
-  * @param list List of devices to set up
 
-  * @return 0 if OK
 
-  * @return negative value on error
 
-  */
 
- int emul_init_for_bus_from_list(const struct device *dev,
 
- 				const struct emul_list_for_bus *list);
 
- #ifdef __cplusplus
 
- }
 
- #endif /* __cplusplus */
 
- /**
 
-  * @}
 
-  */
 
- #endif /* ZEPHYR_INCLUDE_DRIVERS_EMUL_H_ */
 
 
  |