From 02b2f9a4c47404b51935b36fe020233c2b763407 Mon Sep 17 00:00:00 2001 From: Armando Date: Tue, 27 Aug 2024 16:53:36 +0800 Subject: [PATCH 1/3] feat(isp): added isp demosaic driver --- components/esp_driver_isp/CMakeLists.txt | 4 + .../esp_driver_isp/include/driver/isp.h | 4 +- .../include/driver/isp_demosaic.h | 72 +++++++++++++++ .../include/driver/isp_sharpen.h | 2 +- .../include/esp_private/isp_private.h | 1 + components/esp_driver_isp/linker.lf | 2 + components/esp_driver_isp/src/isp_demosaic.c | 66 ++++++++++++++ components/hal/esp32p4/include/hal/isp_ll.h | 87 ++++++++++++++++++- components/hal/include/hal/isp_hal.h | 28 +++++- components/hal/include/hal/isp_types.h | 35 +++++++- components/hal/isp_hal.c | 23 ++++- .../esp32p4/include/soc/Kconfig.soc_caps.in | 16 ++++ components/soc/esp32p4/include/soc/soc_caps.h | 4 + 13 files changed, 338 insertions(+), 6 deletions(-) create mode 100644 components/esp_driver_isp/include/driver/isp_demosaic.h create mode 100644 components/esp_driver_isp/src/isp_demosaic.c diff --git a/components/esp_driver_isp/CMakeLists.txt b/components/esp_driver_isp/CMakeLists.txt index ac61811fe726..ed1d85566203 100644 --- a/components/esp_driver_isp/CMakeLists.txt +++ b/components/esp_driver_isp/CMakeLists.txt @@ -22,6 +22,10 @@ if(CONFIG_SOC_ISP_BF_SUPPORTED) list(APPEND srcs "src/isp_bf.c") endif() +if(CONFIG_SOC_ISP_DEMOSAIC_SUPPORTED) + list(APPEND srcs "src/isp_demosaic.c") +endif() + if(CONFIG_SOC_ISP_SHARPEN_SUPPORTED) list(APPEND srcs "src/isp_sharpen.c") endif() diff --git a/components/esp_driver_isp/include/driver/isp.h b/components/esp_driver_isp/include/driver/isp.h index 9511c278fe56..d188c5aa62d4 100644 --- a/components/esp_driver_isp/include/driver/isp.h +++ b/components/esp_driver_isp/include/driver/isp.h @@ -17,5 +17,7 @@ #include "driver/isp_awb.h" #include "driver/isp_bf.h" #include "driver/isp_ccm.h" -#include "driver/isp_sharpen.h" +#include "driver/isp_demosaic.h" +#include "driver/isp_gamma.h" #include "driver/isp_hist.h" +#include "driver/isp_sharpen.h" diff --git a/components/esp_driver_isp/include/driver/isp_demosaic.h b/components/esp_driver_isp/include/driver/isp_demosaic.h new file mode 100644 index 000000000000..c3fac3967515 --- /dev/null +++ b/components/esp_driver_isp/include/driver/isp_demosaic.h @@ -0,0 +1,72 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#pragma once + +#include +#include "esp_err.h" +#include "driver/isp_types.h" + +#ifdef __cplusplus +extern "C" { +#endif + +/** + * @brief ISP Demosaic configurations + */ +typedef struct { + isp_demosaic_grad_ratio_t grad_ratio; /**< Demosaic gradient ratio, + - gradient_x * grad_ratio < gradient_y, use interpolation results in X direction + - gradient_y * grad_ratio < gradient_x, use interpolation results in Y direction + - else use the average results between X and Y + */ + isp_demosaic_edge_padding_mode_t padding_mode; ///< Demosaic edge padding mode + uint8_t padding_data; ///< Demosaic edge padding pixel data + uint8_t padding_line_tail_valid_start_pixel; ///< Demosaic edge padding line tail valid start pixel, padding data will only be valid between the valid start pixel and the valid end pixel. Set both the start and end pixel to 0 to make all padding pixel valid + uint8_t padding_line_tail_valid_end_pixel; ///< Demosaic edge padding line tail valid end pixel, padding data will only be valid between the valid start pixel and the valid end pixel. Set both the start and end pixel to 0 to make all padding pixel valid +} esp_isp_demosaic_config_t; + +/** + * @brief ISP Demosaic configuration + * + * @note After calling this API, Demosaic doesn't take into effect until `esp_isp_demosaic_enable` is called + * + * @param[in] proc Processor handle + * @param[in] config Demosaic configurations, set NULL to de-configure the ISP Demosaic + * + * @return + * - ESP_OK On success + * - ESP_ERR_INVALID_ARG If the combination of arguments is invalid + */ +esp_err_t esp_isp_demosaic_configure(isp_proc_handle_t proc, const esp_isp_demosaic_config_t *config); + +/** + * @brief Enable ISP Demosaic function + * + * @param[in] proc Processor handle + * + * @return + * - ESP_OK On success + * - ESP_ERR_INVALID_ARG If the combination of arguments is invalid. + * - ESP_ERR_INVALID_STATE Driver state is invalid. + */ +esp_err_t esp_isp_demosaic_enable(isp_proc_handle_t proc); + +/** + * @brief Disable ISP Demosaic function + * + * @param[in] proc Processor handle + * + * @return + * - ESP_OK On success + * - ESP_ERR_INVALID_ARG If the combination of arguments is invalid. + * - ESP_ERR_INVALID_STATE Driver state is invalid. + */ +esp_err_t esp_isp_demosaic_disable(isp_proc_handle_t proc); + +#ifdef __cplusplus +} +#endif diff --git a/components/esp_driver_isp/include/driver/isp_sharpen.h b/components/esp_driver_isp/include/driver/isp_sharpen.h index a1300dc53c3a..636454affb35 100644 --- a/components/esp_driver_isp/include/driver/isp_sharpen.h +++ b/components/esp_driver_isp/include/driver/isp_sharpen.h @@ -18,7 +18,7 @@ extern "C" { * @brief ISP Sharpen configurations */ typedef struct { - isp_sharpen_h_freq_coeff h_freq_coeff; ///< High freq pixel sharpeness coeff + isp_sharpen_h_freq_coeff_t h_freq_coeff; ///< High freq pixel sharpeness coeff isp_sharpen_m_freq_coeff m_freq_coeff; ///< Medium freq pixel sharpeness coeff uint8_t h_thresh; ///< High threshold, pixel value higher than this threshold will be multiplied by `h_freq_coeff` uint8_t l_thresh; ///< Low threshold, pixel value higher than this threshold but lower than `h_thresh` will be multiplied by `m_freq_coeff`. Pixel value lower than this threshold will be set to 0 diff --git a/components/esp_driver_isp/include/esp_private/isp_private.h b/components/esp_driver_isp/include/esp_private/isp_private.h index 5af0fdfc93ff..f69aab59bf8a 100644 --- a/components/esp_driver_isp/include/esp_private/isp_private.h +++ b/components/esp_driver_isp/include/esp_private/isp_private.h @@ -70,6 +70,7 @@ typedef struct isp_processor_t { isp_ae_ctlr_t ae_ctlr; isp_hist_ctlr_t hist_ctlr; isp_fsm_t bf_fsm; + isp_fsm_t demosaic_fsm; isp_fsm_t sharpen_fsm; esp_isp_evt_cbs_t cbs; void *user_data; diff --git a/components/esp_driver_isp/linker.lf b/components/esp_driver_isp/linker.lf index c9ed2f06b0bb..43a8d0cc5d73 100644 --- a/components/esp_driver_isp/linker.lf +++ b/components/esp_driver_isp/linker.lf @@ -3,6 +3,7 @@ archive: libesp_driver_isp.a entries: if ISP_CTRL_FUNC_IN_IRAM = y: isp_sharpen: esp_isp_sharpen_configure (noflash) + isp_demosaic: esp_isp_demosaic_configure (noflash) isp_gamma: esp_isp_gamma_configure (noflash) isp_gamma: esp_isp_gamma_fill_curve_points (noflash) @@ -11,3 +12,4 @@ archive: libhal.a entries: if ISP_CTRL_FUNC_IN_IRAM = y: isp_hal: isp_hal_sharpen_config (noflash) + isp_hal: isp_hal_demosaic_config (noflash) diff --git a/components/esp_driver_isp/src/isp_demosaic.c b/components/esp_driver_isp/src/isp_demosaic.c new file mode 100644 index 000000000000..8c2e0e3018a5 --- /dev/null +++ b/components/esp_driver_isp/src/isp_demosaic.c @@ -0,0 +1,66 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#include +#include +#include "sdkconfig.h" +#include "esp_log.h" +#include "esp_check.h" +#include "freertos/FreeRTOS.h" +#include "driver/isp_core.h" +#include "driver/isp_demosaic.h" +#include "soc/isp_periph.h" +#include "esp_private/isp_private.h" + +static const char *TAG = "ISP_DEMOSAIC"; + +/*--------------------------------------------------------------- + Demosaic +---------------------------------------------------------------*/ +esp_err_t esp_isp_demosaic_configure(isp_proc_handle_t proc, const esp_isp_demosaic_config_t *config) +{ + ESP_RETURN_ON_FALSE_ISR(proc, ESP_ERR_INVALID_ARG, TAG, "invalid argument: null pointer"); + + if (config) { + bool valid_padding_setting = (!config->padding_line_tail_valid_end_pixel && !config->padding_line_tail_valid_start_pixel) || (config->padding_line_tail_valid_end_pixel > config->padding_line_tail_valid_start_pixel); + ESP_RETURN_ON_FALSE_ISR(valid_padding_setting, ESP_ERR_INVALID_ARG, TAG, "wrong padding line tail valid pixel setting"); + + isp_hal_demosaic_cfg_t demosaic_hal_cfg = { + .grad_ratio = config->grad_ratio, + .padding_mode = config->padding_mode, + .padding_data = config->padding_data, + .padding_line_tail_valid_start_pixel = config->padding_line_tail_valid_start_pixel, + .padding_line_tail_valid_end_pixel = config->padding_line_tail_valid_end_pixel, + }; + isp_hal_demosaic_config(&(proc->hal), &demosaic_hal_cfg); + } else { + isp_hal_demosaic_config(&(proc->hal), NULL); + } + + return ESP_OK; +} + +esp_err_t esp_isp_demosaic_enable(isp_proc_handle_t proc) +{ + ESP_RETURN_ON_FALSE(proc, ESP_ERR_INVALID_ARG, TAG, "invalid argument: null pointer"); + ESP_RETURN_ON_FALSE(proc->demosaic_fsm == ISP_FSM_INIT, ESP_ERR_INVALID_STATE, TAG, "demosaic is enabled already"); + + isp_ll_demosaic_enable(proc->hal.hw, true); + proc->demosaic_fsm = ISP_FSM_ENABLE; + + return ESP_OK; +} + +esp_err_t esp_isp_demosaic_disable(isp_proc_handle_t proc) +{ + ESP_RETURN_ON_FALSE(proc, ESP_ERR_INVALID_ARG, TAG, "invalid argument: null pointer"); + ESP_RETURN_ON_FALSE(proc->demosaic_fsm == ISP_FSM_ENABLE, ESP_ERR_INVALID_STATE, TAG, "demosaic isn't enabled yet"); + + isp_ll_demosaic_enable(proc->hal.hw, false); + proc->demosaic_fsm = ISP_FSM_INIT; + + return ESP_OK; +} diff --git a/components/hal/esp32p4/include/hal/isp_ll.h b/components/hal/esp32p4/include/hal/isp_ll.h index 90d268256a42..6aad034f4bc0 100644 --- a/components/hal/esp32p4/include/hal/isp_ll.h +++ b/components/hal/esp32p4/include/hal/isp_ll.h @@ -1327,6 +1327,91 @@ static inline uint32_t isp_ll_awb_get_accumulated_b_value(isp_dev_t *hw) return hw->awb0_acc_b.awb0_acc_b; } +/*--------------------------------------------------------------- + Demosaic +---------------------------------------------------------------*/ +/** + * @brief Enable / Disable demosaic clock + * + * @param[in] hw Hardware instance address + * @param[in] enable Enable / Disable + */ +static inline void isp_ll_demosaic_clk_enable(isp_dev_t *hw, bool enable) +{ + hw->clk_en.clk_demosaic_force_on = enable; +} + +/** + * @brief Enable / Disable demosaic + * + * @param[in] hw Hardware instance address + * @param[in] enable Enable / Disable + */ +static inline void isp_ll_demosaic_enable(isp_dev_t *hw, bool enable) +{ + hw->cntl.demosaic_en = enable; +} + +/** + * @brief Set demosaic low thresh + * + * @param[in] hw Hardware instance address + * @param[in] thresh Thresh + */ +__attribute__((always_inline)) +static inline void isp_ll_demosaic_set_grad_ratio(isp_dev_t *hw, isp_demosaic_grad_ratio_t grad_ratio) +{ + hw->demosaic_grad_ratio.demosaic_grad_ratio = grad_ratio.val; +} + +/** + * @brief Set ISP demosaic padding mode + * + * @param[in] hw Hardware instance address + * @param[in] padding_mode padding mode + */ +__attribute__((always_inline)) +static inline void isp_ll_demosaic_set_padding_mode(isp_dev_t *hw, isp_demosaic_edge_padding_mode_t padding_mode) +{ + hw->demosaic_matrix_ctrl.demosaic_padding_mode = padding_mode; +} + +/** + * @brief Set ISP demosaic padding data + * + * @param[in] hw Hardware instance address + * @param[in] padding_data padding data + */ +__attribute__((always_inline)) +static inline void isp_ll_demosaic_set_padding_data(isp_dev_t *hw, uint32_t padding_data) +{ + hw->demosaic_matrix_ctrl.demosaic_padding_data = padding_data; +} + +/** + * @brief Set ISP demosaic tail start pulse pixel + * + * @param[in] hw Hardware instance address + * @param[in] start_pixel start pixel value + */ +__attribute__((always_inline)) +static inline void isp_ll_demosaic_set_padding_line_tail_valid_start_pixel(isp_dev_t *hw, uint32_t start_pixel) +{ + hw->demosaic_matrix_ctrl.demosaic_tail_pixen_pulse_tl = start_pixel; +} + +/** + * @brief Set ISP demosaic tail pulse end pixel + * + * @param[in] hw Hardware instance address + * @param[in] end_pixel end pixel value + */ +__attribute__((always_inline)) +static inline void isp_ll_demosaic_set_padding_line_tail_valid_end_pixel(isp_dev_t *hw, uint32_t end_pixel) +{ + hw->demosaic_matrix_ctrl.demosaic_tail_pixen_pulse_th = end_pixel; +} + /*--------------------------------------------------------------- Sharpen ---------------------------------------------------------------*/ @@ -1396,7 +1481,7 @@ static inline void isp_ll_sharp_set_medium_freq_coeff(isp_dev_t *hw, isp_sharpen * @param[in] coeff coeff */ __attribute__((always_inline)) -static inline void isp_ll_sharp_set_high_freq_coeff(isp_dev_t *hw, isp_sharpen_h_freq_coeff coeff) +static inline void isp_ll_sharp_set_high_freq_coeff(isp_dev_t *hw, isp_sharpen_h_freq_coeff_t coeff) { //val higher than `sharp_threshold_high` will be multiplied by `sharp_amount_high` hw->sharp_ctrl0.sharp_amount_high = coeff.val; diff --git a/components/hal/include/hal/isp_hal.h b/components/hal/include/hal/isp_hal.h index b4e38ffd4d74..fe60bc4920af 100644 --- a/components/hal/include/hal/isp_hal.h +++ b/components/hal/include/hal/isp_hal.h @@ -33,11 +33,26 @@ typedef struct { uint8_t padding_line_tail_valid_end_pixel; ///< BF edge padding line tail valid end pixel } isp_hal_bf_cfg_t; +/** + * @brief Demosaic configurations + */ +typedef struct { + isp_demosaic_grad_ratio_t grad_ratio; /**< Demosaic gradient ratio, + - gradient_x * grad_ratio < gradient_y, use interpolation results in X direction + - gradient_y * grad_ratio < gradient_x, use interpolation results in Y direction + - else use the average results between X and Y + */ + isp_demosaic_edge_padding_mode_t padding_mode; ///< Sharpen edge padding mode + uint8_t padding_data; ///< Sharpen edge padding pixel data + uint8_t padding_line_tail_valid_start_pixel; ///< Sharpen edge padding line tail valid start pixel + uint8_t padding_line_tail_valid_end_pixel; ///< Sharpen edge padding line tail valid end pixel +} isp_hal_demosaic_cfg_t; + /** * @brief Sharpen configurations */ typedef struct { - isp_sharpen_h_freq_coeff h_freq_coeff; ///< High freq pixel sharpeness coeff + isp_sharpen_h_freq_coeff_t h_freq_coeff; ///< High freq pixel sharpeness coeff isp_sharpen_m_freq_coeff m_freq_coeff; ///< Medium freq pixel sharpeness coeff uint8_t h_thresh; ///< High threshold, pixel value higher than this threshold will be multiplied by `h_freq_coeff` uint8_t l_thresh; ///< Low threshold, pixel value higher than this threshold but lower than `h_thresh` will be multiplied by `m_freq_coeff`. Pixel value lower than this threshold will be set to 0 @@ -166,6 +181,17 @@ void isp_hal_bf_config(isp_hal_context_t *hal, isp_hal_bf_cfg_t *config); */ bool isp_hal_ccm_set_matrix(const isp_hal_context_t *hal, bool saturation, const float flt_matrix[ISP_CCM_DIMENSION][ISP_CCM_DIMENSION]); +/*--------------------------------------------------------------- + Demosaic +---------------------------------------------------------------*/ +/** + * @brief Configure ISP Demosaic + * + * @param[in] hal Context of the HAL layer + * @param[in] config Demosaic config, set NULL to de-config the ISP Demosaic + */ +void isp_hal_demosaic_config(isp_hal_context_t *hal, isp_hal_demosaic_cfg_t *config); + /*--------------------------------------------------------------- INTR ---------------------------------------------------------------*/ diff --git a/components/hal/include/hal/isp_types.h b/components/hal/include/hal/isp_types.h index 81210da06e82..d16825e125a2 100644 --- a/components/hal/include/hal/isp_types.h +++ b/components/hal/include/hal/isp_types.h @@ -161,6 +161,39 @@ typedef enum { #define ISP_CCM_DIMENSION 0 ///< Not support CCM #endif +/*--------------------------------------------------------------- + Demosaic +---------------------------------------------------------------*/ +#if SOC_ISP_DEMOSAIC_SUPPORTED +#define ISP_DEMOSAIC_GRAD_RATIO_INT_BITS SOC_ISP_DEMOSAIC_GRAD_RATIO_INT_BITS +#define ISP_DEMOSAIC_GRAD_RATIO_DEC_BITS SOC_ISP_DEMOSAIC_GRAD_RATIO_DEC_BITS +#define ISP_DEMOSAIC_GRAD_RATIO_RES_BITS SOC_ISP_DEMOSAIC_GRAD_RATIO_RES_BITS +#else +#define ISP_DEMOSAIC_GRAD_RATIO_INT_BITS 8 +#define ISP_DEMOSAIC_GRAD_RATIO_DEC_BITS 8 +#define ISP_DEMOSAIC_GRAD_RATIO_RES_BITS 16 +#endif + +/** + * @brief Gradient ratio + */ +typedef union { + struct { + uint32_t decimal:ISP_DEMOSAIC_GRAD_RATIO_DEC_BITS; ///< Integer part + uint32_t integer:ISP_DEMOSAIC_GRAD_RATIO_INT_BITS; ///< Decimal part + uint32_t reserved:ISP_DEMOSAIC_GRAD_RATIO_RES_BITS; ///< Reserved + }; + uint32_t val; ///< 32-bit gradient ratio value +} isp_demosaic_grad_ratio_t; + +/** + * @brief ISP Demosaic edge padding mode + */ +typedef enum { + ISP_DEMOSAIC_EDGE_PADDING_MODE_SRND_DATA, ///< Fill Demosaic edge padding data with surrounding pixel data + ISP_DEMOSAIC_EDGE_PADDING_MODE_CUSTOM_DATA, ///< Fill Demosaic edge padding data with custom pixel data +} isp_demosaic_edge_padding_mode_t; + /*--------------------------------------------------------------- DVP ---------------------------------------------------------------*/ @@ -203,7 +236,7 @@ typedef union { uint32_t reserved:ISP_SHARPEN_H_FREQ_COEF_RES_BITS; ///< Reserved }; uint32_t val; ///< 32-bit high freq pixel sharpeness coeff register value -} isp_sharpen_h_freq_coeff; +} isp_sharpen_h_freq_coeff_t; /** * @brief Medium freq pixel sharpeness coeff diff --git a/components/hal/isp_hal.c b/components/hal/isp_hal.c index 864e4026c134..b9f315e9980d 100644 --- a/components/hal/isp_hal.c +++ b/components/hal/isp_hal.c @@ -168,6 +168,27 @@ bool isp_hal_ccm_set_matrix(const isp_hal_context_t *hal, bool saturation, const return true; } +/*--------------------------------------------------------------- + Demosaic +---------------------------------------------------------------*/ +void isp_hal_demosaic_config(isp_hal_context_t *hal, isp_hal_demosaic_cfg_t *config) +{ + if (config) { + isp_ll_demosaic_set_grad_ratio(hal->hw, config->grad_ratio); + isp_ll_demosaic_set_padding_mode(hal->hw, config->padding_mode); + isp_ll_demosaic_set_padding_data(hal->hw, config->padding_data); + isp_ll_demosaic_set_padding_line_tail_valid_start_pixel(hal->hw, config->padding_line_tail_valid_start_pixel); + isp_ll_demosaic_set_padding_line_tail_valid_end_pixel(hal->hw, config->padding_line_tail_valid_end_pixel); + } else { + isp_demosaic_grad_ratio_t grad_ratio = {}; + isp_ll_demosaic_set_grad_ratio(hal->hw, grad_ratio); + isp_ll_demosaic_set_padding_mode(hal->hw, 0); + isp_ll_demosaic_set_padding_data(hal->hw, 0); + isp_ll_demosaic_set_padding_line_tail_valid_start_pixel(hal->hw, 0); + isp_ll_demosaic_set_padding_line_tail_valid_end_pixel(hal->hw, 0); + } +} + /*--------------------------------------------------------------- Histogram ---------------------------------------------------------------*/ @@ -202,7 +223,7 @@ void isp_hal_sharpen_config(isp_hal_context_t *hal, isp_hal_sharpen_cfg_t *confi isp_ll_sharp_set_low_thresh(hal->hw, 0); isp_ll_sharp_set_high_thresh(hal->hw, 0); isp_sharpen_m_freq_coeff m_freq = {}; - isp_sharpen_h_freq_coeff h_freq = {}; + isp_sharpen_h_freq_coeff_t h_freq = {}; isp_ll_sharp_set_medium_freq_coeff(hal->hw, m_freq); isp_ll_sharp_set_high_freq_coeff(hal->hw, h_freq); isp_ll_sharp_set_padding_mode(hal->hw, 0); diff --git a/components/soc/esp32p4/include/soc/Kconfig.soc_caps.in b/components/soc/esp32p4/include/soc/Kconfig.soc_caps.in index 2f4baf4dc89a..a5ec84e91b72 100644 --- a/components/soc/esp32p4/include/soc/Kconfig.soc_caps.in +++ b/components/soc/esp32p4/include/soc/Kconfig.soc_caps.in @@ -839,6 +839,10 @@ config SOC_ISP_CCM_SUPPORTED bool default y +config SOC_ISP_DEMOSAIC_SUPPORTED + bool + default y + config SOC_ISP_DVP_SUPPORTED bool default y @@ -891,6 +895,18 @@ config SOC_ISP_CCM_DIMENSION int default 3 +config SOC_ISP_DEMOSAIC_GRAD_RATIO_INT_BITS + int + default 2 + +config SOC_ISP_DEMOSAIC_GRAD_RATIO_DEC_BITS + int + default 4 + +config SOC_ISP_DEMOSAIC_GRAD_RATIO_RES_BITS + int + default 26 + config SOC_ISP_DVP_DATA_WIDTH_MAX int default 16 diff --git a/components/soc/esp32p4/include/soc/soc_caps.h b/components/soc/esp32p4/include/soc/soc_caps.h index 5a13faef8a98..8b5f2cb09fce 100644 --- a/components/soc/esp32p4/include/soc/soc_caps.h +++ b/components/soc/esp32p4/include/soc/soc_caps.h @@ -334,6 +334,7 @@ /*-------------------------- ISP CAPS ----------------------------------------*/ #define SOC_ISP_BF_SUPPORTED 1 #define SOC_ISP_CCM_SUPPORTED 1 +#define SOC_ISP_DEMOSAIC_SUPPORTED 1 #define SOC_ISP_DVP_SUPPORTED 1 #define SOC_ISP_SHARPEN_SUPPORTED 1 #define SOC_ISP_SHARE_CSI_BRG 1 @@ -348,6 +349,9 @@ #define SOC_ISP_BF_TEMPLATE_X_NUMS 3 #define SOC_ISP_BF_TEMPLATE_Y_NUMS 3 #define SOC_ISP_CCM_DIMENSION 3 +#define SOC_ISP_DEMOSAIC_GRAD_RATIO_INT_BITS 2 +#define SOC_ISP_DEMOSAIC_GRAD_RATIO_DEC_BITS 4 +#define SOC_ISP_DEMOSAIC_GRAD_RATIO_RES_BITS 26 #define SOC_ISP_DVP_DATA_WIDTH_MAX 16 #define SOC_ISP_SHARPEN_TEMPLATE_X_NUMS 3 #define SOC_ISP_SHARPEN_TEMPLATE_Y_NUMS 3 From 4a72739840ff0f1ac5bcf6adbf0bad315fb57671 Mon Sep 17 00:00:00 2001 From: Armando Date: Tue, 27 Aug 2024 16:54:49 +0800 Subject: [PATCH 2/3] feat(isp): added demosaic config to isp example --- .../isp/multi_pipelines/main/isp_dsi_main.c | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/examples/peripherals/isp/multi_pipelines/main/isp_dsi_main.c b/examples/peripherals/isp/multi_pipelines/main/isp_dsi_main.c index 4bb5548c20b1..a1cf5beb2a18 100644 --- a/examples/peripherals/isp/multi_pipelines/main/isp_dsi_main.c +++ b/examples/peripherals/isp/multi_pipelines/main/isp_dsi_main.c @@ -17,8 +17,6 @@ #include "esp_cache.h" #include "driver/i2c_master.h" #include "driver/isp.h" -#include "driver/isp_gamma.h" -#include "driver/isp_sharpen.h" #include "isp_af_scheme_sa.h" #include "esp_cam_ctlr_csi.h" #include "esp_cam_ctlr.h" @@ -307,6 +305,15 @@ void app_main(void) ESP_ERROR_CHECK(esp_isp_bf_configure(isp_proc, &bf_config)); ESP_ERROR_CHECK(esp_isp_bf_enable(isp_proc)); + esp_isp_demosaic_config_t demosaic_config = { + .grad_ratio = { + .integer = 2, + .decimal = 5, + }, + }; + ESP_ERROR_CHECK(esp_isp_demosaic_configure(isp_proc, &demosaic_config)); + ESP_ERROR_CHECK(esp_isp_demosaic_enable(isp_proc)); + isp_gamma_curve_points_t pts = {}; ESP_ERROR_CHECK(esp_isp_gamma_fill_curve_points(s_gamma_correction_curve, &pts)); ESP_ERROR_CHECK(esp_isp_gamma_configure(isp_proc, COLOR_COMPONENT_R, &pts)); From 87d8a5154ed89d1c1026313db5c3e442ec061288 Mon Sep 17 00:00:00 2001 From: Armando Date: Tue, 27 Aug 2024 16:55:07 +0800 Subject: [PATCH 3/3] feat(isp): added demosaic programming guide --- docs/doxygen/Doxyfile_esp32p4 | 1 + docs/en/api-reference/peripherals/isp.rst | 84 ++++++++++++++++------- 2 files changed, 62 insertions(+), 23 deletions(-) diff --git a/docs/doxygen/Doxyfile_esp32p4 b/docs/doxygen/Doxyfile_esp32p4 index 0883585060c2..ddb4f1512069 100644 --- a/docs/doxygen/Doxyfile_esp32p4 +++ b/docs/doxygen/Doxyfile_esp32p4 @@ -33,6 +33,7 @@ INPUT += \ $(PROJECT_PATH)/components/esp_driver_isp/include/driver/isp_awb.h \ $(PROJECT_PATH)/components/esp_driver_isp/include/driver/isp_ccm.h \ $(PROJECT_PATH)/components/esp_driver_isp/include/driver/isp_bf.h \ + $(PROJECT_PATH)/components/esp_driver_isp/include/driver/isp_demosaic.h \ $(PROJECT_PATH)/components/esp_driver_isp/include/driver/isp_sharpen.h \ $(PROJECT_PATH)/components/esp_driver_isp/include/driver/isp_core.h \ $(PROJECT_PATH)/components/esp_driver_isp/include/driver/isp_gamma.h \ diff --git a/docs/en/api-reference/peripherals/isp.rst b/docs/en/api-reference/peripherals/isp.rst index 1e0816484815..4fb718c81a4c 100644 --- a/docs/en/api-reference/peripherals/isp.rst +++ b/docs/en/api-reference/peripherals/isp.rst @@ -65,6 +65,7 @@ The ISP driver offers following services: - `Get histogram statistics in one shot or continuous way <#isp-hist-statistics>`__ - covers how to get histogram statistics one-shot or continuously. - `Enable BF function <#isp_bf>`__ - covers how to enable and configure BF function. - `Configure CCM <#isp-ccm-config>`__ - covers how to configure the Color Correction Matrix. +- `Configure Demosaic <#isp-demosaic>`__ - covers how to config the Demosaic function. - `Enable Gamma Correction <#isp-gamma-correction>`__ - covers how to enable and configure gamma correction. - `Configure Sharpen <#isp-sharpen>`__ - covers how to config the Sharpen function. - `Register callback <#isp-callback>`__ - covers how to hook user specific code to ISP driver event callback function. @@ -196,31 +197,18 @@ If the configurations in :cpp:type:`esp_isp_hist_config_t` is specified, users c You can use the created handle to do driver enable / disable the ISP HIST driver setup. -Uninstall ISP Driver -~~~~~~~~~~~~~~~~~~~~ - -If a previously installed ISP processor is no longer needed, it's recommended to recycle the resource by calling :cpp:func:`esp_isp_del_processor`, so that to release the underlying hardware. - -UnInstall ISP AF Driver +Uninstall ISP Driver(s) ~~~~~~~~~~~~~~~~~~~~~~~ -If a previously installed ISP AF processor is no longer needed, it's recommended to recycle the resource by calling :cpp:func:`esp_isp_del_af_controller`, so that to release the underlying hardware. - -UnInstall ISP AWB Driver -~~~~~~~~~~~~~~~~~~~~~~~~ - -If a previously installed ISP AWB processor is no longer needed, it's recommended to free the resource by calling :cpp:func:`esp_isp_del_awb_controller`, it will also release the underlying hardware. +If a previously installed ISP driver(s) are not needed, it's recommended to recycle the resource by following APIs to release the underlying hardware: -UnInstall ISP AE Driver -~~~~~~~~~~~~~~~~~~~~~~~~ - -If a previously installed ISP AE processor is no longer needed, it's recommended to free the resource by calling :cpp:func:`esp_isp_del_ae_controller`, it will also release the underlying hardware. - -UnInstall ISP HIST Driver -~~~~~~~~~~~~~~~~~~~~~~~~~~ - -If a previously installed ISP HIST processor is no longer needed, it's recommended to free the resource by calling :cpp:func:`esp_isp_del_hist_controller`, it will also release the underlying hardware. +.. list:: + - :cpp:func:`esp_isp_del_processor`, for ISP processor. + - :cpp:func:`esp_isp_del_af_controller`, for ISP AF processor. + - :cpp:func:`esp_isp_del_awb_controller`, for ISP AWB processor. + - :cpp:func:`esp_isp_del_ae_controller`, for ISP AE processor. + - :cpp:func:`esp_isp_del_hist_controller`, for ISP Histogram processor. .. _isp-enable-disable: @@ -555,6 +543,36 @@ To adjust the color correction matrix, here is the formula: // Disable CCM if no longer needed ESP_ERROR_CHECK(esp_isp_ccm_disable(isp_proc)); +.. _isp-demosaic: + +ISP Demosaic Processor +~~~~~~~~~~~~~~~~~~~~~~ + +This pipeline is used for doing image demosaic algorithm to convert RAW image to RGB mode. + +Calling :cpp:func:`esp_isp_demosaic_configure` to configure Demosaic function, you can take following code as reference. + +.. code:: c + + esp_isp_demosaic_config_t demosaic_config = { + .grad_ratio = { + .integer = 2, + .decimal = 5, + }, + ... + }; + + ESP_ERROR_CHECK(esp_isp_demosaic_configure(isp_proc, &sharpen_config)); + ESP_ERROR_CHECK(esp_isp_demosaic_enable(isp_proc)); + +After calling :cpp:func:`esp_isp_demosaic_configure`, you need to enable the ISP Sharpen processor, by calling :cpp:func:`esp_isp_demosaic_enable`. This function: + +* Switches the driver state from **init** to **enable**. + +Calling :cpp:func:`esp_isp_demosaic_disable` does the opposite, that is, put the driver back to the **init** state. + +:cpp:func:`esp_isp_demosaic_configure` is allowed to be called even if the driver is in **init** state, but the demosaic configurations will only be taken into effect when in **enable** state. + .. _isp-gamma-correction: Enable Gamma Correction @@ -595,7 +613,7 @@ ISP Sharpen Processor This pipeline is used for doing image input sharpening under YUV mode. -Calling :cpp:func:`esp_isp_sharpen_configure` to configure BF function, you can take following code as reference. +Calling :cpp:func:`esp_isp_sharpen_configure` to configure Sharpen function, you can take following code as reference. .. code:: c @@ -677,7 +695,22 @@ After the ISP HIST controller finished statistics of brightness, it can generate Thread Safety ^^^^^^^^^^^^^ -The factory function :cpp:func:`esp_isp_new_processor`, :cpp:func:`esp_isp_del_processor`, :cpp:func:`esp_isp_new_af_controller`, :cpp:func:`esp_isp_del_af_controller`, :cpp:func:`esp_isp_new_ae_controller` and :cpp:func:`esp_isp_del_ae_controller` are guaranteed to be thread safe by the driver, which means, user can call them from different RTOS tasks without protection by extra locks. Other APIs are not guaranteed to be thread-safe +The factory function + +.. list:: + + - :cpp:func:`esp_isp_new_processor` + - :cpp:func:`esp_isp_del_processor` + - :cpp:func:`esp_isp_new_af_controller` + - :cpp:func:`esp_isp_del_af_controller` + - :cpp:func:`esp_isp_new_awb_controller` + - :cpp:func:`esp_isp_del_awb_controller` + - :cpp:func:`esp_isp_new_ae_controller` + - :cpp:func:`esp_isp_del_ae_controller` + - :cpp:func:`esp_isp_new_hist_controller` + - :cpp:func:`esp_isp_del_hist_controller` + +are guaranteed to be thread safe by the driver, which means, user can call them from different RTOS tasks without protection by extra locks. Other APIs are not guaranteed to be thread-safe. .. _isp-kconfig-options: @@ -704,7 +737,11 @@ This allows the interrupt to run while the cache is disabled, but comes at the c Kconfig option :ref:`CONFIG_ISP_CTRL_FUNC_IN_IRAM` will: - Place some of ISP control functions into IRAM, function list: + +.. list:: + - :cpp:func:`esp_isp_sharpen_configure` + - :cpp:func:`esp_isp_demosaic_configure` Application Examples -------------------- @@ -721,6 +758,7 @@ API Reference .. include-build-file:: inc/isp_awb.inc .. include-build-file:: inc/isp_bf.inc .. include-build-file:: inc/isp_ccm.inc +.. include-build-file:: inc/isp_demosaic.inc .. include-build-file:: inc/isp_sharpen.inc .. include-build-file:: inc/isp_gamma.inc .. include-build-file:: inc/isp_hist.inc