![]() |
MAX78002 Peripheral Driver API
Peripheral Driver API for the MAX78002
|
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 |
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 |
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 |
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 |
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 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.
req | The details of the image capture. |
result | See Error Codes for the list of error codes. |
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.
[in] | data | Pointer to the received bytes in memory. |
[in] | len | The number of bytes received. |
enum mxc_csi2_ahbwait_t |
enum mxc_csi2_dma_frame_t |
enum mxc_csi2_dma_mode_t |
enum mxc_csi2_err_det_t |
enum mxc_csi2_fbwm_t |
enum mxc_csi2_fiform_t |
enum mxc_csi2_payload0_t |
Enumeration type for the CSI-2 Payload 0 data types.
enum mxc_csi2_payload1_t |
Enumeration type for the CSI-2 Payload 1 Datatypes.
enum mxc_csi2_ppi_clk_t |
enum mxc_csi2_rgb_type_t |
enum mxc_csi2_swap_sel_t |
Enumeration type for the CSI-2 Lane Control Source Selections.
int MXC_CSI2_CaptureFrame | ( | void | ) |
Capture an image frame using DMA. Same as MXC_CSI2_CaptureFrameDMA.
int MXC_CSI2_CaptureFrameDMA | ( | void | ) |
Capture an image frame using DMA.
num_data_lanes | Number of data lanes used. |
void MXC_CSI2_CTRL_ClearFlags | ( | uint32_t | flags | ) |
Clears the interrupt flags.
flags | mask of flags to be cleared. |
int MXC_CSI2_CTRL_Config | ( | mxc_csi2_ctrl_cfg_t * | cfg | ) |
Configure the RX Controller.
cfg | Struct containing RX Controller config parameters. |
void MXC_CSI2_CTRL_DisableInt | ( | uint32_t | mask | ) |
Disable RX Controller Interrupts.
mask | The interrupt to be disable. |
void MXC_CSI2_CTRL_EnableInt | ( | uint32_t | mask | ) |
Enable RX Controller Interrupts.
mask | The interrupt to be enabled. |
int MXC_CSI2_CTRL_GetFlags | ( | void | ) |
Gets the interrupt flags that are currently set.
void MXC_CSI2_DMA_Callback | ( | int | a, |
int | b | ||
) |
The processing function for DMA and the CSI-2.
a | Required input parameter for calling this function but unused. |
b | Required input parameter for calling this function but unused. |
int MXC_CSI2_DMA_Config | ( | uint8_t * | dst_addr, |
uint32_t | byte_cnt, | ||
uint32_t | burst_size | ||
) |
Clears the interrupt flags for PPI.
flags | mask of flags to be cleared. |
int MXC_CSI2_DMA_GetChannel | ( | void | ) |
Gets the acquired DMA channel used for CSI-2 operations.
int MXC_CSI2_DMA_GetCurrentFrameEndCnt | ( | void | ) |
Gets the current DMA Frame End Count when using whole frame DMA requests.
int MXC_CSI2_DMA_GetCurrentLineCnt | ( | void | ) |
Gets the current DMA line count when using line by line DMA requests.
void MXC_CSI2_GetImageDetails | ( | uint32_t * | imgLen, |
uint32_t * | w, | ||
uint32_t * | h | ||
) |
Grab the configured image details.
[out] | imgLen | Pointer to the total length of the image (in bytes). |
[out] | w | Pointer to image width (in pixels). |
[out] | h | Pointer to image height (in pixels). |
int MXC_CSI2_GetLaneCtrlSource | ( | mxc_csi2_lane_src_t * | src | ) |
Get Lane Control Source for D0-D4 and C0.
src | Pointer to hold lane control source signal assignments. |
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.
req | The details of the image for capture. |
ctrl_cfg | Configuration details for RX Controller. |
vfifo_cfg | Configuration details for VFIFO. |
void MXC_CSI2_PPI_ClearFlags | ( | uint32_t | flags | ) |
Clears the interrupt flags for PPI.
flags | mask of flags to be cleared. |
void MXC_CSI2_PPI_DisableInt | ( | uint32_t | mask | ) |
Disable PHY Protocol interface (PPI) Interrupts.
mask | The interrupt to be disable. |
void MXC_CSI2_PPI_EnableInt | ( | uint32_t | mask | ) |
Enable PHY Protocol interface (PPI) Interrupts.
mask | The interrupt to be enabled. |
int MXC_CSI2_PPI_GetFlags | ( | void | ) |
Gets the interrupt flags that are currently set for PPI.
int MXC_CSI2_PPI_Stop | ( | void | ) |
Stops the PPI by disabling interrupts.
int MXC_CSI2_SetLaneCtrlSource | ( | mxc_csi2_lane_src_t * | src | ) |
Select Lane Control Source for D0-D4 and C0.
src | The lane control source signal assignments. |
int MXC_CSI2_Shutdown | ( | void | ) |
Shutdown CSI-2.
int MXC_CSI2_Start | ( | int | num_data_lanes | ) |
Enable the blocks and start the CSI-2.
num_data_lanes | Number of data lanes used. |
int MXC_CSI2_Stop | ( | void | ) |
Disable the blocks and stop the CSI-2.
void MXC_CSI2_VFIFO_ChangeIntMode | ( | uint32_t | mask, |
uint32_t | edge | ||
) |
Change FIFO detection mode for FIFO-specific VFIFO interrupts.
mask | The interrupt to be enabled. |
edge | Edge triggered (true) or level triggered (false) FIFO detection. |
void MXC_CSI2_VFIFO_ClearFlags | ( | uint32_t | flags | ) |
Clears the interrupt flags for VFIFO.
flags | mask of flags to be cleared. |
int MXC_CSI2_VFIFO_Config | ( | mxc_csi2_vfifo_cfg_t * | cfg | ) |
Clears the interrupt flags.
flags | mask of flags to be cleared. |
int MXC_CSI2_VFIFO_Disable | ( | void | ) |
Only disables the VFIFO.
void MXC_CSI2_VFIFO_DisableInt | ( | uint32_t | mask | ) |
Disable VFIFO Interrupts.
mask | The interrupt to be disable. |
int MXC_CSI2_VFIFO_Enable | ( | void | ) |
Only enables the VFIFO.
void MXC_CSI2_VFIFO_EnableInt | ( | uint32_t | mask, |
uint32_t | edge | ||
) |
Enable VFIFO Interrupts.
mask | The interrupt to be enabled. |
edge | Edge triggered or level triggered FIFO detection. |
mxc_csi2_ahbwait_t MXC_CSI2_VFIFO_GetAHBWait | ( | void | ) |
Retrieves whether AHB Wait is enabled or disabled.
mxc_csi2_dma_mode_t MXC_CSI2_VFIFO_GetDMAMode | ( | void | ) |
Get the currently set DMA Mode for VFIFO.
int MXC_CSI2_VFIFO_GetFIFOEntityCount | ( | void | ) |
Get the remaining current FIFO count in VFIFO.
int MXC_CSI2_VFIFO_GetFlags | ( | void | ) |
Gets the interrupt flags that are currently set for VFIFO.
int MXC_CSI2_VFIFO_GetPayloadType | ( | uint32_t * | payload0, |
uint32_t * | payload1 | ||
) |
Get the Payload data type.
payload0 | Pointer to save the value of DISABLE_PAYLOAD_0 register. |
payload1 | Pointer to save the value DISABLE_PAYLOAD_1 register. |
mxc_csi2_raw_format_t MXC_CSI2_VFIFO_GetRAWFormat | ( | void | ) |
Gets the currently set Bayer Filter pattern RAW format type.
mxc_csi2_rgb_type_t MXC_CSI2_VFIFO_GetRGBType | ( | void | ) |
Get the currently set RGB type.
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.
ff_not_empty | Set trigger when FIFO not empty. |
ff_abv_thd | Set trigger when FIFO above threshold. |
ff_full | Set trigger when FIFO Full. |
int MXC_CSI2_VFIFO_ProcessRAWtoRGB | ( | mxc_csi2_req_t * | req | ) |
Set parameters for processing RAW image data to RGB type data.
req | Struct containing parameters for RAW to RGB. |
void MXC_CSI2_VFIFO_SetAHBWait | ( | mxc_csi2_ahbwait_t | wait_en | ) |
Set the AHB Wait (enable/disable)
wait_en | The setting to set AHBWAIT using type mxc_csi2_ahbwait_t. |
int MXC_CSI2_VFIFO_SetDMAMode | ( | mxc_csi2_dma_mode_t | dma_mode | ) |
Sets the DMA Mode for VFIFO.
dma_mode | Select DMA mode (condition to trigger) from mxc_csi2_dma_mode_t. |
int MXC_CSI2_VFIFO_SetPayloadType | ( | mxc_csi2_payload0_t | payload0, |
mxc_csi2_payload1_t | payload1 | ||
) |
Sets the Payload data type.
payload0 | Select payload data type from mxc_csi2_payload0_t. |
payload1 | Select payload data type from mxc_csi2_payload1_t. |
int MXC_CSI2_VFIFO_SetRAWFormat | ( | mxc_csi2_raw_format_t | raw_format | ) |
Sets the RAW format type.
raw_format | Select Bayer Filter Pattern format type from mxc_csi2_raw_format_t. |
int MXC_CSI2_VFIFO_SetRGBType | ( | mxc_csi2_rgb_type_t | rgb_type | ) |
Sets the RGB Type when reading CSI2 FIFO.
rgb_type | Select RGB type from mxc_csi2_rgb_type_t. |