RTEMS 6.1-rc6
|
Data Structures | |
struct | _csi_config |
Configuration to initialize the CSI module. More... | |
struct | _csi_handle |
CSI handle structure. More... | |
Variables | |
uint16_t | _csi_config::width |
uint16_t | _csi_config::height |
uint32_t | _csi_config::polarityFlags |
uint8_t | _csi_config::bytesPerPixel |
uint16_t | _csi_config::linePitch_Bytes |
csi_work_mode_t | _csi_config::workMode |
csi_data_bus_t | _csi_config::dataBus |
bool | _csi_config::useExtVsync |
uint32_t | _csi_handle::frameBufferQueue [CSI_DRIVER_ACTUAL_QUEUE_SIZE] |
volatile uint8_t | _csi_handle::queueWriteIdx |
volatile uint8_t | _csi_handle::queueReadIdx |
void *volatile | _csi_handle::emptyBuffer |
volatile uint8_t | _csi_handle::emptyBufferCnt |
volatile uint8_t | _csi_handle::activeBufferNum |
volatile bool | _csi_handle::transferStarted |
csi_transfer_callback_t | _csi_handle::callback |
void * | _csi_handle::userData |
Driver version | |
enum | { kStatus_CSI_NoEmptyBuffer = MAKE_STATUS(kStatusGroup_CSI, 0) , kStatus_CSI_NoFullBuffer = MAKE_STATUS(kStatusGroup_CSI, 1) , kStatus_CSI_QueueFull = MAKE_STATUS(kStatusGroup_CSI, 2) , kStatus_CSI_FrameDone = MAKE_STATUS(kStatusGroup_CSI, 3) } |
Error codes for the CSI driver. More... | |
enum | _csi_work_mode { kCSI_GatedClockMode = CSI_CR1_GCLK_MODE(1U) , kCSI_NonGatedClockMode = 0U , kCSI_CCIR656ProgressiveMode = CSI_CR1_CCIR_EN(1U) } |
CSI work mode. More... | |
enum | _csi_data_bus { kCSI_DataBus8Bit , kCSI_DataBus16Bit , kCSI_DataBus24Bit } |
CSI data bus witdh. More... | |
enum | _csi_polarity_flags { kCSI_HsyncActiveLow = 0U , kCSI_HsyncActiveHigh = CSI_CR1_HSYNC_POL_MASK , kCSI_DataLatchOnRisingEdge = CSI_CR1_REDGE_MASK , kCSI_DataLatchOnFallingEdge = 0U , kCSI_VsyncActiveHigh = 0U , kCSI_VsyncActiveLow = CSI_CR1_SOF_POL_MASK } |
CSI signal polarity. More... | |
enum | _csi_fifo { kCSI_RxFifo = (1U << 0U) , kCSI_StatFifo = (1U << 1U) , kCSI_AllFifo = 0x01 | 0x02 } |
The CSI FIFO, used for FIFO operation. More... | |
enum | _csi_interrupt_enable { kCSI_EndOfFrameInterruptEnable = CSI_CR1_EOF_INT_EN_MASK , kCSI_ChangeOfFieldInterruptEnable = CSI_CR1_COF_INT_EN_MASK , kCSI_StatFifoOverrunInterruptEnable = CSI_CR1_SF_OR_INTEN_MASK , kCSI_RxFifoOverrunInterruptEnable = CSI_CR1_RF_OR_INTEN_MASK , kCSI_StatFifoDmaDoneInterruptEnable = CSI_CR1_SFF_DMA_DONE_INTEN_MASK , kCSI_StatFifoFullInterruptEnable = CSI_CR1_STATFF_INTEN_MASK , kCSI_RxBuffer1DmaDoneInterruptEnable = CSI_CR1_FB2_DMA_DONE_INTEN_MASK , kCSI_RxBuffer0DmaDoneInterruptEnable = CSI_CR1_FB1_DMA_DONE_INTEN_MASK , kCSI_RxFifoFullInterruptEnable = CSI_CR1_RXFF_INTEN_MASK , kCSI_StartOfFrameInterruptEnable = CSI_CR1_SOF_INTEN_MASK , kCSI_EccErrorInterruptEnable = CSI_CR3_ECC_INT_EN_MASK , kCSI_AhbResErrorInterruptEnable = CSI_CR3_HRESP_ERR_EN_MASK , kCSI_BaseAddrChangeErrorInterruptEnable = CSI_CR18_BASEADDR_CHANGE_ERROR_IE_MASK << 6U , kCSI_Field0DoneInterruptEnable = CSI_CR18_FIELD0_DONE_IE_MASK << 6U , kCSI_Field1DoneInterruptEnable = CSI_CR18_DMA_FIELD1_DONE_IE_MASK << 6U } |
CSI feature interrupt source. More... | |
enum | _csi_flags { kCSI_RxFifoDataReadyFlag = CSI_SR_DRDY_MASK , kCSI_EccErrorFlag = CSI_SR_ECC_INT_MASK , kCSI_AhbResErrorFlag = CSI_SR_HRESP_ERR_INT_MASK , kCSI_ChangeOfFieldFlag = CSI_SR_COF_INT_MASK , kCSI_Field0PresentFlag = CSI_SR_F1_INT_MASK , kCSI_Field1PresentFlag = CSI_SR_F2_INT_MASK , kCSI_StartOfFrameFlag = CSI_SR_SOF_INT_MASK , kCSI_EndOfFrameFlag = CSI_SR_EOF_INT_MASK , kCSI_RxFifoFullFlag = CSI_SR_RxFF_INT_MASK , kCSI_RxBuffer1DmaDoneFlag = CSI_SR_DMA_TSF_DONE_FB2_MASK , kCSI_RxBuffer0DmaDoneFlag = CSI_SR_DMA_TSF_DONE_FB1_MASK , kCSI_StatFifoFullFlag = CSI_SR_STATFF_INT_MASK , kCSI_StatFifoDmaDoneFlag = CSI_SR_DMA_TSF_DONE_SFF_MASK , kCSI_StatFifoOverrunFlag = CSI_SR_SF_OR_INT_MASK , kCSI_RxFifoOverrunFlag = CSI_SR_RF_OR_INT_MASK , kCSI_Field0DoneFlag = CSI_SR_DMA_FIELD0_DONE_MASK , kCSI_Field1DoneFlag = CSI_SR_DMA_FIELD1_DONE_MASK , kCSI_BaseAddrChangeErrorFlag = CSI_SR_BASEADDR_CHHANGE_ERROR_MASK } |
CSI status flags. More... | |
typedef enum _csi_work_mode | csi_work_mode_t |
CSI work mode. | |
typedef enum _csi_data_bus | csi_data_bus_t |
CSI data bus witdh. | |
typedef struct _csi_config | csi_config_t |
Configuration to initialize the CSI module. | |
typedef enum _csi_fifo | csi_fifo_t |
The CSI FIFO, used for FIFO operation. | |
typedef struct _csi_handle | csi_handle_t |
typedef void(* | csi_transfer_callback_t) (CSI_Type *base, csi_handle_t *handle, status_t status, void *userData) |
CSI transfer callback function. | |
#define | FSL_CSI_DRIVER_VERSION (MAKE_VERSION(2, 1, 5)) |
#define | CSI_REG_CR1(base) (base)->CR1 |
#define | CSI_REG_CR2(base) (base)->CR2 |
#define | CSI_REG_CR3(base) (base)->CR3 |
#define | CSI_REG_CR18(base) (base)->CR18 |
#define | CSI_REG_SR(base) (base)->SR |
#define | CSI_REG_DMASA_FB1(base) (base)->DMASA_FB1 |
#define | CSI_REG_DMASA_FB2(base) (base)->DMASA_FB2 |
#define | CSI_REG_IMAG_PARA(base) (base)->IMAG_PARA |
#define | CSI_REG_FBUF_PARA(base) (base)->FBUF_PARA |
#define | CSI_DRIVER_QUEUE_SIZE 4U |
Size of the frame buffer queue used in CSI transactional function. | |
#define | CSI_DRIVER_FRAG_MODE 0U |
Enable fragment capture function or not. | |
#define | CSI_DRIVER_ACTUAL_QUEUE_SIZE (CSI_DRIVER_QUEUE_SIZE + 1U) |
#define | CSI_CR1_INT_EN_MASK 0xFFFF0000U |
#define | CSI_CR3_INT_EN_MASK 0x000000FFU |
#define | CSI_CR18_INT_EN_MASK 0x0000FF00U |
Initialization and deinitialization | |
status_t | CSI_Init (CSI_Type *base, const csi_config_t *config) |
Initialize the CSI. | |
void | CSI_Deinit (CSI_Type *base) |
De-initialize the CSI. | |
void | CSI_Reset (CSI_Type *base) |
Reset the CSI. | |
void | CSI_GetDefaultConfig (csi_config_t *config) |
Get the default configuration for to initialize the CSI. | |
Module operation | |
void | CSI_ClearFifo (CSI_Type *base, csi_fifo_t fifo) |
Clear the CSI FIFO. | |
void | CSI_ReflashFifoDma (CSI_Type *base, csi_fifo_t fifo) |
Reflash the CSI FIFO DMA. | |
void | CSI_EnableFifoDmaRequest (CSI_Type *base, csi_fifo_t fifo, bool enable) |
Enable or disable the CSI FIFO DMA request. | |
void | CSI_SetRxBufferAddr (CSI_Type *base, uint8_t index, uint32_t addr) |
Set the RX frame buffer address. | |
Interrupts | |
void | CSI_EnableInterrupts (CSI_Type *base, uint32_t mask) |
Enables CSI interrupt requests. | |
void | CSI_DisableInterrupts (CSI_Type *base, uint32_t mask) |
Disable CSI interrupt requests. | |
Transactional | |
status_t | CSI_TransferCreateHandle (CSI_Type *base, csi_handle_t *handle, csi_transfer_callback_t callback, void *userData) |
Initializes the CSI handle. | |
status_t | CSI_TransferStart (CSI_Type *base, csi_handle_t *handle) |
Start the transfer using transactional functions. | |
status_t | CSI_TransferStop (CSI_Type *base, csi_handle_t *handle) |
Stop the transfer using transactional functions. | |
status_t | CSI_TransferSubmitEmptyBuffer (CSI_Type *base, csi_handle_t *handle, uint32_t frameBuffer) |
Submit empty frame buffer to queue. | |
status_t | CSI_TransferGetFullBuffer (CSI_Type *base, csi_handle_t *handle, uint32_t *frameBuffer) |
Get one full frame buffer from queue. | |
void | CSI_TransferHandleIRQ (CSI_Type *base, csi_handle_t *handle) |
CSI IRQ handle function. | |
typedef void(* csi_transfer_callback_t) (CSI_Type *base, csi_handle_t *handle, status_t status, void *userData) |
CSI transfer callback function.
When a new frame is received and saved to the frame buffer queue, the callback is called and the pass the status kStatus_CSI_FrameDone to upper layer.
typedef enum _csi_work_mode csi_work_mode_t |
CSI work mode.
The CCIR656 interlace mode is not supported currently.
anonymous enum |
Error codes for the CSI driver.
enum _csi_data_bus |
enum _csi_fifo |
enum _csi_flags |
CSI status flags.
The following status register flags can be cleared:
CSI feature interrupt source.
enum _csi_polarity_flags |
CSI signal polarity.
enum _csi_work_mode |
void CSI_ClearFifo | ( | CSI_Type * | base, |
csi_fifo_t | fifo | ||
) |
Clear the CSI FIFO.
This function clears the CSI FIFO.
base | CSI peripheral base address. |
fifo | The FIFO to clear. |
brief Clear the CSI FIFO.
This function clears the CSI FIFO.
param base CSI peripheral base address. param fifo The FIFO to clear.
void CSI_Deinit | ( | CSI_Type * | base | ) |
De-initialize the CSI.
This function disables the CSI peripheral clock.
base | CSI peripheral base address. |
brief De-initialize the CSI.
This function disables the CSI peripheral clock.
param base CSI peripheral base address.
void CSI_DisableInterrupts | ( | CSI_Type * | base, |
uint32_t | mask | ||
) |
Disable CSI interrupt requests.
base | CSI peripheral base address. |
mask | The interrupts to disable, pass in as OR'ed value of _csi_interrupt_enable. |
brief Disable CSI interrupt requests.
param base CSI peripheral base address. param mask The interrupts to disable, pass in as OR'ed value of ref _csi_interrupt_enable.
void CSI_EnableFifoDmaRequest | ( | CSI_Type * | base, |
csi_fifo_t | fifo, | ||
bool | enable | ||
) |
Enable or disable the CSI FIFO DMA request.
base | CSI peripheral base address. |
fifo | The FIFO DMA reques to enable or disable. |
enable | True to enable, false to disable. |
brief Enable or disable the CSI FIFO DMA request.
param base CSI peripheral base address. param fifo The FIFO DMA reques to enable or disable. param enable True to enable, false to disable.
void CSI_EnableInterrupts | ( | CSI_Type * | base, |
uint32_t | mask | ||
) |
Enables CSI interrupt requests.
base | CSI peripheral base address. |
mask | The interrupts to enable, pass in as OR'ed value of _csi_interrupt_enable. |
brief Enables CSI interrupt requests.
param base CSI peripheral base address. param mask The interrupts to enable, pass in as OR'ed value of ref _csi_interrupt_enable.
void CSI_GetDefaultConfig | ( | csi_config_t * | config | ) |
Get the default configuration for to initialize the CSI.
The default configuration value is:
config | Pointer to the CSI configuration. |
brief Get the default configuration for to initialize the CSI.
The default configuration value is:
code config->width = 320U; config->height = 240U; config->polarityFlags = kCSI_HsyncActiveHigh | kCSI_DataLatchOnRisingEdge; config->bytesPerPixel = 2U; config->linePitch_Bytes = 320U * 2U; config->workMode = kCSI_GatedClockMode; config->dataBus = kCSI_DataBus8Bit; config->useExtVsync = true; endcode
param config Pointer to the CSI configuration.
status_t CSI_Init | ( | CSI_Type * | base, |
const csi_config_t * | config | ||
) |
Initialize the CSI.
This function enables the CSI peripheral clock, and resets the CSI registers.
base | CSI peripheral base address. |
config | Pointer to the configuration structure. |
kStatus_Success | Initialize successfully. |
kStatus_InvalidArgument | Initialize failed because of invalid argument. |
brief Initialize the CSI.
This function enables the CSI peripheral clock, and resets the CSI registers.
param base CSI peripheral base address. param config Pointer to the configuration structure.
retval kStatus_Success Initialize successfully. retval kStatus_InvalidArgument Initialize failed because of invalid argument.
void CSI_ReflashFifoDma | ( | CSI_Type * | base, |
csi_fifo_t | fifo | ||
) |
Reflash the CSI FIFO DMA.
This function reflashes the CSI FIFO DMA.
For RXFIFO, there are two frame buffers. When the CSI module started, it saves the frames to frame buffer 0 then frame buffer 1, the two buffers will be written by turns. After reflash DMA using this function, the CSI is reset to save frame to buffer 0.
base | CSI peripheral base address. |
fifo | The FIFO DMA to reflash. |
brief Reflash the CSI FIFO DMA.
This function reflashes the CSI FIFO DMA.
For RXFIFO, there are two frame buffers. When the CSI module started, it saves the frames to frame buffer 0 then frame buffer 1, the two buffers will be written by turns. After reflash DMA using this function, the CSI is reset to save frame to buffer 0.
param base CSI peripheral base address. param fifo The FIFO DMA to reflash.
void CSI_Reset | ( | CSI_Type * | base | ) |
Reset the CSI.
This function resets the CSI peripheral registers to default status.
base | CSI peripheral base address. |
brief Reset the CSI.
This function resets the CSI peripheral registers to default status.
param base CSI peripheral base address.
void CSI_SetRxBufferAddr | ( | CSI_Type * | base, |
uint8_t | index, | ||
uint32_t | addr | ||
) |
Set the RX frame buffer address.
base | CSI peripheral base address. |
index | Buffer index. |
addr | Frame buffer address to set. |
brief Set the RX frame buffer address.
param base CSI peripheral base address. param index Buffer index. param addr Frame buffer address to set.
status_t CSI_TransferCreateHandle | ( | CSI_Type * | base, |
csi_handle_t * | handle, | ||
csi_transfer_callback_t | callback, | ||
void * | userData | ||
) |
Initializes the CSI handle.
This function initializes CSI handle, it should be called before any other CSI transactional functions.
base | CSI peripheral base address. |
handle | Pointer to the handle structure. |
callback | Callback function for CSI transfer. |
userData | Callback function parameter. |
kStatus_Success | Handle created successfully. |
brief Initializes the CSI handle.
This function initializes CSI handle, it should be called before any other CSI transactional functions.
param base CSI peripheral base address. param handle Pointer to the handle structure. param callback Callback function for CSI transfer. param userData Callback function parameter.
retval kStatus_Success Handle created successfully.
status_t CSI_TransferGetFullBuffer | ( | CSI_Type * | base, |
csi_handle_t * | handle, | ||
uint32_t * | frameBuffer | ||
) |
Get one full frame buffer from queue.
After the transfer started using function CSI_TransferStart, the incoming frames will be saved to the empty frame buffers in queue. This function gets the full-filled frame buffer from the queue. If there is no full frame buffer in queue, this function returns error.
base | CSI peripheral base address. |
handle | Pointer to the handle structure. |
frameBuffer | Full frame buffer. |
kStatus_Success | Started successfully. |
kStatus_CSI_NoFullBuffer | There is no full frame buffer in queue. |
brief Get one full frame buffer from queue.
After the transfer started using function ref CSI_TransferStart, the incoming frames will be saved to the empty frame buffers in queue. This function gets the full-filled frame buffer from the queue. If there is no full frame buffer in queue, this function returns error.
param base CSI peripheral base address. param handle Pointer to the handle structure. param frameBuffer Full frame buffer.
retval kStatus_Success Started successfully. retval kStatus_CSI_NoFullBuffer There is no full frame buffer in queue.
void CSI_TransferHandleIRQ | ( | CSI_Type * | base, |
csi_handle_t * | handle | ||
) |
CSI IRQ handle function.
This function handles the CSI IRQ request to work with CSI driver transactional APIs.
base | CSI peripheral base address. |
handle | CSI handle pointer. |
brief CSI IRQ handle function.
This function handles the CSI IRQ request to work with CSI driver transactional APIs.
param base CSI peripheral base address. param handle CSI handle pointer.
status_t CSI_TransferStart | ( | CSI_Type * | base, |
csi_handle_t * | handle | ||
) |
Start the transfer using transactional functions.
When the empty frame buffers have been submit to CSI driver using function CSI_TransferSubmitEmptyBuffer, user could call this function to start the transfer. The incoming frame will be saved to the empty frame buffer, and user could be optionally notified through callback function.
base | CSI peripheral base address. |
handle | Pointer to the handle structure. |
kStatus_Success | Started successfully. |
kStatus_CSI_NoEmptyBuffer | Could not start because no empty frame buffer in queue. |
brief Start the transfer using transactional functions.
When the empty frame buffers have been submit to CSI driver using function ref CSI_TransferSubmitEmptyBuffer, user could call this function to start the transfer. The incoming frame will be saved to the empty frame buffer, and user could be optionally notified through callback function.
param base CSI peripheral base address. param handle Pointer to the handle structure.
retval kStatus_Success Started successfully. retval kStatus_CSI_NoEmptyBuffer Could not start because no empty frame buffer in queue.
status_t CSI_TransferStop | ( | CSI_Type * | base, |
csi_handle_t * | handle | ||
) |
Stop the transfer using transactional functions.
The driver does not clean the full frame buffers in queue. In other words, after calling this function, user still could get the full frame buffers in queue using function CSI_TransferGetFullBuffer.
base | CSI peripheral base address. |
handle | Pointer to the handle structure. |
kStatus_Success | Stoped successfully. |
brief Stop the transfer using transactional functions.
The driver does not clean the full frame buffers in queue. In other words, after calling this function, user still could get the full frame buffers in queue using function ref CSI_TransferGetFullBuffer.
param base CSI peripheral base address. param handle Pointer to the handle structure.
retval kStatus_Success Stoped successfully.
status_t CSI_TransferSubmitEmptyBuffer | ( | CSI_Type * | base, |
csi_handle_t * | handle, | ||
uint32_t | frameBuffer | ||
) |
Submit empty frame buffer to queue.
This function could be called before CSI_TransferStart or after CSI_TransferStart. If there is no room in queue to store the empty frame buffer, this function returns error.
base | CSI peripheral base address. |
handle | Pointer to the handle structure. |
frameBuffer | Empty frame buffer to submit. |
kStatus_Success | Started successfully. |
kStatus_CSI_QueueFull | Could not submit because there is no room in queue. |
brief Submit empty frame buffer to queue.
This function could be called before ref CSI_TransferStart or after ref CSI_TransferStart. If there is no room in queue to store the empty frame buffer, this function returns error.
param base CSI peripheral base address. param handle Pointer to the handle structure. param frameBuffer Empty frame buffer to submit.
retval kStatus_Success Started successfully. retval kStatus_CSI_QueueFull Could not submit because there is no room in queue.
volatile uint8_t _csi_handle::activeBufferNum |
How many frame buffers are in progres currently.
uint8_t _csi_config::bytesPerPixel |
Bytes per pixel, valid values are:
csi_transfer_callback_t _csi_handle::callback |
Callback function.
csi_data_bus_t _csi_config::dataBus |
Data bus width.
void* volatile _csi_handle::emptyBuffer |
Pointer to maintain the empty frame buffers.
volatile uint8_t _csi_handle::emptyBufferCnt |
Empty frame buffers count.
uint32_t _csi_handle::frameBufferQueue[CSI_DRIVER_ACTUAL_QUEUE_SIZE] |
Frame buffer queue.
uint16_t _csi_config::height |
Lines of the input frame.
uint16_t _csi_config::linePitch_Bytes |
Frame buffer line pitch, must be 8-byte aligned.
uint32_t _csi_config::polarityFlags |
Timing signal polarity flags, OR'ed value of _csi_polarity_flags.
volatile uint8_t _csi_handle::queueReadIdx |
Pointer to read out the item.
volatile uint8_t _csi_handle::queueWriteIdx |
Pointer to save incoming item.
volatile bool _csi_handle::transferStarted |
User has called CSI_TransferStart to start frame receiving.
bool _csi_config::useExtVsync |
In CCIR656 progressive mode, set true to use external VSYNC signal, set false to use internal VSYNC signal decoded from SOF.
void* _csi_handle::userData |
CSI callback function parameter.
uint16_t _csi_config::width |
Pixels of the input frame.
csi_work_mode_t _csi_config::workMode |
CSI work mode.