MAX78002 Peripheral Driver API
Peripheral Driver API for the MAX78002
All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Modules Pages
Camera Serial Interface 2 (CSI-2)

Modules

 CSI2_Registers
 

Data Structures

struct  mxc_csi2_lane_src_t
 
struct  mxc_csi2_ctrl_cfg_t
 
struct  mxc_csi2_vfifo_cfg_t
 
struct  mxc_csi2_req_t
 

Typedefs

typedef void(* mxc_csi2_frame_handler_cb_t) (mxc_csi2_req_t *req, int result)
 
typedef int(* mxc_csi2_line_handler_cb_t) (uint8_t *data, unsigned int len)
 

Enumerations

enum  mxc_csi2_ppi_clk_t
 
enum  mxc_csi2_payload0_t
 
enum  mxc_csi2_payload1_t
 
enum  mxc_csi2_swap_sel_t
 
enum  mxc_csi2_dma_mode_t
 
enum  mxc_csi2_fiform_t
 
enum  mxc_csi2_err_det_t
 
enum  mxc_csi2_fbwm_t
 
enum  mxc_csi2_rgb_type_t
 
enum  mxc_csi2_raw_format_t
 
enum  mxc_csi2_raw_autoflush_t
 
enum  mxc_csi2_ahbwait_t
 
enum  mxc_csi2_dma_frame_t
 

Functions

int MXC_CSI2_Init (mxc_csi2_req_t *req, mxc_csi2_ctrl_cfg_t *ctrl_cfg, mxc_csi2_vfifo_cfg_t *vfifo_cfg)
 
int MXC_CSI2_Shutdown (void)
 
int MXC_CSI2_Start (int num_data_lanes)
 
int MXC_CSI2_Stop (void)
 
int MXC_CSI2_CaptureFrame (void)
 
int MXC_CSI2_CaptureFrameDMA (void)
 
int MXC_CSI2_SetLaneCtrlSource (mxc_csi2_lane_src_t *src)
 
int MXC_CSI2_GetLaneCtrlSource (mxc_csi2_lane_src_t *src)
 
void MXC_CSI2_GetImageDetails (uint32_t *imgLen, uint32_t *w, uint32_t *h)
 
int MXC_CSI2_CTRL_Config (mxc_csi2_ctrl_cfg_t *cfg)
 
void MXC_CSI2_CTRL_EnableInt (uint32_t mask)
 
void MXC_CSI2_CTRL_DisableInt (uint32_t mask)
 
int MXC_CSI2_CTRL_GetFlags (void)
 
void MXC_CSI2_CTRL_ClearFlags (uint32_t flags)
 
int MXC_CSI2_VFIFO_Config (mxc_csi2_vfifo_cfg_t *cfg)
 
int MXC_CSI2_VFIFO_NextFIFOTrigMode (uint8_t ff_not_empty, uint8_t ff_abv_thd, uint8_t ff_full)
 
void MXC_CSI2_VFIFO_EnableInt (uint32_t mask, uint32_t edge)
 
void MXC_CSI2_VFIFO_ChangeIntMode (uint32_t mask, uint32_t edge)
 
void MXC_CSI2_VFIFO_DisableInt (uint32_t mask)
 
int MXC_CSI2_VFIFO_GetFlags (void)
 
void MXC_CSI2_VFIFO_ClearFlags (uint32_t flags)
 
int MXC_CSI2_VFIFO_Enable (void)
 
int MXC_CSI2_VFIFO_Disable (void)
 
int MXC_CSI2_VFIFO_ProcessRAWtoRGB (mxc_csi2_req_t *req)
 
int MXC_CSI2_VFIFO_SetPayloadType (mxc_csi2_payload0_t payload0, mxc_csi2_payload1_t payload1)
 
int MXC_CSI2_VFIFO_GetPayloadType (uint32_t *payload0, uint32_t *payload1)
 
int MXC_CSI2_VFIFO_SetDMAMode (mxc_csi2_dma_mode_t dma_mode)
 
mxc_csi2_dma_mode_t MXC_CSI2_VFIFO_GetDMAMode (void)
 
int MXC_CSI2_VFIFO_SetRGBType (mxc_csi2_rgb_type_t rgb_type)
 
mxc_csi2_rgb_type_t MXC_CSI2_VFIFO_GetRGBType (void)
 
