dac.h 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. /*
  2. * Copyright (c) 2006-2024 RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2020-06-19 thread-liu the first version
  9. */
  10. #ifndef __DAC_H__
  11. #define __DAC_H__
  12. #include <rtthread.h>
  13. /**
  14. * @defgroup group_DAC DAC
  15. * @brief DAC driver api
  16. * @ingroup group_device_driver
  17. *
  18. * <b>Example</b>
  19. * @code {.c}
  20. *
  21. * #include <rtthread.h>
  22. * #include <rtdevice.h>
  23. * #include <stdlib.h>
  24. * #define DAC_DEV_NAME "dac1"
  25. * #define DAC_DEV_CHANNEL 1
  26. * #define REFER_VOLTAGE 330
  27. * #define CONVERT_BITS (1 << 12)
  28. *
  29. * static int dac_vol_sample(int argc, char *argv[])
  30. * {
  31. * rt_dac_device_t dac_dev;
  32. * rt_uint32_t value, vol;
  33. * rt_err_t ret = RT_EOK;
  34. *
  35. * dac_dev = (rt_dac_device_t)rt_device_find(DAC_DEV_NAME);
  36. * if (dac_dev == RT_NULL)
  37. * {
  38. * rt_kprintf("dac sample run failed! can't find %s device!\n", DAC_DEV_NAME);
  39. * return -RT_ERROR;
  40. * }
  41. *
  42. * ret = rt_dac_enable(dac_dev, DAC_DEV_CHANNEL);
  43. *
  44. * value = atoi(argv[1]);
  45. * rt_dac_write(dac_dev, DAC_DEV_NAME, DAC_DEV_CHANNEL, value);
  46. * rt_kprintf("the value is :%d \n", value);
  47. *
  48. * vol = value * REFER_VOLTAGE / CONVERT_BITS;
  49. * rt_kprintf("the voltage is :%d.%02d \n", vol / 100, vol % 100);
  50. *
  51. * rt_thread_mdelay(500);
  52. *
  53. * ret = rt_dac_disable(dac_dev, DAC_DEV_CHANNEL);
  54. *
  55. * return ret;
  56. * }
  57. * MSH_CMD_EXPORT(dac_vol_sample, dac voltage convert sample);
  58. *
  59. * @endcode
  60. */
  61. /*!
  62. * @addtogroup group_DAC
  63. * @{
  64. */
  65. struct rt_dac_device;
  66. /**
  67. * @brief Configuration of DAC device
  68. */
  69. struct rt_dac_ops
  70. {
  71. rt_err_t (*disabled)(struct rt_dac_device *device, rt_uint32_t channel);
  72. rt_err_t (*enabled)(struct rt_dac_device *device, rt_uint32_t channel);
  73. rt_err_t (*convert)(struct rt_dac_device *device, rt_uint32_t channel, rt_uint32_t *value);
  74. rt_uint8_t (*get_resolution)(struct rt_dac_device *device);
  75. };
  76. /**
  77. * @brief DAC device structure
  78. *
  79. */
  80. struct rt_dac_device
  81. {
  82. struct rt_device parent;
  83. const struct rt_dac_ops *ops;
  84. };
  85. typedef struct rt_dac_device *rt_dac_device_t;
  86. typedef enum
  87. {
  88. RT_DAC_CMD_ENABLE = RT_DEVICE_CTRL_BASE(DAC) + 0,
  89. RT_DAC_CMD_DISABLE = RT_DEVICE_CTRL_BASE(DAC) + 1,
  90. RT_DAC_CMD_GET_RESOLUTION = RT_DEVICE_CTRL_BASE(DAC) + 2,
  91. } rt_dac_cmd_t;
  92. /**
  93. * @brief Register a DAC device
  94. * @param dac DAC device
  95. * @param name DAC name
  96. * @param ops the operations of DAC device
  97. * @param user_data device private data
  98. * @return rt_err_t error code
  99. */
  100. rt_err_t rt_hw_dac_register(rt_dac_device_t dac,const char *name, const struct rt_dac_ops *ops, const void *user_data);
  101. /**
  102. * @brief set the value of DAC
  103. * @param dev DAC device
  104. * @param channel DAC channel
  105. * @param value the value of DAC
  106. * @return rt_err_t error code
  107. */
  108. rt_err_t rt_dac_write(rt_dac_device_t dev, rt_uint32_t channel, rt_uint32_t value);
  109. /**
  110. * @brief enable the DAC channel
  111. * @param dev DAC device
  112. * @param channel DAC channel
  113. * @return rt_err_t error code
  114. */
  115. rt_err_t rt_dac_enable(rt_dac_device_t dev, rt_uint32_t channel);
  116. /**
  117. * @brief disable the DAC channel
  118. * @param dev DAC device
  119. * @param channel DAC channel
  120. * @return rt_err_t error code
  121. */
  122. rt_err_t rt_dac_disable(rt_dac_device_t dev, rt_uint32_t channel);
  123. /*! @}*/
  124. #endif /* __dac_H__ */