12#include "fsl_common.h"
15#if defined(PXP_AS_CTRL_ALPHA_INVERT_MASK) && (!defined(PXP_AS_CTRL_ALPHA0_INVERT_MASK))
16#define PXP_AS_CTRL_ALPHA0_INVERT_MASK PXP_AS_CTRL_ALPHA_INVERT_MASK
19#if defined(PXP_AS_CTRL_ALPHA_INVERT_MASK) && (!defined(PXP_AS_CTRL_ALPHA_INVERT_MASK))
20#define PXP_AS_CTRL_ALPHA0_INVERT_MASK PXP_AS_CTRL_ALPHA_INVERT_MASK
23#if defined(PXP_STAT_IRQ_MASK) && (!defined(PXP_STAT_IRQ0_MASK))
24#define PXP_STAT_IRQ0_MASK PXP_STAT_IRQ_MASK
27#if defined(PXP_STAT_AXI_READ_ERROR_MASK) && (!defined(PXP_STAT_AXI_READ_ERROR_0_MASK))
28#define PXP_STAT_AXI_READ_ERROR_0_MASK PXP_STAT_AXI_READ_ERROR_MASK
31#if defined(PXP_STAT_AXI_WRITE_ERROR_MASK) && (!defined(PXP_STAT_AXI_WRITE_ERROR_0_MASK))
32#define PXP_STAT_AXI_WRITE_ERROR_0_MASK PXP_STAT_AXI_WRITE_ERROR_MASK
45#define PXP_LUT_TABLE_BYTE (16UL * 1024UL)
47#define PXP_INTERNAL_RAM_LUT_BYTE (256)
51#define FSL_PXP_DRIVER_VERSION (MAKE_VERSION(2, 4, 1))
55#if defined(PXP_CTRL_ROT_POS_MASK)
56#define PXP_SHARE_ROTATE 1
58#define PXP_SHARE_ROTATE 0
62#if defined(PXP_DATA_PATH_CTRL0_MUX0_SEL_MASK)
69#define PXP_PATH(mux, sel) (((mux) << 8U) | (sel))
70#define PXP_GET_MUX_FROM_PATH(path) ((path) >> 8U)
71#define PXP_GET_SEL_FROM_PATH(path) ((path)&0x03U)
80#if !(defined(FSL_FEATURE_PXP_HAS_NO_LUT) && FSL_FEATURE_PXP_HAS_NO_LUT)
82 PXP_CTRL_LUT_DMA_IRQ_ENABLE_MASK,
84#if defined(FSL_FEATURE_PXP_V3) && FSL_FEATURE_PXP_V3
85 kPXP_CompressDoneInterruptEnable =
86 PXP_IRQ_MASK_COMPRESS_DONE_IRQ_EN_MASK >> 16U,
87 kPXP_InputFetchCh0InterruptEnable = PXP_IRQ_MASK_FIRST_CH0_PREFETCH_IRQ_EN_MASK
89 kPXP_InputFetchCh1InterruptEnable = PXP_IRQ_MASK_FIRST_CH1_PREFETCH_IRQ_EN_MASK
91 kPXP_InputStoreCh0InterruptEnable = PXP_IRQ_MASK_FIRST_CH0_STORE_IRQ_EN_MASK
93 kPXP_InputStoreCh1InterruptEnable = PXP_IRQ_MASK_FIRST_CH1_STORE_IRQ_EN_MASK
95 kPXP_DitherFetchCh0InterruptEnable = PXP_IRQ_MASK_DITHER_CH0_PREFETCH_IRQ_EN_MASK
97 kPXP_DitherFetchCh1InterruptEnable = PXP_IRQ_MASK_DITHER_CH1_PREFETCH_IRQ_EN_MASK
99 kPXP_DitherStoreCh0InterruptEnable = PXP_IRQ_MASK_DITHER_CH0_STORE_IRQ_EN_MASK
101 kPXP_DitherStoreCh1InterruptEnable = PXP_IRQ_MASK_DITHER_CH1_STORE_IRQ_EN_MASK
103 kPXP_WfeaStoreCh0InterruptEnable = PXP_IRQ_MASK_WFE_A_CH0_STORE_IRQ_EN_MASK
105 kPXP_WfeaStoreCh1InterruptEnable = PXP_IRQ_MASK_WFE_A_CH1_STORE_IRQ_EN_MASK
107 kPXP_WfebStoreCh0InterruptEnable = PXP_IRQ_MASK_WFE_B_CH0_STORE_IRQ_EN_MASK
109 kPXP_WfebStoreCh1InterruptEnable = PXP_IRQ_MASK_WFE_B_CH1_STORE_IRQ_EN_MASK
111 kPXP_InputStoreInterruptEnable = PXP_IRQ_MASK_FIRST_STORE_IRQ_EN_MASK << 16U,
112 kPXP_DitherStoreInterruptEnable = PXP_IRQ_MASK_DITHER_STORE_IRQ_EN_MASK
114 kPXP_WfeaStoreInterruptEnable = PXP_IRQ_MASK_WFE_A_STORE_IRQ_EN_MASK << 16U,
115 kPXP_WfebStoreInterruptEnable = PXP_IRQ_MASK_WFE_B_STORE_IRQ_EN_MASK << 16U,
133#if !(defined(FSL_FEATURE_PXP_HAS_NO_LUT) && FSL_FEATURE_PXP_HAS_NO_LUT)
136#if defined(PXP_STAT_AXI_READ_ERROR_1_MASK)
137 kPXP_Axi1WriteErrorFlag = PXP_STAT_AXI_WRITE_ERROR_1_MASK,
139 kPXP_Axi1ReadErrorFlag = PXP_STAT_AXI_READ_ERROR_1_MASK,
142#if defined(FSL_FEATURE_PXP_V3) && FSL_FEATURE_PXP_V3
143 kPXP_CompressDoneFlag = PXP_IRQ_COMPRESS_DONE_IRQ_MASK >> 16U,
144 kPXP_InputFetchCh0CompleteFlag = PXP_IRQ_FIRST_CH0_PREFETCH_IRQ_MASK
146 kPXP_InputFetchCh1CompleteFlag = PXP_IRQ_FIRST_CH1_PREFETCH_IRQ_MASK
148 kPXP_InputStoreCh0CompleteFlag = PXP_IRQ_FIRST_CH0_STORE_IRQ_MASK
150 kPXP_InputStoreCh1CompleteFlag = PXP_IRQ_FIRST_CH1_STORE_IRQ_MASK
152 kPXP_DitherFetchCh0CompleteFlag = PXP_IRQ_DITHER_CH0_PREFETCH_IRQ_MASK
154 kPXP_DitherFetchCh1CompleteFlag = PXP_IRQ_DITHER_CH1_PREFETCH_IRQ_MASK
156 kPXP_DitherStoreCh0CompleteFlag = PXP_IRQ_DITHER_CH0_STORE_IRQ_MASK
158 kPXP_DitherStoreCh1CompleteFlag = PXP_IRQ_DITHER_CH1_STORE_IRQ_MASK
160 kPXP_WfeaStoreCh0CompleteFlag = PXP_IRQ_WFE_A_CH0_STORE_IRQ_MASK
162 kPXP_WfeaStoreCh1CompleteFlag = PXP_IRQ_WFE_A_CH1_STORE_IRQ_MASK
164 kPXP_WfebStoreCh0CompleteFlag = PXP_IRQ_WFE_B_CH0_STORE_IRQ_MASK
166 kPXP_WfebStoreCh1CompleteFlag = PXP_IRQ_WFE_B_CH1_STORE_IRQ_MASK
168 kPXP_InputStoreCompleteFlag = PXP_IRQ_FIRST_STORE_IRQ_MASK << 16U,
169 kPXP_DitherStoreCompleteFlag = PXP_IRQ_DITHER_STORE_IRQ_MASK << 16U,
170 kPXP_WfeaStoreCompleteFlag = PXP_IRQ_WFE_A_STORE_IRQ_MASK << 16U,
171 kPXP_WfebStoreCompleteFlag = PXP_IRQ_WFE_B_STORE_IRQ_MASK << 16U,
176#if defined(FSL_FEATURE_PXP_V3) && FSL_FEATURE_PXP_V3
177typedef enum _pxp_path
179 kPXP_Mux0SelectProcessSurfaceEngine = PXP_PATH(0U, 0U),
180 kPXP_Mux0SelectInputFetchEngineChannel0 = PXP_PATH(0U, 1U),
181 kPXP_Mux0SelectInputFetchEngineChannel1 = PXP_PATH(0U, 2U),
182 kPXP_Mux0SelectNone = PXP_PATH(0U, 3U),
183 kPXP_Mux1SelectInputFetchEngineChannel0 = PXP_PATH(1U, 0U),
184 kPXP_Mux1SelectRotation1Engine = PXP_PATH(1U, 1U),
185 kPXP_Mux1SelectNone = PXP_PATH(1U, 2U),
186 kPXP_Mux2SelectInputFetchEngineChannel1 = PXP_PATH(2U, 0U),
187 kPXP_Mux2SelectRotation1Engine = PXP_PATH(2U, 1U),
188 kPXP_Mux2SelectNone = PXP_PATH(2U, 2U),
189 kPXP_Mux3SelectCsc1Engine = PXP_PATH(3U, 0U),
190 kPXP_Mux3SelectRotation1Engine = PXP_PATH(3U, 1U),
191 kPXP_Mux3SelectNone = PXP_PATH(3U, 2U),
192 kPXP_Mux5SelectMux1 = PXP_PATH(5U, 0U),
193 kPXP_Mux5SelectAlphaBlending1 = PXP_PATH(5U, 1U),
194 kPXP_Mux5SelectNone = PXP_PATH(5U, 2U),
195 kPXP_Mux6SelectAlphaBlending1 = PXP_PATH(6U, 0U),
196 kPXP_Mux6SelectAlphaBlending0 = PXP_PATH(6U, 1U),
197 kPXP_Mux6SelectNone = PXP_PATH(6U, 2U),
198 kPXP_Mux7SelectMux5 = PXP_PATH(7U, 0U),
199 kPXP_Mux7SelectCsc2Engine = PXP_PATH(7U, 1U),
200 kPXP_Mux7SelectNone = PXP_PATH(7U, 2U),
201 kPXP_Mux8SelectCsc2Engine = PXP_PATH(8U, 0U),
202 kPXP_Mux8SelectAlphaBlending0 = PXP_PATH(8U, 1U),
203 kPXP_Mux8SelectNone = PXP_PATH(8U, 2U),
204 kPXP_Mux9SelectMux7 = PXP_PATH(9U, 0U),
205 kPXP_Mux9SelectMux8 = PXP_PATH(9U, 1U),
206 kPXP_Mux9SelectNone = PXP_PATH(9U, 2U),
207 kPXP_Mux10SelectMux7 = PXP_PATH(10U, 0U),
208 kPXP_Mux10SelectLut = PXP_PATH(10U, 1U),
209 kPXP_Mux10SelectNone = PXP_PATH(10U, 2U),
210 kPXP_Mux11SelectLut = PXP_PATH(11U, 0U),
211 kPXP_Mux11SelectMux8 = PXP_PATH(11U, 1U),
212 kPXP_Mux11SelectNone = PXP_PATH(11U, 2U),
213 kPXP_Mux12SelectMux10 = PXP_PATH(12U, 0U),
214 kPXP_Mux12SelectMux11 = PXP_PATH(12U, 1U),
215 kPXP_Mux12SelectNone = PXP_PATH(12U, 2U),
216 kPXP_Mux13SelectNone = PXP_PATH(13U, 0U),
217 kPXP_Mux13SelectFetchEngineChannel1 = PXP_PATH(13U, 1U),
218 kPXP_Mux14SelectRotation0Engine = PXP_PATH(14U, 0U),
219 kPXP_Mux14SelectMux11 = PXP_PATH(14U, 1U),
220 kPXP_Mux14SelectNone = PXP_PATH(14U, 2U),
221 kPXP_Mux15SelectFetchEngineChannel0 = PXP_PATH(15U, 0U),
222 kPXP_Mux15SelectMux10 = PXP_PATH(15U, 1U),
223 kPXP_Mux15SelectNone = PXP_PATH(15U, 2U),
224 kPXP_Mux16SelectAluA = PXP_PATH(16U, 0U),
225 kPXP_Mux16SelectOutput = PXP_PATH(16U, 1U),
226 kPXP_Mux16SelectAluB = PXP_PATH(16U, 2U),
227 kPXP_Mux16SelectNone = PXP_PATH(16U, 3U),
228 kPXP_Mux17SelectAluA = PXP_PATH(17U, 0U),
229 kPXP_Mux17SelectAluB = PXP_PATH(17U, 1U),
230 kPXP_Mux17SelectNone = PXP_PATH(17U, 2U),
233typedef enum _pxp_path
235 kPXP_Mux0SelectFetchDataArray = PXP_PATH(0U, 0U),
236 kPXP_Mux0SelectAlu = PXP_PATH(0U, 1U),
237 kPXP_Mux0SelectNone = PXP_PATH(0U, 2U),
238 kPXP_Mux1SelectLut = PXP_PATH(1U, 0U),
239 kPXP_Mux1SelectMux0 = PXP_PATH(1U, 1U),
240 kPXP_Mux1SelectNone = PXP_PATH(1U, 2U),
241 kPXP_Mux3SelectRotation1Engine = PXP_PATH(3U, 0U),
242 kPXP_Mux3SelectCsc1Engine = PXP_PATH(3U, 1U),
243 kPXP_Mux3SelectNone = PXP_PATH(3U, 2U),
244 kPXP_Mux8SelectCsc2Engine = PXP_PATH(8U, 0U),
245 kPXP_Mux8SelectAlphaBlending0 = PXP_PATH(8U, 1U),
246 kPXP_Mux8SelectNone = PXP_PATH(8U, 2U),
247 kPXP_Mux9SelectMux0 = PXP_PATH(9U, 0U),
248 kPXP_Mux9SelectMux8 = PXP_PATH(9U, 1U),
249 kPXP_Mux9SelectNone = PXP_PATH(9U, 2U),
250 kPXP_Mux11SelectLut = PXP_PATH(11U, 0U),
251 kPXP_Mux11SelectMux8 = PXP_PATH(11U, 1U),
252 kPXP_Mux11SelectNone = PXP_PATH(11U, 2U),
253 kPXP_Mux12SelectRotation0Engine = PXP_PATH(12U, 0U),
254 kPXP_Mux12SelectMux11 = PXP_PATH(12U, 1U),
255 kPXP_Mux12SelectNone = PXP_PATH(12U, 2U),
256 kPXP_Mux14SelectDitherEngine = PXP_PATH(14U, 0U),
257 kPXP_Mux14SelectMux12 = PXP_PATH(14U, 1U),
258 kPXP_Mux14SelectNone = PXP_PATH(14U, 2U),
259 kPXP_Mux16SelectOutputBuffer = PXP_PATH(16U, 0U),
260 kPXP_Mux16SelectStoreEngine = PXP_PATH(16U, 1U),
261 kPXP_Mux16SelectNone = PXP_PATH(16U, 2U),
262 kPXP_Mux17SelectOutputBuffer = PXP_PATH(17U, 0U),
263 kPXP_Mux17SelectStoreEngine = PXP_PATH(17U, 1U),
264 kPXP_Mux17SelectNone = PXP_PATH(17U, 2U),
447#if defined(FSL_FEATURE_PXP_V3) && FSL_FEATURE_PXP_V3
451typedef struct _pxp_as_blend_secondary_config
456} pxp_as_blend_secondary_config_t;
516#if !(defined(FSL_FEATURE_PXP_HAS_NO_LUT) && FSL_FEATURE_PXP_HAS_NO_LUT)
559#if defined(FSL_FEATURE_PXP_V3) && FSL_FEATURE_PXP_V3
560 kPXP_RamDither0Err0 = 1U,
561 kPXP_RamDither0Err1 = 2U,
728#if defined(FSL_FEATURE_PXP_V3) && FSL_FEATURE_PXP_V3
733typedef enum _pxp_process_engine_name
735 kPXP_PsAsOutEngine = PXP_CTRL_ENABLE_PS_AS_OUT_MASK,
736 kPXP_DitherEngine = PXP_CTRL_ENABLE_DITHER_MASK,
737 kPXP_WfeaEngine = PXP_CTRL_ENABLE_WFE_A_MASK,
738 kPXP_WfebEngine = PXP_CTRL_ENABLE_WFE_B_MASK,
739 kPXP_InputFetchStoreEngine = PXP_CTRL_ENABLE_INPUT_FETCH_STORE_MASK,
740 kPXP_Alpha1Engine = PXP_CTRL_ENABLE_ALPHA_B_MASK,
741 kPXP_Csc2Engine = PXP_CTRL_ENABLE_CSC2_MASK,
742 kPXP_LutEngine = PXP_CTRL_ENABLE_LUT_MASK,
743 kPXP_Rotate0Engine = PXP_CTRL_ENABLE_ROTATE0_MASK,
744 kPXP_Rotate1Engine = PXP_CTRL_ENABLE_ROTATE1_MASK,
745} pxp_process_engine_name_t;
754typedef enum _pxp_fetch_engine_name
758} pxp_fetch_engine_name_t;
761typedef enum _pxp_fetch_interface_mode
763 kPXP_FetchModeNormal = 0U,
764 kPXP_FetchModeHandshake = 0x1U,
765 kPXP_FetchModeBypass = 0x2U,
766} pxp_fetch_interface_mode_t;
769typedef enum _pxp_scanline_burst
772 kPXP_Scanline16bytes,
773 kPXP_Scanline32bytes,
774 kPXP_Scanline64bytes,
775} pxp_scanline_burst_t;
778typedef struct _pxp_block_format_config
785 pxp_scanline_burst_t burstLength;
794typedef enum _pxp_activeBits
796 kPXP_Active8Bits = 0x0,
797 kPXP_Active16Bits = 0x1,
798 kPXP_Active32Bits = 0x2,
799 kPXP_Active64Bits = 0x3,
803typedef enum _pxp_fetch_output_word_order
805 kPXP_FetchOutputChannel1channel0 = 0x0,
806 kPXP_FetchOutputChannel0channel1 = 0x1,
807} pxp_fetch_output_word_order_t;
814typedef struct _pxp_fetch_shift_component
818} pxp_fetch_shift_component_t;
827typedef struct _pxp_fetch_shift_config
830 pxp_fetch_shift_component_t component0;
831 pxp_fetch_shift_component_t component1;
832 pxp_fetch_shift_component_t component2;
833 pxp_fetch_shift_component_t component3;
834} pxp_fetch_shift_config_t;
837typedef enum _pxp_fetch_pixel_format
839 kPXP_FetchFormatRGB565 = 0x0,
840 kPXP_FetchFormatRGB555 = 0x1,
841 kPXP_FetchFormatARGB1555 = 0x2,
842 kPXP_FetchFormatRGB444 = 0x3,
843 kPXP_FetchFormatARGB4444 = 0x4,
844 kPXP_FetchFormatYUYVorYVYU = 0x5,
845 kPXP_FetchFormatUYVYorVYUY = 0x6,
846 kPXP_FetchFormatYUV422_2P = 0x7,
847} pxp_fetch_pixel_format_t;
850typedef struct _pxp_fetch_engine_config
854 uint32_t inputBaseAddr0;
855 uint32_t inputBaseAddr1;
857 uint16_t totalHeight;
869 pxp_fetch_interface_mode_t interface;
871 pxp_active_bits_t activeBits;
872 pxp_fetch_pixel_format_t pixelFormat;
881 pxp_fetch_shift_config_t shiftConfig;
882 pxp_fetch_output_word_order_t wordOrder;
883} pxp_fetch_engine_config_t;
893typedef enum _pxp_store_engine_name
897} pxp_store_engine_name_t;
900typedef enum _pxp_store_interface_mode
902 kPXP_StoreModeBypass = 0x20U,
903 kPXP_StoreModeNormal = 0x40U,
904 kPXP_StoreModeHandshake = 0x43U,
905 kPXP_StoreModeDual = 0x60U,
907} pxp_store_interface_mode_t;
910typedef enum _pxp_store_yuv_mode
912 kPXP_StoreYUVDisable = 0U,
913 kPXP_StoreYUVPlane1 =
916 kPXP_StoreYUVPlane2 =
919} pxp_store_yuv_mode_t;
922typedef struct _pxp_store_shift_config
926 uint64_t *pDataShiftMask;
928 uint8_t *pDataShiftWidth;
930 uint8_t *pFlagShiftMask;
932 uint8_t *pFlagShiftWidth;
934} pxp_store_shift_config_t;
937typedef struct _pxp_store_engine_config
941 uint32_t outputBaseAddr0;
943 uint32_t outputBaseAddr1;
946 uint16_t totalHeight;
950 pxp_store_interface_mode_t interface;
955 pxp_active_bits_t activeBits;
956 pxp_store_yuv_mode_t yuvMode;
965 pxp_block_config_t storeFormat;
966 pxp_store_shift_config_t shiftConfig;
967} pxp_store_engine_config_t;
972typedef enum _pxp_cfa_input_format
976} pxp_cfa_input_format_t;
979typedef struct _pxp_cfa_config
982 pxp_cfa_input_format_t pixelInFormat;
985 uint16_t totalHeight;
996typedef enum _pxp_histogram_mask_condition
998 kPXP_HistogramMaskEqual = 0x0U,
999 kPXP_HistogramMaskNotequal = 0x1U,
1000 kPXP_HistogramMaskIn = 0x2U,
1001 kPXP_HistogramMaskOut = 0x3U,
1002} pxp_histogram_mask_condition_t;
1005typedef struct _pxp_histogram_config
1008 uint8_t *pParamValue;
1010 uint8_t lutValueOffset;
1011 uint8_t lutValueWidth;
1019 pxp_histogram_mask_condition_t condition;
1021 uint16_t totalHeight;
1023 uint16_t totalWidth;
1025} pxp_histogram_config_t;
1028typedef struct _pxp_histogram_mask_result
1030 uint32_t pixelCount;
1037} pxp_histogram_mask_result_t;
1040enum _pxp_histgram_flags
1042 kPXP_Histogram2levelMatch = 1 << 0U,
1043 kPXP_Histogram4levelMatch = 1 << 1U,
1044 kPXP_Histogram8levelMatch = 1 << 2U,
1045 kPXP_Histogram16levelMatch = 1 << 3U,
1046 kPXP_Histogram32levelMatch = 1 << 4U,
1050typedef struct _pxp_wfea_engine_config
1055 uint16_t updateWidth;
1056 uint16_t updateHeight;
1057 uint16_t updatePitch;
1062 bool fullUpdateEnable;
1065} pxp_wfea_engine_config_t;
1073#if defined(__cplusplus)
1130static inline void PXP_Start(
PXP_Type *base)
1132 base->CTRL_SET = PXP_CTRL_ENABLE_MASK;
1141static inline void PXP_EnableLcdHandShake(
PXP_Type *base,
bool enable)
1143#if defined(PXP_CTRL_ENABLE_LCD_HANDSHAKE_MASK)
1146 base->CTRL_SET = PXP_CTRL_ENABLE_LCD_HANDSHAKE_MASK;
1150 base->CTRL_CLR = PXP_CTRL_ENABLE_LCD_HANDSHAKE_MASK;
1155 base->CTRL_SET = PXP_CTRL_ENABLE_LCD0_HANDSHAKE_MASK;
1159 base->CTRL_CLR = PXP_CTRL_ENABLE_LCD0_HANDSHAKE_MASK;
1164#if (defined(FSL_FEATURE_PXP_HAS_EN_REPEAT) && FSL_FEATURE_PXP_HAS_EN_REPEAT)
1177static inline void PXP_EnableContinousRun(
PXP_Type *base,
bool enable)
1181 base->CTRL_SET = PXP_CTRL_EN_REPEAT_MASK;
1185 base->CTRL_CLR = PXP_CTRL_EN_REPEAT_MASK;
1212void PXP_SetPath(
PXP_Type *base, pxp_path_t path);
1215#if defined(FSL_FEATURE_PXP_V3) && FSL_FEATURE_PXP_V3
1223static inline void PXP_EnableProcessEngine(
PXP_Type *base, uint32_t mask,
bool enable)
1225 mask &= 0xF3F0000UL;
1229 base->CTRL_SET = mask;
1233 base->CTRL_CLR = mask;
1262static inline uint32_t PXP_GetStatusFlags(
PXP_Type *base)
1264#if defined(PXP_STAT_AXI_READ_ERROR_1_MASK)
1265 uint32_t status = base->STAT & (PXP_STAT_NEXT_IRQ_MASK | PXP_STAT_IRQ0_MASK | PXP_STAT_AXI_READ_ERROR_0_MASK |
1266 PXP_STAT_AXI_WRITE_ERROR_0_MASK | PXP_STAT_AXI_READ_ERROR_1_MASK |
1267 PXP_STAT_AXI_WRITE_ERROR_1_MASK);
1269 uint32_t status = base->STAT & (PXP_STAT_NEXT_IRQ_MASK | PXP_STAT_IRQ0_MASK | PXP_STAT_AXI_READ_ERROR_0_MASK |
1270 PXP_STAT_AXI_WRITE_ERROR_0_MASK);
1272#if defined(FSL_FEATURE_PXP_V3) && FSL_FEATURE_PXP_V3
1273 status |= (base->IRQ >> 16U | base->IRQ << 16U);
1286static inline void PXP_ClearStatusFlags(
PXP_Type *base, uint32_t statusMask)
1288 base->STAT_CLR = statusMask;
1289#if defined(FSL_FEATURE_PXP_V3) && FSL_FEATURE_PXP_V3
1290 statusMask &= 0xFFFF8000UL;
1291 base->IRQ_CLR = (statusMask >> 16U | statusMask << 16U);
1304static inline uint8_t PXP_GetAxiErrorId(
PXP_Type *base, uint8_t axiIndex)
1306#if defined(PXP_STAT_AXI_ERROR_ID_1_MASK)
1309 return (uint8_t)((base->STAT & PXP_STAT_AXI_ERROR_ID_0_MASK) >> PXP_STAT_AXI_ERROR_ID_0_SHIFT);
1313 return (uint8_t)((base->STAT & PXP_STAT_AXI_ERROR_ID_1_MASK) >> PXP_STAT_AXI_ERROR_ID_1_SHIFT);
1316 return (uint8_t)((base->STAT & PXP_STAT_AXI_ERROR_ID_MASK) >> PXP_STAT_AXI_ERROR_ID_SHIFT);
1341static inline void PXP_EnableInterrupts(
PXP_Type *base, uint32_t mask)
1343 base->CTRL_SET = (mask & 0xEUL);
1344#if defined(FSL_FEATURE_PXP_V3) && FSL_FEATURE_PXP_V3
1345 mask &= 0xFFFF8000UL;
1346 base->IRQ_MASK_SET = (mask >> 16U | mask << 16U);
1359static inline void PXP_DisableInterrupts(
PXP_Type *base, uint32_t mask)
1361 base->CTRL_CLR = (mask & 0xEUL);
1362#if defined(FSL_FEATURE_PXP_V3) && FSL_FEATURE_PXP_V3
1363 mask &= 0xFFFF8000UL;
1364 base->IRQ_MASK_CLR = (mask >> 16U | mask << 16U);
1391#if defined(FSL_FEATURE_PXP_V3) && FSL_FEATURE_PXP_V3
1398void PXP_SetAlphaSurfaceBlendSecondaryConfig(
PXP_Type *base,
const pxp_as_blend_secondary_config_t *
config);
1424static inline void PXP_EnableAlphaSurfaceOverlayColorKey(
PXP_Type *base, uint32_t num,
bool enable)
1434 base->ALPHA_B_CTRL_1 = (base->ALPHA_B_CTRL_1 & ~PXP_ALPHA_B_CTRL_1_OL_CLRKEY_ENABLE_MASK) |
1435 PXP_ALPHA_B_CTRL_1_OL_CLRKEY_ENABLE((uint32_t)enable);
1467static inline void PXP_EnableAlphaSurfaceOverlayColorKey(
PXP_Type *base,
bool enable)
1471 base->AS_CTRL |= PXP_AS_CTRL_ENABLE_COLORKEY_MASK;
1475 base->AS_CTRL &= ~PXP_AS_CTRL_ENABLE_COLORKEY_MASK;
1490 PXP_Type *base, uint16_t upperLeftX, uint16_t upperLeftY, uint16_t lowerRightX, uint16_t lowerRightY);
1497#if defined(FSL_FEATURE_PXP_V3) && FSL_FEATURE_PXP_V3
1505static inline void PXP_SetProcessSurfaceBackGroundColor(
PXP_Type *base, uint8_t num, uint32_t backGroundColor)
1510 base->PS_BACKGROUND_0 = backGroundColor;
1514 base->PS_BACKGROUND_1 = backGroundColor;
1530static inline void PXP_SetProcessSurfaceBackGroundColor(
PXP_Type *base, uint32_t backGroundColor)
1532#if defined(PXP_PS_BACKGROUND_0_COLOR_MASK)
1533 base->PS_BACKGROUND_0 = backGroundColor;
1535 base->PS_BACKGROUND = backGroundColor;
1560 PXP_Type *base, uint16_t inputWidth, uint16_t inputHeight, uint16_t outputWidth, uint16_t outputHeight);
1572 PXP_Type *base, uint16_t upperLeftX, uint16_t upperLeftY, uint16_t lowerRightX, uint16_t lowerRightY);
1574#if defined(FSL_FEATURE_PXP_V3) && FSL_FEATURE_PXP_V3
1616 base->CSC1_COEF0 &= ~PXP_CSC1_COEF0_YCBCR_MODE_MASK;
1620 base->CSC1_COEF0 |= PXP_CSC1_COEF0_YCBCR_MODE_MASK;
1647static inline void PXP_SetOverwrittenAlphaValue(
PXP_Type *base, uint8_t alpha)
1649 base->OUT_CTRL = (base->OUT_CTRL & ~PXP_OUT_CTRL_ALPHA_MASK) | PXP_OUT_CTRL_ALPHA(alpha);
1661static inline void PXP_EnableOverWrittenAlpha(
PXP_Type *base,
bool enable)
1665 base->OUT_CTRL_SET = PXP_OUT_CTRL_ALPHA_OUTPUT_MASK;
1669 base->OUT_CTRL_CLR = PXP_OUT_CTRL_ALPHA_OUTPUT_MASK;
1697static inline void PXP_SetRotateConfig(
PXP_Type *base,
1704 (base->CTRL & ~(PXP_CTRL_ROTATE_MASK | PXP_CTRL_ROT_POS_MASK | PXP_CTRL_VFLIP_MASK | PXP_CTRL_HFLIP_MASK)) |
1705 PXP_CTRL_ROTATE(degree) | PXP_CTRL_ROT_POS(position) | ((uint32_t)flipMode << PXP_CTRL_HFLIP_SHIFT);
1707 uint32_t ctrl = base->CTRL;
1711 ctrl &= ~(PXP_CTRL_HFLIP0_MASK | PXP_CTRL_VFLIP0_MASK | PXP_CTRL_ROTATE0_MASK);
1712 ctrl |= (PXP_CTRL_ROTATE0(degree) | ((uint32_t)flipMode << PXP_CTRL_HFLIP0_SHIFT));
1716 ctrl &= ~(PXP_CTRL_HFLIP1_MASK | PXP_CTRL_VFLIP1_MASK | PXP_CTRL_ROTATE1_MASK);
1717 ctrl |= (PXP_CTRL_ROTATE1(degree) | ((uint32_t)flipMode << PXP_CTRL_HFLIP1_SHIFT));
1801static inline bool PXP_IsNextCommandPending(
PXP_Type *base)
1803 return (
bool)(base->NEXT & PXP_NEXT_ENABLED_MASK);
1811static inline void PXP_CancelNextCommand(
PXP_Type *base)
1814 uint32_t regAddr = (uint32_t) & (base->NEXT);
1816 *(uint32_t *)regAddr = PXP_NEXT_ENABLED_MASK;
1826#if !(defined(FSL_FEATURE_PXP_HAS_NO_CSC2) && FSL_FEATURE_PXP_HAS_NO_CSC2)
1845static inline void PXP_EnableCsc2(
PXP_Type *base,
bool enable)
1849 base->CSC2_CTRL &= ~PXP_CSC2_CTRL_BYPASS_MASK;
1853 base->CSC2_CTRL |= PXP_CSC2_CTRL_BYPASS_MASK;
1876static inline void PXP_EnableCsc1(
PXP_Type *base,
bool enable)
1880 base->CSC1_COEF0 &= ~PXP_CSC1_COEF0_BYPASS_MASK;
1884 base->CSC1_COEF0 |= PXP_CSC1_COEF0_BYPASS_MASK;
1889#if !(defined(FSL_FEATURE_PXP_HAS_NO_LUT) && FSL_FEATURE_PXP_HAS_NO_LUT)
1941static inline void PXP_EnableLut(
PXP_Type *base,
bool enable)
1945 base->LUT_CTRL &= ~PXP_LUT_CTRL_BYPASS_MASK;
1949 base->LUT_CTRL |= PXP_LUT_CTRL_BYPASS_MASK;
1961 base->LUT_CTRL = (base->LUT_CTRL & ~PXP_LUT_CTRL_SEL_8KB_MASK) | PXP_LUT_CTRL_SEL_8KB(bank);
1966#if (defined(FSL_FEATURE_PXP_HAS_DITHER) && FSL_FEATURE_PXP_HAS_DITHER)
1981void PXP_SetInternalRamData(
PXP_Type *base,
pxp_ram_t ram, uint32_t bytesNum, uint8_t *data, uint16_t memStartAddr);
2016 } pxp_reg_convert_t;
2018 pxp_reg_convert_t pid;
2020 pid._dither_config = *
config;
2021 base->DITHER_CTRL = pid._u32 & 0x00FFFFFFU;
2037void PXP_EnableDither(
PXP_Type *base,
bool enable);
2047#if defined(FSL_FEATURE_PXP_V3) && FSL_FEATURE_PXP_V3
2058#if !(defined(FSL_FEATURE_PXP_HAS_NO_PORTER_DUFF_CTRL) && FSL_FEATURE_PXP_HAS_NO_PORTER_DUFF_CTRL)
2068#if (!(defined(FSL_FEATURE_PXP_HAS_NO_PORTER_DUFF_CTRL) && FSL_FEATURE_PXP_HAS_NO_PORTER_DUFF_CTRL)) || \
2069 (defined(FSL_FEATURE_PXP_V3) && FSL_FEATURE_PXP_V3)
2188#if defined(FSL_FEATURE_PXP_V3) && FSL_FEATURE_PXP_V3
2207 pxp_fetch_engine_name_t name,
2209 const pxp_fetch_engine_config_t *
config);
2219static inline void PXP_EnableFetchEngine(
PXP_Type *base, pxp_fetch_engine_name_t name, uint8_t channel,
bool enable)
2223 if (name == kPXP_FetchInput)
2228 base->INPUT_FETCH_CTRL_CH0_SET = PXP_INPUT_FETCH_CTRL_CH0_CH_EN_MASK;
2232 base->INPUT_FETCH_CTRL_CH1_SET = PXP_INPUT_FETCH_CTRL_CH1_CH_EN_MASK;
2246 base->DITHER_FETCH_CTRL_CH0_SET = PXP_DITHER_FETCH_CTRL_CH0_CH_EN_MASK;
2250 base->DITHER_FETCH_CTRL_CH1_SET = PXP_DITHER_FETCH_CTRL_CH1_CH_EN_MASK;
2262 if (name == kPXP_FetchInput)
2267 base->INPUT_FETCH_CTRL_CH0_CLR = PXP_INPUT_FETCH_CTRL_CH0_CH_EN_MASK;
2271 base->INPUT_FETCH_CTRL_CH1_CLR = PXP_INPUT_FETCH_CTRL_CH1_CH_EN_MASK;
2285 base->DITHER_FETCH_CTRL_CH0_CLR = PXP_DITHER_FETCH_CTRL_CH0_CH_EN_MASK;
2289 base->DITHER_FETCH_CTRL_CH1_CLR = PXP_DITHER_FETCH_CTRL_CH1_CH_EN_MASK;
2321 pxp_store_engine_name_t name,
2323 const pxp_store_engine_config_t *
config);
2333static inline void PXP_EnableStoreEngine(
PXP_Type *base, pxp_store_engine_name_t name, uint8_t channel,
bool enable)
2337 if (name == kPXP_StoreInput)
2342 base->INPUT_STORE_CTRL_CH0_SET = PXP_INPUT_STORE_CTRL_CH0_CH_EN_MASK;
2346 base->INPUT_STORE_CTRL_CH1_SET = PXP_INPUT_STORE_CTRL_CH1_CH_EN_MASK;
2360 base->DITHER_STORE_CTRL_CH0_SET = PXP_DITHER_STORE_CTRL_CH0_CH_EN_MASK;
2364 base->DITHER_STORE_CTRL_CH1_SET = PXP_DITHER_STORE_CTRL_CH1_CH_EN_MASK;
2376 if (name == kPXP_StoreInput)
2381 base->INPUT_STORE_CTRL_CH0_CLR = PXP_INPUT_STORE_CTRL_CH0_CH_EN_MASK;
2385 base->INPUT_STORE_CTRL_CH1_CLR = PXP_INPUT_STORE_CTRL_CH1_CH_EN_MASK;
2399 base->DITHER_STORE_CTRL_CH0_CLR = PXP_DITHER_STORE_CTRL_CH0_CH_EN_MASK;
2403 base->DITHER_STORE_CTRL_CH1_CLR = PXP_DITHER_STORE_CTRL_CH1_CH_EN_MASK;
2425static inline void PXP_CombineStoreEngineChannel(
PXP_Type *base, pxp_store_engine_name_t name,
bool combine)
2427 if (name == kPXP_StoreInput)
2431 base->INPUT_STORE_CTRL_CH0_SET = PXP_INPUT_STORE_CTRL_CH0_SET_COMBINE_2CHANNEL_MASK;
2435 base->INPUT_STORE_CTRL_CH0_CLR = PXP_INPUT_STORE_CTRL_CH0_SET_COMBINE_2CHANNEL_MASK;
2442 base->DITHER_STORE_CTRL_CH0_SET = PXP_DITHER_STORE_CTRL_CH0_SET_COMBINE_2CHANNEL_MASK;
2446 base->DITHER_STORE_CTRL_CH0_CLR = PXP_DITHER_STORE_CTRL_CH0_SET_COMBINE_2CHANNEL_MASK;
2472static inline void PXP_EnableCfa(
PXP_Type *base,
bool enable)
2476 base->CFA_CTRL_CLR = PXP_CFA_CTRL_CFA_BYPASS_MASK;
2480 base->CFA_CTRL_SET = PXP_CFA_CTRL_CFA_BYPASS_MASK;
2507static inline void PXP_EnableHistogram(
PXP_Type *base, uint8_t num,
bool enable)
2513 (base->HIST_A_CTRL & ~PXP_HIST_A_CTRL_ENABLE_MASK) | PXP_HIST_A_CTRL_ENABLE((uint32_t)enable);
2518 (base->HIST_B_CTRL & ~PXP_HIST_B_CTRL_ENABLE_MASK) | PXP_HIST_B_CTRL_ENABLE((uint32_t)enable);
2535void PXP_GetHistogramMaskResult(
PXP_Type *base, uint8_t num, pxp_histogram_mask_result_t *result);
2544static inline uint8_t PXP_GetHistogramMatchResult(
PXP_Type *base, uint8_t num)
2546 uint8_t result = 0U;
2550 result = (uint8_t)((base->HIST_A_CTRL & PXP_HIST_A_CTRL_STATUS_MASK) >> PXP_HIST_A_CTRL_STATUS_SHIFT);
2554 result = (uint8_t)((base->HIST_B_CTRL & PXP_HIST_B_CTRL_STATUS_MASK) >> PXP_HIST_B_CTRL_STATUS_SHIFT);
2575static inline void PXP_ClearHistogramResult(
PXP_Type *base, uint8_t num)
2580 base->HIST_A_CTRL |= PXP_HIST_A_CTRL_CLEAR_MASK;
2584 base->HIST_B_CTRL |= PXP_HIST_B_CTRL_CLEAR_MASK;
2602static inline void PXP_SetHistogramSize(
PXP_Type *base, uint8_t num, uint16_t width, uint16_t height)
2607 base->HIST_A_BUF_SIZE = ((uint32_t)height << 16U) | (uint32_t)width;
2611 base->HIST_B_BUF_SIZE = ((uint32_t)height << 16U) | (uint32_t)width;
2633void PXP_WfeaInit(
PXP_Type *base,
bool ditherHandshake);
2641static inline void PXP_WfeaEnableDitherHandshake(
PXP_Type *base,
bool enable)
2645 base->WFA_FETCH_CTRL |= PXP_WFA_FETCH_CTRL_BF1_HSK_MODE_MASK;
2649 base->WFA_FETCH_CTRL &= ~PXP_WFA_FETCH_CTRL_BF1_HSK_MODE_MASK;
2659void PXP_SetWfeaConfig(
PXP_Type *base,
const pxp_wfea_engine_config_t *
config);
2670static inline void PXP_SetLutUsage(
PXP_Type *base, uint64_t lutStatus)
2672 base->WFE_A_STG1_8X1_OUT0_0 |= (uint32_t)lutStatus;
2673 base->WFE_A_STG1_8X1_OUT0_1 |= (uint32_t)(lutStatus >> 32U);
2685static inline void PXP_ClearLutUsage(
PXP_Type *base, uint64_t lutStatus)
2687 base->WFE_A_STG1_8X1_OUT0_0 &= ~(uint32_t)lutStatus;
2688 base->WFE_A_STG1_8X1_OUT0_1 &= ~(uint32_t)(lutStatus >> 32U);
2697static inline uint64_t PXP_GetLutUsage(
PXP_Type *base)
2699 return ((uint64_t)base->WFE_A_STG1_8X1_OUT0_0 | (uint64_t)base->WFE_A_STG1_8X1_OUT0_1 << 32U);
2706#if defined(__cplusplus)
#define PXP_AS_CTRL_ENABLE_COLORKEY(x)
Definition: MIMXRT1052.h:39098
#define PXP_CTRL_BLOCK_SIZE(x)
Definition: MIMXRT1052.h:37977
#define PXP_CTRL_ROTATE(x)
Definition: MIMXRT1052.h:37949
int32_t status_t
Type used for all status and error return values.
Definition: fsl_common.h:225
void PXP_SetProcessSurfacePosition(PXP_Type *base, uint16_t upperLeftX, uint16_t upperLeftY, uint16_t lowerRightX, uint16_t lowerRightY)
Set the process surface position in output buffer.
Definition: fsl_pxp.c:538
enum _pxp_interlaced_output_mode pxp_interlaced_output_mode_t
PXP interlaced output mode.
void PXP_Reset(PXP_Type *base)
Reset the PXP.
Definition: fsl_pxp.c:337
void PXP_ResetControl(PXP_Type *base)
Reset the PXP and the control register to initialized state.
Definition: fsl_pxp.c:268
uint32_t srcGlobalAlpha
Definition: fsl_pxp.h:691
void PXP_SetProcessSurfaceScaler(PXP_Type *base, uint16_t inputWidth, uint16_t inputHeight, uint16_t outputWidth, uint16_t outputHeight)
Set the process surface scaler configuration.
Definition: fsl_pxp.c:514
uint32_t enableDither0
Definition: fsl_pxp.h:609
void PXP_SetLutConfig(PXP_Type *base, const pxp_lut_config_t *config)
Set the LUT configuration.
Definition: fsl_pxp.c:854
pxp_alpha_mode_t alphaMode
Definition: fsl_pxp.h:443
_pxp_ps_yuv_format
PXP process surface buffer YUV format.
Definition: fsl_pxp.h:360
uint16_t destOffsetY
Definition: fsl_pxp.h:722
void PXP_SetAlphaSurfaceBlendConfig(PXP_Type *base, const pxp_as_blend_config_t *config)
Set the alpha surface blending configuration.
Definition: fsl_pxp.c:365
void PXP_SetProcessSurfaceColorKey(PXP_Type *base, uint32_t colorKeyLow, uint32_t colorKeyHigh)
Set the process surface color key.
Definition: fsl_pxp.c:588
_pxp_csc1_mode
PXP CSC1 mode.
Definition: fsl_pxp.h:468
void PXP_SetNextCommand(PXP_Type *base, void *commandAddr)
Set the next command.
Definition: fsl_pxp.c:736
void PXP_SetCsc1Mode(PXP_Type *base, pxp_csc1_mode_t mode)
Set the CSC1 mode.
Definition: fsl_pxp.c:804
uint16_t destOffsetX
Definition: fsl_pxp.h:721
_pxp_rop_mode
PXP ROP mode during blending.
Definition: fsl_pxp.h:420
uint16_t width
Definition: fsl_pxp.h:334
uint32_t idxMatrixSize0
Definition: fsl_pxp.h:619
_pxp_lut_lookup_mode
PXP LUT lookup mode.
Definition: fsl_pxp.h:519
uint32_t srcPicBaseAddr
Definition: fsl_pxp.h:715
_pxp_csc2_mode
PXP CSC2 mode.
Definition: fsl_pxp.h:475
uint16_t srcPitchBytes
Definition: fsl_pxp.h:716
uint32_t buffer0Addr
Definition: fsl_pxp.h:330
uint16_t width
Definition: fsl_pxp.h:723
pxp_csc2_mode_t mode
Definition: fsl_pxp.h:501
uint32_t bufferAddrU
Definition: fsl_pxp.h:371
float A3
Definition: fsl_pxp.h:504
uint32_t buffer1Addr
Definition: fsl_pxp.h:331
uint32_t ditherMode0
Definition: fsl_pxp.h:612
_pxp_flags
PXP status flags.
Definition: fsl_pxp.h:125
void PXP_Init(PXP_Type *base)
Initialize the PXP.
Definition: fsl_pxp.c:302
int16_t D1
Definition: fsl_pxp.h:511
void PXP_SetOutputBufferConfig(PXP_Type *base, const pxp_output_buffer_config_t *config)
Set the PXP outpt buffer configuration.
Definition: fsl_pxp.c:601
_pxp_dither_matrix_size
PXP dither matrix size.
Definition: fsl_pxp.h:591
pxp_as_pixel_format_t pixelFormat
Definition: fsl_pxp.h:391
uint32_t dstColorMode
Definition: fsl_pxp.h:682
uint32_t idxMatrixSize2
Definition: fsl_pxp.h:623
enum _pxp_rotate_position pxp_rotate_position_t
PXP rotate mode.
enum _pxp_flip_mode pxp_flip_mode_t
PXP output flip mode.
status_t PXP_LoadLutTable(PXP_Type *base, pxp_lut_lookup_mode_t lookupMode, uint32_t bytesNum, uint32_t memAddr, uint16_t lutStartAddr)
Set the look up table to PXP.
Definition: fsl_pxp.c:888
status_t PXP_StartPictureCopy(PXP_Type *base, const pxp_pic_copy_config_t *config)
Copy picture from one buffer to another buffer.
Definition: fsl_pxp.c:1219
float C3
Definition: fsl_pxp.h:510
_pxp_rotate_degree
PXP rotate degree.
Definition: fsl_pxp.h:287
float A2
Definition: fsl_pxp.h:503
_pxp_as_pixel_format
PXP alpha surface buffer pixel format.
Definition: fsl_pxp.h:378
uint32_t dstAlphaMode
Definition: fsl_pxp.h:681
void PXP_SetPorterDuffConfig(PXP_Type *base, const pxp_porter_duff_config_t *config)
Set the Porter Duff configuration.
Definition: fsl_pxp.c:1046
uint16_t pitchBytes
Definition: fsl_pxp.h:333
enum _pxp_csc2_mode pxp_csc2_mode_t
PXP CSC2 mode.
_pxp_alpha_mode
PXP alpha mode during blending.
Definition: fsl_pxp.h:400
int16_t D2
Definition: fsl_pxp.h:512
_pxp_output_pixel_format
PXP output buffer format.
Definition: fsl_pxp.h:305
float B2
Definition: fsl_pxp.h:506
struct _pxp_lut_config pxp_lut_config_t
PXP LUT configuration.
uint32_t bufferAddrV
Definition: fsl_pxp.h:372
int16_t D3
Definition: fsl_pxp.h:513
uint32_t srcFactorMode
Definition: fsl_pxp.h:678
pxp_rop_mode_t ropMode
Definition: fsl_pxp.h:444
enum _pxp_lut_out_mode pxp_lut_out_mode_t
PXP LUT output mode.
uint32_t bufferAddr
Definition: fsl_pxp.h:392
enum _pxp_output_pixel_format pxp_output_pixel_format_t
PXP output buffer format.
uint32_t enable
Definition: fsl_pxp.h:677
_pxp_interrupt_enable
PXP interrupts to enable.
Definition: fsl_pxp.h:76
struct _pxp_csc2_config pxp_csc2_config_t
PXP CSC2 configuration.
uint32_t enableDither1
Definition: fsl_pxp.h:610
enum _pxp_ram pxp_ram_t
PXP internal memory.
float A1
Definition: fsl_pxp.h:502
uint32_t bufferAddr
Definition: fsl_pxp.h:370
uint16_t pitchBytes
Definition: fsl_pxp.h:393
uint16_t srcOffsetX
Definition: fsl_pxp.h:717
pxp_lut_lookup_mode_t lookupMode
Definition: fsl_pxp.h:547
uint32_t data_15_12
Definition: fsl_pxp.h:603
uint8_t alpha
Definition: fsl_pxp.h:440
enum _pxp_rop_mode pxp_rop_mode_t
PXP ROP mode during blending.
pxp_ps_pixel_format_t pixelFormat
Definition: fsl_pxp.h:368
uint32_t data_3_0
Definition: fsl_pxp.h:600
enum _pxp_as_pixel_format pxp_as_pixel_format_t
PXP alpha surface buffer pixel format.
uint32_t lutMode
Definition: fsl_pxp.h:616
uint32_t quantBitNum
Definition: fsl_pxp.h:615
enum _pxp_porter_duff_blend_mode pxp_porter_duff_blend_mode_t
PXP Porter Duff blend mode. Note: don't change the enum item value.
pxp_output_pixel_format_t pixelFormat
Definition: fsl_pxp.h:328
_pxp_ram
PXP internal memory.
Definition: fsl_pxp.h:555
status_t PXP_StartMemCopy(PXP_Type *base, uint32_t srcAddr, uint32_t destAddr, uint32_t size)
Copy continous memory.
Definition: fsl_pxp.c:1259
_pxp_dither_mode
PXP dither mode.
Definition: fsl_pxp.h:571
enum _pxp_rotate_degree pxp_rotate_degree_t
PXP rotate degree.
uint32_t enableDither2
Definition: fsl_pxp.h:611
_pxp_lut_out_mode
PXP LUT output mode.
Definition: fsl_pxp.h:531
enum _pxp_block_size pxp_block_size_t
PXP process block size.
void PXP_SetProcessSurfaceBufferConfig(PXP_Type *base, const pxp_ps_buffer_config_t *config)
Set the process surface input buffer configuration.
Definition: fsl_pxp.c:490
uint32_t cfaValue
Definition: fsl_pxp.h:549
void PXP_SetAlphaSurfacePosition(PXP_Type *base, uint16_t upperLeftX, uint16_t upperLeftY, uint16_t lowerRightX, uint16_t lowerRightY)
Set the alpha surface position in output buffer.
Definition: fsl_pxp.c:419
enum _pxp_ps_yuv_format pxp_ps_yuv_format_t
PXP process surface buffer YUV format.
struct _pxp_dither_config pxp_dither_config_t
PXP dither configuration.
uint16_t height
Definition: fsl_pxp.h:335
status_t PXP_MemCopy(PXP_Type *base, uint32_t srcAddr, uint32_t destAddr, uint32_t size)
Copy continous memory.
Definition: fsl_pxp.c:1302
void PXP_SetCsc2Config(PXP_Type *base, const pxp_csc2_config_t *config)
Set the CSC2 configuration.
Definition: fsl_pxp.c:759
_pxp_flip_mode
PXP output flip mode.
Definition: fsl_pxp.h:271
uint32_t dstFactorMode
Definition: fsl_pxp.h:684
enum _pxp_alpha_mode pxp_alpha_mode_t
PXP alpha mode during blending.
float C1
Definition: fsl_pxp.h:508
uint32_t enableFinalLut
Definition: fsl_pxp.h:625
pxp_as_pixel_format_t pixelFormat
Definition: fsl_pxp.h:725
uint32_t dstGlobalAlpha
Definition: fsl_pxp.h:690
enum _pxp_csc1_mode pxp_csc1_mode_t
PXP CSC1 mode.
uint32_t srcAlphaMode
Definition: fsl_pxp.h:687
uint32_t data_11_8
Definition: fsl_pxp.h:602
_pxp_dither_lut_mode
PXP dither LUT mode.
Definition: fsl_pxp.h:582
uint32_t ditherMode2
Definition: fsl_pxp.h:614
float B3
Definition: fsl_pxp.h:507
uint32_t idxMatrixSize1
Definition: fsl_pxp.h:621
_pxp_interlaced_output_mode
PXP interlaced output mode.
Definition: fsl_pxp.h:296
struct _pxp_dither_final_lut_data pxp_dither_final_lut_data_t
PXP dither final LUT data.
_pxp_block_size
PXP process block size.
Definition: fsl_pxp.h:461
uint32_t data_7_4
Definition: fsl_pxp.h:601
uint16_t destPitchBytes
Definition: fsl_pxp.h:720
bool invertAlpha
Definition: fsl_pxp.h:442
enum _pxp_lut_8k_bank pxp_lut_8k_bank_t
PXP LUT 8K bank index used when lookup mode is kPXP_LutDirectRGB444.
enum _pxp_ps_pixel_format pxp_ps_pixel_format_t
PXP process surface buffer pixel format.
void PXP_SetAlphaSurfaceBufferConfig(PXP_Type *base, const pxp_as_buffer_config_t *config)
Set the alpha surface input buffer configuration.
Definition: fsl_pxp.c:349
uint32_t dstGlobalAlphaMode
Definition: fsl_pxp.h:679
bool swapByte
Definition: fsl_pxp.h:369
void PXP_SetAlphaSurfaceOverlayColorKey(PXP_Type *base, uint32_t colorKeyLow, uint32_t colorKeyHigh)
Set the alpha surface overlay color key.
Definition: fsl_pxp.c:477
float B1
Definition: fsl_pxp.h:505
uint32_t destPicBaseAddr
Definition: fsl_pxp.h:719
uint32_t srcGlobalAlphaMode
Definition: fsl_pxp.h:685
_pxp_ps_pixel_format
PXP process surface buffer pixel format.
Definition: fsl_pxp.h:340
uint16_t srcOffsetY
Definition: fsl_pxp.h:718
_pxp_porter_duff_blend_mode
PXP Porter Duff blend mode. Note: don't change the enum item value.
Definition: fsl_pxp.h:696
status_t PXP_GetPorterDuffConfig(pxp_porter_duff_blend_mode_t mode, pxp_porter_duff_config_t *config)
Get the Porter Duff configuration by blend mode.
Definition: fsl_pxp.c:1072
struct _pxp_ps_buffer_config pxp_ps_buffer_config_t
PXP process surface buffer configuration.
uint16_t pitchBytes
Definition: fsl_pxp.h:373
uint32_t ditherMode1
Definition: fsl_pxp.h:613
void PXP_Deinit(PXP_Type *base)
De-initialize the PXP.
Definition: fsl_pxp.c:322
_pxp_rotate_position
PXP rotate mode.
Definition: fsl_pxp.h:280
float C2
Definition: fsl_pxp.h:509
struct _pxp_as_blend_config pxp_as_blend_config_t
PXP alpha surface blending configuration.
pxp_interlaced_output_mode_t interlacedMode
Definition: fsl_pxp.h:329
uint32_t srcColorMode
Definition: fsl_pxp.h:688
struct _pxp_as_buffer_config pxp_as_buffer_config_t
PXP alphs surface buffer configuration.
uint16_t height
Definition: fsl_pxp.h:724
_pxp_lut_8k_bank
PXP LUT 8K bank index used when lookup mode is kPXP_LutDirectRGB444.
Definition: fsl_pxp.h:539
struct _pxp_pic_copy_config pxp_pic_copy_config_t
PXP Porter Duff blend mode. Note: don't change the enum item value.
void PXP_BuildRect(PXP_Type *base, pxp_output_pixel_format_t outFormat, uint32_t value, uint16_t width, uint16_t height, uint16_t pitch, uint32_t outAddr)
Build a solid rectangle of given pixel value.
Definition: fsl_pxp.c:635
pxp_lut_out_mode_t outMode
Definition: fsl_pxp.h:548
struct _pxp_output_buffer_config pxp_output_buffer_config_t
PXP output buffer configuration.
enum _pxp_lut_lookup_mode pxp_lut_lookup_mode_t
PXP LUT lookup mode.
@ kPXP_PsYUVFormatYUV
Definition: fsl_pxp.h:361
@ kPXP_PsYUVFormatYCbCr
Definition: fsl_pxp.h:362
@ kPXP_Csc1YCbCr2RGB
Definition: fsl_pxp.h:470
@ kPXP_Csc1YUV2RGB
Definition: fsl_pxp.h:469
@ kPXP_PorterDuffColorWithAlpha
Definition: fsl_pxp.h:671
@ kPXP_PorterDuffColorNoAlpha
Definition: fsl_pxp.h:670
@ kPXP_PorterDuffColorStraight
Definition: fsl_pxp.h:668
@ kPXP_PorterDuffColorInversed
Definition: fsl_pxp.h:669
@ kPXP_RopMergeAsNot
Definition: fsl_pxp.h:426
@ kPXP_RopMaskAsNot
Definition: fsl_pxp.h:423
@ kPXP_RopXorAs
Definition: fsl_pxp.h:431
@ kPXP_RopMergeNotAs
Definition: fsl_pxp.h:425
@ kPXP_RopMergeAs
Definition: fsl_pxp.h:424
@ kPXP_RopNotMergeAs
Definition: fsl_pxp.h:430
@ kPXP_RopNotMaskAs
Definition: fsl_pxp.h:429
@ kPXP_RopNotCopyAs
Definition: fsl_pxp.h:427
@ kPXP_RopNotXorAs
Definition: fsl_pxp.h:432
@ kPXP_RopMaskAs
Definition: fsl_pxp.h:421
@ kPXP_RopMaskNotAs
Definition: fsl_pxp.h:422
@ kPXP_RopNot
Definition: fsl_pxp.h:428
@ kPXP_PorterDuffAlphaStraight
Definition: fsl_pxp.h:658
@ kPXP_PorterDuffAlphaInversed
Definition: fsl_pxp.h:659
@ kPXP_LutDirectRGB454
Definition: fsl_pxp.h:526
@ kPXP_LutDirectY8
Definition: fsl_pxp.h:522
@ kPXP_LutDirectRGB444
Definition: fsl_pxp.h:524
@ kPXP_LutCacheRGB565
Definition: fsl_pxp.h:520
@ kPXP_Csc2YCbCr2RGB
Definition: fsl_pxp.h:477
@ kPXP_Csc2YUV2RGB
Definition: fsl_pxp.h:476
@ kPXP_Csc2RGB2YCbCr
Definition: fsl_pxp.h:479
@ kPXP_Csc2RGB2YUV
Definition: fsl_pxp.h:478
@ kPXP_Axi0ReadErrorFlag
Definition: fsl_pxp.h:129
@ kPXP_CompleteFlag
Definition: fsl_pxp.h:126
@ kPXP_Axi0WriteErrorFlag
Definition: fsl_pxp.h:127
@ kPXP_LutDmaLoadFlag
Definition: fsl_pxp.h:134
@ kPXP_CommandLoadFlag
Definition: fsl_pxp.h:131
@ kPXP_DitherMatrix8
Definition: fsl_pxp.h:593
@ kPXP_DitherMatrix16
Definition: fsl_pxp.h:594
@ kPXP_DitherMatrix4
Definition: fsl_pxp.h:592
@ kPXP_PorterDuffFactorInversed
Definition: fsl_pxp.h:638
@ kPXP_PorterDuffFactorZero
Definition: fsl_pxp.h:636
@ kPXP_PorterDuffFactorStraight
Definition: fsl_pxp.h:637
@ kPXP_PorterDuffFactorOne
Definition: fsl_pxp.h:635
@ kPXP_Rotate270
Definition: fsl_pxp.h:291
@ kPXP_Rotate0
Definition: fsl_pxp.h:288
@ kPXP_Rotate180
Definition: fsl_pxp.h:290
@ kPXP_Rotate90
Definition: fsl_pxp.h:289
@ kPXP_AsPixelFormatARGB4444
Definition: fsl_pxp.h:382
@ kPXP_AsPixelFormatRGB565
Definition: fsl_pxp.h:385
@ kPXP_AsPixelFormatRGB555
Definition: fsl_pxp.h:383
@ kPXP_AsPixelFormatARGB1555
Definition: fsl_pxp.h:381
@ kPXP_AsPixelFormatRGB888
Definition: fsl_pxp.h:380
@ kPXP_AsPixelFormatARGB8888
Definition: fsl_pxp.h:379
@ kPXP_AsPixelFormatRGB444
Definition: fsl_pxp.h:384
@ kPXP_AlphaOverride
Definition: fsl_pxp.h:402
@ kPXP_AlphaMultiply
Definition: fsl_pxp.h:403
@ kPXP_AlphaRop
Definition: fsl_pxp.h:407
@ kPXP_AlphaEmbedded
Definition: fsl_pxp.h:401
@ kPXP_OutputPixelFormatYVU2P420
Definition: fsl_pxp.h:322
@ kPXP_OutputPixelFormatYUV2P422
Definition: fsl_pxp.h:319
@ kPXP_OutputPixelFormatVYUY1P422
Definition: fsl_pxp.h:316
@ kPXP_OutputPixelFormatUYVY1P422
Definition: fsl_pxp.h:315
@ kPXP_OutputPixelFormatYVU2P422
Definition: fsl_pxp.h:321
@ kPXP_OutputPixelFormatY8
Definition: fsl_pxp.h:317
@ kPXP_OutputPixelFormatRGB444
Definition: fsl_pxp.h:312
@ kPXP_OutputPixelFormatRGB888
Definition: fsl_pxp.h:307
@ kPXP_OutputPixelFormatYUV2P420
Definition: fsl_pxp.h:320
@ kPXP_OutputPixelFormatARGB8888
Definition: fsl_pxp.h:306
@ kPXP_OutputPixelFormatRGB565
Definition: fsl_pxp.h:313
@ kPXP_OutputPixelFormatYUV1P444
Definition: fsl_pxp.h:314
@ kPXP_OutputPixelFormatRGB555
Definition: fsl_pxp.h:311
@ kPXP_OutputPixelFormatARGB4444
Definition: fsl_pxp.h:310
@ kPXP_OutputPixelFormatARGB1555
Definition: fsl_pxp.h:309
@ kPXP_OutputPixelFormatY4
Definition: fsl_pxp.h:318
@ kPXP_OutputPixelFormatRGB888P
Definition: fsl_pxp.h:308
@ kPXP_CompleteInterruptEnable
Definition: fsl_pxp.h:77
@ kPXP_CommandLoadInterruptEnable
Definition: fsl_pxp.h:78
@ kPXP_LutDmaLoadInterruptEnable
Definition: fsl_pxp.h:81
@ kPXP_RamDither0Lut
Definition: fsl_pxp.h:556
@ kPXP_RamDither1Lut
Definition: fsl_pxp.h:557
@ kPXP_RamDither2Lut
Definition: fsl_pxp.h:558
@ kPXP_DitherQuantOnly
Definition: fsl_pxp.h:576
@ kPXP_DitherOrdered
Definition: fsl_pxp.h:575
@ kPXP_DitherFloydSteinberg
Definition: fsl_pxp.h:573
@ kPXP_DitherSierra
Definition: fsl_pxp.h:577
@ kPXP_DitherAtkinson
Definition: fsl_pxp.h:574
@ kPXP_DitherPassThrough
Definition: fsl_pxp.h:572
@ kPXP_LutOutY8
Definition: fsl_pxp.h:532
@ kPXP_LutOutRGB888
Definition: fsl_pxp.h:534
@ kPXP_LutOutRGBW4444CFA
Definition: fsl_pxp.h:533
@ kPXP_FlipHorizontal
Definition: fsl_pxp.h:273
@ kPXP_FlipBoth
Definition: fsl_pxp.h:275
@ kPXP_FlipVertical
Definition: fsl_pxp.h:274
@ kPXP_FlipDisable
Definition: fsl_pxp.h:272
@ kPXP_DitherLutOff
Definition: fsl_pxp.h:583
@ kPXP_DitherLutPreDither
Definition: fsl_pxp.h:584
@ kPXP_DitherLutPostDither
Definition: fsl_pxp.h:586
@ kPXP_OutputField0
Definition: fsl_pxp.h:298
@ kPXP_OutputField1
Definition: fsl_pxp.h:299
@ kPXP_OutputProgressive
Definition: fsl_pxp.h:297
@ kPXP_OutputInterlaced
Definition: fsl_pxp.h:300
@ kPXP_BlockSize16
Definition: fsl_pxp.h:463
@ kPXP_BlockSize8
Definition: fsl_pxp.h:462
@ kPXP_PsPixelFormatYUV2P420
Definition: fsl_pxp.h:351
@ kPXP_PsPixelFormatYVU2P422
Definition: fsl_pxp.h:352
@ kPXP_PsPixelFormatYVU420
Definition: fsl_pxp.h:355
@ kPXP_PsPixelFormatVYUY1P422
Definition: fsl_pxp.h:347
@ kPXP_PsPixelFormatRGB888
Definition: fsl_pxp.h:341
@ kPXP_PsPixelFormatUYVY1P422
Definition: fsl_pxp.h:346
@ kPXP_PsPixelFormatYUV1P444
Definition: fsl_pxp.h:345
@ kPXP_PsPixelFormatYVU2P420
Definition: fsl_pxp.h:353
@ kPXP_PsPixelFormatY8
Definition: fsl_pxp.h:348
@ kPXP_PsPixelFormatYVU422
Definition: fsl_pxp.h:354
@ kPXP_PsPixelFormatRGB565
Definition: fsl_pxp.h:344
@ kPXP_PsPixelFormatRGB444
Definition: fsl_pxp.h:343
@ kPXP_PsPixelFormatY4
Definition: fsl_pxp.h:349
@ kPXP_PsPixelFormatYUV2P422
Definition: fsl_pxp.h:350
@ kPXP_PsPixelFormatRGB555
Definition: fsl_pxp.h:342
@ kPXP_PorterDuffDstOut
Definition: fsl_pxp.h:706
@ kPXP_PorterDuffIn
Definition: fsl_pxp.h:700
@ kPXP_PorterDuffDstAtop
Definition: fsl_pxp.h:703
@ kPXP_PorterDuffDstOver
Definition: fsl_pxp.h:704
@ kPXP_PorterDuffClear
Definition: fsl_pxp.h:708
@ kPXP_PorterDuffSrc
Definition: fsl_pxp.h:697
@ kPXP_PorterDuffAtop
Definition: fsl_pxp.h:698
@ kPXP_PorterDuffOut
Definition: fsl_pxp.h:701
@ kPXP_PorterDuffDst
Definition: fsl_pxp.h:702
@ kPXP_PorterDuffDstIn
Definition: fsl_pxp.h:705
@ kPXP_PorterDuffOver
Definition: fsl_pxp.h:699
@ kPXP_PorterDuffXor
Definition: fsl_pxp.h:707
@ kPXP_RotateOutputBuffer
Definition: fsl_pxp.h:281
@ kPXP_RotateProcessSurface
Definition: fsl_pxp.h:282
@ kPXP_Lut8kBank1
Definition: fsl_pxp.h:541
@ kPXP_Lut8kBank0
Definition: fsl_pxp.h:540
@ kPXP_PorterDuffLocalAlpha
Definition: fsl_pxp.h:648
@ kPXP_PorterDuffScaledAlpha
Definition: fsl_pxp.h:649
@ kPXP_PorterDuffGlobalAlpha
Definition: fsl_pxp.h:647
Definition: MIMXRT1052.h:37827
PXP alpha surface blending configuration.
Definition: fsl_pxp.h:439
PXP alphs surface buffer configuration.
Definition: fsl_pxp.h:390
PXP CSC2 configuration.
Definition: fsl_pxp.h:500
PXP dither configuration.
Definition: fsl_pxp.h:608
PXP dither final LUT data.
Definition: fsl_pxp.h:599
PXP LUT configuration.
Definition: fsl_pxp.h:546
PXP output buffer configuration.
Definition: fsl_pxp.h:327
PXP Porter Duff blend mode. Note: don't change the enum item value.
Definition: fsl_pxp.h:714
PXP process surface buffer configuration.
Definition: fsl_pxp.h:367
Definition: deflate.c:114
PXP Porter Duff configuration.
Definition: fsl_pxp.h:676