int MXC_CSI2_VFIFO_SetRAWFormat (mxc_csi2_raw_format_t raw_format)
 
mxc_csi2_raw_format_t MXC_CSI2_VFIFO_GetRAWFormat (void)
 
int MXC_CSI2_VFIFO_GetFIFOEntityCount (void)
 
void MXC_CSI2_VFIFO_SetAHBWait (mxc_csi2_ahbwait_t wait_en)
 
mxc_csi2_ahbwait_t MXC_CSI2_VFIFO_GetAHBWait (void)
 
void MXC_CSI2_PPI_EnableInt (uint32_t mask)
 
void MXC_CSI2_PPI_DisableInt (uint32_t mask)
 
int MXC_CSI2_PPI_GetFlags (void)
 
void MXC_CSI2_PPI_ClearFlags (uint32_t flags)
 
int MXC_CSI2_PPI_Stop (void)
 
int MXC_CSI2_DMA_Config (uint8_t *dst_addr, uint32_t byte_cnt, uint32_t burst_size)
 
int MXC_CSI2_DMA_GetChannel (void)
 
int MXC_CSI2_DMA_GetCurrentLineCnt (void)
 
int MXC_CSI2_DMA_GetCurrentFrameEndCnt (void)
 
void MXC_CSI2_DMA_Callback (int a, int b)
 

Detailed Description


Data Structure Documentation

◆ mxc_csi2_lane_src_t

struct mxc_csi2_lane_src_t

Selects control source signals for data and clock lanes.

Data Fields

mxc_csi2_swap_sel_t d0_swap_sel
 
mxc_csi2_swap_sel_t d1_swap_sel
 
mxc_csi2_swap_sel_t d2_swap_sel
 
mxc_csi2_swap_sel_t d3_swap_sel
 
mxc_csi2_swap_sel_t c0_swap_sel
 

◆ mxc_csi2_ctrl_cfg_t

struct mxc_csi2_ctrl_cfg_t

Struct containing RX Controller and D-PHY configuration details.

Data Fields

mxc_csi2_ppi_clk_t invert_ppi_clk
 
uint32_t num_lanes
 
uint32_t flush_cnt
 
mxc_csi2_payload0_t payload0
 
mxc_csi2_payload1_t payload1
 
mxc_csi2_lane_src_t lane_src
 

◆ mxc_csi2_vfifo_cfg_t

struct mxc_csi2_vfifo_cfg_t

Struct containing parameters for the VFIFO.

Data Fields

uint32_t virtual_channel
 
uint32_t flow_ctrl
 
uint32_t wait_en
 
uint32_t wait_cyc
 
mxc_csi2_dma_frame_t dma_whole_frame
 
mxc_csi2_dma_mode_t dma_mode
 
mxc_csi2_fiform_t fifo_rd_mode
 
mxc_csi2_err_det_t err_det_en
 
uint32_t rx_thd
 
mxc_csi2_fbwm_t bandwidth_mode
 

◆ _mxc_csi2_req_t

struct _mxc_csi2_req_t

The information required to capture images.

Data Fields

uint32_t pixels_per_line
 
uint32_t lines_per_frame
 
uint32_t bits_per_pixel_odd
 
uint32_t bits_per_pixel_even
 
uint32_t frame_num
 
mxc_csi2_line_handler_cb_t line_handler
 
uint8_t process_raw_to_rgb
 
mxc_csi2_rgb_type_t rgb_type
 
mxc_csi2_raw_format_t raw_format
 
mxc_csi2_raw_autoflush_t autoflush
 
uint32_t raw_buf0_addr
 
uint32_t raw_buf1_addr
 

Typedef Documentation

◆ mxc_csi2_frame_handler_cb_t

typedef void(* mxc_csi2_frame_handler_cb_t) (mxc_csi2_req_t *req, int result)

The callback routine used to indicate to indicate transaction has terminated. This is currently unused until multi-frame exposures are implemented.

Parameters
reqThe details of the image capture.
resultSee Error Codes for the list of error codes.

◆ mxc_csi2_line_handler_cb_t

typedef int(* mxc_csi2_line_handler_cb_t) (uint8_t *data, unsigned int len)

