2022-04-21 06:24:03 -04:00
|
|
|
/*
|
|
|
|
* SPDX-FileCopyrightText: 2019-2022 Espressif Systems (Shanghai) CO LTD
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*/
|
2019-07-19 09:20:16 -04:00
|
|
|
|
|
|
|
/*******************************************************************************
|
|
|
|
* NOTICE
|
|
|
|
* The ll is not public api, don't use in application code.
|
2020-09-11 03:48:08 -04:00
|
|
|
* See readme.md in hal/include/hal/readme.md
|
2019-07-19 09:20:16 -04:00
|
|
|
******************************************************************************/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <stdlib.h>
|
2023-07-05 05:33:32 -04:00
|
|
|
#include <stdbool.h>
|
2021-08-23 02:03:23 -04:00
|
|
|
#include "hal/misc.h"
|
2019-07-19 09:20:16 -04:00
|
|
|
#include "soc/dac_periph.h"
|
|
|
|
#include "hal/dac_types.h"
|
2020-04-08 09:56:14 -04:00
|
|
|
#include "soc/apb_saradc_struct.h"
|
2021-08-23 02:03:23 -04:00
|
|
|
#include "soc/sens_struct.h"
|
|
|
|
#include "soc/rtc_io_struct.h"
|
2020-04-08 09:56:14 -04:00
|
|
|
#include "soc/apb_saradc_reg.h"
|
2019-07-19 09:20:16 -04:00
|
|
|
|
2020-01-26 22:43:08 -05:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2022-05-24 05:26:36 -04:00
|
|
|
#define DAC_LL_CW_PHASE_0 0x02
|
|
|
|
#define DAC_LL_CW_PHASE_180 0x03
|
|
|
|
|
2020-02-25 09:19:48 -05:00
|
|
|
/*---------------------------------------------------------------
|
2020-04-08 09:56:14 -04:00
|
|
|
DAC common setting
|
2020-02-25 09:19:48 -05:00
|
|
|
---------------------------------------------------------------*/
|
2019-07-19 09:20:16 -04:00
|
|
|
/**
|
|
|
|
* Power on dac module and start output voltage.
|
|
|
|
*
|
|
|
|
* @note Before powering up, make sure the DAC PAD is set to RTC PAD and floating status.
|
|
|
|
* @param channel DAC channel num.
|
|
|
|
*/
|
|
|
|
static inline void dac_ll_power_on(dac_channel_t channel)
|
|
|
|
{
|
2020-02-25 09:19:48 -05:00
|
|
|
SENS.sar_dac_ctrl1.dac_clkgate_en = 1;
|
2019-07-19 09:20:16 -04:00
|
|
|
RTCIO.pad_dac[channel].dac_xpd_force = 1;
|
|
|
|
RTCIO.pad_dac[channel].xpd_dac = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Power done dac module and stop output voltage.
|
|
|
|
*
|
|
|
|
* @param channel DAC channel num.
|
|
|
|
*/
|
|
|
|
static inline void dac_ll_power_down(dac_channel_t channel)
|
|
|
|
{
|
|
|
|
RTCIO.pad_dac[channel].dac_xpd_force = 0;
|
|
|
|
RTCIO.pad_dac[channel].xpd_dac = 0;
|
2020-02-25 09:19:48 -05:00
|
|
|
if (RTCIO.pad_dac[0].xpd_dac == 0 && RTCIO.pad_dac[1].xpd_dac == 0) {
|
|
|
|
SENS.sar_dac_ctrl1.dac_clkgate_en = 0;
|
|
|
|
}
|
2019-07-19 09:20:16 -04:00
|
|
|
}
|
|
|
|
|
2020-04-08 09:56:14 -04:00
|
|
|
/*---------------------------------------------------------------
|
|
|
|
RTC controller setting
|
|
|
|
---------------------------------------------------------------*/
|
2019-07-19 09:20:16 -04:00
|
|
|
/**
|
|
|
|
* Output voltage with value (8 bit).
|
|
|
|
*
|
|
|
|
* @param channel DAC channel num.
|
|
|
|
* @param value Output value. Value range: 0 ~ 255.
|
|
|
|
* The corresponding range of voltage is 0v ~ VDD3P3_RTC.
|
|
|
|
*/
|
2022-10-10 07:17:22 -04:00
|
|
|
__attribute__((always_inline))
|
2019-07-19 09:20:16 -04:00
|
|
|
static inline void dac_ll_update_output_value(dac_channel_t channel, uint8_t value)
|
|
|
|
{
|
2022-05-24 05:26:36 -04:00
|
|
|
if (channel == DAC_CHAN_0) {
|
2019-07-19 09:20:16 -04:00
|
|
|
SENS.sar_dac_ctrl2.dac_cw_en1 = 0;
|
2021-08-23 02:03:23 -04:00
|
|
|
HAL_FORCE_MODIFY_U32_REG_FIELD(RTCIO.pad_dac[channel], dac, value);
|
2022-05-24 05:26:36 -04:00
|
|
|
} else if (channel == DAC_CHAN_1) {
|
2019-07-19 09:20:16 -04:00
|
|
|
SENS.sar_dac_ctrl2.dac_cw_en2 = 0;
|
2021-08-23 02:03:23 -04:00
|
|
|
HAL_FORCE_MODIFY_U32_REG_FIELD(RTCIO.pad_dac[channel], dac, value);
|
2019-07-19 09:20:16 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-02-25 09:19:48 -05:00
|
|
|
/**
|
|
|
|
* Reset dac by software.
|
|
|
|
*/
|
|
|
|
static inline void dac_ll_rtc_reset(void)
|
|
|
|
{
|
|
|
|
SENS.sar_dac_ctrl1.dac_reset = 1;
|
|
|
|
SENS.sar_dac_ctrl1.dac_reset = 0;
|
|
|
|
}
|
|
|
|
|
2020-04-15 08:51:27 -04:00
|
|
|
/**
|
|
|
|
* Enable/disable the synchronization operation function of ADC1 and DAC.
|
|
|
|
*
|
|
|
|
* @note If enabled(default), ADC RTC controller sampling will cause the DAC channel output voltage.
|
|
|
|
*
|
|
|
|
* @param enable Enable or disable adc and dac synchronization function.
|
|
|
|
*/
|
|
|
|
static inline void dac_ll_rtc_sync_by_adc(bool enable)
|
|
|
|
{
|
|
|
|
SENS.sar_amp_ctrl3.sar1_dac_xpd_fsm = enable;
|
|
|
|
}
|
|
|
|
|
2019-07-19 09:20:16 -04:00
|
|
|
/************************************/
|
|
|
|
/* DAC cosine wave generator API's */
|
|
|
|
/************************************/
|
|
|
|
/**
|
|
|
|
* Enable cosine wave generator output.
|
|
|
|
*/
|
|
|
|
static inline void dac_ll_cw_generator_enable(void)
|
|
|
|
{
|
|
|
|
SENS.sar_dac_ctrl1.sw_tone_en = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Disable cosine wave generator output.
|
|
|
|
*/
|
|
|
|
static inline void dac_ll_cw_generator_disable(void)
|
|
|
|
{
|
|
|
|
SENS.sar_dac_ctrl1.sw_tone_en = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Enable the cosine wave generator of DAC channel.
|
|
|
|
*
|
|
|
|
* @param channel DAC channel num.
|
|
|
|
* @param enable
|
|
|
|
*/
|
2022-10-10 07:17:22 -04:00
|
|
|
static inline void dac_ll_cw_enable_channel(dac_channel_t channel, bool enable)
|
2019-07-19 09:20:16 -04:00
|
|
|
{
|
2022-05-24 05:26:36 -04:00
|
|
|
if (channel == DAC_CHAN_0) {
|
2019-07-19 09:20:16 -04:00
|
|
|
SENS.sar_dac_ctrl2.dac_cw_en1 = enable;
|
2022-05-24 05:26:36 -04:00
|
|
|
} else if (channel == DAC_CHAN_1) {
|
2019-07-19 09:20:16 -04:00
|
|
|
SENS.sar_dac_ctrl2.dac_cw_en2 = enable;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set frequency of cosine wave generator output.
|
|
|
|
*
|
|
|
|
* @note We know that CLK8M is about 8M, but don't know the actual value. so this freq have limited error.
|
2022-10-10 07:17:22 -04:00
|
|
|
* @param freq_hz CW generator frequency. Range: >= 130Hz, no exact ceiling limitation, but will distort when reach several MHz
|
2022-05-24 05:26:36 -04:00
|
|
|
* @param rtc8m_freq the calibrated RTC 8M clock frequency
|
2019-07-19 09:20:16 -04:00
|
|
|
*/
|
2022-05-24 05:26:36 -04:00
|
|
|
static inline void dac_ll_cw_set_freq(uint32_t freq, uint32_t rtc8m_freq)
|
2019-07-19 09:20:16 -04:00
|
|
|
{
|
2022-10-10 07:17:22 -04:00
|
|
|
uint32_t sw_freq = (uint32_t)(((uint64_t)freq << 16) / rtc8m_freq);
|
2021-08-23 02:03:23 -04:00
|
|
|
HAL_FORCE_MODIFY_U32_REG_FIELD(SENS.sar_dac_ctrl1, sw_fstep, (sw_freq > 0xFFFF) ? 0xFFFF : sw_freq);
|
2019-07-19 09:20:16 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the amplitude of the cosine wave generator output.
|
|
|
|
*
|
|
|
|
* @param channel DAC channel num.
|
2022-10-10 07:17:22 -04:00
|
|
|
* @param atten The attenuation of the amplitude. The max amplitude is VDD3P3_RTC.
|
|
|
|
* 0: attenuation = 1, amplitude = VDD3P3_RTC / attenuation,
|
|
|
|
* 1: attenuation = 2, amplitude = VDD3P3_RTC / attenuation,
|
|
|
|
* 2: attenuation = 4, amplitude = VDD3P3_RTC / attenuation,
|
|
|
|
* 3: attenuation = 8, amplitude = VDD3P3_RTC / attenuation
|
2019-07-19 09:20:16 -04:00
|
|
|
*/
|
2022-10-10 07:17:22 -04:00
|
|
|
static inline void dac_ll_cw_set_atten(dac_channel_t channel, dac_cosine_atten_t atten)
|
2019-07-19 09:20:16 -04:00
|
|
|
{
|
2022-05-24 05:26:36 -04:00
|
|
|
if (channel == DAC_CHAN_0) {
|
2022-10-10 07:17:22 -04:00
|
|
|
SENS.sar_dac_ctrl2.dac_scale1 = atten;
|
2022-05-24 05:26:36 -04:00
|
|
|
} else if (channel == DAC_CHAN_1) {
|
2022-10-10 07:17:22 -04:00
|
|
|
SENS.sar_dac_ctrl2.dac_scale2 = atten;
|
2019-07-19 09:20:16 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the phase of the cosine wave generator output.
|
|
|
|
*
|
|
|
|
* @param channel DAC channel num.
|
2022-05-24 05:26:36 -04:00
|
|
|
* @param phase Phase value. 0: 0x02 180: 0x03.
|
2019-07-19 09:20:16 -04:00
|
|
|
*/
|
2022-10-10 07:17:22 -04:00
|
|
|
static inline void dac_ll_cw_set_phase(dac_channel_t channel, dac_cosine_phase_t phase)
|
2019-07-19 09:20:16 -04:00
|
|
|
{
|
2022-05-24 05:26:36 -04:00
|
|
|
if (channel == DAC_CHAN_0) {
|
2019-07-19 09:20:16 -04:00
|
|
|
SENS.sar_dac_ctrl2.dac_inv1 = phase;
|
2022-05-24 05:26:36 -04:00
|
|
|
} else if (channel == DAC_CHAN_1) {
|
2019-07-19 09:20:16 -04:00
|
|
|
SENS.sar_dac_ctrl2.dac_inv2 = phase;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the voltage value of the DC component of the cosine wave generator output.
|
|
|
|
*
|
|
|
|
* @note The DC offset setting should be after phase setting.
|
|
|
|
* @note Unreasonable settings can cause the signal to be oversaturated.
|
|
|
|
* @param channel DAC channel num.
|
|
|
|
* @param offset DC value. Range: -128 ~ 127.
|
|
|
|
*/
|
|
|
|
static inline void dac_ll_cw_set_dc_offset(dac_channel_t channel, int8_t offset)
|
|
|
|
{
|
2022-05-24 05:26:36 -04:00
|
|
|
if (channel == DAC_CHAN_0) {
|
|
|
|
if (SENS.sar_dac_ctrl2.dac_inv1 == DAC_LL_CW_PHASE_180) {
|
|
|
|
offset = -offset;
|
2019-07-19 09:20:16 -04:00
|
|
|
}
|
2022-07-27 02:44:17 -04:00
|
|
|
HAL_FORCE_MODIFY_U32_REG_FIELD(SENS.sar_dac_ctrl2, dac_dc1, offset);
|
2022-05-24 05:26:36 -04:00
|
|
|
} else if (channel == DAC_CHAN_1) {
|
|
|
|
if (SENS.sar_dac_ctrl2.dac_inv2 == DAC_LL_CW_PHASE_180) {
|
|
|
|
offset = -offset;
|
2019-07-19 09:20:16 -04:00
|
|
|
}
|
2022-07-27 02:44:17 -04:00
|
|
|
HAL_FORCE_MODIFY_U32_REG_FIELD(SENS.sar_dac_ctrl2, dac_dc2, offset);
|
2019-07-19 09:20:16 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-02-25 09:19:48 -05:00
|
|
|
/*---------------------------------------------------------------
|
|
|
|
Digital controller setting
|
|
|
|
---------------------------------------------------------------*/
|
|
|
|
|
2019-07-19 09:20:16 -04:00
|
|
|
/************************************/
|
|
|
|
/* DAC DMA API's */
|
|
|
|
/************************************/
|
2020-04-08 09:56:14 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Enable/disable invert the DAC digital controller clock signal.
|
2020-09-11 03:48:08 -04:00
|
|
|
*
|
2020-04-08 09:56:14 -04:00
|
|
|
* @param enable true or false.
|
|
|
|
*/
|
|
|
|
static inline void dac_ll_digi_clk_inv(bool enable)
|
|
|
|
{
|
|
|
|
SENS.sar_dac_ctrl1.dac_clk_inv = enable;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Enable/disable DAC-DMA mode for dac digital controller.
|
|
|
|
*/
|
|
|
|
static inline void dac_ll_digi_enable_dma(bool enable)
|
|
|
|
{
|
|
|
|
SENS.sar_dac_ctrl1.dac_dig_force = enable;
|
|
|
|
APB_SARADC.apb_dac_ctrl.apb_dac_trans = enable;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the number of interval clock cycles for the digital controller to trigger the DAC output.
|
|
|
|
* Expression: `dac_output_freq` = `controller_clk` / interval.
|
|
|
|
*
|
|
|
|
* @note The clocks of the DAC digital controller use the ADC digital controller clock divider.
|
|
|
|
*
|
|
|
|
* @param cycle The number of clock cycles for the trigger output interval. The unit is the divided clock.
|
|
|
|
*/
|
|
|
|
static inline void dac_ll_digi_set_trigger_interval(uint32_t cycle)
|
|
|
|
{
|
|
|
|
APB_SARADC.apb_dac_ctrl.dac_timer_target = cycle;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Enable/disable DAC digital controller to trigger the DAC output.
|
|
|
|
*
|
|
|
|
* @param enable true or false.
|
|
|
|
*/
|
|
|
|
static inline void dac_ll_digi_trigger_output(bool enable)
|
|
|
|
{
|
|
|
|
APB_SARADC.apb_dac_ctrl.dac_timer_en = enable;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set DAC conversion mode for digital controller.
|
|
|
|
*
|
|
|
|
* @param mode Conversion mode select. See ``dac_digi_convert_mode_t``.
|
|
|
|
*/
|
2022-05-09 05:33:51 -04:00
|
|
|
static inline void dac_ll_digi_set_convert_mode(bool is_alternate)
|
2020-04-08 09:56:14 -04:00
|
|
|
{
|
2022-05-09 05:33:51 -04:00
|
|
|
APB_SARADC.apb_dac_ctrl.apb_dac_alter_mode = is_alternate;
|
2020-04-08 09:56:14 -04:00
|
|
|
}
|
|
|
|
|
2019-07-19 09:20:16 -04:00
|
|
|
/**
|
2020-04-08 09:56:14 -04:00
|
|
|
* Reset FIFO of DAC digital controller.
|
2019-07-19 09:20:16 -04:00
|
|
|
*/
|
2020-04-08 09:56:14 -04:00
|
|
|
static inline void dac_ll_digi_fifo_reset(void)
|
2019-07-19 09:20:16 -04:00
|
|
|
{
|
2020-04-08 09:56:14 -04:00
|
|
|
APB_SARADC.apb_dac_ctrl.dac_reset_fifo = 1;
|
|
|
|
APB_SARADC.apb_dac_ctrl.dac_reset_fifo = 0;
|
2019-07-19 09:20:16 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2020-04-08 09:56:14 -04:00
|
|
|
* Reset DAC digital controller.
|
2019-07-19 09:20:16 -04:00
|
|
|
*/
|
2020-04-08 09:56:14 -04:00
|
|
|
static inline void dac_ll_digi_reset(void)
|
2019-07-19 09:20:16 -04:00
|
|
|
{
|
2020-04-08 09:56:14 -04:00
|
|
|
APB_SARADC.apb_dac_ctrl.apb_dac_rst = 1;
|
|
|
|
APB_SARADC.apb_dac_ctrl.apb_dac_rst = 0;
|
2020-01-26 22:43:08 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
2020-11-10 02:40:01 -05:00
|
|
|
#endif
|