dac: apply generic check macro

This commit is contained in:
morris 2021-08-25 17:02:19 +08:00
parent f8f9e545e8
commit c2d5af17a2
6 changed files with 26 additions and 46 deletions

View File

@ -8,6 +8,7 @@
#include <string.h> #include <string.h>
#include "esp_log.h" #include "esp_log.h"
#include "esp_err.h" #include "esp_err.h"
#include "esp_check.h"
#include "freertos/FreeRTOS.h" #include "freertos/FreeRTOS.h"
#include "freertos/semphr.h" #include "freertos/semphr.h"
#include "freertos/timers.h" #include "freertos/timers.h"
@ -18,21 +19,14 @@
extern portMUX_TYPE rtc_spinlock; //TODO: Will be placed in the appropriate position after the rtc module is finished. extern portMUX_TYPE rtc_spinlock; //TODO: Will be placed in the appropriate position after the rtc module is finished.
static const char *DAC_TAG = "DAC"; static const char *TAG = "DAC";
#define DAC_CHECK(a, str, ret_val) ({ \
if (!(a)) { \
ESP_LOGE(DAC_TAG,"%s(%d): %s", __FUNCTION__, __LINE__, str); \
return (ret_val); \
} \
})
/*--------------------------------------------------------------- /*---------------------------------------------------------------
DAC DAC
---------------------------------------------------------------*/ ---------------------------------------------------------------*/
esp_err_t dac_pad_get_io_num(dac_channel_t channel, gpio_num_t *gpio_num) esp_err_t dac_pad_get_io_num(dac_channel_t channel, gpio_num_t *gpio_num)
{ {
DAC_CHECK(channel < DAC_CHANNEL_MAX, "DAC channel error", ESP_ERR_INVALID_ARG); ESP_RETURN_ON_FALSE(channel < DAC_CHANNEL_MAX, ESP_ERR_INVALID_ARG, TAG, "DAC channel error");
*gpio_num = (gpio_num_t)dac_periph_signal.dac_channel_io_num[channel]; *gpio_num = (gpio_num_t)dac_periph_signal.dac_channel_io_num[channel];
@ -41,7 +35,7 @@ esp_err_t dac_pad_get_io_num(dac_channel_t channel, gpio_num_t *gpio_num)
static esp_err_t dac_rtc_pad_init(dac_channel_t channel) static esp_err_t dac_rtc_pad_init(dac_channel_t channel)
{ {
DAC_CHECK(channel < DAC_CHANNEL_MAX, "DAC channel error", ESP_ERR_INVALID_ARG); ESP_RETURN_ON_FALSE(channel < DAC_CHANNEL_MAX, ESP_ERR_INVALID_ARG, TAG, "DAC channel error");
gpio_num_t gpio_num = 0; gpio_num_t gpio_num = 0;
dac_pad_get_io_num(channel, &gpio_num); dac_pad_get_io_num(channel, &gpio_num);
@ -55,7 +49,7 @@ static esp_err_t dac_rtc_pad_init(dac_channel_t channel)
esp_err_t dac_output_enable(dac_channel_t channel) esp_err_t dac_output_enable(dac_channel_t channel)
{ {
DAC_CHECK(channel < DAC_CHANNEL_MAX, "DAC channel error", ESP_ERR_INVALID_ARG); ESP_RETURN_ON_FALSE(channel < DAC_CHANNEL_MAX, ESP_ERR_INVALID_ARG, TAG, "DAC channel error");
dac_rtc_pad_init(channel); dac_rtc_pad_init(channel);
portENTER_CRITICAL(&rtc_spinlock); portENTER_CRITICAL(&rtc_spinlock);
@ -68,7 +62,7 @@ esp_err_t dac_output_enable(dac_channel_t channel)
esp_err_t dac_output_disable(dac_channel_t channel) esp_err_t dac_output_disable(dac_channel_t channel)
{ {
DAC_CHECK(channel < DAC_CHANNEL_MAX, "DAC channel error", ESP_ERR_INVALID_ARG); ESP_RETURN_ON_FALSE(channel < DAC_CHANNEL_MAX, ESP_ERR_INVALID_ARG, TAG, "DAC channel error");
portENTER_CRITICAL(&rtc_spinlock); portENTER_CRITICAL(&rtc_spinlock);
dac_hal_power_down(channel); dac_hal_power_down(channel);
@ -79,7 +73,7 @@ esp_err_t dac_output_disable(dac_channel_t channel)
esp_err_t dac_output_voltage(dac_channel_t channel, uint8_t dac_value) esp_err_t dac_output_voltage(dac_channel_t channel, uint8_t dac_value)
{ {
DAC_CHECK(channel < DAC_CHANNEL_MAX, "DAC channel error", ESP_ERR_INVALID_ARG); ESP_RETURN_ON_FALSE(channel < DAC_CHANNEL_MAX, ESP_ERR_INVALID_ARG, TAG, "DAC channel error");
portENTER_CRITICAL(&rtc_spinlock); portENTER_CRITICAL(&rtc_spinlock);
dac_hal_update_output_value(channel, dac_value); dac_hal_update_output_value(channel, dac_value);
@ -90,7 +84,7 @@ esp_err_t dac_output_voltage(dac_channel_t channel, uint8_t dac_value)
esp_err_t dac_out_voltage(dac_channel_t channel, uint8_t dac_value) esp_err_t dac_out_voltage(dac_channel_t channel, uint8_t dac_value)
{ {
DAC_CHECK(channel < DAC_CHANNEL_MAX, "DAC channel error", ESP_ERR_INVALID_ARG); ESP_RETURN_ON_FALSE(channel < DAC_CHANNEL_MAX, ESP_ERR_INVALID_ARG, TAG, "DAC channel error");
portENTER_CRITICAL(&rtc_spinlock); portENTER_CRITICAL(&rtc_spinlock);
dac_hal_update_output_value(channel, dac_value); dac_hal_update_output_value(channel, dac_value);
@ -119,7 +113,7 @@ esp_err_t dac_cw_generator_disable(void)
esp_err_t dac_cw_generator_config(dac_cw_config_t *cw) esp_err_t dac_cw_generator_config(dac_cw_config_t *cw)
{ {
if (!cw) return ESP_ERR_INVALID_ARG; ESP_RETURN_ON_FALSE(cw, ESP_ERR_INVALID_ARG, TAG, "invalid clock configuration");
portENTER_CRITICAL(&rtc_spinlock); portENTER_CRITICAL(&rtc_spinlock);
dac_hal_cw_generator_config(cw); dac_hal_cw_generator_config(cw);

View File

@ -8,6 +8,7 @@
#include <string.h> #include <string.h>
#include "esp_log.h" #include "esp_log.h"
#include "esp_err.h" #include "esp_err.h"
#include "esp_check.h"
#include "esp_pm.h" #include "esp_pm.h"
#include "freertos/FreeRTOS.h" #include "freertos/FreeRTOS.h"
#include "freertos/semphr.h" #include "freertos/semphr.h"
@ -17,14 +18,7 @@
#include "soc/dac_periph.h" #include "soc/dac_periph.h"
#include "hal/dac_hal.h" #include "hal/dac_hal.h"
static const char *DAC_TAG = "DAC"; static const char *TAG = "DAC";
#define DAC_CHECK(a, str, ret_val) ({ \
if (!(a)) { \
ESP_LOGE(DAC_TAG,"%s(%d): %s", __FUNCTION__, __LINE__, str); \
return (ret_val); \
} \
})
extern portMUX_TYPE rtc_spinlock; //TODO: Will be placed in the appropriate position after the rtc module is finished. extern portMUX_TYPE rtc_spinlock; //TODO: Will be placed in the appropriate position after the rtc module is finished.
#define DAC_ENTER_CRITICAL() portENTER_CRITICAL(&rtc_spinlock) #define DAC_ENTER_CRITICAL() portENTER_CRITICAL(&rtc_spinlock)
@ -64,11 +58,11 @@ esp_err_t dac_digi_deinit(void)
esp_err_t dac_digi_controller_config(const dac_digi_config_t *cfg) esp_err_t dac_digi_controller_config(const dac_digi_config_t *cfg)
{ {
DAC_CHECK(cfg->mode < DAC_CONV_MAX, "DAC mode error", ESP_ERR_INVALID_ARG); ESP_RETURN_ON_FALSE(cfg->mode < DAC_CONV_MAX, ESP_ERR_INVALID_ARG, TAG, "DAC mode error");
DAC_CHECK(cfg->interval > 0 && cfg->interval < 4096, "DAC interval error", ESP_ERR_INVALID_ARG); ESP_RETURN_ON_FALSE(cfg->interval > 0 && cfg->interval < 4096, ESP_ERR_INVALID_ARG, TAG, "DAC interval error");
DAC_CHECK(cfg->dig_clk.div_num < 256, "DAC clk div_num error", ESP_ERR_INVALID_ARG); ESP_RETURN_ON_FALSE(cfg->dig_clk.div_num < 256, ESP_ERR_INVALID_ARG, TAG, "DAC clk div_num error");
DAC_CHECK(cfg->dig_clk.div_b > 0 && cfg->dig_clk.div_b < 64, "DAC clk div_b error", ESP_ERR_INVALID_ARG); ESP_RETURN_ON_FALSE(cfg->dig_clk.div_b > 0 && cfg->dig_clk.div_b < 64, ESP_ERR_INVALID_ARG, TAG, "DAC clk div_b error");
DAC_CHECK(cfg->dig_clk.div_a < 64, "DAC clk div_a error", ESP_ERR_INVALID_ARG); ESP_RETURN_ON_FALSE(cfg->dig_clk.div_a < 64, ESP_ERR_INVALID_ARG, TAG, "DAC clk div_a error");
#ifdef CONFIG_PM_ENABLE #ifdef CONFIG_PM_ENABLE
esp_err_t err; esp_err_t err;
if (s_dac_digi_lock == NULL) { if (s_dac_digi_lock == NULL) {
@ -79,7 +73,7 @@ esp_err_t dac_digi_controller_config(const dac_digi_config_t *cfg)
} }
if (err != ESP_OK) { if (err != ESP_OK) {
s_dac_digi_lock = NULL; s_dac_digi_lock = NULL;
ESP_LOGE(DAC_TAG, "DAC-DMA pm lock error"); ESP_LOGE(TAG, "DAC-DMA pm lock error");
return err; return err;
} }
} }
@ -95,7 +89,7 @@ esp_err_t dac_digi_controller_config(const dac_digi_config_t *cfg)
esp_err_t dac_digi_start(void) esp_err_t dac_digi_start(void)
{ {
#ifdef CONFIG_PM_ENABLE #ifdef CONFIG_PM_ENABLE
DAC_CHECK((s_dac_digi_lock), "Should start after call `dac_digi_controller_config`", ESP_FAIL); ESP_RETURN_ON_FALSE(s_dac_digi_lock, ESP_FAIL, TAG, "Should start after call `dac_digi_controller_config`");
esp_pm_lock_acquire(s_dac_digi_lock); esp_pm_lock_acquire(s_dac_digi_lock);
#endif #endif
DAC_ENTER_CRITICAL(); DAC_ENTER_CRITICAL();

View File

@ -18,15 +18,12 @@
#include "soc/soc_caps.h" #include "soc/soc_caps.h"
#include "soc/gpio_periph.h" #include "soc/gpio_periph.h"
#include "esp_log.h" #include "esp_log.h"
#include "esp_check.h"
#include "hal/gpio_hal.h" #include "hal/gpio_hal.h"
#include "esp_rom_gpio.h" #include "esp_rom_gpio.h"
static const char *GPIO_TAG = "gpio"; static const char *GPIO_TAG = "gpio";
#define GPIO_CHECK(a, str, ret_val) \ #define GPIO_CHECK(a, str, ret_val) ESP_RETURN_ON_FALSE(a, ret_val, GPIO_TAG, "%s", str)
if (!(a)) { \
ESP_LOGE(GPIO_TAG,"%s(%d): %s", __FUNCTION__, __LINE__, str); \
return (ret_val); \
}
#define GPIO_ISR_CORE_ID_UNINIT (3) #define GPIO_ISR_CORE_ID_UNINIT (3)

View File

@ -22,8 +22,8 @@
static const char* LEDC_TAG = "ledc"; static const char* LEDC_TAG = "ledc";
#define LEDC_CHECK(a, str, ret_val) ESP_RETURN_ON_FALSE(a, ret_val, LEDC_TAG, "%s", str); #define LEDC_CHECK(a, str, ret_val) ESP_RETURN_ON_FALSE(a, ret_val, LEDC_TAG, "%s", str)
#define LEDC_ARG_CHECK(a, param) ESP_RETURN_ON_FALSE(a, ESP_ERR_INVALID_ARG, LEDC_TAG, param " argument is invalid"); #define LEDC_ARG_CHECK(a, param) ESP_RETURN_ON_FALSE(a, ESP_ERR_INVALID_ARG, LEDC_TAG, param " argument is invalid")
typedef struct { typedef struct {
ledc_mode_t speed_mode; ledc_mode_t speed_mode;

View File

@ -5,6 +5,7 @@
*/ */
#include "freertos/FreeRTOS.h" #include "freertos/FreeRTOS.h"
#include "esp_log.h" #include "esp_log.h"
#include "esp_check.h"
#include "soc/soc_caps.h" #include "soc/soc_caps.h"
#if SOC_PCNT_SUPPORTED #if SOC_PCNT_SUPPORTED
#include "driver/periph_ctrl.h" #include "driver/periph_ctrl.h"
@ -32,11 +33,7 @@
static const char *TAG = "pcnt"; static const char *TAG = "pcnt";
#define PCNT_CHECK(a, str, ret_val) \ #define PCNT_CHECK(a, str, ret_val) ESP_RETURN_ON_FALSE(a, ret_val, TAG, "%s", str)
if (!(a)) { \
ESP_LOGE(TAG,"%s(%d): %s", __FUNCTION__, __LINE__, str); \
return (ret_val); \
}
typedef struct { typedef struct {
pcnt_hal_context_t hal; /*!< PCNT hal context*/ pcnt_hal_context_t hal; /*!< PCNT hal context*/

View File

@ -5,6 +5,7 @@
*/ */
#include "esp_log.h" #include "esp_log.h"
#include "esp_check.h"
#include "esp_err.h" #include "esp_err.h"
#include "driver/sigmadelta.h" #include "driver/sigmadelta.h"
#include "esp_heap_caps.h" #include "esp_heap_caps.h"
@ -14,10 +15,7 @@
static const char *TAG = "sigma-delta"; static const char *TAG = "sigma-delta";
#define SIGMADELTA_CHECK(a,str,ret_val) if(!(a)) { \ #define SIGMADELTA_CHECK(a,str,ret_val) ESP_RETURN_ON_FALSE(a, ret_val, TAG, "%s", str)
ESP_LOGE(TAG,"%s(%d): %s", __FUNCTION__, __LINE__, str); \
return (ret_val); \
}
typedef struct { typedef struct {
sigmadelta_hal_context_t hal; /*!< SIGMADELTA hal context*/ sigmadelta_hal_context_t hal; /*!< SIGMADELTA hal context*/