2022-02-28 05:12:28 -05:00
|
|
|
/*
|
|
|
|
* SPDX-FileCopyrightText: 2022 Espressif Systems (Shanghai) CO LTD
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*/
|
|
|
|
|
2022-09-02 04:18:14 -04:00
|
|
|
#include "sdkconfig.h"
|
|
|
|
#include "ulp_adc.h"
|
2022-02-28 05:12:28 -05:00
|
|
|
#include "esp_err.h"
|
|
|
|
#include "esp_check.h"
|
|
|
|
#include "esp_log.h"
|
2022-07-15 00:52:44 -04:00
|
|
|
#include "esp_adc/adc_oneshot.h"
|
2022-02-28 05:12:28 -05:00
|
|
|
#include "hal/adc_hal_common.h"
|
|
|
|
#include "esp_private/esp_sleep_internal.h"
|
2022-07-20 23:47:09 -04:00
|
|
|
#include "esp_private/adc_share_hw_ctrl.h"
|
2022-02-28 05:12:28 -05:00
|
|
|
|
2022-09-02 04:18:14 -04:00
|
|
|
static const char *TAG = "ulp_adc";
|
2023-12-12 14:12:02 -05:00
|
|
|
static adc_oneshot_unit_handle_t s_adc1_handle = NULL;
|
2022-02-28 05:12:28 -05:00
|
|
|
|
2022-09-02 04:18:14 -04:00
|
|
|
esp_err_t ulp_adc_init(const ulp_adc_cfg_t *cfg)
|
2022-02-28 05:12:28 -05:00
|
|
|
{
|
|
|
|
esp_err_t ret = ESP_OK;
|
|
|
|
|
2023-12-12 14:12:02 -05:00
|
|
|
ESP_RETURN_ON_FALSE(cfg, ESP_ERR_INVALID_ARG, TAG, "cfg == NULL");
|
|
|
|
ESP_RETURN_ON_FALSE(cfg->adc_n == ADC_UNIT_1, ESP_ERR_INVALID_ARG, TAG, "Only ADC_UNIT_1 is supported for now");
|
2022-02-28 05:12:28 -05:00
|
|
|
|
2022-07-15 00:52:44 -04:00
|
|
|
//-------------ADC1 Init---------------//
|
|
|
|
adc_oneshot_unit_init_cfg_t init_config1 = {
|
|
|
|
.unit_id = cfg->adc_n,
|
2022-09-02 04:18:14 -04:00
|
|
|
.ulp_mode = cfg->ulp_mode,
|
2022-07-15 00:52:44 -04:00
|
|
|
};
|
2022-09-02 04:18:14 -04:00
|
|
|
|
|
|
|
if (init_config1.ulp_mode == ADC_ULP_MODE_DISABLE) {
|
|
|
|
/* Default to RISCV for backward compatibility */
|
|
|
|
ESP_LOGI(TAG, "No ulp mode specified in cfg struct, default to riscv");
|
|
|
|
init_config1.ulp_mode = ADC_ULP_MODE_RISCV;
|
|
|
|
}
|
|
|
|
|
2023-12-12 14:12:02 -05:00
|
|
|
ret = adc_oneshot_new_unit(&init_config1, &s_adc1_handle);
|
|
|
|
if (ret != ESP_OK) return ret;
|
2022-07-15 00:52:44 -04:00
|
|
|
|
|
|
|
//-------------ADC1 Config---------------//
|
|
|
|
adc_oneshot_chan_cfg_t config = {
|
|
|
|
.bitwidth = cfg->width,
|
|
|
|
.atten = cfg->atten,
|
|
|
|
};
|
2023-12-12 14:12:02 -05:00
|
|
|
ret = adc_oneshot_config_channel(s_adc1_handle, cfg->channel, &config);
|
|
|
|
if (ret != ESP_OK) return ret;
|
2022-02-28 05:12:28 -05:00
|
|
|
|
|
|
|
//Calibrate the ADC
|
2022-09-02 04:18:14 -04:00
|
|
|
#if SOC_ADC_CALIBRATION_V1_SUPPORTED
|
2022-07-15 00:52:44 -04:00
|
|
|
adc_set_hw_calibration_code(cfg->adc_n, cfg->atten);
|
2022-09-02 04:18:14 -04:00
|
|
|
#endif
|
|
|
|
|
2022-02-28 05:12:28 -05:00
|
|
|
return ret;
|
|
|
|
}
|
2023-12-12 14:12:02 -05:00
|
|
|
|
|
|
|
esp_err_t ulp_adc_deinit()
|
|
|
|
{
|
|
|
|
// No need to check for null-pointer and stuff, oneshot driver already does that
|
|
|
|
return adc_oneshot_del_unit(s_adc1_handle);
|
|
|
|
}
|