2024-01-29 12:16:09 +08:00
|
|
|
/*
|
|
|
|
* SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include "esp_err.h"
|
|
|
|
#include "esp_cam_ctlr_types.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Enable ESP CAM controller
|
|
|
|
*
|
|
|
|
* @param[in] handle ESP CAM controller handle
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK
|
|
|
|
* - ESP_ERR_INVALID_ARG: Invalid argument
|
|
|
|
* - ESP_ERR_INVALID_STATE: Invalid state
|
|
|
|
*/
|
|
|
|
esp_err_t esp_cam_ctlr_enable(esp_cam_ctlr_handle_t handle);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Start ESP CAM controller
|
|
|
|
*
|
|
|
|
* @param[in] handle ESP CAM controller handle
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK
|
|
|
|
* - ESP_ERR_INVALID_ARG: Invalid argument
|
|
|
|
* - ESP_ERR_INVALID_STATE: Invalid state
|
|
|
|
*/
|
|
|
|
esp_err_t esp_cam_ctlr_start(esp_cam_ctlr_handle_t handle);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Stop ESP CAM controller
|
|
|
|
*
|
|
|
|
* @param[in] handle ESP CAM controller handle
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK
|
|
|
|
* - ESP_ERR_INVALID_ARG: Invalid argument
|
|
|
|
* - ESP_ERR_INVALID_STATE: Invalid state
|
|
|
|
*/
|
|
|
|
esp_err_t esp_cam_ctlr_stop(esp_cam_ctlr_handle_t handle);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Disable ESP CAM controller
|
|
|
|
*
|
|
|
|
* @param[in] handle ESP CAM controller handle
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK
|
|
|
|
* - ESP_ERR_INVALID_ARG: Invalid argument
|
|
|
|
* - ESP_ERR_INVALID_STATE: Invalid state
|
|
|
|
*/
|
|
|
|
esp_err_t esp_cam_ctlr_disable(esp_cam_ctlr_handle_t handle);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Receive data to the given transaction
|
|
|
|
*
|
|
|
|
* @param[in] handle ESP CAM controller handle
|
|
|
|
* @param[in] trans ESP CAM controller transaction type
|
|
|
|
* @param[in] timeout_ms Timeout in ms
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK
|
|
|
|
* - ESP_ERR_INVALID_ARG: Invalid argument
|
|
|
|
* - ESP_ERR_INVALID_STATE: Invalid state
|
|
|
|
*/
|
|
|
|
esp_err_t esp_cam_ctlr_receive(esp_cam_ctlr_handle_t handle, esp_cam_ctlr_trans_t *trans, uint32_t timeout_ms);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Delete ESP CAM controller handle
|
|
|
|
*
|
|
|
|
* @param[in] handle ESP CAM controller handle
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK
|
|
|
|
* - ESP_ERR_INVALID_ARG: Invalid argument
|
|
|
|
* - ESP_ERR_INVALID_STATE: Invalid state
|
|
|
|
*/
|
2024-04-26 16:04:18 +08:00
|
|
|
esp_err_t esp_cam_ctlr_del(esp_cam_ctlr_handle_t handle);
|
2024-01-29 12:16:09 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Register ESP CAM controller event callbacks
|
|
|
|
*
|
2024-03-22 15:34:05 +08:00
|
|
|
* @param[in] handle ESP CAM controller handle
|
|
|
|
* @param[in] cbs ESP CAM controller event callbacks
|
|
|
|
* @param[in] user_data User data
|
2024-01-29 12:16:09 +08:00
|
|
|
* @return
|
|
|
|
* - ESP_OK
|
|
|
|
* - ESP_ERR_INVALID_ARG: Invalid argument
|
|
|
|
* - ESP_ERR_INVALID_STATE: Invalid state
|
|
|
|
*/
|
|
|
|
esp_err_t esp_cam_ctlr_register_event_callbacks(esp_cam_ctlr_handle_t handle, const esp_cam_ctlr_evt_cbs_t *cbs, void *user_data);
|
|
|
|
|
2024-04-12 14:30:21 +08:00
|
|
|
/**
|
|
|
|
* @brief Get ESP CAM controller internal malloced backup buffer(s) addr
|
|
|
|
*
|
|
|
|
* @note Generally, data in internal buffer is ready when `on_trans_finished` event
|
|
|
|
*
|
|
|
|
* @param[in] handle ESP CAM controller handle
|
|
|
|
* @param[in] fb_num Number of frame buffer(s) to get. This value must be the same as the number of the followed fbN parameters
|
|
|
|
* @param[out] fb0 Address of the frame buffer 0 (first frame buffer)
|
|
|
|
* @param[out] ... List of other frame buffers if any
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK
|
|
|
|
* - ESP_ERR_INVALID_ARG: Invalid argument
|
|
|
|
* - ESP_ERR_INVALID_STATE: Invalid driver state
|
|
|
|
*/
|
|
|
|
esp_err_t esp_cam_ctlr_get_frame_buffer(esp_cam_ctlr_handle_t handle, uint32_t fb_num, const void **fb0, ...);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get ESP CAM controller internal backup buffer length
|
|
|
|
*
|
|
|
|
* @param[in] handle ESP CAM controller handle
|
|
|
|
* @param[out] ret_fb_len Optional, The size of each frame buffer, in bytes.
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK
|
|
|
|
* - ESP_ERR_INVALID_ARG: NULL ptr
|
|
|
|
* - ESP_ERR_INVALID_STATE: Invalid driver state
|
|
|
|
*/
|
|
|
|
esp_err_t esp_cam_ctlr_get_frame_buffer_len(esp_cam_ctlr_handle_t handle, size_t *ret_fb_len);
|
|
|
|
|
2024-01-29 12:16:09 +08:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|