The callback routine used to handle incoming image data from the camera sensor. It is triggered once per row. Application code should implement this and ensure that the callback is fast enough to keep up with the incoming data.

Parameters
[in]dataPointer to the received bytes in memory.
[in]lenThe number of bytes received.
Returns
This function should return 0 on success. If non-zero, the CSI-2 controller will end the frame capture

Enumeration Type Documentation

◆ mxc_csi2_ahbwait_t

Enumeration type for the CSI-2 AHB Wait option.

Enumerator
MXC_CSI2_AHBWAIT_DISABLE 

Disable AHB Wait.

MXC_CSI2_AHBWAIT_ENABLE 

Enable AHB Wait.

◆ mxc_csi2_dma_frame_t

Enumeration type for the CSI-2 DMA Frame option.

Enumerator
MXC_CSI2_DMA_WHOLE_FRAME 

DMA entire frames at a time.

MXC_CSI2_DMA_LINE_BY_LINE 

DMA line by line per frame.

◆ mxc_csi2_dma_mode_t

Enumeration type for CSI-2 VFIFO DMA Mode.

Enumerator
MXC_CSI2_DMA_NO_DMA 

No DMA Mode.

MXC_CSI2_DMA_SEND_REQUEST 

DMA Request Mode.

MXC_CSI2_DMA_FIFO_ABV_THD 

Above FIFO Threshold Mode.

MXC_CSI2_DMA_FIFO_FULL 

FIFO Full Mode.

◆ mxc_csi2_err_det_t

Enumeration type for CSI-2 VIFO Error Detection.

Enumerator
MXC_CSI2_ERR_DETECT_DISABLE 

Disable Error Detection.

MXC_CSI2_ERR_DETECT_ENABLE 

Enable Error Detection.

◆ mxc_csi2_fbwm_t

Enumeration type for the CSI-2 VFIFO Bandwidth.

Enumerator
MXC_CSI2_NORMAL_BW 

Normal Bandwidth Mode.

MXC_CSI2_FULL_BW 

Full Bandwidth Mode.

◆ mxc_csi2_fiform_t

Enumeration type for CSI-2 VFIFO Read Mode.

Enumerator
MXC_CSI2_READ_ONE_BY_ONE 

One by One FIFO Read Mode.

MXC_CSI2_READ_DIRECT_ADDR 

Direct Addressing FIFO Read Mode.

◆ mxc_csi2_payload0_t

Enumeration type for the CSI-2 Payload 0 data types.

Enumerator
MXC_CSI2_PL0_DISABLE_ALL 

Disable payload0 data.

MXC_CSI2_PL0_NULL 

NULL payload data.

MXC_CSI2_PL0_BLANK 

BLANK payload data.

MXC_CSI2_PL0_EMBEDDED 

EMBEDDED payload data.

MXC_CSI2_PL0_YUV420_8BIT 

YUV420 8-bit data.

MXC_CSI2_PL0_YUV420_10BIT 

YUV420 10-bit data.

MXC_CSI2_PL0_LEG_YUV420_8BIT 

Legacy YUV420 8-bit data.

MXC_CSI2_PL0_YUV422_8BIT_CSP 

YUV422 8-bit CSP data.

MXC_CSI2_PL0_YUV422_10BIT_CSP 

YUV422 10-bit CSP data.

MXC_CSI2_PL0_YUV422_8BIT 

YUV422 8-bit data.

MXC_CSI2_PL0_YUV422_10BIT 

YUV422 10-bit data.

MXC_CSI2_PL0_RGB444 

RGB444 data.

MXC_CSI2_PL0_RGB555 

RGB555 data.

MXC_CSI2_PL0_RGB565 

RGB565 data.

MXC_CSI2_PL0_RGB666 

RGB666 data.

MXC_CSI2_PL0_RGB888 

RGB888 data.

MXC_CSI2_PL0_RAW6 

RAW6 data.

MXC_CSI2_PL0_RAW7 

RAW7 data.

MXC_CSI2_PL0_RAW8 

RAW8 data.

MXC_CSI2_PL0_RAW10 

RAW10 data.

MXC_CSI2_PL0_RAW12 

RAW12 data.

MXC_CSI2_PL0_RAW14 

RAW14 data.

MXC_CSI2_PL0_RAW16 

RAW16 data.

MXC_CSI2_PL0_RAW20 

