test_adc_common.c 13 KB

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