test_adc_common.c 13 KB

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