RAW20 data.

◆ mxc_csi2_payload1_t

Enumeration type for the CSI-2 Payload 1 Datatypes.

Enumerator
MXC_CSI2_PL1_DISABLE_ALL 

Disable payload1 data.

MXC_CSI2_PL1_UD_0x30 

User defined type 0x30 data.

MXC_CSI2_PL1_UD_0x31 

User defined type 0x31 data.

MXC_CSI2_PL1_UD_0x32 

User defined type 0x32 data.

MXC_CSI2_PL1_UD_0x33 

User defined type 0x33 data.

MXC_CSI2_PL1_UD_0x34 

User defined type 0x34 data.

MXC_CSI2_PL1_UD_0x35 

User defined type 0x35 data.

MXC_CSI2_PL1_UD_0x36 

User defined type 0x36 data.

MXC_CSI2_PL1_UD_0x37 

User defined type 0x37 data.

◆ mxc_csi2_ppi_clk_t

Enumeration type for the CSI-2 PPI Clock Inversion.

Enumerator
MXC_CSI2_PPI_NO_INVERT 

No inversion of PPI input clock.

MXC_CSI2_PPI_INVERT 

Invert PPI input clock.

◆ mxc_csi2_raw_autoflush_t

Enumeration type for the CSI-2 Autoflush.

Enumerator
MXC_CSI2_AUTOFLUSH_DISABLE 

Disable FIFO Automatic Flush-Out.

MXC_CSI2_AUTOFLUSH_ENABLE 

Enable FIFO Automatic Flush-Out.

◆ mxc_csi2_raw_format_t

Enumeration type for the CSI-2 RAW Format.

Enumerator
MXC_CSI2_FORMAT_RGRG_GBGB 

RGRG_GBGB Format.

MXC_CSI2_FORMAT_GRGR_BGBG 

GRGR_BGBG Format.

MXC_CSI2_FORMAT_GBGB_RGRG 

GBGB_RGRG Format.

◆ mxc_csi2_rgb_type_t

Enumeration type for the CSI-2 RGB Type.

Enumerator
MXC_CSI2_TYPE_RGB444 

RGB444 Type.

MXC_CSI2_TYPE_RGB555 

RGB555 Type.

MXC_CSI2_TYPE_RGB565 

RGB565 Type.

MXC_CSI2_TYPE_RGB666 

RGB666 Type.

MXC_CSI2_TYPE_RGB888 

RGB888 Type.

◆ mxc_csi2_swap_sel_t

Enumeration type for the CSI-2 Lane Control Source Selections.

Enumerator
MXC_CSI2_PAD_CDRX_PN_L0 

Connected to PAD_CDRX_L0P/N.

MXC_CSI2_PAD_CDRX_PN_L1 

Connected to PAD_CDRX_L1P/N.

MXC_CSI2_PAD_CDRX_PN_L2 

Connected to PAD_CDRX_L2P/N.

MXC_CSI2_PAD_CDRX_PN_L3 

Connected to PAD_CDRX_L3P/N.

MXC_CSI2_PAD_CDRX_PN_L4 

Connected to PAD_CDRX_L4P/N.

Function Documentation

◆ MXC_CSI2_CaptureFrame()

int MXC_CSI2_CaptureFrame ( void  )

Capture an image frame using DMA. Same as MXC_CSI2_CaptureFrameDMA.

Note
API changed on 7-8-2024 to remove 'num_data_lanes' as an argument. Set 'num_lanes' in mxc_csi2_ctrl_cfg_t instead, which is passed to MXC_CSI2_Init
Returns
E_NO_ERROR if everything is successful.

◆ MXC_CSI2_CaptureFrameDMA()

int MXC_CSI2_CaptureFrameDMA ( void  )

Capture an image frame using DMA.

Parameters
num_data_lanesNumber of data lanes used.
Returns
E_NO_ERROR if everything is successful.

◆ MXC_CSI2_CTRL_ClearFlags()

void MXC_CSI2_CTRL_ClearFlags ( uint32_t  flags)

Clears the interrupt flags.

Parameters
flagsmask of flags to be cleared.

◆ MXC_CSI2_CTRL_Config()

int MXC_CSI2_CTRL_Config ( mxc_csi2_ctrl_cfg_t cfg)

