test_adc_common.c 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394
  1. /*
  2. * SPDX-FileCopyrightText: 2021 Espressif Systems (Shanghai) CO LTD
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. */
  6. /*
  7. Tests for the adc device driver
  8. */
  9. #include "esp_system.h"
  10. #include "driver/adc.h"
  11. #include "driver/rtc_io.h"
  12. #include "driver/gpio.h"
  13. #include "unity.h"
  14. #include "esp_system.h"
  15. #include "esp_event.h"
  16. #include "esp_wifi.h"
  17. #include "esp_log.h"
  18. #include "nvs_flash.h"
  19. #include "test_utils.h"
  20. #include "soc/adc_periph.h"
  21. #if !TEMPORARY_DISABLED_FOR_TARGETS(ESP32S3,ESP32C3)
  22. #include "driver/dac.h"
  23. static const char *TAG = "test_adc";
  24. #ifdef CONFIG_IDF_TARGET_ESP32
  25. #define ADC1_TEST_WIDTH ADC_WIDTH_BIT_12
  26. #define ADC2_TEST_WIDTH ADC_WIDTH_BIT_12
  27. #elif defined CONFIG_IDF_TARGET_ESP32S2
  28. #define ADC1_TEST_WIDTH ADC_WIDTH_BIT_13 //ESP32S2 only support 13 bit width
  29. #define ADC2_TEST_WIDTH ADC_WIDTH_BIT_13 //ESP32S2 only support 13 bit width
  30. #endif
  31. #define ADC1_TEST_ATTEN ADC_ATTEN_DB_11
  32. #define ADC2_TEST_ATTEN ADC_ATTEN_DB_11
  33. #if CONFIG_IDF_TARGET_ESP32
  34. #define ADC1_TEST_CHANNEL_NUM 8
  35. #elif CONFIG_IDF_TARGET_ESP32S2
  36. #define ADC1_TEST_CHANNEL_NUM 10
  37. #endif
  38. #define ADC2_TEST_CHANNEL_NUM 6
  39. static const int adc1_ch[ADC1_TEST_CHANNEL_NUM] = {
  40. ADC1_CHANNEL_0,
  41. ADC1_CHANNEL_1,
  42. ADC1_CHANNEL_2,
  43. ADC1_CHANNEL_3,
  44. ADC1_CHANNEL_4,
  45. ADC1_CHANNEL_5,
  46. ADC1_CHANNEL_6,
  47. ADC1_CHANNEL_7,
  48. #if CONFIG_IDF_TARGET_ESP32S2
  49. ADC1_CHANNEL_8,
  50. ADC1_CHANNEL_9,
  51. #endif
  52. };
  53. static const int adc2_ch[ADC2_TEST_CHANNEL_NUM] = {
  54. ADC2_CHANNEL_0,
  55. ADC2_CHANNEL_1,
  56. ADC2_CHANNEL_2,
  57. ADC2_CHANNEL_3,
  58. ADC2_CHANNEL_4,
  59. ADC2_CHANNEL_5,
  60. };
  61. #define ADC_GET_IO_NUM(periph, channel) (adc_channel_io_map[periph][channel])
  62. void adc_fake_tie_middle(adc_unit_t adc_unit, adc_channel_t channel)
  63. {
  64. gpio_num_t gpio_num = 0;
  65. if (adc_unit & ADC_UNIT_1) {
  66. gpio_num = ADC_GET_IO_NUM(0, channel);
  67. TEST_ESP_OK(rtc_gpio_init(gpio_num));
  68. TEST_ESP_OK(rtc_gpio_pullup_en(gpio_num));
  69. TEST_ESP_OK(rtc_gpio_pulldown_en(gpio_num));
  70. TEST_ESP_OK(gpio_set_pull_mode(gpio_num, GPIO_PULLUP_PULLDOWN));
  71. TEST_ESP_OK(rtc_gpio_set_direction(gpio_num, RTC_GPIO_MODE_DISABLED));
  72. }
  73. if (adc_unit & ADC_UNIT_2) {
  74. gpio_num = ADC_GET_IO_NUM(1, channel);
  75. TEST_ESP_OK(rtc_gpio_init(gpio_num));
  76. TEST_ESP_OK(rtc_gpio_pullup_en(gpio_num));
  77. TEST_ESP_OK(rtc_gpio_pulldown_en(gpio_num));
  78. TEST_ESP_OK(gpio_set_pull_mode(gpio_num, GPIO_PULLUP_PULLDOWN));
  79. TEST_ESP_OK(rtc_gpio_set_direction(gpio_num, RTC_GPIO_MODE_DISABLED));
  80. }
  81. vTaskDelay(10 / portTICK_RATE_MS);
  82. }
  83. void adc_fake_tie_high(adc_unit_t adc_unit, adc_channel_t channel)
  84. {
  85. gpio_num_t gpio_num = 0;
  86. if (adc_unit & ADC_UNIT_1) {
  87. gpio_num = ADC_GET_IO_NUM(0, channel);
  88. TEST_ESP_OK(rtc_gpio_init(gpio_num));
  89. TEST_ESP_OK(rtc_gpio_pullup_en(gpio_num));
  90. TEST_ESP_OK(rtc_gpio_pulldown_dis(gpio_num));
  91. TEST_ESP_OK(gpio_set_pull_mode(gpio_num, GPIO_PULLUP_ONLY));
  92. TEST_ESP_OK(rtc_gpio_set_direction(gpio_num, RTC_GPIO_MODE_OUTPUT_ONLY));
  93. TEST_ESP_OK(rtc_gpio_set_level(gpio_num, 1));
  94. }
  95. if (adc_unit & ADC_UNIT_2) {
  96. gpio_num = ADC_GET_IO_NUM(1, channel);
  97. TEST_ESP_OK(rtc_gpio_init(gpio_num));
  98. TEST_ESP_OK(rtc_gpio_pullup_en(gpio_num));
  99. TEST_ESP_OK(rtc_gpio_pulldown_dis(gpio_num));
  100. TEST_ESP_OK(gpio_set_pull_mode(gpio_num, GPIO_PULLUP_ONLY));
  101. TEST_ESP_OK(rtc_gpio_set_direction(gpio_num, RTC_GPIO_MODE_OUTPUT_ONLY));
  102. TEST_ESP_OK(rtc_gpio_set_level(gpio_num, 1));
  103. }
  104. vTaskDelay(10 / portTICK_RATE_MS);
  105. }
  106. void adc_fake_tie_low(adc_unit_t adc_unit, adc_channel_t channel)
  107. {
  108. gpio_num_t gpio_num = 0;
  109. if (adc_unit & ADC_UNIT_1) {
  110. gpio_num = ADC_GET_IO_NUM(0, channel);
  111. TEST_ESP_OK(rtc_gpio_init(gpio_num));
  112. TEST_ESP_OK(rtc_gpio_pullup_dis(gpio_num));
  113. TEST_ESP_OK(rtc_gpio_pulldown_en(gpio_num));
  114. TEST_ESP_OK(gpio_set_pull_mode(gpio_num, GPIO_PULLDOWN_ONLY));
  115. TEST_ESP_OK(rtc_gpio_set_direction(gpio_num, RTC_GPIO_MODE_OUTPUT_ONLY));
  116. TEST_ESP_OK(rtc_gpio_set_level(gpio_num, 0));
  117. }
  118. if (adc_unit & ADC_UNIT_2) {
  119. gpio_num = ADC_GET_IO_NUM(1, channel);
  120. TEST_ESP_OK(rtc_gpio_init(gpio_num));
  121. TEST_ESP_OK(rtc_gpio_pullup_dis(gpio_num));
  122. TEST_ESP_OK(rtc_gpio_pulldown_en(gpio_num));
  123. TEST_ESP_OK(gpio_set_pull_mode(gpio_num, GPIO_PULLDOWN_ONLY));
  124. TEST_ESP_OK(rtc_gpio_set_direction(gpio_num, RTC_GPIO_MODE_OUTPUT_ONLY));
  125. TEST_ESP_OK(rtc_gpio_set_level(gpio_num, 0));
  126. }
  127. vTaskDelay(10 / portTICK_RATE_MS);
  128. }
  129. void adc_io_normal(adc_unit_t adc_unit, adc_channel_t channel)
  130. {
  131. gpio_num_t gpio_num = 0;
  132. if (adc_unit & ADC_UNIT_1) {
  133. gpio_num = ADC_GET_IO_NUM(0, channel);
  134. TEST_ESP_OK(rtc_gpio_init(gpio_num));
  135. TEST_ESP_OK(rtc_gpio_pullup_dis(gpio_num));
  136. TEST_ESP_OK(rtc_gpio_pulldown_dis(gpio_num));
  137. TEST_ESP_OK(gpio_set_pull_mode(gpio_num, GPIO_FLOATING));
  138. TEST_ESP_OK(rtc_gpio_set_direction(gpio_num, RTC_GPIO_MODE_DISABLED));
  139. }
  140. if (adc_unit & ADC_UNIT_2) {
  141. gpio_num = ADC_GET_IO_NUM(1, channel);
  142. TEST_ESP_OK(rtc_gpio_init(gpio_num));
  143. TEST_ESP_OK(rtc_gpio_pullup_dis(gpio_num));
  144. TEST_ESP_OK(rtc_gpio_pulldown_dis(gpio_num));
  145. TEST_ESP_OK(gpio_set_pull_mode(gpio_num, GPIO_FLOATING));
  146. TEST_ESP_OK(rtc_gpio_set_direction(gpio_num, RTC_GPIO_MODE_DISABLED));
  147. }
  148. vTaskDelay(10 / portTICK_RATE_MS);
  149. }
  150. TEST_CASE("ADC1 rtc read", "[adc1]")
  151. {
  152. int adc1_val[ADC1_TEST_CHANNEL_NUM] = {0};
  153. /* adc1 Configure */
  154. adc1_config_width(ADC1_TEST_WIDTH);
  155. ESP_LOGI(TAG, "ADC1 [CH - GPIO]:");
  156. for (int i = 0; i < ADC1_TEST_CHANNEL_NUM; i++) {
  157. TEST_ESP_OK( adc1_config_channel_atten(adc1_ch[i], ADC1_TEST_ATTEN) );
  158. ESP_LOGI(TAG, "[CH%d - IO%d]:", adc1_ch[i], ADC_GET_IO_NUM(0, adc1_ch[i]));
  159. }
  160. printf("ADC tie normal read: ");
  161. vTaskDelay(10 / portTICK_RATE_MS);
  162. /* adc Read */
  163. printf("ADC1: ");
  164. for (int i = 0; i < ADC1_TEST_CHANNEL_NUM; i++) {
  165. adc1_val[i] = adc1_get_raw((adc1_channel_t)adc1_ch[i]);
  166. printf("CH%d-%d ", adc1_ch[i], adc1_val[i]);
  167. }
  168. printf("\n");
  169. /* tie high */
  170. for (int i = 0; i < ADC1_TEST_CHANNEL_NUM; i++) {
  171. adc_fake_tie_high(ADC_UNIT_1, adc1_ch[i]);
  172. }
  173. printf("ADC tie high read: ");
  174. vTaskDelay(50 / portTICK_RATE_MS);
  175. /* adc Read */
  176. printf("ADC1: ");
  177. for (int i = 0; i < ADC1_TEST_CHANNEL_NUM; i++) {
  178. adc1_val[i] = adc1_get_raw((adc1_channel_t)adc1_ch[i]);
  179. printf("CH%d-%d ", adc1_ch[i], adc1_val[i]);
  180. #ifdef CONFIG_IDF_TARGET_ESP32S2
  181. TEST_ASSERT_EQUAL( adc1_val[i], 0x1fff );
  182. #endif
  183. }
  184. printf("\n");
  185. /* tie low */
  186. for (int i = 0; i < ADC1_TEST_CHANNEL_NUM; i++) {
  187. adc_fake_tie_low(ADC_UNIT_1, adc1_ch[i]);
  188. }
  189. printf("ADC tie low read: ");
  190. vTaskDelay(50 / portTICK_RATE_MS);
  191. /* adc Read */
  192. printf("ADC1: ");
  193. for (int i = 0; i < ADC1_TEST_CHANNEL_NUM; i++) {
  194. adc1_val[i] = adc1_get_raw((adc1_channel_t)adc1_ch[i]);
  195. printf("CH%d-%d ", adc1_ch[i], adc1_val[i]);
  196. #ifdef CONFIG_IDF_TARGET_ESP32S2
  197. TEST_ASSERT_INT_WITHIN( 100, 0, adc1_val[i] );
  198. #endif
  199. }
  200. printf("\n");
  201. /* tie midedle */
  202. for (int i = 0; i < ADC1_TEST_CHANNEL_NUM; i++) {
  203. adc_fake_tie_middle(ADC_UNIT_1, adc1_ch[i]);
  204. }
  205. printf("ADC tie mid read: ");
  206. vTaskDelay(50 / portTICK_RATE_MS);
  207. /* adc Read */
  208. printf("ADC1: ");
  209. for (int i = 0; i < ADC1_TEST_CHANNEL_NUM; i++) {
  210. adc1_val[i] = adc1_get_raw((adc1_channel_t)adc1_ch[i]);
  211. printf("CH%d-%d ", adc1_ch[i], adc1_val[i]);
  212. #ifdef CONFIG_IDF_TARGET_ESP32S2
  213. TEST_ASSERT_NOT_EQUAL( adc1_val[i], 0x1fff );
  214. TEST_ASSERT_NOT_EQUAL( adc1_val[i], 0 );
  215. #endif
  216. }
  217. printf("\n");
  218. for (int i = 0; i < ADC1_TEST_CHANNEL_NUM; i++) {
  219. adc_io_normal(ADC_UNIT_1, adc1_ch[i]);
  220. }
  221. }
  222. TEST_CASE("ADC2 rtc read", "[adc2]")
  223. {
  224. int adc2_val[ADC2_TEST_CHANNEL_NUM] = {0};
  225. /* adc2 Configure */
  226. ESP_LOGI(TAG, "ADC2 [CH - GPIO]:");
  227. for (int i = 0; i < ADC2_TEST_CHANNEL_NUM; i++) {
  228. TEST_ESP_OK( adc2_config_channel_atten(adc2_ch[i], ADC2_TEST_ATTEN) );
  229. ESP_LOGI(TAG, "[CH%d - IO%d]:", adc2_ch[i], ADC_GET_IO_NUM(1, adc2_ch[i]));
  230. }
  231. printf("ADC float read: ");
  232. vTaskDelay(10 / portTICK_RATE_MS);
  233. /* adc Read */
  234. printf("ADC2: ");
  235. for (int i = 0; i < ADC2_TEST_CHANNEL_NUM; i++) {
  236. TEST_ESP_OK( adc2_get_raw((adc2_channel_t)adc2_ch[i], ADC2_TEST_WIDTH, &adc2_val[i]) );
  237. printf("CH%d-%d ", adc2_ch[i], adc2_val[i]);
  238. }
  239. printf("\n");
  240. /* tie high */
  241. for (int i = 0; i < ADC2_TEST_CHANNEL_NUM; i++) {
  242. adc_fake_tie_high(ADC_UNIT_2, adc2_ch[i]);
  243. }
  244. printf("ADC tie high read: ");
  245. vTaskDelay(10 / portTICK_RATE_MS);
  246. /* adc Read */
  247. printf("ADC2: ");
  248. for (int i = 0; i < ADC2_TEST_CHANNEL_NUM; i++) {
  249. TEST_ESP_OK( adc2_get_raw((adc2_channel_t)adc2_ch[i], ADC2_TEST_WIDTH, &adc2_val[i]) );
  250. printf("CH%d-%d ", adc2_ch[i], adc2_val[i]);
  251. #ifdef CONFIG_IDF_TARGET_ESP32S2
  252. TEST_ASSERT_EQUAL( adc2_val[i], 0x1fff );
  253. #endif
  254. }
  255. printf("\n");
  256. /* tie low */
  257. for (int i = 0; i < ADC2_TEST_CHANNEL_NUM; i++) {
  258. adc_fake_tie_low(ADC_UNIT_2, adc2_ch[i]);
  259. }
  260. printf("ADC tie low read: ");
  261. vTaskDelay(10 / portTICK_RATE_MS);
  262. /* adc Read */
  263. printf("ADC2: ");
  264. for (int i = 0; i < ADC2_TEST_CHANNEL_NUM; i++) {
  265. TEST_ESP_OK( adc2_get_raw((adc2_channel_t)adc2_ch[i], ADC2_TEST_WIDTH, &adc2_val[i]) );
  266. printf("CH%d-%d ", adc2_ch[i], adc2_val[i]);
  267. #ifdef CONFIG_IDF_TARGET_ESP32S2
  268. TEST_ASSERT_INT_WITHIN( 100, 0, adc2_val[i] );
  269. #endif
  270. }
  271. printf("\n");
  272. /* tie midedle */
  273. for (int i = 0; i < ADC2_TEST_CHANNEL_NUM; i++) {
  274. adc_fake_tie_middle(ADC_UNIT_2, adc2_ch[i]);
  275. }
  276. printf("ADC tie middle read: ");
  277. vTaskDelay(10 / portTICK_RATE_MS);
  278. /* adc Read */
  279. printf("ADC2: ");
  280. for (int i = 0; i < ADC2_TEST_CHANNEL_NUM; i++) {
  281. TEST_ESP_OK( adc2_get_raw((adc2_channel_t)adc2_ch[i], ADC2_TEST_WIDTH, &adc2_val[i]) );
  282. printf("CH%d-%d ", adc2_ch[i], adc2_val[i]);
  283. #ifdef CONFIG_IDF_TARGET_ESP32S2
  284. TEST_ASSERT_NOT_EQUAL( 0, adc2_val[i] );
  285. TEST_ASSERT_NOT_EQUAL( 0x1fff, adc2_val[i] );
  286. #endif
  287. }
  288. printf("\n");
  289. for (int i = 0; i < ADC1_TEST_CHANNEL_NUM; i++) {
  290. adc_io_normal(ADC_UNIT_1, adc1_ch[i]);
  291. }
  292. }
  293. #include "touch_scope.h"
  294. /**
  295. * 0: ADC1 channels raw data debug.
  296. * 1: ADC2 channels raw data debug.
  297. */
  298. #define SCOPE_DEBUG_TYPE 1
  299. #define SCOPE_DEBUG_CHANNEL_MAX (10)
  300. #define SCOPE_DEBUG_ENABLE (0)
  301. #define SCOPE_UART_BUADRATE (256000)
  302. #define SCOPE_DEBUG_FREQ_MS (50)
  303. /**
  304. * Manual test: Capture ADC-DMA data and display it on the serial oscilloscope. Used to observe the stability of the data.
  305. * Use step:
  306. * 1. Call this function in `esp-idf/tools/unit-test-app/main/app_main.c`.
  307. * 2. Use `ESP-Tuning Tool`(download from `www.espressif.com`) to capture.
  308. * 3. The readings of multiple channels will be displayed on the tool.
  309. */
  310. void test_adc_slope_debug(void)
  311. {
  312. float scope_temp[SCOPE_DEBUG_CHANNEL_MAX] = {0}; // max scope channel is 10.
  313. test_tp_scope_debug_init(0, -1, -1, SCOPE_UART_BUADRATE);
  314. #if SCOPE_DEBUG_TYPE == 0
  315. /* adc1 Configure */
  316. adc1_config_width(ADC1_TEST_WIDTH);
  317. ESP_LOGI(TAG, "ADC1 [CH - GPIO] atten %d:", ADC1_TEST_ATTEN);
  318. for (int i = 0; i < ADC1_TEST_CHANNEL_NUM; i++) {
  319. TEST_ESP_OK( adc1_config_channel_atten(adc1_ch[i], ADC1_TEST_ATTEN) );
  320. ESP_LOGI(TAG, "[CH%d - IO%d]", adc1_ch[i], ADC_GET_IO_NUM(0, adc1_ch[i]));
  321. }
  322. /* tie midedle */
  323. for (int i = 0; i < ADC1_TEST_CHANNEL_NUM; i++) {
  324. adc_fake_tie_middle(ADC_UNIT_1, adc1_ch[i]);
  325. }
  326. vTaskDelay(10 / portTICK_RATE_MS);
  327. while (1) {
  328. /* adc Read */
  329. for (int i = 0; i < ADC1_TEST_CHANNEL_NUM; i++) {
  330. scope_temp[i] = adc1_get_raw((adc1_channel_t)adc1_ch[i]);
  331. }
  332. test_tp_print_to_scope(scope_temp, ADC1_TEST_CHANNEL_NUM);
  333. vTaskDelay(SCOPE_DEBUG_FREQ_MS / portTICK_RATE_MS);
  334. }
  335. #elif SCOPE_DEBUG_TYPE == 1
  336. int adc2_val[ADC2_TEST_CHANNEL_NUM] = {0};
  337. /* adc2 Configure */
  338. ESP_LOGI(TAG, "ADC2 [CH - GPIO] atten %d:", ADC2_TEST_ATTEN);
  339. for (int i = 0; i < ADC2_TEST_CHANNEL_NUM; i++) {
  340. TEST_ESP_OK( adc2_config_channel_atten(adc2_ch[i], ADC2_TEST_ATTEN) );
  341. ESP_LOGI(TAG, "[CH%d - IO%d]:", adc2_ch[i], ADC_GET_IO_NUM(1, adc2_ch[i]));
  342. }
  343. /* tie midedle */
  344. for (int i = 0; i < ADC2_TEST_CHANNEL_NUM; i++) {
  345. adc_fake_tie_middle(ADC_UNIT_2, adc2_ch[i]);
  346. }
  347. vTaskDelay(10 / portTICK_RATE_MS);
  348. while (1) {
  349. /* adc Read */
  350. printf("ADC2: ");
  351. for (int i = 0; i < ADC2_TEST_CHANNEL_NUM; i++) {
  352. adc2_get_raw((adc2_channel_t)adc2_ch[i], ADC2_TEST_WIDTH, &adc2_val[i]);
  353. scope_temp[i] = adc2_val[i];
  354. }
  355. test_tp_print_to_scope(scope_temp, ADC2_TEST_CHANNEL_NUM);
  356. vTaskDelay(SCOPE_DEBUG_FREQ_MS / portTICK_RATE_MS);
  357. }
  358. #endif
  359. }
  360. #endif