1 /** 2 * @file 3 * 4 * @brief Backend API for emulated ADC 5 */ 6 7 /* 8 * Copyright 2021 Google LLC 9 * 10 * SPDX-License-Identifier: Apache-2.0 11 */ 12 #ifndef ZEPHYR_INCLUDE_DRIVERS_ADC_ADC_EMUL_H_ 13 #define ZEPHYR_INCLUDE_DRIVERS_ADC_ADC_EMUL_H_ 14 15 #include <zephyr/types.h> 16 #include <zephyr/drivers/adc.h> 17 18 #ifdef __cplusplus 19 extern "C" { 20 #endif 21 22 /** 23 * @brief Emulated ADC backend API 24 * @defgroup adc_emul Emulated ADC 25 * @ingroup adc_interface 26 * @{ 27 * 28 * Behaviour of emulated ADC is application-defined. As-such, each 29 * application may 30 * 31 * - define a Device Tree overlay file to indicate the number of ADC 32 * controllers as well as the number of channels for each controller 33 * - set default reference voltages in Device Tree or using 34 * @ref adc_emul_ref_voltage_set 35 * - asynchronously call @ref adc_emul_const_value_set in order to set 36 * constant mV value on emulated ADC input 37 * - asynchronously call @ref adc_emul_value_func_set in order to assign 38 * function which will be used to obtain voltage on emulated ADC input 39 * 40 * An example of an appropriate Device Tree overlay file is in 41 * tests/drivers/adc/adc_api/boards/native_sim.overlay 42 * 43 * An example of using emulated ADC backend API is in the file 44 * tests/drivers/adc/adc_emul/src/main.c 45 */ 46 47 /** 48 * @brief Type definition of the function which is used to obtain ADC 49 * mV input values 50 * 51 * @param dev Pointer to the device structure for the driver instance 52 * @param chan ADC channel to sample 53 * @param data User data which was passed on @ref adc_emul_value_func_set 54 * @param result The result value which will be set as input for ADC @p chan 55 * 56 * @return 0 on success 57 * @return other as error code which ends ADC context 58 */ 59 typedef int (*adc_emul_value_func)(const struct device *dev, unsigned int chan, 60 void *data, uint32_t *result); 61 62 /** 63 * @brief Set constant mV value input for emulated ADC @p chan 64 * 65 * @param dev The emulated ADC device 66 * @param chan The channel of ADC which input is assigned 67 * @param value New voltage in mV to assign to @p chan input 68 * 69 * @return 0 on success 70 * @return -EINVAL if an invalid argument is provided 71 */ 72 int adc_emul_const_value_set(const struct device *dev, unsigned int chan, 73 uint32_t value); 74 75 /** 76 * @brief Set constant raw value input for emulated ADC @p chan 77 * 78 * @param dev The emulated ADC device 79 * @param chan The channel of ADC which input is assigned 80 * @param raw_value New raw value to assign to @p chan input 81 * 82 * @return 0 on success 83 * @return -EINVAL if an invalid argument is provided 84 */ 85 int adc_emul_const_raw_value_set(const struct device *dev, unsigned int chan, uint32_t raw_value); 86 87 /** 88 * @brief Set function used to obtain voltage for input of emulated 89 * ADC @p chan 90 * 91 * @param dev The emulated ADC device 92 * @param chan The channel of ADC to which @p func is assigned 93 * @param func New function to assign to @p chan 94 * @param data Pointer to data passed to @p func on call 95 * 96 * @return 0 on success 97 * @return -EINVAL if an invalid argument is provided 98 */ 99 int adc_emul_value_func_set(const struct device *dev, unsigned int chan, 100 adc_emul_value_func func, void *data); 101 102 /** 103 * @brief Set function used to obtain voltage for raw input value of emulated 104 * ADC @p chan 105 * 106 * @param dev The emulated ADC device 107 * @param chan The channel of ADC to which @p func is assigned 108 * @param func New function to assign to @p chan 109 * @param data Pointer to data passed to @p func on call 110 * 111 * @return 0 on success 112 * @return -EINVAL if an invalid argument is provided 113 */ 114 int adc_emul_raw_value_func_set(const struct device *dev, unsigned int chan, 115 adc_emul_value_func func, void *data); 116 117 /** 118 * @brief Set reference voltage 119 * 120 * @param dev The emulated ADC device 121 * @param ref Reference config which is changed 122 * @param value New reference voltage in mV 123 * 124 * @return 0 on success 125 * @return -EINVAL if an invalid argument is provided 126 */ 127 int adc_emul_ref_voltage_set(const struct device *dev, enum adc_reference ref, 128 uint16_t value); 129 /** 130 * @} 131 */ 132 133 #ifdef __cplusplus 134 } 135 #endif 136 137 #endif /* ZEPHYR_INCLUDE_DRIVERS_ADC_ADC_EMUL_H_ */ 138