Configure the RX Controller.

Parameters
cfgStruct containing RX Controller config parameters.
Returns
E_NO_ERROR if everything is successful.

◆ MXC_CSI2_CTRL_DisableInt()

void MXC_CSI2_CTRL_DisableInt ( uint32_t  mask)

Disable RX Controller Interrupts.

Parameters
maskThe interrupt to be disable.

◆ MXC_CSI2_CTRL_EnableInt()

void MXC_CSI2_CTRL_EnableInt ( uint32_t  mask)

Enable RX Controller Interrupts.

Parameters
maskThe interrupt to be enabled.

◆ MXC_CSI2_CTRL_GetFlags()

int MXC_CSI2_CTRL_GetFlags ( void  )

Gets the interrupt flags that are currently set.

Returns
The interrupt flags.

◆ MXC_CSI2_DMA_Callback()

void MXC_CSI2_DMA_Callback ( int  a,
int  b 
)

The processing function for DMA and the CSI-2.

Note
When using the DMA functions, the application must call this function periodically. This can be done within the DMA Interrupt Handler.
Parameters
aRequired input parameter for calling this function but unused.
bRequired input parameter for calling this function but unused.

◆ MXC_CSI2_DMA_Config()

int MXC_CSI2_DMA_Config ( uint8_t *  dst_addr,
uint32_t  byte_cnt,
uint32_t  burst_size 
)

Clears the interrupt flags for PPI.

Parameters
flagsmask of flags to be cleared.
Returns
E_NO_ERROR if everything is successful.

◆ MXC_CSI2_DMA_GetChannel()

int MXC_CSI2_DMA_GetChannel ( void  )

Gets the acquired DMA channel used for CSI-2 operations.

Returns
The channel currently used for CSI-2 operations.

◆ MXC_CSI2_DMA_GetCurrentFrameEndCnt()

int MXC_CSI2_DMA_GetCurrentFrameEndCnt ( void  )

Gets the current DMA Frame End Count when using whole frame DMA requests.

Note
In other words, gets the number of frames the DMA interrupt was triggered.
Returns
The current number of frames processed using DMA.

◆ MXC_CSI2_DMA_GetCurrentLineCnt()

int MXC_CSI2_DMA_GetCurrentLineCnt ( void  )

Gets the current DMA line count when using line by line DMA requests.

Note
In other words, gets the number of lines the DMA interrupt was triggered.
Returns
The current number of lines processed using DMA.

◆ MXC_CSI2_GetImageDetails()

void MXC_CSI2_GetImageDetails ( uint32_t *  imgLen,
uint32_t *  w,
uint32_t *  h 
)

Grab the configured image details.

Parameters
[out]imgLenPointer to the total length of the image (in bytes).
[out]wPointer to image width (in pixels).
[out]hPointer to image height (in pixels).

◆ MXC_CSI2_GetLaneCtrlSource()

int MXC_CSI2_GetLaneCtrlSource ( mxc_csi2_lane_src_t src)

Get Lane Control Source for D0-D4 and C0.

Parameters
srcPointer to hold lane control source signal assignments.
Returns
E_NO_ERROR if everything is successful.

◆ MXC_CSI2_Init()

int MXC_CSI2_Init ( mxc_csi2_req_t *  req,
mxc_csi2_ctrl_cfg_t ctrl_cfg,
mxc_csi2_vfifo_cfg_t vfifo_cfg 
)

Initialize CSI-2.

Parameters
reqThe details of the image for capture.
ctrl_cfgConfiguration details for RX Controller.
vfifo_cfgConfiguration details for VFIFO.
Returns
E_NO_ERROR if everything is successful.

◆ MXC_CSI2_PPI_ClearFlags()

void MXC_CSI2_PPI_ClearFlags ( uint32_t  flags)

Clears the interrupt flags for PPI.

Parameters
flagsmask of flags to be cleared.

◆ MXC_CSI2_PPI_DisableInt()

void MXC_CSI2_PPI_DisableInt ( uint32_t  mask)

Disable PHY Protocol interface (PPI) Interrupts.

Parameters
maskThe interrupt to be disable.

◆ MXC_CSI2_PPI_EnableInt()

void MXC_CSI2_PPI_EnableInt ( uint32_t  mask)

