9#ifndef _FSL_FLEXIO_MCULCD_H_
10#define _FSL_FLEXIO_MCULCD_H_
12#include "fsl_common.h"
13#include "fsl_flexio.h"
27#define FSL_FLEXIO_MCULCD_DRIVER_VERSION (MAKE_VERSION(2, 0, 7))
30#ifndef FLEXIO_MCULCD_WAIT_COMPLETE_TIME
41#define FLEXIO_MCULCD_WAIT_COMPLETE_TIME 512
44#ifndef FLEXIO_MCULCD_DATA_BUS_WIDTH
48#define FLEXIO_MCULCD_DATA_BUS_WIDTH 16UL
51#if (16UL != FLEXIO_MCULCD_DATA_BUS_WIDTH) && (8UL != FLEXIO_MCULCD_DATA_BUS_WIDTH)
52#error Only support data bus 8-bit or 16-bit
184#if defined(__cplusplus)
304 FLEXIO_EnableShifterStatusDMA(base->flexioBase, (1UL << base->txShifterStartIndex), enable);
315 FLEXIO_EnableShifterStatusDMA(base->flexioBase, (1UL << base->rxShifterEndIndex), enable);
327static inline uint32_t FLEXIO_MCULCD_GetTxDataRegisterAddress(
FLEXIO_MCULCD_Type *base)
329 return (uint32_t) & (base->flexioBase->SHIFTBUF[base->txShifterStartIndex]);
341static inline uint32_t FLEXIO_MCULCD_GetRxDataRegisterAddress(
FLEXIO_MCULCD_Type *base)
343 return (uint32_t) & (base->flexioBase->SHIFTBUF[base->rxShifterStartIndex]);
470 FLEXIO_Enable(base->flexioBase, enable);
515 base->flexioBase->SHIFTBUF[base->txShifterStartIndex] = data;
525 base->setCSPin(
false);
535 base->setCSPin(
true);
680#if defined(__cplusplus)
void FLEXIO_MCULCD_ClearSingleBeatWriteConfig(FLEXIO_MCULCD_Type *base)
Clear the FLEXIO MCULCD multiple beats write mode configuration.
status_t FLEXIO_MCULCD_TransferGetCount(FLEXIO_MCULCD_Type *base, flexio_mculcd_handle_t *handle, size_t *count)
Gets the data transfer status which used IRQ.
_flexio_mculcd_dma_enable
Define FlexIO MCULCD DMA mask.
Definition: fsl_flexio_mculcd.h:95
flexio_mculcd_pin_func_t setCSPin
Definition: fsl_flexio_mculcd.h:118
void FLEXIO_MCULCD_SetMultiBeatsReadConfig(FLEXIO_MCULCD_Type *base)
Configures the FLEXIO MCULCD to multiple beats read mode.
void FLEXIO_MCULCD_TransferHandleIRQ(void *base, void *handle)
FlexIO MCULCD IRQ handler function.
_flexio_mculcd_status_flags
Define FlexIO MCULCD status mask.
Definition: fsl_flexio_mculcd.h:88
uint32_t FLEXIO_MCULCD_ReadData(FLEXIO_MCULCD_Type *base)
Read data from the FLEXIO MCULCD RX shifter buffer.
uint32_t baudRate_Bps
Definition: fsl_flexio_mculcd.h:132
struct _flexio_mculcd_config flexio_mculcd_config_t
Define FlexIO MCULCD configuration structure.
void FLEXIO_MCULCD_ClearSingleBeatReadConfig(FLEXIO_MCULCD_Type *base)
Clear the FLEXIO MCULCD multiple beats read mode configuration.
void FLEXIO_MCULCD_WaitTransmitComplete(void)
Wait for transmit data send out finished.
uint8_t txShifterEndIndex
Definition: fsl_flexio_mculcd.h:114
flexio_mculcd_transfer_mode_t mode
Definition: fsl_flexio_mculcd.h:147
uint8_t ENWRPinIndex
Definition: fsl_flexio_mculcd.h:111
void FLEXIO_MCULCD_Deinit(FLEXIO_MCULCD_Type *base)
Resets the FLEXIO_MCULCD timer and shifter configuration.
void FLEXIO_MCULCD_EnableInterrupts(FLEXIO_MCULCD_Type *base, uint32_t mask)
Enables the FlexIO MCULCD interrupt.
_flexio_mculcd_transfer_mode
Transfer mode.
Definition: fsl_flexio_mculcd.h:137
void(* flexio_mculcd_transfer_callback_t)(FLEXIO_MCULCD_Type *base, flexio_mculcd_handle_t *handle, status_t status, void *userData)
FlexIO MCULCD callback for finished transfer.
Definition: fsl_flexio_mculcd.h:162
void FLEXIO_MCULCD_WriteDataArrayBlocking(FLEXIO_MCULCD_Type *base, const void *data, size_t size)
Send data array in blocking way.
uint32_t FLEXIO_MCULCD_GetStatusFlags(FLEXIO_MCULCD_Type *base)
Gets FlexIO MCULCD status flags.
flexio_mculcd_pin_func_t setRSPin
Definition: fsl_flexio_mculcd.h:119
void FLEXIO_MCULCD_ClearMultiBeatsReadConfig(FLEXIO_MCULCD_Type *base)
Clear the FLEXIO MCULCD multiple beats read mode configuration.
size_t dataSize
Definition: fsl_flexio_mculcd.h:151
flexio_mculcd_pin_func_t setRDWRPin
Definition: fsl_flexio_mculcd.h:120
uint8_t dataPinStartIndex
Definition: fsl_flexio_mculcd.h:108
void FLEXIO_MCULCD_DisableInterrupts(FLEXIO_MCULCD_Type *base, uint32_t mask)
Disables the FlexIO MCULCD interrupt.
volatile size_t remainingCount
Definition: fsl_flexio_mculcd.h:174
status_t FLEXIO_MCULCD_TransferCreateHandle(FLEXIO_MCULCD_Type *base, flexio_mculcd_handle_t *handle, flexio_mculcd_transfer_callback_t callback, void *userData)
Initializes the FlexIO MCULCD handle, which is used in transactional functions.
uint32_t dataAddrOrSameValue
Definition: fsl_flexio_mculcd.h:148
void FLEXIO_MCULCD_WriteCommandBlocking(FLEXIO_MCULCD_Type *base, uint32_t command)
Send command in blocking way.
bool enable
Definition: fsl_flexio_mculcd.h:126
status_t FLEXIO_MCULCD_SetBaudRate(FLEXIO_MCULCD_Type *base, uint32_t baudRate_Bps, uint32_t srcClock_Hz)
Set desired baud rate.
status_t FLEXIO_MCULCD_TransferNonBlocking(FLEXIO_MCULCD_Type *base, flexio_mculcd_handle_t *handle, flexio_mculcd_transfer_t *xfer)
Transfer data using IRQ.
enum _flexio_mculcd_pixel_format flexio_mculcd_pixel_format_t
Define FlexIO MCULCD pixel format.
size_t dataCount
Definition: fsl_flexio_mculcd.h:173
void FLEXIO_MCULCD_SetSingleBeatReadConfig(FLEXIO_MCULCD_Type *base)
Configures the FLEXIO MCULCD to multiple beats read mode.
_flexio_mculcd_pixel_format
Define FlexIO MCULCD pixel format.
Definition: fsl_flexio_mculcd.h:65
void FLEXIO_MCULCD_ClearStatusFlags(FLEXIO_MCULCD_Type *base, uint32_t mask)
Clears FlexIO MCULCD status flags.
flexio_mculcd_bus_t busType
Definition: fsl_flexio_mculcd.h:107
enum _flexio_mculcd_bus flexio_mculcd_bus_t
Define FlexIO MCULCD bus type.
bool enableInDebug
Definition: fsl_flexio_mculcd.h:128
void FLEXIO_MCULCD_ReadDataArrayBlocking(FLEXIO_MCULCD_Type *base, void *data, size_t size)
Read data into array in blocking way.
volatile uint32_t state
Definition: fsl_flexio_mculcd.h:175
void(* flexio_mculcd_pin_func_t)(bool set)
Function to set or clear the CS and RS pin.
Definition: fsl_flexio_mculcd.h:101
void FLEXIO_MCULCD_ClearMultiBeatsWriteConfig(FLEXIO_MCULCD_Type *base)
Clear the FLEXIO MCULCD multiple beats write mode configuration.
enum _flexio_mculcd_transfer_mode flexio_mculcd_transfer_mode_t
Transfer mode.
flexio_mculcd_transfer_callback_t completionCallback
Definition: fsl_flexio_mculcd.h:176
bool enableInDoze
Definition: fsl_flexio_mculcd.h:127
struct _flexio_mculcd_transfer flexio_mculcd_transfer_t
Define FlexIO MCULCD transfer structure.
_flexio_mculcd_interrupt_enable
Define FlexIO MCULCD interrupt mask.
Definition: fsl_flexio_mculcd.h:81
bool enableFastAccess
Definition: fsl_flexio_mculcd.h:129
uint8_t txShifterStartIndex
Definition: fsl_flexio_mculcd.h:113
uint8_t rxShifterEndIndex
Definition: fsl_flexio_mculcd.h:116
void FLEXIO_MCULCD_TransferBlocking(FLEXIO_MCULCD_Type *base, flexio_mculcd_transfer_t *xfer)
Performs a polling transfer.
void * userData
Definition: fsl_flexio_mculcd.h:177
void FLEXIO_MCULCD_SetSingleBeatWriteConfig(FLEXIO_MCULCD_Type *base)
Configures the FLEXIO MCULCD to multiple beats write mode.
struct _flexio_mculcd_type FLEXIO_MCULCD_Type
Define FlexIO MCULCD access structure typedef.
FLEXIO_Type * flexioBase
Definition: fsl_flexio_mculcd.h:106
void FLEXIO_MCULCD_GetDefaultConfig(flexio_mculcd_config_t *config)
Gets the default configuration to configure the FlexIO MCULCD.
_flexio_mculcd_bus
Define FlexIO MCULCD bus type.
Definition: fsl_flexio_mculcd.h:74
uint8_t rxShifterStartIndex
Definition: fsl_flexio_mculcd.h:115
status_t FLEXIO_MCULCD_Init(FLEXIO_MCULCD_Type *base, flexio_mculcd_config_t *config, uint32_t srcClock_Hz)
Ungates the FlexIO clock, resets the FlexIO module, configures the FlexIO MCULCD hardware,...
void FLEXIO_MCULCD_SetMultiBeatsWriteConfig(FLEXIO_MCULCD_Type *base)
Configures the FLEXIO MCULCD to multiple beats write mode.
uint8_t RDPinIndex
Definition: fsl_flexio_mculcd.h:112
uint32_t dataAddrOrSameValue
Definition: fsl_flexio_mculcd.h:170
void FLEXIO_MCULCD_WriteSameValueBlocking(FLEXIO_MCULCD_Type *base, uint32_t sameValue, size_t size)
Send the same value many times in blocking way.
void FLEXIO_MCULCD_TransferAbort(FLEXIO_MCULCD_Type *base, flexio_mculcd_handle_t *handle)
Aborts the data transfer, which used IRQ.
uint8_t timerIndex
Definition: fsl_flexio_mculcd.h:117
uint32_t command
Definition: fsl_flexio_mculcd.h:146
@ kFLEXIO_MCULCD_TxDmaEnable
Definition: fsl_flexio_mculcd.h:96
@ kFLEXIO_MCULCD_RxDmaEnable
Definition: fsl_flexio_mculcd.h:97
@ kFLEXIO_MCULCD_TxEmptyFlag
Definition: fsl_flexio_mculcd.h:89
@ kFLEXIO_MCULCD_RxFullFlag
Definition: fsl_flexio_mculcd.h:90
@ kFLEXIO_MCULCD_WriteArray
Definition: fsl_flexio_mculcd.h:139
@ kFLEXIO_MCULCD_ReadArray
Definition: fsl_flexio_mculcd.h:138
@ kFLEXIO_MCULCD_WriteSameValue
Definition: fsl_flexio_mculcd.h:140
@ kFLEXIO_MCULCD_BGR888
Definition: fsl_flexio_mculcd.h:69
@ kFLEXIO_MCULCD_BGR565
Definition: fsl_flexio_mculcd.h:67
@ kFLEXIO_MCULCD_RGB565
Definition: fsl_flexio_mculcd.h:66
@ kFLEXIO_MCULCD_RGB888
Definition: fsl_flexio_mculcd.h:68
@ kFLEXIO_MCULCD_TxEmptyInterruptEnable
Definition: fsl_flexio_mculcd.h:82
@ kFLEXIO_MCULCD_RxFullInterruptEnable
Definition: fsl_flexio_mculcd.h:83
@ kStatus_FLEXIO_MCULCD_Busy
Definition: fsl_flexio_mculcd.h:59
@ kStatus_FLEXIO_MCULCD_Idle
Definition: fsl_flexio_mculcd.h:58
@ kStatus_FLEXIO_MCULCD_Error
Definition: fsl_flexio_mculcd.h:60
@ kFLEXIO_MCULCD_8080
Definition: fsl_flexio_mculcd.h:75
@ kFLEXIO_MCULCD_6800
Definition: fsl_flexio_mculcd.h:76
int32_t status_t
Type used for all status and error return values.
Definition: fsl_common.h:225
#define MAKE_STATUS(group, code)
Construct a status code value from a group and code number.
Definition: fsl_common.h:47
@ kStatusGroup_FLEXIO_MCULCD
Definition: fsl_common.h:107
Definition: MIMXRT1052.h:20511
Define FlexIO MCULCD configuration structure.
Definition: fsl_flexio_mculcd.h:125
Define FlexIO MCULCD handle structure.
Definition: fsl_flexio_mculcd.h:169
Define FlexIO MCULCD transfer structure.
Definition: fsl_flexio_mculcd.h:145
Define FlexIO MCULCD access structure typedef.
Definition: fsl_flexio_mculcd.h:105
Definition: deflate.c:114
unsigned size
Definition: tte.h:1