test_dac.c 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. /*
  2. * Copyright (c) 2022-2024, Xiaohua Semiconductor Co., Ltd.
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2024-12-30 CDT first version
  9. */
  10. /*
  11. * 程序清单: DAC 设备使用例程
  12. * 例程导出了 dac_vol_sample 命令到控制终端
  13. * 命令调用格式:dac_vol_sample 参数1:dac1 | dac2 参数2:DAC配置值 (可选,范围0-4095),默认1365≈1.1V
  14. * 程序功能:通过 DAC 设备将数字值转换为模拟量,并输出电压值。将示波器通道连接到输出引脚,观察输出电压值
  15. * 示例代码参考电压为3.3V,转换位数为12位。
  16. */
  17. #include <rtthread.h>
  18. #include <rtdevice.h>
  19. #include <stdlib.h>
  20. #ifdef BSP_USING_DAC
  21. #define REFER_VOLTAGE 330 /* 参考电压 3.3V,数据精度乘以100保留2位小数*/
  22. #define DAC_MAX_OUTPUT_VALUE 4095
  23. #if (defined (HC32F4A8) || defined (HC32F4A0)) && defined (BSP_USING_DAC2)
  24. extern void EthPhyDisable(void);
  25. #endif /* HC32F4A8 && BSP_USING_DAC2 */
  26. static int dac_vol_sample(int argc, char *argv[])
  27. {
  28. char dac_device_name[] = "dac1";
  29. rt_uint8_t channel = 1;
  30. rt_uint8_t max_channel = 2;
  31. rt_dac_device_t dac_dev;
  32. rt_uint32_t value = 1365; /* 默认1.1V */
  33. rt_uint32_t convertBits;
  34. rt_uint32_t vol;
  35. rt_err_t ret = RT_EOK;
  36. /* 参数无输入或者输入错误按照默认值处理 */
  37. if (argc >= 2)
  38. {
  39. if (0 == rt_strcmp(argv[1], "dac1"))
  40. {
  41. rt_strcpy(dac_device_name, "dac1");
  42. max_channel = 2;
  43. }
  44. #if defined (HC32F4A0) || defined (HC32F472) || defined (HC32F4A8) || defined (HC32F334)
  45. else if (0 == rt_strcmp(argv[1], "dac2"))
  46. {
  47. rt_strcpy(dac_device_name, "dac2");
  48. #if defined (HC32F4A0) || defined (HC32F472) || defined (HC32F4A8)
  49. max_channel = 2;
  50. #elif defined (HC32F334)
  51. max_channel = 1;
  52. #endif
  53. }
  54. #endif
  55. #if defined (HC32F472)
  56. else if (0 == rt_strcmp(argv[1], "dac3"))
  57. {
  58. rt_strcpy(dac_device_name, "dac3");
  59. max_channel = 2;
  60. }
  61. else if (0 == rt_strcmp(argv[1], "dac4"))
  62. {
  63. rt_strcpy(dac_device_name, "dac4");
  64. max_channel = 2;
  65. }
  66. #endif
  67. else
  68. {
  69. rt_kprintf("The chip hasn't the dac unit!\r\n");
  70. return -RT_ERROR;
  71. }
  72. }
  73. #if (defined (HC32F4A8) || defined (HC32F4A0)) && defined (BSP_USING_DAC2)
  74. EthPhyDisable();
  75. #endif
  76. /* 查找设备 */
  77. dac_dev = (rt_dac_device_t)rt_device_find(dac_device_name);
  78. if (dac_dev == RT_NULL)
  79. {
  80. rt_kprintf("dac sample run failed! can't find %s device!\n", dac_device_name);
  81. return -RT_ERROR;
  82. }
  83. if (RT_EOK != rt_device_control(&dac_dev->parent, RT_DAC_CMD_GET_RESOLUTION, &convertBits))
  84. {
  85. rt_kprintf("dac sample can't read resolution!\n");
  86. return -RT_ERROR;
  87. }
  88. convertBits = (1 << (rt_uint8_t)convertBits);
  89. for (channel = 1; channel <= max_channel; channel++)
  90. {
  91. /* 打开通道 */
  92. ret = rt_dac_enable(dac_dev, channel);
  93. /* 设置输出值 */
  94. if (argc >= 3)
  95. {
  96. value = atoi(argv[2]);
  97. if (value > DAC_MAX_OUTPUT_VALUE)
  98. {
  99. rt_kprintf("invalid dac value!!! \n");
  100. return -RT_ERROR;
  101. }
  102. }
  103. rt_dac_write(dac_dev, channel, value);
  104. rt_kprintf("%s CH%d Value is :%d \n", dac_device_name, channel, value);
  105. /* 转换为对应电压值 */
  106. vol = value * REFER_VOLTAGE / convertBits;
  107. rt_kprintf("%s CH%d Voltage is :%d.%02dV \n", dac_device_name, channel, vol / 100, vol % 100);
  108. }
  109. return ret;
  110. }
  111. /* 导出到 msh 命令列表中 */
  112. MSH_CMD_EXPORT(dac_vol_sample, dac voltage convert sample < dac1 | dac2 value >);
  113. #endif