Enable PHY Protocol interface (PPI) Interrupts.

Parameters
maskThe interrupt to be enabled.

◆ MXC_CSI2_PPI_GetFlags()

int MXC_CSI2_PPI_GetFlags ( void  )

Gets the interrupt flags that are currently set for PPI.

Returns
The interrupt flags.

◆ MXC_CSI2_PPI_Stop()

int MXC_CSI2_PPI_Stop ( void  )

Stops the PPI by disabling interrupts.

Returns
E_NO_ERROR if everything is successful.

◆ MXC_CSI2_SetLaneCtrlSource()

int MXC_CSI2_SetLaneCtrlSource ( mxc_csi2_lane_src_t src)

Select Lane Control Source for D0-D4 and C0.

Parameters
srcThe lane control source signal assignments.
Returns
E_NO_ERROR if everything is successful.

◆ MXC_CSI2_Shutdown()

int MXC_CSI2_Shutdown ( void  )

Shutdown CSI-2.

Returns
E_NO_ERROR if everything is successful.

◆ MXC_CSI2_Start()

int MXC_CSI2_Start ( int  num_data_lanes)

Enable the blocks and start the CSI-2.

Parameters
num_data_lanesNumber of data lanes used.
Returns
E_NO_ERROR if everything is successful.

◆ MXC_CSI2_Stop()

int MXC_CSI2_Stop ( void  )

Disable the blocks and stop the CSI-2.

Returns
E_NO_ERROR if everything is successful.

◆ MXC_CSI2_VFIFO_ChangeIntMode()

void MXC_CSI2_VFIFO_ChangeIntMode ( uint32_t  mask,
uint32_t  edge 
)

Change FIFO detection mode for FIFO-specific VFIFO interrupts.

Parameters
maskThe interrupt to be enabled.
edgeEdge triggered (true) or level triggered (false) FIFO detection.

◆ MXC_CSI2_VFIFO_ClearFlags()

void MXC_CSI2_VFIFO_ClearFlags ( uint32_t  flags)

Clears the interrupt flags for VFIFO.

Parameters
flagsmask of flags to be cleared.

◆ MXC_CSI2_VFIFO_Config()

int MXC_CSI2_VFIFO_Config ( mxc_csi2_vfifo_cfg_t cfg)

Clears the interrupt flags.

Parameters
flagsmask of flags to be cleared.
Returns
E_NO_ERROR if everything is successful.

◆ MXC_CSI2_VFIFO_Disable()

int MXC_CSI2_VFIFO_Disable ( void  )

Only disables the VFIFO.

Returns
E_NO_ERROR if everything is successful.

◆ MXC_CSI2_VFIFO_DisableInt()

void MXC_CSI2_VFIFO_DisableInt ( uint32_t  mask)

Disable VFIFO Interrupts.

Parameters
maskThe interrupt to be disable.

◆ MXC_CSI2_VFIFO_Enable()

int MXC_CSI2_VFIFO_Enable ( void  )

Only enables the VFIFO.

Returns
E_NO_ERROR if everything is successful.

◆ MXC_CSI2_VFIFO_EnableInt()

void MXC_CSI2_VFIFO_EnableInt ( uint32_t  mask,
uint32_t  edge 
)

Enable VFIFO Interrupts.

Parameters
maskThe interrupt to be enabled.
edgeEdge triggered or level triggered FIFO detection.

◆ MXC_CSI2_VFIFO_GetAHBWait()

mxc_csi2_ahbwait_t MXC_CSI2_VFIFO_GetAHBWait ( void  )

Retrieves whether AHB Wait is enabled or disabled.

Returns
State of AHB Wait

◆ MXC_CSI2_VFIFO_GetDMAMode()

mxc_csi2_dma_mode_t MXC_CSI2_VFIFO_GetDMAMode ( void  )

Get the currently set DMA Mode for VFIFO.

Returns
The currently set DMA mode.

◆ MXC_CSI2_VFIFO_GetFIFOEntityCount()

int MXC_CSI2_VFIFO_GetFIFOEntityCount ( void  )

Get the remaining current FIFO count in VFIFO.

Note
RGB Type can vary entity width.
Returns
Number of entities currently in the FIFO.

◆ MXC_CSI2_VFIFO_GetFlags()

int MXC_CSI2_VFIFO_GetFlags ( void  )

