ulp_riscv_adc.c 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. /*
  2. * SPDX-FileCopyrightText: 2022 Espressif Systems (Shanghai) CO LTD
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. */
  6. #include "ulp_riscv_adc.h"
  7. #include "esp_err.h"
  8. #include "esp_check.h"
  9. #include "esp_log.h"
  10. #include "esp_adc/adc_oneshot.h"
  11. #include "hal/adc_hal_common.h"
  12. #include "esp_private/esp_sleep_internal.h"
  13. #include "esp_private/adc_share_hw_ctrl.h"
  14. static const char *TAG = "ulp_riscv_adc";
  15. esp_err_t ulp_riscv_adc_init(const ulp_riscv_adc_cfg_t *cfg)
  16. {
  17. esp_err_t ret = ESP_OK;
  18. ESP_GOTO_ON_FALSE(cfg, ESP_ERR_INVALID_ARG, err, TAG, "cfg == NULL");
  19. ESP_GOTO_ON_FALSE(cfg->adc_n == ADC_UNIT_1, ESP_ERR_INVALID_ARG, err, TAG, "Only ADC_UNIT_1 is supported for now");
  20. //-------------ADC1 Init---------------//
  21. adc_oneshot_unit_handle_t adc1_handle;
  22. adc_oneshot_unit_init_cfg_t init_config1 = {
  23. .unit_id = cfg->adc_n,
  24. .ulp_mode = ADC_ULP_MODE_RISCV,
  25. };
  26. ESP_ERROR_CHECK(adc_oneshot_new_unit(&init_config1, &adc1_handle));
  27. //-------------ADC1 Config---------------//
  28. adc_oneshot_chan_cfg_t config = {
  29. .bitwidth = cfg->width,
  30. .atten = cfg->atten,
  31. };
  32. ESP_ERROR_CHECK(adc_oneshot_config_channel(adc1_handle, cfg->channel, &config));
  33. //Calibrate the ADC
  34. adc_set_hw_calibration_code(cfg->adc_n, cfg->atten);
  35. esp_sleep_enable_adc_tsens_monitor(true);
  36. err:
  37. return ret;
  38. }