Gets the interrupt flags that are currently set for VFIFO.

Returns
The interrupt flags.

◆ MXC_CSI2_VFIFO_GetPayloadType()

int MXC_CSI2_VFIFO_GetPayloadType ( uint32_t *  payload0,
uint32_t *  payload1 
)

Get the Payload data type.

Note
Value of registers are negative logic. 0 - enabled, 1 disabled. Compare with mxc_csi2_payloadn_t enum types or check user guide for specific value.
Parameters
payload0Pointer to save the value of DISABLE_PAYLOAD_0 register.
payload1Pointer to save the value DISABLE_PAYLOAD_1 register.
Returns
E_NO_ERROR if everything is successful.

◆ MXC_CSI2_VFIFO_GetRAWFormat()

mxc_csi2_raw_format_t MXC_CSI2_VFIFO_GetRAWFormat ( void  )

Gets the currently set Bayer Filter pattern RAW format type.

Returns
The currently set RAW format.

◆ MXC_CSI2_VFIFO_GetRGBType()

mxc_csi2_rgb_type_t MXC_CSI2_VFIFO_GetRGBType ( void  )

Get the currently set RGB type.

Returns
The currently set RGB Type.

◆ MXC_CSI2_VFIFO_NextFIFOTrigMode()

int MXC_CSI2_VFIFO_NextFIFOTrigMode ( uint8_t  ff_not_empty,
uint8_t  ff_abv_thd,
uint8_t  ff_full 
)

Set Next FIFO Trigger Mode: FIFO Not Empty, Above Threshold, Full.

Parameters
ff_not_emptySet trigger when FIFO not empty.
ff_abv_thdSet trigger when FIFO above threshold.
ff_fullSet trigger when FIFO Full.
Returns
E_NO_ERROR if everything is successful.

◆ MXC_CSI2_VFIFO_ProcessRAWtoRGB()

int MXC_CSI2_VFIFO_ProcessRAWtoRGB ( mxc_csi2_req_t *  req)

Set parameters for processing RAW image data to RGB type data.

Note
Payload data type from Init function should be set to RAW.
Parameters
reqStruct containing parameters for RAW to RGB.
Returns
E_NO_ERROR if everything is successful.

◆ MXC_CSI2_VFIFO_SetAHBWait()

void MXC_CSI2_VFIFO_SetAHBWait ( mxc_csi2_ahbwait_t  wait_en)

Set the AHB Wait (enable/disable)

Parameters
wait_enThe setting to set AHBWAIT using type mxc_csi2_ahbwait_t.

◆ MXC_CSI2_VFIFO_SetDMAMode()

int MXC_CSI2_VFIFO_SetDMAMode ( mxc_csi2_dma_mode_t  dma_mode)

Sets the DMA Mode for VFIFO.

Parameters
dma_modeSelect DMA mode (condition to trigger) from mxc_csi2_dma_mode_t.
Returns
E_NO_ERROR if everything is successful.

◆ MXC_CSI2_VFIFO_SetPayloadType()

int MXC_CSI2_VFIFO_SetPayloadType ( mxc_csi2_payload0_t  payload0,
mxc_csi2_payload1_t  payload1 
)

Sets the Payload data type.

Note
Parameters negative logic. 0 - enabled, 1 disabled. Passing set value disables data type.
Parameters
payload0Select payload data type from mxc_csi2_payload0_t.
payload1Select payload data type from mxc_csi2_payload1_t.
Returns
E_NO_ERROR if everything is successful.

◆ MXC_CSI2_VFIFO_SetRAWFormat()

int MXC_CSI2_VFIFO_SetRAWFormat ( mxc_csi2_raw_format_t  raw_format)

Sets the RAW format type.

Parameters
raw_formatSelect Bayer Filter Pattern format type from mxc_csi2_raw_format_t.
Returns
E_NO_ERROR if everything is successful.

◆ MXC_CSI2_VFIFO_SetRGBType()

int MXC_CSI2_VFIFO_SetRGBType ( mxc_csi2_rgb_type_t  rgb_type)

Sets the RGB Type when reading CSI2 FIFO.

Parameters
rgb_typeSelect RGB type from mxc_csi2_rgb_type_t.
Returns
E_NO_ERROR if everything is successful.