KEMBAR78
MCUXpresso SDK API Reference Manual - MKL43Z4 | PDF | Digital To Analog Converter | Software Engineering
0% found this document useful (0 votes)
448 views993 pages

MCUXpresso SDK API Reference Manual - MKL43Z4

This document is the MCUXpresso SDK API Reference Manual from NXP Semiconductors. It contains documentation for various drivers, including the ADC16 analog-to-digital converter driver and CMP analog comparator driver. The document provides overviews of the drivers, typical use cases, descriptions of data structures and enumerations, and API function documentation.

Uploaded by

Deniz Kutan
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
448 views993 pages

MCUXpresso SDK API Reference Manual - MKL43Z4

This document is the MCUXpresso SDK API Reference Manual from NXP Semiconductors. It contains documentation for various drivers, including the ADC16 analog-to-digital converter driver and CMP analog comparator driver. The document provides overviews of the drivers, typical use cases, descriptions of data structures and enumerations, and API function documentation.

Uploaded by

Deniz Kutan
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 993

MCUXpresso SDK API Reference Manual

NXP Semiconductors

Document Number: MCUXSDKAPIRM


Rev. 0
Jun 2019
Contents
Chapter Introduction

Chapter Driver errors status

Chapter Architectural Overview

Chapter Trademarks

Chapter ADC16: 16-bit SAR Analog-to-Digital Converter Driver

5.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11

5.2 Typical use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11


5.2.1 Polling Configuration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
5.2.2 Interrupt Configuration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11

5.3 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14


5.3.1 struct adc16_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14
5.3.2 struct adc16_hardware_compare_config_t . . . . . . . . . . . . . . . . . . . . . 15
5.3.3 struct adc16_channel_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15

5.4 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . 16


5.4.1 FSL_ADC16_DRIVER_VERSION . . . . . . . . . . . . . . . . . . . . . . . . . 16

5.5 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 16


5.5.1 _adc16_channel_status_flags . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16
5.5.2 _adc16_status_flags . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16
5.5.3 adc16_channel_mux_mode_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16
5.5.4 adc16_clock_divider_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
5.5.5 adc16_resolution_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
5.5.6 adc16_clock_source_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
5.5.7 adc16_long_sample_mode_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
5.5.8 adc16_reference_voltage_source_t . . . . . . . . . . . . . . . . . . . . . . . . . 18
5.5.9 adc16_hardware_average_mode_t . . . . . . . . . . . . . . . . . . . . . . . . . . 18
5.5.10 adc16_hardware_compare_mode_t . . . . . . . . . . . . . . . . . . . . . . . . . 18

5.6 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18


5.6.1 ADC16_Init . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18

MCUXpresso SDK API Reference Manual


NXP Semiconductors iii
Section
Contents Page
Number Title Number

5.6.2 ADC16_Deinit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19
5.6.3 ADC16_GetDefaultConfig . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19
5.6.4 ADC16_DoAutoCalibration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19
5.6.5 ADC16_SetOffsetValue . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20
5.6.6 ADC16_EnableDMA . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20
5.6.7 ADC16_EnableHardwareTrigger . . . . . . . . . . . . . . . . . . . . . . . . . . 20
5.6.8 ADC16_SetChannelMuxMode . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
5.6.9 ADC16_SetHardwareCompareConfig . . . . . . . . . . . . . . . . . . . . . . . . 21
5.6.10 ADC16_SetHardwareAverage . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
5.6.11 ADC16_GetStatusFlags . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22
5.6.12 ADC16_ClearStatusFlags . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22
5.6.13 ADC16_SetChannelConfig . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22
5.6.14 ADC16_GetChannelConversionValue . . . . . . . . . . . . . . . . . . . . . . . . 24
5.6.15 ADC16_GetChannelStatusFlags . . . . . . . . . . . . . . . . . . . . . . . . . . . 24

Chapter CMP: Analog Comparator Driver

6.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25

6.2 Typical use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25


6.2.1 Polling Configuration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
6.2.2 Interrupt Configuration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25

6.3 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27


6.3.1 struct cmp_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
6.3.2 struct cmp_filter_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
6.3.3 struct cmp_dac_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28

6.4 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . 28


6.4.1 FSL_CMP_DRIVER_VERSION . . . . . . . . . . . . . . . . . . . . . . . . . . 28

6.5 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 28


6.5.1 _cmp_interrupt_enable . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
6.5.2 _cmp_status_flags . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
6.5.3 cmp_hysteresis_mode_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
6.5.4 cmp_reference_voltage_source_t . . . . . . . . . . . . . . . . . . . . . . . . . . 29

6.6 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29


6.6.1 CMP_Init . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
6.6.2 CMP_Deinit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
6.6.3 CMP_Enable . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31
6.6.4 CMP_GetDefaultConfig . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31
6.6.5 CMP_SetInputChannels . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31
6.6.6 CMP_EnableDMA . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32
6.6.7 CMP_SetFilterConfig . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32

MCUXpresso SDK API Reference Manual


iv NXP Semiconductors
Section
Contents Page
Number Title Number

6.6.8 CMP_SetDACConfig . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32
6.6.9 CMP_EnableInterrupts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32
6.6.10 CMP_DisableInterrupts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33
6.6.11 CMP_GetStatusFlags . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33
6.6.12 CMP_ClearStatusFlags . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33

Chapter COP: Watchdog Driver

7.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35

7.2 Typical use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35

7.3 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36


7.3.1 struct cop_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36

7.4 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . 36


7.4.1 FSL_COP_DRIVER_VERSION . . . . . . . . . . . . . . . . . . . . . . . . . . 36

7.5 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 36


7.5.1 cop_clock_source_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
7.5.2 cop_timeout_cycles_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
7.5.3 cop_timeout_mode_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37

7.6 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37


7.6.1 COP_GetDefaultConfig . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
7.6.2 COP_Init . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
7.6.3 COP_Disable . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38
7.6.4 COP_Refresh . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38

Chapter DAC: Digital-to-Analog Converter Driver

8.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39

8.2 Typical use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39


8.2.1 Working as a basic DAC without the hardware buffer feature . . . . . . . . . . . 39
8.2.2 Working with the hardware buffer . . . . . . . . . . . . . . . . . . . . . . . . . . 39

8.3 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41


8.3.1 struct dac_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41
8.3.2 struct dac_buffer_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41

8.4 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . 42


8.4.1 FSL_DAC_DRIVER_VERSION . . . . . . . . . . . . . . . . . . . . . . . . . . 42

8.5 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 42


8.5.1 _dac_buffer_status_flags . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42

MCUXpresso SDK API Reference Manual


NXP Semiconductors v
Section
Contents Page
Number Title Number

8.5.2 _dac_buffer_interrupt_enable . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42
8.5.3 dac_reference_voltage_source_t . . . . . . . . . . . . . . . . . . . . . . . . . . . 42
8.5.4 dac_buffer_trigger_mode_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42
8.5.5 dac_buffer_work_mode_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43

8.6 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43


8.6.1 DAC_Init . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
8.6.2 DAC_Deinit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
8.6.3 DAC_GetDefaultConfig . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
8.6.4 DAC_Enable . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44
8.6.5 DAC_EnableBuffer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44
8.6.6 DAC_SetBufferConfig . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44
8.6.7 DAC_GetDefaultBufferConfig . . . . . . . . . . . . . . . . . . . . . . . . . . . 44
8.6.8 DAC_EnableBufferDMA . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45
8.6.9 DAC_SetBufferValue . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45
8.6.10 DAC_DoSoftwareTriggerBuffer . . . . . . . . . . . . . . . . . . . . . . . . . . . 45
8.6.11 DAC_GetBufferReadPointer . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45
8.6.12 DAC_SetBufferReadPointer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46
8.6.13 DAC_EnableBufferInterrupts . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46
8.6.14 DAC_DisableBufferInterrupts . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46
8.6.15 DAC_GetBufferStatusFlags . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46
8.6.16 DAC_ClearBufferStatusFlags . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47

Chapter DMA: Direct Memory Access Controller Driver

9.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49

9.2 Typical use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49


9.2.1 DMA Operation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49

9.3 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52


9.3.1 struct dma_transfer_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52
9.3.2 struct dma_channel_link_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . 53
9.3.3 struct dma_handle_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53

9.4 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . 54


9.4.1 FSL_DMA_DRIVER_VERSION . . . . . . . . . . . . . . . . . . . . . . . . . . 54

9.5 Typedef Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54


9.5.1 dma_callback . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54

9.6 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 54


9.6.1 _dma_channel_status_flags . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54
9.6.2 dma_transfer_size_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54
9.6.3 dma_modulo_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54
9.6.4 dma_channel_link_type_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55

MCUXpresso SDK API Reference Manual


vi NXP Semiconductors
Section
Contents Page
Number Title Number

9.6.5 dma_transfer_type_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55
9.6.6 dma_transfer_options_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55

9.7 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56


9.7.1 DMA_Init . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56
9.7.2 DMA_Deinit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57
9.7.3 DMA_ResetChannel . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57
9.7.4 DMA_SetTransferConfig . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57
9.7.5 DMA_SetChannelLinkConfig . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58
9.7.6 DMA_SetSourceAddress . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58
9.7.7 DMA_SetDestinationAddress . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58
9.7.8 DMA_SetTransferSize . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59
9.7.9 DMA_SetModulo . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59
9.7.10 DMA_EnableCycleSteal . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59
9.7.11 DMA_EnableAutoAlign . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60
9.7.12 DMA_EnableAsyncRequest . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60
9.7.13 DMA_EnableInterrupts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60
9.7.14 DMA_DisableInterrupts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61
9.7.15 DMA_EnableChannelRequest . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61
9.7.16 DMA_DisableChannelRequest . . . . . . . . . . . . . . . . . . . . . . . . . . . 61
9.7.17 DMA_TriggerChannelStart . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61
9.7.18 DMA_GetRemainingBytes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62
9.7.19 DMA_GetChannelStatusFlags . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62
9.7.20 DMA_ClearChannelStatusFlags . . . . . . . . . . . . . . . . . . . . . . . . . . . 62
9.7.21 DMA_CreateHandle . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63
9.7.22 DMA_SetCallback . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63
9.7.23 DMA_PrepareTransfer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63
9.7.24 DMA_SubmitTransfer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64
9.7.25 DMA_StartTransfer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64
9.7.26 DMA_StopTransfer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65
9.7.27 DMA_AbortTransfer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65
9.7.28 DMA_HandleIRQ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65

Chapter DMAMUX: Direct Memory Access Multiplexer Driver

10.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67

10.2 Typical use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67


10.2.1 DMAMUX Operation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67

10.3 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . 67


10.3.1 FSL_DMAMUX_DRIVER_VERSION . . . . . . . . . . . . . . . . . . . . . . . 67

10.4 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 68


10.4.1 DMAMUX_Init . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 68

MCUXpresso SDK API Reference Manual


NXP Semiconductors vii
Section
Contents Page
Number Title Number

10.4.2 DMAMUX_Deinit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69
10.4.3 DMAMUX_EnableChannel . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69
10.4.4 DMAMUX_DisableChannel . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69
10.4.5 DMAMUX_SetSource . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 70
10.4.6 DMAMUX_EnablePeriodTrigger . . . . . . . . . . . . . . . . . . . . . . . . . . 70
10.4.7 DMAMUX_DisablePeriodTrigger . . . . . . . . . . . . . . . . . . . . . . . . . 70

Chapter C90TFS Flash Driver

11.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71

11.2 Ftftx FLASH Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72


11.2.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72
11.2.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 76
11.2.3 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 77
11.2.4 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . 77
11.2.5 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78

11.3 Ftftx CACHE Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 93


11.3.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 93
11.3.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 93
11.3.3 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 94
11.3.4 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . 94
11.3.5 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 94

11.4 Ftftx FLEXNVM Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 97


11.4.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 97
11.4.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99
11.4.3 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 99
11.4.4 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . 99
11.4.5 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 100

11.5 ftfx feature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 116


11.5.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 116
11.5.2 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 116
11.5.3 ftfx adapter . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 117

11.6 ftfx controller . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 118


11.6.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 118
11.6.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 124
11.6.3 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 125
11.6.4 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . 125
11.6.5 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 127
11.6.6 Variable Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 140
11.6.7 ftfx utilities . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 141

MCUXpresso SDK API Reference Manual


viii NXP Semiconductors
Section
Contents Page
Number Title Number

Chapter FlexIO: FlexIO Driver

12.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 143

12.2 FlexIO Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 144


12.2.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 144
12.2.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 148
12.2.3 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 151
12.2.4 Typedef Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 151
12.2.5 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . 151
12.2.6 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 155
12.2.7 Variable Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 165

12.3 FlexIO Camera Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 166


12.3.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 166
12.3.2 Typical use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 166
12.3.3 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 169
12.3.4 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 170
12.3.5 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . 170
12.3.6 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 171
12.3.7 FlexIO eDMA Camera Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . 175

12.4 FlexIO I2C Master Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 179


12.4.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 179
12.4.2 Typical use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 179
12.4.3 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 183
12.4.4 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 186
12.4.5 Typedef Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 186
12.4.6 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . 186
12.4.7 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 187

12.5 FlexIO I2S Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 197


12.5.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 197
12.5.2 Typical use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 197
12.5.3 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 202
12.5.4 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 204
12.5.5 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . 204
12.5.6 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 206
12.5.7 FlexIO eDMA I2S Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 217
12.5.8 FlexIO DMA I2S Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 224

12.6 FlexIO MCU Interface LCD Driver . . . . . . . . . . . . . . . . . . . . . . . . . 231


12.6.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 231
12.6.2 Typical use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 231
12.6.3 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 237
12.6.4 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 241

MCUXpresso SDK API Reference Manual


NXP Semiconductors ix
Section
Contents Page
Number Title Number

12.6.5 Typedef Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 241


12.6.6 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . 242
12.6.7 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 243
12.6.8 FlexIO eDMA MCU Interface LCD Driver . . . . . . . . . . . . . . . . . . . . . 256
12.6.9 FlexIO DMA MCU Interface LCD Driver . . . . . . . . . . . . . . . . . . . . . 262
12.6.10 FlexIO SMARTDMA MCU Interface LCD Driver . . . . . . . . . . . . . . . . . 267

12.7 FlexIO SPI Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 272


12.7.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 272
12.7.2 Typical use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 272
12.7.3 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 279
12.7.4 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 283
12.7.5 Typedef Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 283
12.7.6 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . 283
12.7.7 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 285
12.7.8 FlexIO eDMA SPI Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 299
12.7.9 FlexIO DMA SPI Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 307

12.8 FlexIO UART Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 315


12.8.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 315
12.8.2 Typical use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 315
12.8.3 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 324
12.8.4 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 326
12.8.5 Typedef Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 326
12.8.6 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . 326
12.8.7 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 327
12.8.8 FlexIO eDMA UART Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . 340
12.8.9 FlexIO DMA UART Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 346

Chapter GPIO: General-Purpose Input/Output Driver

13.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 353

13.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 353


13.2.1 struct gpio_pin_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 353

13.3 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . 354


13.3.1 FSL_GPIO_DRIVER_VERSION . . . . . . . . . . . . . . . . . . . . . . . . . . 354

13.4 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 354


13.4.1 gpio_pin_direction_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 354

13.5 GPIO Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 355


13.5.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 355
13.5.2 Typical use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 355
13.5.3 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 356

MCUXpresso SDK API Reference Manual


x NXP Semiconductors
Section
Contents Page
Number Title Number

13.6 FGPIO Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 359


13.6.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 359
13.6.2 Typical use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 359
13.6.3 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 360

Chapter I2C: Inter-Integrated Circuit Driver

14.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 363

14.2 I2C Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 364


14.2.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 364
14.2.2 Typical use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 364
14.2.3 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 369
14.2.4 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 373
14.2.5 Typedef Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 373
14.2.6 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . 373
14.2.7 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 375

14.3 I2C eDMA Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 389


14.3.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 389
14.3.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 389
14.3.3 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 390
14.3.4 Typedef Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 390
14.3.5 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 390

14.4 I2C DMA Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 393


14.4.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 393
14.4.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 393
14.4.3 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 394
14.4.4 Typedef Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 394
14.4.5 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 394

14.5 I2C FreeRTOS Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 397


14.5.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 397
14.5.2 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 397
14.5.3 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 397

Chapter LLWU: Low-Leakage Wakeup Unit Driver

15.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 401

15.2 External wakeup pins configurations . . . . . . . . . . . . . . . . . . . . . . . . . 401

15.3 Internal wakeup modules configurations . . . . . . . . . . . . . . . . . . . . . . . 401

15.4 Digital pin filter for external wakeup pin configurations . . . . . . . . . . . . . . 401

MCUXpresso SDK API Reference Manual


NXP Semiconductors xi
Section
Contents Page
Number Title Number

15.5 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 402


15.5.1 struct llwu_external_pin_filter_mode_t . . . . . . . . . . . . . . . . . . . . . . . 402

15.6 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . 402


15.6.1 FSL_LLWU_DRIVER_VERSION . . . . . . . . . . . . . . . . . . . . . . . . . 402

15.7 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 402


15.7.1 llwu_external_pin_mode_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 402
15.7.2 llwu_pin_filter_mode_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 403

15.8 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 403


15.8.1 LLWU_SetExternalWakeupPinMode . . . . . . . . . . . . . . . . . . . . . . . . 403
15.8.2 LLWU_GetExternalWakeupPinFlag . . . . . . . . . . . . . . . . . . . . . . . . 403
15.8.3 LLWU_ClearExternalWakeupPinFlag . . . . . . . . . . . . . . . . . . . . . . . 404
15.8.4 LLWU_EnableInternalModuleInterruptWakup . . . . . . . . . . . . . . . . . . . 405
15.8.5 LLWU_GetInternalWakeupModuleFlag . . . . . . . . . . . . . . . . . . . . . . 405
15.8.6 LLWU_SetPinFilterMode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 405
15.8.7 LLWU_GetPinFilterFlag . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 406
15.8.8 LLWU_ClearPinFilterFlag . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 406

Chapter LPTMR: Low-Power Timer

16.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 407

16.2 Function groups . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 407


16.2.1 Initialization and deinitialization . . . . . . . . . . . . . . . . . . . . . . . . . . 407
16.2.2 Timer period Operations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 407
16.2.3 Start and Stop timer operations . . . . . . . . . . . . . . . . . . . . . . . . . . . 407
16.2.4 Status . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 408
16.2.5 Interrupt . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 408

16.3 Typical use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 408


16.3.1 LPTMR tick example . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 408

16.4 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 410


16.4.1 struct lptmr_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 410

16.5 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 411


16.5.1 lptmr_pin_select_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 411
16.5.2 lptmr_pin_polarity_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 411
16.5.3 lptmr_timer_mode_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 411
16.5.4 lptmr_prescaler_glitch_value_t . . . . . . . . . . . . . . . . . . . . . . . . . . . 411
16.5.5 lptmr_prescaler_clock_select_t . . . . . . . . . . . . . . . . . . . . . . . . . . . 412
16.5.6 lptmr_interrupt_enable_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 412
16.5.7 lptmr_status_flags_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 412

MCUXpresso SDK API Reference Manual


xii NXP Semiconductors
Section
Contents Page
Number Title Number

16.6 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 412


16.6.1 LPTMR_Init . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 412
16.6.2 LPTMR_Deinit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 413
16.6.3 LPTMR_GetDefaultConfig . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 413
16.6.4 LPTMR_EnableInterrupts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 413
16.6.5 LPTMR_DisableInterrupts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 413
16.6.6 LPTMR_GetEnabledInterrupts . . . . . . . . . . . . . . . . . . . . . . . . . . . 414
16.6.7 LPTMR_GetStatusFlags . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 414
16.6.8 LPTMR_ClearStatusFlags . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 414
16.6.9 LPTMR_SetTimerPeriod . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 415
16.6.10 LPTMR_GetCurrentTimerCount . . . . . . . . . . . . . . . . . . . . . . . . . . 415
16.6.11 LPTMR_StartTimer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 415
16.6.12 LPTMR_StopTimer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 416

Chapter LPUART: Low Power UART Driver

17.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 417

17.2 LPUART Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 418


17.2.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 418
17.2.2 Typical use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 418
17.2.3 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 422
17.2.4 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 425
17.2.5 Typedef Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 425
17.2.6 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . 425
17.2.7 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 428

17.3 LPUART DMA Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 441


17.3.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 441
17.3.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 442
17.3.3 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 443
17.3.4 Typedef Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 443
17.3.5 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 443

17.4 LPUART eDMA Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 447


17.4.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 447
17.4.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 448
17.4.3 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 449
17.4.4 Typedef Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 449
17.4.5 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 449

17.5 LPUART FreeRTOS Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 453


17.5.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 453
17.5.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 453
17.5.3 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 454

MCUXpresso SDK API Reference Manual


NXP Semiconductors xiii
Section
Contents Page
Number Title Number

17.5.4 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 454

Chapter PIT: Periodic Interrupt Timer

18.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 457

18.2 Function groups . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 457


18.2.1 Initialization and deinitialization . . . . . . . . . . . . . . . . . . . . . . . . . . 457
18.2.2 Timer period Operations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 457
18.2.3 Start and Stop timer operations . . . . . . . . . . . . . . . . . . . . . . . . . . . 457
18.2.4 Status . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 458
18.2.5 Interrupt . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 458

18.3 Typical use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 458


18.3.1 PIT tick example . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 458

18.4 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 459


18.4.1 struct pit_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 459

18.5 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 460


18.5.1 pit_chnl_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 460
18.5.2 pit_interrupt_enable_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 460
18.5.3 pit_status_flags_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 460

18.6 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 460


18.6.1 PIT_Init . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 460
18.6.2 PIT_Deinit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 461
18.6.3 PIT_GetDefaultConfig . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 461
18.6.4 PIT_SetTimerChainMode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 461
18.6.5 PIT_EnableInterrupts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 462
18.6.6 PIT_DisableInterrupts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 462
18.6.7 PIT_GetEnabledInterrupts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 462
18.6.8 PIT_GetStatusFlags . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 463
18.6.9 PIT_ClearStatusFlags . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 464
18.6.10 PIT_SetTimerPeriod . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 464
18.6.11 PIT_GetCurrentTimerCount . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 465
18.6.12 PIT_StartTimer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 465
18.6.13 PIT_StopTimer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 465
18.6.14 PIT_GetLifetimeTimerCount . . . . . . . . . . . . . . . . . . . . . . . . . . . . 466

Chapter PMC: Power Management Controller

19.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 467

19.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 468


19.2.1 struct pmc_low_volt_detect_config_t . . . . . . . . . . . . . . . . . . . . . . . . 468

MCUXpresso SDK API Reference Manual


xiv NXP Semiconductors
Section
Contents Page
Number Title Number

19.2.2 struct pmc_low_volt_warning_config_t . . . . . . . . . . . . . . . . . . . . . . . 468


19.2.3 struct pmc_bandgap_buffer_config_t . . . . . . . . . . . . . . . . . . . . . . . . 468

19.3 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . 469


19.3.1 FSL_PMC_DRIVER_VERSION . . . . . . . . . . . . . . . . . . . . . . . . . . 469

19.4 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 469


19.4.1 pmc_low_volt_detect_volt_select_t . . . . . . . . . . . . . . . . . . . . . . . . . 469
19.4.2 pmc_low_volt_warning_volt_select_t . . . . . . . . . . . . . . . . . . . . . . . . 469

19.5 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 469


19.5.1 PMC_ConfigureLowVoltDetect . . . . . . . . . . . . . . . . . . . . . . . . . . . 469
19.5.2 PMC_GetLowVoltDetectFlag . . . . . . . . . . . . . . . . . . . . . . . . . . . . 470
19.5.3 PMC_ClearLowVoltDetectFlag . . . . . . . . . . . . . . . . . . . . . . . . . . . 470
19.5.4 PMC_ConfigureLowVoltWarning . . . . . . . . . . . . . . . . . . . . . . . . . . 470
19.5.5 PMC_GetLowVoltWarningFlag . . . . . . . . . . . . . . . . . . . . . . . . . . . 471
19.5.6 PMC_ClearLowVoltWarningFlag . . . . . . . . . . . . . . . . . . . . . . . . . . 471
19.5.7 PMC_ConfigureBandgapBuffer . . . . . . . . . . . . . . . . . . . . . . . . . . . 471
19.5.8 PMC_GetPeriphIOIsolationFlag . . . . . . . . . . . . . . . . . . . . . . . . . . . 472
19.5.9 PMC_ClearPeriphIOIsolationFlag . . . . . . . . . . . . . . . . . . . . . . . . . . 472
19.5.10 PMC_IsRegulatorInRunRegulation . . . . . . . . . . . . . . . . . . . . . . . . . 472

Chapter PORT: Port Control and Interrupts

20.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 475

20.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 477


20.2.1 struct port_pin_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 477

20.3 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . 477


20.3.1 FSL_PORT_DRIVER_VERSION . . . . . . . . . . . . . . . . . . . . . . . . . 477

20.4 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 477


20.4.1 _port_pull . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 477
20.4.2 _port_slew_rate . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 477
20.4.3 _port_passive_filter_enable . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 478
20.4.4 _port_drive_strength . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 478
20.4.5 port_mux_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 478
20.4.6 port_interrupt_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 478

20.5 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 479


20.5.1 PORT_SetPinConfig . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 479
20.5.2 PORT_SetMultiplePinsConfig . . . . . . . . . . . . . . . . . . . . . . . . . . . . 479
20.5.3 PORT_SetPinMux . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 480
20.5.4 PORT_SetPinInterruptConfig . . . . . . . . . . . . . . . . . . . . . . . . . . . . 481
20.5.5 PORT_SetPinDriveStrength . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 481

MCUXpresso SDK API Reference Manual


NXP Semiconductors xv
Section
Contents Page
Number Title Number

20.5.6 PORT_GetPinsInterruptFlags . . . . . . . . . . . . . . . . . . . . . . . . . . . . 482


20.5.7 PORT_ClearPinsInterruptFlags . . . . . . . . . . . . . . . . . . . . . . . . . . . 482

Chapter RCM: Reset Control Module Driver

21.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 483

21.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 484


21.2.1 struct rcm_reset_pin_filter_config_t . . . . . . . . . . . . . . . . . . . . . . . . . 484

21.3 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . 484


21.3.1 FSL_RCM_DRIVER_VERSION . . . . . . . . . . . . . . . . . . . . . . . . . . 484

21.4 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 484


21.4.1 rcm_reset_source_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 484
21.4.2 rcm_run_wait_filter_mode_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 485
21.4.3 rcm_boot_rom_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 485

21.5 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 485


21.5.1 RCM_GetPreviousResetSources . . . . . . . . . . . . . . . . . . . . . . . . . . 485
21.5.2 RCM_GetStickyResetSources . . . . . . . . . . . . . . . . . . . . . . . . . . . . 486
21.5.3 RCM_ClearStickyResetSources . . . . . . . . . . . . . . . . . . . . . . . . . . . 486
21.5.4 RCM_ConfigureResetPinFilter . . . . . . . . . . . . . . . . . . . . . . . . . . . 487
21.5.5 RCM_GetBootRomSource . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 487
21.5.6 RCM_ClearBootRomSource . . . . . . . . . . . . . . . . . . . . . . . . . . . . 487
21.5.7 RCM_SetForceBootRomSource . . . . . . . . . . . . . . . . . . . . . . . . . . . 488

Chapter RTC: Real Time Clock

22.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 489

22.2 Function groups . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 489


22.2.1 Initialization and deinitialization . . . . . . . . . . . . . . . . . . . . . . . . . . 489
22.2.2 Set & Get Datetime . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 489
22.2.3 Set & Get Alarm . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 489
22.2.4 Start & Stop timer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 489
22.2.5 Status . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 490
22.2.6 Interrupt . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 490
22.2.7 RTC Oscillator . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 490
22.2.8 Monotonic Counter . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 490

22.3 Typical use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 490


22.3.1 RTC tick example . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 490

22.4 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 492


22.4.1 struct rtc_datetime_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 492

MCUXpresso SDK API Reference Manual


xvi NXP Semiconductors
Section
Contents Page
Number Title Number

22.4.2 struct rtc_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 493

22.5 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 493


22.5.1 rtc_interrupt_enable_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 493
22.5.2 rtc_status_flags_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 494
22.5.3 rtc_osc_cap_load_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 494

22.6 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 494


22.6.1 RTC_Init . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 494
22.6.2 RTC_Deinit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 494
22.6.3 RTC_GetDefaultConfig . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 495
22.6.4 RTC_SetDatetime . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 495
22.6.5 RTC_GetDatetime . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 495
22.6.6 RTC_SetAlarm . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 496
22.6.7 RTC_GetAlarm . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 496
22.6.8 RTC_EnableInterrupts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 496
22.6.9 RTC_DisableInterrupts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 497
22.6.10 RTC_GetEnabledInterrupts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 497
22.6.11 RTC_GetStatusFlags . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 497
22.6.12 RTC_ClearStatusFlags . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 497
22.6.13 RTC_SetClockSource . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 498
22.6.14 RTC_StartTimer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 498
22.6.15 RTC_StopTimer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 498
22.6.16 RTC_SetOscCapLoad . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 498
22.6.17 RTC_Reset . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 499
22.6.18 RTC_EnableWakeUpPin . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 499

Chapter SAI: Serial Audio Interface

23.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 501

23.2 Typical use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 501


23.2.1 SAI Send/receive using an interrupt method . . . . . . . . . . . . . . . . . . . . 501
23.2.2 SAI Send/receive using a DMA method . . . . . . . . . . . . . . . . . . . . . . . 501

23.3 SAI Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 502


23.3.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 502
23.3.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 510
23.3.3 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 514
23.3.4 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . 514
23.3.5 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 518

23.4 SAI DMA Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 547


23.4.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 547
23.4.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 548

MCUXpresso SDK API Reference Manual


NXP Semiconductors xvii
Section
Contents Page
Number Title Number

23.4.3 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 549

23.5 SAI EDMA Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 555


23.5.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 555
23.5.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 556
23.5.3 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 557

23.6 SAI SDMA Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 565


23.6.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 565
23.6.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 566
23.6.3 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 567

Chapter SIM: System Integration Module Driver

24.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 573

24.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 574


24.2.1 struct sim_uid_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 574

24.3 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 574


24.3.1 _sim_usb_volt_reg_enable_mode . . . . . . . . . . . . . . . . . . . . . . . . . . 574
24.3.2 _sim_flash_mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 574

24.4 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 574


24.4.1 SIM_SetUsbVoltRegulatorEnableMode . . . . . . . . . . . . . . . . . . . . . . . 574
24.4.2 SIM_GetUniqueId . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 576
24.4.3 SIM_SetFlashMode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 576

Chapter SLCD: Segment LCD Driver

25.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 577

25.2 Typical use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 577


25.2.1 SLCD Initialization operation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 577

25.3 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 581


25.3.1 struct slcd_fault_detect_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . 581
25.3.2 struct slcd_clock_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 582
25.3.3 struct slcd_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 583

25.4 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . 584


25.4.1 FSL_SLCD_DRIVER_VERSION . . . . . . . . . . . . . . . . . . . . . . . . . 584

25.5 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 584


25.5.1 slcd_power_supply_option_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . 584
25.5.2 slcd_regulated_voltage_trim_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . 585

MCUXpresso SDK API Reference Manual


xviii NXP Semiconductors
Section
Contents Page
Number Title Number

25.5.3 slcd_load_adjust_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 585


25.5.4 slcd_clock_src_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 586
25.5.5 slcd_alt_clock_div_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 586
25.5.6 slcd_clock_prescaler_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 586
25.5.7 slcd_duty_cycle_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 587
25.5.8 slcd_phase_type_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 587
25.5.9 slcd_phase_index_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 587
25.5.10 slcd_display_mode_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 588
25.5.11 slcd_blink_mode_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 588
25.5.12 slcd_blink_rate_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 588
25.5.13 slcd_fault_detect_clock_prescaler_t . . . . . . . . . . . . . . . . . . . . . . . . . 588
25.5.14 slcd_fault_detect_sample_window_width_t . . . . . . . . . . . . . . . . . . . . . 589
25.5.15 slcd_interrupt_enable_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 589
25.5.16 slcd_lowpower_behavior . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 589

25.6 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 589


25.6.1 SLCD_Init . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 589
25.6.2 SLCD_Deinit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 590
25.6.3 SLCD_GetDefaultConfig . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 590
25.6.4 SLCD_StartDisplay . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 590
25.6.5 SLCD_StopDisplay . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 591
25.6.6 SLCD_StartBlinkMode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 591
25.6.7 SLCD_StopBlinkMode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 591
25.6.8 SLCD_SetBackPlanePhase . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 591
25.6.9 SLCD_SetFrontPlaneSegments . . . . . . . . . . . . . . . . . . . . . . . . . . . 592
25.6.10 SLCD_SetFrontPlaneOnePhase . . . . . . . . . . . . . . . . . . . . . . . . . . . 592
25.6.11 SLCD_EnablePadSafeState . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 593
25.6.12 SLCD_GetFaultDetectCounter . . . . . . . . . . . . . . . . . . . . . . . . . . . 593
25.6.13 SLCD_EnableInterrupts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 593
25.6.14 SLCD_DisableInterrupts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 594
25.6.15 SLCD_GetInterruptStatus . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 594
25.6.16 SLCD_ClearInterruptStatus . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 594

Chapter SMC: System Mode Controller Driver

26.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 597

26.2 Typical use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 597


26.2.1 Enter wait or stop modes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 597

26.3 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 599


26.3.1 struct smc_power_mode_vlls_config_t . . . . . . . . . . . . . . . . . . . . . . . 599

26.4 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . 600


26.4.1 FSL_SMC_DRIVER_VERSION . . . . . . . . . . . . . . . . . . . . . . . . . . 600

MCUXpresso SDK API Reference Manual


NXP Semiconductors xix
Section
Contents Page
Number Title Number

26.5 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 600


26.5.1 smc_power_mode_protection_t . . . . . . . . . . . . . . . . . . . . . . . . . . . 600
26.5.2 smc_power_state_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 600
26.5.3 smc_run_mode_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 600
26.5.4 smc_stop_mode_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 600
26.5.5 smc_stop_submode_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 601
26.5.6 smc_partial_stop_option_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 601
26.5.7 _smc_status . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 601

26.6 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 601


26.6.1 SMC_SetPowerModeProtection . . . . . . . . . . . . . . . . . . . . . . . . . . . 601
26.6.2 SMC_GetPowerModeState . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 602
26.6.3 SMC_PreEnterStopModes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 602
26.6.4 SMC_PostExitStopModes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 602
26.6.5 SMC_PreEnterWaitModes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 602
26.6.6 SMC_PostExitWaitModes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 602
26.6.7 SMC_SetPowerModeRun . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 603
26.6.8 SMC_SetPowerModeWait . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 604
26.6.9 SMC_SetPowerModeStop . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 604
26.6.10 SMC_SetPowerModeVlpr . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 604
26.6.11 SMC_SetPowerModeVlpw . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 605
26.6.12 SMC_SetPowerModeVlps . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 605
26.6.13 SMC_SetPowerModeLls . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 605
26.6.14 SMC_SetPowerModeVlls . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 605

Chapter SPI: Serial Peripheral Interface Driver

27.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 607

27.2 SPI Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 608


27.2.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 608
27.2.2 Typical use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 608
27.2.3 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 613
27.2.4 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 615
27.2.5 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . 615
27.2.6 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 618
27.2.7 Variable Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 628

27.3 SPI DMA Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 629


27.3.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 629
27.3.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 630
27.3.3 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 630
27.3.4 Typedef Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 630
27.3.5 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 630

MCUXpresso SDK API Reference Manual


xx NXP Semiconductors
Section
Contents Page
Number Title Number

27.4 SPI FreeRTOS driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 634


27.4.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 634
27.4.2 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 634
27.4.3 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 634

Chapter TPM: Timer PWM Module

28.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 637

28.2 Typical use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 638


28.2.1 PWM output . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 638

28.3 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 641


28.3.1 struct tpm_chnl_pwm_signal_param_t . . . . . . . . . . . . . . . . . . . . . . . 641
28.3.2 struct tpm_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 642

28.4 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 642


28.4.1 tpm_chnl_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 642
28.4.2 tpm_pwm_mode_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 643
28.4.3 tpm_pwm_level_select_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 643
28.4.4 tpm_trigger_select_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 643
28.4.5 tpm_trigger_source_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 643
28.4.6 tpm_output_compare_mode_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . 644
28.4.7 tpm_input_capture_edge_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 644
28.4.8 tpm_clock_source_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 644
28.4.9 tpm_clock_prescale_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 644
28.4.10 tpm_interrupt_enable_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 645
28.4.11 tpm_status_flags_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 645

28.5 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 645


28.5.1 TPM_Init . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 645
28.5.2 TPM_Deinit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 646
28.5.3 TPM_GetDefaultConfig . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 646
28.5.4 TPM_SetupPwm . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 646
28.5.5 TPM_UpdatePwmDutycycle . . . . . . . . . . . . . . . . . . . . . . . . . . . . 647
28.5.6 TPM_UpdateChnlEdgeLevelSelect . . . . . . . . . . . . . . . . . . . . . . . . . 647
28.5.7 TPM_SetupInputCapture . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 648
28.5.8 TPM_SetupOutputCompare . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 648
28.5.9 TPM_EnableInterrupts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 648
28.5.10 TPM_DisableInterrupts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 649
28.5.11 TPM_GetEnabledInterrupts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 649
28.5.12 TPM_GetStatusFlags . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 649
28.5.13 TPM_ClearStatusFlags . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 649
28.5.14 TPM_SetTimerPeriod . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 650
28.5.15 TPM_GetCurrentTimerCount . . . . . . . . . . . . . . . . . . . . . . . . . . . . 650

MCUXpresso SDK API Reference Manual


NXP Semiconductors xxi
Section
Contents Page
Number Title Number

28.5.16 TPM_StartTimer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 651


28.5.17 TPM_StopTimer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 652

Chapter UART: Universal Asynchronous Receiver/Transmitter Driver

29.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 653

29.2 UART Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 654


29.2.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 654
29.2.2 Typical use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 654
29.2.3 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 659
29.2.4 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 661
29.2.5 Typedef Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 661
29.2.6 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . 661
29.2.7 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 663

29.3 UART DMA Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 678


29.3.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 678
29.3.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 679
29.3.3 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 680
29.3.4 Typedef Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 680
29.3.5 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 680

29.4 UART eDMA Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 684


29.4.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 684
29.4.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 685
29.4.3 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 686
29.4.4 Typedef Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 686
29.4.5 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 686

29.5 UART FreeRTOS Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 690


29.5.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 690
29.5.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 690
29.5.3 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 691
29.5.4 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 691

Chapter VREF: Voltage Reference Driver

30.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 693

30.2 Typical use case and example . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 693

30.3 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 694


30.3.1 struct vref_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 694

30.4 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . 694

MCUXpresso SDK API Reference Manual


xxii NXP Semiconductors
Section
Contents Page
Number Title Number

30.4.1 FSL_VREF_DRIVER_VERSION . . . . . . . . . . . . . . . . . . . . . . . . . 694

30.5 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 694


30.5.1 vref_buffer_mode_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 694

30.6 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 694


30.6.1 VREF_Init . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 694
30.6.2 VREF_Deinit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 695
30.6.3 VREF_GetDefaultConfig . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 695
30.6.4 VREF_SetTrimVal . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 695
30.6.5 VREF_GetTrimVal . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 696

Chapter Clock Driver

31.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 697

31.2 Multipurpose Clock Generator Lite (MCGLITE) . . . . . . . . . . . . . . . . . 698


31.2.1 Function description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 698

Chapter DMA Manager

32.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 699

32.2 Function groups . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 699


32.2.1 DMAMGR Initialization and De-initialization . . . . . . . . . . . . . . . . . . . 699
32.2.2 DMAMGR Operation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 699

32.3 Typical use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 699


32.3.1 DMAMGR static channel allocattion . . . . . . . . . . . . . . . . . . . . . . . . 699
32.3.2 DMAMGR dynamic channel allocation . . . . . . . . . . . . . . . . . . . . . . . 699

32.4 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 700


32.4.1 struct dmamanager_handle_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . 700

32.5 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . 701


32.5.1 DMAMGR_DYNAMIC_ALLOCATE . . . . . . . . . . . . . . . . . . . . . . . 701

32.6 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 701


32.6.1 _dma_manager_status . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 701

32.7 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 701


32.7.1 DMAMGR_Init . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 701
32.7.2 DMAMGR_Deinit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 702
32.7.3 DMAMGR_RequestChannel . . . . . . . . . . . . . . . . . . . . . . . . . . . . 702
32.7.4 DMAMGR_ReleaseChannel . . . . . . . . . . . . . . . . . . . . . . . . . . . . 703
32.7.5 DMAMGR_IsChannelOccupied . . . . . . . . . . . . . . . . . . . . . . . . . . . 704

MCUXpresso SDK API Reference Manual


NXP Semiconductors xxiii
Section
Contents Page
Number Title Number

Chapter Secure Digital Card/Embedded MultiMedia Card/SDIO card

33.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 705

33.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 723


33.2.1 struct sdio_fbr_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 723
33.2.2 struct sdio_common_cis_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 724
33.2.3 struct sdio_func_cis_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 724
33.2.4 struct sd_status_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 725
33.2.5 struct sd_cid_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 726
33.2.6 struct sd_csd_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 726
33.2.7 struct sd_scr_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 727
33.2.8 struct mmc_cid_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 727
33.2.9 struct mmc_csd_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 728
33.2.10 struct mmc_extended_csd_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 729
33.2.11 struct mmc_extended_csd_config_t . . . . . . . . . . . . . . . . . . . . . . . . . 733
33.2.12 struct mmc_boot_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 734

33.3 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . 735


33.3.1 FSL_SDMMC_DRIVER_VERSION . . . . . . . . . . . . . . . . . . . . . . . . 735
33.3.2 SDMMC_LOG . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 735
33.3.3 READ_MMC_TRANSFER_SPEED_FREQUENCY_UNIT . . . . . . . . . . . . 735
33.3.4 READ_MMC_TRANSFER_SPEED_MULTIPLIER . . . . . . . . . . . . . . . 735
33.3.5 MMC_EXTENDED_CSD_BYTES . . . . . . . . . . . . . . . . . . . . . . . . . 735
33.3.6 SD_PRODUCT_NAME_BYTES . . . . . . . . . . . . . . . . . . . . . . . . . . 735
33.3.7 MMC_PRODUCT_NAME_BYTES . . . . . . . . . . . . . . . . . . . . . . . . 735
33.3.8 MMC_SWITCH_COMMAND_SET_SHIFT . . . . . . . . . . . . . . . . . . . . 735
33.3.9 MMC_SWITCH_COMMAND_SET_MASK . . . . . . . . . . . . . . . . . . . 735

33.4 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 735


33.4.1 _sdmmc_status . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 735
33.4.2 sdmmc_operation_voltage_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 736
33.4.3 _sdmmc_r1_card_status_flag . . . . . . . . . . . . . . . . . . . . . . . . . . . . 737
33.4.4 sdmmc_r1_current_state_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 737
33.4.5 _sdspi_r1_error_status_flag . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 738
33.4.6 _sdspi_r2_error_status_flag . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 738
33.4.7 _sdspi_data_error_token . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 738
33.4.8 sdspi_data_token_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 738
33.4.9 sdspi_data_response_token_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . 739
33.4.10 sd_command_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 739
33.4.11 sdspi_command_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 739
33.4.12 sd_application_command_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 739
33.4.13 _sdmmc_command_class . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 740
33.4.14 _sd_ocr_flag . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 740
33.4.15 _sd_specification_version . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 740

MCUXpresso SDK API Reference Manual


xxiv NXP Semiconductors
Section
Contents Page
Number Title Number

33.4.16 sd_data_bus_width_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 741


33.4.17 sd_switch_mode_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 741
33.4.18 _sd_csd_flag . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 741
33.4.19 _sd_scr_flag . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 741
33.4.20 _sd_timing_function . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 741
33.4.21 _sd_group_num . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 742
33.4.22 sd_timing_mode_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 742
33.4.23 sd_driver_strength_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 742
33.4.24 sd_max_current_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 742
33.4.25 sdmmc_command_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 743
33.4.26 _sdio_cccr_reg . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 743
33.4.27 sdio_command_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 744
33.4.28 sdio_func_num_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 744
33.4.29 _sdio_status_flag . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 744
33.4.30 _sdio_ocr_flag . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 745
33.4.31 _sdio_capability_flag . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 745
33.4.32 _sdio_fbr_flag . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 746
33.4.33 sdio_bus_width_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 746
33.4.34 mmc_command_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 746
33.4.35 mmc_classified_voltage_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 746
33.4.36 mmc_classified_density_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 747
33.4.37 mmc_access_mode_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 747
33.4.38 mmc_voltage_window_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 747
33.4.39 mmc_csd_structure_version_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . 747
33.4.40 mmc_specification_version_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . 747
33.4.41 _mmc_extended_csd_revision . . . . . . . . . . . . . . . . . . . . . . . . . . . . 748
33.4.42 mmc_command_set_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 748
33.4.43 _mmc_support_boot_mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 748
33.4.44 mmc_high_speed_timing_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 748
33.4.45 mmc_data_bus_width_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 749
33.4.46 mmc_boot_partition_enable_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . 749
33.4.47 mmc_boot_timing_mode_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 749
33.4.48 mmc_boot_partition_wp_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 749
33.4.49 _mmc_boot_partition_wp_status . . . . . . . . . . . . . . . . . . . . . . . . . . 750
33.4.50 mmc_access_partition_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 750
33.4.51 _mmc_csd_flag . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 750
33.4.52 mmc_extended_csd_access_mode_t . . . . . . . . . . . . . . . . . . . . . . . . . 751
33.4.53 mmc_extended_csd_index_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 751
33.4.54 _mmc_driver_strength . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 751
33.4.55 mmc_extended_csd_flags_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 751
33.4.56 _mmc_boot_mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 752

33.5 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 752


33.5.1 SDMMC_SelectCard . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 752
33.5.2 SDMMC_SendApplicationCommand . . . . . . . . . . . . . . . . . . . . . . . . 752

MCUXpresso SDK API Reference Manual


NXP Semiconductors xxv
Section
Contents Page
Number Title Number

33.5.3 SDMMC_SetBlockCount . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 753


33.5.4 SDMMC_GoIdle . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 753
33.5.5 SDMMC_SetBlockSize . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 754
33.5.6 SDMMC_SetCardInactive . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 754
33.5.7 SDMMC_Delay . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 755
33.5.8 SDMMC_SwitchVoltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 755
33.5.9 SDMMC_SwitchToVoltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 755
33.5.10 SDMMC_ExecuteTuning . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 755

33.6 SDIO Card Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 757


33.6.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 757
33.6.2 SDIO CARD Operation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 757
33.6.3 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 760
33.6.4 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 762
33.6.5 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . 762
33.6.6 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 762
33.6.7 Variable Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 779

33.7 SD Card Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 780


33.7.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 780
33.7.2 SD CARD Operation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 780
33.7.3 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 783
33.7.4 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . 784
33.7.5 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 785

33.8 MMC Card Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 794


33.8.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 794
33.8.2 MMC CARD Operation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 794
33.8.3 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 796
33.8.4 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . 797
33.8.5 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 797

33.9 HOST adapter Driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 809


33.9.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 809
33.9.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 810
33.9.3 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . 812
33.9.4 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 812

Chapter SPI based Secure Digital Card (SDSPI)

34.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 817

34.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 819


34.2.1 struct sdspi_host_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 819
34.2.2 struct sdspi_card_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 819

MCUXpresso SDK API Reference Manual


xxvi NXP Semiconductors
Section
Contents Page
Number Title Number

34.3 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 820


34.3.1 _sdspi_status . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 820
34.3.2 _sdspi_card_flag . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 821
34.3.3 _sdspi_response_type . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 821
34.3.4 _sdspi_cmd . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 821

34.4 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 821


34.4.1 SDSPI_Init . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 821
34.4.2 SDSPI_Deinit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 822
34.4.3 SDSPI_CheckReadOnly . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 822
34.4.4 SDSPI_ReadBlocks . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 823
34.4.5 SDSPI_WriteBlocks . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 823
34.4.6 SDSPI_SendCid . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 824
34.4.7 SDSPI_SendPreErase . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 825
34.4.8 SDSPI_EraseBlocks . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 825
34.4.9 SDSPI_SwitchToHighSpeed . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 826

Chapter Debug Console

35.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 827

35.2 Function groups . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 827


35.2.1 Initialization . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 827
35.2.2 Advanced Feature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 828

35.3 Typical use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 832

35.4 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . 834


35.4.1 DEBUGCONSOLE_REDIRECT_TO_TOOLCHAIN . . . . . . . . . . . . . . . 834
35.4.2 DEBUGCONSOLE_REDIRECT_TO_SDK . . . . . . . . . . . . . . . . . . . . 834
35.4.3 DEBUGCONSOLE_DISABLE . . . . . . . . . . . . . . . . . . . . . . . . . . . 834
35.4.4 SDK_DEBUGCONSOLE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 834
35.4.5 SDK_DEBUGCONSOLE_UART . . . . . . . . . . . . . . . . . . . . . . . . . 834
35.4.6 PRINTF . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 834

35.5 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 834


35.5.1 DbgConsole_Init . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 834
35.5.2 DbgConsole_Deinit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 835
35.5.3 DbgConsole_Printf . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 835
35.5.4 DbgConsole_Putchar . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 836
35.5.5 DbgConsole_Scanf . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 837
35.5.6 DbgConsole_Getchar . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 837
35.5.7 DbgConsole_Flush . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 838
35.5.8 StrFormatPrintf . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 838
35.5.9 StrFormatScanf . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 838

MCUXpresso SDK API Reference Manual


NXP Semiconductors xxvii
Section
Contents Page
Number Title Number

35.6 Semihosting . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 840


35.6.1 Guide Semihosting for IAR . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 840
35.6.2 Guide Semihosting for Keil µVision . . . . . . . . . . . . . . . . . . . . . . . . . 840
35.6.3 Guide Semihosting for MCUXpresso IDE . . . . . . . . . . . . . . . . . . . . . 841
35.6.4 Guide Semihosting for ARMGCC . . . . . . . . . . . . . . . . . . . . . . . . . . 841

35.7 SWO . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 844


35.7.1 Guide SWO for SDK . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 844
35.7.2 Guide SWO for Keil µVision . . . . . . . . . . . . . . . . . . . . . . . . . . . . 845
35.7.3 Guide SWO for MCUXpresso IDE . . . . . . . . . . . . . . . . . . . . . . . . . 846
35.7.4 Guide SWO for ARMGCC . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 846

Chapter Notification Framework

36.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 847

36.2 Notifier Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 847

36.3 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 849


36.3.1 struct notifier_notification_block_t . . . . . . . . . . . . . . . . . . . . . . . . . 849
36.3.2 struct notifier_callback_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . 850
36.3.3 struct notifier_handle_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 850

36.4 Typedef Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 851


36.4.1 notifier_user_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 851
36.4.2 notifier_user_function_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 851
36.4.3 notifier_callback_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 852

36.5 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 852


36.5.1 _notifier_status . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 852
36.5.2 notifier_policy_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 853
36.5.3 notifier_notification_type_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 853
36.5.4 notifier_callback_type_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 853

36.6 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 854


36.6.1 NOTIFIER_CreateHandle . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 854
36.6.2 NOTIFIER_SwitchConfig . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 855
36.6.3 NOTIFIER_GetErrorCallbackIndex . . . . . . . . . . . . . . . . . . . . . . . . . 856

Chapter Shell

37.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 857

37.2 Function groups . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 857


37.2.1 Initialization . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 857
37.2.2 Advanced Feature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 857

MCUXpresso SDK API Reference Manual


xxviii NXP Semiconductors
Section
Contents Page
Number Title Number

37.2.3 Shell Operation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 858

37.3 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 859


37.3.1 struct shell_command_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 859

37.4 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . 860


37.4.1 SHELL_NON_BLOCKING_MODE . . . . . . . . . . . . . . . . . . . . . . . . 860
37.4.2 SHELL_AUTO_COMPLETE . . . . . . . . . . . . . . . . . . . . . . . . . . . . 860
37.4.3 SHELL_BUFFER_SIZE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 860
37.4.4 SHELL_MAX_ARGS . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 860
37.4.5 SHELL_HISTORY_COUNT . . . . . . . . . . . . . . . . . . . . . . . . . . . . 860
37.4.6 SHELL_HANDLE_SIZE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 860
37.4.7 SHELL_COMMAND_DEFINE . . . . . . . . . . . . . . . . . . . . . . . . . . . 860
37.4.8 SHELL_COMMAND . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 861

37.5 Typedef Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 861


37.5.1 cmd_function_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 861

37.6 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 861


37.6.1 shell_status_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 861

37.7 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 861


37.7.1 SHELL_Init . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 861
37.7.2 SHELL_RegisterCommand . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 862
37.7.3 SHELL_UnregisterCommand . . . . . . . . . . . . . . . . . . . . . . . . . . . . 863
37.7.4 SHELL_Write . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 863
37.7.5 SHELL_Printf . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 863
37.7.6 SHELL_Task . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 864

Chapter OSA_Adapter: Operatin System Abstraction Adapter

38.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 865

38.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 867


38.2.1 struct osa_task_def_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 867
38.2.2 struct osa_thread_link_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 868
38.2.3 struct osa_time_def_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 868

38.3 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . 868


38.3.1 USE_RTOS . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 868
38.3.2 osaWaitForever_c . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 868

38.4 Typedef Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 868


38.4.1 osa_task_priority_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 868
38.4.2 osa_task_ptr_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 869
38.4.3 osa_event_flags_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 869

MCUXpresso SDK API Reference Manual


NXP Semiconductors xxix
Section
Contents Page
Number Title Number

38.4.4 osa_msg_handle_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 869


38.4.5 osa_timer_fct_ptr_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 869

38.5 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 869


38.5.1 osa_timer_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 869
38.5.2 osa_status_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 869

38.6 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 869


38.6.1 OSA_TaskCreate . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 869
38.6.2 OSA_TaskGetCurrentHandle . . . . . . . . . . . . . . . . . . . . . . . . . . . . 870
38.6.3 OSA_TaskYield . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 870
38.6.4 OSA_TaskGetPriority . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 870
38.6.5 OSA_TaskSetPriority . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 871
38.6.6 OSA_TaskDestroy . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 872
38.6.7 OSA_SemaphoreCreate . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 872
38.6.8 OSA_SemaphoreDestroy . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 873
38.6.9 OSA_SemaphoreWait . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 873
38.6.10 OSA_SemaphorePost . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 874
38.6.11 OSA_MutexCreate . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 875
38.6.12 OSA_MutexLock . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 875
38.6.13 OSA_MutexUnlock . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 876
38.6.14 OSA_MutexDestroy . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 876
38.6.15 OSA_EventCreate . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 876
38.6.16 OSA_EventSet . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 877
38.6.17 OSA_EventClear . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 877
38.6.18 OSA_EventWait . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 878
38.6.19 OSA_EventDestroy . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 878
38.6.20 OSA_MsgQCreate . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 879
38.6.21 OSA_MsgQPut . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 879
38.6.22 OSA_MsgQGet . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 880
38.6.23 OSA_MsgQDestroy . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 880
38.6.24 OSA_TimeDelay . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 880
38.6.25 OSA_TimeGetMsec . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 881
38.6.26 OSA_InstallIntHandler . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 881

38.7 OSA BM . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 882


38.7.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 882
38.7.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 883
38.7.3 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 885
38.7.4 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 886

38.8 OSA FreeRTOS . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 887


38.8.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 887
38.8.2 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 888
38.8.3 Typedef Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 889

MCUXpresso SDK API Reference Manual


xxx NXP Semiconductors
Section
Contents Page
Number Title Number

Chapter Serial Manager

39.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 891

39.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 893


39.2.1 struct serial_manager_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . 893
39.2.2 struct serial_manager_callback_message_t . . . . . . . . . . . . . . . . . . . . . 893

39.3 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 893


39.3.1 serial_port_type_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 893
39.3.2 serial_manager_status_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 893

39.4 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 894


39.4.1 SerialManager_Init . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 894
39.4.2 SerialManager_Deinit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 895
39.4.3 SerialManager_OpenWriteHandle . . . . . . . . . . . . . . . . . . . . . . . . . . 895
39.4.4 SerialManager_CloseWriteHandle . . . . . . . . . . . . . . . . . . . . . . . . . 896
39.4.5 SerialManager_OpenReadHandle . . . . . . . . . . . . . . . . . . . . . . . . . . 897
39.4.6 SerialManager_CloseReadHandle . . . . . . . . . . . . . . . . . . . . . . . . . . 897
39.4.7 SerialManager_WriteBlocking . . . . . . . . . . . . . . . . . . . . . . . . . . . 898
39.4.8 SerialManager_ReadBlocking . . . . . . . . . . . . . . . . . . . . . . . . . . . . 899
39.4.9 SerialManager_EnterLowpower . . . . . . . . . . . . . . . . . . . . . . . . . . . 899
39.4.10 SerialManager_ExitLowpower . . . . . . . . . . . . . . . . . . . . . . . . . . . 900

39.5 Serial Port Uart . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 901


39.5.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 901
39.5.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 901
39.5.3 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . 902

39.6 Serial Port USB . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 903


39.6.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 903
39.6.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 904
39.6.3 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . 904
39.6.4 USB Device Configuration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 905

39.7 Serial Port SWO . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 907


39.7.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 907
39.7.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 907
39.7.3 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . 907

39.8 Serial Port Virtual USB . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 908


39.8.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 908
39.8.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 909
39.8.3 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . 909

MCUXpresso SDK API Reference Manual


NXP Semiconductors xxxi
Section
Contents Page
Number Title Number

Chapter Button

40.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 911

40.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 912


40.2.1 struct button_callback_message_t . . . . . . . . . . . . . . . . . . . . . . . . . . 912
40.2.2 struct button_gpio_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 912
40.2.3 struct button_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 913

40.3 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . 913


40.3.1 BUTTON_HANDLE_SIZE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 913
40.3.2 BUTTON_TIMER_INTERVAL . . . . . . . . . . . . . . . . . . . . . . . . . . 913
40.3.3 BUTTON_SHORT_PRESS_THRESHOLD . . . . . . . . . . . . . . . . . . . . 913
40.3.4 BUTTON_LONG_PRESS_THRESHOLD . . . . . . . . . . . . . . . . . . . . . 913
40.3.5 BUTTON_DOUBLE_CLICK_THRESHOLD . . . . . . . . . . . . . . . . . . . 913
40.3.6 BUTTON_USE_COMMON_TASK . . . . . . . . . . . . . . . . . . . . . . . . 913
40.3.7 BUTTON_TASK_PRIORITY . . . . . . . . . . . . . . . . . . . . . . . . . . . 913
40.3.8 BUTTON_TASK_STACK_SIZE . . . . . . . . . . . . . . . . . . . . . . . . . . 913
40.3.9 BUTTON_EVENT_BUTTON . . . . . . . . . . . . . . . . . . . . . . . . . . . 913

40.4 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 913


40.4.1 button_status_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 913
40.4.2 button_event_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 913

40.5 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 914


40.5.1 BUTTON_Init . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 914
40.5.2 BUTTON_InstallCallback . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 915
40.5.3 BUTTON_Deinit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 915
40.5.4 BUTTON_WakeUpSetting . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 915
40.5.5 BUTTON_EnterLowpower . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 916
40.5.6 BUTTON_ExitLowpower . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 916

Chapter GPIO_Adapter

41.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 917

41.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 918


41.2.1 struct hal_gpio_pin_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . 918

41.3 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . 918


41.3.1 HAL_GPIO_HANDLE_SIZE . . . . . . . . . . . . . . . . . . . . . . . . . . . . 918
41.3.2 HAL_GPIO_HANDLE_ISR_PRIORITY . . . . . . . . . . . . . . . . . . . . . . 918

41.4 Typedef Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 918


41.4.1 hal_gpio_handle_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 918
41.4.2 hal_gpio_callback_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 918

MCUXpresso SDK API Reference Manual


xxxii NXP Semiconductors
Section
Contents Page
Number Title Number

41.5 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 919


41.5.1 hal_gpio_interrupt_trigger_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 919
41.5.2 hal_gpio_status_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 919
41.5.3 hal_gpio_direction_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 919

41.6 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 919


41.6.1 HAL_GpioInit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 919
41.6.2 HAL_GpioDeinit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 920
41.6.3 HAL_GpioGetInput . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 920
41.6.4 HAL_GpioSetOutput . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 921
41.6.5 HAL_GpioGetTriggerMode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 921
41.6.6 HAL_GpioSetTriggerMode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 922
41.6.7 HAL_GpioInstallCallback . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 922
41.6.8 HAL_GpioWakeUpSetting . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 923
41.6.9 HAL_GpioEnterLowpower . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 924
41.6.10 HAL_GpioExitLowpower . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 924

Chapter LED

42.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 925

42.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 927


42.2.1 struct led_pin_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 927
42.2.2 struct led_rgb_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 927
42.2.3 struct led_monochrome_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . 927
42.2.4 struct led_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 928
42.2.5 struct led_flash_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 928

42.3 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . 928


42.3.1 LED_DIMMING_ENABLEMENT . . . . . . . . . . . . . . . . . . . . . . . . . 928
42.3.2 LED_HANDLE_SIZE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 928
42.3.3 LED_TIMER_INTERVAL . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 928
42.3.4 LED_DIMMING_UPDATE_INTERVAL . . . . . . . . . . . . . . . . . . . . . 928
42.3.5 LED_FLASH_CYCLE_FOREVER . . . . . . . . . . . . . . . . . . . . . . . . . 928
42.3.6 LED_BLIP_INTERVAL . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 928
42.3.7 LED_MAKE_COLOR . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 928

42.4 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 929


42.4.1 led_status_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 929
42.4.2 led_flash_type_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 929
42.4.3 _led_color . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 929
42.4.4 led_type_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 929

42.5 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 929


42.5.1 LED_Init . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 929

MCUXpresso SDK API Reference Manual


NXP Semiconductors xxxiii
Section
Contents Page
Number Title Number

42.5.2 LED_Deinit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 931


42.5.3 LED_SetColor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 931
42.5.4 LED_TurnOnOff . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 932
42.5.5 LED_Blip . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 932
42.5.6 LED_Flash . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 932
42.5.7 LED_Dimming . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 933
42.5.8 LED_EnterLowpower . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 933
42.5.9 LED_ExitLowpower . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 934

Chapter GenericList

43.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 935

43.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 936


43.2.1 struct list_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 936
43.2.2 struct list_element_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 936

43.3 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 936


43.3.1 list_status_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 936

43.4 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 937


43.4.1 LIST_Init . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 937
43.4.2 LIST_GetList . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 937
43.4.3 LIST_AddHead . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 937
43.4.4 LIST_AddTail . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 937
43.4.5 LIST_RemoveHead . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 938
43.4.6 LIST_GetHead . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 938
43.4.7 LIST_GetNext . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 938
43.4.8 LIST_GetPrev . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 939
43.4.9 LIST_RemoveElement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 939
43.4.10 LIST_AddPrevElement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 939
43.4.11 LIST_GetSize . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 940
43.4.12 LIST_GetAvailableSize . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 940

Chapter Panic

44.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 941

44.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 941


44.2.1 struct panic_data_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 941

44.3 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . 941


44.3.1 PANIC_ENABLE_LOG . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 941

44.4 Typedef Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 941


44.4.1 panic_id_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 941

MCUXpresso SDK API Reference Manual


xxxiv NXP Semiconductors
Section
Contents Page
Number Title Number

44.5 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 942


44.5.1 panic . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 942

Chapter Timer_Adapter

45.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 943

45.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 944


45.2.1 struct hal_timer_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 944

45.3 Typedef Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 944


45.3.1 hal_timer_callback_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 944
45.3.2 hal_timer_handle_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 945

45.4 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 945


45.4.1 hal_timer_status_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 945

45.5 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 945


45.5.1 HAL_TimerInit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 945
45.5.2 HAL_TimerDeinit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 946
45.5.3 HAL_TimerEnable . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 946
45.5.4 HAL_TimerDisable . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 946
45.5.5 HAL_TimerInstallCallback . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 946
45.5.6 HAL_TimerGetCurrentTimerCount . . . . . . . . . . . . . . . . . . . . . . . . . 947
45.5.7 HAL_TimerUpdateTimeout . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 947
45.5.8 HAL_TimerGetMaxTimeout . . . . . . . . . . . . . . . . . . . . . . . . . . . . 948
45.5.9 HAL_TimerExitLowpower . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 948
45.5.10 HAL_TimerEnterLowpower . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 948

Chapter Manager

46.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 951

46.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 952


46.2.1 struct timer_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 952

46.3 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . 953


46.3.1 TM_COMMON_TASK_ENABLE . . . . . . . . . . . . . . . . . . . . . . . . . 953

46.4 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 953


46.4.1 timer_status_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 953
46.4.2 timer_mode_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 953

46.5 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 953


46.5.1 TM_Init . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 953
46.5.2 TM_Open . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 954

MCUXpresso SDK API Reference Manual


NXP Semiconductors xxxv
Section
Contents Page
Number Title Number

46.5.3 TM_Close . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 954


46.5.4 TM_InstallCallback . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 954
46.5.5 TM_Start . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 955
46.5.6 TM_Stop . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 955
46.5.7 TM_IsTimerActive . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 956
46.5.8 TM_IsTimerReady . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 956
46.5.9 TM_GetRemainingTime . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 956
46.5.10 TM_GetFirstExpireTime . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 956
46.5.11 TM_GetFirstTimerWithParam . . . . . . . . . . . . . . . . . . . . . . . . . . . . 957
46.5.12 TM_AreAllTimersOff . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 957
46.5.13 TM_NotCountedTimeBeforeSleep . . . . . . . . . . . . . . . . . . . . . . . . . 957
46.5.14 TM_SyncLpmTimers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 957
46.5.15 TM_MakeTimerTaskReady . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 958

Chapter UART_Adapter

47.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 959

47.2 Data Structure Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 960


47.2.1 struct hal_uart_config_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 960
47.2.2 struct hal_uart_transfer_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 960

47.3 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . 961


47.3.1 HAL_UART_TRANSFER_MODE . . . . . . . . . . . . . . . . . . . . . . . . . 961

47.4 Typedef Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 961


47.4.1 hal_uart_transfer_callback_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 961

47.5 Enumeration Type Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . 961


47.5.1 hal_uart_status_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 961
47.5.2 hal_uart_parity_mode_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 961
47.5.3 hal_uart_stop_bit_count_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 962

47.6 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 962


47.6.1 HAL_UartInit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 962
47.6.2 HAL_UartDeinit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 962
47.6.3 HAL_UartReceiveBlocking . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 963
47.6.4 HAL_UartSendBlocking . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 963

MCUXpresso SDK API Reference Manual


xxxvi NXP Semiconductors
Chapter 1
Introduction
The MCUXpresso Software Development Kit (MCUXpresso SDK) is a collection of software enable-
ment for NXP Microcontrollers that includes peripheral drivers, multicore support and integrated RTOS
support for FreeRTOSTM . In addition to the base enablement, the MCUXpresso SDK is augmented
with demo applications, driver example projects, and API documentation to help users quickly leverage
the support provided by MCUXpresso SDK. The MCUXpresso SDK Web Builder is available to
provide access to all MCUXpresso SDK packages. See the MCUXpresso Software Development Kit (SD-
K) Release Notes (document MCUXSDKRN) in the Supported Devices section at MCUXpresso-SDK:
Software Development Kit for MCUXpresso for details.
The MCUXpresso SDK is built with the following runtime software components:
• Arm® and DSP standard libraries, and CMSIS-compliant device header files which provide direct
access to the peripheral registers.
• Peripheral drivers that provide stateless, high-performance, ease-of-use APIs. Communication
drivers provide higher-level transactional APIs for a higher-performance option.
• RTOS wrapper driver built on top of MCUXpresso SDK peripheral drivers and leverage native RT-
OS services to better comply to the RTOS cases.
• Real time operation systems (RTOS) for FreeRTOS OS.
• Stacks and middleware in source or object formats including:
– CMSIS-DSP, a suite of common signal processing functions.
– The MCUXpresso SDK comes complete with software examples demonstrating the usage of
the peripheral drivers, RTOS wrapper drivers, middleware, and RTOSes.
All demo applications and driver examples are provided with projects for the following toolchains:
– IAR Embedded Workbench
– GNU Arm Embedded Toolchain
The peripheral drivers and RTOS driver wrappers can be used across multiple devices within the product
family without modification. The configuration items for each driver are encapsulated into C language
data structures. Device-specific configuration information is provided as part of the MCUXpresso SDK
and need not be modified by the user. If necessary, the user is able to modify the peripheral driver and
RTOS wrapper driver configuration during runtime. The driver examples demonstrate how to configure
the drivers by passing the proper configuration data to the APIs. The folder structure is organized to reduce
the total number of includes required to compile a project.
The rest of this document describes the API references in detail for the peripheral drivers and RT-
OS wrapper drivers. For the latest version of this and other MCUXpresso SDK documents, see the
mcuxpresso.nxp.com/apidoc/.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 1
Deliverable Location
Demo Applications <install_dir>/boards/<board_name>/demo_-
apps
Driver Examples <install_dir>/boards/<board_name>/driver_-
examples
Documentation <install_dir>/docs
Middleware <install_dir>/middleware
Drivers <install_dir>/<device_name>/drivers/
CMSIS Standard Arm Cortex-M Headers, math <install_dir>/CMSIS
and DSP Libraries
Device Startup and Linker <install_dir>/<device_name>/<toolchain>/
MCUXpresso SDK Utilities <install_dir>/devices/<device_name>/utilities
RTOS Kernel Code <install_dir>/rtos

Table 2: MCUXpresso SDK Folder Structure

MCUXpresso SDK API Reference Manual


2 NXP Semiconductors
Chapter 2
Driver errors status
• #kStatus_DMA_Busy = 5000
• kStatus_FLEXIO_CAMERA_RxBusy = 5500
• kStatus_FLEXIO_CAMERA_RxIdle = 5501
• kStatus_FLEXIO_I2C_Busy = 800
• kStatus_FLEXIO_I2C_Idle = 801
• kStatus_FLEXIO_I2C_Nak = 802
• kStatus_FLEXIO_I2S_Idle = 2300
• kStatus_FLEXIO_I2S_TxBusy = 2301
• kStatus_FLEXIO_I2S_RxBusy = 2302
• kStatus_FLEXIO_I2S_Error = 2303
• kStatus_FLEXIO_I2S_QueueFull = 2304
• kStatus_FLEXIO_MCULCD_Idle = 2400
• kStatus_FLEXIO_MCULCD_Busy = 2401
• kStatus_FLEXIO_MCULCD_Error = 2302
• kStatus_FLEXIO_SPI_Busy = 501
• kStatus_FLEXIO_SPI_Idle = 502
• kStatus_FLEXIO_SPI_Error = 503
• kStatus_FLEXIO_UART_TxBusy = 700
• kStatus_FLEXIO_UART_RxBusy = 701
• kStatus_FLEXIO_UART_TxIdle = 702
• kStatus_FLEXIO_UART_RxIdle = 703
• kStatus_FLEXIO_UART_ERROR = 704
• kStatus_FLEXIO_UART_RxRingBufferOverrun = 705
• kStatus_FLEXIO_UART_RxHardwareOverrun = 706
• kStatus_I2C_Busy = 1100
• kStatus_I2C_Idle = 1101
• kStatus_I2C_Nak = 1102
• kStatus_I2C_ArbitrationLost = 1103
• kStatus_I2C_Timeout = 1104
• kStatus_I2C_Addr_Nak = 1105
• kStatus_LPUART_TxBusy = 1300
• kStatus_LPUART_RxBusy = 1301
• kStatus_LPUART_TxIdle = 1302
• kStatus_LPUART_RxIdle = 1303
• kStatus_LPUART_TxWatermarkTooLarge = 1304
• kStatus_LPUART_RxWatermarkTooLarge = 1305
• kStatus_LPUART_FlagCannotClearManually = 1306
• kStatus_LPUART_Error = 1307

MCUXpresso SDK API Reference Manual


NXP Semiconductors 3
• kStatus_LPUART_RxRingBufferOverrun = 1308
• kStatus_LPUART_RxHardwareOverrun = 1309
• kStatus_LPUART_NoiseError = 1310
• kStatus_LPUART_FramingError = 1311
• kStatus_LPUART_ParityError = 1312
• kStatus_LPUART_BaudrateNotSupport = 1313
• kStatus_LPUART_IdleLineDetected = 1314
• kStatus_SAI_TxBusy = 1900
• kStatus_SAI_RxBusy = 1901
• kStatus_SAI_TxError = 1902
• kStatus_SAI_RxError = 1903
• kStatus_SAI_QueueFull = 1904
• kStatus_SAI_TxIdle = 1905
• kStatus_SAI_RxIdle = 1906
• kStatus_SMC_StopAbort = 3900
• kStatus_SPI_Busy = 1400
• kStatus_SPI_Idle = 1401
• kStatus_SPI_Error = 1402
• kStatus_UART_TxBusy = 1000
• kStatus_UART_RxBusy = 1001
• kStatus_UART_TxIdle = 1002
• kStatus_UART_RxIdle = 1003
• kStatus_UART_TxWatermarkTooLarge = 1004
• kStatus_UART_RxWatermarkTooLarge = 1005
• kStatus_UART_FlagCannotClearManually = 1006
• kStatus_UART_Error = 1007
• kStatus_UART_RxRingBufferOverrun = 1008
• kStatus_UART_RxHardwareOverrun = 1009
• kStatus_UART_NoiseError = 1010
• kStatus_UART_FramingError = 1011
• kStatus_UART_ParityError = 1012
• kStatus_UART_BaudrateNotSupport = 1013
• kStatus_UART_IdleLineDetected = 1014
• kStatus_DMAMGR_ChannelOccupied = 5200
• kStatus_DMAMGR_ChannelNotUsed = 5201
• kStatus_DMAMGR_NoFreeChannel = 5202
• kStatus_NOTIFIER_ErrorNotificationBefore = 9800
• kStatus_NOTIFIER_ErrorNotificationAfter = 9801

MCUXpresso SDK API Reference Manual


4 NXP Semiconductors
Chapter 3
Architectural Overview
This chapter provides the architectural overview for the MCUXpresso Software Development Kit (MCU-
Xpresso SDK). It describes each layer within the architecture and its associated components.
Overview
The MCUXpresso SDK architecture consists of five key components listed below.
1. The Arm Cortex Microcontroller Software Interface Standard (CMSIS) CORE compliance device-
specific header files, SOC Header, and CMSIS math/DSP libraries.
2. Peripheral Drivers
3. Real-time Operating Systems (RTOS)
4. Stacks and Middleware that integrate with the MCUXpresso SDK
5. Demo Applications based on the MCUXpresso SDK

Figure 1: MCUXpresso SDK Block Diagram

MCU header files


Each supported MCU device in the MCUXpresso SDK has an overall System-on Chip (SoC) memory-

MCUXpresso SDK API Reference Manual


NXP Semiconductors 5
mapped header file. This header file contains the memory map and register base address for each peripheral
and the IRQ vector table with associated vector numbers. The overall SoC header file provides access to
the peripheral registers through pointers and predefined bit masks. In addition to the overall SoC memory-
mapped header file, the MCUXpresso SDK includes a feature header file for each device. The feature
header file allows NXP to deliver a single software driver for a given peripheral. The feature file ensures
that the driver is properly compiled for the target SOC.
CMSIS Support
Along with the SoC header files and peripheral extension header files, the MCUXpresso SDK also includes
common CMSIS header files for the Arm Cortex-M core and the math and DSP libraries from the latest
CMSIS release. The CMSIS DSP library source code is also included for reference.
MCUXpresso SDK Peripheral Drivers
The MCUXpresso SDK peripheral drivers mainly consist of low-level functional APIs for the MCU
product family on-chip peripherals and also of high-level transactional APIs for some bus drivers/DM-
A driver/eDMA driver to quickly enable the peripherals and perform transfers.
All MCUXpresso SDK peripheral drivers only depend on the CMSIS headers, device feature files, fsl_-
common.h, and fsl_clock.h files so that users can easily pull selected drivers and their dependencies into
projects. With the exception of the clock/power-relevant peripherals, each peripheral has its own driver.
Peripheral drivers handle the peripheral clock gating/ungating inside the drivers during initialization and
deinitialization respectively.
Low-level functional APIs provide common peripheral functionality, abstracting the hardware peripheral
register accesses into a set of stateless basic functional operations. These APIs primarily focus on the
control, configuration, and function of basic peripheral operations. The APIs hide the register access
details and various MCU peripheral instantiation differences so that the application can be abstracted from
the low-level hardware details. The API prototypes are intentionally similar to help ensure easy portability
across supported MCUXpresso SDK devices.
Transactional APIs provide a quick method for customers to utilize higher-level functionality of the pe-
ripherals. The transactional APIs utilize interrupts and perform asynchronous operations without user
intervention. Transactional APIs operate on high-level logic that requires data storage for internal oper-
ation context handling. However, the Peripheral Drivers do not allocate this memory space. Rather, the
user passes in the memory to the driver for internal driver operation. Transactional APIs ensure the NVIC
is enabled properly inside the drivers. The transactional APIs do not meet all customer needs, but provide
a baseline for development of custom user APIs.
Note that the transactional drivers never disable an NVIC after use. This is due to the shared nature of
interrupt vectors on devices. It is up to the user to ensure that NVIC interrupts are properly disabled after
usage is complete.
Interrupt handling for transactional APIs
A double weak mechanism is introduced for drivers with transactional API. The double weak indicates
two levels of weak vector entries. See the examples below:

PUBWEAK SPI0_IRQHandler
PUBWEAK SPI0_DriverIRQHandler
SPI0_IRQHandler

MCUXpresso SDK API Reference Manual


6 NXP Semiconductors
LDR R0, =SPI0_DriverIRQHandler
BX R0

The first level of the weak implementation are the functions defined in the vector table. In the devices/<-
DEVICE_NAME>/<TOOLCHAIN>/startup_<DEVICE_NAME>.s/.S file, the implementation of the
first layer weak function calls the second layer of weak function. The implementation of the second
layer weak function (ex. SPI0_DriverIRQHandler) jumps to itself (B). The MCUXpresso SDK drivers
with transactional APIs provide the reimplementation of the second layer function inside of the peripheral
driver. If the MCUXpresso SDK drivers with transactional APIs are linked into the image, the SPI0_-
DriverIRQHandler is replaced with the function implemented in the MCUXpresso SDK SPI driver.
The reason for implementing the double weak functions is to provide a better user experience when using
the transactional APIs. For drivers with a transactional function, call the transactional APIs and the drivers
complete the interrupt-driven flow. Users are not required to redefine the vector entries out of the box. At
the same time, if users are not satisfied by the second layer weak function implemented in the MCU-
Xpresso SDK drivers, users can redefine the first layer weak function and implement their own interrupt
handler functions to suit their implementation.
The limitation of the double weak mechanism is that it cannot be used for peripherals that share the same
vector entry. For this use case, redefine the first layer weak function to enable the desired peripheral
interrupt functionality. For example, if the MCU’s UART0 and UART1 share the same vector entry,
redefine the UART0_UART1_IRQHandler according to the use case requirements.
Feature Header Files
The peripheral drivers are designed to be reusable regardless of the peripheral functional differences from
one MCU device to another. An overall Peripheral Feature Header File is provided for the MCUXpresso
SDK-supported MCU device to define the features or configuration differences for each sub-family device.
Application
See the Getting Started with MCUXpresso SDK document (MCUXSDKGSUG).

MCUXpresso SDK API Reference Manual


NXP Semiconductors 7
MCUXpresso SDK API Reference Manual
8 NXP Semiconductors
Chapter 4
Trademarks
Information in this document is provided solely to enable system and software implementers to use NXP
products. There are no express or implied copyright licenses granted hereunder to design or fabricate any
integrated circuits based on the information in this document. NXP reserves the right to make changes
without further notice to any products herein.
How to Reach Us:
Home Page: nxp.com
Web Support: nxp.com/support
NXP makes no warranty, representation, or guarantee regarding the suitability of its products for any
particular purpose, nor does NXP assume any liability arising out of the application or use of any product
or circuit, and specifically disclaims any and all liability, including without limitation consequential or
incidental damages. “Typical” parameters that may be provided in NXP data sheets and/or specifications
can and do vary in different applications, and actual performance may vary over time. All operating
parameters, including “typicals,” must be validated for each customer application by customer’s technical
experts. NXP does not convey any license under its patent rights nor the rights of others. NXP sells
products pursuant to standard terms and conditions of sale, which can be found at the following address:
http://www.nxp.com/SalesTermsandConditions.
NXP, the NXP logo, NXP SECURE CONNECTIONS FOR A SMARTER WORLD, COOLFLUX, EM-
BRACE, GREENCHIP, HITAG, I2C BUS, ICODE, JCOP, LIFE VIBES, MIFARE, MIFARE CLASSIC,
MIFARE DESFire, MIFARE PLUS, MIFARE FLEX, MANTIS, MIFARE ULTRALIGHT, MIFARE4M-
OBILE, MIGLO, NTAG, ROADLINK, SMARTLX, SMARTMX, STARPLUG, TOPFET, TRENCHM-
OS, UCODE, Freescale, the Freescale logo, AltiVec, C-5, CodeTEST, CodeWarrior, ColdFire, ColdFire+,
C-Ware, the Energy Efficient Solutions logo, Kinetis, Layerscape, MagniV, mobileGT, PEG, PowerQUI-
CC, Processor Expert, QorIQ, QorIQ Qonverge, Ready Play, SafeAssure, the SafeAssure logo, StarCore,
Symphony, VortiQa, Vybrid, Airfast, BeeKit, BeeStack, CoreNet, Flexis, MXC, Platform in a Package,
QUICC Engine, SMARTMOS, Tower, TurboLink, and UMEMS are trademarks of NXP B.V. All other
product or service names are the property of their respective owners. AMBA, Arm, Arm7, Arm7TD-
MI, Arm9, Arm11, Artisan, big.LITTLE, Cordio, CoreLink, CoreSight, Cortex, DesignStart, Dynam-
IQ, Jazelle, Keil, Mali, Mbed, Mbed Enabled, NEON, POP, RealView, SecurCore, Socrates, Thumb,
TrustZone, ULINK, ULINK2, ULINK-ME, ULINK-PLUS, ULINKpro, Vision, Versatile are trademarks
or registered trademarks of Arm Limited (or its subsidiaries) in the US and/or elsewhere. The related
technology may be protected by any or all of patents, copyrights, designs and trade secrets. All rights
reserved. Oracle and Java are registered trademarks of Oracle and/or its affiliates. The Power Architecture
and Power.org word marks and the Power and Power.org logos and related marks are trademarks and
service marks licensed by Power.org.
© 2019 NXP B.V.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 9
MCUXpresso SDK API Reference Manual
10 NXP Semiconductors
Chapter 5
ADC16: 16-bit SAR Analog-to-Digital Converter Driver
5.1 Overview
The MCUXpresso SDK provides a peripheral driver for the 16-bit SAR Analog-to-Digital Converter (A-
DC16) module of MCUXpresso SDK devices.

5.2 Typical use case


5.2.1 Polling Configuration

Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/adc16

5.2.2 Interrupt Configuration

Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/adc16

Data Structures
• struct adc16_config_t
ADC16 converter configuration. More...
• struct adc16_hardware_compare_config_t
ADC16 Hardware comparison configuration. More...
• struct adc16_channel_config_t
ADC16 channel conversion configuration. More...

Enumerations
• enum _adc16_channel_status_flags { kADC16_ChannelConversionDoneFlag = ADC_SC1_COC-
O_MASK }
Channel status flags.
• enum _adc16_status_flags {
kADC16_ActiveFlag = ADC_SC2_ADACT_MASK,
kADC16_CalibrationFailedFlag = ADC_SC3_CALF_MASK }
Converter status flags.
• enum adc16_channel_mux_mode_t {
kADC16_ChannelMuxA = 0U,
kADC16_ChannelMuxB = 1U }
Channel multiplexer mode for each channel.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 11
Typical use case

• enum adc16_clock_divider_t {
kADC16_ClockDivider1 = 0U,
kADC16_ClockDivider2 = 1U,
kADC16_ClockDivider4 = 2U,
kADC16_ClockDivider8 = 3U }
Clock divider for the converter.
• enum adc16_resolution_t {
kADC16_Resolution8or9Bit = 0U,
kADC16_Resolution12or13Bit = 1U,
kADC16_Resolution10or11Bit = 2U,
kADC16_ResolutionSE8Bit = kADC16_Resolution8or9Bit,
kADC16_ResolutionSE12Bit = kADC16_Resolution12or13Bit,
kADC16_ResolutionSE10Bit = kADC16_Resolution10or11Bit,
kADC16_ResolutionDF9Bit = kADC16_Resolution8or9Bit,
kADC16_ResolutionDF13Bit = kADC16_Resolution12or13Bit,
kADC16_ResolutionDF11Bit = kADC16_Resolution10or11Bit,
kADC16_Resolution16Bit = 3U,
kADC16_ResolutionSE16Bit = kADC16_Resolution16Bit,
kADC16_ResolutionDF16Bit = kADC16_Resolution16Bit }
Converter’s resolution.
• enum adc16_clock_source_t {
kADC16_ClockSourceAlt0 = 0U,
kADC16_ClockSourceAlt1 = 1U,
kADC16_ClockSourceAlt2 = 2U,
kADC16_ClockSourceAlt3 = 3U,
kADC16_ClockSourceAsynchronousClock = kADC16_ClockSourceAlt3 }
Clock source.
• enum adc16_long_sample_mode_t {
kADC16_LongSampleCycle24 = 0U,
kADC16_LongSampleCycle16 = 1U,
kADC16_LongSampleCycle10 = 2U,
kADC16_LongSampleCycle6 = 3U,
kADC16_LongSampleDisabled = 4U }
Long sample mode.
• enum adc16_reference_voltage_source_t {
kADC16_ReferenceVoltageSourceVref = 0U,
kADC16_ReferenceVoltageSourceValt = 1U }
Reference voltage source.
• enum adc16_hardware_average_mode_t {
kADC16_HardwareAverageCount4 = 0U,
kADC16_HardwareAverageCount8 = 1U,
kADC16_HardwareAverageCount16 = 2U,
kADC16_HardwareAverageCount32 = 3U,
kADC16_HardwareAverageDisabled = 4U }
Hardware average mode.
• enum adc16_hardware_compare_mode_t {

MCUXpresso SDK API Reference Manual


12 NXP Semiconductors
Typical use case

kADC16_HardwareCompareMode0 = 0U,
kADC16_HardwareCompareMode1 = 1U,
kADC16_HardwareCompareMode2 = 2U,
kADC16_HardwareCompareMode3 = 3U }
Hardware compare mode.

Driver version
• #define FSL_ADC16_DRIVER_VERSION (MAKE_VERSION(2, 0, 2))
ADC16 driver version 2.0.2.

Initialization
• void ADC16_Init (ADC_Type ∗base, const adc16_config_t ∗config)
Initializes the ADC16 module.
• void ADC16_Deinit (ADC_Type ∗base)
De-initializes the ADC16 module.
• void ADC16_GetDefaultConfig (adc16_config_t ∗config)
Gets an available pre-defined settings for the converter’s configuration.
• status_t ADC16_DoAutoCalibration (ADC_Type ∗base)
Automates the hardware calibration.
• static void ADC16_SetOffsetValue (ADC_Type ∗base, int16_t value)
Sets the offset value for the conversion result.

Advanced Features
• static void ADC16_EnableDMA (ADC_Type ∗base, bool enable)
Enables generating the DMA trigger when the conversion is complete.
• static void ADC16_EnableHardwareTrigger (ADC_Type ∗base, bool enable)
Enables the hardware trigger mode.
• void ADC16_SetChannelMuxMode (ADC_Type ∗base, adc16_channel_mux_mode_t mode)
Sets the channel mux mode.
• void ADC16_SetHardwareCompareConfig (ADC_Type ∗base, const adc16_hardware_compare_-
config_t ∗config)
Configures the hardware compare mode.
• void ADC16_SetHardwareAverage (ADC_Type ∗base, adc16_hardware_average_mode_t mode)
Sets the hardware average mode.
• uint32_t ADC16_GetStatusFlags (ADC_Type ∗base)
Gets the status flags of the converter.
• void ADC16_ClearStatusFlags (ADC_Type ∗base, uint32_t mask)
Clears the status flags of the converter.

Conversion Channel
• void ADC16_SetChannelConfig (ADC_Type ∗base, uint32_t channelGroup, const adc16_channel-
_config_t ∗config)
Configures the conversion channel.
• static uint32_t ADC16_GetChannelConversionValue (ADC_Type ∗base, uint32_t channelGroup)
Gets the conversion value.
• uint32_t ADC16_GetChannelStatusFlags (ADC_Type ∗base, uint32_t channelGroup)

MCUXpresso SDK API Reference Manual


NXP Semiconductors 13
Data Structure Documentation

Gets the status flags of channel.

5.3 Data Structure Documentation


5.3.1 struct adc16_config_t

Data Fields

• adc16_reference_voltage_source_t referenceVoltageSource
Select the reference voltage source.
• adc16_clock_source_t clockSource
Select the input clock source to converter.
• bool enableAsynchronousClock
Enable the asynchronous clock output.
• adc16_clock_divider_t clockDivider
Select the divider of input clock source.
• adc16_resolution_t resolution
Select the sample resolution mode.
• adc16_long_sample_mode_t longSampleMode
Select the long sample mode.
• bool enableHighSpeed
Enable the high-speed mode.
• bool enableLowPower
Enable low power.
• bool enableContinuousConversion
Enable continuous conversion mode.

MCUXpresso SDK API Reference Manual


14 NXP Semiconductors
Data Structure Documentation

5.3.1.0.0.1 Field Documentation

5.3.1.0.0.1.1 adc16_reference_voltage_source_t adc16_config_t::referenceVoltageSource

5.3.1.0.0.1.2 adc16_clock_source_t adc16_config_t::clockSource

5.3.1.0.0.1.3 bool adc16_config_t::enableAsynchronousClock

5.3.1.0.0.1.4 adc16_clock_divider_t adc16_config_t::clockDivider

5.3.1.0.0.1.5 adc16_resolution_t adc16_config_t::resolution

5.3.1.0.0.1.6 adc16_long_sample_mode_t adc16_config_t::longSampleMode

5.3.1.0.0.1.7 bool adc16_config_t::enableHighSpeed

5.3.1.0.0.1.8 bool adc16_config_t::enableLowPower

5.3.1.0.0.1.9 bool adc16_config_t::enableContinuousConversion

5.3.2 struct adc16_hardware_compare_config_t

Data Fields

• adc16_hardware_compare_mode_t hardwareCompareMode
Select the hardware compare mode.
• int16_t value1
Setting value1 for hardware compare mode.
• int16_t value2
Setting value2 for hardware compare mode.

5.3.2.0.0.2 Field Documentation

5.3.2.0.0.2.1 adc16_hardware_compare_mode_t adc16_hardware_compare_config_t::hardware-


CompareMode

See "adc16_hardware_compare_mode_t".

5.3.2.0.0.2.2 int16_t adc16_hardware_compare_config_t::value1

5.3.2.0.0.2.3 int16_t adc16_hardware_compare_config_t::value2

5.3.3 struct adc16_channel_config_t

Data Fields

• uint32_t channelNumber
Setting the conversion channel number.
• bool enableInterruptOnConversionCompleted

MCUXpresso SDK API Reference Manual


NXP Semiconductors 15
Enumeration Type Documentation

Generate an interrupt request once the conversion is completed.


• bool enableDifferentialConversion
Using Differential sample mode.

5.3.3.0.0.3 Field Documentation

5.3.3.0.0.3.1 uint32_t adc16_channel_config_t::channelNumber

The available range is 0-31. See channel connection information for each chip in Reference Manual
document.

5.3.3.0.0.3.2 bool adc16_channel_config_t::enableInterruptOnConversionCompleted

5.3.3.0.0.3.3 bool adc16_channel_config_t::enableDifferentialConversion

5.4 Macro Definition Documentation


5.4.1 #define FSL_ADC16_DRIVER_VERSION (MAKE_VERSION(2, 0, 2))

5.5 Enumeration Type Documentation


5.5.1 enum _adc16_channel_status_flags

Enumerator
kADC16_ChannelConversionDoneFlag Conversion done.

5.5.2 enum _adc16_status_flags

Enumerator
kADC16_ActiveFlag Converter is active.
kADC16_CalibrationFailedFlag Calibration is failed.

5.5.3 enum adc16_channel_mux_mode_t

For some ADC16 channels, there are two pin selections in channel multiplexer. For example, ADC0_SE4a
and ADC0_SE4b are the different channels that share the same channel number.

Enumerator
kADC16_ChannelMuxA For channel with channel mux a.
kADC16_ChannelMuxB For channel with channel mux b.

MCUXpresso SDK API Reference Manual


16 NXP Semiconductors
Enumeration Type Documentation

5.5.4 enum adc16_clock_divider_t

Enumerator
kADC16_ClockDivider1 For divider 1 from the input clock to the module.
kADC16_ClockDivider2 For divider 2 from the input clock to the module.
kADC16_ClockDivider4 For divider 4 from the input clock to the module.
kADC16_ClockDivider8 For divider 8 from the input clock to the module.

5.5.5 enum adc16_resolution_t

Enumerator
kADC16_Resolution8or9Bit Single End 8-bit or Differential Sample 9-bit.
kADC16_Resolution12or13Bit Single End 12-bit or Differential Sample 13-bit.
kADC16_Resolution10or11Bit Single End 10-bit or Differential Sample 11-bit.
kADC16_ResolutionSE8Bit Single End 8-bit.
kADC16_ResolutionSE12Bit Single End 12-bit.
kADC16_ResolutionSE10Bit Single End 10-bit.
kADC16_ResolutionDF9Bit Differential Sample 9-bit.
kADC16_ResolutionDF13Bit Differential Sample 13-bit.
kADC16_ResolutionDF11Bit Differential Sample 11-bit.
kADC16_Resolution16Bit Single End 16-bit or Differential Sample 16-bit.
kADC16_ResolutionSE16Bit Single End 16-bit.
kADC16_ResolutionDF16Bit Differential Sample 16-bit.

5.5.6 enum adc16_clock_source_t

Enumerator
kADC16_ClockSourceAlt0 Selection 0 of the clock source.
kADC16_ClockSourceAlt1 Selection 1 of the clock source.
kADC16_ClockSourceAlt2 Selection 2 of the clock source.
kADC16_ClockSourceAlt3 Selection 3 of the clock source.
kADC16_ClockSourceAsynchronousClock Using internal asynchronous clock.

5.5.7 enum adc16_long_sample_mode_t

Enumerator
kADC16_LongSampleCycle24 20 extra ADCK cycles, 24 ADCK cycles total.
kADC16_LongSampleCycle16 12 extra ADCK cycles, 16 ADCK cycles total.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 17
Function Documentation

kADC16_LongSampleCycle10 6 extra ADCK cycles, 10 ADCK cycles total.


kADC16_LongSampleCycle6 2 extra ADCK cycles, 6 ADCK cycles total.
kADC16_LongSampleDisabled Disable the long sample feature.

5.5.8 enum adc16_reference_voltage_source_t

Enumerator
kADC16_ReferenceVoltageSourceVref For external pins pair of VrefH and VrefL.
kADC16_ReferenceVoltageSourceValt For alternate reference pair of ValtH and ValtL.

5.5.9 enum adc16_hardware_average_mode_t

Enumerator
kADC16_HardwareAverageCount4 For hardware average with 4 samples.
kADC16_HardwareAverageCount8 For hardware average with 8 samples.
kADC16_HardwareAverageCount16 For hardware average with 16 samples.
kADC16_HardwareAverageCount32 For hardware average with 32 samples.
kADC16_HardwareAverageDisabled Disable the hardware average feature.

5.5.10 enum adc16_hardware_compare_mode_t

Enumerator
kADC16_HardwareCompareMode0 x < value1.
kADC16_HardwareCompareMode1 x > value1.
kADC16_HardwareCompareMode2 if value1 <= value2, then x < value1 || x > value2; else,
value1 > x > value2.
kADC16_HardwareCompareMode3 if value1 <= value2, then value1 <= x <= value2; else x >=
value1 || x <= value2.

5.6 Function Documentation


5.6.1 void ADC16_Init ( ADC_Type ∗ base, const adc16_config_t ∗ config )

MCUXpresso SDK API Reference Manual


18 NXP Semiconductors
Function Documentation

Parameters

base ADC16 peripheral base address.


config Pointer to configuration structure. See "adc16_config_t".

5.6.2 void ADC16_Deinit ( ADC_Type ∗ base )

Parameters

base ADC16 peripheral base address.

5.6.3 void ADC16_GetDefaultConfig ( adc16_config_t ∗ config )

This function initializes the converter configuration structure with available settings. The default values
are as follows.

* config->referenceVoltageSource = kADC16_ReferenceVoltageSourceVref
;
* config->clockSource = kADC16_ClockSourceAsynchronousClock
;
* config->enableAsynchronousClock = true;
* config->clockDivider = kADC16_ClockDivider8;
* config->resolution = kADC16_ResolutionSE12Bit;
* config->longSampleMode = kADC16_LongSampleDisabled;
* config->enableHighSpeed = false;
* config->enableLowPower = false;
* config->enableContinuousConversion = false;
*

Parameters

config Pointer to the configuration structure.

5.6.4 status_t ADC16_DoAutoCalibration ( ADC_Type ∗ base )

This auto calibration helps to adjust the plus/minus side gain automatically. Execute the calibration before
using the converter. Note that the hardware trigger should be used during the calibration.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 19
Function Documentation

Parameters

base ADC16 peripheral base address.

Returns
Execution status.

Return values

kStatus_Success Calibration is done successfully.


kStatus_Fail Calibration has failed.

5.6.5 static void ADC16_SetOffsetValue ( ADC_Type ∗ base, int16_t value )


[inline], [static]

This offset value takes effect on the conversion result. If the offset value is not zero, the reading result is
subtracted by it. Note, the hardware calibration fills the offset value automatically.
Parameters

base ADC16 peripheral base address.


value Setting offset value.

5.6.6 static void ADC16_EnableDMA ( ADC_Type ∗ base, bool enable )


[inline], [static]

Parameters

base ADC16 peripheral base address.


enable Switcher of the DMA feature. "true" means enabled, "false" means not enabled.

5.6.7 static void ADC16_EnableHardwareTrigger ( ADC_Type ∗ base, bool enable )


[inline], [static]

MCUXpresso SDK API Reference Manual


20 NXP Semiconductors
Function Documentation

Parameters

base ADC16 peripheral base address.


enable Switcher of the hardware trigger feature. "true" means enabled, "false" means not
enabled.

5.6.8 void ADC16_SetChannelMuxMode ( ADC_Type ∗ base,


adc16_channel_mux_mode_t mode )

Some sample pins share the same channel index. The channel mux mode decides which pin is used for an
indicated channel.
Parameters

base ADC16 peripheral base address.


mode Setting channel mux mode. See "adc16_channel_mux_mode_t".

5.6.9 void ADC16_SetHardwareCompareConfig ( ADC_Type ∗ base, const


adc16_hardware_compare_config_t ∗ config )

The hardware compare mode provides a way to process the conversion result automatically by using
hardware. Only the result in the compare range is available. To compare the range, see "adc16_hardware-
_compare_mode_t" or the appopriate reference manual for more information.
Parameters

base ADC16 peripheral base address.


config Pointer to the "adc16_hardware_compare_config_t" structure. Passing "NULL" dis-
ables the feature.

5.6.10 void ADC16_SetHardwareAverage ( ADC_Type ∗ base,


adc16_hardware_average_mode_t mode )

The hardware average mode provides a way to process the conversion result automatically by using hard-
ware. The multiple conversion results are accumulated and averaged internally making them easier to
read.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 21
Function Documentation

Parameters

base ADC16 peripheral base address.


mode Setting the hardware average mode. See "adc16_hardware_average_mode_t".

5.6.11 uint32_t ADC16_GetStatusFlags ( ADC_Type ∗ base )

Parameters

base ADC16 peripheral base address.

Returns
Flags’ mask if indicated flags are asserted. See "_adc16_status_flags".

5.6.12 void ADC16_ClearStatusFlags ( ADC_Type ∗ base, uint32_t mask )

Parameters

base ADC16 peripheral base address.


mask Mask value for the cleared flags. See "_adc16_status_flags".

5.6.13 void ADC16_SetChannelConfig ( ADC_Type ∗ base, uint32_t channelGroup,


const adc16_channel_config_t ∗ config )

This operation triggers the conversion when in software trigger mode. When in hardware trigger mode,
this API configures the channel while the external trigger source helps to trigger the conversion.
Note that the "Channel Group" has a detailed description. To allow sequential conversions of the ADC
to be triggered by internal peripherals, the ADC has more than one group of status and control registers,
one for each conversion. The channel group parameter indicates which group of registers are used, for
example, channel group 0 is for Group A registers and channel group 1 is for Group B registers. The
channel groups are used in a "ping-pong" approach to control the ADC operation. At any point, only
one of the channel groups is actively controlling ADC conversions. The channel group 0 is used for
both software and hardware trigger modes. Channel group 1 and greater indicates multiple channel group
registers for use only in hardware trigger mode. See the chip configuration information in the appropriate
MCU reference manual for the number of SC1n registers (channel groups) specific to this device. Channel
group 1 or greater are not used for software trigger operation. Therefore, writing to these channel groups
does not initiate a new conversion. Updating the channel group 0 while a different channel group is

MCUXpresso SDK API Reference Manual


22 NXP Semiconductors
Function Documentation

actively controlling a conversion is allowed and vice versa. Writing any of the channel group registers
while that specific channel group is actively controlling a conversion aborts the current conversion.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 23
Function Documentation

Parameters

base ADC16 peripheral base address.


channelGroup Channel group index.
config Pointer to the "adc16_channel_config_t" structure for the conversion channel.

5.6.14 static uint32_t ADC16_GetChannelConversionValue ( ADC_Type ∗ base,


uint32_t channelGroup ) [inline], [static]

Parameters

base ADC16 peripheral base address.


channelGroup Channel group index.

Returns
Conversion value.

5.6.15 uint32_t ADC16_GetChannelStatusFlags ( ADC_Type ∗ base, uint32_t


channelGroup )

Parameters

base ADC16 peripheral base address.


channelGroup Channel group index.

Returns
Flags’ mask if indicated flags are asserted. See "_adc16_channel_status_flags".

MCUXpresso SDK API Reference Manual


24 NXP Semiconductors
Chapter 6
CMP: Analog Comparator Driver
6.1 Overview
The MCUXpresso SDK provides a peripheral driver for the Analog Comparator (CMP) module of MCU-
Xpresso SDK devices.
The CMP driver is a basic comparator with advanced features. The APIs for the basic comparator enable
the CMP to compare the two voltages of the two input channels and create the output of the comparator
result. The APIs for advanced features can be used as the plug-in functions based on the basic comparator.
They can process the comparator’s output with hardware support.

6.2 Typical use case


6.2.1 Polling Configuration

Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/cmp

6.2.2 Interrupt Configuration

Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/cmp

Data Structures
• struct cmp_config_t
Configures the comparator. More...
• struct cmp_filter_config_t
Configures the filter. More...
• struct cmp_dac_config_t
Configures the internal DAC. More...

Enumerations
• enum _cmp_interrupt_enable {
kCMP_OutputRisingInterruptEnable = CMP_SCR_IER_MASK,
kCMP_OutputFallingInterruptEnable = CMP_SCR_IEF_MASK }
Interrupt enable/disable mask.
• enum _cmp_status_flags {
kCMP_OutputRisingEventFlag = CMP_SCR_CFR_MASK,
kCMP_OutputFallingEventFlag = CMP_SCR_CFF_MASK,
kCMP_OutputAssertEventFlag = CMP_SCR_COUT_MASK }
Status flags’ mask.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 25
Typical use case

• enum cmp_hysteresis_mode_t {
kCMP_HysteresisLevel0 = 0U,
kCMP_HysteresisLevel1 = 1U,
kCMP_HysteresisLevel2 = 2U,
kCMP_HysteresisLevel3 = 3U }
CMP Hysteresis mode.
• enum cmp_reference_voltage_source_t {
kCMP_VrefSourceVin1 = 0U,
kCMP_VrefSourceVin2 = 1U }
CMP Voltage Reference source.

Driver version
• #define FSL_CMP_DRIVER_VERSION (MAKE_VERSION(2, 0, 1))
CMP driver version 2.0.1.

Initialization
• void CMP_Init (CMP_Type ∗base, const cmp_config_t ∗config)
Initializes the CMP.
• void CMP_Deinit (CMP_Type ∗base)
De-initializes the CMP module.
• static void CMP_Enable (CMP_Type ∗base, bool enable)
Enables/disables the CMP module.
• void CMP_GetDefaultConfig (cmp_config_t ∗config)
Initializes the CMP user configuration structure.
• void CMP_SetInputChannels (CMP_Type ∗base, uint8_t positiveChannel, uint8_t negativeChannel)
Sets the input channels for the comparator.

Advanced Features
• void CMP_EnableDMA (CMP_Type ∗base, bool enable)
Enables/disables the DMA request for rising/falling events.
• void CMP_SetFilterConfig (CMP_Type ∗base, const cmp_filter_config_t ∗config)
Configures the filter.
• void CMP_SetDACConfig (CMP_Type ∗base, const cmp_dac_config_t ∗config)
Configures the internal DAC.
• void CMP_EnableInterrupts (CMP_Type ∗base, uint32_t mask)
Enables the interrupts.
• void CMP_DisableInterrupts (CMP_Type ∗base, uint32_t mask)
Disables the interrupts.

Results
• uint32_t CMP_GetStatusFlags (CMP_Type ∗base)
Gets the status flags.
• void CMP_ClearStatusFlags (CMP_Type ∗base, uint32_t mask)
Clears the status flags.

MCUXpresso SDK API Reference Manual


26 NXP Semiconductors
Data Structure Documentation

6.3 Data Structure Documentation


6.3.1 struct cmp_config_t

Data Fields

• bool enableCmp
Enable the CMP module.
• cmp_hysteresis_mode_t hysteresisMode
CMP Hysteresis mode.
• bool enableHighSpeed
Enable High-speed (HS) comparison mode.
• bool enableInvertOutput
Enable the inverted comparator output.
• bool useUnfilteredOutput
Set the compare output(COUT) to equal COUTA(true) or COUT(false).
• bool enablePinOut
The comparator output is available on the associated pin.
• bool enableTriggerMode
Enable the trigger mode.

6.3.1.0.0.4 Field Documentation

6.3.1.0.0.4.1 bool cmp_config_t::enableCmp

6.3.1.0.0.4.2 cmp_hysteresis_mode_t cmp_config_t::hysteresisMode

6.3.1.0.0.4.3 bool cmp_config_t::enableHighSpeed

6.3.1.0.0.4.4 bool cmp_config_t::enableInvertOutput

6.3.1.0.0.4.5 bool cmp_config_t::useUnfilteredOutput

6.3.1.0.0.4.6 bool cmp_config_t::enablePinOut

6.3.1.0.0.4.7 bool cmp_config_t::enableTriggerMode

6.3.2 struct cmp_filter_config_t

Data Fields

• uint8_t filterCount
Filter Sample Count.
• uint8_t filterPeriod
Filter Sample Period.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 27
Enumeration Type Documentation

6.3.2.0.0.5 Field Documentation

6.3.2.0.0.5.1 uint8_t cmp_filter_config_t::filterCount

Available range is 1-7; 0 disables the filter.

6.3.2.0.0.5.2 uint8_t cmp_filter_config_t::filterPeriod

The divider to the bus clock. Available range is 0-255.

6.3.3 struct cmp_dac_config_t

Data Fields

• cmp_reference_voltage_source_t referenceVoltageSource
Supply voltage reference source.
• uint8_t DACValue
Value for the DAC Output Voltage.

6.3.3.0.0.6 Field Documentation

6.3.3.0.0.6.1 cmp_reference_voltage_source_t cmp_dac_config_t::referenceVoltageSource

6.3.3.0.0.6.2 uint8_t cmp_dac_config_t::DACValue

Available range is 0-63.

6.4 Macro Definition Documentation


6.4.1 #define FSL_CMP_DRIVER_VERSION (MAKE_VERSION(2, 0, 1))

6.5 Enumeration Type Documentation


6.5.1 enum _cmp_interrupt_enable

Enumerator
kCMP_OutputRisingInterruptEnable Comparator interrupt enable rising.
kCMP_OutputFallingInterruptEnable Comparator interrupt enable falling.

6.5.2 enum _cmp_status_flags

Enumerator
kCMP_OutputRisingEventFlag Rising-edge on the comparison output has occurred.
kCMP_OutputFallingEventFlag Falling-edge on the comparison output has occurred.

MCUXpresso SDK API Reference Manual


28 NXP Semiconductors
Function Documentation

kCMP_OutputAssertEventFlag Return the current value of the analog comparator output.

6.5.3 enum cmp_hysteresis_mode_t

Enumerator
kCMP_HysteresisLevel0 Hysteresis level 0.
kCMP_HysteresisLevel1 Hysteresis level 1.
kCMP_HysteresisLevel2 Hysteresis level 2.
kCMP_HysteresisLevel3 Hysteresis level 3.

6.5.4 enum cmp_reference_voltage_source_t

Enumerator
kCMP_VrefSourceVin1 Vin1 is selected as a resistor ladder network supply reference Vin.
kCMP_VrefSourceVin2 Vin2 is selected as a resistor ladder network supply reference Vin.

6.6 Function Documentation


6.6.1 void CMP_Init ( CMP_Type ∗ base, const cmp_config_t ∗ config )

This function initializes the CMP module. The operations included are as follows.
• Enabling the clock for CMP module.
• Configuring the comparator.
• Enabling the CMP module. Note that for some devices, multiple CMP instances share the same
clock gate. In this case, to enable the clock for any instance enables all CMPs. See the appropriate
MCU reference manual for the clock assignment of the CMP.
Parameters

base CMP peripheral base address.


config Pointer to the configuration structure.

6.6.2 void CMP_Deinit ( CMP_Type ∗ base )

This function de-initializes the CMP module. The operations included are as follows.
• Disabling the CMP module.
• Disabling the clock for CMP module.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 29
Function Documentation

This function disables the clock for the CMP. Note that for some devices, multiple CMP instances share
the same clock gate. In this case, before disabling the clock for the CMP, ensure that all the CMP instances
are not used.

MCUXpresso SDK API Reference Manual


30 NXP Semiconductors
Function Documentation

Parameters

base CMP peripheral base address.

6.6.3 static void CMP_Enable ( CMP_Type ∗ base, bool enable ) [inline],


[static]

Parameters

base CMP peripheral base address.


enable Enables or disables the module.

6.6.4 void CMP_GetDefaultConfig ( cmp_config_t ∗ config )

This function initializes the user configuration structure to these default values.

* config->enableCmp = true;
* config->hysteresisMode = kCMP_HysteresisLevel0;
* config->enableHighSpeed = false;
* config->enableInvertOutput = false;
* config->useUnfilteredOutput = false;
* config->enablePinOut = false;
* config->enableTriggerMode = false;
*

Parameters

config Pointer to the configuration structure.

6.6.5 void CMP_SetInputChannels ( CMP_Type ∗ base, uint8_t positiveChannel,


uint8_t negativeChannel )

This function sets the input channels for the comparator. Note that two input channels cannot be set the
same way in the application. When the user selects the same input from the analog mux to the positive
and negative port, the comparator is disabled automatically.
Parameters

MCUXpresso SDK API Reference Manual


NXP Semiconductors 31
Function Documentation

base CMP peripheral base address.


positive- Positive side input channel number. Available range is 0-7.
Channel
negative- Negative side input channel number. Available range is 0-7.
Channel

6.6.6 void CMP_EnableDMA ( CMP_Type ∗ base, bool enable )

This function enables/disables the DMA request for rising/falling events. Either event triggers the genera-
tion of the DMA request from CMP if the DMA feature is enabled. Both events are ignored for generating
the DMA request from the CMP if the DMA is disabled.
Parameters

base CMP peripheral base address.


enable Enables or disables the feature.

6.6.7 void CMP_SetFilterConfig ( CMP_Type ∗ base, const cmp_filter_config_t ∗


config )

Parameters

base CMP peripheral base address.


config Pointer to the configuration structure.

6.6.8 void CMP_SetDACConfig ( CMP_Type ∗ base, const cmp_dac_config_t ∗


config )

Parameters

base CMP peripheral base address.


config Pointer to the configuration structure. "NULL" disables the feature.

6.6.9 void CMP_EnableInterrupts ( CMP_Type ∗ base, uint32_t mask )

MCUXpresso SDK API Reference Manual


32 NXP Semiconductors
Function Documentation

Parameters

base CMP peripheral base address.


mask Mask value for interrupts. See "_cmp_interrupt_enable".

6.6.10 void CMP_DisableInterrupts ( CMP_Type ∗ base, uint32_t mask )

Parameters

base CMP peripheral base address.


mask Mask value for interrupts. See "_cmp_interrupt_enable".

6.6.11 uint32_t CMP_GetStatusFlags ( CMP_Type ∗ base )

Parameters

base CMP peripheral base address.

Returns
Mask value for the asserted flags. See "_cmp_status_flags".

6.6.12 void CMP_ClearStatusFlags ( CMP_Type ∗ base, uint32_t mask )

Parameters

base CMP peripheral base address.


mask Mask value for the flags. See "_cmp_status_flags".

MCUXpresso SDK API Reference Manual


NXP Semiconductors 33
Function Documentation

MCUXpresso SDK API Reference Manual


34 NXP Semiconductors
Chapter 7
COP: Watchdog Driver
7.1 Overview
The MCUXpresso SDK provides a peripheral driver for the Computer Operating Properly module (COP)
of MCUXpresso SDK devices.

7.2 Typical use case


Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/cop

Data Structures
• struct cop_config_t
Describes COP configuration structure. More...

Enumerations
• enum cop_clock_source_t {
kCOP_LpoClock = 0U,
kCOP_McgIrClock = 1U,
kCOP_OscErClock = 2U,
kCOP_BusClock = 3U }
COP clock source selection.
• enum cop_timeout_cycles_t {
kCOP_2Power5CyclesOr2Power13Cycles = 1U,
kCOP_2Power8CyclesOr2Power16Cycles = 2U,
kCOP_2Power10CyclesOr2Power18Cycles = 3U }
Define the COP timeout cycles.
• enum cop_timeout_mode_t {
kCOP_ShortTimeoutMode = 0U,
kCOP_LongTimeoutMode = 1U }
Define the COP timeout mode.

Driver version
• #define FSL_COP_DRIVER_VERSION (MAKE_VERSION(2, 0, 1))
COP driver version 2.0.1.

COP refresh sequence.


• #define COP_FIRST_BYTE_OF_REFRESH (0x55U)
First byte of refresh sequence.
• #define COP_SECOND_BYTE_OF_REFRESH (0xAAU)
Second byte of refresh sequence.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 35
Enumeration Type Documentation

COP Functional Operation


• void COP_GetDefaultConfig (cop_config_t ∗config)
Initializes the COP configuration structure.
• void COP_Init (SIM_Type ∗base, const cop_config_t ∗config)
Initializes the COP module.
• static void COP_Disable (SIM_Type ∗base)
De-initializes the COP module.
• void COP_Refresh (SIM_Type ∗base)
Refreshes the COP timer.

7.3 Data Structure Documentation


7.3.1 struct cop_config_t

Data Fields

• bool enableWindowMode
COP run mode: window mode or normal mode.
• cop_timeout_mode_t timeoutMode
COP timeout mode: long timeout or short timeout.
• bool enableStop
Enable or disable COP in STOP mode.
• bool enableDebug
Enable or disable COP in DEBUG mode.
• cop_clock_source_t clockSource
Set COP clock source.
• cop_timeout_cycles_t timeoutCycles
Set COP timeout value.

7.4 Macro Definition Documentation


7.4.1 #define FSL_COP_DRIVER_VERSION (MAKE_VERSION(2, 0, 1))

7.5 Enumeration Type Documentation


7.5.1 enum cop_clock_source_t

Enumerator
kCOP_LpoClock COP clock sourced from LPO.
kCOP_McgIrClock COP clock sourced from MCGIRCLK.
kCOP_OscErClock COP clock sourced from OSCERCLK.
kCOP_BusClock COP clock sourced from Bus clock.

MCUXpresso SDK API Reference Manual


36 NXP Semiconductors
Function Documentation

7.5.2 enum cop_timeout_cycles_t

Enumerator
kCOP_2Power5CyclesOr2Power13Cycles 2∧ 5 or 2∧ 13 clock cycles
kCOP_2Power8CyclesOr2Power16Cycles 2∧ 8 or 2∧ 16 clock cycles
kCOP_2Power10CyclesOr2Power18Cycles 2∧ 10 or 2∧ 18 clock cycles

7.5.3 enum cop_timeout_mode_t

Enumerator
kCOP_ShortTimeoutMode COP selects long timeout.
kCOP_LongTimeoutMode COP selects short timeout.

7.6 Function Documentation


7.6.1 void COP_GetDefaultConfig ( cop_config_t ∗ config )

This function initializes the COP configuration structure to default values. The default values are:

* copConfig->enableWindowMode = false;
* copConfig->timeoutMode = kCOP_LongTimeoutMode;
* copConfig->enableStop = false;
* copConfig->enableDebug = false;
* copConfig->clockSource = kCOP_LpoClock;
* copConfig->timeoutCycles = kCOP_2Power10CyclesOr2Power18Cycles;
*

Parameters

config Pointer to the COP configuration structure.

See Also
cop_config_t

7.6.2 void COP_Init ( SIM_Type ∗ base, const cop_config_t ∗ config )

This function configures the COP. After it is called, the COP starts running according to the configura-
tion. Because all COP control registers are write-once only, the COP_Init function and the COP_Disable
function can be called only once. A second call has no effect.
Example:

MCUXpresso SDK API Reference Manual


NXP Semiconductors 37
Function Documentation

* cop_config_t config;
* COP_GetDefaultConfig(&config);
* config.timeoutCycles = kCOP_2Power8CyclesOr2Power16Cycles
;
* COP_Init(sim_base,&config);
*

Parameters

base SIM peripheral base address.


config The configuration of COP.

7.6.3 static void COP_Disable ( SIM_Type ∗ base ) [inline], [static]

This dedicated function is not provided. Instead, the COP_Disable function can be used to disable the
COP.
Disables the COP module.
This function disables the COP Watchdog. Note: The COP configuration register is a write-once after
reset. To disable the COP Watchdog, call this function first.
Parameters

base SIM peripheral base address.

7.6.4 void COP_Refresh ( SIM_Type ∗ base )

This function feeds the COP.


Parameters

base SIM peripheral base address.

MCUXpresso SDK API Reference Manual


38 NXP Semiconductors
Chapter 8
DAC: Digital-to-Analog Converter Driver
8.1 Overview
The MCUXpresso SDK provides a peripheral driver for the Digital-to-Analog Converter (DAC) module
of MCUXpresso SDK devices.
The DAC driver includes a basic DAC module (converter) and a DAC buffer.
The basic DAC module supports operations unique to the DAC converter in each DAC instance. The
APIs in this part are used in the initialization phase, which enables the DAC module in the application.
The APIs enable/disable the clock, enable/disable the module, and configure the converter. Call the initial
APIs to prepare the DAC module for the application. The DAC buffer operates the DAC hardware buffer.
The DAC module supports a hardware buffer to keep a group of DAC values to be converted. This feature
supports updating the DAC output value automatically by triggering the buffer read pointer to move in
the buffer. Use the APIs to configure the hardware buffer’s trigger mode, watermark, work mode, and use
size. Additionally, the APIs operate the DMA, interrupts, flags, the pointer (the index of the buffer), item
values, and so on.
Note that the most functional features are designed for the DAC hardware buffer.

8.2 Typical use case


8.2.1 Working as a basic DAC without the hardware buffer feature

Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/dac

8.2.2 Working with the hardware buffer

Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/dac

Data Structures
• struct dac_config_t
DAC module configuration. More...
• struct dac_buffer_config_t
DAC buffer configuration. More...

Enumerations
• enum _dac_buffer_status_flags {
kDAC_BufferReadPointerTopPositionFlag = DAC_SR_DACBFRPTF_MASK,
kDAC_BufferReadPointerBottomPositionFlag = DAC_SR_DACBFRPBF_MASK }

MCUXpresso SDK API Reference Manual


NXP Semiconductors 39
Typical use case

DAC buffer flags.


• enum _dac_buffer_interrupt_enable {
kDAC_BufferReadPointerTopInterruptEnable = DAC_C0_DACBTIEN_MASK,
kDAC_BufferReadPointerBottomInterruptEnable = DAC_C0_DACBBIEN_MASK }
DAC buffer interrupts.
• enum dac_reference_voltage_source_t {
kDAC_ReferenceVoltageSourceVref1 = 0U,
kDAC_ReferenceVoltageSourceVref2 = 1U }
DAC reference voltage source.
• enum dac_buffer_trigger_mode_t {
kDAC_BufferTriggerByHardwareMode = 0U,
kDAC_BufferTriggerBySoftwareMode = 1U }
DAC buffer trigger mode.
• enum dac_buffer_work_mode_t {
kDAC_BufferWorkAsNormalMode = 0U,
kDAC_BufferWorkAsOneTimeScanMode,
kDAC_BufferWorkAsFIFOMode }
DAC buffer work mode.

Driver version
• #define FSL_DAC_DRIVER_VERSION (MAKE_VERSION(2, 0, 1))
DAC driver version 2.0.1.

Initialization
• void DAC_Init (DAC_Type ∗base, const dac_config_t ∗config)
Initializes the DAC module.
• void DAC_Deinit (DAC_Type ∗base)
De-initializes the DAC module.
• void DAC_GetDefaultConfig (dac_config_t ∗config)
Initializes the DAC user configuration structure.
• static void DAC_Enable (DAC_Type ∗base, bool enable)
Enables the DAC module.

Buffer
• static void DAC_EnableBuffer (DAC_Type ∗base, bool enable)
Enables the DAC buffer.
• void DAC_SetBufferConfig (DAC_Type ∗base, const dac_buffer_config_t ∗config)
Configures the CMP buffer.
• void DAC_GetDefaultBufferConfig (dac_buffer_config_t ∗config)
Initializes the DAC buffer configuration structure.
• static void DAC_EnableBufferDMA (DAC_Type ∗base, bool enable)
Enables the DMA for DAC buffer.
• void DAC_SetBufferValue (DAC_Type ∗base, uint8_t index, uint16_t value)
Sets the value for items in the buffer.
• static void DAC_DoSoftwareTriggerBuffer (DAC_Type ∗base)
Triggers the buffer using software and updates the read pointer of the DAC buffer.

MCUXpresso SDK API Reference Manual


40 NXP Semiconductors
Data Structure Documentation

• static uint8_t DAC_GetBufferReadPointer (DAC_Type ∗base)


Gets the current read pointer of the DAC buffer.
• void DAC_SetBufferReadPointer (DAC_Type ∗base, uint8_t index)
Sets the current read pointer of the DAC buffer.
• void DAC_EnableBufferInterrupts (DAC_Type ∗base, uint32_t mask)
Enables interrupts for the DAC buffer.
• void DAC_DisableBufferInterrupts (DAC_Type ∗base, uint32_t mask)
Disables interrupts for the DAC buffer.
• uint32_t DAC_GetBufferStatusFlags (DAC_Type ∗base)
Gets the flags of events for the DAC buffer.
• void DAC_ClearBufferStatusFlags (DAC_Type ∗base, uint32_t mask)
Clears the flags of events for the DAC buffer.

8.3 Data Structure Documentation


8.3.1 struct dac_config_t

Data Fields

• dac_reference_voltage_source_t referenceVoltageSource
Select the DAC reference voltage source.
• bool enableLowPowerMode
Enable the low-power mode.

8.3.1.0.0.7 Field Documentation

8.3.1.0.0.7.1 dac_reference_voltage_source_t dac_config_t::referenceVoltageSource

8.3.1.0.0.7.2 bool dac_config_t::enableLowPowerMode

8.3.2 struct dac_buffer_config_t

Data Fields

• dac_buffer_trigger_mode_t triggerMode
Select the buffer’s trigger mode.
• dac_buffer_work_mode_t workMode
Select the buffer’s work mode.
• uint8_t upperLimit
Set the upper limit for the buffer index.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 41
Enumeration Type Documentation

8.3.2.0.0.8 Field Documentation

8.3.2.0.0.8.1 dac_buffer_trigger_mode_t dac_buffer_config_t::triggerMode

8.3.2.0.0.8.2 dac_buffer_work_mode_t dac_buffer_config_t::workMode

8.3.2.0.0.8.3 uint8_t dac_buffer_config_t::upperLimit

Normally, 0-15 is available for a buffer with 16 items.

8.4 Macro Definition Documentation


8.4.1 #define FSL_DAC_DRIVER_VERSION (MAKE_VERSION(2, 0, 1))

8.5 Enumeration Type Documentation


8.5.1 enum _dac_buffer_status_flags

Enumerator
kDAC_BufferReadPointerTopPositionFlag DAC Buffer Read Pointer Top Position Flag.
kDAC_BufferReadPointerBottomPositionFlag DAC Buffer Read Pointer Bottom Position Flag.

8.5.2 enum _dac_buffer_interrupt_enable

Enumerator
kDAC_BufferReadPointerTopInterruptEnable DAC Buffer Read Pointer Top Flag Interrupt En-
able.
kDAC_BufferReadPointerBottomInterruptEnable DAC Buffer Read Pointer Bottom Flag Inter-
rupt Enable.

8.5.3 enum dac_reference_voltage_source_t

Enumerator
kDAC_ReferenceVoltageSourceVref1 The DAC selects DACREF_1 as the reference voltage.
kDAC_ReferenceVoltageSourceVref2 The DAC selects DACREF_2 as the reference voltage.

8.5.4 enum dac_buffer_trigger_mode_t

Enumerator
kDAC_BufferTriggerByHardwareMode The DAC hardware trigger is selected.

MCUXpresso SDK API Reference Manual


42 NXP Semiconductors
Function Documentation

kDAC_BufferTriggerBySoftwareMode The DAC software trigger is selected.

8.5.5 enum dac_buffer_work_mode_t

Enumerator
kDAC_BufferWorkAsNormalMode Normal mode.
kDAC_BufferWorkAsOneTimeScanMode One-Time Scan mode.
kDAC_BufferWorkAsFIFOMode FIFO mode.

8.6 Function Documentation


8.6.1 void DAC_Init ( DAC_Type ∗ base, const dac_config_t ∗ config )

This function initializes the DAC module including the following operations.
• Enabling the clock for DAC module.
• Configuring the DAC converter with a user configuration.
• Enabling the DAC module.
Parameters

base DAC peripheral base address.


config Pointer to the configuration structure. See "dac_config_t".

8.6.2 void DAC_Deinit ( DAC_Type ∗ base )

This function de-initializes the DAC module including the following operations.
• Disabling the DAC module.
• Disabling the clock for the DAC module.
Parameters

base DAC peripheral base address.

8.6.3 void DAC_GetDefaultConfig ( dac_config_t ∗ config )

This function initializes the user configuration structure to a default value. The default values are as
follows.
* config->referenceVoltageSource = kDAC_ReferenceVoltageSourceVref2;
* config->enableLowPowerMode = false;
*

MCUXpresso SDK API Reference Manual


NXP Semiconductors 43
Function Documentation

Parameters

config Pointer to the configuration structure. See "dac_config_t".

8.6.4 static void DAC_Enable ( DAC_Type ∗ base, bool enable ) [inline],


[static]

Parameters

base DAC peripheral base address.


enable Enables or disables the feature.

8.6.5 static void DAC_EnableBuffer ( DAC_Type ∗ base, bool enable ) [inline],


[static]

Parameters

base DAC peripheral base address.


enable Enables or disables the feature.

8.6.6 void DAC_SetBufferConfig ( DAC_Type ∗ base, const dac_buffer_config_t ∗


config )

Parameters

base DAC peripheral base address.


config Pointer to the configuration structure. See "dac_buffer_config_t".

8.6.7 void DAC_GetDefaultBufferConfig ( dac_buffer_config_t ∗ config )

This function initializes the DAC buffer configuration structure to default values. The default values are
as follows.

* config->triggerMode = kDAC_BufferTriggerBySoftwareMode;
* config->watermark = kDAC_BufferWatermark1Word;
* config->workMode = kDAC_BufferWorkAsNormalMode;
* config->upperLimit = DAC_DATL_COUNT - 1U;
*

MCUXpresso SDK API Reference Manual


44 NXP Semiconductors
Function Documentation

Parameters

config Pointer to the configuration structure. See "dac_buffer_config_t".

8.6.8 static void DAC_EnableBufferDMA ( DAC_Type ∗ base, bool enable )


[inline], [static]

Parameters

base DAC peripheral base address.


enable Enables or disables the feature.

8.6.9 void DAC_SetBufferValue ( DAC_Type ∗ base, uint8_t index, uint16_t value )

Parameters

base DAC peripheral base address.


index Setting the index for items in the buffer. The available index should not exceed the
size of the DAC buffer.
value Setting the value for items in the buffer. 12-bits are available.

8.6.10 static void DAC_DoSoftwareTriggerBuffer ( DAC_Type ∗ base ) [inline],


[static]

This function triggers the function using software. The read pointer of the DAC buffer is updated with one
step after this function is called. Changing the read pointer depends on the buffer’s work mode.
Parameters

base DAC peripheral base address.

8.6.11 static uint8_t DAC_GetBufferReadPointer ( DAC_Type ∗ base ) [inline],


[static]

This function gets the current read pointer of the DAC buffer. The current output value depends on the
item indexed by the read pointer. It is updated either by a software trigger or a hardware trigger.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 45
Function Documentation

Parameters

base DAC peripheral base address.

Returns
The current read pointer of the DAC buffer.

8.6.12 void DAC_SetBufferReadPointer ( DAC_Type ∗ base, uint8_t index )

This function sets the current read pointer of the DAC buffer. The current output value depends on the
item indexed by the read pointer. It is updated either by a software trigger or a hardware trigger. After the
read pointer changes, the DAC output value also changes.
Parameters

base DAC peripheral base address.


index Setting an index value for the pointer.

8.6.13 void DAC_EnableBufferInterrupts ( DAC_Type ∗ base, uint32_t mask )

Parameters

base DAC peripheral base address.


mask Mask value for interrupts. See "_dac_buffer_interrupt_enable".

8.6.14 void DAC_DisableBufferInterrupts ( DAC_Type ∗ base, uint32_t mask )

Parameters

base DAC peripheral base address.


mask Mask value for interrupts. See "_dac_buffer_interrupt_enable".

8.6.15 uint32_t DAC_GetBufferStatusFlags ( DAC_Type ∗ base )

MCUXpresso SDK API Reference Manual


46 NXP Semiconductors
Function Documentation

Parameters

base DAC peripheral base address.

Returns
Mask value for the asserted flags. See "_dac_buffer_status_flags".

8.6.16 void DAC_ClearBufferStatusFlags ( DAC_Type ∗ base, uint32_t mask )

Parameters

base DAC peripheral base address.


mask Mask value for flags. See "_dac_buffer_status_flags_t".

MCUXpresso SDK API Reference Manual


NXP Semiconductors 47
Function Documentation

MCUXpresso SDK API Reference Manual


48 NXP Semiconductors
Chapter 9
DMA: Direct Memory Access Controller Driver
9.1 Overview
The MCUXpresso SDK provides a peripheral driver for the Direct Memory Access (DMA) of MCU-
Xpresso SDK devices.

9.2 Typical use case


9.2.1 DMA Operation

Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/dma

Data Structures
• struct dma_transfer_config_t
DMA transfer configuration structure. More...
• struct dma_channel_link_config_t
DMA transfer configuration structure. More...
• struct dma_handle_t
DMA DMA handle structure. More...

Typedefs
• typedef void(∗ dma_callback )(struct _dma_handle ∗handle, void ∗userData)
Callback function prototype for the DMA driver.

Enumerations
• enum _dma_channel_status_flags {
kDMA_TransactionsBCRFlag = DMA_DSR_BCR_BCR_MASK,
kDMA_TransactionsDoneFlag = DMA_DSR_BCR_DONE_MASK,
kDMA_TransactionsBusyFlag = DMA_DSR_BCR_BSY_MASK,
kDMA_TransactionsRequestFlag = DMA_DSR_BCR_REQ_MASK,
kDMA_BusErrorOnDestinationFlag = DMA_DSR_BCR_BED_MASK,
kDMA_BusErrorOnSourceFlag = DMA_DSR_BCR_BES_MASK,
kDMA_ConfigurationErrorFlag = DMA_DSR_BCR_CE_MASK }
status flag for the DMA driver.
• enum dma_transfer_size_t {
kDMA_Transfersize32bits = 0x0U,
kDMA_Transfersize8bits,
kDMA_Transfersize16bits }
DMA transfer size type.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 49
Typical use case

• enum dma_modulo_t {
kDMA_ModuloDisable = 0x0U,
kDMA_Modulo16Bytes,
kDMA_Modulo32Bytes,
kDMA_Modulo64Bytes,
kDMA_Modulo128Bytes,
kDMA_Modulo256Bytes,
kDMA_Modulo512Bytes,
kDMA_Modulo1KBytes,
kDMA_Modulo2KBytes,
kDMA_Modulo4KBytes,
kDMA_Modulo8KBytes,
kDMA_Modulo16KBytes,
kDMA_Modulo32KBytes,
kDMA_Modulo64KBytes,
kDMA_Modulo128KBytes,
kDMA_Modulo256KBytes }
Configuration type for the DMA modulo.
• enum dma_channel_link_type_t {
kDMA_ChannelLinkDisable = 0x0U,
kDMA_ChannelLinkChannel1AndChannel2,
kDMA_ChannelLinkChannel1,
kDMA_ChannelLinkChannel1AfterBCR0 }
DMA channel link type.
• enum dma_transfer_type_t {
kDMA_MemoryToMemory = 0x0U,
kDMA_PeripheralToMemory,
kDMA_MemoryToPeripheral }
DMA transfer type.
• enum dma_transfer_options_t {
kDMA_NoOptions = 0x0U,
kDMA_EnableInterrupt }
DMA transfer options.
• enum _dma_transfer_status
DMA transfer status.

Driver version
• #define FSL_DMA_DRIVER_VERSION (MAKE_VERSION(2, 0, 1))
DMA driver version 2.0.1.

DMA Initialization and De-initialization


• void DMA_Init (DMA_Type ∗base)
Initializes the DMA peripheral.
• void DMA_Deinit (DMA_Type ∗base)
Deinitializes the DMA peripheral.

MCUXpresso SDK API Reference Manual


50 NXP Semiconductors
Typical use case

DMA Channel Operation


• void DMA_ResetChannel (DMA_Type ∗base, uint32_t channel)
Resets the DMA channel.
• void DMA_SetTransferConfig (DMA_Type ∗base, uint32_t channel, const dma_transfer_config_t
∗config)
Configures the DMA transfer attribute.
• void DMA_SetChannelLinkConfig (DMA_Type ∗base, uint32_t channel, const dma_channel_link-
_config_t ∗config)
Configures the DMA channel link feature.
• static void DMA_SetSourceAddress (DMA_Type ∗base, uint32_t channel, uint32_t srcAddr)
Sets the DMA source address for the DMA transfer.
• static void DMA_SetDestinationAddress (DMA_Type ∗base, uint32_t channel, uint32_t destAddr)
Sets the DMA destination address for the DMA transfer.
• static void DMA_SetTransferSize (DMA_Type ∗base, uint32_t channel, uint32_t size)
Sets the DMA transfer size for the DMA transfer.
• void DMA_SetModulo (DMA_Type ∗base, uint32_t channel, dma_modulo_t srcModulo, dma_-
modulo_t destModulo)
Sets the DMA modulo for the DMA transfer.
• static void DMA_EnableCycleSteal (DMA_Type ∗base, uint32_t channel, bool enable)
Enables the DMA cycle steal for the DMA transfer.
• static void DMA_EnableAutoAlign (DMA_Type ∗base, uint32_t channel, bool enable)
Enables the DMA auto align for the DMA transfer.
• static void DMA_EnableAsyncRequest (DMA_Type ∗base, uint32_t channel, bool enable)
Enables the DMA async request for the DMA transfer.
• static void DMA_EnableInterrupts (DMA_Type ∗base, uint32_t channel)
Enables an interrupt for the DMA transfer.
• static void DMA_DisableInterrupts (DMA_Type ∗base, uint32_t channel)
Disables an interrupt for the DMA transfer.

DMA Channel Transfer Operation


• static void DMA_EnableChannelRequest (DMA_Type ∗base, uint32_t channel)
Enables the DMA hardware channel request.
• static void DMA_DisableChannelRequest (DMA_Type ∗base, uint32_t channel)
Disables the DMA hardware channel request.
• static void DMA_TriggerChannelStart (DMA_Type ∗base, uint32_t channel)
Starts the DMA transfer with a software trigger.

DMA Channel Status Operation


• static uint32_t DMA_GetRemainingBytes (DMA_Type ∗base, uint32_t channel)
Gets the remaining bytes of the current DMA transfer.
• static uint32_t DMA_GetChannelStatusFlags (DMA_Type ∗base, uint32_t channel)
Gets the DMA channel status flags.
• static void DMA_ClearChannelStatusFlags (DMA_Type ∗base, uint32_t channel, uint32_t mask)
Clears the DMA channel status flags.

DMA Channel Transactional Operation


• void DMA_CreateHandle (dma_handle_t ∗handle, DMA_Type ∗base, uint32_t channel)

MCUXpresso SDK API Reference Manual


NXP Semiconductors 51
Data Structure Documentation

Creates the DMA handle.


• void DMA_SetCallback (dma_handle_t ∗handle, dma_callback callback, void ∗userData)
Sets the DMA callback function.
• void DMA_PrepareTransfer (dma_transfer_config_t ∗config, void ∗srcAddr, uint32_t srcWidth,
void ∗destAddr, uint32_t destWidth, uint32_t transferBytes, dma_transfer_type_t type)
Prepares the DMA transfer configuration structure.
• status_t DMA_SubmitTransfer (dma_handle_t ∗handle, const dma_transfer_config_t ∗config,
uint32_t options)
Submits the DMA transfer request.
• static void DMA_StartTransfer (dma_handle_t ∗handle)
DMA starts a transfer.
• static void DMA_StopTransfer (dma_handle_t ∗handle)
DMA stops a transfer.
• void DMA_AbortTransfer (dma_handle_t ∗handle)
DMA aborts a transfer.
• void DMA_HandleIRQ (dma_handle_t ∗handle)
DMA IRQ handler for current transfer complete.

9.3 Data Structure Documentation


9.3.1 struct dma_transfer_config_t

Data Fields

• uint32_t srcAddr
DMA transfer source address.
• uint32_t destAddr
DMA destination address.
• bool enableSrcIncrement
Source address increase after each transfer.
• dma_transfer_size_t srcSize
Source transfer size unit.
• bool enableDestIncrement
Destination address increase after each transfer.
• dma_transfer_size_t destSize
Destination transfer unit.
• uint32_t transferSize
The number of bytes to be transferred.

MCUXpresso SDK API Reference Manual


52 NXP Semiconductors
Data Structure Documentation

9.3.1.0.0.9 Field Documentation

9.3.1.0.0.9.1 uint32_t dma_transfer_config_t::srcAddr

9.3.1.0.0.9.2 uint32_t dma_transfer_config_t::destAddr

9.3.1.0.0.9.3 bool dma_transfer_config_t::enableSrcIncrement

9.3.1.0.0.9.4 dma_transfer_size_t dma_transfer_config_t::srcSize

9.3.1.0.0.9.5 bool dma_transfer_config_t::enableDestIncrement

9.3.1.0.0.9.6 dma_transfer_size_t dma_transfer_config_t::destSize

9.3.1.0.0.9.7 uint32_t dma_transfer_config_t::transferSize

9.3.2 struct dma_channel_link_config_t

Data Fields

• dma_channel_link_type_t linkType
Channel link type.
• uint32_t channel1
The index of channel 1.
• uint32_t channel2
The index of channel 2.

9.3.2.0.0.10 Field Documentation

9.3.2.0.0.10.1 dma_channel_link_type_t dma_channel_link_config_t::linkType

9.3.2.0.0.10.2 uint32_t dma_channel_link_config_t::channel1

9.3.2.0.0.10.3 uint32_t dma_channel_link_config_t::channel2

9.3.3 struct dma_handle_t

Data Fields

• DMA_Type ∗ base
DMA peripheral address.
• uint8_t channel
DMA channel used.
• dma_callback callback
DMA callback function.
• void ∗ userData
Callback parameter.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 53
Enumeration Type Documentation

9.3.3.0.0.11 Field Documentation

9.3.3.0.0.11.1 DMA_Type∗ dma_handle_t::base

9.3.3.0.0.11.2 uint8_t dma_handle_t::channel

9.3.3.0.0.11.3 dma_callback dma_handle_t::callback

9.3.3.0.0.11.4 void∗ dma_handle_t::userData

9.4 Macro Definition Documentation


9.4.1 #define FSL_DMA_DRIVER_VERSION (MAKE_VERSION(2, 0, 1))

9.5 Typedef Documentation


9.5.1 typedef void(∗ dma_callback)(struct _dma_handle ∗handle, void ∗userData)

9.6 Enumeration Type Documentation


9.6.1 enum _dma_channel_status_flags

Enumerator
kDMA_TransactionsBCRFlag Contains the number of bytes yet to be transferred for a given block.

kDMA_TransactionsDoneFlag Transactions Done.


kDMA_TransactionsBusyFlag Transactions Busy.
kDMA_TransactionsRequestFlag Transactions Request.
kDMA_BusErrorOnDestinationFlag Bus Error on Destination.
kDMA_BusErrorOnSourceFlag Bus Error on Source.
kDMA_ConfigurationErrorFlag Configuration Error.

9.6.2 enum dma_transfer_size_t

Enumerator
kDMA_Transfersize32bits 32 bits are transferred for every read/write
kDMA_Transfersize8bits 8 bits are transferred for every read/write
kDMA_Transfersize16bits 16b its are transferred for every read/write

9.6.3 enum dma_modulo_t

Enumerator
kDMA_ModuloDisable Buffer disabled.

MCUXpresso SDK API Reference Manual


54 NXP Semiconductors
Enumeration Type Documentation

kDMA_Modulo16Bytes Circular buffer size is 16 bytes.


kDMA_Modulo32Bytes Circular buffer size is 32 bytes.
kDMA_Modulo64Bytes Circular buffer size is 64 bytes.
kDMA_Modulo128Bytes Circular buffer size is 128 bytes.
kDMA_Modulo256Bytes Circular buffer size is 256 bytes.
kDMA_Modulo512Bytes Circular buffer size is 512 bytes.
kDMA_Modulo1KBytes Circular buffer size is 1 KB.
kDMA_Modulo2KBytes Circular buffer size is 2 KB.
kDMA_Modulo4KBytes Circular buffer size is 4 KB.
kDMA_Modulo8KBytes Circular buffer size is 8 KB.
kDMA_Modulo16KBytes Circular buffer size is 16 KB.
kDMA_Modulo32KBytes Circular buffer size is 32 KB.
kDMA_Modulo64KBytes Circular buffer size is 64 KB.
kDMA_Modulo128KBytes Circular buffer size is 128 KB.
kDMA_Modulo256KBytes Circular buffer size is 256 KB.

9.6.4 enum dma_channel_link_type_t

Enumerator
kDMA_ChannelLinkDisable No channel link.
kDMA_ChannelLinkChannel1AndChannel2 Perform a link to channel LCH1 after each cycle-
steal transfer. followed by a link to LCH2 after the BCR decrements to 0.
kDMA_ChannelLinkChannel1 Perform a link to LCH1 after each cycle-steal transfer.
kDMA_ChannelLinkChannel1AfterBCR0 Perform a link to LCH1 after the BCR decrements.

9.6.5 enum dma_transfer_type_t

Enumerator
kDMA_MemoryToMemory Memory to Memory transfer.
kDMA_PeripheralToMemory Peripheral to Memory transfer.
kDMA_MemoryToPeripheral Memory to Peripheral transfer.

9.6.6 enum dma_transfer_options_t

Enumerator
kDMA_NoOptions Transfer without options.
kDMA_EnableInterrupt Enable interrupt while transfer complete.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 55
Function Documentation

9.7 Function Documentation


9.7.1 void DMA_Init ( DMA_Type ∗ base )

This function ungates the DMA clock.

MCUXpresso SDK API Reference Manual


56 NXP Semiconductors
Function Documentation

Parameters

base DMA peripheral base address.

9.7.2 void DMA_Deinit ( DMA_Type ∗ base )

This function gates the DMA clock.


Parameters

base DMA peripheral base address.

9.7.3 void DMA_ResetChannel ( DMA_Type ∗ base, uint32_t channel )

Sets all register values to reset values and enables the cycle steal and auto stop channel request features.
Parameters

base DMA peripheral base address.


channel DMA channel number.

9.7.4 void DMA_SetTransferConfig ( DMA_Type ∗ base, uint32_t channel, const


dma_transfer_config_t ∗ config )

This function configures the transfer attribute including the source address, destination address, transfer
size, and so on. This example shows how to set up the dma_transfer_config_t parameters and how to call
the DMA_ConfigBasicTransfer function.

* dma_transfer_config_t transferConfig;
* memset(&transferConfig, 0, sizeof(transferConfig));
* transferConfig.srcAddr = (uint32_t)srcAddr;
* transferConfig.destAddr = (uint32_t)destAddr;
* transferConfig.enbaleSrcIncrement = true;
* transferConfig.enableDestIncrement = true;
* transferConfig.srcSize = kDMA_Transfersize32bits;
* transferConfig.destSize = kDMA_Transfersize32bits;
* transferConfig.transferSize = sizeof(uint32_t) * BUFF_LENGTH;
* DMA_SetTransferConfig(DMA0, 0, &transferConfig);
*

MCUXpresso SDK API Reference Manual


NXP Semiconductors 57
Function Documentation

Parameters

base DMA peripheral base address.


channel DMA channel number.
config Pointer to the DMA transfer configuration structure.

9.7.5 void DMA_SetChannelLinkConfig ( DMA_Type ∗ base, uint32_t channel,


const dma_channel_link_config_t ∗ config )

This function allows DMA channels to have their transfers linked. The current DMA channel triggers a
DMA request to the linked channels (LCH1 or LCH2) depending on the channel link type. Perform a link
to channel LCH1 after each cycle-steal transfer followed by a link to LCH2 after the BCR decrements to 0
if the type is kDMA_ChannelLinkChannel1AndChannel2. Perform a link to LCH1 after each cycle-steal
transfer if the type is kDMA_ChannelLinkChannel1. Perform a link to LCH1 after the BCR decrements
to 0 if the type is kDMA_ChannelLinkChannel1AfterBCR0.
Parameters

base DMA peripheral base address.


channel DMA channel number.
config Pointer to the channel link configuration structure.

9.7.6 static void DMA_SetSourceAddress ( DMA_Type ∗ base, uint32_t channel,


uint32_t srcAddr ) [inline], [static]

Parameters

base DMA peripheral base address.


channel DMA channel number.
srcAddr DMA source address.

9.7.7 static void DMA_SetDestinationAddress ( DMA_Type ∗ base, uint32_t


channel, uint32_t destAddr ) [inline], [static]

MCUXpresso SDK API Reference Manual


58 NXP Semiconductors
Function Documentation

Parameters

base DMA peripheral base address.


channel DMA channel number.
destAddr DMA destination address.

9.7.8 static void DMA_SetTransferSize ( DMA_Type ∗ base, uint32_t channel,


uint32_t size ) [inline], [static]

Parameters

base DMA peripheral base address.


channel DMA channel number.
size The number of bytes to be transferred.

9.7.9 void DMA_SetModulo ( DMA_Type ∗ base, uint32_t channel, dma_modulo_t


srcModulo, dma_modulo_t destModulo )

This function defines a specific address range specified to be the value after (SAR + SSIZE)/(DAR + DS-
IZE) calculation is performed or the original register value. It provides the ability to implement a circular
data queue easily.
Parameters

base DMA peripheral base address.


channel DMA channel number.
srcModulo source address modulo.
destModulo destination address modulo.

9.7.10 static void DMA_EnableCycleSteal ( DMA_Type ∗ base, uint32_t channel,


bool enable ) [inline], [static]

If the cycle steal feature is enabled (true), the DMA controller forces a single read/write transfer per
request, or it continuously makes read/write transfers until the BCR decrements to 0.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 59
Function Documentation

Parameters

base DMA peripheral base address.


channel DMA channel number.
enable The command for enable (true) or disable (false).

9.7.11 static void DMA_EnableAutoAlign ( DMA_Type ∗ base, uint32_t channel,


bool enable ) [inline], [static]

If the auto align feature is enabled (true), the appropriate address register increments regardless of DINC
or SINC.
Parameters

base DMA peripheral base address.


channel DMA channel number.
enable The command for enable (true) or disable (false).

9.7.12 static void DMA_EnableAsyncRequest ( DMA_Type ∗ base, uint32_t


channel, bool enable ) [inline], [static]

If the async request feature is enabled (true), the DMA supports asynchronous DREQs while the MCU is
in stop mode.
Parameters

base DMA peripheral base address.


channel DMA channel number.
enable The command for enable (true) or disable (false).

9.7.13 static void DMA_EnableInterrupts ( DMA_Type ∗ base, uint32_t channel )


[inline], [static]

MCUXpresso SDK API Reference Manual


60 NXP Semiconductors
Function Documentation

Parameters

base DMA peripheral base address.


channel DMA channel number.

9.7.14 static void DMA_DisableInterrupts ( DMA_Type ∗ base, uint32_t channel )


[inline], [static]

Parameters

base DMA peripheral base address.


channel DMA channel number.

9.7.15 static void DMA_EnableChannelRequest ( DMA_Type ∗ base, uint32_t


channel ) [inline], [static]

Parameters

base DMA peripheral base address.


channel The DMA channel number.

9.7.16 static void DMA_DisableChannelRequest ( DMA_Type ∗ base, uint32_t


channel ) [inline], [static]

Parameters

base DMA peripheral base address.


channel DMA channel number.

9.7.17 static void DMA_TriggerChannelStart ( DMA_Type ∗ base, uint32_t channel


) [inline], [static]

This function starts only one read/write iteration.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 61
Function Documentation

Parameters

base DMA peripheral base address.


channel The DMA channel number.

9.7.18 static uint32_t DMA_GetRemainingBytes ( DMA_Type ∗ base, uint32_t


channel ) [inline], [static]

Parameters

base DMA peripheral base address.


channel DMA channel number.

Returns
The number of bytes which have not been transferred yet.

9.7.19 static uint32_t DMA_GetChannelStatusFlags ( DMA_Type ∗ base, uint32_t


channel ) [inline], [static]

Parameters

base DMA peripheral base address.


channel DMA channel number.

Returns
The mask of the channel status. Use the _dma_channel_status_flags type to decode the return 32 bit
variables.

9.7.20 static void DMA_ClearChannelStatusFlags ( DMA_Type ∗ base, uint32_t


channel, uint32_t mask ) [inline], [static]

MCUXpresso SDK API Reference Manual


62 NXP Semiconductors
Function Documentation

Parameters

base DMA peripheral base address.


channel DMA channel number.
mask The mask of the channel status to be cleared. Use the defined _dma_channel_status-
_flags type.

9.7.21 void DMA_CreateHandle ( dma_handle_t ∗ handle, DMA_Type ∗ base,


uint32_t channel )

This function is called first if using the transactional API for the DMA. This function initializes the internal
state of the DMA handle.
Parameters

handle DMA handle pointer. The DMA handle stores callback function and parameters.
base DMA peripheral base address.
channel DMA channel number.

9.7.22 void DMA_SetCallback ( dma_handle_t ∗ handle, dma_callback callback,


void ∗ userData )

This callback is called in the DMA IRQ handler. Use the callback to do something after the current transfer
complete.
Parameters

handle DMA handle pointer.


callback DMA callback function pointer.
userData Parameter for callback function. If it is not needed, just set to NULL.

9.7.23 void DMA_PrepareTransfer ( dma_transfer_config_t ∗ config, void ∗


srcAddr, uint32_t srcWidth, void ∗ destAddr, uint32_t destWidth, uint32_t
transferBytes, dma_transfer_type_t type )

This function prepares the transfer configuration structure according to the user input.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 63
Function Documentation

Parameters

config Pointer to the user configuration structure of type dma_transfer_config_t.


srcAddr DMA transfer source address.
srcWidth DMA transfer source address width (byte).
destAddr DMA transfer destination address.
destWidth DMA transfer destination address width (byte).
transferBytes DMA transfer bytes to be transferred.
type DMA transfer type.

9.7.24 status_t DMA_SubmitTransfer ( dma_handle_t ∗ handle, const


dma_transfer_config_t ∗ config, uint32_t options )

This function submits the DMA transfer request according to the transfer configuration structure.
Parameters

handle DMA handle pointer.


config Pointer to DMA transfer configuration structure.
options Additional configurations for transfer. Use the defined dma_transfer_options_t type.

Return values

kStatus_DMA_Success It indicates that the DMA submit transfer request succeeded.


kStatus_DMA_Busy It indicates that the DMA is busy. Submit transfer request is not allowed.

Note
This function can’t process multi transfer request.

9.7.25 static void DMA_StartTransfer ( dma_handle_t ∗ handle ) [inline],


[static]

This function enables the channel request. Call this function after submitting a transfer request.

MCUXpresso SDK API Reference Manual


64 NXP Semiconductors
Function Documentation

Parameters

handle DMA handle pointer.

Return values

kStatus_DMA_Success It indicates that the DMA start transfer succeed.


kStatus_DMA_Busy It indicates that the DMA has started a transfer.

9.7.26 static void DMA_StopTransfer ( dma_handle_t ∗ handle ) [inline],


[static]

This function disables the channel request to stop a DMA transfer. The transfer can be resumed by calling
the DMA_StartTransfer.
Parameters

handle DMA handle pointer.

9.7.27 void DMA_AbortTransfer ( dma_handle_t ∗ handle )

This function disables the channel request and clears all status bits. Submit another transfer after calling
this API.
Parameters

handle DMA handle pointer.

9.7.28 void DMA_HandleIRQ ( dma_handle_t ∗ handle )

This function clears the channel interrupt flag and calls the callback function if it is not NULL.
Parameters

handle DMA handle pointer.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 65
Function Documentation

MCUXpresso SDK API Reference Manual


66 NXP Semiconductors
Chapter 10
DMAMUX: Direct Memory Access Multiplexer Driver
10.1 Overview
The MCUXpresso SDK provides a peripheral driver for the Direct Memory Access Multiplexer (DMAM-
UX) of MCUXpresso SDK devices.

10.2 Typical use case


10.2.1 DMAMUX Operation

Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/dmamux

Driver version
• #define FSL_DMAMUX_DRIVER_VERSION (MAKE_VERSION(2, 0, 3))
DMAMUX driver version 2.0.3.

DMAMUX Initialization and de-initialization


• void DMAMUX_Init (DMAMUX_Type ∗base)
Initializes the DMAMUX peripheral.
• void DMAMUX_Deinit (DMAMUX_Type ∗base)
Deinitializes the DMAMUX peripheral.

DMAMUX Channel Operation


• static void DMAMUX_EnableChannel (DMAMUX_Type ∗base, uint32_t channel)
Enables the DMAMUX channel.
• static void DMAMUX_DisableChannel (DMAMUX_Type ∗base, uint32_t channel)
Disables the DMAMUX channel.
• static void DMAMUX_SetSource (DMAMUX_Type ∗base, uint32_t channel, uint32_t source)
Configures the DMAMUX channel source.
• static void DMAMUX_EnablePeriodTrigger (DMAMUX_Type ∗base, uint32_t channel)
Enables the DMAMUX period trigger.
• static void DMAMUX_DisablePeriodTrigger (DMAMUX_Type ∗base, uint32_t channel)
Disables the DMAMUX period trigger.

10.3 Macro Definition Documentation


10.3.1 #define FSL_DMAMUX_DRIVER_VERSION (MAKE_VERSION(2, 0, 3))

MCUXpresso SDK API Reference Manual


NXP Semiconductors 67
Function Documentation

10.4 Function Documentation


10.4.1 void DMAMUX_Init ( DMAMUX_Type ∗ base )

This function ungates the DMAMUX clock.

MCUXpresso SDK API Reference Manual


68 NXP Semiconductors
Function Documentation

Parameters

base DMAMUX peripheral base address.

10.4.2 void DMAMUX_Deinit ( DMAMUX_Type ∗ base )

This function gates the DMAMUX clock.


Parameters

base DMAMUX peripheral base address.

10.4.3 static void DMAMUX_EnableChannel ( DMAMUX_Type ∗ base, uint32_t


channel ) [inline], [static]

This function enables the DMAMUX channel.


Parameters

base DMAMUX peripheral base address.


channel DMAMUX channel number.

10.4.4 static void DMAMUX_DisableChannel ( DMAMUX_Type ∗ base, uint32_t


channel ) [inline], [static]

This function disables the DMAMUX channel.

Note
The user must disable the DMAMUX channel before configuring it.

Parameters

base DMAMUX peripheral base address.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 69
Function Documentation

channel DMAMUX channel number.

10.4.5 static void DMAMUX_SetSource ( DMAMUX_Type ∗ base, uint32_t channel,


uint32_t source ) [inline], [static]

Parameters

base DMAMUX peripheral base address.


channel DMAMUX channel number.
source Channel source, which is used to trigger the DMA transfer.

10.4.6 static void DMAMUX_EnablePeriodTrigger ( DMAMUX_Type ∗ base, uint32_t


channel ) [inline], [static]

This function enables the DMAMUX period trigger feature.


Parameters

base DMAMUX peripheral base address.


channel DMAMUX channel number.

10.4.7 static void DMAMUX_DisablePeriodTrigger ( DMAMUX_Type ∗ base,


uint32_t channel ) [inline], [static]

This function disables the DMAMUX period trigger.


Parameters

base DMAMUX peripheral base address.


channel DMAMUX channel number.

MCUXpresso SDK API Reference Manual


70 NXP Semiconductors
Chapter 11
C90TFS Flash Driver
11.1 Overview
The flash provides the C90TFS Flash driver of Kinetis devices with the C90TFS Flash module inside. The
flash driver provides general APIs to handle specific operations on C90TFS/FTFx Flash module. The user
can use those APIs directly in the application. In addition, it provides internal functions called by the
driver. Although these functions are not meant to be called from the user’s application directly, the APIs
can still be used.

Modules
• Ftftx CACHE Driver
• Ftftx FLASH Driver
• Ftftx FLEXNVM Driver
• ftfx controller
• ftfx feature

MCUXpresso SDK API Reference Manual


NXP Semiconductors 71
Ftftx FLASH Driver

11.2 Ftftx FLASH Driver


11.2.1 Overview

Data Structures

• union pflash_prot_status_t
PFlash protection status. More...
• struct flash_config_t
Flash driver state information. More...

Enumerations

• enum flash_prot_state_t {
kFLASH_ProtectionStateUnprotected,
kFLASH_ProtectionStateProtected,
kFLASH_ProtectionStateMixed }
Enumeration for the three possible flash protection levels.
• enum flash_property_tag_t {
kFLASH_PropertyPflash0SectorSize = 0x00U,
kFLASH_PropertyPflash0TotalSize = 0x01U,
kFLASH_PropertyPflash0BlockSize = 0x02U,
kFLASH_PropertyPflash0BlockCount = 0x03U,
kFLASH_PropertyPflash0BlockBaseAddr = 0x04U,
kFLASH_PropertyPflash0FacSupport = 0x05U,
kFLASH_PropertyPflash0AccessSegmentSize = 0x06U,
kFLASH_PropertyPflash0AccessSegmentCount = 0x07U,
kFLASH_PropertyPflash1SectorSize = 0x10U,
kFLASH_PropertyPflash1TotalSize = 0x11U,
kFLASH_PropertyPflash1BlockSize = 0x12U,
kFLASH_PropertyPflash1BlockCount = 0x13U,
kFLASH_PropertyPflash1BlockBaseAddr = 0x14U,
kFLASH_PropertyPflash1FacSupport = 0x15U,
kFLASH_PropertyPflash1AccessSegmentSize = 0x16U,
kFLASH_PropertyPflash1AccessSegmentCount = 0x17U,
kFLASH_PropertyFlexRamBlockBaseAddr = 0x20U,
kFLASH_PropertyFlexRamTotalSize = 0x21U }
Enumeration for various flash properties.

Flash version

• #define FSL_FLASH_DRIVER_VERSION (MAKE_VERSION(3U, 0U, 0U))


Flash driver version for SDK.
• #define FSL_FLASH_DRIVER_VERSION_ROM (MAKE_VERSION(3U, 0U, 0U))
Flash driver version for ROM.

MCUXpresso SDK API Reference Manual


72 NXP Semiconductors
Ftftx FLASH Driver

Initialization

• status_t FLASH_Init (flash_config_t ∗config)


Initializes the global flash properties structure members.

Erasing

• status_t FLASH_Erase (flash_config_t ∗config, uint32_t start, uint32_t lengthInBytes, uint32_t key)
Erases the Dflash sectors encompassed by parameters passed into function.
• status_t FLASH_EraseAll (flash_config_t ∗config, uint32_t key)
Erases entire flexnvm.
• status_t FLASH_EraseAllUnsecure (flash_config_t ∗config, uint32_t key)
Erases the entire flexnvm, including protected sectors.

Programming

• status_t FLASH_Program (flash_config_t ∗config, uint32_t start, uint8_t ∗src, uint32_t lengthIn-
Bytes)
Programs flash with data at locations passed in through parameters.
• status_t FLASH_ProgramOnce (ftfx_config_t ∗config, uint32_t index, uint8_t ∗dst, uint32_t length-
InBytes)
Reads the Program Once Field through parameters.

Reading

Programs flash with data at locations passed in through parameters via the Program Section command.
This function programs the flash memory with the desired data for a given flash area as determined by the
start address and length.
Parameters

config A pointer to the storage for the driver runtime state.


start The start address of the desired flash memory to be programmed. Must be word-
aligned.
src A pointer to the source buffer of data that is to be programmed into the flash.
lengthInBytes The length, given in bytes (not words or long-words), to be programmed. Must be
word-aligned.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 73
Ftftx FLASH Driver

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_- Parameter is not aligned with specified baseline.
AlignmentError
kStatus_FTFx_Address- Address is out of range.
Error
kStatus_FTFx_Set- Failed to set flexram as RAM.
FlexramAsRamError
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during command execution.
CommandFailure
kStatus_FTFx_Recover- Failed to recover FlexRAM as EEPROM.
FlexramAsEepromError

• status_t FLASH_ReadResource (flash_config_t ∗config, uint32_t start, uint8_t ∗dst, uint32_-


t lengthInBytes, ftfx_read_resource_opt_t option)
Reads the resource with data at locations passed in through parameters.
• status_t FLASH_ReadOnce (ftfx_config_t ∗config, uint32_t index, uint8_t ∗dst, uint32_t lengthIn-
Bytes)
Reads the Program Once Field through parameters.

Verification

• status_t FLASH_VerifyErase (flash_config_t ∗config, uint32_t start, uint32_t lengthInBytes, ftfx_-


margin_value_t margin)
Verifies an erasure of the desired flash area at a specified margin level.
• status_t FLASH_VerifyEraseAll (flash_config_t ∗config, ftfx_margin_value_t margin)
Verifies erasure of the entire flash at a specified margin level.
• status_t FLASH_VerifyProgram (flash_config_t ∗config, uint32_t start, uint32_t lengthInBytes,
const uint8_t ∗expectedData, ftfx_margin_value_t margin, uint32_t ∗failedAddress, uint32_t
∗failedData)
Verifies programming of the desired flash area at a specified margin level.

MCUXpresso SDK API Reference Manual


74 NXP Semiconductors
Ftftx FLASH Driver

Security

• status_t FLASH_GetSecurityState (flash_config_t ∗config, ftfx_security_state_t ∗state)


Returns the security state via the pointer passed into the function.
• status_t FLASH_SecurityBypass (flash_config_t ∗config, const uint8_t ∗backdoorKey)
Allows users to bypass security with a backdoor key.

Protection

Swaps the lower half flash with the higher half flash.
Parameters

config A pointer to the storage for the driver runtime state.


address Address used to configure the flash swap function
isSetEnable The possible option used to configure the Flash Swap function or check the flash
Swap status.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_- Parameter is not aligned with specified baseline.
AlignmentError
kStatus_FTFx_Swap- Swap indicator address is invalid.
IndicatorAddressError
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during command execution.
CommandFailure

MCUXpresso SDK API Reference Manual


NXP Semiconductors 75
Ftftx FLASH Driver

kStatus_FTFx_Swap- Swap system is not in an uninitialized state.


SystemNotInUninitialized

• status_t FLASH_IsProtected (flash_config_t ∗config, uint32_t start, uint32_t lengthInBytes, flash_-


prot_state_t ∗protection_state)
Returns the protection state of the desired flash area via the pointer passed into the function.
• status_t FLASH_PflashSetProtection (flash_config_t ∗config, pflash_prot_status_t ∗protectStatus)
Returns the access state of the desired flash area via the pointer passed into the function.
• status_t FLASH_PflashGetProtection (flash_config_t ∗config, pflash_prot_status_t ∗protectStatus)
Gets the PFlash protection status.

Properties

• status_t FLASH_GetProperty (flash_config_t ∗config, flash_property_tag_t whichProperty, uint32-


_t ∗value)
Returns the desired flash property.

11.2.2 Data Structure Documentation

11.2.2.1 union pflash_prot_status_t

Data Fields
• uint32_t protl
PROT[31:0] .
• uint32_t proth
PROT[63:32].
• uint8_t protsl
PROTS[7:0] .
• uint8_t protsh
PROTS[15:8] .

11.2.2.1.0.12 Field Documentation

11.2.2.1.0.12.1 uint32_t pflash_prot_status_t::protl

11.2.2.1.0.12.2 uint32_t pflash_prot_status_t::proth

11.2.2.1.0.12.3 uint8_t pflash_prot_status_t::protsl

11.2.2.1.0.12.4 uint8_t pflash_prot_status_t::protsh

11.2.2.2 struct flash_config_t

An instance of this structure is allocated by the user of the flash driver and passed into each of the driver
APIs.

MCUXpresso SDK API Reference Manual


76 NXP Semiconductors
Ftftx FLASH Driver

11.2.3 Macro Definition Documentation

11.2.3.1 #define FSL_FLASH_DRIVER_VERSION (MAKE_VERSION(3U, 0U, 0U))

Version 3.0.0.

11.2.3.2 #define FSL_FLASH_DRIVER_VERSION_ROM (MAKE_VERSION(3U, 0U, 0U))

Version 3.0.0.

11.2.4 Enumeration Type Documentation

11.2.4.1 enum flash_prot_state_t

Enumerator
kFLASH_ProtectionStateUnprotected Flash region is not protected.
kFLASH_ProtectionStateProtected Flash region is protected.
kFLASH_ProtectionStateMixed Flash is mixed with protected and unprotected region.

11.2.4.2 enum flash_property_tag_t

Enumerator
kFLASH_PropertyPflash0SectorSize Pflash sector size property.
kFLASH_PropertyPflash0TotalSize Pflash total size property.
kFLASH_PropertyPflash0BlockSize Pflash block size property.
kFLASH_PropertyPflash0BlockCount Pflash block count property.
kFLASH_PropertyPflash0BlockBaseAddr Pflash block base address property.
kFLASH_PropertyPflash0FacSupport Pflash fac support property.
kFLASH_PropertyPflash0AccessSegmentSize Pflash access segment size property.
kFLASH_PropertyPflash0AccessSegmentCount Pflash access segment count property.
kFLASH_PropertyPflash1SectorSize Pflash sector size property.
kFLASH_PropertyPflash1TotalSize Pflash total size property.
kFLASH_PropertyPflash1BlockSize Pflash block size property.
kFLASH_PropertyPflash1BlockCount Pflash block count property.
kFLASH_PropertyPflash1BlockBaseAddr Pflash block base address property.
kFLASH_PropertyPflash1FacSupport Pflash fac support property.
kFLASH_PropertyPflash1AccessSegmentSize Pflash access segment size property.
kFLASH_PropertyPflash1AccessSegmentCount Pflash access segment count property.
kFLASH_PropertyFlexRamBlockBaseAddr FlexRam block base address property.
kFLASH_PropertyFlexRamTotalSize FlexRam total size property.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 77
Ftftx FLASH Driver

11.2.5 Function Documentation

11.2.5.1 status_t FLASH_Init ( flash_config_t ∗ config )

This function checks and initializes the Flash module for the other Flash APIs.

MCUXpresso SDK API Reference Manual


78 NXP Semiconductors
Ftftx FLASH Driver

Parameters

config Pointer to the storage for the driver runtime state.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Partition- Failed to update the partition status.
StatusUpdateFailure

11.2.5.2 status_t FLASH_Erase ( flash_config_t ∗ config, uint32_t start, uint32_t


lengthInBytes, uint32_t key )

This function erases the appropriate number of flash sectors based on the desired start address and length.
Parameters

config The pointer to the storage for the driver runtime state.
start The start address of the desired flash memory to be erased. The start address does not
need to be sector-aligned but must be word-aligned.
lengthInBytes The length, given in bytes (not words or long-words) to be erased. Must be word-
aligned.
key The value used to validate all flash erase APIs.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_- The parameter is not aligned with the specified baseline.
AlignmentError

MCUXpresso SDK API Reference Manual


NXP Semiconductors 79
Ftftx FLASH Driver

kStatus_FTFx_Address- The address is out of range.


Error
kStatus_FTFx_EraseKey- The API erase key is invalid.
Error
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during the command execution.
CommandFailure

11.2.5.3 status_t FLASH_EraseAll ( flash_config_t ∗ config, uint32_t key )

Parameters

config Pointer to the storage for the driver runtime state.


key A value used to validate all flash erase APIs.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_EraseKey- API erase key is invalid.
Error
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation

MCUXpresso SDK API Reference Manual


80 NXP Semiconductors
Ftftx FLASH Driver

kStatus_FTFx_- Run-time error during command execution.


CommandFailure
kStatus_FTFx_Partition- Failed to update the partition status.
StatusUpdateFailure

11.2.5.4 status_t FLASH_EraseAllUnsecure ( flash_config_t ∗ config, uint32_t key )

Parameters

config Pointer to the storage for the driver runtime state.


key A value used to validate all flash erase APIs.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_EraseKey- API erase key is invalid.
Error
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during command execution.
CommandFailure
kStatus_FTFx_Partition- Failed to update the partition status.
StatusUpdateFailure

11.2.5.5 status_t FLASH_Program ( flash_config_t ∗ config, uint32_t start, uint8_t ∗ src,


uint32_t lengthInBytes )

This function programs the flash memory with the desired data for a given flash area as determined by the
start address and the length.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 81
Ftftx FLASH Driver

Parameters

config A pointer to the storage for the driver runtime state.


start The start address of the desired flash memory to be programmed. Must be word-
aligned.
src A pointer to the source buffer of data that is to be programmed into the flash.
lengthInBytes The length, given in bytes (not words or long-words), to be programmed. Must be
word-aligned.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_- Parameter is not aligned with the specified baseline.
AlignmentError
kStatus_FTFx_Address- Address is out of range.
Error
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during the command execution.
CommandFailure

11.2.5.6 status_t FLASH_ProgramOnce ( ftfx_config_t ∗ config, uint32_t index, uint8_t ∗


dst, uint32_t lengthInBytes )

This function reads the read once feild with given index and length.
Parameters

config A pointer to the storage for the driver runtime state.

MCUXpresso SDK API Reference Manual


82 NXP Semiconductors
Ftftx FLASH Driver

index The index indicating the area of program once field to be read.
dst A pointer to the destination buffer of data that is used to store data to be read.
lengthInBytes The length, given in bytes (not words or long-words), to be programmed. Must be
word-aligned.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during the command execution.
CommandFailure

11.2.5.7 status_t FLASH_ReadResource ( flash_config_t ∗ config, uint32_t start, uint8_t


∗ dst, uint32_t lengthInBytes, ftfx_read_resource_opt_t option )

This function reads the flash memory with the desired location for a given flash area as determined by the
start address and length.
Parameters

config A pointer to the storage for the driver runtime state.


start The start address of the desired flash memory to be programmed. Must be word-
aligned.
dst A pointer to the destination buffer of data that is used to store data to be read.
lengthInBytes The length, given in bytes (not words or long-words), to be read. Must be word-
aligned.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 83
Ftftx FLASH Driver

option The resource option which indicates which area should be read back.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_- Parameter is not aligned with the specified baseline.
AlignmentError
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during the command execution.
CommandFailure

11.2.5.8 status_t FLASH_ReadOnce ( ftfx_config_t ∗ config, uint32_t index, uint8_t ∗ dst,


uint32_t lengthInBytes )

This function reads the read once feild with given index and length.
Parameters

config A pointer to the storage for the driver runtime state.


index The index indicating the area of program once field to be read.
dst A pointer to the destination buffer of data that is used to store data to be read.
lengthInBytes The length, given in bytes (not words or long-words), to be programmed. Must be
word-aligned.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument

MCUXpresso SDK API Reference Manual


84 NXP Semiconductors
Ftftx FLASH Driver

kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.


RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during the command execution.
CommandFailure

11.2.5.9 status_t FLASH_VerifyErase ( flash_config_t ∗ config, uint32_t start, uint32_t


lengthInBytes, ftfx_margin_value_t margin )

This function checks the appropriate number of flash sectors based on the desired start address and length
to check whether the flash is erased to the specified read margin level.
Parameters

config A pointer to the storage for the driver runtime state.


start The start address of the desired flash memory to be verified. The start address does
not need to be sector-aligned but must be word-aligned.
lengthInBytes The length, given in bytes (not words or long-words), to be verified. Must be word-
aligned.
margin Read margin choice.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_- Parameter is not aligned with specified baseline.
AlignmentError
kStatus_FTFx_Address- Address is out of range.
Error

MCUXpresso SDK API Reference Manual


NXP Semiconductors 85
Ftftx FLASH Driver

kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.


RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during the command execution.
CommandFailure

11.2.5.10 status_t FLASH_VerifyEraseAll ( flash_config_t ∗ config, ftfx_margin_value_t


margin )

This function checks whether the flash is erased to the specified read margin level.
Parameters

config A pointer to the storage for the driver runtime state.


margin Read margin choice.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during the command execution.
CommandFailure

11.2.5.11 status_t FLASH_VerifyProgram ( flash_config_t ∗ config, uint32_t start,


uint32_t lengthInBytes, const uint8_t ∗ expectedData, ftfx_margin_value_t
margin, uint32_t ∗ failedAddress, uint32_t ∗ failedData )

This function verifies the data programmed in the flash memory using the Flash Program Check Command
and compares it to the expected data for a given flash area as determined by the start address and length.

MCUXpresso SDK API Reference Manual


86 NXP Semiconductors
Ftftx FLASH Driver

Parameters

config A pointer to the storage for the driver runtime state.


start The start address of the desired flash memory to be verified. Must be word-aligned.
lengthInBytes The length, given in bytes (not words or long-words), to be verified. Must be word-
aligned.
expectedData A pointer to the expected data that is to be verified against.
margin Read margin choice.
failedAddress A pointer to the returned failing address.
failedData A pointer to the returned failing data. Some derivatives do not include failed data as
part of the FCCOBx registers. In this case, zeros are returned upon failure.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_- Parameter is not aligned with specified baseline.
AlignmentError
kStatus_FTFx_Address- Address is out of range.
Error
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during the command execution.
CommandFailure

11.2.5.12 status_t FLASH_GetSecurityState ( flash_config_t ∗ config, ftfx_security_state_t


∗ state )

This function retrieves the current flash security status, including the security enabling state and the back-
door key enabling state.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 87
Ftftx FLASH Driver

Parameters

config A pointer to storage for the driver runtime state.


state A pointer to the value returned for the current security status code:

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument

11.2.5.13 status_t FLASH_SecurityBypass ( flash_config_t ∗ config, const uint8_t ∗


backdoorKey )

If the MCU is in secured state, this function unsecures the MCU by comparing the provided backdoor key
with ones in the flash configuration field.
Parameters

config A pointer to the storage for the driver runtime state.


backdoorKey A pointer to the user buffer containing the backdoor key.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during the command execution.
CommandFailure

MCUXpresso SDK API Reference Manual


88 NXP Semiconductors
Ftftx FLASH Driver

11.2.5.14 status_t FLASH_IsProtected ( flash_config_t ∗ config, uint32_t start, uint32_t


lengthInBytes, flash_prot_state_t ∗ protection_state )

This function retrieves the current flash protect status for a given flash area as determined by the start
address and length.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 89
Ftftx FLASH Driver

Parameters

config A pointer to the storage for the driver runtime state.


start The start address of the desired flash memory to be checked. Must be word-aligned.
lengthInBytes The length, given in bytes (not words or long-words) to be checked. Must be word-
aligned.
protection_- A pointer to the value returned for the current protection status code for the desired
state flash area.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_- Parameter is not aligned with specified baseline.
AlignmentError
kStatus_FTFx_Address- The address is out of range.
Error

11.2.5.15 status_t FLASH_PflashSetProtection ( flash_config_t ∗ config,


pflash_prot_status_t ∗ protectStatus )

This function retrieves the current flash access status for a given flash area as determined by the start
address and length.
Parameters

config A pointer to the storage for the driver runtime state.


start The start address of the desired flash memory to be checked. Must be word-aligned.
lengthInBytes The length, given in bytes (not words or long-words), to be checked. Must be word-
aligned.
access_state A pointer to the value returned for the current access status code for the desired flash
area.

Return values

MCUXpresso SDK API Reference Manual


90 NXP Semiconductors
Ftftx FLASH Driver

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_- The parameter is not aligned to the specified baseline.
AlignmentError
kStatus_FTFx_Address- The address is out of range.
Error
Sets the PFlash Protection to the intended protection status.
Parameters

config A pointer to storage for the driver runtime state.


protectStatus The expected protect status to set to the PFlash protection register. Each bit is cor-
responding to protection of 1/32(64) of the total PFlash. The least significant bit is
corresponding to the lowest address area of PFlash. The most significant bit is corre-
sponding to the highest address area of PFlash. There are two possible cases as shown
below: 0: this area is protected. 1: this area is unprotected.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_- Run-time error during command execution.
CommandFailure

11.2.5.16 status_t FLASH_PflashGetProtection ( flash_config_t ∗ config,


pflash_prot_status_t ∗ protectStatus )

Parameters

config A pointer to the storage for the driver runtime state.


protectStatus Protect status returned by the PFlash IP. Each bit is corresponding to the protection of
1/32(64) of the total PFlash. The least significant bit corresponds to the lowest address
area of the PFlash. The most significant bit corresponds to the highest address area
of PFlash. There are two possible cases as shown below: 0: this area is protected. 1:
this area is unprotected.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 91
Ftftx FLASH Driver

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument

11.2.5.17 status_t FLASH_GetProperty ( flash_config_t ∗ config, flash_property_tag_t


whichProperty, uint32_t ∗ value )

Parameters

config A pointer to the storage for the driver runtime state.


whichProperty The desired property from the list of properties in enum flash_property_tag_t
value A pointer to the value returned for the desired flash property.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_Unknown- An unknown property tag.
Property

MCUXpresso SDK API Reference Manual


92 NXP Semiconductors
Ftftx CACHE Driver

11.3 Ftftx CACHE Driver


11.3.1 Overview

Data Structures

• struct ftfx_prefetch_speculation_status_t
FTFx prefetch speculation status. More...
• struct ftfx_cache_config_t
FTFx cache driver state information. More...

Enumerations

• enum _ftfx_cache_ram_func_constants { kFTFx_CACHE_RamFuncMaxSizeInWords = 16U }


Constants for execute-in-RAM flash function.

Functions

• status_t FTFx_CACHE_Init (ftfx_cache_config_t ∗config)


Initializes the global FTFx cache structure members.
• status_t FTFx_CACHE_ClearCachePrefetchSpeculation (ftfx_cache_config_t ∗config, bool isPre-
Process)
Process the cache/prefetch/speculation to the flash.
• status_t FTFx_CACHE_PflashSetPrefetchSpeculation (ftfx_prefetch_speculation_status_t ∗speculation-
Status)
Sets the PFlash prefetch speculation to the intended speculation status.
• status_t FTFx_CACHE_PflashGetPrefetchSpeculation (ftfx_prefetch_speculation_status_t ∗speculation-
Status)
Gets the PFlash prefetch speculation status.

FTFx cache version

• #define FSL_FTFX_CACHE_DRIVER_VERSION (MAKE_VERSION(3, 0, 0))


Flexnvm driver version for SDK.

11.3.2 Data Structure Documentation

11.3.2.1 struct ftfx_prefetch_speculation_status_t

Data Fields
• bool instructionOff
Instruction speculation.
• bool dataOff

MCUXpresso SDK API Reference Manual


NXP Semiconductors 93
Ftftx CACHE Driver

Data speculation.

11.3.2.1.0.13 Field Documentation

11.3.2.1.0.13.1 bool ftfx_prefetch_speculation_status_t::instructionOff

11.3.2.1.0.13.2 bool ftfx_prefetch_speculation_status_t::dataOff

11.3.2.2 struct ftfx_cache_config_t

An instance of this structure is allocated by the user of the flash driver and passed into each of the driver
APIs.

Data Fields
• uint8_t flashMemoryIndex
0 - primary flash; 1 - secondary flash
• uint32_t ∗ comBitOperFuncAddr
An buffer point to the flash execute-in-RAM function.

11.3.2.2.0.14 Field Documentation

11.3.2.2.0.14.1 uint32_t∗ ftfx_cache_config_t::comBitOperFuncAddr

11.3.3 Macro Definition Documentation

11.3.3.1 #define FSL_FTFX_CACHE_DRIVER_VERSION (MAKE_VERSION(3, 0, 0))

Version 1.0.0.

11.3.4 Enumeration Type Documentation

11.3.4.1 enum _ftfx_cache_ram_func_constants

Enumerator
kFTFx_CACHE_RamFuncMaxSizeInWords The maximum size of execute-in-RAM function.

11.3.5 Function Documentation

11.3.5.1 status_t FTFx_CACHE_Init ( ftfx_cache_config_t ∗ config )

This function checks and initializes the Flash module for the other FTFx cache APIs.

MCUXpresso SDK API Reference Manual


94 NXP Semiconductors
Ftftx CACHE Driver

Parameters

config Pointer to the storage for the driver runtime state.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady

11.3.5.2 status_t FTFx_CACHE_ClearCachePrefetchSpeculation ( ftfx_cache_config_t ∗


config, bool isPreProcess )

Parameters

config A pointer to the storage for the driver runtime state.


process The possible option used to control flash cache/prefetch/speculation

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- Invalid argument is provided.
Argument
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady

11.3.5.3 status_t FTFx_CACHE_PflashSetPrefetchSpeculation ( ftfx_prefetch_-


speculation_status_t ∗ speculationStatus )

Parameters

speculation- The expected protect status to set to the PFlash protection register. Each bit is
Status

MCUXpresso SDK API Reference Manual


NXP Semiconductors 95
Ftftx CACHE Driver

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid speculation option argument is provided.
SpeculationOption

11.3.5.4 status_t FTFx_CACHE_PflashGetPrefetchSpeculation ( ftfx_prefetch_-


speculation_status_t ∗ speculationStatus )

Parameters

speculation- Speculation status returned by the PFlash IP.


Status

Return values

kStatus_FTFx_Success API was executed successfully.

MCUXpresso SDK API Reference Manual


96 NXP Semiconductors
Ftftx FLEXNVM Driver

11.4 Ftftx FLEXNVM Driver


11.4.1 Overview

Data Structures

• struct flexnvm_config_t
Flexnvm driver state information. More...

Enumerations

• enum flexnvm_property_tag_t {
kFLEXNVM_PropertyDflashSectorSize = 0x00U,
kFLEXNVM_PropertyDflashTotalSize = 0x01U,
kFLEXNVM_PropertyDflashBlockSize = 0x02U,
kFLEXNVM_PropertyDflashBlockCount = 0x03U,
kFLEXNVM_PropertyDflashBlockBaseAddr = 0x04U,
kFLEXNVM_PropertyFlexRamBlockBaseAddr = 0x05U,
kFLEXNVM_PropertyFlexRamTotalSize = 0x06U,
kFLEXNVM_PropertyEepromTotalSize = 0x07U }
Enumeration for various flexnvm properties.

Functions

• status_t FLEXNVM_EepromWrite (flexnvm_config_t ∗config, uint32_t start, uint8_t ∗src, uint32_t


lengthInBytes)
Sets the FlexRAM function command.

Flexnvm version

• #define FSL_FLEXNVM_DRIVER_VERSION (MAKE_VERSION(3, 0, 0))


Flexnvm driver version for SDK.

Initialization

• status_t FLEXNVM_Init (flexnvm_config_t ∗config)


Initializes the global flash properties structure members.

Erasing

• status_t FLEXNVM_DflashErase (flexnvm_config_t ∗config, uint32_t start, uint32_t lengthInBytes,


uint32_t key)

MCUXpresso SDK API Reference Manual


NXP Semiconductors 97
Ftftx FLEXNVM Driver

Erases the Dflash sectors encompassed by parameters passed into function.


• status_t FLEXNVM_EraseAll (flexnvm_config_t ∗config, uint32_t key)
Erases entire flexnvm.
• status_t FLEXNVM_EraseAllUnsecure (flexnvm_config_t ∗config, uint32_t key)
Erases the entire flexnvm, including protected sectors.

Programming

• status_t FLEXNVM_DflashProgram (flexnvm_config_t ∗config, uint32_t start, uint8_t ∗src, uint32-


_t lengthInBytes)
Programs flash with data at locations passed in through parameters.
• status_t FLEXNVM_ProgramPartition (flexnvm_config_t ∗config, ftfx_partition_flexram_load_-
opt_t option, uint32_t eepromDataSizeCode, uint32_t flexnvmPartitionCode)
Programs flash with data at locations passed in through parameters via the Program Section command.

Reading

• status_t FLEXNVM_ReadResource (flexnvm_config_t ∗config, uint32_t start, uint8_t ∗dst, uint32-


_t lengthInBytes, ftfx_read_resource_opt_t option)
Reads the resource with data at locations passed in through parameters.

Verification

• status_t FLEXNVM_DflashVerifyErase (flexnvm_config_t ∗config, uint32_t start, uint32_t length-


InBytes, ftfx_margin_value_t margin)
Verifies an erasure of the desired flash area at a specified margin level.
• status_t FLEXNVM_VerifyEraseAll (flexnvm_config_t ∗config, ftfx_margin_value_t margin)
Verifies erasure of the entire flash at a specified margin level.
• status_t FLEXNVM_DflashVerifyProgram (flexnvm_config_t ∗config, uint32_t start, uint32_t
lengthInBytes, const uint8_t ∗expectedData, ftfx_margin_value_t margin, uint32_t ∗failedAddress,
uint32_t ∗failedData)
Verifies programming of the desired flash area at a specified margin level.

Security

• status_t FLEXNVM_GetSecurityState (flexnvm_config_t ∗config, ftfx_security_state_t ∗state)


Returns the security state via the pointer passed into the function.
• status_t FLEXNVM_SecurityBypass (flexnvm_config_t ∗config, const uint8_t ∗backdoorKey)
Allows users to bypass security with a backdoor key.

Flash Protection Utilities

• status_t FLEXNVM_DflashSetProtection (flexnvm_config_t ∗config, uint8_t protectStatus)

MCUXpresso SDK API Reference Manual


98 NXP Semiconductors
Ftftx FLEXNVM Driver

Sets the DFlash protection to the intended protection status.


• status_t FLEXNVM_DflashGetProtection (flexnvm_config_t ∗config, uint8_t ∗protectStatus)
Gets the DFlash protection status.
• status_t FLEXNVM_EepromSetProtection (flexnvm_config_t ∗config, uint8_t protectStatus)
Sets the EEPROM protection to the intended protection status.
• status_t FLEXNVM_EepromGetProtection (flexnvm_config_t ∗config, uint8_t ∗protectStatus)
Gets the EEPROM protection status.

Properties

• status_t FLEXNVM_GetProperty (flexnvm_config_t ∗config, flexnvm_property_tag_t which-


Property, uint32_t ∗value)
Returns the desired flexnvm property.

11.4.2 Data Structure Documentation

11.4.2.1 struct flexnvm_config_t

An instance of this structure is allocated by the user of the Flexnvm driver and passed into each of the
driver APIs.

11.4.3 Macro Definition Documentation

11.4.3.1 #define FSL_FLEXNVM_DRIVER_VERSION (MAKE_VERSION(3, 0, 0))

Version 1.0.0.

11.4.4 Enumeration Type Documentation

11.4.4.1 enum flexnvm_property_tag_t

Enumerator
kFLEXNVM_PropertyDflashSectorSize Dflash sector size property.
kFLEXNVM_PropertyDflashTotalSize Dflash total size property.
kFLEXNVM_PropertyDflashBlockSize Dflash block size property.
kFLEXNVM_PropertyDflashBlockCount Dflash block count property.
kFLEXNVM_PropertyDflashBlockBaseAddr Dflash block base address property.
kFLEXNVM_PropertyFlexRamBlockBaseAddr FlexRam block base address property.
kFLEXNVM_PropertyFlexRamTotalSize FlexRam total size property.
kFLEXNVM_PropertyEepromTotalSize EEPROM total size property.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 99
Ftftx FLEXNVM Driver

11.4.5 Function Documentation

11.4.5.1 status_t FLEXNVM_Init ( flexnvm_config_t ∗ config )

This function checks and initializes the Flash module for the other Flash APIs.

MCUXpresso SDK API Reference Manual


100 NXP Semiconductors
Ftftx FLEXNVM Driver

Parameters

config Pointer to the storage for the driver runtime state.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Partition- Failed to update the partition status.
StatusUpdateFailure

11.4.5.2 status_t FLEXNVM_DflashErase ( flexnvm_config_t ∗ config, uint32_t start,


uint32_t lengthInBytes, uint32_t key )

This function erases the appropriate number of flash sectors based on the desired start address and length.
Parameters

config The pointer to the storage for the driver runtime state.
start The start address of the desired flash memory to be erased. The start address does not
need to be sector-aligned but must be word-aligned.
lengthInBytes The length, given in bytes (not words or long-words) to be erased. Must be word-
aligned.
key The value used to validate all flash erase APIs.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_- The parameter is not aligned with the specified baseline.
AlignmentError

MCUXpresso SDK API Reference Manual


NXP Semiconductors 101
Ftftx FLEXNVM Driver

kStatus_FTFx_Address- The address is out of range.


Error
kStatus_FTFx_EraseKey- The API erase key is invalid.
Error
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during the command execution.
CommandFailure

11.4.5.3 status_t FLEXNVM_EraseAll ( flexnvm_config_t ∗ config, uint32_t key )

Parameters

config Pointer to the storage for the driver runtime state.


key A value used to validate all flash erase APIs.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_EraseKey- API erase key is invalid.
Error
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation

MCUXpresso SDK API Reference Manual


102 NXP Semiconductors
Ftftx FLEXNVM Driver

kStatus_FTFx_- Run-time error during command execution.


CommandFailure
kStatus_FTFx_Partition- Failed to update the partition status.
StatusUpdateFailure

11.4.5.4 status_t FLEXNVM_EraseAllUnsecure ( flexnvm_config_t ∗ config, uint32_t key )

Parameters

config Pointer to the storage for the driver runtime state.


key A value used to validate all flash erase APIs.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_EraseKey- API erase key is invalid.
Error
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during command execution.
CommandFailure
kStatus_FTFx_Partition- Failed to update the partition status.
StatusUpdateFailure

11.4.5.5 status_t FLEXNVM_DflashProgram ( flexnvm_config_t ∗ config, uint32_t start,


uint8_t ∗ src, uint32_t lengthInBytes )

This function programs the flash memory with the desired data for a given flash area as determined by the
start address and the length.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 103
Ftftx FLEXNVM Driver

Parameters

config A pointer to the storage for the driver runtime state.


start The start address of the desired flash memory to be programmed. Must be word-
aligned.
src A pointer to the source buffer of data that is to be programmed into the flash.
lengthInBytes The length, given in bytes (not words or long-words), to be programmed. Must be
word-aligned.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_- Parameter is not aligned with the specified baseline.
AlignmentError
kStatus_FTFx_Address- Address is out of range.
Error
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during the command execution.
CommandFailure

11.4.5.6 status_t FLEXNVM_ProgramPartition ( flexnvm_config_t ∗ config,


ftfx_partition_flexram_load_opt_t option, uint32_t eepromDataSizeCode,
uint32_t flexnvmPartitionCode )

This function programs the flash memory with the desired data for a given flash area as determined by the
start address and length.
Parameters

MCUXpresso SDK API Reference Manual


104 NXP Semiconductors
Ftftx FLEXNVM Driver

config A pointer to the storage for the driver runtime state.


start The start address of the desired flash memory to be programmed. Must be word-
aligned.
src A pointer to the source buffer of data that is to be programmed into the flash.
lengthInBytes The length, given in bytes (not words or long-words), to be programmed. Must be
word-aligned.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_- Parameter is not aligned with specified baseline.
AlignmentError
kStatus_FTFx_Address- Address is out of range.
Error
kStatus_FTFx_Set- Failed to set flexram as RAM.
FlexramAsRamError
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during command execution.
CommandFailure
kStatus_FTFx_Recover- Failed to recover FlexRAM as EEPROM.
FlexramAsEepromError
Prepares the FlexNVM block for use as data flash, EEPROM backup, or a combination of both and ini-
tializes the FlexRAM.
Parameters

config Pointer to storage for the driver runtime state.


option The option used to set FlexRAM load behavior during reset.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 105
Ftftx FLEXNVM Driver

eepromData- Determines the amount of FlexRAM used in each of the available EEPROM subsys-
SizeCode tems.
flexnvm- Specifies how to split the FlexNVM block between data flash memory and EEPROM
PartitionCode backup memory supporting EEPROM functions.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- Invalid argument is provided.
Argument
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during command execution.
CommandFailure

11.4.5.7 status_t FLEXNVM_ReadResource ( flexnvm_config_t ∗ config, uint32_t start,


uint8_t ∗ dst, uint32_t lengthInBytes, ftfx_read_resource_opt_t option )

This function reads the flash memory with the desired location for a given flash area as determined by the
start address and length.
Parameters

config A pointer to the storage for the driver runtime state.


start The start address of the desired flash memory to be programmed. Must be word-
aligned.
dst A pointer to the destination buffer of data that is used to store data to be read.
lengthInBytes The length, given in bytes (not words or long-words), to be read. Must be word-
aligned.

MCUXpresso SDK API Reference Manual


106 NXP Semiconductors
Ftftx FLEXNVM Driver

option The resource option which indicates which area should be read back.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_- Parameter is not aligned with the specified baseline.
AlignmentError
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during the command execution.
CommandFailure

11.4.5.8 status_t FLEXNVM_DflashVerifyErase ( flexnvm_config_t ∗ config, uint32_t start,


uint32_t lengthInBytes, ftfx_margin_value_t margin )

This function checks the appropriate number of flash sectors based on the desired start address and length
to check whether the flash is erased to the specified read margin level.
Parameters

config A pointer to the storage for the driver runtime state.


start The start address of the desired flash memory to be verified. The start address does
not need to be sector-aligned but must be word-aligned.
lengthInBytes The length, given in bytes (not words or long-words), to be verified. Must be word-
aligned.
margin Read margin choice.

Return values

MCUXpresso SDK API Reference Manual


NXP Semiconductors 107
Ftftx FLEXNVM Driver

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_- Parameter is not aligned with specified baseline.
AlignmentError
kStatus_FTFx_Address- Address is out of range.
Error
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during the command execution.
CommandFailure

11.4.5.9 status_t FLEXNVM_VerifyEraseAll ( flexnvm_config_t ∗ config,


ftfx_margin_value_t margin )

This function checks whether the flash is erased to the specified read margin level.
Parameters

config A pointer to the storage for the driver runtime state.


margin Read margin choice.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady

MCUXpresso SDK API Reference Manual


108 NXP Semiconductors
Ftftx FLEXNVM Driver

kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.


Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during the command execution.
CommandFailure

11.4.5.10 status_t FLEXNVM_DflashVerifyProgram ( flexnvm_config_t ∗ config,


uint32_t start, uint32_t lengthInBytes, const uint8_t ∗ expectedData,
ftfx_margin_value_t margin, uint32_t ∗ failedAddress, uint32_t ∗ failedData )

This function verifies the data programmed in the flash memory using the Flash Program Check Command
and compares it to the expected data for a given flash area as determined by the start address and length.
Parameters

config A pointer to the storage for the driver runtime state.


start The start address of the desired flash memory to be verified. Must be word-aligned.
lengthInBytes The length, given in bytes (not words or long-words), to be verified. Must be word-
aligned.
expectedData A pointer to the expected data that is to be verified against.
margin Read margin choice.
failedAddress A pointer to the returned failing address.
failedData A pointer to the returned failing data. Some derivatives do not include failed data as
part of the FCCOBx registers. In this case, zeros are returned upon failure.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_- Parameter is not aligned with specified baseline.
AlignmentError

MCUXpresso SDK API Reference Manual


NXP Semiconductors 109
Ftftx FLEXNVM Driver

kStatus_FTFx_Address- Address is out of range.


Error
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during the command execution.
CommandFailure

11.4.5.11 status_t FLEXNVM_GetSecurityState ( flexnvm_config_t ∗ config,


ftfx_security_state_t ∗ state )

This function retrieves the current flash security status, including the security enabling state and the back-
door key enabling state.
Parameters

config A pointer to storage for the driver runtime state.


state A pointer to the value returned for the current security status code:

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument

11.4.5.12 status_t FLEXNVM_SecurityBypass ( flexnvm_config_t ∗ config, const uint8_t ∗


backdoorKey )

If the MCU is in secured state, this function unsecures the MCU by comparing the provided backdoor key
with ones in the flash configuration field.
Parameters

MCUXpresso SDK API Reference Manual


110 NXP Semiconductors
Ftftx FLEXNVM Driver

config A pointer to the storage for the driver runtime state.


backdoorKey A pointer to the user buffer containing the backdoor key.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during the command execution.
CommandFailure

11.4.5.13 status_t FLEXNVM_EepromWrite ( flexnvm_config_t ∗ config, uint32_t start,


uint8_t ∗ src, uint32_t lengthInBytes )

Parameters

config A pointer to the storage for the driver runtime state.


option The option used to set the work mode of FlexRAM.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error

MCUXpresso SDK API Reference Manual


NXP Semiconductors 111
Ftftx FLEXNVM Driver

kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.


ProtectionViolation
kStatus_FTFx_- Run-time error during the command execution.
CommandFailure
Programs the EEPROM with data at locations passed in through parameters.
This function programs the emulated EEPROM with the desired data for a given flash area as determined
by the start address and length.
Parameters

config A pointer to the storage for the driver runtime state.


start The start address of the desired flash memory to be programmed. Must be word-
aligned.
src A pointer to the source buffer of data that is to be programmed into the flash.
lengthInBytes The length, given in bytes (not words or long-words), to be programmed. Must be
word-aligned.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_Address- Address is out of range.
Error
kStatus_FTFx_Set- Failed to set flexram as eeprom.
FlexramAsEepromError
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_Recover- Failed to recover the FlexRAM as RAM.
FlexramAsRamError

11.4.5.14 status_t FLEXNVM_DflashSetProtection ( flexnvm_config_t ∗ config, uint8_t


protectStatus )

Parameters

MCUXpresso SDK API Reference Manual


112 NXP Semiconductors
Ftftx FLEXNVM Driver

config A pointer to the storage for the driver runtime state.


protectStatus The expected protect status to set to the DFlash protection register. Each bit cor-
responds to the protection of the 1/8 of the total DFlash. The least significant bit
corresponds to the lowest address area of the DFlash. The most significant bit cor-
responds to the highest address area of the DFlash. There are two possible cases as
shown below: 0: this area is protected. 1: this area is unprotected.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_- Flash API is not supported.
CommandNotSupported
kStatus_FTFx_- Run-time error during command execution.
CommandFailure

11.4.5.15 status_t FLEXNVM_DflashGetProtection ( flexnvm_config_t ∗ config, uint8_t ∗


protectStatus )

Parameters

config A pointer to the storage for the driver runtime state.


protectStatus DFlash Protect status returned by the PFlash IP. Each bit corresponds to the protection
of the 1/8 of the total DFlash. The least significant bit corresponds to the lowest
address area of the DFlash. The most significant bit corresponds to the highest address
area of the DFlash, and so on. There are two possible cases as below: 0: this area is
protected. 1: this area is unprotected.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument

MCUXpresso SDK API Reference Manual


NXP Semiconductors 113
Ftftx FLEXNVM Driver

kStatus_FTFx_- Flash API is not supported.


CommandNotSupported

11.4.5.16 status_t FLEXNVM_EepromSetProtection ( flexnvm_config_t ∗ config, uint8_t


protectStatus )

Parameters

config A pointer to the storage for the driver runtime state.


protectStatus The expected protect status to set to the EEPROM protection register. Each bit cor-
responds to the protection of the 1/8 of the total EEPROM. The least significant bit
corresponds to the lowest address area of the EEPROM. The most significant bit cor-
responds to the highest address area of EEPROM, and so on. There are two possible
cases as shown below: 0: this area is protected. 1: this area is unprotected.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_- Flash API is not supported.
CommandNotSupported
kStatus_FTFx_- Run-time error during command execution.
CommandFailure

11.4.5.17 status_t FLEXNVM_EepromGetProtection ( flexnvm_config_t ∗ config, uint8_t ∗


protectStatus )

Parameters

config A pointer to the storage for the driver runtime state.


protectStatus DFlash Protect status returned by the PFlash IP. Each bit corresponds to the protection
of the 1/8 of the total EEPROM. The least significant bit corresponds to the lowest
address area of the EEPROM. The most significant bit corresponds to the highest
address area of the EEPROM. There are two possible cases as below: 0: this area is
protected. 1: this area is unprotected.

MCUXpresso SDK API Reference Manual


114 NXP Semiconductors
Ftftx FLEXNVM Driver

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_- Flash API is not supported.
CommandNotSupported

11.4.5.18 status_t FLEXNVM_GetProperty ( flexnvm_config_t ∗ config,


flexnvm_property_tag_t whichProperty, uint32_t ∗ value )

Parameters

config A pointer to the storage for the driver runtime state.


whichProperty The desired property from the list of properties in enum flexnvm_property_tag_t
value A pointer to the value returned for the desired flexnvm property.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_Unknown- An unknown property tag.
Property

MCUXpresso SDK API Reference Manual


NXP Semiconductors 115
ftfx feature

11.5 ftfx feature


11.5.1 Overview

Modules

• ftfx adapter

Macros

• #define FTFx_DRIVER_HAS_FLASH1_SUPPORT (0)


Indicates whether the secondary flash is supported in the Flash driver.

FTFx configuration

• #define FTFx_DRIVER_IS_FLASH_RESIDENT 1
Flash driver location.
• #define FTFx_DRIVER_IS_EXPORTED 0
Flash Driver Export option.

Secondary flash configuration

• #define FTFx_FLASH1_HAS_PROT_CONTROL (0)


Indicates whether the secondary flash has its own protection register in flash module.
• #define FTFx_FLASH1_HAS_XACC_CONTROL (0)
Indicates whether the secondary flash has its own Execute-Only access register in flash module.

11.5.2 Macro Definition Documentation

11.5.2.1 #define FTFx_DRIVER_IS_FLASH_RESIDENT 1

Used for the flash resident application.

11.5.2.2 #define FTFx_DRIVER_IS_EXPORTED 0

Used for the MCUXpresso SDK application.

11.5.2.3 #define FTFx_FLASH1_HAS_PROT_CONTROL (0)

11.5.2.4 #define FTFx_FLASH1_HAS_XACC_CONTROL (0)

MCUXpresso SDK API Reference Manual


116 NXP Semiconductors
ftfx feature

11.5.3 ftfx adapter

MCUXpresso SDK API Reference Manual


NXP Semiconductors 117
ftfx controller

11.6 ftfx controller


11.6.1 Overview

Modules

• ftfx utilities

Data Structures

• struct ftfx_spec_mem_t
ftfx special memory access information. More...
• struct ftfx_mem_desc_t
Flash memory descriptor. More...
• struct ftfx_ops_config_t
Active FTFx information for the current operation. More...
• struct ftfx_ifr_desc_t
Flash IFR memory descriptor. More...
• struct ftfx_config_t
Flash driver state information. More...

Enumerations

• enum ftfx_partition_flexram_load_opt_t {
kFTFx_PartitionFlexramLoadOptLoadedWithValidEepromData,
kFTFx_PartitionFlexramLoadOptNotLoaded = 0x01U }
Enumeration for the FlexRAM load during reset option.
• enum ftfx_read_resource_opt_t {
kFTFx_ResourceOptionFlashIfr,
kFTFx_ResourceOptionVersionId = 0x01U }
Enumeration for the two possible options of flash read resource command.
• enum ftfx_margin_value_t {
kFTFx_MarginValueNormal,
kFTFx_MarginValueUser,
kFTFx_MarginValueFactory,
kFTFx_MarginValueInvalid }
Enumeration for supported FTFx margin levels.
• enum ftfx_security_state_t {
kFTFx_SecurityStateNotSecure = (int)0xc33cc33c,
kFTFx_SecurityStateBackdoorEnabled = (int)0x5aa55aa5,
kFTFx_SecurityStateBackdoorDisabled = (int)0x5ac33ca5 }
Enumeration for the three possible FTFx security states.
• enum ftfx_flexram_func_opt_t {
kFTFx_FlexramFuncOptAvailableAsRam = 0xFFU,
kFTFx_FlexramFuncOptAvailableForEeprom = 0x00U }
Enumeration for the two possilbe options of set FlexRAM function command.

MCUXpresso SDK API Reference Manual


118 NXP Semiconductors
ftfx controller

• enum ftfx_swap_state_t {
kFTFx_SwapStateUninitialized = 0x00U,
kFTFx_SwapStateReady = 0x01U,
kFTFx_SwapStateUpdate = 0x02U,
kFTFx_SwapStateUpdateErased = 0x03U,
kFTFx_SwapStateComplete = 0x04U,
kFTFx_SwapStateDisabled = 0x05U }
Enumeration for the possible flash Swap status.
• enum _ftfx_memory_type
Enumeration for FTFx memory type.

Variables

• uint32_t ftfx_spec_mem_t::base
Base address of flash special memory.
• uint32_t ftfx_spec_mem_t::size
size of flash special memory.
• uint32_t ftfx_spec_mem_t::count
flash special memory count.
• uint8_t ftfx_mem_desc_t::type
Type of flash block.
• uint8_t ftfx_mem_desc_t::index
Index of flash block.
• uint32_t ftfx_mem_desc_t::blockBase
A base address of the flash block.
• uint32_t ftfx_mem_desc_t::totalSize
The size of the flash block.
• uint32_t ftfx_mem_desc_t::sectorSize
The size in bytes of a sector of flash.
• uint32_t ftfx_mem_desc_t::blockCount
A number of flash blocks.
• uint32_t ftfx_ops_config_t::convertedAddress
A converted address for the current flash type.
• uint32_t ftfx_config_t::flexramBlockBase
The base address of the FlexRAM/acceleration RAM.
• uint32_t ftfx_config_t::flexramTotalSize
The size of the FlexRAM/acceleration RAM.
• uint16_t ftfx_config_t::eepromTotalSize
The size of EEPROM area which was partitioned from FlexRAM.
• uint32_t ∗ ftfx_config_t::runCmdFuncAddr
An buffer point to the flash execute-in-RAM function.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 119
ftfx controller

FTFx status

• enum _ftfx_status {
kStatus_FTFx_Success = (int32_t)MAKE_STATUS(kStatusGroupGeneric, 0),
kStatus_FTFx_InvalidArgument = (int32_t)MAKE_STATUS(kStatusGroupGeneric, 4),
kStatus_FTFx_SizeError = (int32_t)MAKE_STATUS(kStatusGroupFtfxDriver, 0),
kStatus_FTFx_AlignmentError,
kStatus_FTFx_AddressError = (int32_t)MAKE_STATUS(kStatusGroupFtfxDriver, 2),
kStatus_FTFx_AccessError,
kStatus_FTFx_ProtectionViolation,
kStatus_FTFx_CommandFailure,
kStatus_FTFx_UnknownProperty = (int32_t)MAKE_STATUS(kStatusGroupFtfxDriver, 6),
kStatus_FTFx_EraseKeyError = (int32_t)MAKE_STATUS(kStatusGroupFtfxDriver, 7),
kStatus_FTFx_RegionExecuteOnly,
kStatus_FTFx_ExecuteInRamFunctionNotReady,
kStatus_FTFx_PartitionStatusUpdateFailure,
kStatus_FTFx_SetFlexramAsEepromError,
kStatus_FTFx_RecoverFlexramAsRamError,
kStatus_FTFx_SetFlexramAsRamError = (int32_t)MAKE_STATUS(kStatusGroupFtfxDriver, 13),
kStatus_FTFx_RecoverFlexramAsEepromError,
kStatus_FTFx_CommandNotSupported = (int32_t)MAKE_STATUS(kStatusGroupFtfxDriver, 15),
kStatus_FTFx_SwapSystemNotInUninitialized,
kStatus_FTFx_SwapIndicatorAddressError,
kStatus_FTFx_ReadOnlyProperty = (int32_t)MAKE_STATUS(kStatusGroupFtfxDriver, 18),
kStatus_FTFx_InvalidPropertyValue,
kStatus_FTFx_InvalidSpeculationOption }
FTFx driver status codes.
• #define kStatusGroupGeneric 0
FTFx driver status group.
• #define kStatusGroupFtfxDriver 1

FTFx API key

• enum _ftfx_driver_api_keys { kFTFx_ApiEraseKey = FOUR_CHAR_CODE(’k’, ’f’, ’e’, ’k’) }


Enumeration for FTFx driver API keys.

Initialization

• status_t FTFx_API_Init (ftfx_config_t ∗config)


Initializes the global flash properties structure members.
• status_t FTFx_API_UpdateFlexnvmPartitionStatus (ftfx_config_t ∗config)
Updates FlexNVM memory partition status according to data flash 0 IFR.

MCUXpresso SDK API Reference Manual


120 NXP Semiconductors
ftfx controller

Erasing

• status_t FTFx_CMD_Erase (ftfx_config_t ∗config, uint32_t start, uint32_t lengthInBytes, uint32_t


key)
Erases the flash sectors encompassed by parameters passed into function.
• status_t FTFx_CMD_EraseAll (ftfx_config_t ∗config, uint32_t key)
Erases entire flash.
• status_t FTFx_CMD_EraseAllUnsecure (ftfx_config_t ∗config, uint32_t key)
Erases the entire flash, including protected sectors.
• status_t FTFx_CMD_EraseAllExecuteOnlySegments (ftfx_config_t ∗config, uint32_t key)
Erases all program flash execute-only segments defined by the FXACC registers.

Programming

• status_t FTFx_CMD_Program (ftfx_config_t ∗config, uint32_t start, const uint8_t ∗src, uint32_t
lengthInBytes)
Programs flash with data at locations passed in through parameters.
• status_t FTFx_CMD_ProgramOnce (ftfx_config_t ∗config, uint32_t index, const uint8_t ∗src,
uint32_t lengthInBytes)
Programs Program Once Field through parameters.

Reading

Programs flash with data at locations passed in through parameters via the Program Section command.
This function programs the flash memory with the desired data for a given flash area as determined by the
start address and length.
Parameters

config A pointer to the storage for the driver runtime state.


start The start address of the desired flash memory to be programmed. Must be word-
aligned.
src A pointer to the source buffer of data that is to be programmed into the flash.
lengthInBytes The length, given in bytes (not words or long-words), to be programmed. Must be
word-aligned.

Return values

MCUXpresso SDK API Reference Manual


NXP Semiconductors 121
ftfx controller

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_- Parameter is not aligned with specified baseline.
AlignmentError
kStatus_FTFx_Address- Address is out of range.
Error
kStatus_FTFx_Set- Failed to set flexram as RAM.
FlexramAsRamError
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during command execution.
CommandFailure
kStatus_FTFx_Recover- Failed to recover FlexRAM as EEPROM.
FlexramAsEepromError
Prepares the FlexNVM block for use as data flash, EEPROM backup, or a combination of both and ini-
tializes the FlexRAM.
Parameters

config Pointer to storage for the driver runtime state.


option The option used to set FlexRAM load behavior during reset.
eepromData- Determines the amount of FlexRAM used in each of the available EEPROM subsys-
SizeCode tems.
flexnvm- Specifies how to split the FlexNVM block between data flash memory and EEPROM
PartitionCode backup memory supporting EEPROM functions.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- Invalid argument is provided.
Argument

MCUXpresso SDK API Reference Manual


122 NXP Semiconductors
ftfx controller

kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.


RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during command execution.
CommandFailure

• status_t FTFx_CMD_ReadOnce (ftfx_config_t ∗config, uint32_t index, uint8_t ∗dst, uint32_-


t lengthInBytes)
Reads the Program Once Field through parameters.
• status_t FTFx_CMD_ReadResource (ftfx_config_t ∗config, uint32_t start, uint8_t ∗dst, uint32_t
lengthInBytes, ftfx_read_resource_opt_t option)
Reads the resource with data at locations passed in through parameters.

Verification

• status_t FTFx_CMD_VerifyErase (ftfx_config_t ∗config, uint32_t start, uint32_t lengthInBytes,


ftfx_margin_value_t margin)
Verifies an erasure of the desired flash area at a specified margin level.
• status_t FTFx_CMD_VerifyEraseAll (ftfx_config_t ∗config, ftfx_margin_value_t margin)
Verifies erasure of the entire flash at a specified margin level.
• status_t FTFx_CMD_VerifyEraseAllExecuteOnlySegments (ftfx_config_t ∗config, ftfx_margin_-
value_t margin)
Verifies whether the program flash execute-only segments have been erased to the specified read margin
level.
• status_t FTFx_CMD_VerifyProgram (ftfx_config_t ∗config, uint32_t start, uint32_t lengthIn-
Bytes, const uint8_t ∗expectedData, ftfx_margin_value_t margin, uint32_t ∗failedAddress, uint32_t
∗failedData)
Verifies programming of the desired flash area at a specified margin level.

Security

• status_t FTFx_REG_GetSecurityState (ftfx_config_t ∗config, ftfx_security_state_t ∗state)


Returns the security state via the pointer passed into the function.
• status_t FTFx_CMD_SecurityBypass (ftfx_config_t ∗config, const uint8_t ∗backdoorKey)
Allows users to bypass security with a backdoor key.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 123
ftfx controller

11.6.2 Data Structure Documentation

11.6.2.1 struct ftfx_spec_mem_t

Data Fields
• uint32_t base
Base address of flash special memory.
• uint32_t size
size of flash special memory.
• uint32_t count
flash special memory count.

11.6.2.2 struct ftfx_mem_desc_t

Data Fields
• uint8_t type
Type of flash block.
• uint8_t index
Index of flash block.
• uint32_t blockBase
A base address of the flash block.
• uint32_t totalSize
The size of the flash block.
• uint32_t sectorSize
The size in bytes of a sector of flash.
• uint32_t blockCount
A number of flash blocks.

11.6.2.3 struct ftfx_ops_config_t

Data Fields
• uint32_t convertedAddress
A converted address for the current flash type.

11.6.2.4 struct ftfx_ifr_desc_t

11.6.2.5 struct ftfx_config_t

An instance of this structure is allocated by the user of the flash driver and passed into each of the driver
APIs.

MCUXpresso SDK API Reference Manual


124 NXP Semiconductors
ftfx controller

Data Fields
• uint32_t flexramBlockBase
The base address of the FlexRAM/acceleration RAM.
• uint32_t flexramTotalSize
The size of the FlexRAM/acceleration RAM.
• uint16_t eepromTotalSize
The size of EEPROM area which was partitioned from FlexRAM.
• uint32_t ∗ runCmdFuncAddr
An buffer point to the flash execute-in-RAM function.

11.6.3 Macro Definition Documentation

11.6.3.1 #define kStatusGroupGeneric 0

11.6.4 Enumeration Type Documentation

11.6.4.1 enum _ftfx_status

Enumerator
kStatus_FTFx_Success API is executed successfully.
kStatus_FTFx_InvalidArgument Invalid argument.
kStatus_FTFx_SizeError Error size.
kStatus_FTFx_AlignmentError Parameter is not aligned with the specified baseline.
kStatus_FTFx_AddressError Address is out of range.
kStatus_FTFx_AccessError Invalid instruction codes and out-of bound addresses.
kStatus_FTFx_ProtectionViolation The program/erase operation is requested to execute on pro-
tected areas.
kStatus_FTFx_CommandFailure Run-time error during command execution.
kStatus_FTFx_UnknownProperty Unknown property.
kStatus_FTFx_EraseKeyError API erase key is invalid.
kStatus_FTFx_RegionExecuteOnly The current region is execute-only.
kStatus_FTFx_ExecuteInRamFunctionNotReady Execute-in-RAM function is not available.
kStatus_FTFx_PartitionStatusUpdateFailure Failed to update partition status.
kStatus_FTFx_SetFlexramAsEepromError Failed to set FlexRAM as EEPROM.
kStatus_FTFx_RecoverFlexramAsRamError Failed to recover FlexRAM as RAM.
kStatus_FTFx_SetFlexramAsRamError Failed to set FlexRAM as RAM.
kStatus_FTFx_RecoverFlexramAsEepromError Failed to recover FlexRAM as EEPROM.
kStatus_FTFx_CommandNotSupported Flash API is not supported.
kStatus_FTFx_SwapSystemNotInUninitialized Swap system is not in an uninitialzed state.
kStatus_FTFx_SwapIndicatorAddressError The swap indicator address is invalid.
kStatus_FTFx_ReadOnlyProperty The flash property is read-only.
kStatus_FTFx_InvalidPropertyValue The flash property value is out of range.
kStatus_FTFx_InvalidSpeculationOption The option of flash prefetch speculation is invalid.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 125
ftfx controller

11.6.4.2 enum _ftfx_driver_api_keys

Note
The resulting value is built with a byte order such that the string being readable in expected order
when viewed in a hex editor, if the value is treated as a 32-bit little endian value.

Enumerator
kFTFx_ApiEraseKey Key value used to validate all FTFx erase APIs.

11.6.4.3 enum ftfx_partition_flexram_load_opt_t

Enumerator
kFTFx_PartitionFlexramLoadOptLoadedWithValidEepromData FlexRAM is loaded with valid
EEPROM data during reset sequence.
kFTFx_PartitionFlexramLoadOptNotLoaded FlexRAM is not loaded during reset sequence.

11.6.4.4 enum ftfx_read_resource_opt_t

Enumerator
kFTFx_ResourceOptionFlashIfr Select code for Program flash 0 IFR, Program flash swap 0 IFR,
Data flash 0 IFR.
kFTFx_ResourceOptionVersionId Select code for the version ID.

11.6.4.5 enum ftfx_margin_value_t

Enumerator
kFTFx_MarginValueNormal Use the ’normal’ read level for 1s.
kFTFx_MarginValueUser Apply the ’User’ margin to the normal read-1 level.
kFTFx_MarginValueFactory Apply the ’Factory’ margin to the normal read-1 level.
kFTFx_MarginValueInvalid Not real margin level, Used to determine the range of valid margin
level.

11.6.4.6 enum ftfx_security_state_t

Enumerator
kFTFx_SecurityStateNotSecure Flash is not secure.
kFTFx_SecurityStateBackdoorEnabled Flash backdoor is enabled.
kFTFx_SecurityStateBackdoorDisabled Flash backdoor is disabled.

MCUXpresso SDK API Reference Manual


126 NXP Semiconductors
ftfx controller

11.6.4.7 enum ftfx_flexram_func_opt_t

Enumerator
kFTFx_FlexramFuncOptAvailableAsRam An option used to make FlexRAM available as RAM.
kFTFx_FlexramFuncOptAvailableForEeprom An option used to make FlexRAM available for E-
EPROM.

11.6.4.8 enum ftfx_swap_state_t

Enumerator
kFTFx_SwapStateUninitialized Flash Swap system is in an uninitialized state.
kFTFx_SwapStateReady Flash Swap system is in a ready state.
kFTFx_SwapStateUpdate Flash Swap system is in an update state.
kFTFx_SwapStateUpdateErased Flash Swap system is in an updateErased state.
kFTFx_SwapStateComplete Flash Swap system is in a complete state.
kFTFx_SwapStateDisabled Flash Swap system is in a disabled state.

11.6.5 Function Documentation

11.6.5.1 status_t FTFx_API_Init ( ftfx_config_t ∗ config )

This function checks and initializes the Flash module for the other Flash APIs.
Parameters

config Pointer to the storage for the driver runtime state.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady

11.6.5.2 status_t FTFx_API_UpdateFlexnvmPartitionStatus ( ftfx_config_t ∗ config )

This function updates FlexNVM memory partition status.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 127
ftfx controller

Parameters

config Pointer to the storage for the driver runtime state.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_Partition- Failed to update the partition status.
StatusUpdateFailure

11.6.5.3 status_t FTFx_CMD_Erase ( ftfx_config_t ∗ config, uint32_t start, uint32_t


lengthInBytes, uint32_t key )

This function erases the appropriate number of flash sectors based on the desired start address and length.
Parameters

config The pointer to the storage for the driver runtime state.
start The start address of the desired flash memory to be erased. The start address does not
need to be sector-aligned but must be word-aligned.
lengthInBytes The length, given in bytes (not words or long-words) to be erased. Must be word-
aligned.
key The value used to validate all flash erase APIs.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_- The parameter is not aligned with the specified baseline.
AlignmentError
kStatus_FTFx_Address- The address is out of range.
Error

MCUXpresso SDK API Reference Manual


128 NXP Semiconductors
ftfx controller

kStatus_FTFx_EraseKey- The API erase key is invalid.


Error
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during the command execution.
CommandFailure

11.6.5.4 status_t FTFx_CMD_EraseAll ( ftfx_config_t ∗ config, uint32_t key )

Parameters

config Pointer to the storage for the driver runtime state.


key A value used to validate all flash erase APIs.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_EraseKey- API erase key is invalid.
Error
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during command execution.
CommandFailure

MCUXpresso SDK API Reference Manual


NXP Semiconductors 129
ftfx controller

kStatus_FTFx_Partition- Failed to update the partition status.


StatusUpdateFailure

11.6.5.5 status_t FTFx_CMD_EraseAllUnsecure ( ftfx_config_t ∗ config, uint32_t key )

Parameters

config Pointer to the storage for the driver runtime state.


key A value used to validate all flash erase APIs.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_EraseKey- API erase key is invalid.
Error
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during command execution.
CommandFailure
kStatus_FTFx_Partition- Failed to update the partition status.
StatusUpdateFailure

11.6.5.6 status_t FTFx_CMD_EraseAllExecuteOnlySegments ( ftfx_config_t ∗ config,


uint32_t key )

Parameters

config Pointer to the storage for the driver runtime state.

MCUXpresso SDK API Reference Manual


130 NXP Semiconductors
ftfx controller

key A value used to validate all flash erase APIs.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_EraseKey- API erase key is invalid.
Error
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during the command execution.
CommandFailure

11.6.5.7 status_t FTFx_CMD_Program ( ftfx_config_t ∗ config, uint32_t start, const


uint8_t ∗ src, uint32_t lengthInBytes )

This function programs the flash memory with the desired data for a given flash area as determined by the
start address and the length.
Parameters

config A pointer to the storage for the driver runtime state.


start The start address of the desired flash memory to be programmed. Must be word-
aligned.
src A pointer to the source buffer of data that is to be programmed into the flash.
lengthInBytes The length, given in bytes (not words or long-words), to be programmed. Must be
word-aligned.

Return values

MCUXpresso SDK API Reference Manual


NXP Semiconductors 131
ftfx controller

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_- Parameter is not aligned with the specified baseline.
AlignmentError
kStatus_FTFx_Address- Address is out of range.
Error
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during the command execution.
CommandFailure

11.6.5.8 status_t FTFx_CMD_ProgramOnce ( ftfx_config_t ∗ config, uint32_t index, const


uint8_t ∗ src, uint32_t lengthInBytes )

This function programs the Program Once Field with the desired data for a given flash area as determined
by the index and length.
Parameters

config A pointer to the storage for the driver runtime state.


index The index indicating which area of the Program Once Field to be programmed.
src A pointer to the source buffer of data that is to be programmed into the Program Once
Field.
lengthInBytes The length, given in bytes (not words or long-words), to be programmed. Must be
word-aligned.

Return values

kStatus_FTFx_Success API was executed successfully.

MCUXpresso SDK API Reference Manual


132 NXP Semiconductors
ftfx controller

kStatus_FTFx_Invalid- An invalid argument is provided.


Argument
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during the command execution.
CommandFailure

11.6.5.9 status_t FTFx_CMD_ReadOnce ( ftfx_config_t ∗ config, uint32_t index, uint8_t ∗


dst, uint32_t lengthInBytes )

This function reads the read once feild with given index and length.
Parameters

config A pointer to the storage for the driver runtime state.


index The index indicating the area of program once field to be read.
dst A pointer to the destination buffer of data that is used to store data to be read.
lengthInBytes The length, given in bytes (not words or long-words), to be programmed. Must be
word-aligned.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error

MCUXpresso SDK API Reference Manual


NXP Semiconductors 133
ftfx controller

kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.


ProtectionViolation
kStatus_FTFx_- Run-time error during the command execution.
CommandFailure

11.6.5.10 status_t FTFx_CMD_ReadResource ( ftfx_config_t ∗ config, uint32_t start,


uint8_t ∗ dst, uint32_t lengthInBytes, ftfx_read_resource_opt_t option )

This function reads the flash memory with the desired location for a given flash area as determined by the
start address and length.
Parameters

config A pointer to the storage for the driver runtime state.


start The start address of the desired flash memory to be programmed. Must be word-
aligned.
dst A pointer to the destination buffer of data that is used to store data to be read.
lengthInBytes The length, given in bytes (not words or long-words), to be read. Must be word-
aligned.
option The resource option which indicates which area should be read back.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_- Parameter is not aligned with the specified baseline.
AlignmentError
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation

MCUXpresso SDK API Reference Manual


134 NXP Semiconductors
ftfx controller

kStatus_FTFx_- Run-time error during the command execution.


CommandFailure

11.6.5.11 status_t FTFx_CMD_VerifyErase ( ftfx_config_t ∗ config, uint32_t start,


uint32_t lengthInBytes, ftfx_margin_value_t margin )

This function checks the appropriate number of flash sectors based on the desired start address and length
to check whether the flash is erased to the specified read margin level.
Parameters

config A pointer to the storage for the driver runtime state.


start The start address of the desired flash memory to be verified. The start address does
not need to be sector-aligned but must be word-aligned.
lengthInBytes The length, given in bytes (not words or long-words), to be verified. Must be word-
aligned.
margin Read margin choice.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_- Parameter is not aligned with specified baseline.
AlignmentError
kStatus_FTFx_Address- Address is out of range.
Error
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation

MCUXpresso SDK API Reference Manual


NXP Semiconductors 135
ftfx controller

kStatus_FTFx_- Run-time error during the command execution.


CommandFailure

11.6.5.12 status_t FTFx_CMD_VerifyEraseAll ( ftfx_config_t ∗ config, ftfx_margin_value_t


margin )

This function checks whether the flash is erased to the specified read margin level.
Parameters

config A pointer to the storage for the driver runtime state.


margin Read margin choice.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during the command execution.
CommandFailure

11.6.5.13 status_t FTFx_CMD_VerifyEraseAllExecuteOnlySegments ( ftfx_config_t ∗


config, ftfx_margin_value_t margin )

Parameters

config A pointer to the storage for the driver runtime state.


margin Read margin choice.

MCUXpresso SDK API Reference Manual


136 NXP Semiconductors
ftfx controller

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during the command execution.
CommandFailure

11.6.5.14 status_t FTFx_CMD_VerifyProgram ( ftfx_config_t ∗ config, uint32_t start,


uint32_t lengthInBytes, const uint8_t ∗ expectedData, ftfx_margin_value_t
margin, uint32_t ∗ failedAddress, uint32_t ∗ failedData )

This function verifies the data programed in the flash memory using the Flash Program Check Command
and compares it to the expected data for a given flash area as determined by the start address and length.
Parameters

config A pointer to the storage for the driver runtime state.


start The start address of the desired flash memory to be verified. Must be word-aligned.
lengthInBytes The length, given in bytes (not words or long-words), to be verified. Must be word-
aligned.
expectedData A pointer to the expected data that is to be verified against.
margin Read margin choice.
failedAddress A pointer to the returned failing address.
failedData A pointer to the returned failing data. Some derivatives do not include failed data as
part of the FCCOBx registers. In this case, zeros are returned upon failure.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 137
ftfx controller

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_- Parameter is not aligned with specified baseline.
AlignmentError
kStatus_FTFx_Address- Address is out of range.
Error
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during the command execution.
CommandFailure

11.6.5.15 status_t FTFx_REG_GetSecurityState ( ftfx_config_t ∗ config,


ftfx_security_state_t ∗ state )

This function retrieves the current flash security status, including the security enabling state and the back-
door key enabling state.
Parameters

config A pointer to storage for the driver runtime state.


state A pointer to the value returned for the current security status code:

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument

11.6.5.16 status_t FTFx_CMD_SecurityBypass ( ftfx_config_t ∗ config, const uint8_t ∗


backdoorKey )

If the MCU is in secured state, this function unsecures the MCU by comparing the provided backdoor key
with ones in the flash configuration field.

MCUXpresso SDK API Reference Manual


138 NXP Semiconductors
ftfx controller

Parameters

config A pointer to the storage for the driver runtime state.


backdoorKey A pointer to the user buffer containing the backdoor key.

Return values

kStatus_FTFx_Success API was executed successfully.


kStatus_FTFx_Invalid- An invalid argument is provided.
Argument
kStatus_FTFx_ExecuteIn- Execute-in-RAM function is not available.
RamFunctionNotReady
kStatus_FTFx_Access- Invalid instruction codes and out-of bounds addresses.
Error
kStatus_FTFx_- The program/erase operation is requested to execute on protected areas.
ProtectionViolation
kStatus_FTFx_- Run-time error during the command execution.
CommandFailure

11.6.6 Variable Documentation

11.6.6.1 uint32_t ftfx_spec_mem_t::base

11.6.6.2 uint32_t ftfx_spec_mem_t::size

11.6.6.3 uint32_t ftfx_spec_mem_t::count

11.6.6.4 uint8_t ftfx_mem_desc_t::type

11.6.6.5 uint8_t ftfx_mem_desc_t::index

11.6.6.6 uint32_t ftfx_mem_desc_t::totalSize

11.6.6.7 uint32_t ftfx_mem_desc_t::sectorSize

11.6.6.8 uint32_t ftfx_mem_desc_t::blockCount

11.6.6.9 uint32_t ftfx_ops_config_t::convertedAddress

11.6.6.10 uint32_t∗ ftfx_config_t::runCmdFuncAddr

MCUXpresso SDK API Reference Manual


NXP Semiconductors 139
ftfx controller

11.6.7 ftfx utilities

11.6.7.1 Overview

Macros
• #define MAKE_VERSION(major, minor, bugfix) (((major) << 16) | ((minor) << 8) | (bugfix))
Constructs the version number for drivers.
• #define MAKE_STATUS(group, code) ((((group)∗100) + (code)))
Constructs a status code value from a group and a code number.
• #define FOUR_CHAR_CODE(a, b, c, d) (((uint32_t)(d) << 24u) | ((uint32_t)(c) << 16u) |
((uint32_t)(b) << 8u) | ((uint32_t)(a)))
Constructs the four character code for the Flash driver API key.
• #define ALIGN_DOWN(x, a) (((uint32_t)(x)) & ∼((uint32_t)(a)-1u))
Alignment(down) utility.
• #define ALIGN_UP(x, a) ALIGN_DOWN((uint32_t)(x) + (uint32_t)(a) - 1u, a)
Alignment(up) utility.
• #define B1P4(b) (((uint32_t)(b)&0xFFU) << 24U)
bytes2word utility.

11.6.7.2 Macro Definition Documentation

11.6.7.2.1 #define MAKE_VERSION( major, minor, bugfix ) (((major) << 16) | ((minor) << 8) |
(bugfix))

11.6.7.2.2 #define MAKE_STATUS( group, code ) ((((group)∗100) + (code)))

11.6.7.2.3 #define FOUR_CHAR_CODE( a, b, c, d ) (((uint32_t)(d) << 24u) | ((uint32_t)(c) <<


16u) | ((uint32_t)(b) << 8u) | ((uint32_t)(a)))

11.6.7.2.4 #define ALIGN_DOWN( x, a ) (((uint32_t)(x)) & ∼((uint32_t)(a)-1u))

11.6.7.2.5 #define ALIGN_UP( x, a ) ALIGN_DOWN((uint32_t)(x) + (uint32_t)(a) - 1u, a)

11.6.7.2.6 #define B1P4( b ) (((uint32_t)(b)&0xFFU) << 24U)

MCUXpresso SDK API Reference Manual


140 NXP Semiconductors
Chapter 12
FlexIO: FlexIO Driver
12.1 Overview
The MCUXpresso SDK provides a generic driver and multiple protocol-specific FlexIO drivers for the
FlexIO module of MCUXpresso SDK devices.

Modules
• FlexIO Camera Driver
• FlexIO Driver
• FlexIO I2C Master Driver
• FlexIO I2S Driver
• FlexIO MCU Interface LCD Driver
• FlexIO SPI Driver
• FlexIO UART Driver

MCUXpresso SDK API Reference Manual


NXP Semiconductors 141
FlexIO Driver

12.2 FlexIO Driver


12.2.1 Overview

Data Structures

• struct flexio_config_t
Define FlexIO user configuration structure. More...
• struct flexio_timer_config_t
Define FlexIO timer configuration structure. More...
• struct flexio_shifter_config_t
Define FlexIO shifter configuration structure. More...

Macros

• #define FLEXIO_TIMER_TRIGGER_SEL_PININPUT(x) ((uint32_t)(x) << 1U)


Calculate FlexIO timer trigger.

Typedefs

• typedef void(∗ flexio_isr_t )(void ∗base, void ∗handle)


typedef for FlexIO simulated driver interrupt handler.

Enumerations

• enum flexio_timer_trigger_polarity_t {
kFLEXIO_TimerTriggerPolarityActiveHigh = 0x0U,
kFLEXIO_TimerTriggerPolarityActiveLow = 0x1U }
Define time of timer trigger polarity.
• enum flexio_timer_trigger_source_t {
kFLEXIO_TimerTriggerSourceExternal = 0x0U,
kFLEXIO_TimerTriggerSourceInternal = 0x1U }
Define type of timer trigger source.
• enum flexio_pin_config_t {
kFLEXIO_PinConfigOutputDisabled = 0x0U,
kFLEXIO_PinConfigOpenDrainOrBidirection = 0x1U,
kFLEXIO_PinConfigBidirectionOutputData = 0x2U,
kFLEXIO_PinConfigOutput = 0x3U }
Define type of timer/shifter pin configuration.
• enum flexio_pin_polarity_t {
kFLEXIO_PinActiveHigh = 0x0U,
kFLEXIO_PinActiveLow = 0x1U }
Definition of pin polarity.

MCUXpresso SDK API Reference Manual


142 NXP Semiconductors
FlexIO Driver

• enum flexio_timer_mode_t {
kFLEXIO_TimerModeDisabled = 0x0U,
kFLEXIO_TimerModeDual8BitBaudBit = 0x1U,
kFLEXIO_TimerModeDual8BitPWM = 0x2U,
kFLEXIO_TimerModeSingle16Bit = 0x3U }
Define type of timer work mode.
• enum flexio_timer_output_t {
kFLEXIO_TimerOutputOneNotAffectedByReset = 0x0U,
kFLEXIO_TimerOutputZeroNotAffectedByReset = 0x1U,
kFLEXIO_TimerOutputOneAffectedByReset = 0x2U,
kFLEXIO_TimerOutputZeroAffectedByReset = 0x3U }
Define type of timer initial output or timer reset condition.
• enum flexio_timer_decrement_source_t {
kFLEXIO_TimerDecSrcOnFlexIOClockShiftTimerOutput = 0x0U,
kFLEXIO_TimerDecSrcOnTriggerInputShiftTimerOutput = 0x1U,
kFLEXIO_TimerDecSrcOnPinInputShiftPinInput = 0x2U,
kFLEXIO_TimerDecSrcOnTriggerInputShiftTriggerInput = 0x3U }
Define type of timer decrement.
• enum flexio_timer_reset_condition_t {
kFLEXIO_TimerResetNever = 0x0U,
kFLEXIO_TimerResetOnTimerPinEqualToTimerOutput = 0x2U,
kFLEXIO_TimerResetOnTimerTriggerEqualToTimerOutput = 0x3U,
kFLEXIO_TimerResetOnTimerPinRisingEdge = 0x4U,
kFLEXIO_TimerResetOnTimerTriggerRisingEdge = 0x6U,
kFLEXIO_TimerResetOnTimerTriggerBothEdge = 0x7U }
Define type of timer reset condition.
• enum flexio_timer_disable_condition_t {
kFLEXIO_TimerDisableNever = 0x0U,
kFLEXIO_TimerDisableOnPreTimerDisable = 0x1U,
kFLEXIO_TimerDisableOnTimerCompare = 0x2U,
kFLEXIO_TimerDisableOnTimerCompareTriggerLow = 0x3U,
kFLEXIO_TimerDisableOnPinBothEdge = 0x4U,
kFLEXIO_TimerDisableOnPinBothEdgeTriggerHigh = 0x5U,
kFLEXIO_TimerDisableOnTriggerFallingEdge = 0x6U }
Define type of timer disable condition.
• enum flexio_timer_enable_condition_t {
kFLEXIO_TimerEnabledAlways = 0x0U,
kFLEXIO_TimerEnableOnPrevTimerEnable = 0x1U,
kFLEXIO_TimerEnableOnTriggerHigh = 0x2U,
kFLEXIO_TimerEnableOnTriggerHighPinHigh = 0x3U,
kFLEXIO_TimerEnableOnPinRisingEdge = 0x4U,
kFLEXIO_TimerEnableOnPinRisingEdgeTriggerHigh = 0x5U,
kFLEXIO_TimerEnableOnTriggerRisingEdge = 0x6U,
kFLEXIO_TimerEnableOnTriggerBothEdge = 0x7U }
Define type of timer enable condition.
• enum flexio_timer_stop_bit_condition_t {

MCUXpresso SDK API Reference Manual


NXP Semiconductors 143
FlexIO Driver

kFLEXIO_TimerStopBitDisabled = 0x0U,
kFLEXIO_TimerStopBitEnableOnTimerCompare = 0x1U,
kFLEXIO_TimerStopBitEnableOnTimerDisable = 0x2U,
kFLEXIO_TimerStopBitEnableOnTimerCompareDisable = 0x3U }
Define type of timer stop bit generate condition.
• enum flexio_timer_start_bit_condition_t {
kFLEXIO_TimerStartBitDisabled = 0x0U,
kFLEXIO_TimerStartBitEnabled = 0x1U }
Define type of timer start bit generate condition.
• enum flexio_shifter_timer_polarity_t {
kFLEXIO_ShifterTimerPolarityOnPositive = 0x0U,
kFLEXIO_ShifterTimerPolarityOnNegitive = 0x1U }
Define type of timer polarity for shifter control.
• enum flexio_shifter_mode_t {
kFLEXIO_ShifterDisabled = 0x0U,
kFLEXIO_ShifterModeReceive = 0x1U,
kFLEXIO_ShifterModeTransmit = 0x2U,
kFLEXIO_ShifterModeMatchStore = 0x4U,
kFLEXIO_ShifterModeMatchContinuous = 0x5U }
Define type of shifter working mode.
• enum flexio_shifter_input_source_t {
kFLEXIO_ShifterInputFromPin = 0x0U,
kFLEXIO_ShifterInputFromNextShifterOutput = 0x1U }
Define type of shifter input source.
• enum flexio_shifter_stop_bit_t {
kFLEXIO_ShifterStopBitDisable = 0x0U,
kFLEXIO_ShifterStopBitLow = 0x2U,
kFLEXIO_ShifterStopBitHigh = 0x3U }
Define of STOP bit configuration.
• enum flexio_shifter_start_bit_t {
kFLEXIO_ShifterStartBitDisabledLoadDataOnEnable = 0x0U,
kFLEXIO_ShifterStartBitDisabledLoadDataOnShift = 0x1U,
kFLEXIO_ShifterStartBitLow = 0x2U,
kFLEXIO_ShifterStartBitHigh = 0x3U }
Define type of START bit configuration.
• enum flexio_shifter_buffer_type_t {
kFLEXIO_ShifterBuffer = 0x0U,
kFLEXIO_ShifterBufferBitSwapped = 0x1U,
kFLEXIO_ShifterBufferByteSwapped = 0x2U,
kFLEXIO_ShifterBufferBitByteSwapped = 0x3U }
Define FlexIO shifter buffer type.

Variables

• FLEXIO_Type ∗const s_flexioBases [ ]


Pointers to flexio bases for each instance.

MCUXpresso SDK API Reference Manual


144 NXP Semiconductors
FlexIO Driver

• const clock_ip_name_t s_flexioClocks [ ]


Pointers to flexio clocks for each instance.

Driver version

• #define FSL_FLEXIO_DRIVER_VERSION (MAKE_VERSION(2, 0, 2))


FlexIO driver version 2.0.2.

FlexIO Initialization and De-initialization

• void FLEXIO_GetDefaultConfig (flexio_config_t ∗userConfig)


Gets the default configuration to configure the FlexIO module.
• void FLEXIO_Init (FLEXIO_Type ∗base, const flexio_config_t ∗userConfig)
Configures the FlexIO with a FlexIO configuration.
• void FLEXIO_Deinit (FLEXIO_Type ∗base)
Gates the FlexIO clock.
• uint32_t FLEXIO_GetInstance (FLEXIO_Type ∗base)
Get instance number for FLEXIO module.

FlexIO Basic Operation

• void FLEXIO_Reset (FLEXIO_Type ∗base)


Resets the FlexIO module.
• static void FLEXIO_Enable (FLEXIO_Type ∗base, bool enable)
Enables the FlexIO module operation.
• void FLEXIO_SetShifterConfig (FLEXIO_Type ∗base, uint8_t index, const flexio_shifter_config_t
∗shifterConfig)
Configures the shifter with the shifter configuration.
• void FLEXIO_SetTimerConfig (FLEXIO_Type ∗base, uint8_t index, const flexio_timer_config_t
∗timerConfig)
Configures the timer with the timer configuration.

FlexIO Interrupt Operation

• static void FLEXIO_EnableShifterStatusInterrupts (FLEXIO_Type ∗base, uint32_t mask)


Enables the shifter status interrupt.
• static void FLEXIO_DisableShifterStatusInterrupts (FLEXIO_Type ∗base, uint32_t mask)
Disables the shifter status interrupt.
• static void FLEXIO_EnableShifterErrorInterrupts (FLEXIO_Type ∗base, uint32_t mask)
Enables the shifter error interrupt.
• static void FLEXIO_DisableShifterErrorInterrupts (FLEXIO_Type ∗base, uint32_t mask)
Disables the shifter error interrupt.
• static void FLEXIO_EnableTimerStatusInterrupts (FLEXIO_Type ∗base, uint32_t mask)
Enables the timer status interrupt.
• static void FLEXIO_DisableTimerStatusInterrupts (FLEXIO_Type ∗base, uint32_t mask)

MCUXpresso SDK API Reference Manual


NXP Semiconductors 145
FlexIO Driver

Disables the timer status interrupt.

FlexIO Status Operation

• static uint32_t FLEXIO_GetShifterStatusFlags (FLEXIO_Type ∗base)


Gets the shifter status flags.
• static void FLEXIO_ClearShifterStatusFlags (FLEXIO_Type ∗base, uint32_t mask)
Clears the shifter status flags.
• static uint32_t FLEXIO_GetShifterErrorFlags (FLEXIO_Type ∗base)
Gets the shifter error flags.
• static void FLEXIO_ClearShifterErrorFlags (FLEXIO_Type ∗base, uint32_t mask)
Clears the shifter error flags.
• static uint32_t FLEXIO_GetTimerStatusFlags (FLEXIO_Type ∗base)
Gets the timer status flags.
• static void FLEXIO_ClearTimerStatusFlags (FLEXIO_Type ∗base, uint32_t mask)
Clears the timer status flags.

FlexIO DMA Operation

• static void FLEXIO_EnableShifterStatusDMA (FLEXIO_Type ∗base, uint32_t mask, bool enable)


Enables/disables the shifter status DMA.
• uint32_t FLEXIO_GetShifterBufferAddress (FLEXIO_Type ∗base, flexio_shifter_buffer_type_-
t type, uint8_t index)
Gets the shifter buffer address for the DMA transfer usage.
• status_t FLEXIO_RegisterHandleIRQ (void ∗base, void ∗handle, flexio_isr_t isr)
Registers the handle and the interrupt handler for the FlexIO-simulated peripheral.
• status_t FLEXIO_UnregisterHandleIRQ (void ∗base)
Unregisters the handle and the interrupt handler for the FlexIO-simulated peripheral.

12.2.2 Data Structure Documentation

12.2.2.1 struct flexio_config_t

Data Fields
• bool enableFlexio
Enable/disable FlexIO module.
• bool enableInDoze
Enable/disable FlexIO operation in doze mode.
• bool enableInDebug
Enable/disable FlexIO operation in debug mode.
• bool enableFastAccess
Enable/disable fast access to FlexIO registers, fast access requires
the FlexIO clock to be at least twice the frequency of the bus clock.

MCUXpresso SDK API Reference Manual


146 NXP Semiconductors
FlexIO Driver

12.2.2.1.0.1 Field Documentation

12.2.2.1.0.1.1 bool flexio_config_t::enableFastAccess

12.2.2.2 struct flexio_timer_config_t

Data Fields
• uint32_t triggerSelect
The internal trigger selection number using MACROs.
• flexio_timer_trigger_polarity_t triggerPolarity
Trigger Polarity.
• flexio_timer_trigger_source_t triggerSource
Trigger Source, internal (see ’trgsel’) or external.
• flexio_pin_config_t pinConfig
Timer Pin Configuration.
• uint32_t pinSelect
Timer Pin number Select.
• flexio_pin_polarity_t pinPolarity
Timer Pin Polarity.
• flexio_timer_mode_t timerMode
Timer work Mode.
• flexio_timer_output_t timerOutput
Configures the initial state of the Timer Output and
whether it is affected by the Timer reset.
• flexio_timer_decrement_source_t timerDecrement
Configures the source of the Timer decrement and the
source of the Shift clock.
• flexio_timer_reset_condition_t timerReset
Configures the condition that causes the timer counter
(and optionally the timer output) to be reset.
• flexio_timer_disable_condition_t timerDisable
Configures the condition that causes the Timer to be
disabled and stop decrementing.
• flexio_timer_enable_condition_t timerEnable
Configures the condition that causes the Timer to be
enabled and start decrementing.
• flexio_timer_stop_bit_condition_t timerStop
Timer STOP Bit generation.
• flexio_timer_start_bit_condition_t timerStart
Timer STRAT Bit generation.
• uint32_t timerCompare
Value for Timer Compare N Register.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 147
FlexIO Driver

12.2.2.2.0.2 Field Documentation

12.2.2.2.0.2.1 uint32_t flexio_timer_config_t::triggerSelect

12.2.2.2.0.2.2 flexio_timer_trigger_polarity_t flexio_timer_config_t::triggerPolarity

12.2.2.2.0.2.3 flexio_timer_trigger_source_t flexio_timer_config_t::triggerSource

12.2.2.2.0.2.4 flexio_pin_config_t flexio_timer_config_t::pinConfig

12.2.2.2.0.2.5 uint32_t flexio_timer_config_t::pinSelect

12.2.2.2.0.2.6 flexio_pin_polarity_t flexio_timer_config_t::pinPolarity

12.2.2.2.0.2.7 flexio_timer_mode_t flexio_timer_config_t::timerMode

12.2.2.2.0.2.8 flexio_timer_output_t flexio_timer_config_t::timerOutput

12.2.2.2.0.2.9 flexio_timer_decrement_source_t flexio_timer_config_t::timerDecrement

12.2.2.2.0.2.10 flexio_timer_reset_condition_t flexio_timer_config_t::timerReset

12.2.2.2.0.2.11 flexio_timer_disable_condition_t flexio_timer_config_t::timerDisable

12.2.2.2.0.2.12 flexio_timer_enable_condition_t flexio_timer_config_t::timerEnable

12.2.2.2.0.2.13 flexio_timer_stop_bit_condition_t flexio_timer_config_t::timerStop

12.2.2.2.0.2.14 flexio_timer_start_bit_condition_t flexio_timer_config_t::timerStart

12.2.2.2.0.2.15 uint32_t flexio_timer_config_t::timerCompare

12.2.2.3 struct flexio_shifter_config_t

Data Fields
• uint32_t timerSelect
Selects which Timer is used for controlling the
logic/shift register and generating the Shift clock.
• flexio_shifter_timer_polarity_t timerPolarity
Timer Polarity.
• flexio_pin_config_t pinConfig
Shifter Pin Configuration.
• uint32_t pinSelect
Shifter Pin number Select.
• flexio_pin_polarity_t pinPolarity
Shifter Pin Polarity.
• flexio_shifter_mode_t shifterMode
Configures the mode of the Shifter.
• flexio_shifter_input_source_t inputSource
Selects the input source for the shifter.

MCUXpresso SDK API Reference Manual


148 NXP Semiconductors
FlexIO Driver

• flexio_shifter_stop_bit_t shifterStop
Shifter STOP bit.
• flexio_shifter_start_bit_t shifterStart
Shifter START bit.

12.2.2.3.0.3 Field Documentation

12.2.2.3.0.3.1 uint32_t flexio_shifter_config_t::timerSelect

12.2.2.3.0.3.2 flexio_shifter_timer_polarity_t flexio_shifter_config_t::timerPolarity

12.2.2.3.0.3.3 flexio_pin_config_t flexio_shifter_config_t::pinConfig

12.2.2.3.0.3.4 uint32_t flexio_shifter_config_t::pinSelect

12.2.2.3.0.3.5 flexio_pin_polarity_t flexio_shifter_config_t::pinPolarity

12.2.2.3.0.3.6 flexio_shifter_mode_t flexio_shifter_config_t::shifterMode

12.2.2.3.0.3.7 flexio_shifter_input_source_t flexio_shifter_config_t::inputSource

12.2.2.3.0.3.8 flexio_shifter_stop_bit_t flexio_shifter_config_t::shifterStop

12.2.2.3.0.3.9 flexio_shifter_start_bit_t flexio_shifter_config_t::shifterStart

12.2.3 Macro Definition Documentation

12.2.3.1 #define FSL_FLEXIO_DRIVER_VERSION (MAKE_VERSION(2, 0, 2))

12.2.3.2 #define FLEXIO_TIMER_TRIGGER_SEL_PININPUT( x ) ((uint32_t)(x) << 1U)

12.2.4 Typedef Documentation

12.2.4.1 typedef void(∗ flexio_isr_t)(void ∗base, void ∗handle)

12.2.5 Enumeration Type Documentation

12.2.5.1 enum flexio_timer_trigger_polarity_t

Enumerator
kFLEXIO_TimerTriggerPolarityActiveHigh Active high.
kFLEXIO_TimerTriggerPolarityActiveLow Active low.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 149
FlexIO Driver

12.2.5.2 enum flexio_timer_trigger_source_t

Enumerator
kFLEXIO_TimerTriggerSourceExternal External trigger selected.
kFLEXIO_TimerTriggerSourceInternal Internal trigger selected.

12.2.5.3 enum flexio_pin_config_t

Enumerator
kFLEXIO_PinConfigOutputDisabled Pin output disabled.
kFLEXIO_PinConfigOpenDrainOrBidirection Pin open drain or bidirectional output enable.
kFLEXIO_PinConfigBidirectionOutputData Pin bidirectional output data.
kFLEXIO_PinConfigOutput Pin output.

12.2.5.4 enum flexio_pin_polarity_t

Enumerator
kFLEXIO_PinActiveHigh Active high.
kFLEXIO_PinActiveLow Active low.

12.2.5.5 enum flexio_timer_mode_t

Enumerator
kFLEXIO_TimerModeDisabled Timer Disabled.
kFLEXIO_TimerModeDual8BitBaudBit Dual 8-bit counters baud/bit mode.
kFLEXIO_TimerModeDual8BitPWM Dual 8-bit counters PWM mode.
kFLEXIO_TimerModeSingle16Bit Single 16-bit counter mode.

12.2.5.6 enum flexio_timer_output_t

Enumerator
kFLEXIO_TimerOutputOneNotAffectedByReset Logic one when enabled and is not affected by
timer reset.
kFLEXIO_TimerOutputZeroNotAffectedByReset Logic zero when enabled and is not affected by
timer reset.
kFLEXIO_TimerOutputOneAffectedByReset Logic one when enabled and on timer reset.
kFLEXIO_TimerOutputZeroAffectedByReset Logic zero when enabled and on timer reset.

MCUXpresso SDK API Reference Manual


150 NXP Semiconductors
FlexIO Driver

12.2.5.7 enum flexio_timer_decrement_source_t

Enumerator
kFLEXIO_TimerDecSrcOnFlexIOClockShiftTimerOutput Decrement counter on FlexIO clock,
Shift clock equals Timer output.
kFLEXIO_TimerDecSrcOnTriggerInputShiftTimerOutput Decrement counter on Trigger input
(both edges), Shift clock equals Timer output.
kFLEXIO_TimerDecSrcOnPinInputShiftPinInput Decrement counter on Pin input (both edges),
Shift clock equals Pin input.
kFLEXIO_TimerDecSrcOnTriggerInputShiftTriggerInput Decrement counter on Trigger input
(both edges), Shift clock equals Trigger input.

12.2.5.8 enum flexio_timer_reset_condition_t

Enumerator
kFLEXIO_TimerResetNever Timer never reset.
kFLEXIO_TimerResetOnTimerPinEqualToTimerOutput Timer reset on Timer Pin equal to Timer
Output.
kFLEXIO_TimerResetOnTimerTriggerEqualToTimerOutput Timer reset on Timer Trigger equal
to Timer Output.
kFLEXIO_TimerResetOnTimerPinRisingEdge Timer reset on Timer Pin rising edge.
kFLEXIO_TimerResetOnTimerTriggerRisingEdge Timer reset on Trigger rising edge.
kFLEXIO_TimerResetOnTimerTriggerBothEdge Timer reset on Trigger rising or falling edge.

12.2.5.9 enum flexio_timer_disable_condition_t

Enumerator
kFLEXIO_TimerDisableNever Timer never disabled.
kFLEXIO_TimerDisableOnPreTimerDisable Timer disabled on Timer N-1 disable.
kFLEXIO_TimerDisableOnTimerCompare Timer disabled on Timer compare.
kFLEXIO_TimerDisableOnTimerCompareTriggerLow Timer disabled on Timer compare and
Trigger Low.
kFLEXIO_TimerDisableOnPinBothEdge Timer disabled on Pin rising or falling edge.
kFLEXIO_TimerDisableOnPinBothEdgeTriggerHigh Timer disabled on Pin rising or falling edge
provided Trigger is high.
kFLEXIO_TimerDisableOnTriggerFallingEdge Timer disabled on Trigger falling edge.

12.2.5.10 enum flexio_timer_enable_condition_t

Enumerator
kFLEXIO_TimerEnabledAlways Timer always enabled.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 151
FlexIO Driver

kFLEXIO_TimerEnableOnPrevTimerEnable Timer enabled on Timer N-1 enable.


kFLEXIO_TimerEnableOnTriggerHigh Timer enabled on Trigger high.
kFLEXIO_TimerEnableOnTriggerHighPinHigh Timer enabled on Trigger high and Pin high.
kFLEXIO_TimerEnableOnPinRisingEdge Timer enabled on Pin rising edge.
kFLEXIO_TimerEnableOnPinRisingEdgeTriggerHigh Timer enabled on Pin rising edge and Trig-
ger high.
kFLEXIO_TimerEnableOnTriggerRisingEdge Timer enabled on Trigger rising edge.
kFLEXIO_TimerEnableOnTriggerBothEdge Timer enabled on Trigger rising or falling edge.

12.2.5.11 enum flexio_timer_stop_bit_condition_t

Enumerator
kFLEXIO_TimerStopBitDisabled Stop bit disabled.
kFLEXIO_TimerStopBitEnableOnTimerCompare Stop bit is enabled on timer compare.
kFLEXIO_TimerStopBitEnableOnTimerDisable Stop bit is enabled on timer disable.
kFLEXIO_TimerStopBitEnableOnTimerCompareDisable Stop bit is enabled on timer compare
and timer disable.

12.2.5.12 enum flexio_timer_start_bit_condition_t

Enumerator
kFLEXIO_TimerStartBitDisabled Start bit disabled.
kFLEXIO_TimerStartBitEnabled Start bit enabled.

12.2.5.13 enum flexio_shifter_timer_polarity_t

Enumerator
kFLEXIO_ShifterTimerPolarityOnPositive Shift on positive edge of shift clock.
kFLEXIO_ShifterTimerPolarityOnNegitive Shift on negative edge of shift clock.

12.2.5.14 enum flexio_shifter_mode_t

Enumerator
kFLEXIO_ShifterDisabled Shifter is disabled.
kFLEXIO_ShifterModeReceive Receive mode.
kFLEXIO_ShifterModeTransmit Transmit mode.
kFLEXIO_ShifterModeMatchStore Match store mode.
kFLEXIO_ShifterModeMatchContinuous Match continuous mode.

MCUXpresso SDK API Reference Manual


152 NXP Semiconductors
FlexIO Driver

12.2.5.15 enum flexio_shifter_input_source_t

Enumerator
kFLEXIO_ShifterInputFromPin Shifter input from pin.
kFLEXIO_ShifterInputFromNextShifterOutput Shifter input from Shifter N+1.

12.2.5.16 enum flexio_shifter_stop_bit_t

Enumerator
kFLEXIO_ShifterStopBitDisable Disable shifter stop bit.
kFLEXIO_ShifterStopBitLow Set shifter stop bit to logic low level.
kFLEXIO_ShifterStopBitHigh Set shifter stop bit to logic high level.

12.2.5.17 enum flexio_shifter_start_bit_t

Enumerator
kFLEXIO_ShifterStartBitDisabledLoadDataOnEnable Disable shifter start bit, transmitter loads
data on enable.
kFLEXIO_ShifterStartBitDisabledLoadDataOnShift Disable shifter start bit, transmitter loads
data on first shift.
kFLEXIO_ShifterStartBitLow Set shifter start bit to logic low level.
kFLEXIO_ShifterStartBitHigh Set shifter start bit to logic high level.

12.2.5.18 enum flexio_shifter_buffer_type_t

Enumerator
kFLEXIO_ShifterBuffer Shifter Buffer N Register.
kFLEXIO_ShifterBufferBitSwapped Shifter Buffer N Bit Byte Swapped Register.
kFLEXIO_ShifterBufferByteSwapped Shifter Buffer N Byte Swapped Register.
kFLEXIO_ShifterBufferBitByteSwapped Shifter Buffer N Bit Swapped Register.

12.2.6 Function Documentation

12.2.6.1 void FLEXIO_GetDefaultConfig ( flexio_config_t ∗ userConfig )

The configuration can used directly to call the FLEXIO_Configure().


Example:
flexio_config_t config;
FLEXIO_GetDefaultConfig(&config);

MCUXpresso SDK API Reference Manual


NXP Semiconductors 153
FlexIO Driver

Parameters

userConfig pointer to flexio_config_t structure

12.2.6.2 void FLEXIO_Init ( FLEXIO_Type ∗ base, const flexio_config_t ∗ userConfig )

The configuration structure can be filled by the user or be set with default values by FLEXIO_GetDefault-
Config().
Example

flexio_config_t config = {
.enableFlexio = true,
.enableInDoze = false,
.enableInDebug = true,
.enableFastAccess = false
};
FLEXIO_Configure(base, &config);

Parameters

base FlexIO peripheral base address


userConfig pointer to flexio_config_t structure

12.2.6.3 void FLEXIO_Deinit ( FLEXIO_Type ∗ base )

Call this API to stop the FlexIO clock.

Note
After calling this API, call the FLEXO_Init to use the FlexIO module.

Parameters

base FlexIO peripheral base address

12.2.6.4 uint32_t FLEXIO_GetInstance ( FLEXIO_Type ∗ base )

MCUXpresso SDK API Reference Manual


154 NXP Semiconductors
FlexIO Driver

Parameters

base FLEXIO peripheral base address.

12.2.6.5 void FLEXIO_Reset ( FLEXIO_Type ∗ base )

Parameters

base FlexIO peripheral base address

12.2.6.6 static void FLEXIO_Enable ( FLEXIO_Type ∗ base, bool enable ) [inline],


[static]

Parameters

base FlexIO peripheral base address


enable true to enable, false to disable.

12.2.6.7 void FLEXIO_SetShifterConfig ( FLEXIO_Type ∗ base, uint8_t index, const


flexio_shifter_config_t ∗ shifterConfig )

The configuration structure covers both the SHIFTCTL and SHIFTCFG registers. To configure the shifter
to the proper mode, select which timer controls the shifter to shift, whether to generate start bit/stop bit,
and the polarity of start bit and stop bit.
Example

flexio_shifter_config_t config = {
.timerSelect = 0,
.timerPolarity = kFLEXIO_ShifterTimerPolarityOnPositive,
.pinConfig = kFLEXIO_PinConfigOpenDrainOrBidirection,
.pinPolarity = kFLEXIO_PinActiveLow,
.shifterMode = kFLEXIO_ShifterModeTransmit,
.inputSource = kFLEXIO_ShifterInputFromPin,
.shifterStop = kFLEXIO_ShifterStopBitHigh,
.shifterStart = kFLEXIO_ShifterStartBitLow
};
FLEXIO_SetShifterConfig(base, &config);

MCUXpresso SDK API Reference Manual


NXP Semiconductors 155
FlexIO Driver

Parameters

base FlexIO peripheral base address


index Shifter index
shifterConfig Pointer to flexio_shifter_config_t structure

12.2.6.8 void FLEXIO_SetTimerConfig ( FLEXIO_Type ∗ base, uint8_t index, const


flexio_timer_config_t ∗ timerConfig )

The configuration structure covers both the TIMCTL and TIMCFG registers. To configure the timer to the
proper mode, select trigger source for timer and the timer pin output and the timing for timer.
Example

flexio_timer_config_t config = {
.triggerSelect = FLEXIO_TIMER_TRIGGER_SEL_SHIFTnSTAT(0),
.triggerPolarity = kFLEXIO_TimerTriggerPolarityActiveLow,
.triggerSource = kFLEXIO_TimerTriggerSourceInternal,
.pinConfig = kFLEXIO_PinConfigOpenDrainOrBidirection,
.pinSelect = 0,
.pinPolarity = kFLEXIO_PinActiveHigh,
.timerMode = kFLEXIO_TimerModeDual8BitBaudBit,
.timerOutput = kFLEXIO_TimerOutputZeroNotAffectedByReset,
.timerDecrement = kFLEXIO_TimerDecSrcOnFlexIOClockShiftTimerOutput
,
.timerReset = kFLEXIO_TimerResetOnTimerPinEqualToTimerOutput,
.timerDisable = kFLEXIO_TimerDisableOnTimerCompare,
.timerEnable = kFLEXIO_TimerEnableOnTriggerHigh,
.timerStop = kFLEXIO_TimerStopBitEnableOnTimerDisable,
.timerStart = kFLEXIO_TimerStartBitEnabled
};
FLEXIO_SetTimerConfig(base, &config);

Parameters

base FlexIO peripheral base address


index Timer index
timerConfig Pointer to the flexio_timer_config_t structure

12.2.6.9 static void FLEXIO_EnableShifterStatusInterrupts ( FLEXIO_Type ∗ base,


uint32_t mask ) [inline], [static]

The interrupt generates when the corresponding SSF is set.

MCUXpresso SDK API Reference Manual


156 NXP Semiconductors
FlexIO Driver

Parameters

base FlexIO peripheral base address


mask The shifter status mask which can be calculated by (1 << shifter index)

Note
For multiple shifter status interrupt enable, for example, two shifter status enable, can calculate the
mask by using ((1 << shifter index0) | (1 << shifter index1))

12.2.6.10 static void FLEXIO_DisableShifterStatusInterrupts ( FLEXIO_Type ∗ base,


uint32_t mask ) [inline], [static]

The interrupt won’t generate when the corresponding SSF is set.


Parameters

base FlexIO peripheral base address


mask The shifter status mask which can be calculated by (1 << shifter index)

Note
For multiple shifter status interrupt enable, for example, two shifter status enable, can calculate the
mask by using ((1 << shifter index0) | (1 << shifter index1))

12.2.6.11 static void FLEXIO_EnableShifterErrorInterrupts ( FLEXIO_Type ∗ base,


uint32_t mask ) [inline], [static]

The interrupt generates when the corresponding SEF is set.


Parameters

base FlexIO peripheral base address


mask The shifter error mask which can be calculated by (1 << shifter index)

Note
For multiple shifter error interrupt enable, for example, two shifter error enable, can calculate the
mask by using ((1 << shifter index0) | (1 << shifter index1))

MCUXpresso SDK API Reference Manual


NXP Semiconductors 157
FlexIO Driver

12.2.6.12 static void FLEXIO_DisableShifterErrorInterrupts ( FLEXIO_Type ∗ base,


uint32_t mask ) [inline], [static]

The interrupt won’t generate when the corresponding SEF is set.

MCUXpresso SDK API Reference Manual


158 NXP Semiconductors
FlexIO Driver

Parameters

base FlexIO peripheral base address


mask The shifter error mask which can be calculated by (1 << shifter index)

Note
For multiple shifter error interrupt enable, for example, two shifter error enable, can calculate the
mask by using ((1 << shifter index0) | (1 << shifter index1))

12.2.6.13 static void FLEXIO_EnableTimerStatusInterrupts ( FLEXIO_Type ∗ base,


uint32_t mask ) [inline], [static]

The interrupt generates when the corresponding SSF is set.


Parameters

base FlexIO peripheral base address


mask The timer status mask which can be calculated by (1 << timer index)

Note
For multiple timer status interrupt enable, for example, two timer status enable, can calculate the
mask by using ((1 << timer index0) | (1 << timer index1))

12.2.6.14 static void FLEXIO_DisableTimerStatusInterrupts ( FLEXIO_Type ∗ base,


uint32_t mask ) [inline], [static]

The interrupt won’t generate when the corresponding SSF is set.


Parameters

base FlexIO peripheral base address


mask The timer status mask which can be calculated by (1 << timer index)

Note
For multiple timer status interrupt enable, for example, two timer status enable, can calculate the
mask by using ((1 << timer index0) | (1 << timer index1))

12.2.6.15 static uint32_t FLEXIO_GetShifterStatusFlags ( FLEXIO_Type ∗ base )


[inline], [static]

MCUXpresso SDK API Reference Manual


NXP Semiconductors 159
FlexIO Driver

Parameters

base FlexIO peripheral base address

Returns
Shifter status flags

12.2.6.16 static void FLEXIO_ClearShifterStatusFlags ( FLEXIO_Type ∗ base, uint32_t


mask ) [inline], [static]

Parameters

base FlexIO peripheral base address


mask The shifter status mask which can be calculated by (1 << shifter index)

Note
For clearing multiple shifter status flags, for example, two shifter status flags, can calculate the mask
by using ((1 << shifter index0) | (1 << shifter index1))

12.2.6.17 static uint32_t FLEXIO_GetShifterErrorFlags ( FLEXIO_Type ∗ base )


[inline], [static]

Parameters

base FlexIO peripheral base address

Returns
Shifter error flags

12.2.6.18 static void FLEXIO_ClearShifterErrorFlags ( FLEXIO_Type ∗ base, uint32_t


mask ) [inline], [static]

MCUXpresso SDK API Reference Manual


160 NXP Semiconductors
FlexIO Driver

Parameters

base FlexIO peripheral base address


mask The shifter error mask which can be calculated by (1 << shifter index)

Note
For clearing multiple shifter error flags, for example, two shifter error flags, can calculate the mask
by using ((1 << shifter index0) | (1 << shifter index1))

12.2.6.19 static uint32_t FLEXIO_GetTimerStatusFlags ( FLEXIO_Type ∗ base )


[inline], [static]

Parameters

base FlexIO peripheral base address

Returns
Timer status flags

12.2.6.20 static void FLEXIO_ClearTimerStatusFlags ( FLEXIO_Type ∗ base, uint32_t


mask ) [inline], [static]

Parameters

base FlexIO peripheral base address


mask The timer status mask which can be calculated by (1 << timer index)

Note
For clearing multiple timer status flags, for example, two timer status flags, can calculate the mask
by using ((1 << timer index0) | (1 << timer index1))

12.2.6.21 static void FLEXIO_EnableShifterStatusDMA ( FLEXIO_Type ∗ base, uint32_t


mask, bool enable ) [inline], [static]

The DMA request generates when the corresponding SSF is set.


Note
For multiple shifter status DMA enables, for example, calculate the mask by using ((1 << shifter
index0) | (1 << shifter index1))

MCUXpresso SDK API Reference Manual


NXP Semiconductors 161
FlexIO Driver

Parameters

base FlexIO peripheral base address


mask The shifter status mask which can be calculated by (1 << shifter index)
enable True to enable, false to disable.

12.2.6.22 uint32_t FLEXIO_GetShifterBufferAddress ( FLEXIO_Type ∗ base,


flexio_shifter_buffer_type_t type, uint8_t index )

Parameters

base FlexIO peripheral base address


type Shifter type of flexio_shifter_buffer_type_t
index Shifter index

Returns
Corresponding shifter buffer index

12.2.6.23 status_t FLEXIO_RegisterHandleIRQ ( void ∗ base, void ∗ handle, flexio_isr_t


isr )

Parameters

base Pointer to the FlexIO simulated peripheral type.


handle Pointer to the handler for FlexIO simulated peripheral.
isr FlexIO simulated peripheral interrupt handler.

Return values

kStatus_Success Successfully create the handle.


kStatus_OutOfRange The FlexIO type/handle/ISR table out of range.

12.2.6.24 status_t FLEXIO_UnregisterHandleIRQ ( void ∗ base )

MCUXpresso SDK API Reference Manual


162 NXP Semiconductors
FlexIO Driver

Parameters

base Pointer to the FlexIO simulated peripheral type.

Return values

kStatus_Success Successfully create the handle.


kStatus_OutOfRange The FlexIO type/handle/ISR table out of range.

12.2.7 Variable Documentation

12.2.7.1 FLEXIO_Type∗ const s_flexioBases[ ]

12.2.7.2 const clock_ip_name_t s_flexioClocks[ ]

MCUXpresso SDK API Reference Manual


NXP Semiconductors 163
FlexIO Camera Driver

12.3 FlexIO Camera Driver


12.3.1 Overview

The MCUXpresso SDK provides a driver for the camera function using Flexible I/O.
FlexIO Camera driver includes functional APIs and eDMA transactional APIs. Functional APIs target
low level APIs. Users can use functional APIs for FlexIO Camera initialization/configuration/operation
purpose. Using the functional API requires knowledge of the FlexIO Camera peripheral and how to
organize functional APIs to meet the requirements of the application. All functional API use the FLE-
XIO_CAMERA_Type ∗ as the first parameter. FlexIO Camera functional operation groups provide the
functional APIs set.
eDMA transactional APIs target high-level APIs. Users can use the transactional API to enable the pe-
ripheral quickly and can also use in the application if the code size and performance of transactional APIs
satisfy requirements. If the code size and performance are critical requirements, see the transactional API
implementation and write custom code. All transactional APIs use the flexio_camera_edma_handle_t as
the second parameter. Users need to initialize the handle by calling the FLEXIO_CAMERA_Transfer-
CreateHandleEDMA() API.
eDMA transactional APIs support asynchronous receive. This means that the functions FLEXIO_CAME-
RA_TransferReceiveEDMA() set up an interrupt for data receive. When the receive is complete, the upper
layer is notified through a callback function with the status kStatus_FLEXIO_CAMERA_RxIdle.

12.3.2 Typical use case

12.3.2.1 FlexIO Camera Receive using eDMA method


volatile uint32_t isEDMAGetOnePictureFinish = false;
edma_handle_t g_edmaHandle;
flexio_camera_edma_handle_t g_cameraEdmaHandle;
edma_config_t edmaConfig;
FLEXIO_CAMERA_Type g_FlexioCameraDevice = {.flexioBase = FLEXIO0,
.datPinStartIdx = 24U, /* fxio_pin 24 -31 are used. */
.pclkPinIdx = 1U, /* fxio_pin 1 is used as pclk pin. */
.hrefPinIdx = 18U, /* flexio_pin 18 is used as href pin. */
.shifterStartIdx = 0U, /* Shifter 0 = 7 are used. */
.shifterCount = 8U,
.timerIdx = 0U};
flexio_camera_config_t cameraConfig;

/* Configure DMAMUX */
DMAMUX_Init(DMAMUX0);
/* Configure DMA */
EDMA_GetDefaultConfig(&edmaConfig);
EDMA_Init(DMA0, &edmaConfig);

DMAMUX_SetSource(DMAMUX0, DMA_CHN_FLEXIO_TO_FRAMEBUFF, (g_FlexioCameraDevice.


shifterStartIdx + 1U));
DMAMUX_EnableChannel(DMAMUX0, DMA_CHN_FLEXIO_TO_FRAMEBUFF);
EDMA_CreateHandle(&g_edmaHandle, DMA0, DMA_CHN_FLEXIO_TO_FRAMEBUFF);

FLEXIO_CAMERA_GetDefaultConfig(&cameraConfig);
FLEXIO_CAMERA_Init(&g_FlexioCameraDevice, &cameraConfig);
/* Clear all the flag. */

MCUXpresso SDK API Reference Manual


164 NXP Semiconductors
FlexIO Camera Driver

FLEXIO_CAMERA_ClearStatusFlags(&g_FlexioCameraDevice,
kFLEXIO_CAMERA_RxDataRegFullFlag |
kFLEXIO_CAMERA_RxErrorFlag);
FLEXIO_ClearTimerStatusFlags(FLEXIO0, 0xFF);
FLEXIO_CAMERA_TransferCreateHandleEDMA(&g_FlexioCameraDevice, &
g_cameraEdmaHandle, FLEXIO_CAMERA_UserCallback, NULL,
&g_edmaHandle);
cameraTransfer.dataAddress = (uint32_t)u16CameraFrameBuffer;
cameraTransfer.dataNum = sizeof(u16CameraFrameBuffer);
FLEXIO_CAMERA_TransferReceiveEDMA(&g_FlexioCameraDevice, &
g_cameraEdmaHandle, &cameraTransfer);
while (!(isEDMAGetOnePictureFinish))
{
;
}

/* A callback function is also needed */


void FLEXIO_CAMERA_UserCallback(FLEXIO_CAMERA_Type *base,
flexio_camera_edma_handle_t *handle,
status_t status,
void *userData)
{
userData = userData;
/* eDMA Transfer finished */
if (kStatus_FLEXIO_CAMERA_RxIdle == status)
{
isEDMAGetOnePictureFinish = true;
}
}

Modules

• FlexIO eDMA Camera Driver

Data Structures

• struct FLEXIO_CAMERA_Type
Define structure of configuring the FlexIO Camera device. More...
• struct flexio_camera_config_t
Define FlexIO Camera user configuration structure. More...
• struct flexio_camera_transfer_t
Define FlexIO Camera transfer structure. More...

Macros

• #define FLEXIO_CAMERA_PARALLEL_DATA_WIDTH (8U)


Define the Camera CPI interface is constantly 8-bit width.

Enumerations

• enum _flexio_camera_status {
kStatus_FLEXIO_CAMERA_RxBusy = MAKE_STATUS(kStatusGroup_FLEXIO_CAMERA,

MCUXpresso SDK API Reference Manual


NXP Semiconductors 165
FlexIO Camera Driver

0),
kStatus_FLEXIO_CAMERA_RxIdle = MAKE_STATUS(kStatusGroup_FLEXIO_CAMERA, 1)
}
Error codes for the Camera driver.
• enum _flexio_camera_status_flags {
kFLEXIO_CAMERA_RxDataRegFullFlag = 0x1U,
kFLEXIO_CAMERA_RxErrorFlag = 0x2U }
Define FlexIO Camera status mask.

Driver version

• #define FSL_FLEXIO_CAMERA_DRIVER_VERSION (MAKE_VERSION(2, 1, 2))


FlexIO Camera driver version 2.1.2.

Initialization and configuration

• void FLEXIO_CAMERA_Init (FLEXIO_CAMERA_Type ∗base, const flexio_camera_config_-


t ∗config)
Ungates the FlexIO clock, resets the FlexIO module, and configures the FlexIO Camera.
• void FLEXIO_CAMERA_Deinit (FLEXIO_CAMERA_Type ∗base)
Resets the FLEXIO_CAMERA shifer and timer config.
• void FLEXIO_CAMERA_GetDefaultConfig (flexio_camera_config_t ∗config)
Gets the default configuration to configure the FlexIO Camera.
• static void FLEXIO_CAMERA_Enable (FLEXIO_CAMERA_Type ∗base, bool enable)
Enables/disables the FlexIO Camera module operation.

Status

• uint32_t FLEXIO_CAMERA_GetStatusFlags (FLEXIO_CAMERA_Type ∗base)


Gets the FlexIO Camera status flags.
• void FLEXIO_CAMERA_ClearStatusFlags (FLEXIO_CAMERA_Type ∗base, uint32_t mask)
Clears the receive buffer full flag manually.

Interrupts

• void FLEXIO_CAMERA_EnableInterrupt (FLEXIO_CAMERA_Type ∗base)


Switches on the interrupt for receive buffer full event.
• void FLEXIO_CAMERA_DisableInterrupt (FLEXIO_CAMERA_Type ∗base)
Switches off the interrupt for receive buffer full event.

DMA support

• static void FLEXIO_CAMERA_EnableRxDMA (FLEXIO_CAMERA_Type ∗base, bool enable)

MCUXpresso SDK API Reference Manual


166 NXP Semiconductors
FlexIO Camera Driver

Enables/disables the FlexIO Camera receive DMA.


• static uint32_t FLEXIO_CAMERA_GetRxBufferAddress (FLEXIO_CAMERA_Type ∗base)
Gets the data from the receive buffer.

12.3.3 Data Structure Documentation

12.3.3.1 struct FLEXIO_CAMERA_Type

Data Fields
• FLEXIO_Type ∗ flexioBase
FlexIO module base address.
• uint32_t datPinStartIdx
First data pin (D0) index for flexio_camera.
• uint32_t pclkPinIdx
Pixel clock pin (PCLK) index for flexio_camera.
• uint32_t hrefPinIdx
Horizontal sync pin (HREF) index for flexio_camera.
• uint32_t shifterStartIdx
First shifter index used for flexio_camera data FIFO.
• uint32_t shifterCount
The count of shifters that are used as flexio_camera data FIFO.
• uint32_t timerIdx
Timer index used for flexio_camera in FlexIO.

12.3.3.1.0.4 Field Documentation

12.3.3.1.0.4.1 FLEXIO_Type∗ FLEXIO_CAMERA_Type::flexioBase

12.3.3.1.0.4.2 uint32_t FLEXIO_CAMERA_Type::datPinStartIdx

Then the successive following FLEXIO_CAMERA_DATA_WIDTH-1 pins are used as D1-D7.

12.3.3.1.0.4.3 uint32_t FLEXIO_CAMERA_Type::pclkPinIdx

12.3.3.1.0.4.4 uint32_t FLEXIO_CAMERA_Type::hrefPinIdx

12.3.3.1.0.4.5 uint32_t FLEXIO_CAMERA_Type::shifterStartIdx

12.3.3.1.0.4.6 uint32_t FLEXIO_CAMERA_Type::shifterCount

12.3.3.1.0.4.7 uint32_t FLEXIO_CAMERA_Type::timerIdx

12.3.3.2 struct flexio_camera_config_t

Data Fields
• bool enablecamera
Enable/disable FlexIO Camera TX & RX.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 167
FlexIO Camera Driver

• bool enableInDoze
Enable/disable FlexIO operation in doze mode.
• bool enableInDebug
Enable/disable FlexIO operation in debug mode.
• bool enableFastAccess
Enable/disable fast access to FlexIO registers,
fast access requires the FlexIO clock to be at least twice the frequency of the bus clock.

12.3.3.2.0.5 Field Documentation

12.3.3.2.0.5.1 bool flexio_camera_config_t::enablecamera

12.3.3.2.0.5.2 bool flexio_camera_config_t::enableFastAccess

12.3.3.3 struct flexio_camera_transfer_t

Data Fields
• uint32_t dataAddress
Transfer buffer.
• uint32_t dataNum
Transfer num.

12.3.4 Macro Definition Documentation

12.3.4.1 #define FSL_FLEXIO_CAMERA_DRIVER_VERSION (MAKE_VERSION(2, 1, 2))

12.3.4.2 #define FLEXIO_CAMERA_PARALLEL_DATA_WIDTH (8U)

12.3.5 Enumeration Type Documentation

12.3.5.1 enum _flexio_camera_status

Enumerator
kStatus_FLEXIO_CAMERA_RxBusy Receiver is busy.
kStatus_FLEXIO_CAMERA_RxIdle Camera receiver is idle.

12.3.5.2 enum _flexio_camera_status_flags

Enumerator
kFLEXIO_CAMERA_RxDataRegFullFlag Receive buffer full flag.
kFLEXIO_CAMERA_RxErrorFlag Receive buffer error flag.

MCUXpresso SDK API Reference Manual


168 NXP Semiconductors
FlexIO Camera Driver

12.3.6 Function Documentation

12.3.6.1 void FLEXIO_CAMERA_Init ( FLEXIO_CAMERA_Type ∗ base, const


flexio_camera_config_t ∗ config )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 169
FlexIO Camera Driver

Parameters

base Pointer to FLEXIO_CAMERA_Type structure


config Pointer to flexio_camera_config_t structure

12.3.6.2 void FLEXIO_CAMERA_Deinit ( FLEXIO_CAMERA_Type ∗ base )

Note
After calling this API, call FLEXO_CAMERA_Init to use the FlexIO Camera module.

Parameters

base Pointer to FLEXIO_CAMERA_Type structure

12.3.6.3 void FLEXIO_CAMERA_GetDefaultConfig ( flexio_camera_config_t ∗ config )

The configuration can be used directly for calling the FLEXIO_CAMERA_Init(). Example:

flexio_camera_config_t config;
FLEXIO_CAMERA_GetDefaultConfig(&userConfig);

Parameters

config Pointer to the flexio_camera_config_t structure

12.3.6.4 static void FLEXIO_CAMERA_Enable ( FLEXIO_CAMERA_Type ∗ base, bool


enable ) [inline], [static]

Parameters

base Pointer to the FLEXIO_CAMERA_Type


enable True to enable, false does not have any effect.

12.3.6.5 uint32_t FLEXIO_CAMERA_GetStatusFlags ( FLEXIO_CAMERA_Type ∗ base )

MCUXpresso SDK API Reference Manual


170 NXP Semiconductors
FlexIO Camera Driver

Parameters

base Pointer to FLEXIO_CAMERA_Type structure

Returns
FlexIO shifter status flags
• FLEXIO_SHIFTSTAT_SSF_MASK
• 0

12.3.6.6 void FLEXIO_CAMERA_ClearStatusFlags ( FLEXIO_CAMERA_Type ∗ base,


uint32_t mask )

Parameters

base Pointer to the device.


mask status flag The parameter can be any combination of the following values:
• kFLEXIO_CAMERA_RxDataRegFullFlag
• kFLEXIO_CAMERA_RxErrorFlag

12.3.6.7 void FLEXIO_CAMERA_EnableInterrupt ( FLEXIO_CAMERA_Type ∗ base )

Parameters

base Pointer to the device.

12.3.6.8 void FLEXIO_CAMERA_DisableInterrupt ( FLEXIO_CAMERA_Type ∗ base )

Parameters

base Pointer to the device.

12.3.6.9 static void FLEXIO_CAMERA_EnableRxDMA ( FLEXIO_CAMERA_Type ∗ base,


bool enable ) [inline], [static]

MCUXpresso SDK API Reference Manual


NXP Semiconductors 171
FlexIO Camera Driver

Parameters

base Pointer to FLEXIO_CAMERA_Type structure


enable True to enable, false to disable.
The FlexIO Camera mode can’t work without the DMA or eDMA support, Usually, it needs at least two
DMA or eDMA channels, one for transferring data from Camera, such as 0V7670 to FlexIO buffer,
another is for transferring data from FlexIO buffer to LCD.

12.3.6.10 static uint32_t FLEXIO_CAMERA_GetRxBufferAddress (


FLEXIO_CAMERA_Type ∗ base ) [inline], [static]

Parameters

base Pointer to the device.

Returns
data Pointer to the buffer that keeps the data with count of base->shifterCount .

MCUXpresso SDK API Reference Manual


172 NXP Semiconductors
FlexIO Camera Driver

12.3.7 FlexIO eDMA Camera Driver

12.3.7.1 Overview

Data Structures
• struct flexio_camera_edma_handle_t
Camera eDMA handle. More...

Typedefs
• typedef void(∗ flexio_camera_edma_transfer_callback_t )(FLEXIO_CAMERA_Type ∗base, flexio-
_camera_edma_handle_t ∗handle, status_t status, void ∗userData)
Camera transfer callback function.

Driver version
• #define FSL_FLEXIO_CAMERA_EDMA_DRIVER_VERSION (MAKE_VERSION(2, 1, 2))
FlexIO Camera EDMA driver version 2.1.2.

eDMA transactional
• status_t FLEXIO_CAMERA_TransferCreateHandleEDMA (FLEXIO_CAMERA_Type ∗base,
flexio_camera_edma_handle_t ∗handle, flexio_camera_edma_transfer_callback_t callback, void
∗userData, edma_handle_t ∗rxEdmaHandle)
Initializes the Camera handle, which is used in transactional functions.
• status_t FLEXIO_CAMERA_TransferReceiveEDMA (FLEXIO_CAMERA_Type ∗base, flexio_-
camera_edma_handle_t ∗handle, flexio_camera_transfer_t ∗xfer)
Receives data using eDMA.
• void FLEXIO_CAMERA_TransferAbortReceiveEDMA (FLEXIO_CAMERA_Type ∗base, flexio-
_camera_edma_handle_t ∗handle)
Aborts the receive data which used the eDMA.
• status_t FLEXIO_CAMERA_TransferGetReceiveCountEDMA (FLEXIO_CAMERA_Type ∗base,
flexio_camera_edma_handle_t ∗handle, size_t ∗count)
Gets the remaining bytes to be received.

12.3.7.2 Data Structure Documentation

12.3.7.2.1 struct _flexio_camera_edma_handle

Forward declaration of the handle typedef.

Data Fields

• flexio_camera_edma_transfer_callback_t callback

MCUXpresso SDK API Reference Manual


NXP Semiconductors 173
FlexIO Camera Driver

Callback function.
• void ∗ userData
Camera callback function parameter.
• size_t rxSize
Total bytes to be received.
• edma_handle_t ∗ rxEdmaHandle
The eDMA RX channel used.
• uint8_t nbytes
eDMA minor byte transfer count initially configured.
• volatile uint8_t rxState
RX transfer state.

12.3.7.2.1.1 Field Documentation

12.3.7.2.1.1.1 flexio_camera_edma_transfer_callback_t flexio_camera_edma_handle_t::callback

12.3.7.2.1.1.2 void∗ flexio_camera_edma_handle_t::userData

12.3.7.2.1.1.3 size_t flexio_camera_edma_handle_t::rxSize

12.3.7.2.1.1.4 edma_handle_t∗ flexio_camera_edma_handle_t::rxEdmaHandle

12.3.7.2.1.1.5 uint8_t flexio_camera_edma_handle_t::nbytes

12.3.7.3 Macro Definition Documentation

12.3.7.3.1 #define FSL_FLEXIO_CAMERA_EDMA_DRIVER_VERSION (MAKE_VERSION(2, 1, 2))

12.3.7.4 Typedef Documentation

12.3.7.4.1 typedef void(∗ flexio_camera_edma_transfer_callback_t)(FLEXIO_CAMERA_Type


∗base, flexio_camera_edma_handle_t ∗handle, status_t status, void ∗userData)

12.3.7.5 Function Documentation

12.3.7.5.1 status_t FLEXIO_CAMERA_TransferCreateHandleEDMA ( FLEXIO_CAMERA_Type


∗ base, flexio_camera_edma_handle_t ∗ handle, flexio_camera_edma_transfer-
_callback_t callback, void ∗ userData, edma_handle_t ∗ rxEdmaHandle
)

Parameters

base Pointer to the FLEXIO_CAMERA_Type.

MCUXpresso SDK API Reference Manual


174 NXP Semiconductors
FlexIO Camera Driver

handle Pointer to flexio_camera_edma_handle_t structure.


callback The callback function.
userData The parameter of the callback function.
rxEdmaHandle User requested DMA handle for RX DMA transfer.

Return values

kStatus_Success Successfully create the handle.


kStatus_OutOfRange The FlexIO Camera eDMA type/handle table out of range.

12.3.7.5.2 status_t FLEXIO_CAMERA_TransferReceiveEDMA ( FLEXIO_CAMERA_Type ∗ base,


flexio_camera_edma_handle_t ∗ handle, flexio_camera_transfer_t ∗ xfer )

This function receives data using eDMA. This is a non-blocking function, which returns right away. When
all data is received, the receive callback function is called.
Parameters

base Pointer to the FLEXIO_CAMERA_Type.


handle Pointer to the flexio_camera_edma_handle_t structure.
xfer Camera eDMA transfer structure, see flexio_camera_transfer_t.

Return values

kStatus_Success if succeeded, others failed.


kStatus_CAMERA_Rx- Previous transfer on going.
Busy

12.3.7.5.3 void FLEXIO_CAMERA_TransferAbortReceiveEDMA ( FLEXIO_CAMERA_Type ∗


base, flexio_camera_edma_handle_t ∗ handle )

This function aborts the receive data which used the eDMA.
Parameters

base Pointer to the FLEXIO_CAMERA_Type.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 175
FlexIO Camera Driver

handle Pointer to the flexio_camera_edma_handle_t structure.

12.3.7.5.4 status_t FLEXIO_CAMERA_TransferGetReceiveCountEDMA ( FLEXIO_CAM-


ERA_Type ∗ base, flexio_camera_edma_handle_t ∗ handle, size_t ∗ count
)

This function gets the number of bytes still not received.


Parameters

base Pointer to the FLEXIO_CAMERA_Type.


handle Pointer to the flexio_camera_edma_handle_t structure.
count Number of bytes sent so far by the non-blocking transaction.

Return values

kStatus_Success Succeed get the transfer count.


kStatus_InvalidArgument The count parameter is invalid.

MCUXpresso SDK API Reference Manual


176 NXP Semiconductors
FlexIO I2C Master Driver

12.4 FlexIO I2C Master Driver


12.4.1 Overview

The MCUXpresso SDK provides a peripheral driver for I2C master function using Flexible I/O module of
MCUXpresso SDK devices.
The FlexIO I2C master driver includes functional APIs and transactional APIs.
Functional APIs target low level APIs. Functional APIs can be used for the FlexIO I2C master initial-
ization/configuration/operation for the optimization/customization purpose. Using the functional APIs
requires the knowledge of the FlexIO I2C master peripheral and how to organize functional APIs to meet
the application requirements. The FlexIO I2C master functional operation groups provide the functional
APIs set.
Transactional APIs target high-level APIs. The transactional APIs can be used to enable the peripheral
quickly and also in the application if the code size and performance of transactional APIs satisfy the
requirements. If the code size and performance are critical requirements, see the transactional API imple-
mentation and write custom code using the functional APIs or accessing the hardware registers.
Transactional APIs support an asynchronous transfer. This means that the functions FLEXIO_I2C_-
MasterTransferNonBlocking() set up the interrupt non-blocking transfer. When the transfer completes,
the upper layer is notified through a callback function with the kStatus_Success status.

12.4.2 Typical use case

12.4.2.1 FlexIO I2C master transfer using an interrupt method


flexio_i2c_master_handle_t g_m_handle;
flexio_i2c_master_config_t masterConfig;
flexio_i2c_master_transfer_t masterXfer;
volatile bool completionFlag = false;
const uint8_t sendData[] = [......];
FLEXIO_I2C_Type i2cDev;

void FLEXIO_I2C_MasterCallback(FLEXIO_I2C_Type *base, status_t status, void *userData)


{
userData = userData;

if (kStatus_Success == status)
{
completionFlag = true;
}
}

void main(void)
{
//...

FLEXIO_I2C_MasterGetDefaultConfig(&masterConfig);

FLEXIO_I2C_MasterInit(&i2cDev, &user_config);
FLEXIO_I2C_MasterTransferCreateHandle(&i2cDev, &g_m_handle,
FLEXIO_I2C_MasterCallback, NULL);

// Prepares to send.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 177
FlexIO I2C Master Driver

masterXfer.slaveAddress = g_accel_address[0];
masterXfer.direction = kI2C_Read;
masterXfer.subaddress = &who_am_i_reg;
masterXfer.subaddressSize = 1;
masterXfer.data = &who_am_i_value;
masterXfer.dataSize = 1;
masterXfer.flags = kI2C_TransferDefaultFlag;

// Sends out.
FLEXIO_I2C_MasterTransferNonBlocking(&i2cDev, &g_m_handle, &
masterXfer);

// Wait for sending is complete.


while (!completionFlag)
{
}

// ...
}

Data Structures

• struct FLEXIO_I2C_Type
Define FlexIO I2C master access structure typedef. More...
• struct flexio_i2c_master_config_t
Define FlexIO I2C master user configuration structure. More...
• struct flexio_i2c_master_transfer_t
Define FlexIO I2C master transfer structure. More...
• struct flexio_i2c_master_handle_t
Define FlexIO I2C master handle structure. More...

Typedefs

• typedef void(∗ flexio_i2c_master_transfer_callback_t )(FLEXIO_I2C_Type ∗base, flexio_i2c_-


master_handle_t ∗handle, status_t status, void ∗userData)
FlexIO I2C master transfer callback typedef.

Enumerations

• enum _flexio_i2c_status {
kStatus_FLEXIO_I2C_Busy = MAKE_STATUS(kStatusGroup_FLEXIO_I2C, 0),
kStatus_FLEXIO_I2C_Idle = MAKE_STATUS(kStatusGroup_FLEXIO_I2C, 1),
kStatus_FLEXIO_I2C_Nak = MAKE_STATUS(kStatusGroup_FLEXIO_I2C, 2) }
FlexIO I2C transfer status.
• enum _flexio_i2c_master_interrupt {
kFLEXIO_I2C_TxEmptyInterruptEnable = 0x1U,
kFLEXIO_I2C_RxFullInterruptEnable = 0x2U }
Define FlexIO I2C master interrupt mask.
• enum _flexio_i2c_master_status_flags {

MCUXpresso SDK API Reference Manual


178 NXP Semiconductors
FlexIO I2C Master Driver

kFLEXIO_I2C_TxEmptyFlag = 0x1U,
kFLEXIO_I2C_RxFullFlag = 0x2U,
kFLEXIO_I2C_ReceiveNakFlag = 0x4U }
Define FlexIO I2C master status mask.
• enum flexio_i2c_direction_t {
kFLEXIO_I2C_Write = 0x0U,
kFLEXIO_I2C_Read = 0x1U }
Direction of master transfer.

Driver version

• #define FSL_FLEXIO_I2C_MASTER_DRIVER_VERSION (MAKE_VERSION(2, 1, 7))


FlexIO I2C master driver version 2.1.7.

Initialization and deinitialization

• status_t FLEXIO_I2C_MasterInit (FLEXIO_I2C_Type ∗base, flexio_i2c_master_config_t ∗master-


Config, uint32_t srcClock_Hz)
Ungates the FlexIO clock, resets the FlexIO module, and configures the FlexIO I2C hardware configura-
tion.
• void FLEXIO_I2C_MasterDeinit (FLEXIO_I2C_Type ∗base)
De-initializes the FlexIO I2C master peripheral.
• void FLEXIO_I2C_MasterGetDefaultConfig (flexio_i2c_master_config_t ∗masterConfig)
Gets the default configuration to configure the FlexIO module.
• static void FLEXIO_I2C_MasterEnable (FLEXIO_I2C_Type ∗base, bool enable)
Enables/disables the FlexIO module operation.

Status

• uint32_t FLEXIO_I2C_MasterGetStatusFlags (FLEXIO_I2C_Type ∗base)


Gets the FlexIO I2C master status flags.
• void FLEXIO_I2C_MasterClearStatusFlags (FLEXIO_I2C_Type ∗base, uint32_t mask)
Clears the FlexIO I2C master status flags.

Interrupts

• void FLEXIO_I2C_MasterEnableInterrupts (FLEXIO_I2C_Type ∗base, uint32_t mask)


Enables the FlexIO i2c master interrupt requests.
• void FLEXIO_I2C_MasterDisableInterrupts (FLEXIO_I2C_Type ∗base, uint32_t mask)
Disables the FlexIO I2C master interrupt requests.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 179
FlexIO I2C Master Driver

Bus Operations

• void FLEXIO_I2C_MasterSetBaudRate (FLEXIO_I2C_Type ∗base, uint32_t baudRate_Bps,


uint32_t srcClock_Hz)
Sets the FlexIO I2C master transfer baudrate.
• void FLEXIO_I2C_MasterStart (FLEXIO_I2C_Type ∗base, uint8_t address, flexio_i2c_direction_t
direction)
Sends START + 7-bit address to the bus.
• void FLEXIO_I2C_MasterStop (FLEXIO_I2C_Type ∗base)
Sends the stop signal on the bus.
• void FLEXIO_I2C_MasterRepeatedStart (FLEXIO_I2C_Type ∗base)
Sends the repeated start signal on the bus.
• void FLEXIO_I2C_MasterAbortStop (FLEXIO_I2C_Type ∗base)
Sends the stop signal when transfer is still on-going.
• void FLEXIO_I2C_MasterEnableAck (FLEXIO_I2C_Type ∗base, bool enable)
Configures the sent ACK/NAK for the following byte.
• status_t FLEXIO_I2C_MasterSetTransferCount (FLEXIO_I2C_Type ∗base, uint8_t count)
Sets the number of bytes to be transferred from a start signal to a stop signal.
• static void FLEXIO_I2C_MasterWriteByte (FLEXIO_I2C_Type ∗base, uint32_t data)
Writes one byte of data to the I2C bus.
• static uint8_t FLEXIO_I2C_MasterReadByte (FLEXIO_I2C_Type ∗base)
Reads one byte of data from the I2C bus.
• status_t FLEXIO_I2C_MasterWriteBlocking (FLEXIO_I2C_Type ∗base, const uint8_t ∗txBuff,
uint8_t txSize)
Sends a buffer of data in bytes.
• void FLEXIO_I2C_MasterReadBlocking (FLEXIO_I2C_Type ∗base, uint8_t ∗rxBuff, uint8_t rx-
Size)
Receives a buffer of bytes.
• status_t FLEXIO_I2C_MasterTransferBlocking (FLEXIO_I2C_Type ∗base, flexio_i2c_master_-
transfer_t ∗xfer)
Performs a master polling transfer on the I2C bus.

Transactional

• status_t FLEXIO_I2C_MasterTransferCreateHandle (FLEXIO_I2C_Type ∗base, flexio_i2c_-


master_handle_t ∗handle, flexio_i2c_master_transfer_callback_t callback, void ∗userData)
Initializes the I2C handle which is used in transactional functions.
• status_t FLEXIO_I2C_MasterTransferNonBlocking (FLEXIO_I2C_Type ∗base, flexio_i2c_-
master_handle_t ∗handle, flexio_i2c_master_transfer_t ∗xfer)
Performs a master interrupt non-blocking transfer on the I2C bus.
• status_t FLEXIO_I2C_MasterTransferGetCount (FLEXIO_I2C_Type ∗base, flexio_i2c_master_-
handle_t ∗handle, size_t ∗count)
Gets the master transfer status during a interrupt non-blocking transfer.
• void FLEXIO_I2C_MasterTransferAbort (FLEXIO_I2C_Type ∗base, flexio_i2c_master_handle_t
∗handle)
Aborts an interrupt non-blocking transfer early.
• void FLEXIO_I2C_MasterTransferHandleIRQ (void ∗i2cType, void ∗i2cHandle)
Master interrupt handler.

MCUXpresso SDK API Reference Manual


180 NXP Semiconductors
FlexIO I2C Master Driver

12.4.3 Data Structure Documentation

12.4.3.1 struct FLEXIO_I2C_Type

Data Fields
• FLEXIO_Type ∗ flexioBase
FlexIO base pointer.
• uint8_t SDAPinIndex
Pin select for I2C SDA.
• uint8_t SCLPinIndex
Pin select for I2C SCL.
• uint8_t shifterIndex [2]
Shifter index used in FlexIO I2C.
• uint8_t timerIndex [2]
Timer index used in FlexIO I2C.

12.4.3.1.0.1 Field Documentation

12.4.3.1.0.1.1 FLEXIO_Type∗ FLEXIO_I2C_Type::flexioBase

12.4.3.1.0.1.2 uint8_t FLEXIO_I2C_Type::SDAPinIndex

12.4.3.1.0.1.3 uint8_t FLEXIO_I2C_Type::SCLPinIndex

12.4.3.1.0.1.4 uint8_t FLEXIO_I2C_Type::shifterIndex[2]

12.4.3.1.0.1.5 uint8_t FLEXIO_I2C_Type::timerIndex[2]

12.4.3.2 struct flexio_i2c_master_config_t

Data Fields
• bool enableMaster
Enables the FlexIO I2C peripheral at initialization time.
• bool enableInDoze
Enable/disable FlexIO operation in doze mode.
• bool enableInDebug
Enable/disable FlexIO operation in debug mode.
• bool enableFastAccess
Enable/disable fast access to FlexIO registers, fast access requires
the FlexIO clock to be at least twice the frequency of the bus clock.
• uint32_t baudRate_Bps
Baud rate in Bps.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 181
FlexIO I2C Master Driver

12.4.3.2.0.2 Field Documentation

12.4.3.2.0.2.1 bool flexio_i2c_master_config_t::enableMaster

12.4.3.2.0.2.2 bool flexio_i2c_master_config_t::enableInDoze

12.4.3.2.0.2.3 bool flexio_i2c_master_config_t::enableInDebug

12.4.3.2.0.2.4 bool flexio_i2c_master_config_t::enableFastAccess

12.4.3.2.0.2.5 uint32_t flexio_i2c_master_config_t::baudRate_Bps

12.4.3.3 struct flexio_i2c_master_transfer_t

Data Fields
• uint32_t flags
Transfer flag which controls the transfer, reserved for FlexIO I2C.
• uint8_t slaveAddress
7-bit slave address.
• flexio_i2c_direction_t direction
Transfer direction, read or write.
• uint32_t subaddress
Sub address.
• uint8_t subaddressSize
Size of command buffer.
• uint8_t volatile ∗ data
Transfer buffer.
• volatile size_t dataSize
Transfer size.

12.4.3.3.0.3 Field Documentation

12.4.3.3.0.3.1 uint32_t flexio_i2c_master_transfer_t::flags

12.4.3.3.0.3.2 uint8_t flexio_i2c_master_transfer_t::slaveAddress

12.4.3.3.0.3.3 flexio_i2c_direction_t flexio_i2c_master_transfer_t::direction

12.4.3.3.0.3.4 uint32_t flexio_i2c_master_transfer_t::subaddress

Transferred MSB first.

MCUXpresso SDK API Reference Manual


182 NXP Semiconductors
FlexIO I2C Master Driver

12.4.3.3.0.3.5 uint8_t flexio_i2c_master_transfer_t::subaddressSize

12.4.3.3.0.3.6 uint8_t volatile∗ flexio_i2c_master_transfer_t::data

12.4.3.3.0.3.7 volatile size_t flexio_i2c_master_transfer_t::dataSize

12.4.3.4 struct _flexio_i2c_master_handle

FlexIO I2C master handle typedef.

Data Fields
• flexio_i2c_master_transfer_t transfer
FlexIO I2C master transfer copy.
• size_t transferSize
Total bytes to be transferred.
• uint8_t state
Transfer state maintained during transfer.
• flexio_i2c_master_transfer_callback_t completionCallback
Callback function called at transfer event.
• void ∗ userData
Callback parameter passed to callback function.

12.4.3.4.0.4 Field Documentation

12.4.3.4.0.4.1 flexio_i2c_master_transfer_t flexio_i2c_master_handle_t::transfer

12.4.3.4.0.4.2 size_t flexio_i2c_master_handle_t::transferSize

12.4.3.4.0.4.3 uint8_t flexio_i2c_master_handle_t::state

12.4.3.4.0.4.4 flexio_i2c_master_transfer_callback_t flexio_i2c_master_handle_t::completion-


Callback

Callback function called at transfer event.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 183
FlexIO I2C Master Driver

12.4.3.4.0.4.5 void∗ flexio_i2c_master_handle_t::userData

12.4.4 Macro Definition Documentation

12.4.4.1 #define FSL_FLEXIO_I2C_MASTER_DRIVER_VERSION (MAKE_VERSION(2, 1,


7))

12.4.5 Typedef Documentation

12.4.5.1 typedef void(∗ flexio_i2c_master_transfer_callback_t)(FLEXIO_I2C_Type ∗base,


flexio_i2c_master_handle_t ∗handle, status_t status, void ∗userData)

12.4.6 Enumeration Type Documentation

12.4.6.1 enum _flexio_i2c_status

Enumerator
kStatus_FLEXIO_I2C_Busy I2C is busy doing transfer.
kStatus_FLEXIO_I2C_Idle I2C is busy doing transfer.
kStatus_FLEXIO_I2C_Nak NAK received during transfer.

12.4.6.2 enum _flexio_i2c_master_interrupt

Enumerator
kFLEXIO_I2C_TxEmptyInterruptEnable Tx buffer empty interrupt enable.
kFLEXIO_I2C_RxFullInterruptEnable Rx buffer full interrupt enable.

12.4.6.3 enum _flexio_i2c_master_status_flags

Enumerator
kFLEXIO_I2C_TxEmptyFlag Tx shifter empty flag.
kFLEXIO_I2C_RxFullFlag Rx shifter full/Transfer complete flag.
kFLEXIO_I2C_ReceiveNakFlag Receive NAK flag.

12.4.6.4 enum flexio_i2c_direction_t

Enumerator
kFLEXIO_I2C_Write Master send to slave.
kFLEXIO_I2C_Read Master receive from slave.

MCUXpresso SDK API Reference Manual


184 NXP Semiconductors
FlexIO I2C Master Driver

12.4.7 Function Documentation

12.4.7.1 status_t FLEXIO_I2C_MasterInit ( FLEXIO_I2C_Type ∗ base,


flexio_i2c_master_config_t ∗ masterConfig, uint32_t srcClock_Hz )

Example

FLEXIO_I2C_Type base = {
.flexioBase = FLEXIO,
.SDAPinIndex = 0,
.SCLPinIndex = 1,
.shifterIndex = {0,1},
.timerIndex = {0,1}
};
flexio_i2c_master_config_t config = {
.enableInDoze = false,
.enableInDebug = true,
.enableFastAccess = false,
.baudRate_Bps = 100000
};
FLEXIO_I2C_MasterInit(base, &config, srcClock_Hz);

Parameters

base Pointer to FLEXIO_I2C_Type structure.


masterConfig Pointer to flexio_i2c_master_config_t structure.
srcClock_Hz FlexIO source clock in Hz.

Return values

kStatus_Success Initialization successful


kStatus_InvalidArgument The source clock exceed upper range limitation

12.4.7.2 void FLEXIO_I2C_MasterDeinit ( FLEXIO_I2C_Type ∗ base )

Calling this API Resets the FlexIO I2C master shifer and timer config, module can’t work unless the
FLEXIO_I2C_MasterInit is called.
Parameters

base pointer to FLEXIO_I2C_Type structure.

12.4.7.3 void FLEXIO_I2C_MasterGetDefaultConfig ( flexio_i2c_master_config_t ∗


masterConfig )

The configuration can be used directly for calling the FLEXIO_I2C_MasterInit().

MCUXpresso SDK API Reference Manual


NXP Semiconductors 185
FlexIO I2C Master Driver

Example:
flexio_i2c_master_config_t config;
FLEXIO_I2C_MasterGetDefaultConfig(&config);

Parameters

masterConfig Pointer to flexio_i2c_master_config_t structure.

12.4.7.4 static void FLEXIO_I2C_MasterEnable ( FLEXIO_I2C_Type ∗ base, bool enable


) [inline], [static]

Parameters

base Pointer to FLEXIO_I2C_Type structure.


enable Pass true to enable module, false does not have any effect.

12.4.7.5 uint32_t FLEXIO_I2C_MasterGetStatusFlags ( FLEXIO_I2C_Type ∗ base )

Parameters

base Pointer to FLEXIO_I2C_Type structure

Returns
Status flag, use status flag to AND _flexio_i2c_master_status_flags can get the related status.

12.4.7.6 void FLEXIO_I2C_MasterClearStatusFlags ( FLEXIO_I2C_Type ∗ base, uint32_t


mask )

Parameters

base Pointer to FLEXIO_I2C_Type structure.


mask Status flag. The parameter can be any combination of the following values:
• kFLEXIO_I2C_RxFullFlag
• kFLEXIO_I2C_ReceiveNakFlag

12.4.7.7 void FLEXIO_I2C_MasterEnableInterrupts ( FLEXIO_I2C_Type ∗ base, uint32_t


mask )

MCUXpresso SDK API Reference Manual


186 NXP Semiconductors
FlexIO I2C Master Driver

Parameters

base Pointer to FLEXIO_I2C_Type structure.


mask Interrupt source. Currently only one interrupt request source:
• kFLEXIO_I2C_TransferCompleteInterruptEnable

12.4.7.8 void FLEXIO_I2C_MasterDisableInterrupts ( FLEXIO_I2C_Type ∗ base, uint32_t


mask )

Parameters

base Pointer to FLEXIO_I2C_Type structure.


mask Interrupt source.

12.4.7.9 void FLEXIO_I2C_MasterSetBaudRate ( FLEXIO_I2C_Type ∗ base, uint32_t


baudRate_Bps, uint32_t srcClock_Hz )

Parameters

base Pointer to FLEXIO_I2C_Type structure


baudRate_Bps the baud rate value in HZ
srcClock_Hz source clock in HZ

12.4.7.10 void FLEXIO_I2C_MasterStart ( FLEXIO_I2C_Type ∗ base, uint8_t address,


flexio_i2c_direction_t direction )
Note
This API should be called when the transfer configuration is ready to send a START signal and 7-bit
address to the bus. This is a non-blocking API, which returns directly after the address is put into
the data register but the address transfer is not finished on the bus. Ensure that the kFLEXIO_I2C_-
RxFullFlag status is asserted before calling this API.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 187
FlexIO I2C Master Driver

Parameters

base Pointer to FLEXIO_I2C_Type structure.


address 7-bit address.
direction transfer direction. This parameter is one of the values in flexio_i2c_direction_t:
• kFLEXIO_I2C_Write: Transmit
• kFLEXIO_I2C_Read: Receive

12.4.7.11 void FLEXIO_I2C_MasterStop ( FLEXIO_I2C_Type ∗ base )

Parameters

base Pointer to FLEXIO_I2C_Type structure.

12.4.7.12 void FLEXIO_I2C_MasterRepeatedStart ( FLEXIO_I2C_Type ∗ base )

Parameters

base Pointer to FLEXIO_I2C_Type structure.

12.4.7.13 void FLEXIO_I2C_MasterAbortStop ( FLEXIO_I2C_Type ∗ base )

Parameters

base Pointer to FLEXIO_I2C_Type structure.

12.4.7.14 void FLEXIO_I2C_MasterEnableAck ( FLEXIO_I2C_Type ∗ base, bool enable )

Parameters

base Pointer to FLEXIO_I2C_Type structure.


enable True to configure send ACK, false configure to send NAK.

12.4.7.15 status_t FLEXIO_I2C_MasterSetTransferCount ( FLEXIO_I2C_Type ∗ base,


uint8_t count )

MCUXpresso SDK API Reference Manual


188 NXP Semiconductors
FlexIO I2C Master Driver

Note
Call this API before a transfer begins because the timer generates a number of clocks according to
the number of bytes that need to be transferred.

Parameters

base Pointer to FLEXIO_I2C_Type structure.


count Number of bytes need to be transferred from a start signal to a re-start/stop signal

Return values

kStatus_Success Successfully configured the count.


kStatus_InvalidArgument Input argument is invalid.

12.4.7.16 static void FLEXIO_I2C_MasterWriteByte ( FLEXIO_I2C_Type ∗ base, uint32_t


data ) [inline], [static]

Note
This is a non-blocking API, which returns directly after the data is put into the data register but the
data transfer is not finished on the bus. Ensure that the TxEmptyFlag is asserted before calling this
API.

Parameters

base Pointer to FLEXIO_I2C_Type structure.


data a byte of data.

12.4.7.17 static uint8_t FLEXIO_I2C_MasterReadByte ( FLEXIO_I2C_Type ∗ base )


[inline], [static]
Note
This is a non-blocking API, which returns directly after the data is read from the data register. Ensure
that the data is ready in the register.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 189
FlexIO I2C Master Driver

Parameters

base Pointer to FLEXIO_I2C_Type structure.

Returns
data byte read.

12.4.7.18 status_t FLEXIO_I2C_MasterWriteBlocking ( FLEXIO_I2C_Type ∗ base, const


uint8_t ∗ txBuff, uint8_t txSize )

Note
This function blocks via polling until all bytes have been sent.

Parameters

base Pointer to FLEXIO_I2C_Type structure.


txBuff The data bytes to send.
txSize The number of data bytes to send.

Return values

kStatus_Success Successfully write data.


kStatus_FLEXIO_I2C_- Receive NAK during writing data.
Nak

12.4.7.19 void FLEXIO_I2C_MasterReadBlocking ( FLEXIO_I2C_Type ∗ base, uint8_t ∗


rxBuff, uint8_t rxSize )

Note
This function blocks via polling until all bytes have been received.

Parameters

MCUXpresso SDK API Reference Manual


190 NXP Semiconductors
FlexIO I2C Master Driver

base Pointer to FLEXIO_I2C_Type structure.


rxBuff The buffer to store the received bytes.
rxSize The number of data bytes to be received.

12.4.7.20 status_t FLEXIO_I2C_MasterTransferBlocking ( FLEXIO_I2C_Type ∗ base,


flexio_i2c_master_transfer_t ∗ xfer )
Note
The API does not return until the transfer succeeds or fails due to receiving NAK.

Parameters

base pointer to FLEXIO_I2C_Type structure.


xfer pointer to flexio_i2c_master_transfer_t structure.

Returns
status of status_t.

12.4.7.21 status_t FLEXIO_I2C_MasterTransferCreateHandle ( FLEXIO_I2C_Type ∗ base,


flexio_i2c_master_handle_t ∗ handle, flexio_i2c_master_transfer_callback_t
callback, void ∗ userData )

Parameters

base Pointer to FLEXIO_I2C_Type structure.


handle Pointer to flexio_i2c_master_handle_t structure to store the transfer state.
callback Pointer to user callback function.
userData User param passed to the callback function.

Return values

kStatus_Success Successfully create the handle.


kStatus_OutOfRange The FlexIO type/handle/isr table out of range.

12.4.7.22 status_t FLEXIO_I2C_MasterTransferNonBlocking ( FLEXIO_I2C_Type ∗ base,


flexio_i2c_master_handle_t ∗ handle, flexio_i2c_master_transfer_t ∗ xfer )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 191
FlexIO I2C Master Driver

Note
The API returns immediately after the transfer initiates. Call FLEXIO_I2C_MasterGetTransfer-
Count to poll the transfer status to check whether the transfer is finished. If the return status is not
kStatus_FLEXIO_I2C_Busy, the transfer is finished.

Parameters

base Pointer to FLEXIO_I2C_Type structure


handle Pointer to flexio_i2c_master_handle_t structure which stores the transfer state
xfer pointer to flexio_i2c_master_transfer_t structure

Return values

kStatus_Success Successfully start a transfer.


kStatus_FLEXIO_I2C_- FlexIO I2C is not idle, is running another transfer.
Busy

12.4.7.23 status_t FLEXIO_I2C_MasterTransferGetCount ( FLEXIO_I2C_Type ∗ base,


flexio_i2c_master_handle_t ∗ handle, size_t ∗ count )

Parameters

base Pointer to FLEXIO_I2C_Type structure.


handle Pointer to flexio_i2c_master_handle_t structure which stores the transfer state.
count Number of bytes transferred so far by the non-blocking transaction.

Return values

kStatus_InvalidArgument count is Invalid.


kStatus_Success Successfully return the count.

12.4.7.24 void FLEXIO_I2C_MasterTransferAbort ( FLEXIO_I2C_Type ∗ base,


flexio_i2c_master_handle_t ∗ handle )

Note
This API can be called at any time when an interrupt non-blocking transfer initiates to abort the
transfer early.

MCUXpresso SDK API Reference Manual


192 NXP Semiconductors
FlexIO I2C Master Driver

Parameters

base Pointer to FLEXIO_I2C_Type structure


handle Pointer to flexio_i2c_master_handle_t structure which stores the transfer state

12.4.7.25 void FLEXIO_I2C_MasterTransferHandleIRQ ( void ∗ i2cType, void ∗ i2cHandle


)

Parameters

i2cType Pointer to FLEXIO_I2C_Type structure


i2cHandle Pointer to flexio_i2c_master_transfer_t structure

MCUXpresso SDK API Reference Manual


NXP Semiconductors 193
FlexIO I2S Driver

12.5 FlexIO I2S Driver


12.5.1 Overview

The MCUXpresso SDK provides a peripheral driver for I2S function using Flexible I/O module of MCU-
Xpresso SDK devices.
The FlexIO I2S driver includes functional APIs and transactional APIs.
Functional APIs are feature/property target low level APIs.
Functional APIs can be used for FlexIO I2S initialization/configuration/operation for optimiza-
tion/customization purpose. Using the functional API requires the knowledge of the FlexIO I2S peripheral
and how to organize functional APIs to meet the application requirements. All functional API use the pe-
ripheral base address as the first parameter. FlexIO I2S functional operation groups provide the functional
APIs set.
Transactional APIs are transaction target high level APIs. The transactional APIs can be used to enable
the peripheral and also in the application if the code size and performance of transactional APIs can
satisfy requirements. If the code size and performance are critical requirements, see the transactional API
implementation and write custom code. All transactional APIs use the sai_handle_t as the first parameter.
Initialize the handle by calling the FlexIO_I2S_TransferTxCreateHandle() or FlexIO_I2S_TransferRx-
CreateHandle() API.
Transactional APIs support asynchronous transfer. This means that the functions FLEXIO_I2S_Transfer-
SendNonBlocking() and FLEXIO_I2S_TransferReceiveNonBlocking() set up an interrupt for data trans-
fer. When the transfer completes, the upper layer is notified through a callback function with the kStatus-
_FLEXIO_I2S_TxIdle and kStatus_FLEXIO_I2S_RxIdle status.

12.5.2 Typical use case

12.5.2.1 FlexIO I2S send/receive using an interrupt method


sai_handle_t g_saiTxHandle;
sai_config_t user_config;
sai_transfer_t sendXfer;
volatile bool txFinished;
volatile bool rxFinished;
const uint8_t sendData[] = [......];

void FLEXIO_I2S_UserCallback(sai_handle_t *handle, status_t status, void *userData)


{
userData = userData;

if (kStatus_FLEXIO_I2S_TxIdle == status)
{
txFinished = true;
}
}

void main(void)
{
//...

FLEXIO_I2S_TxGetDefaultConfig(&user_config);

MCUXpresso SDK API Reference Manual


194 NXP Semiconductors
FlexIO I2S Driver

FLEXIO_I2S_TxInit(FLEXIO I2S0, &user_config);


FLEXIO_I2S_TransferTxCreateHandle(FLEXIO I2S0, &g_saiHandle,
FLEXIO_I2S_UserCallback, NULL);

//Configures the SAI format.


FLEXIO_I2S_TransferTxSetTransferFormat(FLEXIO I2S0, &g_saiHandle, mclkSource, mclk);

// Prepares to send.
sendXfer.data = sendData
sendXfer.dataSize = sizeof(sendData)/sizeof(sendData[0]);
txFinished = false;

// Sends out.
FLEXIO_I2S_TransferSendNonBlocking(FLEXIO I2S0, &g_saiHandle, &
sendXfer);

// Waiting to send is finished.


while (!txFinished)
{
}

// ...
}

12.5.2.2 FLEXIO_I2S send/receive using a DMA method


sai_handle_t g_saiHandle;
dma_handle_t g_saiTxDmaHandle;
dma_handle_t g_saiRxDmaHandle;
sai_config_t user_config;
sai_transfer_t sendXfer;
volatile bool txFinished;
uint8_t sendData[] = ...;

void FLEXIO_I2S_UserCallback(sai_handle_t *handle, status_t status, void *userData)


{
userData = userData;

if (kStatus_FLEXIO_I2S_TxIdle == status)
{
txFinished = true;
}
}

void main(void)
{
//...

FLEXIO_I2S_TxGetDefaultConfig(&user_config);
FLEXIO_I2S_TxInit(FLEXIO I2S0, &user_config);

// Sets up the DMA.


DMAMUX_Init(DMAMUX0);
DMAMUX_SetSource(DMAMUX0, FLEXIO_I2S_TX_DMA_CHANNEL, FLEXIO_I2S_TX_DMA_REQUEST);
DMAMUX_EnableChannel(DMAMUX0, FLEXIO_I2S_TX_DMA_CHANNEL);

DMA_Init(DMA0);

/* Creates the DMA handle. */


DMA_TransferTxCreateHandle(&g_saiTxDmaHandle, DMA0, FLEXIO_I2S_TX_DMA_CHANNEL);

FLEXIO_I2S_TransferTxCreateHandleDMA(FLEXIO I2S0, &g_saiTxDmaHandle


, FLEXIO_I2S_UserCallback, NULL);

MCUXpresso SDK API Reference Manual


NXP Semiconductors 195
FlexIO I2S Driver

// Prepares to send.
sendXfer.data = sendData
sendXfer.dataSize = sizeof(sendData)/sizeof(sendData[0]);
txFinished = false;

// Sends out.
FLEXIO_I2S_TransferSendDMA(&g_saiHandle, &sendXfer);

// Waiting to send is finished.


while (!txFinished)
{
}

// ...
}

Modules

• FlexIO DMA I2S Driver


• FlexIO eDMA I2S Driver

Data Structures

• struct FLEXIO_I2S_Type
Define FlexIO I2S access structure typedef. More...
• struct flexio_i2s_config_t
FlexIO I2S configure structure. More...
• struct flexio_i2s_format_t
FlexIO I2S audio format, FlexIO I2S only support the same format in Tx and Rx. More...
• struct flexio_i2s_transfer_t
Define FlexIO I2S transfer structure. More...
• struct flexio_i2s_handle_t
Define FlexIO I2S handle structure. More...

Macros

• #define FLEXIO_I2S_XFER_QUEUE_SIZE (4)


FlexIO I2S transfer queue size, user can refine it according to use case.

Typedefs

• typedef void(∗ flexio_i2s_callback_t )(FLEXIO_I2S_Type ∗base, flexio_i2s_handle_t ∗handle,


status_t status, void ∗userData)
FlexIO I2S xfer callback prototype.

MCUXpresso SDK API Reference Manual


196 NXP Semiconductors
FlexIO I2S Driver

Enumerations

• enum _flexio_i2s_status {
kStatus_FLEXIO_I2S_Idle = MAKE_STATUS(kStatusGroup_FLEXIO_I2S, 0),
kStatus_FLEXIO_I2S_TxBusy = MAKE_STATUS(kStatusGroup_FLEXIO_I2S, 1),
kStatus_FLEXIO_I2S_RxBusy = MAKE_STATUS(kStatusGroup_FLEXIO_I2S, 2),
kStatus_FLEXIO_I2S_Error = MAKE_STATUS(kStatusGroup_FLEXIO_I2S, 3),
kStatus_FLEXIO_I2S_QueueFull = MAKE_STATUS(kStatusGroup_FLEXIO_I2S, 4) }
FlexIO I2S transfer status.
• enum flexio_i2s_master_slave_t {
kFLEXIO_I2S_Master = 0x0U,
kFLEXIO_I2S_Slave = 0x1U }
Master or slave mode.
• enum _flexio_i2s_interrupt_enable {
kFLEXIO_I2S_TxDataRegEmptyInterruptEnable = 0x1U,
kFLEXIO_I2S_RxDataRegFullInterruptEnable = 0x2U }
Define FlexIO FlexIO I2S interrupt mask.
• enum _flexio_i2s_status_flags {
kFLEXIO_I2S_TxDataRegEmptyFlag = 0x1U,
kFLEXIO_I2S_RxDataRegFullFlag = 0x2U }
Define FlexIO FlexIO I2S status mask.
• enum flexio_i2s_sample_rate_t {
kFLEXIO_I2S_SampleRate8KHz = 8000U,
kFLEXIO_I2S_SampleRate11025Hz = 11025U,
kFLEXIO_I2S_SampleRate12KHz = 12000U,
kFLEXIO_I2S_SampleRate16KHz = 16000U,
kFLEXIO_I2S_SampleRate22050Hz = 22050U,
kFLEXIO_I2S_SampleRate24KHz = 24000U,
kFLEXIO_I2S_SampleRate32KHz = 32000U,
kFLEXIO_I2S_SampleRate44100Hz = 44100U,
kFLEXIO_I2S_SampleRate48KHz = 48000U,
kFLEXIO_I2S_SampleRate96KHz = 96000U }
Audio sample rate.
• enum flexio_i2s_word_width_t {
kFLEXIO_I2S_WordWidth8bits = 8U,
kFLEXIO_I2S_WordWidth16bits = 16U,
kFLEXIO_I2S_WordWidth24bits = 24U,
kFLEXIO_I2S_WordWidth32bits = 32U }
Audio word width.

Driver version

• #define FSL_FLEXIO_I2S_DRIVER_VERSION (MAKE_VERSION(2, 1, 6))


FlexIO I2S driver version 2.1.6.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 197
FlexIO I2S Driver

Initialization and deinitialization

• void FLEXIO_I2S_Init (FLEXIO_I2S_Type ∗base, const flexio_i2s_config_t ∗config)


Initializes the FlexIO I2S.
• void FLEXIO_I2S_GetDefaultConfig (flexio_i2s_config_t ∗config)
Sets the FlexIO I2S configuration structure to default values.
• void FLEXIO_I2S_Deinit (FLEXIO_I2S_Type ∗base)
De-initializes the FlexIO I2S.
• static void FLEXIO_I2S_Enable (FLEXIO_I2S_Type ∗base, bool enable)
Enables/disables the FlexIO I2S module operation.

Status

• uint32_t FLEXIO_I2S_GetStatusFlags (FLEXIO_I2S_Type ∗base)


Gets the FlexIO I2S status flags.

Interrupts

• void FLEXIO_I2S_EnableInterrupts (FLEXIO_I2S_Type ∗base, uint32_t mask)


Enables the FlexIO I2S interrupt.
• void FLEXIO_I2S_DisableInterrupts (FLEXIO_I2S_Type ∗base, uint32_t mask)
Disables the FlexIO I2S interrupt.

DMA Control

• static void FLEXIO_I2S_TxEnableDMA (FLEXIO_I2S_Type ∗base, bool enable)


Enables/disables the FlexIO I2S Tx DMA requests.
• static void FLEXIO_I2S_RxEnableDMA (FLEXIO_I2S_Type ∗base, bool enable)
Enables/disables the FlexIO I2S Rx DMA requests.
• static uint32_t FLEXIO_I2S_TxGetDataRegisterAddress (FLEXIO_I2S_Type ∗base)
Gets the FlexIO I2S send data register address.
• static uint32_t FLEXIO_I2S_RxGetDataRegisterAddress (FLEXIO_I2S_Type ∗base)
Gets the FlexIO I2S receive data register address.

Bus Operations

• void FLEXIO_I2S_MasterSetFormat (FLEXIO_I2S_Type ∗base, flexio_i2s_format_t ∗format,


uint32_t srcClock_Hz)
Configures the FlexIO I2S audio format in master mode.
• void FLEXIO_I2S_SlaveSetFormat (FLEXIO_I2S_Type ∗base, flexio_i2s_format_t ∗format)
Configures the FlexIO I2S audio format in slave mode.
• void FLEXIO_I2S_WriteBlocking (FLEXIO_I2S_Type ∗base, uint8_t bitWidth, uint8_t ∗txData,
size_t size)
Sends data using a blocking method.
• static void FLEXIO_I2S_WriteData (FLEXIO_I2S_Type ∗base, uint8_t bitWidth, uint32_t data)

MCUXpresso SDK API Reference Manual


198 NXP Semiconductors
FlexIO I2S Driver

Writes data into a data register.


• void FLEXIO_I2S_ReadBlocking (FLEXIO_I2S_Type ∗base, uint8_t bitWidth, uint8_t ∗rxData,
size_t size)
Receives a piece of data using a blocking method.
• static uint32_t FLEXIO_I2S_ReadData (FLEXIO_I2S_Type ∗base)
Reads a data from the data register.

Transactional

• void FLEXIO_I2S_TransferTxCreateHandle (FLEXIO_I2S_Type ∗base, flexio_i2s_handle_t


∗handle, flexio_i2s_callback_t callback, void ∗userData)
Initializes the FlexIO I2S handle.
• void FLEXIO_I2S_TransferSetFormat (FLEXIO_I2S_Type ∗base, flexio_i2s_handle_t ∗handle,
flexio_i2s_format_t ∗format, uint32_t srcClock_Hz)
Configures the FlexIO I2S audio format.
• void FLEXIO_I2S_TransferRxCreateHandle (FLEXIO_I2S_Type ∗base, flexio_i2s_handle_t
∗handle, flexio_i2s_callback_t callback, void ∗userData)
Initializes the FlexIO I2S receive handle.
• status_t FLEXIO_I2S_TransferSendNonBlocking (FLEXIO_I2S_Type ∗base, flexio_i2s_handle_t
∗handle, flexio_i2s_transfer_t ∗xfer)
Performs an interrupt non-blocking send transfer on FlexIO I2S.
• status_t FLEXIO_I2S_TransferReceiveNonBlocking (FLEXIO_I2S_Type ∗base, flexio_i2s_-
handle_t ∗handle, flexio_i2s_transfer_t ∗xfer)
Performs an interrupt non-blocking receive transfer on FlexIO I2S.
• void FLEXIO_I2S_TransferAbortSend (FLEXIO_I2S_Type ∗base, flexio_i2s_handle_t ∗handle)
Aborts the current send.
• void FLEXIO_I2S_TransferAbortReceive (FLEXIO_I2S_Type ∗base, flexio_i2s_handle_t ∗handle)
Aborts the current receive.
• status_t FLEXIO_I2S_TransferGetSendCount (FLEXIO_I2S_Type ∗base, flexio_i2s_handle_t
∗handle, size_t ∗count)
Gets the remaining bytes to be sent.
• status_t FLEXIO_I2S_TransferGetReceiveCount (FLEXIO_I2S_Type ∗base, flexio_i2s_handle_t
∗handle, size_t ∗count)
Gets the remaining bytes to be received.
• void FLEXIO_I2S_TransferTxHandleIRQ (void ∗i2sBase, void ∗i2sHandle)
Tx interrupt handler.
• void FLEXIO_I2S_TransferRxHandleIRQ (void ∗i2sBase, void ∗i2sHandle)
Rx interrupt handler.

12.5.3 Data Structure Documentation

12.5.3.1 struct FLEXIO_I2S_Type

Data Fields
• FLEXIO_Type ∗ flexioBase
FlexIO base pointer.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 199
FlexIO I2S Driver

• uint8_t txPinIndex
Tx data pin index in FlexIO pins.
• uint8_t rxPinIndex
Rx data pin index.
• uint8_t bclkPinIndex
Bit clock pin index.
• uint8_t fsPinIndex
Frame sync pin index.
• uint8_t txShifterIndex
Tx data shifter index.
• uint8_t rxShifterIndex
Rx data shifter index.
• uint8_t bclkTimerIndex
Bit clock timer index.
• uint8_t fsTimerIndex
Frame sync timer index.

12.5.3.2 struct flexio_i2s_config_t

Data Fields
• bool enableI2S
Enable FlexIO I2S.
• flexio_i2s_master_slave_t masterSlave
Master or slave.
• flexio_pin_polarity_t txPinPolarity
Tx data pin polarity, active high or low.
• flexio_pin_polarity_t rxPinPolarity
Rx data pin polarity.
• flexio_pin_polarity_t bclkPinPolarity
Bit clock pin polarity.
• flexio_pin_polarity_t fsPinPolarity
Frame sync pin polarity.
• flexio_shifter_timer_polarity_t txTimerPolarity
Tx data valid on bclk rising or falling edge.
• flexio_shifter_timer_polarity_t rxTimerPolarity
Rx data valid on bclk rising or falling edge.

12.5.3.3 struct flexio_i2s_format_t

Data Fields
• uint8_t bitWidth
Bit width of audio data, always 8/16/24/32 bits.
• uint32_t sampleRate_Hz
Sample rate of the audio data.

MCUXpresso SDK API Reference Manual


200 NXP Semiconductors
FlexIO I2S Driver

12.5.3.4 struct flexio_i2s_transfer_t

Data Fields
• uint8_t ∗ data
Data buffer start pointer.
• size_t dataSize
Bytes to be transferred.

12.5.3.4.0.5 Field Documentation

12.5.3.4.0.5.1 size_t flexio_i2s_transfer_t::dataSize

12.5.3.5 struct _flexio_i2s_handle

Data Fields
• uint32_t state
Internal state.
• flexio_i2s_callback_t callback
Callback function called at transfer event.
• void ∗ userData
Callback parameter passed to callback function.
• uint8_t bitWidth
Bit width for transfer, 8/16/24/32bits.
• flexio_i2s_transfer_t queue [FLEXIO_I2S_XFER_QUEUE_SIZE]
Transfer queue storing queued transfer.
• size_t transferSize [FLEXIO_I2S_XFER_QUEUE_SIZE]
Data bytes need to transfer.
• volatile uint8_t queueUser
Index for user to queue transfer.
• volatile uint8_t queueDriver
Index for driver to get the transfer data and size.

12.5.4 Macro Definition Documentation

12.5.4.1 #define FSL_FLEXIO_I2S_DRIVER_VERSION (MAKE_VERSION(2, 1, 6))

12.5.4.2 #define FLEXIO_I2S_XFER_QUEUE_SIZE (4)

12.5.5 Enumeration Type Documentation

12.5.5.1 enum _flexio_i2s_status

Enumerator
kStatus_FLEXIO_I2S_Idle FlexIO I2S is in idle state.
kStatus_FLEXIO_I2S_TxBusy FlexIO I2S Tx is busy.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 201
FlexIO I2S Driver

kStatus_FLEXIO_I2S_RxBusy FlexIO I2S Tx is busy.


kStatus_FLEXIO_I2S_Error FlexIO I2S error occurred.
kStatus_FLEXIO_I2S_QueueFull FlexIO I2S transfer queue is full.

12.5.5.2 enum flexio_i2s_master_slave_t

Enumerator
kFLEXIO_I2S_Master Master mode.
kFLEXIO_I2S_Slave Slave mode.

12.5.5.3 enum _flexio_i2s_interrupt_enable

Enumerator
kFLEXIO_I2S_TxDataRegEmptyInterruptEnable Transmit buffer empty interrupt enable.
kFLEXIO_I2S_RxDataRegFullInterruptEnable Receive buffer full interrupt enable.

12.5.5.4 enum _flexio_i2s_status_flags

Enumerator
kFLEXIO_I2S_TxDataRegEmptyFlag Transmit buffer empty flag.
kFLEXIO_I2S_RxDataRegFullFlag Receive buffer full flag.

12.5.5.5 enum flexio_i2s_sample_rate_t

Enumerator
kFLEXIO_I2S_SampleRate8KHz Sample rate 8000Hz.
kFLEXIO_I2S_SampleRate11025Hz Sample rate 11025Hz.
kFLEXIO_I2S_SampleRate12KHz Sample rate 12000Hz.
kFLEXIO_I2S_SampleRate16KHz Sample rate 16000Hz.
kFLEXIO_I2S_SampleRate22050Hz Sample rate 22050Hz.
kFLEXIO_I2S_SampleRate24KHz Sample rate 24000Hz.
kFLEXIO_I2S_SampleRate32KHz Sample rate 32000Hz.
kFLEXIO_I2S_SampleRate44100Hz Sample rate 44100Hz.
kFLEXIO_I2S_SampleRate48KHz Sample rate 48000Hz.
kFLEXIO_I2S_SampleRate96KHz Sample rate 96000Hz.

MCUXpresso SDK API Reference Manual


202 NXP Semiconductors
FlexIO I2S Driver

12.5.5.6 enum flexio_i2s_word_width_t

Enumerator
kFLEXIO_I2S_WordWidth8bits Audio data width 8 bits.
kFLEXIO_I2S_WordWidth16bits Audio data width 16 bits.
kFLEXIO_I2S_WordWidth24bits Audio data width 24 bits.
kFLEXIO_I2S_WordWidth32bits Audio data width 32 bits.

12.5.6 Function Documentation

12.5.6.1 void FLEXIO_I2S_Init ( FLEXIO_I2S_Type ∗ base, const flexio_i2s_config_t ∗


config )

This API configures FlexIO pins and shifter to I2S and configures the FlexIO I2S with a configuration
structure. The configuration structure can be filled by the user, or be set with default values by FLEXIO_-
I2S_GetDefaultConfig().

Note
This API should be called at the beginning of the application to use the FlexIO I2S driver. Otherwise,
any access to the FlexIO I2S module can cause hard fault because the clock is not enabled.

Parameters

base FlexIO I2S base pointer


config FlexIO I2S configure structure.

12.5.6.2 void FLEXIO_I2S_GetDefaultConfig ( flexio_i2s_config_t ∗ config )

The purpose of this API is to get the configuration structure initialized for use in FLEXIO_I2S_Init().
Users may use the initialized structure unchanged in FLEXIO_I2S_Init() or modify some fields of the
structure before calling FLEXIO_I2S_Init().
Parameters

config pointer to master configuration structure

12.5.6.3 void FLEXIO_I2S_Deinit ( FLEXIO_I2S_Type ∗ base )

Calling this API resets the FlexIO I2S shifter and timer config. After calling this API, call the FLEXO_-
I2S_Init to use the FlexIO I2S module.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 203
FlexIO I2S Driver

Parameters

base FlexIO I2S base pointer

12.5.6.4 static void FLEXIO_I2S_Enable ( FLEXIO_I2S_Type ∗ base, bool enable )


[inline], [static]

Parameters

base Pointer to FLEXIO_I2S_Type


enable True to enable, false dose not have any effect.

12.5.6.5 uint32_t FLEXIO_I2S_GetStatusFlags ( FLEXIO_I2S_Type ∗ base )

Parameters

base Pointer to FLEXIO_I2S_Type structure

Returns
Status flag, which are ORed by the enumerators in the _flexio_i2s_status_flags.

12.5.6.6 void FLEXIO_I2S_EnableInterrupts ( FLEXIO_I2S_Type ∗ base, uint32_t mask )

This function enables the FlexIO UART interrupt.


Parameters

base Pointer to FLEXIO_I2S_Type structure


mask interrupt source

12.5.6.7 void FLEXIO_I2S_DisableInterrupts ( FLEXIO_I2S_Type ∗ base, uint32_t mask


)

This function enables the FlexIO UART interrupt.

MCUXpresso SDK API Reference Manual


204 NXP Semiconductors
FlexIO I2S Driver

Parameters

base pointer to FLEXIO_I2S_Type structure


mask interrupt source

12.5.6.8 static void FLEXIO_I2S_TxEnableDMA ( FLEXIO_I2S_Type ∗ base, bool enable


) [inline], [static]

Parameters

base FlexIO I2S base pointer


enable True means enable DMA, false means disable DMA.

12.5.6.9 static void FLEXIO_I2S_RxEnableDMA ( FLEXIO_I2S_Type ∗ base, bool enable


) [inline], [static]

Parameters

base FlexIO I2S base pointer


enable True means enable DMA, false means disable DMA.

12.5.6.10 static uint32_t FLEXIO_I2S_TxGetDataRegisterAddress ( FLEXIO_I2S_Type ∗


base ) [inline], [static]

This function returns the I2S data register address, mainly used by DMA/eDMA.
Parameters

base Pointer to FLEXIO_I2S_Type structure

Returns
FlexIO i2s send data register address.

12.5.6.11 static uint32_t FLEXIO_I2S_RxGetDataRegisterAddress ( FLEXIO_I2S_Type ∗


base ) [inline], [static]

This function returns the I2S data register address, mainly used by DMA/eDMA.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 205
FlexIO I2S Driver

Parameters

base Pointer to FLEXIO_I2S_Type structure

Returns
FlexIO i2s receive data register address.

12.5.6.12 void FLEXIO_I2S_MasterSetFormat ( FLEXIO_I2S_Type ∗ base,


flexio_i2s_format_t ∗ format, uint32_t srcClock_Hz )

Audio format can be changed in run-time of FlexIO I2S. This function configures the sample rate and
audio data format to be transferred.
Parameters

base Pointer to FLEXIO_I2S_Type structure


format Pointer to FlexIO I2S audio data format structure.
srcClock_Hz I2S master clock source frequency in Hz.

12.5.6.13 void FLEXIO_I2S_SlaveSetFormat ( FLEXIO_I2S_Type ∗ base,


flexio_i2s_format_t ∗ format )

Audio format can be changed in run-time of FlexIO I2S. This function configures the sample rate and
audio data format to be transferred.
Parameters

base Pointer to FLEXIO_I2S_Type structure


format Pointer to FlexIO I2S audio data format structure.

12.5.6.14 void FLEXIO_I2S_WriteBlocking ( FLEXIO_I2S_Type ∗ base, uint8_t bitWidth,


uint8_t ∗ txData, size_t size )

Note
This function blocks via polling until data is ready to be sent.

MCUXpresso SDK API Reference Manual


206 NXP Semiconductors
FlexIO I2S Driver

Parameters

base FlexIO I2S base pointer.


bitWidth How many bits in a audio word, usually 8/16/24/32 bits.
txData Pointer to the data to be written.
size Bytes to be written.

12.5.6.15 static void FLEXIO_I2S_WriteData ( FLEXIO_I2S_Type ∗ base, uint8_t


bitWidth, uint32_t data ) [inline], [static]

Parameters

base FlexIO I2S base pointer.


bitWidth How many bits in a audio word, usually 8/16/24/32 bits.
data Data to be written.

12.5.6.16 void FLEXIO_I2S_ReadBlocking ( FLEXIO_I2S_Type ∗ base, uint8_t bitWidth,


uint8_t ∗ rxData, size_t size )

Note
This function blocks via polling until data is ready to be sent.

Parameters

base FlexIO I2S base pointer


bitWidth How many bits in a audio word, usually 8/16/24/32 bits.
rxData Pointer to the data to be read.
size Bytes to be read.

12.5.6.17 static uint32_t FLEXIO_I2S_ReadData ( FLEXIO_I2S_Type ∗ base )


[inline], [static]

MCUXpresso SDK API Reference Manual


NXP Semiconductors 207
FlexIO I2S Driver

Parameters

base FlexIO I2S base pointer

Returns
Data read from data register.

12.5.6.18 void FLEXIO_I2S_TransferTxCreateHandle ( FLEXIO_I2S_Type ∗ base,


flexio_i2s_handle_t ∗ handle, flexio_i2s_callback_t callback, void ∗ userData )

This function initializes the FlexIO I2S handle which can be used for other FlexIO I2S transactional APIs.
Call this API once to get the initialized handle.
Parameters

base Pointer to FLEXIO_I2S_Type structure


handle Pointer to flexio_i2s_handle_t structure to store the transfer state.
callback FlexIO I2S callback function, which is called while finished a block.
userData User parameter for the FlexIO I2S callback.

12.5.6.19 void FLEXIO_I2S_TransferSetFormat ( FLEXIO_I2S_Type ∗ base,


flexio_i2s_handle_t ∗ handle, flexio_i2s_format_t ∗ format, uint32_t
srcClock_Hz )

Audio format can be changed at run-time of FlexIO I2S. This function configures the sample rate and
audio data format to be transferred.
Parameters

base Pointer to FLEXIO_I2S_Type structure.


handle FlexIO I2S handle pointer.
format Pointer to audio data format structure.
srcClock_Hz FlexIO I2S bit clock source frequency in Hz. This parameter should be 0 while in
slave mode.

12.5.6.20 void FLEXIO_I2S_TransferRxCreateHandle ( FLEXIO_I2S_Type ∗ base,


flexio_i2s_handle_t ∗ handle, flexio_i2s_callback_t callback, void ∗ userData )

This function initializes the FlexIO I2S handle which can be used for other FlexIO I2S transactional APIs.
Call this API once to get the initialized handle.

MCUXpresso SDK API Reference Manual


208 NXP Semiconductors
FlexIO I2S Driver

Parameters

base Pointer to FLEXIO_I2S_Type structure.


handle Pointer to flexio_i2s_handle_t structure to store the transfer state.
callback FlexIO I2S callback function, which is called while finished a block.
userData User parameter for the FlexIO I2S callback.

12.5.6.21 status_t FLEXIO_I2S_TransferSendNonBlocking ( FLEXIO_I2S_Type ∗ base,


flexio_i2s_handle_t ∗ handle, flexio_i2s_transfer_t ∗ xfer )

Note
The API returns immediately after transfer initiates. Call FLEXIO_I2S_GetRemainingBytes to poll
the transfer status and check whether the transfer is finished. If the return status is 0, the transfer is
finished.

Parameters

base Pointer to FLEXIO_I2S_Type structure.


handle Pointer to flexio_i2s_handle_t structure which stores the transfer state
xfer Pointer to flexio_i2s_transfer_t structure

Return values

kStatus_Success Successfully start the data transmission.


kStatus_FLEXIO_I2S_Tx- Previous transmission still not finished, data not all written to TX register
Busy yet.
kStatus_InvalidArgument The input parameter is invalid.

12.5.6.22 status_t FLEXIO_I2S_TransferReceiveNonBlocking ( FLEXIO_I2S_Type ∗


base, flexio_i2s_handle_t ∗ handle, flexio_i2s_transfer_t ∗ xfer )

Note
The API returns immediately after transfer initiates. Call FLEXIO_I2S_GetRemainingBytes to poll
the transfer status to check whether the transfer is finished. If the return status is 0, the transfer is
finished.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 209
FlexIO I2S Driver

Parameters

base Pointer to FLEXIO_I2S_Type structure.


handle Pointer to flexio_i2s_handle_t structure which stores the transfer state
xfer Pointer to flexio_i2s_transfer_t structure

Return values

kStatus_Success Successfully start the data receive.


kStatus_FLEXIO_I2S_- Previous receive still not finished.
RxBusy
kStatus_InvalidArgument The input parameter is invalid.

12.5.6.23 void FLEXIO_I2S_TransferAbortSend ( FLEXIO_I2S_Type ∗ base,


flexio_i2s_handle_t ∗ handle )

Note
This API can be called at any time when interrupt non-blocking transfer initiates to abort the transfer
in a early time.

Parameters

base Pointer to FLEXIO_I2S_Type structure.


handle Pointer to flexio_i2s_handle_t structure which stores the transfer state

12.5.6.24 void FLEXIO_I2S_TransferAbortReceive ( FLEXIO_I2S_Type ∗ base,


flexio_i2s_handle_t ∗ handle )

Note
This API can be called at any time when interrupt non-blocking transfer initiates to abort the transfer
in a early time.

Parameters

MCUXpresso SDK API Reference Manual


210 NXP Semiconductors
FlexIO I2S Driver

base Pointer to FLEXIO_I2S_Type structure.


handle Pointer to flexio_i2s_handle_t structure which stores the transfer state

12.5.6.25 status_t FLEXIO_I2S_TransferGetSendCount ( FLEXIO_I2S_Type ∗ base,


flexio_i2s_handle_t ∗ handle, size_t ∗ count )

Parameters

base Pointer to FLEXIO_I2S_Type structure.


handle Pointer to flexio_i2s_handle_t structure which stores the transfer state
count Bytes sent.

Return values

kStatus_Success Succeed get the transfer count.


kStatus_NoTransferIn- There is not a non-blocking transaction currently in progress.
Progress

12.5.6.26 status_t FLEXIO_I2S_TransferGetReceiveCount ( FLEXIO_I2S_Type ∗ base,


flexio_i2s_handle_t ∗ handle, size_t ∗ count )

Parameters

base Pointer to FLEXIO_I2S_Type structure.


handle Pointer to flexio_i2s_handle_t structure which stores the transfer state

Returns
count Bytes received.

Return values

kStatus_Success Succeed get the transfer count.


kStatus_NoTransferIn- There is not a non-blocking transaction currently in progress.
Progress

12.5.6.27 void FLEXIO_I2S_TransferTxHandleIRQ ( void ∗ i2sBase, void ∗ i2sHandle )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 211
FlexIO I2S Driver

Parameters

i2sBase Pointer to FLEXIO_I2S_Type structure.


i2sHandle Pointer to flexio_i2s_handle_t structure

12.5.6.28 void FLEXIO_I2S_TransferRxHandleIRQ ( void ∗ i2sBase, void ∗ i2sHandle )

Parameters

i2sBase Pointer to FLEXIO_I2S_Type structure.


i2sHandle Pointer to flexio_i2s_handle_t structure.

MCUXpresso SDK API Reference Manual


212 NXP Semiconductors
FlexIO I2S Driver

12.5.7 FlexIO eDMA I2S Driver

12.5.7.1 Overview

Data Structures
• struct flexio_i2s_edma_handle_t
FlexIO I2S DMA transfer handle, users should not touch the content of the handle. More...

Typedefs
• typedef void(∗ flexio_i2s_edma_callback_t )(FLEXIO_I2S_Type ∗base, flexio_i2s_edma_handle_t
∗handle, status_t status, void ∗userData)
FlexIO I2S eDMA transfer callback function for finish and error.

Driver version
• #define FSL_FLEXIO_I2S_EDMA_DRIVER_VERSION (MAKE_VERSION(2, 1, 5))
FlexIO I2S EDMA driver version 2.1.5.

eDMA Transactional
• void FLEXIO_I2S_TransferTxCreateHandleEDMA (FLEXIO_I2S_Type ∗base, flexio_i2s_edma-
_handle_t ∗handle, flexio_i2s_edma_callback_t callback, void ∗userData, edma_handle_t ∗dma-
Handle)
Initializes the FlexIO I2S eDMA handle.
• void FLEXIO_I2S_TransferRxCreateHandleEDMA (FLEXIO_I2S_Type ∗base, flexio_i2s_edma-
_handle_t ∗handle, flexio_i2s_edma_callback_t callback, void ∗userData, edma_handle_t ∗dma-
Handle)
Initializes the FlexIO I2S Rx eDMA handle.
• void FLEXIO_I2S_TransferSetFormatEDMA (FLEXIO_I2S_Type ∗base, flexio_i2s_edma_-
handle_t ∗handle, flexio_i2s_format_t ∗format, uint32_t srcClock_Hz)
Configures the FlexIO I2S Tx audio format.
• status_t FLEXIO_I2S_TransferSendEDMA (FLEXIO_I2S_Type ∗base, flexio_i2s_edma_handle_t
∗handle, flexio_i2s_transfer_t ∗xfer)
Performs a non-blocking FlexIO I2S transfer using DMA.
• status_t FLEXIO_I2S_TransferReceiveEDMA (FLEXIO_I2S_Type ∗base, flexio_i2s_edma_-
handle_t ∗handle, flexio_i2s_transfer_t ∗xfer)
Performs a non-blocking FlexIO I2S receive using eDMA.
• void FLEXIO_I2S_TransferAbortSendEDMA (FLEXIO_I2S_Type ∗base, flexio_i2s_edma_-
handle_t ∗handle)
Aborts a FlexIO I2S transfer using eDMA.
• void FLEXIO_I2S_TransferAbortReceiveEDMA (FLEXIO_I2S_Type ∗base, flexio_i2s_edma_-
handle_t ∗handle)
Aborts a FlexIO I2S receive using eDMA.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 213
FlexIO I2S Driver

• status_t FLEXIO_I2S_TransferGetSendCountEDMA (FLEXIO_I2S_Type ∗base, flexio_i2s_edma-


_handle_t ∗handle, size_t ∗count)
Gets the remaining bytes to be sent.
• status_t FLEXIO_I2S_TransferGetReceiveCountEDMA (FLEXIO_I2S_Type ∗base, flexio_i2s_-
edma_handle_t ∗handle, size_t ∗count)
Get the remaining bytes to be received.

12.5.7.2 Data Structure Documentation

12.5.7.2.1 struct _flexio_i2s_edma_handle

Data Fields

• edma_handle_t ∗ dmaHandle
DMA handler for FlexIO I2S send.
• uint8_t bytesPerFrame
Bytes in a frame.
• uint8_t nbytes
eDMA minor byte transfer count initially configured.
• uint32_t state
Internal state for FlexIO I2S eDMA transfer.
• flexio_i2s_edma_callback_t callback
Callback for users while transfer finish or error occurred.
• void ∗ userData
User callback parameter.
• edma_tcd_t tcd [FLEXIO_I2S_XFER_QUEUE_SIZE+1U]
TCD pool for eDMA transfer.
• flexio_i2s_transfer_t queue [FLEXIO_I2S_XFER_QUEUE_SIZE]
Transfer queue storing queued transfer.
• size_t transferSize [FLEXIO_I2S_XFER_QUEUE_SIZE]
Data bytes need to transfer.
• volatile uint8_t queueUser
Index for user to queue transfer.
• volatile uint8_t queueDriver
Index for driver to get the transfer data and size.

MCUXpresso SDK API Reference Manual


214 NXP Semiconductors
FlexIO I2S Driver

12.5.7.2.1.1 Field Documentation

12.5.7.2.1.1.1 uint8_t flexio_i2s_edma_handle_t::nbytes

12.5.7.2.1.1.2 edma_tcd_t flexio_i2s_edma_handle_t::tcd[FLEXIO_I2S_XFER_QUEUE_SIZ-


E+1U]

12.5.7.2.1.1.3 flexio_i2s_transfer_t flexio_i2s_edma_handle_t::queue[FLEXIO_I2S_XFER_QUE-


UE_SIZE]

12.5.7.2.1.1.4 volatile uint8_t flexio_i2s_edma_handle_t::queueUser

12.5.7.3 Macro Definition Documentation

12.5.7.3.1 #define FSL_FLEXIO_I2S_EDMA_DRIVER_VERSION (MAKE_VERSION(2, 1, 5))

12.5.7.4 Function Documentation

12.5.7.4.1 void FLEXIO_I2S_TransferTxCreateHandleEDMA ( FLEXIO_I2S_Type ∗ base,


flexio_i2s_edma_handle_t ∗ handle, flexio_i2s_edma_callback_t callback, void ∗
userData, edma_handle_t ∗ dmaHandle )

This function initializes the FlexIO I2S master DMA handle which can be used for other FlexIO I2S master
transactional APIs. Usually, for a specified FlexIO I2S instance, call this API once to get the initialized
handle.
Parameters

base FlexIO I2S peripheral base address.


handle FlexIO I2S eDMA handle pointer.
callback FlexIO I2S eDMA callback function called while finished a block.
userData User parameter for callback.
dmaHandle eDMA handle for FlexIO I2S. This handle is a static value allocated by users.

12.5.7.4.2 void FLEXIO_I2S_TransferRxCreateHandleEDMA ( FLEXIO_I2S_Type ∗ base,


flexio_i2s_edma_handle_t ∗ handle, flexio_i2s_edma_callback_t callback, void ∗
userData, edma_handle_t ∗ dmaHandle )

This function initializes the FlexIO I2S slave DMA handle which can be used for other FlexIO I2S master
transactional APIs. Usually, for a specified FlexIO I2S instance, call this API once to get the initialized
handle.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 215
FlexIO I2S Driver

Parameters

base FlexIO I2S peripheral base address.


handle FlexIO I2S eDMA handle pointer.
callback FlexIO I2S eDMA callback function called while finished a block.
userData User parameter for callback.
dmaHandle eDMA handle for FlexIO I2S. This handle is a static value allocated by users.

12.5.7.4.3 void FLEXIO_I2S_TransferSetFormatEDMA ( FLEXIO_I2S_Type ∗ base,


flexio_i2s_edma_handle_t ∗ handle, flexio_i2s_format_t ∗ format, uint32_t
srcClock_Hz )

Audio format can be changed in run-time of FlexIO I2S. This function configures the sample rate and
audio data format to be transferred. This function also sets the eDMA parameter according to format.
Parameters

base FlexIO I2S peripheral base address.


handle FlexIO I2S eDMA handle pointer
format Pointer to FlexIO I2S audio data format structure.
srcClock_Hz FlexIO I2S clock source frequency in Hz, it should be 0 while in slave mode.

Return values

kStatus_Success Audio format set successfully.


kStatus_InvalidArgument The input arguments is invalid.

12.5.7.4.4 status_t FLEXIO_I2S_TransferSendEDMA ( FLEXIO_I2S_Type ∗ base,


flexio_i2s_edma_handle_t ∗ handle, flexio_i2s_transfer_t ∗ xfer )

Note
This interface returned immediately after transfer initiates. Users should call FLEXIO_I2S_Get-
TransferStatus to poll the transfer status and check whether the FlexIO I2S transfer is finished.

Parameters

MCUXpresso SDK API Reference Manual


216 NXP Semiconductors
FlexIO I2S Driver

base FlexIO I2S peripheral base address.


handle FlexIO I2S DMA handle pointer.
xfer Pointer to DMA transfer structure.

Return values

kStatus_Success Start a FlexIO I2S eDMA send successfully.


kStatus_InvalidArgument The input arguments is invalid.
kStatus_TxBusy FlexIO I2S is busy sending data.

12.5.7.4.5 status_t FLEXIO_I2S_TransferReceiveEDMA ( FLEXIO_I2S_Type ∗ base,


flexio_i2s_edma_handle_t ∗ handle, flexio_i2s_transfer_t ∗ xfer )

Note
This interface returned immediately after transfer initiates. Users should call FLEXIO_I2S_Get-
ReceiveRemainingBytes to poll the transfer status and check whether the FlexIO I2S transfer is
finished.

Parameters

base FlexIO I2S peripheral base address.


handle FlexIO I2S DMA handle pointer.
xfer Pointer to DMA transfer structure.

Return values

kStatus_Success Start a FlexIO I2S eDMA receive successfully.


kStatus_InvalidArgument The input arguments is invalid.
kStatus_RxBusy FlexIO I2S is busy receiving data.

12.5.7.4.6 void FLEXIO_I2S_TransferAbortSendEDMA ( FLEXIO_I2S_Type ∗ base,


flexio_i2s_edma_handle_t ∗ handle )

Parameters

MCUXpresso SDK API Reference Manual


NXP Semiconductors 217
FlexIO I2S Driver

base FlexIO I2S peripheral base address.


handle FlexIO I2S DMA handle pointer.

12.5.7.4.7 void FLEXIO_I2S_TransferAbortReceiveEDMA ( FLEXIO_I2S_Type ∗ base,


flexio_i2s_edma_handle_t ∗ handle )

Parameters

base FlexIO I2S peripheral base address.


handle FlexIO I2S DMA handle pointer.

12.5.7.4.8 status_t FLEXIO_I2S_TransferGetSendCountEDMA ( FLEXIO_I2S_Type ∗ base,


flexio_i2s_edma_handle_t ∗ handle, size_t ∗ count )

Parameters

base FlexIO I2S peripheral base address.


handle FlexIO I2S DMA handle pointer.
count Bytes sent.

Return values

kStatus_Success Succeed get the transfer count.


kStatus_NoTransferIn- There is not a non-blocking transaction currently in progress.
Progress

12.5.7.4.9 status_t FLEXIO_I2S_TransferGetReceiveCountEDMA ( FLEXIO_I2S_Type ∗ base,


flexio_i2s_edma_handle_t ∗ handle, size_t ∗ count )

Parameters

base FlexIO I2S peripheral base address.


handle FlexIO I2S DMA handle pointer.

MCUXpresso SDK API Reference Manual


218 NXP Semiconductors
FlexIO I2S Driver

count Bytes received.

Return values

kStatus_Success Succeed get the transfer count.


kStatus_NoTransferIn- There is not a non-blocking transaction currently in progress.
Progress

MCUXpresso SDK API Reference Manual


NXP Semiconductors 219
FlexIO I2S Driver

12.5.8 FlexIO DMA I2S Driver

12.5.8.1 Overview

Data Structures
• struct flexio_i2s_dma_handle_t
FlexIO I2S DMA transfer handle, users should not touch the content of the handle. More...

Typedefs
• typedef void(∗ flexio_i2s_dma_callback_t )(FLEXIO_I2S_Type ∗base, flexio_i2s_dma_handle_-
t ∗handle, status_t status, void ∗userData)
FlexIO I2S DMA transfer callback function for finish and error.

Driver version
• #define FSL_FLEXIO_I2S_DMA_DRIVER_VERSION (MAKE_VERSION(2, 1, 5))
FlexIO I2S DMA driver version 2.1.5.

DMA Transactional
• void FLEXIO_I2S_TransferTxCreateHandleDMA (FLEXIO_I2S_Type ∗base, flexio_i2s_dma-
_handle_t ∗handle, flexio_i2s_dma_callback_t callback, void ∗userData, dma_handle_t ∗dma-
Handle)
Initializes the FlexIO I2S DMA handle.
• void FLEXIO_I2S_TransferRxCreateHandleDMA (FLEXIO_I2S_Type ∗base, flexio_i2s_dma-
_handle_t ∗handle, flexio_i2s_dma_callback_t callback, void ∗userData, dma_handle_t ∗dma-
Handle)
Initializes the FlexIO I2S Rx DMA handle.
• void FLEXIO_I2S_TransferSetFormatDMA (FLEXIO_I2S_Type ∗base, flexio_i2s_dma_handle_t
∗handle, flexio_i2s_format_t ∗format, uint32_t srcClock_Hz)
Configures the FlexIO I2S Tx audio format.
• status_t FLEXIO_I2S_TransferSendDMA (FLEXIO_I2S_Type ∗base, flexio_i2s_dma_handle_-
t ∗handle, flexio_i2s_transfer_t ∗xfer)
Performs a non-blocking FlexIO I2S transfer using DMA.
• status_t FLEXIO_I2S_TransferReceiveDMA (FLEXIO_I2S_Type ∗base, flexio_i2s_dma_handle_t
∗handle, flexio_i2s_transfer_t ∗xfer)
Performs a non-blocking FlexIO I2S receive using DMA.
• void FLEXIO_I2S_TransferAbortSendDMA (FLEXIO_I2S_Type ∗base, flexio_i2s_dma_handle_t
∗handle)
Aborts a FlexIO I2S transfer using DMA.
• void FLEXIO_I2S_TransferAbortReceiveDMA (FLEXIO_I2S_Type ∗base, flexio_i2s_dma_-
handle_t ∗handle)
Aborts a FlexIO I2S receive using DMA.

MCUXpresso SDK API Reference Manual


220 NXP Semiconductors
FlexIO I2S Driver

• status_t FLEXIO_I2S_TransferGetSendCountDMA (FLEXIO_I2S_Type ∗base, flexio_i2s_dma_-


handle_t ∗handle, size_t ∗count)
Gets the remaining bytes to be sent.
• status_t FLEXIO_I2S_TransferGetReceiveCountDMA (FLEXIO_I2S_Type ∗base, flexio_i2s_-
dma_handle_t ∗handle, size_t ∗count)
Gets the remaining bytes to be received.

12.5.8.2 Data Structure Documentation

12.5.8.2.1 struct _flexio_i2s_dma_handle

Data Fields

• dma_handle_t ∗ dmaHandle
DMA handler for FlexIO I2S send.
• uint8_t bytesPerFrame
Bytes in a frame.
• uint32_t state
Internal state for FlexIO I2S DMA transfer.
• flexio_i2s_dma_callback_t callback
Callback for users while transfer finish or error occurred.
• void ∗ userData
User callback parameter.
• flexio_i2s_transfer_t queue [FLEXIO_I2S_XFER_QUEUE_SIZE]
Transfer queue storing queued transfer.
• size_t transferSize [FLEXIO_I2S_XFER_QUEUE_SIZE]
Data bytes need to transfer.
• volatile uint8_t queueUser
Index for user to queue transfer.
• volatile uint8_t queueDriver
Index for driver to get the transfer data and size.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 221
FlexIO I2S Driver

12.5.8.2.1.1 Field Documentation

12.5.8.2.1.1.1 flexio_i2s_transfer_t flexio_i2s_dma_handle_t::queue[FLEXIO_I2S_XFER_QUE-


UE_SIZE]

12.5.8.2.1.1.2 volatile uint8_t flexio_i2s_dma_handle_t::queueUser

12.5.8.3 Macro Definition Documentation

12.5.8.3.1 #define FSL_FLEXIO_I2S_DMA_DRIVER_VERSION (MAKE_VERSION(2, 1, 5))

12.5.8.4 Function Documentation

12.5.8.4.1 void FLEXIO_I2S_TransferTxCreateHandleDMA ( FLEXIO_I2S_Type ∗ base,


flexio_i2s_dma_handle_t ∗ handle, flexio_i2s_dma_callback_t callback, void ∗
userData, dma_handle_t ∗ dmaHandle )

This function initializes the FlexIO I2S master DMA handle which can be used for other FlexIO I2S master
transactional APIs. Usually, for a specified FlexIO I2S instance, call this API once to get the initialized
handle.
Parameters

base FlexIO I2S peripheral base address.


handle FlexIO I2S DMA handle pointer.
callback FlexIO I2S DMA callback function called while finished a block.
userData User parameter for callback.
dmaHandle DMA handle for FlexIO I2S. This handle is a static value allocated by users.

12.5.8.4.2 void FLEXIO_I2S_TransferRxCreateHandleDMA ( FLEXIO_I2S_Type ∗ base,


flexio_i2s_dma_handle_t ∗ handle, flexio_i2s_dma_callback_t callback, void ∗
userData, dma_handle_t ∗ dmaHandle )

This function initializes the FlexIO I2S slave DMA handle which can be used for other FlexIO I2S master
transactional APIs. Usually, for a specified FlexIO I2S instance, call this API once to get the initialized
handle.
Parameters

MCUXpresso SDK API Reference Manual


222 NXP Semiconductors
FlexIO I2S Driver

base FlexIO I2S peripheral base address.


handle FlexIO I2S DMA handle pointer.
callback FlexIO I2S DMA callback function called while finished a block.
userData User parameter for callback.
dmaHandle DMA handle for FlexIO I2S. This handle is a static value allocated by users.

12.5.8.4.3 void FLEXIO_I2S_TransferSetFormatDMA ( FLEXIO_I2S_Type ∗ base,


flexio_i2s_dma_handle_t ∗ handle, flexio_i2s_format_t ∗ format, uint32_t srcClock_Hz
)

Audio format can be changed at run-time of FlexIO I2S. This function configures the sample rate and
audio data format to be transferred. This function also sets the DMA parameter according to the format.
Parameters

base FlexIO I2S peripheral base address.


handle FlexIO I2S DMA handle pointer
format Pointer to FlexIO I2S audio data format structure.
srcClock_Hz FlexIO I2S clock source frequency in Hz. It should be 0 while in slave mode.

Return values

kStatus_Success Audio format set successfully.


kStatus_InvalidArgument The input arguments is invalid.

12.5.8.4.4 status_t FLEXIO_I2S_TransferSendDMA ( FLEXIO_I2S_Type ∗ base,


flexio_i2s_dma_handle_t ∗ handle, flexio_i2s_transfer_t ∗ xfer )

Note
This interface returns immediately after transfer initiates. Call FLEXIO_I2S_GetTransferStatus to
poll the transfer status and check whether FLEXIO I2S transfer finished.

Parameters

MCUXpresso SDK API Reference Manual


NXP Semiconductors 223
FlexIO I2S Driver

base FlexIO I2S peripheral base address.


handle FlexIO I2S DMA handle pointer.
xfer Pointer to DMA transfer structure.

Return values

kStatus_Success Start a FlexIO I2S DMA send successfully.


kStatus_InvalidArgument The input arguments is invalid.
kStatus_TxBusy FlexIO I2S is busy sending data.

12.5.8.4.5 status_t FLEXIO_I2S_TransferReceiveDMA ( FLEXIO_I2S_Type ∗ base,


flexio_i2s_dma_handle_t ∗ handle, flexio_i2s_transfer_t ∗ xfer )

Note
This interface returns immediately after transfer initiates. Call FLEXIO_I2S_GetReceive-
RemainingBytes to poll the transfer status to check whether the FlexIO I2S transfer is finished.

Parameters

base FlexIO I2S peripheral base address.


handle FlexIO I2S DMA handle pointer.
xfer Pointer to DMA transfer structure.

Return values

kStatus_Success Start a FlexIO I2S DMA receive successfully.


kStatus_InvalidArgument The input arguments is invalid.
kStatus_RxBusy FlexIO I2S is busy receiving data.

12.5.8.4.6 void FLEXIO_I2S_TransferAbortSendDMA ( FLEXIO_I2S_Type ∗ base,


flexio_i2s_dma_handle_t ∗ handle )

Parameters

MCUXpresso SDK API Reference Manual


224 NXP Semiconductors
FlexIO I2S Driver

base FlexIO I2S peripheral base address.


handle FlexIO I2S DMA handle pointer.

12.5.8.4.7 void FLEXIO_I2S_TransferAbortReceiveDMA ( FLEXIO_I2S_Type ∗ base,


flexio_i2s_dma_handle_t ∗ handle )

Parameters

base FlexIO I2S peripheral base address.


handle FlexIO I2S DMA handle pointer.

12.5.8.4.8 status_t FLEXIO_I2S_TransferGetSendCountDMA ( FLEXIO_I2S_Type ∗ base,


flexio_i2s_dma_handle_t ∗ handle, size_t ∗ count )

Parameters

base FlexIO I2S peripheral base address.


handle FlexIO I2S DMA handle pointer.
count Bytes sent.

Return values

kStatus_Success Succeed get the transfer count.


kStatus_NoTransferIn- There is not a non-blocking transaction currently in progress.
Progress

12.5.8.4.9 status_t FLEXIO_I2S_TransferGetReceiveCountDMA ( FLEXIO_I2S_Type ∗ base,


flexio_i2s_dma_handle_t ∗ handle, size_t ∗ count )

Parameters

base FlexIO I2S peripheral base address.


handle FlexIO I2S DMA handle pointer.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 225
FlexIO I2S Driver

count Bytes received.

Return values

kStatus_Success Succeed get the transfer count.


kStatus_NoTransferIn- There is not a non-blocking transaction currently in progress.
Progress

MCUXpresso SDK API Reference Manual


226 NXP Semiconductors
FlexIO MCU Interface LCD Driver

12.6 FlexIO MCU Interface LCD Driver


12.6.1 Overview

The MCUXpresso SDK provides a peripheral driver for LCD (8080 or 6800 interface) function using
Flexible I/O module of MCUXpresso SDK devices.
The FlexIO LCD driver supports both 8-bit and 16-bit data bus, 8080 and 6800 interface. User could
change the macro FLEXIO_MCULCD_DATA_BUS_WIDTH to choose 8-bit data bus or 16-bit data bus.
The FlexIO LCD driver supports three kinds of data transfer:
1. Send a data array. For example, send the LCD image data to the LCD controller.
2. Send a value many times. For example, send 0 many times to clean the LCD screen.
3. Read data into a data array. For example, read image from LCD controller.
The FlexIO LCD driver includes functional APIs and transactional APIs.
Functional APIs are feature/property target low level APIs. Functional APIs can be used for FlexIO LCD
initialization/configuration/operation for optimization/customization purpose. Using the functional API
requires the knowledge of the FlexIO LCD peripheral and how to organize functional APIs to meet the
application requirements. All functional API use the peripheral base address as the first parameter. FlexIO
LCD functional operation groups provide the functional APIs set.
Transactional APIs are transaction target high level APIs. The transactional APIs can be used to enable
the peripheral and also in the application if the code size and performance of transactional APIs can
satisfy requirements. If the code size and performance are critical requirements, see the transactional API
implementation and write custom code.
Transactional APIs support asynchronous transfer. This means that the function FLEXIO_MCULCD_-
TransferNonBlocking sets up an interrupt for data transfer. When the transfer completes, the upper layer
is notified through a callback function with the kStatus_FLEXIO_MCULCD_Idle status.

12.6.2 Typical use case

12.6.2.1 FlexIO LCD send/receive using functional APIs

This example shows how to send command, or write and read data using the functional APIs. The data
bus is 16-bit.

uint16_t dataToSend[] = { ... };


uint16_t dataToReceive[] = { ... };

FLEXIO_MCULCD_Type flexioLcdDev;
flexio_MCULCD_transfer_t xfer;
flexio_MCULCD_config_t config;

FLEXIO_MCULCD_GetDefaultConfig(&config);
FLEXIO_MCULCD_Init(&flexioLcdDev, &config, 120000000);

// Method 1:
FLEXIO_MCULCD_StartTransfer(&flexioLcdDev);

MCUXpresso SDK API Reference Manual


NXP Semiconductors 227
FlexIO MCU Interface LCD Driver

FLEXIO_MCULCD_WriteCommandBlocking(&flexioLcdDev, command1);
FLEXIO_MCULCD_StopTransfer(&flexioLcdDev);

// Method 2:
xfer.command = command1;
xfer.dataCount = 0; // Only send command, no data transfer.
FLEXIO_MCULCD_TransferBlocking(&flexioLcdDev, &xfer);

// Method 1:
FLEXIO_MCULCD_StartTransfer(&flexioLcdDev);
FLEXIO_MCULCD_WriteCommandBlocking(&flexioLcdDev, command2);
FLEXIO_MCULCD_WriteDataArrayBlocking(&flexioLcdDev, dataToSend, sizeof(
dataToSend));
FLEXIO_MCULCD_StopTransfer(&flexioLcdDev);

// Method 2:
xfer.command = command2;
xfer.mode = kFLEXIO_MCULCD_WriteArray;
xfer.dataAddrOrSameValue = (uint32_t)dataToSend;
xfer.dataCount = sizeof(dataToSend);
FLEXIO_MCULCD_TransferBlocking(&flexioLcdDev, &xfer);

// Method 1:
FLEXIO_MCULCD_StartTransfer(&flexioLcdDev);
FLEXIO_MCULCD_WriteCommandBlocking(&flexioLcdDev, command2);
FLEXIO_MCULCD_WriteSameValueBlocking(&flexioLcdDev, value, 1000); //
Send value 1000 times
FLEXIO_MCULCD_StopTransfer(&flexioLcdDev);

// Method 2:
xfer.command = command2;
xfer.mode = kFLEXIO_MCULCD_WriteSameValue;
xfer.dataAddrOrSameValue = value;
xfer.dataCount = 1000;
FLEXIO_MCULCD_TransferBlocking(&flexioLcdDev, &xfer);

// Method 1:
FLEXIO_MCULCD_StartTransfer(&flexioLcdDev);
FLEXIO_MCULCD_WriteCommandBlocking(&flexioLcdDev, command3);
FLEXIO_MCULCD_ReadDataArrayBlocking(&flexioLcdDev, dataToReceive, sizeof
(dataToReceive));
FLEXIO_MCULCD_StopTransfer(&flexioLcdDev);

// Method 2:
xfer.command = command3;
xfer.mode = kFLEXIO_MCULCD_ReadArray;
xfer.dataAddrOrSameValue = (uint32_t)dataToReceive;
xfer.dataCount = sizeof(dataToReceive);
FLEXIO_MCULCD_TransferBlocking(&flexioLcdDev, &xfer);

12.6.2.2 FlexIO LCD send/receive using interrupt transactional APIs


flexio_MCULCD_handle_t handle;
volatile bool completeFlag = false;

void flexioLcdCallback(FLEXIO_MCULCD_Type *base, flexio_MCULCD_handle_t *handle, status_t


status, void *userData)
{
if (kStatus_FLEXIO_MCULCD_Idle == status)
{
completeFlag = true;
}
}

void main(void)

MCUXpresso SDK API Reference Manual


228 NXP Semiconductors
FlexIO MCU Interface LCD Driver

{
// Init the FlexIO LCD driver.
FLEXIO_MCULCD_Init(...);

// Create the transactional handle.


FLEXIO_MCULCD_TransferCreateHandle(&flexioLcdDev, &handle,
flexioLcdCallback, NULL);

xfer.command = command1;
xfer.dataCount = 0; // Only send command, no data transfer.
completeFlag = false;
FLEXIO_MCULCD_TransferNonBlocking(&flexioLcdDev, &xfer);

// When only send method, it is not necessary to wait for the callback,
// because the command is sent using a blocking method internally. The
// command has been sent out after the function FLEXIO_MCULCD_TransferNonBlocking
// returns.
while (!completeFlag)
{
}

xfer.command = command2;
xfer.mode = kFLEXIO_MCULCD_WriteArray;
xfer.dataAddrOrSameValue = (uint32_t)dataToSend;
xfer.dataCount = sizeof(dataToSend);
completeFlag = false;
FLEXIO_MCULCD_TransferNonBlocking(&flexioLcdDev, &handle, &xfer);

while (!completeFlag)
{
}

xfer.command = command2;
xfer.mode = kFLEXIO_MCULCD_WriteSameValue;
xfer.dataAddrOrSameValue = value;
xfer.dataCount = 1000;
completeFlag = false;
FLEXIO_MCULCD_TransferNonBlocking(&flexioLcdDev, &handle, &xfer);

while (!completeFlag)
{
}

xfer.command = command3;
xfer.mode = kFLEXIO_MCULCD_ReadArray;
xfer.dataAddrOrSameValue = (uint32_t)dataToReceive;
xfer.dataCount = sizeof(dataToReceive);
completeFlag = false;
FLEXIO_MCULCD_TransferNonBlocking(&flexioLcdDev, &handle, &xfer);

while (!completeFlag)
{
}
}

Modules

• FlexIO DMA MCU Interface LCD Driver


• FlexIO SMARTDMA MCU Interface LCD Driver
• FlexIO eDMA MCU Interface LCD Driver
SDK provide eDMA transactional APIs to transfer data using eDMA, the eDMA method is similar with
interrupt transactional method.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 229
FlexIO MCU Interface LCD Driver

Data Structures

• struct FLEXIO_MCULCD_Type
Define FlexIO MCULCD access structure typedef. More...
• struct flexio_mculcd_config_t
Define FlexIO MCULCD configuration structure. More...
• struct flexio_mculcd_transfer_t
Define FlexIO MCULCD transfer structure. More...
• struct flexio_mculcd_handle_t
Define FlexIO MCULCD handle structure. More...

Macros

• #define FLEXIO_MCULCD_WAIT_COMPLETE_TIME 512


The delay time to wait for FLEXIO transmit complete.
• #define FLEXIO_MCULCD_DATA_BUS_WIDTH 16
The data bus width, must be 8 or 16.

Typedefs

• typedef void(∗ flexio_mculcd_pin_func_t )(bool set)


Function to set or clear the CS and RS pin.
• typedef 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.

Enumerations

• enum _flexio_mculcd_status {
kStatus_FLEXIO_MCULCD_Idle = MAKE_STATUS(kStatusGroup_FLEXIO_MCULCD, 0),
kStatus_FLEXIO_MCULCD_Busy = MAKE_STATUS(kStatusGroup_FLEXIO_MCULCD, 1),
kStatus_FLEXIO_MCULCD_Error = MAKE_STATUS(kStatusGroup_FLEXIO_MCULCD, 2) }
FlexIO LCD transfer status.
• enum flexio_mculcd_pixel_format_t {
kFLEXIO_MCULCD_RGB565 = 0,
kFLEXIO_MCULCD_BGR565,
kFLEXIO_MCULCD_RGB888,
kFLEXIO_MCULCD_BGR888 }
Define FlexIO MCULCD pixel format.
• enum flexio_mculcd_bus_t {
kFLEXIO_MCULCD_8080,
kFLEXIO_MCULCD_6800 }
Define FlexIO MCULCD bus type.
• enum _flexio_mculcd_interrupt_enable {
kFLEXIO_MCULCD_TxEmptyInterruptEnable = (1U << 0U),

MCUXpresso SDK API Reference Manual


230 NXP Semiconductors
FlexIO MCU Interface LCD Driver

kFLEXIO_MCULCD_RxFullInterruptEnable = (1U << 1U) }


Define FlexIO MCULCD interrupt mask.
• enum _flexio_mculcd_status_flags {
kFLEXIO_MCULCD_TxEmptyFlag = (1U << 0U),
kFLEXIO_MCULCD_RxFullFlag = (1U << 1U) }
Define FlexIO MCULCD status mask.
• enum _flexio_mculcd_dma_enable {
kFLEXIO_MCULCD_TxDmaEnable = 0x1U,
kFLEXIO_MCULCD_RxDmaEnable = 0x2U }
Define FlexIO MCULCD DMA mask.
• enum flexio_mculcd_transfer_mode_t {
kFLEXIO_MCULCD_ReadArray,
kFLEXIO_MCULCD_WriteArray,
kFLEXIO_MCULCD_WriteSameValue }
Transfer mode.

Driver version

• #define FSL_FLEXIO_MCULCD_DRIVER_VERSION (MAKE_VERSION(2, 0, 2))


FlexIO MCULCD driver version 2.0.2.

FlexIO MCULCD Configuration

• 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, and
configures the FlexIO MCULCD with FlexIO MCULCD configuration.
• void FLEXIO_MCULCD_Deinit (FLEXIO_MCULCD_Type ∗base)
Resets the FLEXIO_MCULCD timer and shifter configuration.
• void FLEXIO_MCULCD_GetDefaultConfig (flexio_mculcd_config_t ∗config)
Gets the default configuration to configure the FlexIO MCULCD.

Status

• uint32_t FLEXIO_MCULCD_GetStatusFlags (FLEXIO_MCULCD_Type ∗base)


Gets FlexIO MCULCD status flags.
• void FLEXIO_MCULCD_ClearStatusFlags (FLEXIO_MCULCD_Type ∗base, uint32_t mask)
Clears FlexIO MCULCD status flags.

Interrupts

• void FLEXIO_MCULCD_EnableInterrupts (FLEXIO_MCULCD_Type ∗base, uint32_t mask)


Enables the FlexIO MCULCD interrupt.
• void FLEXIO_MCULCD_DisableInterrupts (FLEXIO_MCULCD_Type ∗base, uint32_t mask)

MCUXpresso SDK API Reference Manual


NXP Semiconductors 231
FlexIO MCU Interface LCD Driver

Disables the FlexIO MCULCD interrupt.

DMA Control

• static void FLEXIO_MCULCD_EnableTxDMA (FLEXIO_MCULCD_Type ∗base, bool enable)


Enables/disables the FlexIO MCULCD transmit DMA.
• static void FLEXIO_MCULCD_EnableRxDMA (FLEXIO_MCULCD_Type ∗base, bool enable)
Enables/disables the FlexIO MCULCD receive DMA.
• static uint32_t FLEXIO_MCULCD_GetTxDataRegisterAddress (FLEXIO_MCULCD_Type
∗base)
Gets the FlexIO MCULCD transmit data register address.
• static uint32_t FLEXIO_MCULCD_GetRxDataRegisterAddress (FLEXIO_MCULCD_Type
∗base)
Gets the FlexIO MCULCD receive data register address.

Bus Operations

• status_t FLEXIO_MCULCD_SetBaudRate (FLEXIO_MCULCD_Type ∗base, uint32_t baudRate-


_Bps, uint32_t srcClock_Hz)
Set desired baud rate.
• void FLEXIO_MCULCD_SetSingleBeatWriteConfig (FLEXIO_MCULCD_Type ∗base)
Configures the FLEXIO MCULCD to multiple beats write mode.
• void FLEXIO_MCULCD_ClearSingleBeatWriteConfig (FLEXIO_MCULCD_Type ∗base)
Clear the FLEXIO MCULCD multiple beats write mode configuration.
• void FLEXIO_MCULCD_SetSingleBeatReadConfig (FLEXIO_MCULCD_Type ∗base)
Configures the FLEXIO MCULCD to multiple beats read mode.
• void FLEXIO_MCULCD_ClearSingleBeatReadConfig (FLEXIO_MCULCD_Type ∗base)
Clear the FLEXIO MCULCD multiple beats read mode configuration.
• void FLEXIO_MCULCD_SetMultiBeatsWriteConfig (FLEXIO_MCULCD_Type ∗base)
Configures the FLEXIO MCULCD to multiple beats write mode.
• void FLEXIO_MCULCD_ClearMultiBeatsWriteConfig (FLEXIO_MCULCD_Type ∗base)
Clear the FLEXIO MCULCD multiple beats write mode configuration.
• void FLEXIO_MCULCD_SetMultiBeatsReadConfig (FLEXIO_MCULCD_Type ∗base)
Configures the FLEXIO MCULCD to multiple beats read mode.
• void FLEXIO_MCULCD_ClearMultiBeatsReadConfig (FLEXIO_MCULCD_Type ∗base)
Clear the FLEXIO MCULCD multiple beats read mode configuration.
• static void FLEXIO_MCULCD_Enable (FLEXIO_MCULCD_Type ∗base, bool enable)
Enables/disables the FlexIO MCULCD module operation.
• uint32_t FLEXIO_MCULCD_ReadData (FLEXIO_MCULCD_Type ∗base)
Read data from the FLEXIO MCULCD RX shifter buffer.
• static void FLEXIO_MCULCD_WriteData (FLEXIO_MCULCD_Type ∗base, uint32_t data)
Write data into the FLEXIO MCULCD TX shifter buffer.
• static void FLEXIO_MCULCD_StartTransfer (FLEXIO_MCULCD_Type ∗base)
Assert the nCS to start transfer.
• static void FLEXIO_MCULCD_StopTransfer (FLEXIO_MCULCD_Type ∗base)
De-assert the nCS to stop transfer.
• void FLEXIO_MCULCD_WaitTransmitComplete (void)
Wait for transmit data send out finished.

MCUXpresso SDK API Reference Manual


232 NXP Semiconductors
FlexIO MCU Interface LCD Driver

• void FLEXIO_MCULCD_WriteCommandBlocking (FLEXIO_MCULCD_Type ∗base, uint32_-


t command)
Send command in blocking way.
• void FLEXIO_MCULCD_WriteDataArrayBlocking (FLEXIO_MCULCD_Type ∗base, void ∗data,
size_t size)
Send data array in blocking way.
• void FLEXIO_MCULCD_ReadDataArrayBlocking (FLEXIO_MCULCD_Type ∗base, void ∗data,
size_t size)
Read data into array in blocking way.
• 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_TransferBlocking (FLEXIO_MCULCD_Type ∗base, flexio_mculcd_-
transfer_t ∗xfer)
Performs a polling transfer.

Transactional

• 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.
• status_t FLEXIO_MCULCD_TransferNonBlocking (FLEXIO_MCULCD_Type ∗base, flexio_-
mculcd_handle_t ∗handle, flexio_mculcd_transfer_t ∗xfer)
Transfer data using IRQ.
• void FLEXIO_MCULCD_TransferAbort (FLEXIO_MCULCD_Type ∗base, flexio_mculcd_-
handle_t ∗handle)
Aborts the data transfer, which used IRQ.
• 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.
• void FLEXIO_MCULCD_TransferHandleIRQ (void ∗base, void ∗handle)
FlexIO MCULCD IRQ handler function.

12.6.3 Data Structure Documentation

12.6.3.1 struct FLEXIO_MCULCD_Type

Data Fields
• FLEXIO_Type ∗ flexioBase
FlexIO base pointer.
• flexio_mculcd_bus_t busType
The bus type, 8080 or 6800.
• uint8_t dataPinStartIndex
Start index of the data pin, the FlexIO pin dataPinStartIndex to (dataPinStartIndex + FLEXIO_MCULC-
D_DATA_BUS_WIDTH -1) will be used for data transfer.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 233
FlexIO MCU Interface LCD Driver

• uint8_t ENWRPinIndex
Pin select for WR(8080 mode), EN(6800 mode).
• uint8_t RDPinIndex
Pin select for RD(8080 mode), not used in 6800 mode.
• uint8_t txShifterStartIndex
Start index of shifters used for data write, it must be 0 or 4.
• uint8_t txShifterEndIndex
End index of shifters used for data write.
• uint8_t rxShifterStartIndex
Start index of shifters used for data read.
• uint8_t rxShifterEndIndex
End index of shifters used for data read, it must be 3 or 7.
• uint8_t timerIndex
Timer index used in FlexIO MCULCD.
• flexio_mculcd_pin_func_t setCSPin
Function to set or clear the CS pin.
• flexio_mculcd_pin_func_t setRSPin
Function to set or clear the RS pin.
• flexio_mculcd_pin_func_t setRDWRPin
Function to set or clear the RD/WR pin, only used in 6800 mode.

12.6.3.1.0.1 Field Documentation

12.6.3.1.0.1.1 FLEXIO_Type∗ FLEXIO_MCULCD_Type::flexioBase

12.6.3.1.0.1.2 flexio_mculcd_bus_t FLEXIO_MCULCD_Type::busType

12.6.3.1.0.1.3 uint8_t FLEXIO_MCULCD_Type::dataPinStartIndex

Only support data bus width 8 and 16.

MCUXpresso SDK API Reference Manual


234 NXP Semiconductors
FlexIO MCU Interface LCD Driver

12.6.3.1.0.1.4 uint8_t FLEXIO_MCULCD_Type::ENWRPinIndex

12.6.3.1.0.1.5 uint8_t FLEXIO_MCULCD_Type::RDPinIndex

12.6.3.1.0.1.6 uint8_t FLEXIO_MCULCD_Type::txShifterStartIndex

12.6.3.1.0.1.7 uint8_t FLEXIO_MCULCD_Type::txShifterEndIndex

12.6.3.1.0.1.8 uint8_t FLEXIO_MCULCD_Type::rxShifterStartIndex

12.6.3.1.0.1.9 uint8_t FLEXIO_MCULCD_Type::rxShifterEndIndex

12.6.3.1.0.1.10 uint8_t FLEXIO_MCULCD_Type::timerIndex

12.6.3.1.0.1.11 flexio_mculcd_pin_func_t FLEXIO_MCULCD_Type::setCSPin

12.6.3.1.0.1.12 flexio_mculcd_pin_func_t FLEXIO_MCULCD_Type::setRSPin

12.6.3.1.0.1.13 flexio_mculcd_pin_func_t FLEXIO_MCULCD_Type::setRDWRPin

12.6.3.2 struct flexio_mculcd_config_t

Data Fields
• bool enable
Enable/disable FlexIO MCULCD after configuration.
• bool enableInDoze
Enable/disable FlexIO operation in doze mode.
• bool enableInDebug
Enable/disable FlexIO operation in debug mode.
• bool enableFastAccess
Enable/disable fast access to FlexIO registers,
fast access requires the FlexIO clock to be at least twice the frequency of the bus clock.
• uint32_t baudRate_Bps
Baud rate in Bps.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 235
FlexIO MCU Interface LCD Driver

12.6.3.2.0.2 Field Documentation

12.6.3.2.0.2.1 bool flexio_mculcd_config_t::enable

12.6.3.2.0.2.2 bool flexio_mculcd_config_t::enableInDoze

12.6.3.2.0.2.3 bool flexio_mculcd_config_t::enableInDebug

12.6.3.2.0.2.4 bool flexio_mculcd_config_t::enableFastAccess

12.6.3.2.0.2.5 uint32_t flexio_mculcd_config_t::baudRate_Bps

12.6.3.3 struct flexio_mculcd_transfer_t

Data Fields
• uint32_t command
Command to send.
• flexio_mculcd_transfer_mode_t mode
Transfer mode.
• uint32_t dataAddrOrSameValue
When sending the same value for many times, this is the value to send.
• size_t dataSize
How many bytes to transfer.

12.6.3.3.0.3 Field Documentation

12.6.3.3.0.3.1 uint32_t flexio_mculcd_transfer_t::command

12.6.3.3.0.3.2 flexio_mculcd_transfer_mode_t flexio_mculcd_transfer_t::mode

12.6.3.3.0.3.3 uint32_t flexio_mculcd_transfer_t::dataAddrOrSameValue

When writing or reading array, this is the address of the data array.

12.6.3.3.0.3.4 size_t flexio_mculcd_transfer_t::dataSize

12.6.3.4 struct _flexio_mculcd_handle

typedef for flexio_mculcd_handle_t in advance.

Data Fields
• uint32_t dataAddrOrSameValue
When sending the same value for many times, this is the value to send.
• size_t dataCount
Total count to be transferred.
• volatile size_t remainingCount
Remaining count to transfer.
• volatile uint32_t state

MCUXpresso SDK API Reference Manual


236 NXP Semiconductors
FlexIO MCU Interface LCD Driver

FlexIO MCULCD internal state.


• flexio_mculcd_transfer_callback_t completionCallback
FlexIO MCULCD transfer completed callback.
• void ∗ userData
Callback parameter.

12.6.3.4.0.4 Field Documentation

12.6.3.4.0.4.1 uint32_t flexio_mculcd_handle_t::dataAddrOrSameValue

When writing or reading array, this is the address of the data array.

12.6.3.4.0.4.2 size_t flexio_mculcd_handle_t::dataCount

12.6.3.4.0.4.3 volatile size_t flexio_mculcd_handle_t::remainingCount

12.6.3.4.0.4.4 volatile uint32_t flexio_mculcd_handle_t::state

12.6.3.4.0.4.5 flexio_mculcd_transfer_callback_t flexio_mculcd_handle_t::completionCallback

12.6.3.4.0.4.6 void∗ flexio_mculcd_handle_t::userData

12.6.4 Macro Definition Documentation

12.6.4.1 #define FSL_FLEXIO_MCULCD_DRIVER_VERSION (MAKE_VERSION(2, 0, 2))

12.6.4.2 #define FLEXIO_MCULCD_WAIT_COMPLETE_TIME 512

Currently there is no method to detect whether the data has been sent out from the shifter, so the driver
use a software delay for this. When the data is written to shifter buffer, the driver call the delay function
to wait for the data shift out. If this value is too small, then the last few bytes might be lost when writing
data using interrupt method or DMA method.

12.6.5 Typedef Documentation

12.6.5.1 typedef void(∗ flexio_mculcd_pin_func_t)(bool set)

12.6.5.2 typedef void(∗ flexio_mculcd_transfer_callback_t)(FLEXIO_MCULCD_Type


∗base, flexio_mculcd_handle_t ∗handle, status_t status, void ∗userData)

When transfer finished, the callback function is called and returns the status as kStatus_FLEXIO_MC-
ULCD_Idle.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 237
FlexIO MCU Interface LCD Driver

12.6.6 Enumeration Type Documentation

12.6.6.1 enum _flexio_mculcd_status

Enumerator
kStatus_FLEXIO_MCULCD_Idle FlexIO LCD is idle.
kStatus_FLEXIO_MCULCD_Busy FlexIO LCD is busy.
kStatus_FLEXIO_MCULCD_Error FlexIO LCD error occurred.

12.6.6.2 enum flexio_mculcd_pixel_format_t

Enumerator
kFLEXIO_MCULCD_RGB565 RGB565, 16-bit.
kFLEXIO_MCULCD_BGR565 BGR565, 16-bit.
kFLEXIO_MCULCD_RGB888 RGB888, 24-bit.
kFLEXIO_MCULCD_BGR888 BGR888, 24-bit.

12.6.6.3 enum flexio_mculcd_bus_t

Enumerator
kFLEXIO_MCULCD_8080 Using Intel 8080 bus.
kFLEXIO_MCULCD_6800 Using Motorola 6800 bus.

12.6.6.4 enum _flexio_mculcd_interrupt_enable

Enumerator
kFLEXIO_MCULCD_TxEmptyInterruptEnable Transmit buffer empty interrupt enable.
kFLEXIO_MCULCD_RxFullInterruptEnable Receive buffer full interrupt enable.

12.6.6.5 enum _flexio_mculcd_status_flags

Enumerator
kFLEXIO_MCULCD_TxEmptyFlag Transmit buffer empty flag.
kFLEXIO_MCULCD_RxFullFlag Receive buffer full flag.

MCUXpresso SDK API Reference Manual


238 NXP Semiconductors
FlexIO MCU Interface LCD Driver

12.6.6.6 enum _flexio_mculcd_dma_enable

Enumerator
kFLEXIO_MCULCD_TxDmaEnable Tx DMA request source.
kFLEXIO_MCULCD_RxDmaEnable Rx DMA request source.

12.6.6.7 enum flexio_mculcd_transfer_mode_t

Enumerator
kFLEXIO_MCULCD_ReadArray Read data into an array.
kFLEXIO_MCULCD_WriteArray Write data from an array.
kFLEXIO_MCULCD_WriteSameValue Write the same value many times.

12.6.7 Function Documentation

12.6.7.1 status_t FLEXIO_MCULCD_Init ( FLEXIO_MCULCD_Type ∗ base,


flexio_mculcd_config_t ∗ config, uint32_t srcClock_Hz )

The configuration structure can be filled by the user, or be set with default values by the FLEXIO_MCU-
LCD_GetDefaultConfig.
Parameters

base Pointer to the FLEXIO_MCULCD_Type structure.


config Pointer to the flexio_mculcd_config_t structure.
srcClock_Hz FlexIO source clock in Hz.

Return values

kStatus_Success Initialization success.


kStatus_InvalidArgument Initialization failed because of invalid argument.

12.6.7.2 void FLEXIO_MCULCD_Deinit ( FLEXIO_MCULCD_Type ∗ base )

Parameters

MCUXpresso SDK API Reference Manual


NXP Semiconductors 239
FlexIO MCU Interface LCD Driver

base Pointer to the FLEXIO_MCULCD_Type.

12.6.7.3 void FLEXIO_MCULCD_GetDefaultConfig ( flexio_mculcd_config_t ∗ config )

The default configuration value is:

* config->enable = true;
* config->enableInDoze = false;
* config->enableInDebug = true;
* config->enableFastAccess = true;
* config->baudRate_Bps = 96000000U;
*

Parameters

Config Pointer to the flexio_mculcd_config_t structure.

12.6.7.4 uint32_t FLEXIO_MCULCD_GetStatusFlags ( FLEXIO_MCULCD_Type ∗ base )

Parameters

base Pointer to the FLEXIO_MCULCD_Type structure.

Returns
status flag; OR’ed value or the _flexio_mculcd_status_flags.

Note
Don’t use this function with DMA APIs.

12.6.7.5 void FLEXIO_MCULCD_ClearStatusFlags ( FLEXIO_MCULCD_Type ∗ base,


uint32_t mask )

Parameters

MCUXpresso SDK API Reference Manual


240 NXP Semiconductors
FlexIO MCU Interface LCD Driver

base Pointer to the FLEXIO_MCULCD_Type structure.


mask Status to clear, it is the OR’ed value of _flexio_mculcd_status_flags.

Note
Don’t use this function with DMA APIs.

12.6.7.6 void FLEXIO_MCULCD_EnableInterrupts ( FLEXIO_MCULCD_Type ∗ base,


uint32_t mask )

This function enables the FlexIO MCULCD interrupt.


Parameters

base Pointer to the FLEXIO_MCULCD_Type structure.


mask Interrupts to enable, it is the OR’ed value of _flexio_mculcd_interrupt_enable.

12.6.7.7 void FLEXIO_MCULCD_DisableInterrupts ( FLEXIO_MCULCD_Type ∗ base,


uint32_t mask )

This function disables the FlexIO MCULCD interrupt.


Parameters

base Pointer to the FLEXIO_MCULCD_Type structure.


mask Interrupts to disable, it is the OR’ed value of _flexio_mculcd_interrupt_enable.

12.6.7.8 static void FLEXIO_MCULCD_EnableTxDMA ( FLEXIO_MCULCD_Type ∗ base,


bool enable ) [inline], [static]

Parameters

base Pointer to the FLEXIO_MCULCD_Type structure.


mask MCULCD DMA source.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 241
FlexIO MCU Interface LCD Driver

enable True means enable DMA, false means disable DMA.

12.6.7.9 static void FLEXIO_MCULCD_EnableRxDMA ( FLEXIO_MCULCD_Type ∗ base,


bool enable ) [inline], [static]

Parameters

base Pointer to the FLEXIO_MCULCD_Type structure.


mask MCULCD DMA source.
enable True means enable DMA, false means disable DMA.

12.6.7.10 static uint32_t FLEXIO_MCULCD_GetTxDataRegisterAddress (


FLEXIO_MCULCD_Type ∗ base ) [inline], [static]

This function returns the MCULCD data register address, which is mainly used by DMA/eDMA.
Parameters

base Pointer to the FLEXIO_MCULCD_Type structure.

Returns
FlexIO MCULCD transmit data register address.

12.6.7.11 static uint32_t FLEXIO_MCULCD_GetRxDataRegisterAddress (


FLEXIO_MCULCD_Type ∗ base ) [inline], [static]

This function returns the MCULCD data register address, which is mainly used by DMA/eDMA.
Parameters

base Pointer to the FLEXIO_MCULCD_Type structure.

Returns
FlexIO MCULCD receive data register address.

12.6.7.12 status_t FLEXIO_MCULCD_SetBaudRate ( FLEXIO_MCULCD_Type ∗ base,


uint32_t baudRate_Bps, uint32_t srcClock_Hz )

MCUXpresso SDK API Reference Manual


242 NXP Semiconductors
FlexIO MCU Interface LCD Driver

Parameters

base Pointer to the FLEXIO_MCULCD_Type structure.


baudRate_Bps Desired baud rate.
srcClock_Hz FLEXIO clock frequency in Hz.

Return values

kStatus_Success Set successfully.


kStatus_InvalidArgument Could not set the baud rate.

12.6.7.13 void FLEXIO_MCULCD_SetSingleBeatWriteConfig ( FLEXIO_MCULCD_Type


∗ base )

At the begining multiple beats write operation, the FLEXIO MCULCD is configured to multiple beats
write mode using this function. After write operation, the configuration is cleared by FLEXIO_MCULC-
D_ClearSingleBeatWriteConfig.
Parameters

base Pointer to the FLEXIO_MCULCD_Type.

Note
This is an internal used function, upper layer should not use.

12.6.7.14 void FLEXIO_MCULCD_ClearSingleBeatWriteConfig ( FLEXIO_MCULCD_-


Type ∗ base )

Clear the write configuration set by FLEXIO_MCULCD_SetSingleBeatWriteConfig.


Parameters

base Pointer to the FLEXIO_MCULCD_Type.

Note
This is an internal used function, upper layer should not use.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 243
FlexIO MCU Interface LCD Driver

12.6.7.15 void FLEXIO_MCULCD_SetSingleBeatReadConfig ( FLEXIO_MCULCD_Type


∗ base )

At the begining or multiple beats read operation, the FLEXIO MCULCD is configured to multiple beats
read mode using this function. After read operation, the configuration is cleared by FLEXIO_MCULCD-
_ClearSingleBeatReadConfig.
Parameters

base Pointer to the FLEXIO_MCULCD_Type.

Note
This is an internal used function, upper layer should not use.

12.6.7.16 void FLEXIO_MCULCD_ClearSingleBeatReadConfig ( FLEXIO_MCULCD_-


Type ∗ base )

Clear the read configuration set by FLEXIO_MCULCD_SetSingleBeatReadConfig.


Parameters

base Pointer to the FLEXIO_MCULCD_Type.

Note
This is an internal used function, upper layer should not use.

12.6.7.17 void FLEXIO_MCULCD_SetMultiBeatsWriteConfig ( FLEXIO_MCULCD_Type


∗ base )

At the begining multiple beats write operation, the FLEXIO MCULCD is configured to multiple beats
write mode using this function. After write operation, the configuration is cleared by FLEXIO_MCULC-
D_ClearMultBeatsWriteConfig.
Parameters

base Pointer to the FLEXIO_MCULCD_Type.

Note
This is an internal used function, upper layer should not use.

MCUXpresso SDK API Reference Manual


244 NXP Semiconductors
FlexIO MCU Interface LCD Driver

12.6.7.18 void FLEXIO_MCULCD_ClearMultiBeatsWriteConfig ( FLEXIO_MCULCD_-


Type ∗ base )

Clear the write configuration set by FLEXIO_MCULCD_SetMultBeatsWriteConfig.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 245
FlexIO MCU Interface LCD Driver

Parameters

base Pointer to the FLEXIO_MCULCD_Type.

Note
This is an internal used function, upper layer should not use.

12.6.7.19 void FLEXIO_MCULCD_SetMultiBeatsReadConfig ( FLEXIO_MCULCD_Type


∗ base )

At the begining or multiple beats read operation, the FLEXIO MCULCD is configured to multiple beats
read mode using this function. After read operation, the configuration is cleared by FLEXIO_MCULCD-
_ClearMultBeatsReadConfig.
Parameters

base Pointer to the FLEXIO_MCULCD_Type.

Note
This is an internal used function, upper layer should not use.

12.6.7.20 void FLEXIO_MCULCD_ClearMultiBeatsReadConfig ( FLEXIO_MCULCD_-


Type ∗ base )

Clear the read configuration set by FLEXIO_MCULCD_SetMultBeatsReadConfig.


Parameters

base Pointer to the FLEXIO_MCULCD_Type.

Note
This is an internal used function, upper layer should not use.

12.6.7.21 static void FLEXIO_MCULCD_Enable ( FLEXIO_MCULCD_Type ∗ base, bool


enable ) [inline], [static]

MCUXpresso SDK API Reference Manual


246 NXP Semiconductors
FlexIO MCU Interface LCD Driver

Parameters

base Pointer to the FLEXIO_MCULCD_Type.


enable True to enable, false does not have any effect.

12.6.7.22 uint32_t FLEXIO_MCULCD_ReadData ( FLEXIO_MCULCD_Type ∗ base )

Read data from the RX shift buffer directly, it does no check whether the buffer is empty or not.
If the data bus width is 8-bit:

* uint8_t value;
* value = (uint8_t)FLEXIO_MCULCD_ReadData(base);
*

If the data bus width is 16-bit:

* uint16_t value;
* value = (uint16_t)FLEXIO_MCULCD_ReadData(base);
*

Note
This function returns the RX shifter buffer value (32-bit) directly. The return value should be con-
verted according to data bus width.

Parameters

base Pointer to the FLEXIO_MCULCD_Type structure.

Returns
The data read out.

Note
Don’t use this function with DMA APIs.

12.6.7.23 static void FLEXIO_MCULCD_WriteData ( FLEXIO_MCULCD_Type ∗ base,


uint32_t data ) [inline], [static]

Write data into the TX shift buffer directly, it does no check whether the buffer is full or not.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 247
FlexIO MCU Interface LCD Driver

Parameters

base Pointer to the FLEXIO_MCULCD_Type structure.


data The data to write.

Note
Don’t use this function with DMA APIs.

12.6.7.24 static void FLEXIO_MCULCD_StartTransfer ( FLEXIO_MCULCD_Type ∗ base


) [inline], [static]

Parameters

base Pointer to the FLEXIO_MCULCD_Type structure.

12.6.7.25 static void FLEXIO_MCULCD_StopTransfer ( FLEXIO_MCULCD_Type ∗ base


) [inline], [static]

Parameters

base Pointer to the FLEXIO_MCULCD_Type structure.

12.6.7.26 void FLEXIO_MCULCD_WaitTransmitComplete ( void )

Currently there is no effective method to wait for the data send out from the shiter, so here use a while
loop to wait.

Note
This is an internal used function.

12.6.7.27 void FLEXIO_MCULCD_WriteCommandBlocking ( FLEXIO_MCULCD_Type ∗


base, uint32_t command )

This function sends the command and returns when the command has been sent out.

MCUXpresso SDK API Reference Manual


248 NXP Semiconductors
FlexIO MCU Interface LCD Driver

Parameters

base Pointer to the FLEXIO_MCULCD_Type structure.


command The command to send.

12.6.7.28 void FLEXIO_MCULCD_WriteDataArrayBlocking ( FLEXIO_MCULCD_Type ∗


base, void ∗ data, size_t size )

This function sends the data array and returns when the data sent out.
Parameters

base Pointer to the FLEXIO_MCULCD_Type structure.


data The data array to send.
size How many bytes to write.

12.6.7.29 void FLEXIO_MCULCD_ReadDataArrayBlocking ( FLEXIO_MCULCD_Type ∗


base, void ∗ data, size_t size )

This function reads the data into array and returns when the data read finished.
Parameters

base Pointer to the FLEXIO_MCULCD_Type structure.


data The array to save the data.
size How many bytes to read.

12.6.7.30 void FLEXIO_MCULCD_WriteSameValueBlocking ( FLEXIO_MCULCD_Type ∗


base, uint32_t sameValue, size_t size )

This function sends the same value many times. It could be used to clear the LCD screen. If the data bus
width is 8, this function will send LSB 8 bits of sameValue for size times. If the data bus is 16, this
function will send LSB 16 bits of sameValue for size / 2 times.
Parameters

MCUXpresso SDK API Reference Manual


NXP Semiconductors 249
FlexIO MCU Interface LCD Driver

base Pointer to the FLEXIO_MCULCD_Type structure.


sameValue The same value to send.
size How many bytes to send.

12.6.7.31 void FLEXIO_MCULCD_TransferBlocking ( FLEXIO_MCULCD_Type ∗ base,


flexio_mculcd_transfer_t ∗ xfer )
Note
The API does not return until the transfer finished.

Parameters

base pointer to FLEXIO_MCULCD_Type structure.


xfer pointer to flexio_mculcd_transfer_t structure.

12.6.7.32 status_t FLEXIO_MCULCD_TransferCreateHandle ( FLEXIO_MCULCD_Type


∗ base, flexio_mculcd_handle_t ∗ handle, flexio_mculcd_transfer_callback_t
callback, void ∗ userData )

Parameters

base Pointer to the FLEXIO_MCULCD_Type structure.


handle Pointer to the flexio_mculcd_handle_t structure to store the transfer state.
callback The callback function.
userData The parameter of the callback function.

Return values

kStatus_Success Successfully create the handle.


kStatus_OutOfRange The FlexIO type/handle/ISR table out of range.

12.6.7.33 status_t FLEXIO_MCULCD_TransferNonBlocking ( FLEXIO_MCULCD_Type ∗


base, flexio_mculcd_handle_t ∗ handle, flexio_mculcd_transfer_t ∗ xfer )

This function sends data using IRQ. This is a non-blocking function, which returns right away. When all
data is sent out/received, the callback function is called.

MCUXpresso SDK API Reference Manual


250 NXP Semiconductors
FlexIO MCU Interface LCD Driver

Parameters

base Pointer to the FLEXIO_MCULCD_Type structure.


handle Pointer to the flexio_mculcd_handle_t structure to store the transfer state.
xfer FlexIO MCULCD transfer structure. See flexio_mculcd_transfer_t.

Return values

kStatus_Success Successfully start a transfer.


kStatus_InvalidArgument Input argument is invalid.
kStatus_FLEXIO_MCUL- MCULCD is busy with another transfer.
CD_Busy

12.6.7.34 void FLEXIO_MCULCD_TransferAbort ( FLEXIO_MCULCD_Type ∗ base,


flexio_mculcd_handle_t ∗ handle )

Parameters

base Pointer to the FLEXIO_MCULCD_Type structure.


handle Pointer to the flexio_mculcd_handle_t structure to store the transfer state.

12.6.7.35 status_t FLEXIO_MCULCD_TransferGetCount ( FLEXIO_MCULCD_Type ∗


base, flexio_mculcd_handle_t ∗ handle, size_t ∗ count )

Parameters

base Pointer to the FLEXIO_MCULCD_Type structure.


handle Pointer to the flexio_mculcd_handle_t structure to store the transfer state.
count How many bytes transferred so far by the non-blocking transaction.

Return values

kStatus_Success Get the transferred count Successfully.


kStatus_NoTransferIn- No transfer in process.
Progress

12.6.7.36 void FLEXIO_MCULCD_TransferHandleIRQ ( void ∗ base, void ∗ handle )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 251
FlexIO MCU Interface LCD Driver

Parameters

base Pointer to the FLEXIO_MCULCD_Type structure.


handle Pointer to the flexio_mculcd_handle_t structure to store the transfer state.

MCUXpresso SDK API Reference Manual


252 NXP Semiconductors
FlexIO MCU Interface LCD Driver

12.6.8 FlexIO eDMA MCU Interface LCD Driver

SDK provide eDMA transactional APIs to transfer data using eDMA, the eDMA method is similar with
interrupt transactional method.

12.6.8.1 Overview
Note
eDMA transactional functions use multiple beats method for better performance, in contrast, the
blocking functions and interupt functions use single beat method. The function FLEXIO_MCUL-
CD_ReadData, FLEXIO_MCULCD_WriteData, FLEXIO_MCULCD_GetStatusFlags, and FLEX-
IO_MCULCD_ClearStatusFlags are only used for single beat case, so don’t use these functions to
work together with eDMA functions.

flexio_MCULCD_edma_handle_t handle;
volatile bool completeFlag = false;
edma_handle_t rxEdmaHandle;
edma_handle_t txEdmaHandle;

void flexioLcdCallback(FLEXIO_MCULCD_Type *base, flexio_MCULCD_edma_handle_t *handle,


status_t status, void *userData)
{
if (kStatus_FLEXIO_MCULCD_Idle == status)
{
completeFlag = true;
}
}

void main(void)
{
// Create the edma Handle.
EDMA_CreateHandle(&rxEdmaHandle, DMA0, channel);
EDMA_CreateHandle(&txEdmaHandle, DMA0, channel);

// Configure the DMAMUX.


// ...
// rxEdmaHandle should use the last FlexIO RX shifters as DMA requst source.
// txEdmaHandle should use the first FlexIO TX shifters as DMA requst source.

// Init the FlexIO LCD driver.


FLEXIO_MCULCD_Init(...);

// Create the transactional handle.


FLEXIO_MCULCD_TransferCreateHandleEDMA(&flexioLcdDev, &handle,
flexioLcdCallback, NULL, &txEdmaHandle, &rxEdmaHandle);

xfer.command = command2;
xfer.mode = kFLEXIO_MCULCD_WriteArray;
xfer.dataAddrOrSameValue = (uint32_t)dataToSend;
xfer.dataCount = sizeof(dataToSend);
completeFlag = false;
FLEXIO_MCULCD_TransferEDMA(&flexioLcdDev, &handle, &xfer);

while (!completeFlag)
{
}

xfer.command = command2;
xfer.mode = kFLEXIO_MCULCD_WriteSameValue;

MCUXpresso SDK API Reference Manual


NXP Semiconductors 253
FlexIO MCU Interface LCD Driver

xfer.dataAddrOrSameValue = value;
xfer.dataCount = 1000;
completeFlag = false;
FLEXIO_MCULCD_TransferEDMA(&flexioLcdDev, &handle, &xfer);

while (!completeFlag)
{
}

xfer.command = command3;
xfer.mode = kFLEXIO_MCULCD_ReadArray;
xfer.dataAddrOrSameValue = (uint32_t)dataToReceive;
xfer.dataCount = sizeof(dataToReceive);
completeFlag = false;
FLEXIO_MCULCD_TransferEDMA(&flexioLcdDev, &handle, &xfer);

while (!completeFlag)
{
}
}

Data Structures
• struct flexio_mculcd_edma_handle_t
FlexIO MCULCD eDMA transfer handle, users should not touch the content of the handle. More...

Macros
• #define FSL_FLEXIO_MCULCD_EDMA_DRIVER_VERSION (MAKE_VERSION(2, 0, 2))
FlexIO MCULCD EDMA driver version 2.0.2.

Typedefs
• typedef void(∗ flexio_mculcd_edma_transfer_callback_t )(FLEXIO_MCULCD_Type ∗base, flexio-
_mculcd_edma_handle_t ∗handle, status_t status, void ∗userData)
FlexIO MCULCD master callback for transfer complete.

eDMA Transactional
• status_t FLEXIO_MCULCD_TransferCreateHandleEDMA (FLEXIO_MCULCD_Type ∗base,
flexio_mculcd_edma_handle_t ∗handle, flexio_mculcd_edma_transfer_callback_t callback, void
∗userData, edma_handle_t ∗txDmaHandle, edma_handle_t ∗rxDmaHandle)
Initializes the FLEXO MCULCD master eDMA handle.
• status_t FLEXIO_MCULCD_TransferEDMA (FLEXIO_MCULCD_Type ∗base, flexio_mculcd_-
edma_handle_t ∗handle, flexio_mculcd_transfer_t ∗xfer)
Performs a non-blocking FlexIO MCULCD transfer using eDMA.
• void FLEXIO_MCULCD_TransferAbortEDMA (FLEXIO_MCULCD_Type ∗base, flexio_mculcd-
_edma_handle_t ∗handle)
Aborts a FlexIO MCULCD transfer using eDMA.
• status_t FLEXIO_MCULCD_TransferGetCountEDMA (FLEXIO_MCULCD_Type ∗base, flexio_-
mculcd_edma_handle_t ∗handle, size_t ∗count)

MCUXpresso SDK API Reference Manual


254 NXP Semiconductors
FlexIO MCU Interface LCD Driver

Gets the remaining bytes for FlexIO MCULCD eDMA transfer.

12.6.8.2 Data Structure Documentation

12.6.8.2.1 struct _flexio_mculcd_edma_handle

typedef for flexio_mculcd_edma_handle_t in advance.

Data Fields

• FLEXIO_MCULCD_Type ∗ base
Pointer to the FLEXIO_MCULCD_Type.
• uint8_t txShifterNum
Number of shifters used for TX.
• uint8_t rxShifterNum
Number of shifters used for RX.
• uint32_t minorLoopBytes
eDMA transfer minor loop bytes.
• edma_modulo_t txEdmaModulo
Modulo value for the FlexIO shifter buffer access.
• edma_modulo_t rxEdmaModulo
Modulo value for the FlexIO shifter buffer access.
• uint32_t dataAddrOrSameValue
When sending the same value for many times, this is the value to send.
• size_t dataCount
Total count to be transferred.
• volatile size_t remainingCount
Remaining count still not transfered.
• volatile uint32_t state
FlexIO MCULCD driver internal state.
• edma_handle_t ∗ txDmaHandle
DMA handle for MCULCD TX.
• edma_handle_t ∗ rxDmaHandle
DMA handle for MCULCD RX.
• flexio_mculcd_edma_transfer_callback_t completionCallback
Callback for MCULCD DMA transfer.
• void ∗ userData
User Data for MCULCD DMA callback.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 255
FlexIO MCU Interface LCD Driver

12.6.8.2.1.1 Field Documentation

12.6.8.2.1.1.1 FLEXIO_MCULCD_Type∗ flexio_mculcd_edma_handle_t::base

12.6.8.2.1.1.2 uint8_t flexio_mculcd_edma_handle_t::txShifterNum

12.6.8.2.1.1.3 uint8_t flexio_mculcd_edma_handle_t::rxShifterNum

12.6.8.2.1.1.4 uint32_t flexio_mculcd_edma_handle_t::minorLoopBytes

12.6.8.2.1.1.5 edma_modulo_t flexio_mculcd_edma_handle_t::txEdmaModulo

12.6.8.2.1.1.6 edma_modulo_t flexio_mculcd_edma_handle_t::rxEdmaModulo

12.6.8.2.1.1.7 uint32_t flexio_mculcd_edma_handle_t::dataAddrOrSameValue

When writing or reading array, this is the address of the data array.

12.6.8.2.1.1.8 size_t flexio_mculcd_edma_handle_t::dataCount

12.6.8.2.1.1.9 volatile size_t flexio_mculcd_edma_handle_t::remainingCount

12.6.8.2.1.1.10 volatile uint32_t flexio_mculcd_edma_handle_t::state

12.6.8.3 Macro Definition Documentation

12.6.8.3.1 #define FSL_FLEXIO_MCULCD_EDMA_DRIVER_VERSION (MAKE_VERSION(2, 0, 2))

12.6.8.4 Typedef Documentation

12.6.8.4.1 typedef void(∗ flexio_mculcd_edma_transfer_callback_t)(FLEXIO_MCULCD_Type


∗base, flexio_mculcd_edma_handle_t ∗handle, status_t status, void ∗userData)

When transfer finished, the callback function is called and returns the status as kStatus_FLEXIO_MC-
ULCD_Idle.

12.6.8.5 Function Documentation

12.6.8.5.1 status_t FLEXIO_MCULCD_TransferCreateHandleEDMA ( FLEXIO_MCULCD_Type


∗ base, flexio_mculcd_edma_handle_t ∗ handle, flexio_mculcd_edma_transfer_-
callback_t callback, void ∗ userData, edma_handle_t ∗ txDmaHandle, edma_handle_t
∗ rxDmaHandle )

This function initializes the FLEXO MCULCD master eDMA handle which can be used for other FLEXO
MCULCD transactional APIs. For a specified FLEXO MCULCD instance, call this API once to get the
initialized handle.

MCUXpresso SDK API Reference Manual


256 NXP Semiconductors
FlexIO MCU Interface LCD Driver

Parameters

base Pointer to FLEXIO_MCULCD_Type structure.


handle Pointer to flexio_mculcd_edma_handle_t structure to store the transfer state.
callback MCULCD transfer complete callback, NULL means no callback.
userData callback function parameter.
txDmaHandle User requested eDMA handle for FlexIO MCULCD eDMA TX, the DMA request
source of this handle should be the first of TX shifters.
rxDmaHandle User requested eDMA handle for FlexIO MCULCD eDMA RX, the DMA request
source of this handle should be the last of RX shifters.

Return values

kStatus_Success Successfully create the handle.

12.6.8.5.2 status_t FLEXIO_MCULCD_TransferEDMA ( FLEXIO_MCULCD_Type ∗ base,


flexio_mculcd_edma_handle_t ∗ handle, flexio_mculcd_transfer_t ∗ xfer )

This function returns immediately after transfer initiates. To check whether the transfer is completed, user
could:
1. Use the transfer completed callback;
2. Polling function FLEXIO_MCULCD_GetTransferCountEDMA
Parameters

base pointer to FLEXIO_MCULCD_Type structure.


handle pointer to flexio_mculcd_edma_handle_t structure to store the transfer state.
xfer Pointer to FlexIO MCULCD transfer structure.

Return values

kStatus_Success Successfully start a transfer.


kStatus_InvalidArgument Input argument is invalid.
kStatus_FLEXIO_MCUL- FlexIO MCULCD is not idle, it is running another transfer.
CD_Busy

12.6.8.5.3 void FLEXIO_MCULCD_TransferAbortEDMA ( FLEXIO_MCULCD_Type ∗ base,


flexio_mculcd_edma_handle_t ∗ handle )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 257
FlexIO MCU Interface LCD Driver

Parameters

base pointer to FLEXIO_MCULCD_Type structure.


handle FlexIO MCULCD eDMA handle pointer.

12.6.8.5.4 status_t FLEXIO_MCULCD_TransferGetCountEDMA ( FLEXIO_MCULCD_Type ∗


base, flexio_mculcd_edma_handle_t ∗ handle, size_t ∗ count )

Parameters

base pointer to FLEXIO_MCULCD_Type structure.


handle FlexIO MCULCD eDMA handle pointer.
count Number of count transferred so far by the eDMA transaction.

Return values

kStatus_Success Get the transferred count Successfully.


kStatus_NoTransferIn- No transfer in process.
Progress

MCUXpresso SDK API Reference Manual


258 NXP Semiconductors
FlexIO MCU Interface LCD Driver

12.6.9 FlexIO DMA MCU Interface LCD Driver

12.6.9.1 Overview

Data Structures
• struct flexio_mculcd_dma_handle_t
FlexIO MCULCD DMA transfer handle, users should not touch the content of the handle. More...

Macros
• #define FSL_FLEXIO_MCULCD_DMA_DRIVER_VERSION (MAKE_VERSION(2, 0, 0))
FlexIO MCULCD DMA driver version 2.0.0.

Typedefs
• typedef void(∗ flexio_mculcd_dma_transfer_callback_t )(FLEXIO_MCULCD_Type ∗base, flexio-
_mculcd_dma_handle_t ∗handle, status_t status, void ∗userData)
FlexIO MCULCD master callback for transfer complete.

DMA Transactional
• status_t FLEXIO_MCULCD_TransferCreateHandleDMA (FLEXIO_MCULCD_Type ∗base,
flexio_mculcd_dma_handle_t ∗handle, flexio_mculcd_dma_transfer_callback_t callback, void
∗userData, dma_handle_t ∗txDmaHandle, dma_handle_t ∗rxDmaHandle)
Initializes the FLEXO MCULCD master DMA handle.
• status_t FLEXIO_MCULCD_TransferDMA (FLEXIO_MCULCD_Type ∗base, flexio_mculcd_-
dma_handle_t ∗handle, flexio_mculcd_transfer_t ∗xfer)
Performs a non-blocking FlexIO MCULCD transfer using DMA.
• void FLEXIO_MCULCD_TransferAbortDMA (FLEXIO_MCULCD_Type ∗base, flexio_mculcd_-
dma_handle_t ∗handle)
Aborts a FlexIO MCULCD transfer using DMA.
• status_t FLEXIO_MCULCD_TransferGetCountDMA (FLEXIO_MCULCD_Type ∗base, flexio_-
mculcd_dma_handle_t ∗handle, size_t ∗count)
Gets the remaining bytes for FlexIO MCULCD DMA transfer.

12.6.9.2 Data Structure Documentation

12.6.9.2.1 struct _flexio_mculcd_dma_handle

typedef for flexio_mculcd_dma_handle_t in advance.

Data Fields

• FLEXIO_MCULCD_Type ∗ base

MCUXpresso SDK API Reference Manual


NXP Semiconductors 259
FlexIO MCU Interface LCD Driver

Pointer to the FLEXIO_MCULCD_Type.


• uint8_t txShifterNum
Number of shifters used for TX.
• uint8_t rxShifterNum
Number of shifters used for RX.
• dma_trigger_burst_t txTriggerBurst
Trigger burst setting for TX.
• dma_trigger_burst_t rxTriggerBurst
Trigger burst setting for RX.
• uint32_t burstBytes
DMA transfer bytes per burst.
• uint32_t dataAddrOrSameValue
When sending the same value for many times, this is the value to send.
• size_t dataCount
Total count to be transferred.
• volatile size_t remainingCount
Remaining count still not transfered.
• volatile uint32_t state
FlexIO MCULCD driver internal state.
• dma_handle_t ∗ txDmaHandle
DMA handle for MCULCD TX.
• dma_handle_t ∗ rxDmaHandle
DMA handle for MCULCD RX.
• flexio_mculcd_dma_transfer_callback_t completionCallback
Callback for MCULCD DMA transfer.
• void ∗ userData
User Data for MCULCD DMA callback.

12.6.9.2.1.1 Field Documentation

12.6.9.2.1.1.1 FLEXIO_MCULCD_Type∗ flexio_mculcd_dma_handle_t::base

12.6.9.2.1.1.2 uint8_t flexio_mculcd_dma_handle_t::txShifterNum

12.6.9.2.1.1.3 uint8_t flexio_mculcd_dma_handle_t::rxShifterNum

12.6.9.2.1.1.4 dma_trigger_burst_t flexio_mculcd_dma_handle_t::txTriggerBurst

12.6.9.2.1.1.5 dma_trigger_burst_t flexio_mculcd_dma_handle_t::rxTriggerBurst

12.6.9.2.1.1.6 uint32_t flexio_mculcd_dma_handle_t::burstBytes

12.6.9.2.1.1.7 uint32_t flexio_mculcd_dma_handle_t::dataAddrOrSameValue

When writing or reading array, this is the address of the data array.

MCUXpresso SDK API Reference Manual


260 NXP Semiconductors
FlexIO MCU Interface LCD Driver

12.6.9.2.1.1.8 size_t flexio_mculcd_dma_handle_t::dataCount

12.6.9.2.1.1.9 volatile size_t flexio_mculcd_dma_handle_t::remainingCount

12.6.9.2.1.1.10 volatile uint32_t flexio_mculcd_dma_handle_t::state

12.6.9.3 Macro Definition Documentation

12.6.9.3.1 #define FSL_FLEXIO_MCULCD_DMA_DRIVER_VERSION (MAKE_VERSION(2, 0, 0))

12.6.9.4 Typedef Documentation

12.6.9.4.1 typedef void(∗ flexio_mculcd_dma_transfer_callback_t)(FLEXIO_MCULCD_Type


∗base, flexio_mculcd_dma_handle_t ∗handle, status_t status, void ∗userData)

When transfer finished, the callback function is called and returns the status as kStatus_FLEXIO_MC-
ULCD_Idle.

12.6.9.5 Function Documentation

12.6.9.5.1 status_t FLEXIO_MCULCD_TransferCreateHandleDMA ( FLEXIO_MCULCD_Type ∗


base, flexio_mculcd_dma_handle_t ∗ handle, flexio_mculcd_dma_transfer_callback_t
callback, void ∗ userData, dma_handle_t ∗ txDmaHandle, dma_handle_t ∗
rxDmaHandle )

This function initializes the FLEXO MCULCD master DMA handle which can be used for other FLEXO
MCULCD transactional APIs. For a specified FLEXO MCULCD instance, call this API once to get the
initialized handle.
Parameters

base Pointer to FLEXIO_MCULCD_Type structure.


handle Pointer to flexio_mculcd_dma_handle_t structure to store the transfer state.
callback MCULCD transfer complete callback, NULL means no callback.
userData callback function parameter.
txDmaHandle User requested DMA handle for FlexIO MCULCD DMA TX, the DMA request
source of this handle should be the first of TX shifters.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 261
FlexIO MCU Interface LCD Driver

rxDmaHandle User requested DMA handle for FlexIO MCULCD DMA RX, the DMA request
source of this handle should be the last of RX shifters.

Return values

kStatus_Success Successfully create the handle.

12.6.9.5.2 status_t FLEXIO_MCULCD_TransferDMA ( FLEXIO_MCULCD_Type ∗ base,


flexio_mculcd_dma_handle_t ∗ handle, flexio_mculcd_transfer_t ∗ xfer )

This function returns immediately after transfer initiates. To check whether the transfer is completed, user
could:
1. Use the transfer completed callback;
2. Polling function FLEXIO_MCULCD_GetTransferCountDMA
Parameters

base pointer to FLEXIO_MCULCD_Type structure.


handle pointer to flexio_mculcd_dma_handle_t structure to store the transfer state.
xfer Pointer to FlexIO MCULCD transfer structure.

Return values

kStatus_Success Successfully start a transfer.


kStatus_InvalidArgument Input argument is invalid.
kStatus_FLEXIO_MCUL- FlexIO MCULCD is not idle, it is running another transfer.
CD_Busy

12.6.9.5.3 void FLEXIO_MCULCD_TransferAbortDMA ( FLEXIO_MCULCD_Type ∗ base,


flexio_mculcd_dma_handle_t ∗ handle )

Parameters

base pointer to FLEXIO_MCULCD_Type structure.


handle FlexIO MCULCD DMA handle pointer.

12.6.9.5.4 status_t FLEXIO_MCULCD_TransferGetCountDMA ( FLEXIO_MCULCD_Type ∗ base,


flexio_mculcd_dma_handle_t ∗ handle, size_t ∗ count )

MCUXpresso SDK API Reference Manual


262 NXP Semiconductors
FlexIO MCU Interface LCD Driver

Parameters

base pointer to FLEXIO_MCULCD_Type structure.


handle FlexIO MCULCD DMA handle pointer.
count Number of count transferred so far by the DMA transaction.

Return values

kStatus_Success Get the transferred count Successfully.


kStatus_NoTransferIn- No transfer in process.
Progress

MCUXpresso SDK API Reference Manual


NXP Semiconductors 263
FlexIO MCU Interface LCD Driver

12.6.10 FlexIO SMARTDMA MCU Interface LCD Driver

12.6.10.1 Overview

Data Structures
• struct flexio_mculcd_smartdma_handle_t
FlexIO MCULCD SMARTDMA transfer handle, users should not touch the content of the handle. More...
• struct flexio_mculcd_smartdma_config_t
FlexIO MCULCD SMARTDMA configuration. More...

Macros
• #define FSL_FLEXIO_MCULCD_SMARTDMA_DRIVER_VERSION (MAKE_VERSION(2, 0,
0))
FlexIO MCULCD SMARTDMA driver version 2.0.0.
• #define FLEXIO_MCULCD_SMARTDMA_TX_LEN_ALIGN 64U
SMARTDMA transfer size should be multiple of 64 bytes.
• #define FLEXIO_MCULCD_SMARTDMA_TX_ADDR_ALIGN 4U
SMARTDMA transfer memory address should be 4 byte aligned.

Typedefs
• typedef void(∗ flexio_mculcd_smartdma_transfer_callback_t )(FLEXIO_MCULCD_Type ∗base,
flexio_mculcd_smartdma_handle_t ∗handle, status_t status, void ∗userData)
FlexIO MCULCD master callback for transfer complete.

SMARTDMA Transactional
• status_t FLEXIO_MCULCD_TransferCreateHandleSMARTDMA (FLEXIO_MCULCD_Type
∗base, flexio_mculcd_smartdma_handle_t ∗handle, const flexio_mculcd_smartdma_config_-
t ∗config, flexio_mculcd_smartdma_transfer_callback_t callback, void ∗userData)
Initializes the FLEXO MCULCD master SMARTDMA handle.
• status_t FLEXIO_MCULCD_TransferSMARTDMA (FLEXIO_MCULCD_Type ∗base, flexio_-
mculcd_smartdma_handle_t ∗handle, flexio_mculcd_transfer_t ∗xfer)
Performs a non-blocking FlexIO MCULCD transfer using SMARTDMA.
• void FLEXIO_MCULCD_TransferAbortSMARTDMA (FLEXIO_MCULCD_Type ∗base, flexio_-
mculcd_smartdma_handle_t ∗handle)
Aborts a FlexIO MCULCD transfer using SMARTDMA.
• status_t FLEXIO_MCULCD_TransferGetCountSMARTDMA (FLEXIO_MCULCD_Type ∗base,
flexio_mculcd_smartdma_handle_t ∗handle, size_t ∗count)
Gets the remaining bytes for FlexIO MCULCD SMARTDMA transfer.

MCUXpresso SDK API Reference Manual


264 NXP Semiconductors
FlexIO MCU Interface LCD Driver

12.6.10.2 Data Structure Documentation

12.6.10.2.1 struct _flexio_mculcd_smartdma_handle

typedef for flexio_mculcd_smartdma_handle_t in advance.

Data Fields

• FLEXIO_MCULCD_Type ∗ base
Pointer to the FLEXIO_MCULCD_Type.
• size_t dataCount
Total count to be transferred.
• uint32_t dataAddrOrSameValue
When sending the same value for many times, this is the value to send.
• size_t dataCountUsingEzh
Data transfered using SMARTDMA.
• volatile size_t remainingCount
Remaining count to transfer.
• volatile uint32_t state
FlexIO MCULCD driver internal state.
• uint8_t smartdmaApi
The SMARTDMA API used during transfer.
• bool needColorConvert
Need color convert or not.
• uint8_t blockingXferBuffer [FLEXIO_MCULCD_SMARTDMA_TX_LEN_ALIGN ∗3/2]
Used for blocking method color space convet.
• flexio_mculcd_smartdma_transfer_callback_t completionCallback
Callback for MCULCD SMARTDMA transfer.
• void ∗ userData
User Data for MCULCD SMARTDMA callback.

12.6.10.2.1.1 Field Documentation

12.6.10.2.1.1.1 FLEXIO_MCULCD_Type∗ flexio_mculcd_smartdma_handle_t::base

12.6.10.2.1.1.2 size_t flexio_mculcd_smartdma_handle_t::dataCount

12.6.10.2.1.1.3 uint32_t flexio_mculcd_smartdma_handle_t::dataAddrOrSameValue

When writing or reading array, this is the address of the data array.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 265
FlexIO MCU Interface LCD Driver

12.6.10.2.1.1.4 size_t flexio_mculcd_smartdma_handle_t::dataCountUsingEzh

12.6.10.2.1.1.5 volatile size_t flexio_mculcd_smartdma_handle_t::remainingCount

12.6.10.2.1.1.6 volatile uint32_t flexio_mculcd_smartdma_handle_t::state

12.6.10.2.1.1.7 uint8_t flexio_mculcd_smartdma_handle_t::smartdmaApi

12.6.10.2.1.1.8 bool flexio_mculcd_smartdma_handle_t::needColorConvert

12.6.10.2.1.1.9 uint8_t flexio_mculcd_smartdma_handle_t::blockingXferBuffer[FLEXIO_MCUL-


CD_SMARTDMA_TX_LEN_ALIGN ∗3/2]

12.6.10.2.2 struct flexio_mculcd_smartdma_config_t

Data Fields

• flexio_mculcd_pixel_format_t inputPixelFormat
The pixel format in the frame buffer.
• flexio_mculcd_pixel_format_t outputPixelFormat
The pixel format on the 8080/68k bus.

12.6.10.2.2.1 Field Documentation

12.6.10.2.2.1.1 flexio_mculcd_pixel_format_t flexio_mculcd_smartdma_config_t::inputPixel-


Format

12.6.10.2.2.1.2 flexio_mculcd_pixel_format_t flexio_mculcd_smartdma_config_t::outputPixel-


Format

12.6.10.3 Macro Definition Documentation

12.6.10.3.1 #define FSL_FLEXIO_MCULCD_SMARTDMA_DRIVER_VERSION (MAKE_VERSIO-


N(2, 0, 0))

12.6.10.3.2 #define FLEXIO_MCULCD_SMARTDMA_TX_LEN_ALIGN 64U

12.6.10.3.3 #define FLEXIO_MCULCD_SMARTDMA_TX_ADDR_ALIGN 4U

12.6.10.4 Typedef Documentation

12.6.10.4.1 typedef void(∗ flexio_mculcd_smartdma_transfer_callback_t)(FLEXIO_MCULCD-


_Type ∗base, flexio_mculcd_smartdma_handle_t ∗handle, status_t status, void
∗userData)

When transfer finished, the callback function is called and returns the status as kStatus_FLEXIO_MC-
ULCD_Idle.

MCUXpresso SDK API Reference Manual


266 NXP Semiconductors
FlexIO MCU Interface LCD Driver

12.6.10.5 Function Documentation

12.6.10.5.1 status_t FLEXIO_MCULCD_TransferCreateHandleSMARTDMA (


FLEXIO_MCULCD_Type ∗ base, flexio_mculcd_smartdma_handle_t
∗ handle, const flexio_mculcd_smartdma_config_t ∗ config, flexio-
_mculcd_smartdma_transfer_callback_t callback, void ∗ userData
)

This function initializes the FLEXO MCULCD master SMARTDMA handle which can be used for other
FLEXO MCULCD transactional APIs. For a specified FLEXO MCULCD instance, call this API once to
get the initialized handle.
Parameters

base Pointer to FLEXIO_MCULCD_Type structure.


handle Pointer to flexio_mculcd_smartdma_handle_t structure to store the transfer state.
config Pointer to the configuration.
callback MCULCD transfer complete callback, NULL means no callback.
userData callback function parameter.

Return values

kStatus_Success Successfully create the handle.

12.6.10.5.2 status_t FLEXIO_MCULCD_TransferSMARTDMA ( FLEXIO_MCULCD_Type ∗ base,


flexio_mculcd_smartdma_handle_t ∗ handle, flexio_mculcd_transfer_t ∗ xfer )

This function returns immediately after transfer initiates. Use the callback function to check whether the
transfer is completed.
Parameters

base pointer to FLEXIO_MCULCD_Type structure.


handle pointer to flexio_mculcd_smartdma_handle_t structure to store the transfer state.
xfer Pointer to FlexIO MCULCD transfer structure.

Return values

MCUXpresso SDK API Reference Manual


NXP Semiconductors 267
FlexIO MCU Interface LCD Driver

kStatus_Success Successfully start a transfer.


kStatus_InvalidArgument Input argument is invalid.
kStatus_FLEXIO_MCUL- FlexIO MCULCD is not idle, it is running another transfer.
CD_Busy

12.6.10.5.3 void FLEXIO_MCULCD_TransferAbortSMARTDMA ( FLEXIO_MCULCD_Type ∗


base, flexio_mculcd_smartdma_handle_t ∗ handle )

Parameters

base pointer to FLEXIO_MCULCD_Type structure.


handle FlexIO MCULCD SMARTDMA handle pointer.

12.6.10.5.4 status_t FLEXIO_MCULCD_TransferGetCountSMARTDMA ( FLEXIO_MCUL-


CD_Type ∗ base, flexio_mculcd_smartdma_handle_t ∗ handle, size_t ∗ count
)

Parameters

base pointer to FLEXIO_MCULCD_Type structure.


handle FlexIO MCULCD SMARTDMA handle pointer.
count Number of count transferred so far by the SMARTDMA transaction.

Return values

kStatus_Success Get the transferred count Successfully.


kStatus_NoTransferIn- No transfer in process.
Progress

MCUXpresso SDK API Reference Manual


268 NXP Semiconductors
FlexIO SPI Driver

12.7 FlexIO SPI Driver


12.7.1 Overview

The MCUXpresso SDK provides a peripheral driver for an SPI function using the Flexible I/O module of
MCUXpresso SDK devices.
FlexIO SPI driver includes functional APIs and transactional APIs.
Functional APIs target low-level APIs. Functional APIs can be used for FlexIO SPI initializa-
tion/configuration/operation for optimization/customization purpose. Using the functional API requires
the knowledge of the FlexIO SPI peripheral and how to organize functional APIs to meet the application
requirements. All functional API use the FLEXIO_SPI_Type ∗base as the first parameter. FlexIO SPI
functional operation groups provide the functional API set.
Transactional APIs target high-level APIs. Transactional APIs can be used to enable the peripheral and
also in the application if the code size and performance of transactional APIs can satisfy requirements.
If the code size and performance are critical requirements, see the transactional API implementation and
write custom code. All transactional APIs use the flexio_spi_master_handle_t/flexio_spi_slave_handle_t
as the second parameter. Initialize the handle by calling the FLEXIO_SPI_MasterTransferCreateHandle()
or FLEXIO_SPI_SlaveTransferCreateHandle() API.
Transactional APIs support asynchronous transfer. This means that the functions FLEXIO_SPI_Master-
TransferNonBlocking()/FLEXIO_SPI_SlaveTransferNonBlocking() set up an interrupt for data transfer.
When the transfer is complete, the upper layer is notified through a callback function with the kStatus_F-
LEXIO_SPI_Idle status.
Note that the FlexIO SPI slave driver only supports discontinuous PCS access, which is a limitation. The
FlexIO SPI slave driver can support continuous PCS, but the slave cannot adapt discontinuous and contin-
uous PCS automatically. Users can change the timer disable mode in FLEXIO_SPI_SlaveInit manually,
from kFLEXIO_TimerDisableOnTimerCompare to kFLEXIO_TimerDisableNever to enable a discontin-
uous PCS access. Only CPHA = 0 is supported.

12.7.2 Typical use case

12.7.2.1 FlexIO SPI send/receive using an interrupt method


flexio_spi_master_handle_t g_spiHandle;
FLEXIO_SPI_Type spiDev;
volatile bool txFinished;
static uint8_t srcBuff[BUFFER_SIZE];
static uint8_t destBuff[BUFFER_SIZE];

void FLEXIO_SPI_MasterUserCallback(FLEXIO_SPI_Type *base, flexio_spi_master_handle_t *handle


, status_t status, void *userData)
{
userData = userData;

if (kStatus_FLEXIO_SPI_Idle == status)
{
txFinished = true;
}

MCUXpresso SDK API Reference Manual


NXP Semiconductors 269
FlexIO SPI Driver

void main(void)
{
//...
flexio_spi_transfer_t xfer = {0};
flexio_spi_master_config_t userConfig;

FLEXIO_SPI_MasterGetDefaultConfig(&userConfig);
userConfig.baudRate_Bps = 500000U;

spiDev.flexioBase = BOARD_FLEXIO_BASE;
spiDev.SDOPinIndex = FLEXIO_SPI_MOSI_PIN;
spiDev.SDIPinIndex = FLEXIO_SPI_MISO_PIN;
spiDev.SCKPinIndex = FLEXIO_SPI_SCK_PIN;
spiDev.CSnPinIndex = FLEXIO_SPI_CSn_PIN;
spiDev.shifterIndex[0] = 0U;
spiDev.shifterIndex[1] = 1U;
spiDev.timerIndex[0] = 0U;
spiDev.timerIndex[1] = 1U;

FLEXIO_SPI_MasterInit(&spiDev, &userConfig, FLEXIO_CLOCK_FREQUENCY);

xfer.txData = srcBuff;
xfer.rxData = destBuff;
xfer.dataSize = BUFFER_SIZE;
xfer.flags = kFLEXIO_SPI_8bitMsb;
FLEXIO_SPI_MasterTransferCreateHandle(&spiDev, &g_spiHandle,
FLEXIO_SPI_MasterUserCallback, NULL);
FLEXIO_SPI_MasterTransferNonBlocking(&spiDev, &g_spiHandle, &xfer);

// Send finished.
while (!txFinished)
{
}

// ...
}

12.7.2.2 FlexIO_SPI Send/Receive in DMA way


dma_handle_t g_spiTxDmaHandle;
dma_handle_t g_spiRxDmaHandle;
flexio_spi_master_handle_t g_spiHandle;
FLEXIO_SPI_Type spiDev;
volatile bool txFinished;
static uint8_t srcBuff[BUFFER_SIZE];
static uint8_t destBuff[BUFFER_SIZE];
void FLEXIO_SPI_MasterUserCallback(FLEXIO_SPI_Type *base, flexio_spi_master_dma_handle_t
*handle, status_t status, void *userData)
{
userData = userData;

if (kStatus_FLEXIO_SPI_Idle == status)
{
txFinished = true;
}
}

void main(void)
{
flexio_spi_transfer_t xfer = {0};
flexio_spi_master_config_t userConfig;

FLEXIO_SPI_MasterGetDefaultConfig(&userConfig);

MCUXpresso SDK API Reference Manual


270 NXP Semiconductors
FlexIO SPI Driver

userConfig.baudRate_Bps = 500000U;

spiDev.flexioBase = BOARD_FLEXIO_BASE;
spiDev.SDOPinIndex = FLEXIO_SPI_MOSI_PIN;
spiDev.SDIPinIndex = FLEXIO_SPI_MISO_PIN;
spiDev.SCKPinIndex = FLEXIO_SPI_SCK_PIN;
spiDev.CSnPinIndex = FLEXIO_SPI_CSn_PIN;
spiDev.shifterIndex[0] = 0U;
spiDev.shifterIndex[1] = 1U;
spiDev.timerIndex[0] = 0U;
spiDev.timerIndex[1] = 1U;

/* Init DMAMUX. */
DMAMUX_Init(EXAMPLE_FLEXIO_SPI_DMAMUX_BASEADDR)

/* Init the DMA/EDMA module */


#if defined(FSL_FEATURE_SOC_DMA_COUNT) && FSL_FEATURE_SOC_DMA_COUNT > 0U
DMA_Init(EXAMPLE_FLEXIO_SPI_DMA_BASEADDR);
DMA_CreateHandle(&txHandle, EXAMPLE_FLEXIO_SPI_DMA_BASEADDR,
FLEXIO_SPI_TX_DMA_CHANNEL);
DMA_CreateHandle(&rxHandle, EXAMPLE_FLEXIO_SPI_DMA_BASEADDR,
FLEXIO_SPI_RX_DMA_CHANNEL);
#endif /* FSL_FEATURE_SOC_DMA_COUNT */

#if defined(FSL_FEATURE_SOC_EDMA_COUNT) && FSL_FEATURE_SOC_EDMA_COUNT > 0U


edma_config_t edmaConfig;

EDMA_GetDefaultConfig(&edmaConfig);
EDMA_Init(EXAMPLE_FLEXIO_SPI_DMA_BASEADDR, &edmaConfig);
EDMA_CreateHandle(&txHandle, EXAMPLE_FLEXIO_SPI_DMA_BASEADDR, FLEXIO_SPI_TX_DMA_CHANNEL);
EDMA_CreateHandle(&rxHandle, EXAMPLE_FLEXIO_SPI_DMA_BASEADDR, FLEXIO_SPI_RX_DMA_CHANNEL);
#endif /* FSL_FEATURE_SOC_EDMA_COUNT */

dma_request_source_tx = (dma_request_source_t)(FLEXIO_DMA_REQUEST_BASE + spiDev.


shifterIndex[0]);
dma_request_source_rx = (dma_request_source_t)(FLEXIO_DMA_REQUEST_BASE + spiDev.
shifterIndex[1]);

/* Requests DMA channels for transmit and receive. */


DMAMUX_SetSource(EXAMPLE_FLEXIO_SPI_DMAMUX_BASEADDR, FLEXIO_SPI_TX_DMA_CHANNEL, (
dma_request_source_t)dma_request_source_tx);
DMAMUX_SetSource(EXAMPLE_FLEXIO_SPI_DMAMUX_BASEADDR, FLEXIO_SPI_RX_DMA_CHANNEL, (
dma_request_source_t)dma_request_source_rx);
DMAMUX_EnableChannel(EXAMPLE_FLEXIO_SPI_DMAMUX_BASEADDR,
FLEXIO_SPI_TX_DMA_CHANNEL);
DMAMUX_EnableChannel(EXAMPLE_FLEXIO_SPI_DMAMUX_BASEADDR,
FLEXIO_SPI_RX_DMA_CHANNEL);

FLEXIO_SPI_MasterInit(&spiDev, &userConfig, FLEXIO_CLOCK_FREQUENCY);

/* Initializes the buffer. */


for (i = 0; i < BUFFER_SIZE; i++)
{
srcBuff[i] = i;
}

/* Sends to the slave. */


xfer.txData = srcBuff;
xfer.rxData = destBuff;
xfer.dataSize = BUFFER_SIZE;
xfer.flags = kFLEXIO_SPI_8bitMsb;
FLEXIO_SPI_MasterTransferCreateHandleDMA(&spiDev, &
g_spiHandle, FLEXIO_SPI_MasterUserCallback, NULL, &g_spiTxDmaHandle, &g_spiRxDmaHandle);
FLEXIO_SPI_MasterTransferDMA(&spiDev, &g_spiHandle, &xfer);

// Send finished.
while (!txFinished)
{

MCUXpresso SDK API Reference Manual


NXP Semiconductors 271
FlexIO SPI Driver

// ...
}

Modules

• FlexIO DMA SPI Driver


• FlexIO eDMA SPI Driver

Data Structures

• struct FLEXIO_SPI_Type
Define FlexIO SPI access structure typedef. More...
• struct flexio_spi_master_config_t
Define FlexIO SPI master configuration structure. More...
• struct flexio_spi_slave_config_t
Define FlexIO SPI slave configuration structure. More...
• struct flexio_spi_transfer_t
Define FlexIO SPI transfer structure. More...
• struct flexio_spi_master_handle_t
Define FlexIO SPI handle structure. More...

Macros

• #define FLEXIO_SPI_DUMMYDATA (0xFFFFU)


FlexIO SPI dummy transfer data, the data is sent while txData is NULL.

Typedefs

• typedef flexio_spi_master_handle_t flexio_spi_slave_handle_t


Slave handle is the same with master handle.
• typedef void(∗ flexio_spi_master_transfer_callback_t )(FLEXIO_SPI_Type ∗base, flexio_spi_-
master_handle_t ∗handle, status_t status, void ∗userData)
FlexIO SPI master callback for finished transmit.
• typedef void(∗ flexio_spi_slave_transfer_callback_t )(FLEXIO_SPI_Type ∗base, flexio_spi_slave-
_handle_t ∗handle, status_t status, void ∗userData)
FlexIO SPI slave callback for finished transmit.

Enumerations

• enum _flexio_spi_status {
kStatus_FLEXIO_SPI_Busy = MAKE_STATUS(kStatusGroup_FLEXIO_SPI, 1),
kStatus_FLEXIO_SPI_Idle = MAKE_STATUS(kStatusGroup_FLEXIO_SPI, 2),
kStatus_FLEXIO_SPI_Error = MAKE_STATUS(kStatusGroup_FLEXIO_SPI, 3) }

MCUXpresso SDK API Reference Manual


272 NXP Semiconductors
FlexIO SPI Driver

Error codes for the FlexIO SPI driver.


• enum flexio_spi_clock_phase_t {
kFLEXIO_SPI_ClockPhaseFirstEdge = 0x0U,
kFLEXIO_SPI_ClockPhaseSecondEdge = 0x1U }
FlexIO SPI clock phase configuration.
• enum flexio_spi_shift_direction_t {
kFLEXIO_SPI_MsbFirst = 0,
kFLEXIO_SPI_LsbFirst = 1 }
FlexIO SPI data shifter direction options.
• enum flexio_spi_data_bitcount_mode_t {
kFLEXIO_SPI_8BitMode = 0x08U,
kFLEXIO_SPI_16BitMode = 0x10U }
FlexIO SPI data length mode options.
• enum _flexio_spi_interrupt_enable {
kFLEXIO_SPI_TxEmptyInterruptEnable = 0x1U,
kFLEXIO_SPI_RxFullInterruptEnable = 0x2U }
Define FlexIO SPI interrupt mask.
• enum _flexio_spi_status_flags {
kFLEXIO_SPI_TxBufferEmptyFlag = 0x1U,
kFLEXIO_SPI_RxBufferFullFlag = 0x2U }
Define FlexIO SPI status mask.
• enum _flexio_spi_dma_enable {
kFLEXIO_SPI_TxDmaEnable = 0x1U,
kFLEXIO_SPI_RxDmaEnable = 0x2U,
kFLEXIO_SPI_DmaAllEnable = 0x3U }
Define FlexIO SPI DMA mask.
• enum _flexio_spi_transfer_flags {
kFLEXIO_SPI_8bitMsb = 0x1U,
kFLEXIO_SPI_8bitLsb = 0x2U,
kFLEXIO_SPI_16bitMsb = 0x9U,
kFLEXIO_SPI_16bitLsb = 0xaU }
Define FlexIO SPI transfer flags.

Driver version

• #define FSL_FLEXIO_SPI_DRIVER_VERSION (MAKE_VERSION(2, 1, 3))


FlexIO SPI driver version 2.1.3.

FlexIO SPI Configuration

• void FLEXIO_SPI_MasterInit (FLEXIO_SPI_Type ∗base, flexio_spi_master_config_t ∗master-


Config, uint32_t srcClock_Hz)
Ungates the FlexIO clock, resets the FlexIO module, configures the FlexIO SPI master hardware, and
configures the FlexIO SPI with FlexIO SPI master configuration.
• void FLEXIO_SPI_MasterDeinit (FLEXIO_SPI_Type ∗base)
Resets the FlexIO SPI timer and shifter config.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 273
FlexIO SPI Driver

• void FLEXIO_SPI_MasterGetDefaultConfig (flexio_spi_master_config_t ∗masterConfig)


Gets the default configuration to configure the FlexIO SPI master.
• void FLEXIO_SPI_SlaveInit (FLEXIO_SPI_Type ∗base, flexio_spi_slave_config_t ∗slaveConfig)
Ungates the FlexIO clock, resets the FlexIO module, configures the FlexIO SPI slave hardware configura-
tion, and configures the FlexIO SPI with FlexIO SPI slave configuration.
• void FLEXIO_SPI_SlaveDeinit (FLEXIO_SPI_Type ∗base)
Gates the FlexIO clock.
• void FLEXIO_SPI_SlaveGetDefaultConfig (flexio_spi_slave_config_t ∗slaveConfig)
Gets the default configuration to configure the FlexIO SPI slave.

Status

• uint32_t FLEXIO_SPI_GetStatusFlags (FLEXIO_SPI_Type ∗base)


Gets FlexIO SPI status flags.
• void FLEXIO_SPI_ClearStatusFlags (FLEXIO_SPI_Type ∗base, uint32_t mask)
Clears FlexIO SPI status flags.

Interrupts

• void FLEXIO_SPI_EnableInterrupts (FLEXIO_SPI_Type ∗base, uint32_t mask)


Enables the FlexIO SPI interrupt.
• void FLEXIO_SPI_DisableInterrupts (FLEXIO_SPI_Type ∗base, uint32_t mask)
Disables the FlexIO SPI interrupt.

DMA Control

• void FLEXIO_SPI_EnableDMA (FLEXIO_SPI_Type ∗base, uint32_t mask, bool enable)


Enables/disables the FlexIO SPI transmit DMA.
• static uint32_t FLEXIO_SPI_GetTxDataRegisterAddress (FLEXIO_SPI_Type ∗base, flexio_spi_-
shift_direction_t direction)
Gets the FlexIO SPI transmit data register address for MSB first transfer.
• static uint32_t FLEXIO_SPI_GetRxDataRegisterAddress (FLEXIO_SPI_Type ∗base, flexio_spi_-
shift_direction_t direction)
Gets the FlexIO SPI receive data register address for the MSB first transfer.

Bus Operations

• static void FLEXIO_SPI_Enable (FLEXIO_SPI_Type ∗base, bool enable)


Enables/disables the FlexIO SPI module operation.
• void FLEXIO_SPI_MasterSetBaudRate (FLEXIO_SPI_Type ∗base, uint32_t baudRate_Bps,
uint32_t srcClockHz)
Sets baud rate for the FlexIO SPI transfer, which is only used for the master.
• static void FLEXIO_SPI_WriteData (FLEXIO_SPI_Type ∗base, flexio_spi_shift_direction_t direc-
tion, uint16_t data)
Writes one byte of data, which is sent using the MSB method.

MCUXpresso SDK API Reference Manual


274 NXP Semiconductors
FlexIO SPI Driver

• static uint16_t FLEXIO_SPI_ReadData (FLEXIO_SPI_Type ∗base, flexio_spi_shift_direction_t di-


rection)
Reads 8 bit/16 bit data.
• void FLEXIO_SPI_WriteBlocking (FLEXIO_SPI_Type ∗base, flexio_spi_shift_direction_t direc-
tion, const uint8_t ∗buffer, size_t size)
Sends a buffer of data bytes.
• void FLEXIO_SPI_ReadBlocking (FLEXIO_SPI_Type ∗base, flexio_spi_shift_direction_t direc-
tion, uint8_t ∗buffer, size_t size)
Receives a buffer of bytes.
• void FLEXIO_SPI_MasterTransferBlocking (FLEXIO_SPI_Type ∗base, flexio_spi_transfer_t
∗xfer)
Receives a buffer of bytes.

Transactional

• status_t FLEXIO_SPI_MasterTransferCreateHandle (FLEXIO_SPI_Type ∗base, flexio_spi_-


master_handle_t ∗handle, flexio_spi_master_transfer_callback_t callback, void ∗userData)
Initializes the FlexIO SPI Master handle, which is used in transactional functions.
• status_t FLEXIO_SPI_MasterTransferNonBlocking (FLEXIO_SPI_Type ∗base, flexio_spi_master-
_handle_t ∗handle, flexio_spi_transfer_t ∗xfer)
Master transfer data using IRQ.
• void FLEXIO_SPI_MasterTransferAbort (FLEXIO_SPI_Type ∗base, flexio_spi_master_handle_t
∗handle)
Aborts the master data transfer, which used IRQ.
• status_t FLEXIO_SPI_MasterTransferGetCount (FLEXIO_SPI_Type ∗base, flexio_spi_master_-
handle_t ∗handle, size_t ∗count)
Gets the data transfer status which used IRQ.
• void FLEXIO_SPI_MasterTransferHandleIRQ (void ∗spiType, void ∗spiHandle)
FlexIO SPI master IRQ handler function.
• status_t FLEXIO_SPI_SlaveTransferCreateHandle (FLEXIO_SPI_Type ∗base, flexio_spi_slave_-
handle_t ∗handle, flexio_spi_slave_transfer_callback_t callback, void ∗userData)
Initializes the FlexIO SPI Slave handle, which is used in transactional functions.
• status_t FLEXIO_SPI_SlaveTransferNonBlocking (FLEXIO_SPI_Type ∗base, flexio_spi_slave_-
handle_t ∗handle, flexio_spi_transfer_t ∗xfer)
Slave transfer data using IRQ.
• static void FLEXIO_SPI_SlaveTransferAbort (FLEXIO_SPI_Type ∗base, flexio_spi_slave_handle-
_t ∗handle)
Aborts the slave data transfer which used IRQ, share same API with master.
• static status_t FLEXIO_SPI_SlaveTransferGetCount (FLEXIO_SPI_Type ∗base, flexio_spi_slave-
_handle_t ∗handle, size_t ∗count)
Gets the data transfer status which used IRQ, share same API with master.
• void FLEXIO_SPI_SlaveTransferHandleIRQ (void ∗spiType, void ∗spiHandle)
FlexIO SPI slave IRQ handler function.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 275
FlexIO SPI Driver

12.7.3 Data Structure Documentation

12.7.3.1 struct FLEXIO_SPI_Type

Data Fields
• FLEXIO_Type ∗ flexioBase
FlexIO base pointer.
• uint8_t SDOPinIndex
Pin select for data output.
• uint8_t SDIPinIndex
Pin select for data input.
• uint8_t SCKPinIndex
Pin select for clock.
• uint8_t CSnPinIndex
Pin select for enable.
• uint8_t shifterIndex [2]
Shifter index used in FlexIO SPI.
• uint8_t timerIndex [2]
Timer index used in FlexIO SPI.

12.7.3.1.0.1 Field Documentation

12.7.3.1.0.1.1 FLEXIO_Type∗ FLEXIO_SPI_Type::flexioBase

12.7.3.1.0.1.2 uint8_t FLEXIO_SPI_Type::SDOPinIndex

12.7.3.1.0.1.3 uint8_t FLEXIO_SPI_Type::SDIPinIndex

12.7.3.1.0.1.4 uint8_t FLEXIO_SPI_Type::SCKPinIndex

12.7.3.1.0.1.5 uint8_t FLEXIO_SPI_Type::CSnPinIndex

12.7.3.1.0.1.6 uint8_t FLEXIO_SPI_Type::shifterIndex[2]

12.7.3.1.0.1.7 uint8_t FLEXIO_SPI_Type::timerIndex[2]

12.7.3.2 struct flexio_spi_master_config_t

Data Fields
• bool enableMaster
Enable/disable FlexIO SPI master after configuration.
• bool enableInDoze
Enable/disable FlexIO operation in doze mode.
• bool enableInDebug
Enable/disable FlexIO operation in debug mode.
• bool enableFastAccess
Enable/disable fast access to FlexIO registers,
fast access requires the FlexIO clock to be at least twice the frequency of the bus clock.

MCUXpresso SDK API Reference Manual


276 NXP Semiconductors
FlexIO SPI Driver

• uint32_t baudRate_Bps
Baud rate in Bps.
• flexio_spi_clock_phase_t phase
Clock phase.
• flexio_spi_data_bitcount_mode_t dataMode
8bit or 16bit mode.

12.7.3.2.0.2 Field Documentation

12.7.3.2.0.2.1 bool flexio_spi_master_config_t::enableMaster

12.7.3.2.0.2.2 bool flexio_spi_master_config_t::enableInDoze

12.7.3.2.0.2.3 bool flexio_spi_master_config_t::enableInDebug

12.7.3.2.0.2.4 bool flexio_spi_master_config_t::enableFastAccess

12.7.3.2.0.2.5 uint32_t flexio_spi_master_config_t::baudRate_Bps

12.7.3.2.0.2.6 flexio_spi_clock_phase_t flexio_spi_master_config_t::phase

12.7.3.2.0.2.7 flexio_spi_data_bitcount_mode_t flexio_spi_master_config_t::dataMode

12.7.3.3 struct flexio_spi_slave_config_t

Data Fields
• bool enableSlave
Enable/disable FlexIO SPI slave after configuration.
• bool enableInDoze
Enable/disable FlexIO operation in doze mode.
• bool enableInDebug
Enable/disable FlexIO operation in debug mode.
• bool enableFastAccess
Enable/disable fast access to FlexIO registers,
fast access requires the FlexIO clock to be at least twice the frequency of the bus clock.
• flexio_spi_clock_phase_t phase
Clock phase.
• flexio_spi_data_bitcount_mode_t dataMode
8bit or 16bit mode.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 277
FlexIO SPI Driver

12.7.3.3.0.3 Field Documentation

12.7.3.3.0.3.1 bool flexio_spi_slave_config_t::enableSlave

12.7.3.3.0.3.2 bool flexio_spi_slave_config_t::enableInDoze

12.7.3.3.0.3.3 bool flexio_spi_slave_config_t::enableInDebug

12.7.3.3.0.3.4 bool flexio_spi_slave_config_t::enableFastAccess

12.7.3.3.0.3.5 flexio_spi_clock_phase_t flexio_spi_slave_config_t::phase

12.7.3.3.0.3.6 flexio_spi_data_bitcount_mode_t flexio_spi_slave_config_t::dataMode

12.7.3.4 struct flexio_spi_transfer_t

Data Fields
• uint8_t ∗ txData
Send buffer.
• uint8_t ∗ rxData
Receive buffer.
• size_t dataSize
Transfer bytes.
• uint8_t flags
FlexIO SPI control flag, MSB first or LSB first.

12.7.3.4.0.4 Field Documentation

12.7.3.4.0.4.1 uint8_t∗ flexio_spi_transfer_t::txData

12.7.3.4.0.4.2 uint8_t∗ flexio_spi_transfer_t::rxData

12.7.3.4.0.4.3 size_t flexio_spi_transfer_t::dataSize

12.7.3.4.0.4.4 uint8_t flexio_spi_transfer_t::flags

12.7.3.5 struct _flexio_spi_master_handle

typedef for flexio_spi_master_handle_t in advance.

Data Fields
• uint8_t ∗ txData
Transfer buffer.
• uint8_t ∗ rxData
Receive buffer.
• size_t transferSize
Total bytes to be transferred.
• volatile size_t txRemainingBytes

MCUXpresso SDK API Reference Manual


278 NXP Semiconductors
FlexIO SPI Driver

Send data remaining in bytes.


• volatile size_t rxRemainingBytes
Receive data remaining in bytes.
• volatile uint32_t state
FlexIO SPI internal state.
• uint8_t bytePerFrame
SPI mode, 2bytes or 1byte in a frame.
• flexio_spi_shift_direction_t direction
Shift direction.
• flexio_spi_master_transfer_callback_t callback
FlexIO SPI callback.
• void ∗ userData
Callback parameter.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 279
FlexIO SPI Driver

12.7.3.5.0.5 Field Documentation

12.7.3.5.0.5.1 uint8_t∗ flexio_spi_master_handle_t::txData

12.7.3.5.0.5.2 uint8_t∗ flexio_spi_master_handle_t::rxData

12.7.3.5.0.5.3 size_t flexio_spi_master_handle_t::transferSize

12.7.3.5.0.5.4 volatile size_t flexio_spi_master_handle_t::txRemainingBytes

12.7.3.5.0.5.5 volatile size_t flexio_spi_master_handle_t::rxRemainingBytes

12.7.3.5.0.5.6 volatile uint32_t flexio_spi_master_handle_t::state

12.7.3.5.0.5.7 flexio_spi_shift_direction_t flexio_spi_master_handle_t::direction

12.7.3.5.0.5.8 flexio_spi_master_transfer_callback_t flexio_spi_master_handle_t::callback

12.7.3.5.0.5.9 void∗ flexio_spi_master_handle_t::userData

12.7.4 Macro Definition Documentation

12.7.4.1 #define FSL_FLEXIO_SPI_DRIVER_VERSION (MAKE_VERSION(2, 1, 3))

12.7.4.2 #define FLEXIO_SPI_DUMMYDATA (0xFFFFU)

12.7.5 Typedef Documentation

12.7.5.1 typedef flexio_spi_master_handle_t flexio_spi_slave_handle_t

12.7.6 Enumeration Type Documentation

12.7.6.1 enum _flexio_spi_status

Enumerator
kStatus_FLEXIO_SPI_Busy FlexIO SPI is busy.
kStatus_FLEXIO_SPI_Idle SPI is idle.
kStatus_FLEXIO_SPI_Error FlexIO SPI error.

12.7.6.2 enum flexio_spi_clock_phase_t

Enumerator
kFLEXIO_SPI_ClockPhaseFirstEdge First edge on SPSCK occurs at the middle of the first cycle
of a data transfer.

MCUXpresso SDK API Reference Manual


280 NXP Semiconductors
FlexIO SPI Driver

kFLEXIO_SPI_ClockPhaseSecondEdge First edge on SPSCK occurs at the start of the first cycle
of a data transfer.

12.7.6.3 enum flexio_spi_shift_direction_t

Enumerator
kFLEXIO_SPI_MsbFirst Data transfers start with most significant bit.
kFLEXIO_SPI_LsbFirst Data transfers start with least significant bit.

12.7.6.4 enum flexio_spi_data_bitcount_mode_t

Enumerator
kFLEXIO_SPI_8BitMode 8-bit data transmission mode.
kFLEXIO_SPI_16BitMode 16-bit data transmission mode.

12.7.6.5 enum _flexio_spi_interrupt_enable

Enumerator
kFLEXIO_SPI_TxEmptyInterruptEnable Transmit buffer empty interrupt enable.
kFLEXIO_SPI_RxFullInterruptEnable Receive buffer full interrupt enable.

12.7.6.6 enum _flexio_spi_status_flags

Enumerator
kFLEXIO_SPI_TxBufferEmptyFlag Transmit buffer empty flag.
kFLEXIO_SPI_RxBufferFullFlag Receive buffer full flag.

12.7.6.7 enum _flexio_spi_dma_enable

Enumerator
kFLEXIO_SPI_TxDmaEnable Tx DMA request source.
kFLEXIO_SPI_RxDmaEnable Rx DMA request source.
kFLEXIO_SPI_DmaAllEnable All DMA request source.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 281
FlexIO SPI Driver

12.7.6.8 enum _flexio_spi_transfer_flags

Enumerator
kFLEXIO_SPI_8bitMsb FlexIO SPI 8-bit MSB first.
kFLEXIO_SPI_8bitLsb FlexIO SPI 8-bit LSB first.
kFLEXIO_SPI_16bitMsb FlexIO SPI 16-bit MSB first.
kFLEXIO_SPI_16bitLsb FlexIO SPI 16-bit LSB first.

12.7.7 Function Documentation

12.7.7.1 void FLEXIO_SPI_MasterInit ( FLEXIO_SPI_Type ∗ base,


flexio_spi_master_config_t ∗ masterConfig, uint32_t srcClock_Hz )

The configuration structure can be filled by the user, or be set with default values by the FLEXIO_SPI_-
MasterGetDefaultConfig().

Note
FlexIO SPI master only support CPOL = 0, which means clock inactive low.

Example

FLEXIO_SPI_Type spiDev = {
.flexioBase = FLEXIO,
.SDOPinIndex = 0,
.SDIPinIndex = 1,
.SCKPinIndex = 2,
.CSnPinIndex = 3,
.shifterIndex = {0,1},
.timerIndex = {0,1}
};
flexio_spi_master_config_t config = {
.enableMaster = true,
.enableInDoze = false,
.enableInDebug = true,
.enableFastAccess = false,
.baudRate_Bps = 500000,
.phase = kFLEXIO_SPI_ClockPhaseFirstEdge,
.direction = kFLEXIO_SPI_MsbFirst,
.dataMode = kFLEXIO_SPI_8BitMode
};
FLEXIO_SPI_MasterInit(&spiDev, &config, srcClock_Hz);

Parameters

MCUXpresso SDK API Reference Manual


282 NXP Semiconductors
FlexIO SPI Driver

base Pointer to the FLEXIO_SPI_Type structure.


masterConfig Pointer to the flexio_spi_master_config_t structure.
srcClock_Hz FlexIO source clock in Hz.

12.7.7.2 void FLEXIO_SPI_MasterDeinit ( FLEXIO_SPI_Type ∗ base )

Parameters

base Pointer to the FLEXIO_SPI_Type.

12.7.7.3 void FLEXIO_SPI_MasterGetDefaultConfig ( flexio_spi_master_config_t ∗


masterConfig )

The configuration can be used directly by calling the FLEXIO_SPI_MasterConfigure(). Example:

flexio_spi_master_config_t masterConfig;
FLEXIO_SPI_MasterGetDefaultConfig(&masterConfig);

Parameters

masterConfig Pointer to the flexio_spi_master_config_t structure.

12.7.7.4 void FLEXIO_SPI_SlaveInit ( FLEXIO_SPI_Type ∗ base,


flexio_spi_slave_config_t ∗ slaveConfig )

The configuration structure can be filled by the user, or be set with default values by the FLEXIO_SPI_-
SlaveGetDefaultConfig().

Note
Only one timer is needed in the FlexIO SPI slave. As a result, the second timer index is ignored.
FlexIO SPI slave only support CPOL = 0, which means clock inactive low. Example
FLEXIO_SPI_Type spiDev = {
.flexioBase = FLEXIO,
.SDOPinIndex = 0,
.SDIPinIndex = 1,
.SCKPinIndex = 2,
.CSnPinIndex = 3,
.shifterIndex = {0,1},
.timerIndex = {0}
};
flexio_spi_slave_config_t config = {
.enableSlave = true,
.enableInDoze = false,

MCUXpresso SDK API Reference Manual


NXP Semiconductors 283
FlexIO SPI Driver

.enableInDebug = true,
.enableFastAccess = false,
.phase = kFLEXIO_SPI_ClockPhaseFirstEdge,
.direction = kFLEXIO_SPI_MsbFirst,
.dataMode = kFLEXIO_SPI_8BitMode
};
FLEXIO_SPI_SlaveInit(&spiDev, &config);

Parameters

base Pointer to the FLEXIO_SPI_Type structure.


slaveConfig Pointer to the flexio_spi_slave_config_t structure.

12.7.7.5 void FLEXIO_SPI_SlaveDeinit ( FLEXIO_SPI_Type ∗ base )

Parameters

base Pointer to the FLEXIO_SPI_Type.

12.7.7.6 void FLEXIO_SPI_SlaveGetDefaultConfig ( flexio_spi_slave_config_t ∗


slaveConfig )

The configuration can be used directly for calling the FLEXIO_SPI_SlaveConfigure(). Example:

flexio_spi_slave_config_t slaveConfig;
FLEXIO_SPI_SlaveGetDefaultConfig(&slaveConfig);

Parameters

slaveConfig Pointer to the flexio_spi_slave_config_t structure.

12.7.7.7 uint32_t FLEXIO_SPI_GetStatusFlags ( FLEXIO_SPI_Type ∗ base )

Parameters

base Pointer to the FLEXIO_SPI_Type structure.

Returns
status flag; Use the status flag to AND the following flag mask and get the status.
• kFLEXIO_SPI_TxEmptyFlag
• kFLEXIO_SPI_RxEmptyFlag

MCUXpresso SDK API Reference Manual


284 NXP Semiconductors
FlexIO SPI Driver

12.7.7.8 void FLEXIO_SPI_ClearStatusFlags ( FLEXIO_SPI_Type ∗ base, uint32_t mask


)

MCUXpresso SDK API Reference Manual


NXP Semiconductors 285
FlexIO SPI Driver

Parameters

base Pointer to the FLEXIO_SPI_Type structure.


mask status flag The parameter can be any combination of the following values:
• kFLEXIO_SPI_TxEmptyFlag
• kFLEXIO_SPI_RxEmptyFlag

12.7.7.9 void FLEXIO_SPI_EnableInterrupts ( FLEXIO_SPI_Type ∗ base, uint32_t mask


)

This function enables the FlexIO SPI interrupt.


Parameters

base Pointer to the FLEXIO_SPI_Type structure.


mask interrupt source. The parameter can be any combination of the following values:
• kFLEXIO_SPI_RxFullInterruptEnable
• kFLEXIO_SPI_TxEmptyInterruptEnable

12.7.7.10 void FLEXIO_SPI_DisableInterrupts ( FLEXIO_SPI_Type ∗ base, uint32_t


mask )

This function disables the FlexIO SPI interrupt.


Parameters

base Pointer to the FLEXIO_SPI_Type structure.


mask interrupt source The parameter can be any combination of the following values:
• kFLEXIO_SPI_RxFullInterruptEnable
• kFLEXIO_SPI_TxEmptyInterruptEnable

12.7.7.11 void FLEXIO_SPI_EnableDMA ( FLEXIO_SPI_Type ∗ base, uint32_t mask,


bool enable )

This function enables/disables the FlexIO SPI Tx DMA, which means that asserting the kFLEXIO_SPI_-
TxEmptyFlag does/doesn’t trigger the DMA request.

MCUXpresso SDK API Reference Manual


286 NXP Semiconductors
FlexIO SPI Driver

Parameters

base Pointer to the FLEXIO_SPI_Type structure.


mask SPI DMA source.
enable True means enable DMA, false means disable DMA.

12.7.7.12 static uint32_t FLEXIO_SPI_GetTxDataRegisterAddress ( FLEXIO_SPI_Type ∗


base, flexio_spi_shift_direction_t direction ) [inline], [static]

This function returns the SPI data register address, which is mainly used by DMA/eDMA.
Parameters

base Pointer to the FLEXIO_SPI_Type structure.


direction Shift direction of MSB first or LSB first.

Returns
FlexIO SPI transmit data register address.

12.7.7.13 static uint32_t FLEXIO_SPI_GetRxDataRegisterAddress ( FLEXIO_SPI_Type ∗


base, flexio_spi_shift_direction_t direction ) [inline], [static]

This function returns the SPI data register address, which is mainly used by DMA/eDMA.
Parameters

base Pointer to the FLEXIO_SPI_Type structure.


direction Shift direction of MSB first or LSB first.

Returns
FlexIO SPI receive data register address.

12.7.7.14 static void FLEXIO_SPI_Enable ( FLEXIO_SPI_Type ∗ base, bool enable )


[inline], [static]

MCUXpresso SDK API Reference Manual


NXP Semiconductors 287
FlexIO SPI Driver

Parameters

base Pointer to the FLEXIO_SPI_Type.


enable True to enable, false does not have any effect.

12.7.7.15 void FLEXIO_SPI_MasterSetBaudRate ( FLEXIO_SPI_Type ∗ base, uint32_t


baudRate_Bps, uint32_t srcClockHz )

Parameters

base Pointer to the FLEXIO_SPI_Type structure.


baudRate_Bps Baud Rate needed in Hz.
srcClockHz SPI source clock frequency in Hz.

12.7.7.16 static void FLEXIO_SPI_WriteData ( FLEXIO_SPI_Type ∗ base,


flexio_spi_shift_direction_t direction, uint16_t data ) [inline], [static]
Note
This is a non-blocking API, which returns directly after the data is put into the data register but the
data transfer is not finished on the bus. Ensure that the TxEmptyFlag is asserted before calling this
API.

Parameters

base Pointer to the FLEXIO_SPI_Type structure.


direction Shift direction of MSB first or LSB first.
data 8 bit/16 bit data.

12.7.7.17 static uint16_t FLEXIO_SPI_ReadData ( FLEXIO_SPI_Type ∗ base,


flexio_spi_shift_direction_t direction ) [inline], [static]
Note
This is a non-blocking API, which returns directly after the data is read from the data register. Ensure
that the RxFullFlag is asserted before calling this API.

MCUXpresso SDK API Reference Manual


288 NXP Semiconductors
FlexIO SPI Driver

Parameters

base Pointer to the FLEXIO_SPI_Type structure.


direction Shift direction of MSB first or LSB first.

Returns
8 bit/16 bit data received.

12.7.7.18 void FLEXIO_SPI_WriteBlocking ( FLEXIO_SPI_Type ∗ base,


flexio_spi_shift_direction_t direction, const uint8_t ∗ buffer, size_t size )
Note
This function blocks using the polling method until all bytes have been sent.

Parameters

base Pointer to the FLEXIO_SPI_Type structure.


direction Shift direction of MSB first or LSB first.
buffer The data bytes to send.
size The number of data bytes to send.

12.7.7.19 void FLEXIO_SPI_ReadBlocking ( FLEXIO_SPI_Type ∗ base,


flexio_spi_shift_direction_t direction, uint8_t ∗ buffer, size_t size )
Note
This function blocks using the polling method until all bytes have been received.

Parameters

base Pointer to the FLEXIO_SPI_Type structure.


direction Shift direction of MSB first or LSB first.
buffer The buffer to store the received bytes.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 289
FlexIO SPI Driver

size The number of data bytes to be received.


direction Shift direction of MSB first or LSB first.

12.7.7.20 void FLEXIO_SPI_MasterTransferBlocking ( FLEXIO_SPI_Type ∗ base,


flexio_spi_transfer_t ∗ xfer )
Note
This function blocks via polling until all bytes have been received.

Parameters

base pointer to FLEXIO_SPI_Type structure


xfer FlexIO SPI transfer structure, see flexio_spi_transfer_t.

12.7.7.21 status_t FLEXIO_SPI_MasterTransferCreateHandle ( FLEXIO_SPI_Type ∗ base,


flexio_spi_master_handle_t ∗ handle, flexio_spi_master_transfer_callback_t
callback, void ∗ userData )

Parameters

base Pointer to the FLEXIO_SPI_Type structure.


handle Pointer to the flexio_spi_master_handle_t structure to store the transfer state.
callback The callback function.
userData The parameter of the callback function.

Return values

kStatus_Success Successfully create the handle.


kStatus_OutOfRange The FlexIO type/handle/ISR table out of range.

12.7.7.22 status_t FLEXIO_SPI_MasterTransferNonBlocking ( FLEXIO_SPI_Type ∗ base,


flexio_spi_master_handle_t ∗ handle, flexio_spi_transfer_t ∗ xfer )

This function sends data using IRQ. This is a non-blocking function, which returns right away. When all
data is sent out/received, the callback function is called.

MCUXpresso SDK API Reference Manual


290 NXP Semiconductors
FlexIO SPI Driver

Parameters

base Pointer to the FLEXIO_SPI_Type structure.


handle Pointer to the flexio_spi_master_handle_t structure to store the transfer state.
xfer FlexIO SPI transfer structure. See flexio_spi_transfer_t.

Return values

kStatus_Success Successfully start a transfer.


kStatus_InvalidArgument Input argument is invalid.
kStatus_FLEXIO_SPI_- SPI is not idle, is running another transfer.
Busy

12.7.7.23 void FLEXIO_SPI_MasterTransferAbort ( FLEXIO_SPI_Type ∗ base,


flexio_spi_master_handle_t ∗ handle )

Parameters

base Pointer to the FLEXIO_SPI_Type structure.


handle Pointer to the flexio_spi_master_handle_t structure to store the transfer state.

12.7.7.24 status_t FLEXIO_SPI_MasterTransferGetCount ( FLEXIO_SPI_Type ∗ base,


flexio_spi_master_handle_t ∗ handle, size_t ∗ count )

Parameters

base Pointer to the FLEXIO_SPI_Type structure.


handle Pointer to the flexio_spi_master_handle_t structure to store the transfer state.
count Number of bytes transferred so far by the non-blocking transaction.

Return values

kStatus_InvalidArgument count is Invalid.


kStatus_Success Successfully return the count.

12.7.7.25 void FLEXIO_SPI_MasterTransferHandleIRQ ( void ∗ spiType, void ∗ spiHandle


)

MCUXpresso SDK API Reference Manual


NXP Semiconductors 291
FlexIO SPI Driver

Parameters

spiType Pointer to the FLEXIO_SPI_Type structure.


spiHandle Pointer to the flexio_spi_master_handle_t structure to store the transfer state.

12.7.7.26 status_t FLEXIO_SPI_SlaveTransferCreateHandle ( FLEXIO_SPI_Type ∗ base,


flexio_spi_slave_handle_t ∗ handle, flexio_spi_slave_transfer_callback_t
callback, void ∗ userData )

Parameters

base Pointer to the FLEXIO_SPI_Type structure.


handle Pointer to the flexio_spi_slave_handle_t structure to store the transfer state.
callback The callback function.
userData The parameter of the callback function.

Return values

kStatus_Success Successfully create the handle.


kStatus_OutOfRange The FlexIO type/handle/ISR table out of range.

12.7.7.27 status_t FLEXIO_SPI_SlaveTransferNonBlocking ( FLEXIO_SPI_Type ∗ base,


flexio_spi_slave_handle_t ∗ handle, flexio_spi_transfer_t ∗ xfer )

This function sends data using IRQ. This is a non-blocking function, which returns right away. When all
data is sent out/received, the callback function is called.
Parameters

handle Pointer to the flexio_spi_slave_handle_t structure to store the transfer state.


base Pointer to the FLEXIO_SPI_Type structure.
xfer FlexIO SPI transfer structure. See flexio_spi_transfer_t.

Return values

kStatus_Success Successfully start a transfer.


kStatus_InvalidArgument Input argument is invalid.
kStatus_FLEXIO_SPI_- SPI is not idle; it is running another transfer.
Busy

MCUXpresso SDK API Reference Manual


292 NXP Semiconductors
FlexIO SPI Driver

12.7.7.28 static void FLEXIO_SPI_SlaveTransferAbort ( FLEXIO_SPI_Type ∗ base,


flexio_spi_slave_handle_t ∗ handle ) [inline], [static]

MCUXpresso SDK API Reference Manual


NXP Semiconductors 293
FlexIO SPI Driver

Parameters

base Pointer to the FLEXIO_SPI_Type structure.


handle Pointer to the flexio_spi_slave_handle_t structure to store the transfer state.

12.7.7.29 static status_t FLEXIO_SPI_SlaveTransferGetCount ( FLEXIO_SPI_Type


∗ base, flexio_spi_slave_handle_t ∗ handle, size_t ∗ count ) [inline],
[static]

Parameters

base Pointer to the FLEXIO_SPI_Type structure.


handle Pointer to the flexio_spi_slave_handle_t structure to store the transfer state.
count Number of bytes transferred so far by the non-blocking transaction.

Return values

kStatus_InvalidArgument count is Invalid.


kStatus_Success Successfully return the count.

12.7.7.30 void FLEXIO_SPI_SlaveTransferHandleIRQ ( void ∗ spiType, void ∗ spiHandle )

Parameters

spiType Pointer to the FLEXIO_SPI_Type structure.


spiHandle Pointer to the flexio_spi_slave_handle_t structure to store the transfer state.

MCUXpresso SDK API Reference Manual


294 NXP Semiconductors
FlexIO SPI Driver

12.7.8 FlexIO eDMA SPI Driver

12.7.8.1 Overview

Data Structures
• struct flexio_spi_master_edma_handle_t
FlexIO SPI eDMA transfer handle, users should not touch the content of the handle. More...

Typedefs
• typedef
flexio_spi_master_edma_handle_t flexio_spi_slave_edma_handle_t
Slave handle is the same with master handle.
• typedef void(∗ flexio_spi_master_edma_transfer_callback_t )(FLEXIO_SPI_Type ∗base, flexio_-
spi_master_edma_handle_t ∗handle, status_t status, void ∗userData)
FlexIO SPI master callback for finished transmit.
• typedef void(∗ flexio_spi_slave_edma_transfer_callback_t )(FLEXIO_SPI_Type ∗base, flexio_spi-
_slave_edma_handle_t ∗handle, status_t status, void ∗userData)
FlexIO SPI slave callback for finished transmit.

Driver version
• #define FSL_FLEXIO_SPI_EDMA_DRIVER_VERSION (MAKE_VERSION(2, 1, 3))
FlexIO SPI EDMA driver version 2.1.3.

eDMA Transactional
• status_t FLEXIO_SPI_MasterTransferCreateHandleEDMA (FLEXIO_SPI_Type ∗base, flexio_-
spi_master_edma_handle_t ∗handle, flexio_spi_master_edma_transfer_callback_t callback, void
∗userData, edma_handle_t ∗txHandle, edma_handle_t ∗rxHandle)
Initializes the FlexIO SPI master eDMA handle.
• status_t FLEXIO_SPI_MasterTransferEDMA (FLEXIO_SPI_Type ∗base, flexio_spi_master_-
edma_handle_t ∗handle, flexio_spi_transfer_t ∗xfer)
Performs a non-blocking FlexIO SPI transfer using eDMA.
• void FLEXIO_SPI_MasterTransferAbortEDMA (FLEXIO_SPI_Type ∗base, flexio_spi_master_-
edma_handle_t ∗handle)
Aborts a FlexIO SPI transfer using eDMA.
• status_t FLEXIO_SPI_MasterTransferGetCountEDMA (FLEXIO_SPI_Type ∗base, flexio_spi_-
master_edma_handle_t ∗handle, size_t ∗count)
Gets the remaining bytes for FlexIO SPI eDMA transfer.
• static void FLEXIO_SPI_SlaveTransferCreateHandleEDMA (FLEXIO_SPI_Type ∗base, flexio-
_spi_slave_edma_handle_t ∗handle, flexio_spi_slave_edma_transfer_callback_t callback, void
∗userData, edma_handle_t ∗txHandle, edma_handle_t ∗rxHandle)
Initializes the FlexIO SPI slave eDMA handle.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 295
FlexIO SPI Driver

• status_t FLEXIO_SPI_SlaveTransferEDMA (FLEXIO_SPI_Type ∗base, flexio_spi_slave_edma_-


handle_t ∗handle, flexio_spi_transfer_t ∗xfer)
Performs a non-blocking FlexIO SPI transfer using eDMA.
• static void FLEXIO_SPI_SlaveTransferAbortEDMA (FLEXIO_SPI_Type ∗base, flexio_spi_slave-
_edma_handle_t ∗handle)
Aborts a FlexIO SPI transfer using eDMA.
• static status_t FLEXIO_SPI_SlaveTransferGetCountEDMA (FLEXIO_SPI_Type ∗base, flexio_spi-
_slave_edma_handle_t ∗handle, size_t ∗count)
Gets the remaining bytes to be transferred for FlexIO SPI eDMA.

12.7.8.2 Data Structure Documentation

12.7.8.2.1 struct _flexio_spi_master_edma_handle

typedef for flexio_spi_master_edma_handle_t in advance.

Data Fields

• size_t transferSize
Total bytes to be transferred.
• uint8_t nbytes
eDMA minor byte transfer count initially configured.
• bool txInProgress
Send transfer in progress.
• bool rxInProgress
Receive transfer in progress.
• edma_handle_t ∗ txHandle
DMA handler for SPI send.
• edma_handle_t ∗ rxHandle
DMA handler for SPI receive.
• flexio_spi_master_edma_transfer_callback_t callback
Callback for SPI DMA transfer.
• void ∗ userData
User Data for SPI DMA callback.

MCUXpresso SDK API Reference Manual


296 NXP Semiconductors
FlexIO SPI Driver

12.7.8.2.1.1 Field Documentation

12.7.8.2.1.1.1 size_t flexio_spi_master_edma_handle_t::transferSize

12.7.8.2.1.1.2 uint8_t flexio_spi_master_edma_handle_t::nbytes

12.7.8.3 Macro Definition Documentation

12.7.8.3.1 #define FSL_FLEXIO_SPI_EDMA_DRIVER_VERSION (MAKE_VERSION(2, 1, 3))

12.7.8.4 Typedef Documentation

12.7.8.4.1 typedef flexio_spi_master_edma_handle_t flexio_spi_slave_edma_handle_t

12.7.8.5 Function Documentation

12.7.8.5.1 status_t FLEXIO_SPI_MasterTransferCreateHandleEDMA ( FLEXIO_SPI_Type ∗ base,


flexio_spi_master_edma_handle_t ∗ handle, flexio_spi_master_edma_transfer_-
callback_t callback, void ∗ userData, edma_handle_t ∗ txHandle, edma_handle_t ∗
rxHandle )

This function initializes the FlexIO SPI master eDMA handle which can be used for other FlexIO SPI
master transactional APIs. For a specified FlexIO SPI instance, call this API once to get the initialized
handle.
Parameters

base Pointer to FLEXIO_SPI_Type structure.


handle Pointer to flexio_spi_master_edma_handle_t structure to store the transfer state.
callback SPI callback, NULL means no callback.
userData callback function parameter.
txHandle User requested eDMA handle for FlexIO SPI RX eDMA transfer.
rxHandle User requested eDMA handle for FlexIO SPI TX eDMA transfer.

Return values

kStatus_Success Successfully create the handle.


kStatus_OutOfRange The FlexIO SPI eDMA type/handle table out of range.

12.7.8.5.2 status_t FLEXIO_SPI_MasterTransferEDMA ( FLEXIO_SPI_Type ∗ base,


flexio_spi_master_edma_handle_t ∗ handle, flexio_spi_transfer_t ∗ xfer )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 297
FlexIO SPI Driver

Note
This interface returns immediately after transfer initiates. Call FLEXIO_SPI_MasterGetTransfer-
CountEDMA to poll the transfer status and check whether the FlexIO SPI transfer is finished.

Parameters

base Pointer to FLEXIO_SPI_Type structure.


handle Pointer to flexio_spi_master_edma_handle_t structure to store the transfer state.
xfer Pointer to FlexIO SPI transfer structure.

Return values

kStatus_Success Successfully start a transfer.


kStatus_InvalidArgument Input argument is invalid.
kStatus_FLEXIO_SPI_- FlexIO SPI is not idle, is running another transfer.
Busy

12.7.8.5.3 void FLEXIO_SPI_MasterTransferAbortEDMA ( FLEXIO_SPI_Type ∗ base,


flexio_spi_master_edma_handle_t ∗ handle )

Parameters

base Pointer to FLEXIO_SPI_Type structure.


handle FlexIO SPI eDMA handle pointer.

12.7.8.5.4 status_t FLEXIO_SPI_MasterTransferGetCountEDMA ( FLEXIO_SPI_Type ∗ base,


flexio_spi_master_edma_handle_t ∗ handle, size_t ∗ count )

Parameters

base Pointer to FLEXIO_SPI_Type structure.


handle FlexIO SPI eDMA handle pointer.
count Number of bytes transferred so far by the non-blocking transaction.

MCUXpresso SDK API Reference Manual


298 NXP Semiconductors
FlexIO SPI Driver

12.7.8.5.5 static void FLEXIO_SPI_SlaveTransferCreateHandleEDMA ( FLEXIO_SPI_Type ∗ base,


flexio_spi_slave_edma_handle_t ∗ handle, flexio_spi_slave_edma_transfer_callback_t
callback, void ∗ userData, edma_handle_t ∗ txHandle, edma_handle_t ∗ rxHandle )
[inline], [static]

This function initializes the FlexIO SPI slave eDMA handle.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 299
FlexIO SPI Driver

Parameters

base Pointer to FLEXIO_SPI_Type structure.


handle Pointer to flexio_spi_slave_edma_handle_t structure to store the transfer state.
callback SPI callback, NULL means no callback.
userData callback function parameter.
txHandle User requested eDMA handle for FlexIO SPI TX eDMA transfer.
rxHandle User requested eDMA handle for FlexIO SPI RX eDMA transfer.

12.7.8.5.6 status_t FLEXIO_SPI_SlaveTransferEDMA ( FLEXIO_SPI_Type ∗ base,


flexio_spi_slave_edma_handle_t ∗ handle, flexio_spi_transfer_t ∗ xfer )

Note
This interface returns immediately after transfer initiates. Call FLEXIO_SPI_SlaveGetTransfer-
CountEDMA to poll the transfer status and check whether the FlexIO SPI transfer is finished.

Parameters

base Pointer to FLEXIO_SPI_Type structure.


handle Pointer to flexio_spi_slave_edma_handle_t structure to store the transfer state.
xfer Pointer to FlexIO SPI transfer structure.

Return values

kStatus_Success Successfully start a transfer.


kStatus_InvalidArgument Input argument is invalid.
kStatus_FLEXIO_SPI_- FlexIO SPI is not idle, is running another transfer.
Busy

12.7.8.5.7 static void FLEXIO_SPI_SlaveTransferAbortEDMA ( FLEXIO_SPI_Type ∗ base,


flexio_spi_slave_edma_handle_t ∗ handle ) [inline], [static]

Parameters

MCUXpresso SDK API Reference Manual


300 NXP Semiconductors
FlexIO SPI Driver

base Pointer to FLEXIO_SPI_Type structure.


handle Pointer to flexio_spi_slave_edma_handle_t structure to store the transfer state.

12.7.8.5.8 static status_t FLEXIO_SPI_SlaveTransferGetCountEDMA ( FLEXIO_SPI_Type


∗ base, flexio_spi_slave_edma_handle_t ∗ handle, size_t ∗ count ) [inline],
[static]

Parameters

base Pointer to FLEXIO_SPI_Type structure.


handle FlexIO SPI eDMA handle pointer.
count Number of bytes transferred so far by the non-blocking transaction.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 301
FlexIO SPI Driver

12.7.9 FlexIO DMA SPI Driver

12.7.9.1 Overview

Data Structures
• struct flexio_spi_master_dma_handle_t
FlexIO SPI DMA transfer handle, users should not touch the content of the handle. More...

Typedefs
• typedef
flexio_spi_master_dma_handle_t flexio_spi_slave_dma_handle_t
Slave handle is the same with master handle.
• typedef void(∗ flexio_spi_master_dma_transfer_callback_t )(FLEXIO_SPI_Type ∗base, flexio_spi-
_master_dma_handle_t ∗handle, status_t status, void ∗userData)
FlexIO SPI master callback for finished transmit.
• typedef void(∗ flexio_spi_slave_dma_transfer_callback_t )(FLEXIO_SPI_Type ∗base, flexio_spi_-
slave_dma_handle_t ∗handle, status_t status, void ∗userData)
FlexIO SPI slave callback for finished transmit.

Driver version
• #define FSL_FLEXIO_SPI_DMA_DRIVER_VERSION (MAKE_VERSION(2, 1, 3))
FlexIO SPI DMA driver version 2.1.3.

DMA Transactional
• status_t FLEXIO_SPI_MasterTransferCreateHandleDMA (FLEXIO_SPI_Type ∗base, flexio_spi-
_master_dma_handle_t ∗handle, flexio_spi_master_dma_transfer_callback_t callback, void ∗user-
Data, dma_handle_t ∗txHandle, dma_handle_t ∗rxHandle)
Initializes the FLEXO SPI master DMA handle.
• status_t FLEXIO_SPI_MasterTransferDMA (FLEXIO_SPI_Type ∗base, flexio_spi_master_dma_-
handle_t ∗handle, flexio_spi_transfer_t ∗xfer)
Performs a non-blocking FlexIO SPI transfer using DMA.
• void FLEXIO_SPI_MasterTransferAbortDMA (FLEXIO_SPI_Type ∗base, flexio_spi_master_-
dma_handle_t ∗handle)
Aborts a FlexIO SPI transfer using DMA.
• status_t FLEXIO_SPI_MasterTransferGetCountDMA (FLEXIO_SPI_Type ∗base, flexio_spi_-
master_dma_handle_t ∗handle, size_t ∗count)
Gets the remaining bytes for FlexIO SPI DMA transfer.
• static void FLEXIO_SPI_SlaveTransferCreateHandleDMA (FLEXIO_SPI_Type ∗base, flexio_spi-
_slave_dma_handle_t ∗handle, flexio_spi_slave_dma_transfer_callback_t callback, void ∗userData,
dma_handle_t ∗txHandle, dma_handle_t ∗rxHandle)
Initializes the FlexIO SPI slave DMA handle.

MCUXpresso SDK API Reference Manual


302 NXP Semiconductors
FlexIO SPI Driver

• status_t FLEXIO_SPI_SlaveTransferDMA (FLEXIO_SPI_Type ∗base, flexio_spi_slave_dma_-


handle_t ∗handle, flexio_spi_transfer_t ∗xfer)
Performs a non-blocking FlexIO SPI transfer using DMA.
• static void FLEXIO_SPI_SlaveTransferAbortDMA (FLEXIO_SPI_Type ∗base, flexio_spi_slave_-
dma_handle_t ∗handle)
Aborts a FlexIO SPI transfer using DMA.
• static status_t FLEXIO_SPI_SlaveTransferGetCountDMA (FLEXIO_SPI_Type ∗base, flexio_spi_-
slave_dma_handle_t ∗handle, size_t ∗count)
Gets the remaining bytes to be transferred for FlexIO SPI DMA.

12.7.9.2 Data Structure Documentation

12.7.9.2.1 struct _flexio_spi_master_dma_handle

typedef for flexio_spi_master_dma_handle_t in advance.

Data Fields

• size_t transferSize
Total bytes to be transferred.
• bool txInProgress
Send transfer in progress.
• bool rxInProgress
Receive transfer in progress.
• dma_handle_t ∗ txHandle
DMA handler for SPI send.
• dma_handle_t ∗ rxHandle
DMA handler for SPI receive.
• flexio_spi_master_dma_transfer_callback_t callback
Callback for SPI DMA transfer.
• void ∗ userData
User Data for SPI DMA callback.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 303
FlexIO SPI Driver

12.7.9.2.1.1 Field Documentation

12.7.9.2.1.1.1 size_t flexio_spi_master_dma_handle_t::transferSize

12.7.9.3 Macro Definition Documentation

12.7.9.3.1 #define FSL_FLEXIO_SPI_DMA_DRIVER_VERSION (MAKE_VERSION(2, 1, 3))

12.7.9.4 Typedef Documentation

12.7.9.4.1 typedef flexio_spi_master_dma_handle_t flexio_spi_slave_dma_handle_t

12.7.9.5 Function Documentation

12.7.9.5.1 status_t FLEXIO_SPI_MasterTransferCreateHandleDMA ( FLEXIO_SPI_Type ∗ base,


flexio_spi_master_dma_handle_t ∗ handle, flexio_spi_master_dma_transfer_callback-
_t callback, void ∗ userData, dma_handle_t ∗ txHandle, dma_handle_t ∗ rxHandle
)

This function initializes the FLEXO SPI master DMA handle which can be used for other FLEXO SPI
master transactional APIs. Usually, for a specified FLEXO SPI instance, call this API once to get the
initialized handle.
Parameters

base Pointer to FLEXIO_SPI_Type structure.


handle Pointer to flexio_spi_master_dma_handle_t structure to store the transfer state.
callback SPI callback, NULL means no callback.
userData callback function parameter.
txHandle User requested DMA handle for FlexIO SPI RX DMA transfer.
rxHandle User requested DMA handle for FlexIO SPI TX DMA transfer.

Return values

kStatus_Success Successfully create the handle.


kStatus_OutOfRange The FlexIO SPI DMA type/handle table out of range.

12.7.9.5.2 status_t FLEXIO_SPI_MasterTransferDMA ( FLEXIO_SPI_Type ∗ base,


flexio_spi_master_dma_handle_t ∗ handle, flexio_spi_transfer_t ∗ xfer )

MCUXpresso SDK API Reference Manual


304 NXP Semiconductors
FlexIO SPI Driver

Note
This interface returned immediately after transfer initiates. Call FLEXIO_SPI_MasterGetTransfer-
CountDMA to poll the transfer status to check whether the FlexIO SPI transfer is finished.

Parameters

base Pointer to FLEXIO_SPI_Type structure.


handle Pointer to flexio_spi_master_dma_handle_t structure to store the transfer state.
xfer Pointer to FlexIO SPI transfer structure.

Return values

kStatus_Success Successfully start a transfer.


kStatus_InvalidArgument Input argument is invalid.
kStatus_FLEXIO_SPI_- FlexIO SPI is not idle, is running another transfer.
Busy

12.7.9.5.3 void FLEXIO_SPI_MasterTransferAbortDMA ( FLEXIO_SPI_Type ∗ base,


flexio_spi_master_dma_handle_t ∗ handle )

Parameters

base Pointer to FLEXIO_SPI_Type structure.


handle FlexIO SPI DMA handle pointer.

12.7.9.5.4 status_t FLEXIO_SPI_MasterTransferGetCountDMA ( FLEXIO_SPI_Type ∗ base,


flexio_spi_master_dma_handle_t ∗ handle, size_t ∗ count )

Parameters

base Pointer to FLEXIO_SPI_Type structure.


handle FlexIO SPI DMA handle pointer.
count Number of bytes transferred so far by the non-blocking transaction.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 305
FlexIO SPI Driver

12.7.9.5.5 static void FLEXIO_SPI_SlaveTransferCreateHandleDMA ( FLEXIO_SPI_Type ∗ base,


flexio_spi_slave_dma_handle_t ∗ handle, flexio_spi_slave_dma_transfer_callback_t
callback, void ∗ userData, dma_handle_t ∗ txHandle, dma_handle_t ∗ rxHandle )
[inline], [static]

This function initializes the FlexIO SPI slave DMA handle.

MCUXpresso SDK API Reference Manual


306 NXP Semiconductors
FlexIO SPI Driver

Parameters

base Pointer to FLEXIO_SPI_Type structure.


handle Pointer to flexio_spi_slave_dma_handle_t structure to store the transfer state.
callback SPI callback, NULL means no callback.
userData callback function parameter.
txHandle User requested DMA handle for FlexIO SPI TX DMA transfer.
rxHandle User requested DMA handle for FlexIO SPI RX DMA transfer.

12.7.9.5.6 status_t FLEXIO_SPI_SlaveTransferDMA ( FLEXIO_SPI_Type ∗ base,


flexio_spi_slave_dma_handle_t ∗ handle, flexio_spi_transfer_t ∗ xfer )

Note
This interface returns immediately after transfer initiates. Call FLEXIO_SPI_SlaveGetTransfer-
CountDMA to poll the transfer status and check whether the FlexIO SPI transfer is finished.

Parameters

base Pointer to FLEXIO_SPI_Type structure.


handle Pointer to flexio_spi_slave_dma_handle_t structure to store the transfer state.
xfer Pointer to FlexIO SPI transfer structure.

Return values

kStatus_Success Successfully start a transfer.


kStatus_InvalidArgument Input argument is invalid.
kStatus_FLEXIO_SPI_- FlexIO SPI is not idle, is running another transfer.
Busy

12.7.9.5.7 static void FLEXIO_SPI_SlaveTransferAbortDMA ( FLEXIO_SPI_Type ∗ base,


flexio_spi_slave_dma_handle_t ∗ handle ) [inline], [static]

Parameters

MCUXpresso SDK API Reference Manual


NXP Semiconductors 307
FlexIO SPI Driver

base Pointer to FLEXIO_SPI_Type structure.


handle Pointer to flexio_spi_slave_dma_handle_t structure to store the transfer state.

12.7.9.5.8 static status_t FLEXIO_SPI_SlaveTransferGetCountDMA ( FLEXIO_SPI_Type ∗ base,


flexio_spi_slave_dma_handle_t ∗ handle, size_t ∗ count ) [inline], [static]

Parameters

base Pointer to FLEXIO_SPI_Type structure.


handle FlexIO SPI DMA handle pointer.
count Number of bytes transferred so far by the non-blocking transaction.

MCUXpresso SDK API Reference Manual


308 NXP Semiconductors
FlexIO UART Driver

12.8 FlexIO UART Driver


12.8.1 Overview

The MCUXpresso SDK provides a peripheral driver for the Universal Asynchronous Receiver/Transmitter
(UART) function using the Flexible I/O.
FlexIO UART driver includes functional APIs and transactional APIs. Functional APIs target low-level
APIs. Functional APIs can be used for the FlexIO UART initialization/configuration/operation for opti-
mization/customization purpose. Using the functional APIs requires the knowledge of the FlexIO UART
peripheral and how to organize functional APIs to meet the application requirements. All functional API
use the FLEXIO_UART_Type ∗ as the first parameter. FlexIO UART functional operation groups provide
the functional APIs set.
Transactional APIs target high-level APIs. Transactional APIs can be used to enable the peripheral and
also in the application if the code size and performance of transactional APIs satisfy requirements. If the
code size and performance are critical requirements, see the transactional API implementation and write
custom code. All transactional APIs use the flexio_uart_handle_t as the second parameter. Initialize the
handle by calling the FLEXIO_UART_TransferCreateHandle() API.
Transactional APIs support asynchronous transfer. This means that the functions FLEXIO_UART_Send-
NonBlocking() and FLEXIO_UART_ReceiveNonBlocking() set up an interrupt for data transfer. When
the transfer is complete, the upper layer is notified through a callback function with the kStatus_FLEXI-
O_UART_TxIdle and kStatus_FLEXIO_UART_RxIdle status.
Transactional receive APIs support the ring buffer. Prepare the memory for the ring buffer and pass in the
start address and size through calling the FLEXIO_UART_InstallRingBuffer(). When the ring buffer is
enabled, the received data is saved to the ring buffer in the background. The function FLEXIO_UART_-
ReceiveNonBlocking() first gets data the from the ring buffer. If ring buffer does not have enough data,
the function returns the data to the ring buffer and saves the received data to user memory. When all data is
received, the upper layer is informed through a callback with the statuskStatus_FLEXIO_UART_RxIdle
status.
If the receive ring buffer is full, the upper layer is informed through a callback with status kStatus_FL-
EXIO_UART_RxRingBufferOverrun. In the callback function, the upper layer reads data from the ring
buffer. If not, the oldest data is overwritten by the new data.
The ring buffer size is specified when calling the FLEXIO_UART_InstallRingBuffer. Note that one byte
is reserved for the ring buffer maintenance. Create a handle as follows.
FLEXIO_UART_InstallRingBuffer(&uartDev, &handle, &ringBuffer, 32);

In this example, the buffer size is 32. However, only 31 bytes are used for saving data.

12.8.2 Typical use case

12.8.2.1 FlexIO UART send/receive using a polling method


uint8_t ch;

MCUXpresso SDK API Reference Manual


NXP Semiconductors 309
FlexIO UART Driver

FLEXIO_UART_Type uartDev;
status_t result = kStatus_Success;
flexio_uart_user_config user_config;
FLEXIO_UART_GetDefaultConfig(&user_config);
user_config.baudRate_Bps = 115200U;
user_config.enableUart = true;

uartDev.flexioBase = BOARD_FLEXIO_BASE;
uartDev.TxPinIndex = FLEXIO_UART_TX_PIN;
uartDev.RxPinIndex = FLEXIO_UART_RX_PIN;
uartDev.shifterIndex[0] = 0U;
uartDev.shifterIndex[1] = 1U;
uartDev.timerIndex[0] = 0U;
uartDev.timerIndex[1] = 1U;

result = FLEXIO_UART_Init(&uartDev, &user_config, 48000000U);


//Check if configuration is correct.
if(result != kStatus_Success)
{
return;
}
FLEXIO_UART_WriteBlocking(&uartDev, txbuff, sizeof(txbuff));

while(1)
{
FLEXIO_UART_ReadBlocking(&uartDev, &ch, 1);
FLEXIO_UART_WriteBlocking(&uartDev, &ch, 1);
}

12.8.2.2 FlexIO UART send/receive using an interrupt method


FLEXIO_UART_Type uartDev;
flexio_uart_handle_t g_uartHandle;
flexio_uart_config_t user_config;
flexio_uart_transfer_t sendXfer;
flexio_uart_transfer_t receiveXfer;
volatile bool txFinished;
volatile bool rxFinished;
uint8_t sendData[] = [’H’, ’e’, ’l’, ’l’, ’o’];
uint8_t receiveData[32];

void FLEXIO_UART_UserCallback(FLEXIO_UART_Type *base, flexio_uart_handle_t *handle,


status_t status, void *userData)
{
userData = userData;

if (kStatus_FLEXIO_UART_TxIdle == status)
{
txFinished = true;
}

if (kStatus_FLEXIO_UART_RxIdle == status)
{
rxFinished = true;
}
}

void main(void)
{
//...

FLEXIO_UART_GetDefaultConfig(&user_config);
user_config.baudRate_Bps = 115200U;
user_config.enableUart = true;

MCUXpresso SDK API Reference Manual


310 NXP Semiconductors
FlexIO UART Driver

uartDev.flexioBase = BOARD_FLEXIO_BASE;
uartDev.TxPinIndex = FLEXIO_UART_TX_PIN;
uartDev.RxPinIndex = FLEXIO_UART_RX_PIN;
uartDev.shifterIndex[0] = 0U;
uartDev.shifterIndex[1] = 1U;
uartDev.timerIndex[0] = 0U;
uartDev.timerIndex[1] = 1U;

result = FLEXIO_UART_Init(&uartDev, &user_config, 120000000U);


//Check if configuration is correct.
if(result != kStatus_Success)
{
return;
}

FLEXIO_UART_TransferCreateHandle(&uartDev, &g_uartHandle,
FLEXIO_UART_UserCallback, NULL);

// Prepares to send.
sendXfer.data = sendData;
sendXfer.dataSize = sizeof(sendData)/sizeof(sendData[0]);
txFinished = false;

// Sends out.
FLEXIO_UART_SendNonBlocking(&uartDev, &g_uartHandle, &sendXfer);

// Send finished.
while (!txFinished)
{
}

// Prepares to receive.
receiveXfer.data = receiveData;
receiveXfer.dataSize = sizeof(receiveData)/sizeof(receiveData[0]);
rxFinished = false;

// Receives.
FLEXIO_UART_ReceiveNonBlocking(&uartDev, &g_uartHandle, &receiveXfer, NULL);

// Receive finished.
while (!rxFinished)
{
}

// ...
}

12.8.2.3 FlexIO UART receive using the ringbuffer feature


#define RING_BUFFER_SIZE 64
#define RX_DATA_SIZE 32

FLEXIO_UART_Type uartDev;
flexio_uart_handle_t g_uartHandle;
flexio_uart_config_t user_config;
flexio_uart_transfer_t sendXfer;
flexio_uart_transfer_t receiveXfer;
volatile bool txFinished;
volatile bool rxFinished;
uint8_t receiveData[RX_DATA_SIZE];
uint8_t ringBuffer[RING_BUFFER_SIZE];

void FLEXIO_UART_UserCallback(FLEXIO_UART_Type *base, flexio_uart_handle_t *handle,


status_t status, void *userData)
{

MCUXpresso SDK API Reference Manual


NXP Semiconductors 311
FlexIO UART Driver

userData = userData;

if (kStatus_FLEXIO_UART_RxIdle == status)
{
rxFinished = true;
}
}

void main(void)
{
size_t bytesRead;
//...

FLEXIO_UART_GetDefaultConfig(&user_config);
user_config.baudRate_Bps = 115200U;
user_config.enableUart = true;

uartDev.flexioBase = BOARD_FLEXIO_BASE;
uartDev.TxPinIndex = FLEXIO_UART_TX_PIN;
uartDev.RxPinIndex = FLEXIO_UART_RX_PIN;
uartDev.shifterIndex[0] = 0U;
uartDev.shifterIndex[1] = 1U;
uartDev.timerIndex[0] = 0U;
uartDev.timerIndex[1] = 1U;

result = FLEXIO_UART_Init(&uartDev, &user_config, 48000000U);


//Check if configuration is correct.
if(result != kStatus_Success)
{
return;
}

FLEXIO_UART_TransferCreateHandle(&uartDev, &g_uartHandle,
FLEXIO_UART_UserCallback, NULL);
FLEXIO_UART_InstallRingBuffer(&uartDev, &g_uartHandle, ringBuffer, RING_BUFFER_SIZE);

// Receive is working in the background to the ring buffer.

// Prepares to receive.
receiveXfer.data = receiveData;
receiveXfer.dataSize = RX_DATA_SIZE;
rxFinished = false;

// Receives.
FLEXIO_UART_ReceiveNonBlocking(&uartDev, &g_uartHandle, &receiveXfer, &bytesRead);

if (bytesRead = RX_DATA_SIZE) /* Have read enough data. */


{
;
}
else
{
if (bytesRead) /* Received some data, process first. */
{
;
}

// Receive finished.
while (!rxFinished)
{
}
}

// ...
}

MCUXpresso SDK API Reference Manual


312 NXP Semiconductors
FlexIO UART Driver

12.8.2.4 FlexIO UART send/receive using a DMA method


FLEXIO_UART_Type uartDev;
flexio_uart_handle_t g_uartHandle;
dma_handle_t g_uartTxDmaHandle;
dma_handle_t g_uartRxDmaHandle;
flexio_uart_config_t user_config;
flexio_uart_transfer_t sendXfer;
flexio_uart_transfer_t receiveXfer;
volatile bool txFinished;
volatile bool rxFinished;
uint8_t sendData[] = [’H’, ’e’, ’l’, ’l’, ’o’];
uint8_t receiveData[32];

void FLEXIO_UART_UserCallback(FLEXIO_UART_Type *base, flexio_uart_handle_t *handle,


status_t status, void *userData)
{
userData = userData;

if (kStatus_FLEXIO_UART_TxIdle == status)
{
txFinished = true;
}

if (kStatus_FLEXIO_UART_RxIdle == status)
{
rxFinished = true;
}
}

void main(void)
{
//...

FLEXIO_UART_GetDefaultConfig(&user_config);
user_config.baudRate_Bps = 115200U;
user_config.enableUart = true;

uartDev.flexioBase = BOARD_FLEXIO_BASE;
uartDev.TxPinIndex = FLEXIO_UART_TX_PIN;
uartDev.RxPinIndex = FLEXIO_UART_RX_PIN;
uartDev.shifterIndex[0] = 0U;
uartDev.shifterIndex[1] = 1U;
uartDev.timerIndex[0] = 0U;
uartDev.timerIndex[1] = 1U;
result = FLEXIO_UART_Init(&uartDev, &user_config, 48000000U);
//Check if configuration is correct.
if(result != kStatus_Success)
{
return;
}

/* Init DMAMUX. */
DMAMUX_Init(EXAMPLE_FLEXIO_UART_DMAMUX_BASEADDR)

/* Init the DMA/EDMA module */


#if defined(FSL_FEATURE_SOC_DMA_COUNT) && FSL_FEATURE_SOC_DMA_COUNT > 0U
DMA_Init(EXAMPLE_FLEXIO_UART_DMA_BASEADDR);
DMA_CreateHandle(&g_uartTxDmaHandle, EXAMPLE_FLEXIO_UART_DMA_BASEADDR,
FLEXIO_UART_TX_DMA_CHANNEL);
DMA_CreateHandle(&g_uartRxDmaHandle, EXAMPLE_FLEXIO_UART_DMA_BASEADDR,
FLEXIO_UART_RX_DMA_CHANNEL);
#endif /* FSL_FEATURE_SOC_DMA_COUNT */

#if defined(FSL_FEATURE_SOC_EDMA_COUNT) && FSL_FEATURE_SOC_EDMA_COUNT > 0U


edma_config_t edmaConfig;

MCUXpresso SDK API Reference Manual


NXP Semiconductors 313
FlexIO UART Driver

EDMA_GetDefaultConfig(&edmaConfig);
EDMA_Init(EXAMPLE_FLEXIO_UART_DMA_BASEADDR, &edmaConfig);
EDMA_CreateHandle(&g_uartTxDmaHandle, EXAMPLE_FLEXIO_UART_DMA_BASEADDR, FLEXIO_UART_TX_DMA_CHANNEL)
;
EDMA_CreateHandle(&g_uartRxDmaHandle, EXAMPLE_FLEXIO_UART_DMA_BASEADDR, FLEXIO_UART_RX_DMA_CHANNEL)
;
#endif /* FSL_FEATURE_SOC_EDMA_COUNT */

dma_request_source_tx = (dma_request_source_t)(FLEXIO_DMA_REQUEST_BASE + uartDev.


shifterIndex[0]);
dma_request_source_rx = (dma_request_source_t)(FLEXIO_DMA_REQUEST_BASE + uartDev.
shifterIndex[1]);

/* Requests DMA channels for transmit and receive. */


DMAMUX_SetSource(EXAMPLE_FLEXIO_UART_DMAMUX_BASEADDR, FLEXIO_UART_TX_DMA_CHANNEL, (
dma_request_source_t)dma_request_source_tx);
DMAMUX_SetSource(EXAMPLE_FLEXIO_UART_DMAMUX_BASEADDR, FLEXIO_UART_RX_DMA_CHANNEL, (
dma_request_source_t)dma_request_source_rx);
DMAMUX_EnableChannel(EXAMPLE_FLEXIO_UART_DMAMUX_BASEADDR,
FLEXIO_UART_TX_DMA_CHANNEL);
DMAMUX_EnableChannel(EXAMPLE_FLEXIO_UART_DMAMUX_BASEADDR,
FLEXIO_UART_RX_DMA_CHANNEL);

FLEXIO_UART_TransferCreateHandleDMA(&uartDev, &g_uartHandle,
FLEXIO_UART_UserCallback, NULL, &g_uartTxDmaHandle, &g_uartRxDmaHandle);

// Prepares to send.
sendXfer.data = sendData
sendXfer.dataSize = sizeof(sendData)/sizeof(sendData[0]);
txFinished = false;

// Sends out.
FLEXIO_UART_SendDMA(&uartDev, &g_uartHandle, &sendXfer);

// Send finished.
while (!txFinished)
{
}

// Prepares to receive.
receiveXfer.data = receiveData;
receiveXfer.dataSize = sizeof(receiveData)/sizeof(receiveData[0]);
rxFinished = false;

// Receives.
FLEXIO_UART_ReceiveDMA(&uartDev, &g_uartHandle, &receiveXfer, NULL);

// Receive finished.
while (!rxFinished)
{
}

// ...
}

Modules

• FlexIO DMA UART Driver


• FlexIO eDMA UART Driver

MCUXpresso SDK API Reference Manual


314 NXP Semiconductors
FlexIO UART Driver

Data Structures

• struct FLEXIO_UART_Type
Define FlexIO UART access structure typedef. More...
• struct flexio_uart_config_t
Define FlexIO UART user configuration structure. More...
• struct flexio_uart_transfer_t
Define FlexIO UART transfer structure. More...
• struct flexio_uart_handle_t
Define FLEXIO UART handle structure. More...

Typedefs

• typedef void(∗ flexio_uart_transfer_callback_t )(FLEXIO_UART_Type ∗base, flexio_uart_handle-


_t ∗handle, status_t status, void ∗userData)
FlexIO UART transfer callback function.

Enumerations

• enum _flexio_uart_status {
kStatus_FLEXIO_UART_TxBusy = MAKE_STATUS(kStatusGroup_FLEXIO_UART, 0),
kStatus_FLEXIO_UART_RxBusy = MAKE_STATUS(kStatusGroup_FLEXIO_UART, 1),
kStatus_FLEXIO_UART_TxIdle = MAKE_STATUS(kStatusGroup_FLEXIO_UART, 2),
kStatus_FLEXIO_UART_RxIdle = MAKE_STATUS(kStatusGroup_FLEXIO_UART, 3),
kStatus_FLEXIO_UART_ERROR = MAKE_STATUS(kStatusGroup_FLEXIO_UART, 4),
kStatus_FLEXIO_UART_RxRingBufferOverrun,
kStatus_FLEXIO_UART_RxHardwareOverrun = MAKE_STATUS(kStatusGroup_FLEXIO_UA-
RT, 6) }
Error codes for the UART driver.
• enum flexio_uart_bit_count_per_char_t {
kFLEXIO_UART_7BitsPerChar = 7U,
kFLEXIO_UART_8BitsPerChar = 8U,
kFLEXIO_UART_9BitsPerChar = 9U }
FlexIO UART bit count per char.
• enum _flexio_uart_interrupt_enable {
kFLEXIO_UART_TxDataRegEmptyInterruptEnable = 0x1U,
kFLEXIO_UART_RxDataRegFullInterruptEnable = 0x2U }
Define FlexIO UART interrupt mask.
• enum _flexio_uart_status_flags {
kFLEXIO_UART_TxDataRegEmptyFlag = 0x1U,
kFLEXIO_UART_RxDataRegFullFlag = 0x2U,
kFLEXIO_UART_RxOverRunFlag = 0x4U }
Define FlexIO UART status mask.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 315
FlexIO UART Driver

Driver version

• #define FSL_FLEXIO_UART_DRIVER_VERSION (MAKE_VERSION(2, 1, 5))


FlexIO UART driver version 2.1.5.

Initialization and deinitialization

• status_t FLEXIO_UART_Init (FLEXIO_UART_Type ∗base, const flexio_uart_config_t ∗user-


Config, uint32_t srcClock_Hz)
Ungates the FlexIO clock, resets the FlexIO module, configures FlexIO UART hardware, and configures
the FlexIO UART with FlexIO UART configuration.
• void FLEXIO_UART_Deinit (FLEXIO_UART_Type ∗base)
Resets the FlexIO UART shifter and timer config.
• void FLEXIO_UART_GetDefaultConfig (flexio_uart_config_t ∗userConfig)
Gets the default configuration to configure the FlexIO UART.

Status

• uint32_t FLEXIO_UART_GetStatusFlags (FLEXIO_UART_Type ∗base)


Gets the FlexIO UART status flags.
• void FLEXIO_UART_ClearStatusFlags (FLEXIO_UART_Type ∗base, uint32_t mask)
Gets the FlexIO UART status flags.

Interrupts

• void FLEXIO_UART_EnableInterrupts (FLEXIO_UART_Type ∗base, uint32_t mask)


Enables the FlexIO UART interrupt.
• void FLEXIO_UART_DisableInterrupts (FLEXIO_UART_Type ∗base, uint32_t mask)
Disables the FlexIO UART interrupt.

DMA Control

• static uint32_t FLEXIO_UART_GetTxDataRegisterAddress (FLEXIO_UART_Type ∗base)


Gets the FlexIO UARt transmit data register address.
• static uint32_t FLEXIO_UART_GetRxDataRegisterAddress (FLEXIO_UART_Type ∗base)
Gets the FlexIO UART receive data register address.
• static void FLEXIO_UART_EnableTxDMA (FLEXIO_UART_Type ∗base, bool enable)
Enables/disables the FlexIO UART transmit DMA.
• static void FLEXIO_UART_EnableRxDMA (FLEXIO_UART_Type ∗base, bool enable)
Enables/disables the FlexIO UART receive DMA.

Bus Operations

• static void FLEXIO_UART_Enable (FLEXIO_UART_Type ∗base, bool enable)

MCUXpresso SDK API Reference Manual


316 NXP Semiconductors
FlexIO UART Driver

Enables/disables the FlexIO UART module operation.


• static void FLEXIO_UART_WriteByte (FLEXIO_UART_Type ∗base, const uint8_t ∗buffer)
Writes one byte of data.
• static void FLEXIO_UART_ReadByte (FLEXIO_UART_Type ∗base, uint8_t ∗buffer)
Reads one byte of data.
• void FLEXIO_UART_WriteBlocking (FLEXIO_UART_Type ∗base, const uint8_t ∗txData, size_t
txSize)
Sends a buffer of data bytes.
• void FLEXIO_UART_ReadBlocking (FLEXIO_UART_Type ∗base, uint8_t ∗rxData, size_t rx-
Size)
Receives a buffer of bytes.

Transactional

• status_t FLEXIO_UART_TransferCreateHandle (FLEXIO_UART_Type ∗base, flexio_uart_-


handle_t ∗handle, flexio_uart_transfer_callback_t callback, void ∗userData)
Initializes the UART handle.
• void FLEXIO_UART_TransferStartRingBuffer (FLEXIO_UART_Type ∗base, flexio_uart_handle-
_t ∗handle, uint8_t ∗ringBuffer, size_t ringBufferSize)
Sets up the RX ring buffer.
• void FLEXIO_UART_TransferStopRingBuffer (FLEXIO_UART_Type ∗base, flexio_uart_handle-
_t ∗handle)
Aborts the background transfer and uninstalls the ring buffer.
• status_t FLEXIO_UART_TransferSendNonBlocking (FLEXIO_UART_Type ∗base, flexio_uart_-
handle_t ∗handle, flexio_uart_transfer_t ∗xfer)
Transmits a buffer of data using the interrupt method.
• void FLEXIO_UART_TransferAbortSend (FLEXIO_UART_Type ∗base, flexio_uart_handle_t
∗handle)
Aborts the interrupt-driven data transmit.
• status_t FLEXIO_UART_TransferGetSendCount (FLEXIO_UART_Type ∗base, flexio_uart_-
handle_t ∗handle, size_t ∗count)
Gets the number of bytes sent.
• status_t FLEXIO_UART_TransferReceiveNonBlocking (FLEXIO_UART_Type ∗base, flexio_-
uart_handle_t ∗handle, flexio_uart_transfer_t ∗xfer, size_t ∗receivedBytes)
Receives a buffer of data using the interrupt method.
• void FLEXIO_UART_TransferAbortReceive (FLEXIO_UART_Type ∗base, flexio_uart_handle_t
∗handle)
Aborts the receive data which was using IRQ.
• status_t FLEXIO_UART_TransferGetReceiveCount (FLEXIO_UART_Type ∗base, flexio_uart_-
handle_t ∗handle, size_t ∗count)
Gets the number of bytes received.
• void FLEXIO_UART_TransferHandleIRQ (void ∗uartType, void ∗uartHandle)
FlexIO UART IRQ handler function.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 317
FlexIO UART Driver

12.8.3 Data Structure Documentation

12.8.3.1 struct FLEXIO_UART_Type

Data Fields
• FLEXIO_Type ∗ flexioBase
FlexIO base pointer.
• uint8_t TxPinIndex
Pin select for UART_Tx.
• uint8_t RxPinIndex
Pin select for UART_Rx.
• uint8_t shifterIndex [2]
Shifter index used in FlexIO UART.
• uint8_t timerIndex [2]
Timer index used in FlexIO UART.

12.8.3.1.0.1 Field Documentation

12.8.3.1.0.1.1 FLEXIO_Type∗ FLEXIO_UART_Type::flexioBase

12.8.3.1.0.1.2 uint8_t FLEXIO_UART_Type::TxPinIndex

12.8.3.1.0.1.3 uint8_t FLEXIO_UART_Type::RxPinIndex

12.8.3.1.0.1.4 uint8_t FLEXIO_UART_Type::shifterIndex[2]

12.8.3.1.0.1.5 uint8_t FLEXIO_UART_Type::timerIndex[2]

12.8.3.2 struct flexio_uart_config_t

Data Fields
• bool enableUart
Enable/disable FlexIO UART TX & RX.
• bool enableInDoze
Enable/disable FlexIO operation in doze mode.
• bool enableInDebug
Enable/disable FlexIO operation in debug mode.
• bool enableFastAccess
Enable/disable fast access to FlexIO registers,
fast access requires the FlexIO clock to be at least twice the frequency of the bus clock.
• uint32_t baudRate_Bps
Baud rate in Bps.
• flexio_uart_bit_count_per_char_t bitCountPerChar
number of bits, 7/8/9 -bit

MCUXpresso SDK API Reference Manual


318 NXP Semiconductors
FlexIO UART Driver

12.8.3.2.0.2 Field Documentation

12.8.3.2.0.2.1 bool flexio_uart_config_t::enableUart

12.8.3.2.0.2.2 bool flexio_uart_config_t::enableFastAccess

12.8.3.2.0.2.3 uint32_t flexio_uart_config_t::baudRate_Bps

12.8.3.3 struct flexio_uart_transfer_t

Data Fields
• uint8_t ∗ data
Transfer buffer.
• size_t dataSize
Transfer size.

12.8.3.4 struct _flexio_uart_handle

Data Fields
• uint8_t ∗volatile txData
Address of remaining data to send.
• volatile size_t txDataSize
Size of the remaining data to send.
• uint8_t ∗volatile rxData
Address of remaining data to receive.
• volatile size_t rxDataSize
Size of the remaining data to receive.
• size_t txDataSizeAll
Total bytes to be sent.
• size_t rxDataSizeAll
Total bytes to be received.
• uint8_t ∗ rxRingBuffer
Start address of the receiver ring buffer.
• size_t rxRingBufferSize
Size of the ring buffer.
• volatile uint16_t rxRingBufferHead
Index for the driver to store received data into ring buffer.
• volatile uint16_t rxRingBufferTail
Index for the user to get data from the ring buffer.
• flexio_uart_transfer_callback_t callback
Callback function.
• void ∗ userData
UART callback function parameter.
• volatile uint8_t txState
TX transfer state.
• volatile uint8_t rxState
RX transfer state.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 319
FlexIO UART Driver

12.8.3.4.0.3 Field Documentation

12.8.3.4.0.3.1 uint8_t∗ volatile flexio_uart_handle_t::txData

12.8.3.4.0.3.2 volatile size_t flexio_uart_handle_t::txDataSize

12.8.3.4.0.3.3 uint8_t∗ volatile flexio_uart_handle_t::rxData

12.8.3.4.0.3.4 volatile size_t flexio_uart_handle_t::rxDataSize

12.8.3.4.0.3.5 size_t flexio_uart_handle_t::txDataSizeAll

12.8.3.4.0.3.6 size_t flexio_uart_handle_t::rxDataSizeAll

12.8.3.4.0.3.7 uint8_t∗ flexio_uart_handle_t::rxRingBuffer

12.8.3.4.0.3.8 size_t flexio_uart_handle_t::rxRingBufferSize

12.8.3.4.0.3.9 volatile uint16_t flexio_uart_handle_t::rxRingBufferHead

12.8.3.4.0.3.10 volatile uint16_t flexio_uart_handle_t::rxRingBufferTail

12.8.3.4.0.3.11 flexio_uart_transfer_callback_t flexio_uart_handle_t::callback

12.8.3.4.0.3.12 void∗ flexio_uart_handle_t::userData

12.8.3.4.0.3.13 volatile uint8_t flexio_uart_handle_t::txState

12.8.4 Macro Definition Documentation

12.8.4.1 #define FSL_FLEXIO_UART_DRIVER_VERSION (MAKE_VERSION(2, 1, 5))

12.8.5 Typedef Documentation

12.8.5.1 typedef void(∗ flexio_uart_transfer_callback_t)(FLEXIO_UART_Type ∗base,


flexio_uart_handle_t ∗handle, status_t status, void ∗userData)

12.8.6 Enumeration Type Documentation

12.8.6.1 enum _flexio_uart_status

Enumerator
kStatus_FLEXIO_UART_TxBusy Transmitter is busy.
kStatus_FLEXIO_UART_RxBusy Receiver is busy.
kStatus_FLEXIO_UART_TxIdle UART transmitter is idle.
kStatus_FLEXIO_UART_RxIdle UART receiver is idle.
kStatus_FLEXIO_UART_ERROR ERROR happens on UART.

MCUXpresso SDK API Reference Manual


320 NXP Semiconductors
FlexIO UART Driver

kStatus_FLEXIO_UART_RxRingBufferOverrun UART RX software ring buffer overrun.


kStatus_FLEXIO_UART_RxHardwareOverrun UART RX receiver overrun.

12.8.6.2 enum flexio_uart_bit_count_per_char_t

Enumerator
kFLEXIO_UART_7BitsPerChar 7-bit data characters
kFLEXIO_UART_8BitsPerChar 8-bit data characters
kFLEXIO_UART_9BitsPerChar 9-bit data characters

12.8.6.3 enum _flexio_uart_interrupt_enable

Enumerator
kFLEXIO_UART_TxDataRegEmptyInterruptEnable Transmit buffer empty interrupt enable.
kFLEXIO_UART_RxDataRegFullInterruptEnable Receive buffer full interrupt enable.

12.8.6.4 enum _flexio_uart_status_flags

Enumerator
kFLEXIO_UART_TxDataRegEmptyFlag Transmit buffer empty flag.
kFLEXIO_UART_RxDataRegFullFlag Receive buffer full flag.
kFLEXIO_UART_RxOverRunFlag Receive buffer over run flag.

12.8.7 Function Documentation

12.8.7.1 status_t FLEXIO_UART_Init ( FLEXIO_UART_Type ∗ base, const


flexio_uart_config_t ∗ userConfig, uint32_t srcClock_Hz )

The configuration structure can be filled by the user or be set with default values by FLEXIO_UART_-
GetDefaultConfig().
Example

FLEXIO_UART_Type base = {
.flexioBase = FLEXIO,
.TxPinIndex = 0,
.RxPinIndex = 1,
.shifterIndex = {0,1},
.timerIndex = {0,1}
};
flexio_uart_config_t config = {
.enableInDoze = false,

MCUXpresso SDK API Reference Manual


NXP Semiconductors 321
FlexIO UART Driver

.enableInDebug = true,
.enableFastAccess = false,
.baudRate_Bps = 115200U,
.bitCountPerChar = 8
};
FLEXIO_UART_Init(base, &config, srcClock_Hz);

Parameters

base Pointer to the FLEXIO_UART_Type structure.


userConfig Pointer to the flexio_uart_config_t structure.
srcClock_Hz FlexIO source clock in Hz.

Return values

kStatus_Success Configuration success


kStatus_InvalidArgument Buadrate configuration out of range

12.8.7.2 void FLEXIO_UART_Deinit ( FLEXIO_UART_Type ∗ base )

Note
After calling this API, call the FLEXO_UART_Init to use the FlexIO UART module.

Parameters

base Pointer to FLEXIO_UART_Type structure

12.8.7.3 void FLEXIO_UART_GetDefaultConfig ( flexio_uart_config_t ∗ userConfig )

The configuration can be used directly for calling the FLEXIO_UART_Init(). Example:

flexio_uart_config_t config;
FLEXIO_UART_GetDefaultConfig(&userConfig);

Parameters

userConfig Pointer to the flexio_uart_config_t structure.

12.8.7.4 uint32_t FLEXIO_UART_GetStatusFlags ( FLEXIO_UART_Type ∗ base )

MCUXpresso SDK API Reference Manual


322 NXP Semiconductors
FlexIO UART Driver

Parameters

base Pointer to the FLEXIO_UART_Type structure.

Returns
FlexIO UART status flags.

12.8.7.5 void FLEXIO_UART_ClearStatusFlags ( FLEXIO_UART_Type ∗ base, uint32_t


mask )

Parameters

base Pointer to the FLEXIO_UART_Type structure.


mask Status flag. The parameter can be any combination of the following values:
• kFLEXIO_UART_TxDataRegEmptyFlag
• kFLEXIO_UART_RxEmptyFlag
• kFLEXIO_UART_RxOverRunFlag

12.8.7.6 void FLEXIO_UART_EnableInterrupts ( FLEXIO_UART_Type ∗ base, uint32_t


mask )

This function enables the FlexIO UART interrupt.


Parameters

base Pointer to the FLEXIO_UART_Type structure.


mask Interrupt source.

12.8.7.7 void FLEXIO_UART_DisableInterrupts ( FLEXIO_UART_Type ∗ base, uint32_t


mask )

This function disables the FlexIO UART interrupt.


Parameters

MCUXpresso SDK API Reference Manual


NXP Semiconductors 323
FlexIO UART Driver

base Pointer to the FLEXIO_UART_Type structure.


mask Interrupt source.

12.8.7.8 static uint32_t FLEXIO_UART_GetTxDataRegisterAddress (


FLEXIO_UART_Type ∗ base ) [inline], [static]

This function returns the UART data register address, which is mainly used by DMA/eDMA.
Parameters

base Pointer to the FLEXIO_UART_Type structure.

Returns
FlexIO UART transmit data register address.

12.8.7.9 static uint32_t FLEXIO_UART_GetRxDataRegisterAddress (


FLEXIO_UART_Type ∗ base ) [inline], [static]

This function returns the UART data register address, which is mainly used by DMA/eDMA.
Parameters

base Pointer to the FLEXIO_UART_Type structure.

Returns
FlexIO UART receive data register address.

12.8.7.10 static void FLEXIO_UART_EnableTxDMA ( FLEXIO_UART_Type ∗ base, bool


enable ) [inline], [static]

This function enables/disables the FlexIO UART Tx DMA, which means asserting the kFLEXIO_UAR-
T_TxDataRegEmptyFlag does/doesn’t trigger the DMA request.
Parameters

base Pointer to the FLEXIO_UART_Type structure.


enable True to enable, false to disable.

MCUXpresso SDK API Reference Manual


324 NXP Semiconductors
FlexIO UART Driver

12.8.7.11 static void FLEXIO_UART_EnableRxDMA ( FLEXIO_UART_Type ∗ base, bool


enable ) [inline], [static]

This function enables/disables the FlexIO UART Rx DMA, which means asserting kFLEXIO_UART_-
RxDataRegFullFlag does/doesn’t trigger the DMA request.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 325
FlexIO UART Driver

Parameters

base Pointer to the FLEXIO_UART_Type structure.


enable True to enable, false to disable.

12.8.7.12 static void FLEXIO_UART_Enable ( FLEXIO_UART_Type ∗ base, bool enable


) [inline], [static]

Parameters

base Pointer to the FLEXIO_UART_Type.


enable True to enable, false does not have any effect.

12.8.7.13 static void FLEXIO_UART_WriteByte ( FLEXIO_UART_Type ∗ base, const


uint8_t ∗ buffer ) [inline], [static]

Note
This is a non-blocking API, which returns directly after the data is put into the data register. Ensure
that the TxEmptyFlag is asserted before calling this API.

Parameters

base Pointer to the FLEXIO_UART_Type structure.


buffer The data bytes to send.

12.8.7.14 static void FLEXIO_UART_ReadByte ( FLEXIO_UART_Type ∗ base, uint8_t ∗


buffer ) [inline], [static]

Note
This is a non-blocking API, which returns directly after the data is read from the data register. Ensure
that the RxFullFlag is asserted before calling this API.

Parameters

MCUXpresso SDK API Reference Manual


326 NXP Semiconductors
FlexIO UART Driver

base Pointer to the FLEXIO_UART_Type structure.


buffer The buffer to store the received bytes.

12.8.7.15 void FLEXIO_UART_WriteBlocking ( FLEXIO_UART_Type ∗ base, const


uint8_t ∗ txData, size_t txSize )

Note
This function blocks using the polling method until all bytes have been sent.

Parameters

base Pointer to the FLEXIO_UART_Type structure.


txData The data bytes to send.
txSize The number of data bytes to send.

12.8.7.16 void FLEXIO_UART_ReadBlocking ( FLEXIO_UART_Type ∗ base, uint8_t ∗


rxData, size_t rxSize )

Note
This function blocks using the polling method until all bytes have been received.

Parameters

base Pointer to the FLEXIO_UART_Type structure.


rxData The buffer to store the received bytes.
rxSize The number of data bytes to be received.

12.8.7.17 status_t FLEXIO_UART_TransferCreateHandle ( FLEXIO_UART_Type ∗ base,


flexio_uart_handle_t ∗ handle, flexio_uart_transfer_callback_t callback, void ∗
userData )

This function initializes the FlexIO UART handle, which can be used for other FlexIO UART transactional
APIs. Call this API once to get the initialized handle.
The UART driver supports the "background" receiving, which means that users can set up a RX ring buffer
optionally. Data received is stored into the ring buffer even when the user doesn’t call the FLEXIO_UAR-
T_TransferReceiveNonBlocking() API. If there is already data received in the ring buffer, users can get the
received data from the ring buffer directly. The ring buffer is disabled if passing NULL as ringBuffer.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 327
FlexIO UART Driver

Parameters

base to FLEXIO_UART_Type structure.


handle Pointer to the flexio_uart_handle_t structure to store the transfer state.
callback The callback function.
userData The parameter of the callback function.

Return values

kStatus_Success Successfully create the handle.


kStatus_OutOfRange The FlexIO type/handle/ISR table out of range.

12.8.7.18 void FLEXIO_UART_TransferStartRingBuffer ( FLEXIO_UART_Type ∗ base,


flexio_uart_handle_t ∗ handle, uint8_t ∗ ringBuffer, size_t ringBufferSize )

This function sets up the RX ring buffer to a specific UART handle.


When the RX ring buffer is used, data received is stored into the ring buffer even when the user doesn’t
call the UART_ReceiveNonBlocking() API. If there is already data received in the ring buffer, users can
get the received data from the ring buffer directly.

Note
When using the RX ring buffer, one byte is reserved for internal use. In other words, if ring-
BufferSize is 32, only 31 bytes are used for saving data.

Parameters

base Pointer to the FLEXIO_UART_Type structure.


handle Pointer to the flexio_uart_handle_t structure to store the transfer state.
ringBuffer Start address of ring buffer for background receiving. Pass NULL to disable the ring
buffer.
ringBufferSize Size of the ring buffer.

12.8.7.19 void FLEXIO_UART_TransferStopRingBuffer ( FLEXIO_UART_Type ∗ base,


flexio_uart_handle_t ∗ handle )

This function aborts the background transfer and uninstalls the ring buffer.

MCUXpresso SDK API Reference Manual


328 NXP Semiconductors
FlexIO UART Driver

Parameters

base Pointer to the FLEXIO_UART_Type structure.


handle Pointer to the flexio_uart_handle_t structure to store the transfer state.

12.8.7.20 status_t FLEXIO_UART_TransferSendNonBlocking ( FLEXIO_UART_Type ∗


base, flexio_uart_handle_t ∗ handle, flexio_uart_transfer_t ∗ xfer )

This function sends data using an interrupt method. This is a non-blocking function, which returns directly
without waiting for all data to be written to the TX register. When all data is written to the TX register in
ISR, the FlexIO UART driver calls the callback function and passes the kStatus_FLEXIO_UART_TxIdle
as status parameter.

Note
The kStatus_FLEXIO_UART_TxIdle is passed to the upper layer when all data is written to the TX
register. However, it does not ensure that all data is sent out.

Parameters

base Pointer to the FLEXIO_UART_Type structure.


handle Pointer to the flexio_uart_handle_t structure to store the transfer state.
xfer FlexIO UART transfer structure. See flexio_uart_transfer_t.

Return values

kStatus_Success Successfully starts the data transmission.


kStatus_UART_TxBusy Previous transmission still not finished, data not written to the TX register.

12.8.7.21 void FLEXIO_UART_TransferAbortSend ( FLEXIO_UART_Type ∗ base,


flexio_uart_handle_t ∗ handle )

This function aborts the interrupt-driven data sending. Get the remainBytes to find out how many bytes
are still not sent out.
Parameters

MCUXpresso SDK API Reference Manual


NXP Semiconductors 329
FlexIO UART Driver

base Pointer to the FLEXIO_UART_Type structure.


handle Pointer to the flexio_uart_handle_t structure to store the transfer state.

12.8.7.22 status_t FLEXIO_UART_TransferGetSendCount ( FLEXIO_UART_Type ∗


base, flexio_uart_handle_t ∗ handle, size_t ∗ count )

This function gets the number of bytes sent driven by interrupt.


Parameters

base Pointer to the FLEXIO_UART_Type structure.


handle Pointer to the flexio_uart_handle_t structure to store the transfer state.
count Number of bytes sent so far by the non-blocking transaction.

Return values

kStatus_NoTransferIn- transfer has finished or no transfer in progress.


Progress
kStatus_Success Successfully return the count.

12.8.7.23 status_t FLEXIO_UART_TransferReceiveNonBlocking ( FLEXIO_UART_Type


∗ base, flexio_uart_handle_t ∗ handle, flexio_uart_transfer_t ∗ xfer, size_t ∗
receivedBytes )

This function receives data using the interrupt method. This is a non-blocking function, which returns
without waiting for all data to be received. If the RX ring buffer is used and not empty, the data in ring
buffer is copied and the parameter receivedBytes shows how many bytes are copied from the ring
buffer. After copying, if the data in ring buffer is not enough to read, the receive request is saved by the
UART driver. When new data arrives, the receive request is serviced first. When all data is received, the
UART driver notifies the upper layer through a callback function and passes the status parameter kStatus_-
UART_RxIdle. For example, if the upper layer needs 10 bytes but there are only 5 bytes in the ring buffer,
the 5 bytes are copied to xfer->data. This function returns with the parameter receivedBytes set to
5. For the last 5 bytes, newly arrived data is saved from the xfer->data[5]. When 5 bytes are received, the
UART driver notifies upper layer. If the RX ring buffer is not enabled, this function enables the RX and
RX interrupt to receive data to xfer->data. When all data is received, the upper layer is notified.

MCUXpresso SDK API Reference Manual


330 NXP Semiconductors
FlexIO UART Driver

Parameters

base Pointer to the FLEXIO_UART_Type structure.


handle Pointer to the flexio_uart_handle_t structure to store the transfer state.
xfer UART transfer structure. See flexio_uart_transfer_t.
receivedBytes Bytes received from the ring buffer directly.

Return values

kStatus_Success Successfully queue the transfer into the transmit queue.


kStatus_FLEXIO_UART- Previous receive request is not finished.
_RxBusy

12.8.7.24 void FLEXIO_UART_TransferAbortReceive ( FLEXIO_UART_Type ∗ base,


flexio_uart_handle_t ∗ handle )

This function aborts the receive data which was using IRQ.
Parameters

base Pointer to the FLEXIO_UART_Type structure.


handle Pointer to the flexio_uart_handle_t structure to store the transfer state.

12.8.7.25 status_t FLEXIO_UART_TransferGetReceiveCount ( FLEXIO_UART_Type ∗


base, flexio_uart_handle_t ∗ handle, size_t ∗ count )

This function gets the number of bytes received driven by interrupt.


Parameters

base Pointer to the FLEXIO_UART_Type structure.


handle Pointer to the flexio_uart_handle_t structure to store the transfer state.
count Number of bytes received so far by the non-blocking transaction.

Return values

kStatus_NoTransferIn- transfer has finished or no transfer in progress.


Progress
kStatus_Success Successfully return the count.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 331
FlexIO UART Driver

12.8.7.26 void FLEXIO_UART_TransferHandleIRQ ( void ∗ uartType, void ∗ uartHandle )

This function processes the FlexIO UART transmit and receives the IRQ request.

MCUXpresso SDK API Reference Manual


332 NXP Semiconductors
FlexIO UART Driver

Parameters

uartType Pointer to the FLEXIO_UART_Type structure.


uartHandle Pointer to the flexio_uart_handle_t structure to store the transfer state.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 333
FlexIO UART Driver

12.8.8 FlexIO eDMA UART Driver

12.8.8.1 Overview

Data Structures
• struct flexio_uart_edma_handle_t
UART eDMA handle. More...

Typedefs
• typedef void(∗ flexio_uart_edma_transfer_callback_t )(FLEXIO_UART_Type ∗base, flexio_uart_-
edma_handle_t ∗handle, status_t status, void ∗userData)
UART transfer callback function.

Driver version
• #define FSL_FLEXIO_UART_EDMA_DRIVER_VERSION (MAKE_VERSION(2, 1, 4))
FlexIO UART EDMA driver version 2.1.4.

eDMA transactional
• status_t FLEXIO_UART_TransferCreateHandleEDMA (FLEXIO_UART_Type ∗base, flexio_uart-
_edma_handle_t ∗handle, flexio_uart_edma_transfer_callback_t callback, void ∗userData, edma_-
handle_t ∗txEdmaHandle, edma_handle_t ∗rxEdmaHandle)
Initializes the UART handle which is used in transactional functions.
• status_t FLEXIO_UART_TransferSendEDMA (FLEXIO_UART_Type ∗base, flexio_uart_edma_-
handle_t ∗handle, flexio_uart_transfer_t ∗xfer)
Sends data using eDMA.
• status_t FLEXIO_UART_TransferReceiveEDMA (FLEXIO_UART_Type ∗base, flexio_uart_-
edma_handle_t ∗handle, flexio_uart_transfer_t ∗xfer)
Receives data using eDMA.
• void FLEXIO_UART_TransferAbortSendEDMA (FLEXIO_UART_Type ∗base, flexio_uart_-
edma_handle_t ∗handle)
Aborts the sent data which using eDMA.
• void FLEXIO_UART_TransferAbortReceiveEDMA (FLEXIO_UART_Type ∗base, flexio_uart_-
edma_handle_t ∗handle)
Aborts the receive data which using eDMA.
• status_t FLEXIO_UART_TransferGetSendCountEDMA (FLEXIO_UART_Type ∗base, flexio_-
uart_edma_handle_t ∗handle, size_t ∗count)
Gets the number of bytes sent out.
• status_t FLEXIO_UART_TransferGetReceiveCountEDMA (FLEXIO_UART_Type ∗base, flexio-
_uart_edma_handle_t ∗handle, size_t ∗count)
Gets the number of bytes received.

MCUXpresso SDK API Reference Manual


334 NXP Semiconductors
FlexIO UART Driver

12.8.8.2 Data Structure Documentation

12.8.8.2.1 struct _flexio_uart_edma_handle

Data Fields

• flexio_uart_edma_transfer_callback_t callback
Callback function.
• void ∗ userData
UART callback function parameter.
• size_t txDataSizeAll
Total bytes to be sent.
• size_t rxDataSizeAll
Total bytes to be received.
• edma_handle_t ∗ txEdmaHandle
The eDMA TX channel used.
• edma_handle_t ∗ rxEdmaHandle
The eDMA RX channel used.
• uint8_t nbytes
eDMA minor byte transfer count initially configured.
• volatile uint8_t txState
TX transfer state.
• volatile uint8_t rxState
RX transfer state.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 335
FlexIO UART Driver

12.8.8.2.1.1 Field Documentation

12.8.8.2.1.1.1 flexio_uart_edma_transfer_callback_t flexio_uart_edma_handle_t::callback

12.8.8.2.1.1.2 void∗ flexio_uart_edma_handle_t::userData

12.8.8.2.1.1.3 size_t flexio_uart_edma_handle_t::txDataSizeAll

12.8.8.2.1.1.4 size_t flexio_uart_edma_handle_t::rxDataSizeAll

12.8.8.2.1.1.5 edma_handle_t∗ flexio_uart_edma_handle_t::txEdmaHandle

12.8.8.2.1.1.6 edma_handle_t∗ flexio_uart_edma_handle_t::rxEdmaHandle

12.8.8.2.1.1.7 uint8_t flexio_uart_edma_handle_t::nbytes

12.8.8.2.1.1.8 volatile uint8_t flexio_uart_edma_handle_t::txState

12.8.8.3 Macro Definition Documentation

12.8.8.3.1 #define FSL_FLEXIO_UART_EDMA_DRIVER_VERSION (MAKE_VERSION(2, 1, 4))

12.8.8.4 Typedef Documentation

12.8.8.4.1 typedef void(∗ flexio_uart_edma_transfer_callback_t)(FLEXIO_UART_Type ∗base,


flexio_uart_edma_handle_t ∗handle, status_t status, void ∗userData)

12.8.8.5 Function Documentation

12.8.8.5.1 status_t FLEXIO_UART_TransferCreateHandleEDMA ( FLEXIO_UART_Type ∗ base,


flexio_uart_edma_handle_t ∗ handle, flexio_uart_edma_transfer_callback_t callback,
void ∗ userData, edma_handle_t ∗ txEdmaHandle, edma_handle_t ∗ rxEdmaHandle )

MCUXpresso SDK API Reference Manual


336 NXP Semiconductors
FlexIO UART Driver

Parameters

base Pointer to FLEXIO_UART_Type.


handle Pointer to flexio_uart_edma_handle_t structure.
callback The callback function.
userData The parameter of the callback function.
rxEdmaHandle User requested DMA handle for RX DMA transfer.
txEdmaHandle User requested DMA handle for TX DMA transfer.

Return values

kStatus_Success Successfully create the handle.


kStatus_OutOfRange The FlexIO SPI eDMA type/handle table out of range.

12.8.8.5.2 status_t FLEXIO_UART_TransferSendEDMA ( FLEXIO_UART_Type ∗ base,


flexio_uart_edma_handle_t ∗ handle, flexio_uart_transfer_t ∗ xfer )

This function sends data using eDMA. This is a non-blocking function, which returns right away. When
all data is sent out, the send callback function is called.
Parameters

base Pointer to FLEXIO_UART_Type


handle UART handle pointer.
xfer UART eDMA transfer structure, see flexio_uart_transfer_t.

Return values

kStatus_Success if succeed, others failed.


kStatus_FLEXIO_UART- Previous transfer on going.
_TxBusy

12.8.8.5.3 status_t FLEXIO_UART_TransferReceiveEDMA ( FLEXIO_UART_Type ∗ base,


flexio_uart_edma_handle_t ∗ handle, flexio_uart_transfer_t ∗ xfer )

This function receives data using eDMA. This is a non-blocking function, which returns right away. When
all data is received, the receive callback function is called.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 337
FlexIO UART Driver

Parameters

base Pointer to FLEXIO_UART_Type


handle Pointer to flexio_uart_edma_handle_t structure
xfer UART eDMA transfer structure, see flexio_uart_transfer_t.

Return values

kStatus_Success if succeed, others failed.


kStatus_UART_RxBusy Previous transfer on going.

12.8.8.5.4 void FLEXIO_UART_TransferAbortSendEDMA ( FLEXIO_UART_Type ∗ base,


flexio_uart_edma_handle_t ∗ handle )

This function aborts sent data which using eDMA.


Parameters

base Pointer to FLEXIO_UART_Type


handle Pointer to flexio_uart_edma_handle_t structure

12.8.8.5.5 void FLEXIO_UART_TransferAbortReceiveEDMA ( FLEXIO_UART_Type ∗ base,


flexio_uart_edma_handle_t ∗ handle )

This function aborts the receive data which using eDMA.


Parameters

base Pointer to FLEXIO_UART_Type


handle Pointer to flexio_uart_edma_handle_t structure

12.8.8.5.6 status_t FLEXIO_UART_TransferGetSendCountEDMA ( FLEXIO_UART_Type ∗ base,


flexio_uart_edma_handle_t ∗ handle, size_t ∗ count )

This function gets the number of bytes sent out.

MCUXpresso SDK API Reference Manual


338 NXP Semiconductors
FlexIO UART Driver

Parameters

base Pointer to FLEXIO_UART_Type


handle Pointer to flexio_uart_edma_handle_t structure
count Number of bytes sent so far by the non-blocking transaction.

Return values

kStatus_NoTransferIn- transfer has finished or no transfer in progress.


Progress
kStatus_Success Successfully return the count.

12.8.8.5.7 status_t FLEXIO_UART_TransferGetReceiveCountEDMA ( FLEXIO_UART_Type ∗


base, flexio_uart_edma_handle_t ∗ handle, size_t ∗ count )

This function gets the number of bytes received.


Parameters

base Pointer to FLEXIO_UART_Type


handle Pointer to flexio_uart_edma_handle_t structure
count Number of bytes received so far by the non-blocking transaction.

Return values

kStatus_NoTransferIn- transfer has finished or no transfer in progress.


Progress
kStatus_Success Successfully return the count.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 339
FlexIO UART Driver

12.8.9 FlexIO DMA UART Driver

12.8.9.1 Overview

Data Structures
• struct flexio_uart_dma_handle_t
UART DMA handle. More...

Typedefs
• typedef void(∗ flexio_uart_dma_transfer_callback_t )(FLEXIO_UART_Type ∗base, flexio_uart_-
dma_handle_t ∗handle, status_t status, void ∗userData)
UART transfer callback function.

Driver version
• #define FSL_FLEXIO_UART_DMA_DRIVER_VERSION (MAKE_VERSION(2, 1, 4))
FlexIO UART DMA driver version 2.1.4.

eDMA transactional
• status_t FLEXIO_UART_TransferCreateHandleDMA (FLEXIO_UART_Type ∗base, flexio_uart-
_dma_handle_t ∗handle, flexio_uart_dma_transfer_callback_t callback, void ∗userData, dma_-
handle_t ∗txDmaHandle, dma_handle_t ∗rxDmaHandle)
Initializes the FLEXIO_UART handle which is used in transactional functions.
• status_t FLEXIO_UART_TransferSendDMA (FLEXIO_UART_Type ∗base, flexio_uart_dma_-
handle_t ∗handle, flexio_uart_transfer_t ∗xfer)
Sends data using DMA.
• status_t FLEXIO_UART_TransferReceiveDMA (FLEXIO_UART_Type ∗base, flexio_uart_dma_-
handle_t ∗handle, flexio_uart_transfer_t ∗xfer)
Receives data using DMA.
• void FLEXIO_UART_TransferAbortSendDMA (FLEXIO_UART_Type ∗base, flexio_uart_dma_-
handle_t ∗handle)
Aborts the sent data which using DMA.
• void FLEXIO_UART_TransferAbortReceiveDMA (FLEXIO_UART_Type ∗base, flexio_uart_-
dma_handle_t ∗handle)
Aborts the receive data which using DMA.
• status_t FLEXIO_UART_TransferGetSendCountDMA (FLEXIO_UART_Type ∗base, flexio_uart-
_dma_handle_t ∗handle, size_t ∗count)
Gets the number of bytes sent out.
• status_t FLEXIO_UART_TransferGetReceiveCountDMA (FLEXIO_UART_Type ∗base, flexio_-
uart_dma_handle_t ∗handle, size_t ∗count)
Gets the number of bytes received.

MCUXpresso SDK API Reference Manual


340 NXP Semiconductors
FlexIO UART Driver

12.8.9.2 Data Structure Documentation

12.8.9.2.1 struct _flexio_uart_dma_handle

Data Fields

• flexio_uart_dma_transfer_callback_t callback
Callback function.
• void ∗ userData
UART callback function parameter.
• size_t txDataSizeAll
Total bytes to be sent.
• size_t rxDataSizeAll
Total bytes to be received.
• dma_handle_t ∗ txDmaHandle
The DMA TX channel used.
• dma_handle_t ∗ rxDmaHandle
The DMA RX channel used.
• volatile uint8_t txState
TX transfer state.
• volatile uint8_t rxState
RX transfer state.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 341
FlexIO UART Driver

12.8.9.2.1.1 Field Documentation

12.8.9.2.1.1.1 flexio_uart_dma_transfer_callback_t flexio_uart_dma_handle_t::callback

12.8.9.2.1.1.2 void∗ flexio_uart_dma_handle_t::userData

12.8.9.2.1.1.3 size_t flexio_uart_dma_handle_t::txDataSizeAll

12.8.9.2.1.1.4 size_t flexio_uart_dma_handle_t::rxDataSizeAll

12.8.9.2.1.1.5 dma_handle_t∗ flexio_uart_dma_handle_t::txDmaHandle

12.8.9.2.1.1.6 dma_handle_t∗ flexio_uart_dma_handle_t::rxDmaHandle

12.8.9.2.1.1.7 volatile uint8_t flexio_uart_dma_handle_t::txState

12.8.9.3 Macro Definition Documentation

12.8.9.3.1 #define FSL_FLEXIO_UART_DMA_DRIVER_VERSION (MAKE_VERSION(2, 1, 4))

12.8.9.4 Typedef Documentation

12.8.9.4.1 typedef void(∗ flexio_uart_dma_transfer_callback_t)(FLEXIO_UART_Type ∗base,


flexio_uart_dma_handle_t ∗handle, status_t status, void ∗userData)

12.8.9.5 Function Documentation

12.8.9.5.1 status_t FLEXIO_UART_TransferCreateHandleDMA ( FLEXIO_UART_Type ∗ base,


flexio_uart_dma_handle_t ∗ handle, flexio_uart_dma_transfer_callback_t callback,
void ∗ userData, dma_handle_t ∗ txDmaHandle, dma_handle_t ∗ rxDmaHandle )

MCUXpresso SDK API Reference Manual


342 NXP Semiconductors
FlexIO UART Driver

Parameters

base Pointer to FLEXIO_UART_Type structure.


handle Pointer to flexio_uart_dma_handle_t structure.
callback FlexIO UART callback, NULL means no callback.
userData User callback function data.
txDmaHandle User requested DMA handle for TX DMA transfer.
rxDmaHandle User requested DMA handle for RX DMA transfer.

Return values

kStatus_Success Successfully create the handle.


kStatus_OutOfRange The FlexIO UART DMA type/handle table out of range.

12.8.9.5.2 status_t FLEXIO_UART_TransferSendDMA ( FLEXIO_UART_Type ∗ base,


flexio_uart_dma_handle_t ∗ handle, flexio_uart_transfer_t ∗ xfer )

This function send data using DMA. This is non-blocking function, which returns right away. When all
data is sent out, the send callback function is called.
Parameters

base Pointer to FLEXIO_UART_Type structure


handle Pointer to flexio_uart_dma_handle_t structure
xfer FLEXIO_UART DMA transfer structure, see flexio_uart_transfer_t.

Return values

kStatus_Success if succeed, others failed.


kStatus_FLEXIO_UART- Previous transfer on going.
_TxBusy

12.8.9.5.3 status_t FLEXIO_UART_TransferReceiveDMA ( FLEXIO_UART_Type ∗ base,


flexio_uart_dma_handle_t ∗ handle, flexio_uart_transfer_t ∗ xfer )

This function receives data using DMA. This is non-blocking function, which returns right away. When
all data is received, the receive callback function is called.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 343
FlexIO UART Driver

Parameters

base Pointer to FLEXIO_UART_Type structure


handle Pointer to flexio_uart_dma_handle_t structure
xfer FLEXIO_UART DMA transfer structure, see flexio_uart_transfer_t.

Return values

kStatus_Success if succeed, others failed.


kStatus_FLEXIO_UART- Previous transfer on going.
_RxBusy

12.8.9.5.4 void FLEXIO_UART_TransferAbortSendDMA ( FLEXIO_UART_Type ∗ base,


flexio_uart_dma_handle_t ∗ handle )

This function aborts the sent data which using DMA.


Parameters

base Pointer to FLEXIO_UART_Type structure


handle Pointer to flexio_uart_dma_handle_t structure

12.8.9.5.5 void FLEXIO_UART_TransferAbortReceiveDMA ( FLEXIO_UART_Type ∗ base,


flexio_uart_dma_handle_t ∗ handle )

This function aborts the receive data which using DMA.


Parameters

base Pointer to FLEXIO_UART_Type structure


handle Pointer to flexio_uart_dma_handle_t structure

12.8.9.5.6 status_t FLEXIO_UART_TransferGetSendCountDMA ( FLEXIO_UART_Type ∗ base,


flexio_uart_dma_handle_t ∗ handle, size_t ∗ count )

This function gets the number of bytes sent out.

MCUXpresso SDK API Reference Manual


344 NXP Semiconductors
FlexIO UART Driver

Parameters

base Pointer to FLEXIO_UART_Type structure


handle Pointer to flexio_uart_dma_handle_t structure
count Number of bytes sent so far by the non-blocking transaction.

Return values

kStatus_NoTransferIn- transfer has finished or no transfer in progress.


Progress
kStatus_Success Successfully return the count.

12.8.9.5.7 status_t FLEXIO_UART_TransferGetReceiveCountDMA ( FLEXIO_UART_Type ∗


base, flexio_uart_dma_handle_t ∗ handle, size_t ∗ count )

This function gets the number of bytes received.


Parameters

base Pointer to FLEXIO_UART_Type structure


handle Pointer to flexio_uart_dma_handle_t structure
count Number of bytes received so far by the non-blocking transaction.

Return values

kStatus_NoTransferIn- transfer has finished or no transfer in progress.


Progress
kStatus_Success Successfully return the count.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 345
FlexIO UART Driver

MCUXpresso SDK API Reference Manual


346 NXP Semiconductors
Chapter 13
GPIO: General-Purpose Input/Output Driver
13.1 Overview
Modules
• FGPIO Driver
• GPIO Driver

Data Structures
• struct gpio_pin_config_t
The GPIO pin configuration structure. More...

Enumerations
• enum gpio_pin_direction_t {
kGPIO_DigitalInput = 0U,
kGPIO_DigitalOutput = 1U }
GPIO direction definition.

Driver version
• #define FSL_GPIO_DRIVER_VERSION (MAKE_VERSION(2, 3, 2))
GPIO driver version 2.3.2.

13.2 Data Structure Documentation


13.2.1 struct gpio_pin_config_t

Each pin can only be configured as either an output pin or an input pin at a time. If configured as an input
pin, leave the outputConfig unused. Note that in some use cases, the corresponding port property should
be configured in advance with the PORT_SetPinConfig().

Data Fields

• gpio_pin_direction_t pinDirection
GPIO direction, input or output.
• uint8_t outputLogic
Set a default output logic, which has no use in input.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 347
Enumeration Type Documentation

13.3 Macro Definition Documentation


13.3.1 #define FSL_GPIO_DRIVER_VERSION (MAKE_VERSION(2, 3, 2))

13.4 Enumeration Type Documentation


13.4.1 enum gpio_pin_direction_t

Enumerator
kGPIO_DigitalInput Set current pin as digital input.
kGPIO_DigitalOutput Set current pin as digital output.

MCUXpresso SDK API Reference Manual


348 NXP Semiconductors
GPIO Driver

13.5 GPIO Driver


13.5.1 Overview

The MCUXpresso SDK provides a peripheral driver for the General-Purpose Input/Output (GPIO) module
of MCUXpresso SDK devices.

13.5.2 Typical use case

13.5.2.1 Output Operation

Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/gpio

13.5.2.2 Input Operation

Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/gpio

GPIO Configuration

• void GPIO_PinInit (GPIO_Type ∗base, uint32_t pin, const gpio_pin_config_t ∗config)


Initializes a GPIO pin used by the board.

GPIO Output Operations

• static void GPIO_PinWrite (GPIO_Type ∗base, uint32_t pin, uint8_t output)


Sets the output level of the multiple GPIO pins to the logic 1 or 0.
• static void GPIO_PortSet (GPIO_Type ∗base, uint32_t mask)
Sets the output level of the multiple GPIO pins to the logic 1.
• static void GPIO_PortClear (GPIO_Type ∗base, uint32_t mask)
Sets the output level of the multiple GPIO pins to the logic 0.
• static void GPIO_PortToggle (GPIO_Type ∗base, uint32_t mask)
Reverses the current output logic of the multiple GPIO pins.

GPIO Input Operations

• static uint32_t GPIO_PinRead (GPIO_Type ∗base, uint32_t pin)


Reads the current input value of the GPIO port.

GPIO Interrupt

• uint32_t GPIO_PortGetInterruptFlags (GPIO_Type ∗base)


Reads the GPIO port interrupt status flag.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 349
GPIO Driver

• void GPIO_PortClearInterruptFlags (GPIO_Type ∗base, uint32_t mask)


Clears multiple GPIO pin interrupt status flags.

13.5.3 Function Documentation

13.5.3.1 void GPIO_PinInit ( GPIO_Type ∗ base, uint32_t pin, const gpio_pin_config_t ∗


config )

To initialize the GPIO, define a pin configuration, as either input or output, in the user file. Then, call the
GPIO_PinInit() function.
This is an example to define an input pin or an output pin configuration.

* Define a digital input pin configuration,


* gpio_pin_config_t config =
* {
* kGPIO_DigitalInput,
* 0,
* }
* Define a digital output pin configuration,
* gpio_pin_config_t config =
* {
* kGPIO_DigitalOutput,
* 0,
* }
*

Parameters

base GPIO peripheral base pointer (GPIOA, GPIOB, GPIOC, and so on.)
pin GPIO port pin number
config GPIO pin configuration pointer

13.5.3.2 static void GPIO_PinWrite ( GPIO_Type ∗ base, uint32_t pin, uint8_t output )
[inline], [static]

Parameters

base GPIO peripheral base pointer (GPIOA, GPIOB, GPIOC, and so on.)
pin GPIO pin number

MCUXpresso SDK API Reference Manual


350 NXP Semiconductors
GPIO Driver

output GPIO pin output logic level.


• 0: corresponding pin output low-logic level.
• 1: corresponding pin output high-logic level.

13.5.3.3 static void GPIO_PortSet ( GPIO_Type ∗ base, uint32_t mask ) [inline],


[static]

Parameters

base GPIO peripheral base pointer (GPIOA, GPIOB, GPIOC, and so on.)
mask GPIO pin number macro

13.5.3.4 static void GPIO_PortClear ( GPIO_Type ∗ base, uint32_t mask ) [inline],


[static]

Parameters

base GPIO peripheral base pointer (GPIOA, GPIOB, GPIOC, and so on.)
mask GPIO pin number macro

13.5.3.5 static void GPIO_PortToggle ( GPIO_Type ∗ base, uint32_t mask ) [inline],


[static]

Parameters

base GPIO peripheral base pointer (GPIOA, GPIOB, GPIOC, and so on.)
mask GPIO pin number macro

13.5.3.6 static uint32_t GPIO_PinRead ( GPIO_Type ∗ base, uint32_t pin ) [inline],


[static]

Parameters

MCUXpresso SDK API Reference Manual


NXP Semiconductors 351
GPIO Driver

base GPIO peripheral base pointer (GPIOA, GPIOB, GPIOC, and so on.)
pin GPIO pin number

Return values

GPIO port input value


• 0: corresponding pin input low-logic level.
• 1: corresponding pin input high-logic level.

13.5.3.7 uint32_t GPIO_PortGetInterruptFlags ( GPIO_Type ∗ base )

If a pin is configured to generate the DMA request, the corresponding flag is cleared automatically at the
completion of the requested DMA transfer. Otherwise, the flag remains set until a logic one is written to
that flag. If configured for a level sensitive interrupt that remains asserted, the flag is set again immediately.
Parameters

base GPIO peripheral base pointer (GPIOA, GPIOB, GPIOC, and so on.)

Return values

The current GPIO port interrupt status flag, for example, 0x00010001 means
the pin 0 and 17 have the interrupt.

13.5.3.8 void GPIO_PortClearInterruptFlags ( GPIO_Type ∗ base, uint32_t mask )

Parameters

base GPIO peripheral base pointer (GPIOA, GPIOB, GPIOC, and so on.)
mask GPIO pin number macro

MCUXpresso SDK API Reference Manual


352 NXP Semiconductors
FGPIO Driver

13.6 FGPIO Driver


13.6.1 Overview

This chapter describes the programming interface of the FGPIO driver. The FGPIO driver configures the
FGPIO module and provides a functional interface to build the GPIO application.

Note
FGPIO (Fast GPIO) is only available in a few MCUs. FGPIO and GPIO share the same peripheral
but use different registers. FGPIO is closer to the core than the regular GPIO and it’s faster to read
and write.

13.6.2 Typical use case

13.6.2.1 Output Operation

Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/gpio

13.6.2.2 Input Operation

Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/gpio

FGPIO Configuration

• void FGPIO_PinInit (FGPIO_Type ∗base, uint32_t pin, const gpio_pin_config_t ∗config)


Initializes a FGPIO pin used by the board.

FGPIO Output Operations

• static void FGPIO_PinWrite (FGPIO_Type ∗base, uint32_t pin, uint8_t output)


Sets the output level of the multiple FGPIO pins to the logic 1 or 0.
• static void FGPIO_PortSet (FGPIO_Type ∗base, uint32_t mask)
Sets the output level of the multiple FGPIO pins to the logic 1.
• static void FGPIO_PortClear (FGPIO_Type ∗base, uint32_t mask)
Sets the output level of the multiple FGPIO pins to the logic 0.
• static void FGPIO_PortToggle (FGPIO_Type ∗base, uint32_t mask)
Reverses the current output logic of the multiple FGPIO pins.

FGPIO Input Operations

• static uint32_t FGPIO_PinRead (FGPIO_Type ∗base, uint32_t pin)


Reads the current input value of the FGPIO port.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 353
FGPIO Driver

FGPIO Interrupt

• uint32_t FGPIO_PortGetInterruptFlags (FGPIO_Type ∗base)


Reads the FGPIO port interrupt status flag.
• void FGPIO_PortClearInterruptFlags (FGPIO_Type ∗base, uint32_t mask)
Clears the multiple FGPIO pin interrupt status flag.

13.6.3 Function Documentation

13.6.3.1 void FGPIO_PinInit ( FGPIO_Type ∗ base, uint32_t pin, const gpio_pin_config_t


∗ config )

To initialize the FGPIO driver, define a pin configuration, as either input or output, in the user file. Then,
call the FGPIO_PinInit() function.
This is an example to define an input pin or an output pin configuration:

* Define a digital input pin configuration,


* gpio_pin_config_t config =
* {
* kGPIO_DigitalInput,
* 0,
* }
* Define a digital output pin configuration,
* gpio_pin_config_t config =
* {
* kGPIO_DigitalOutput,
* 0,
* }
*

Parameters

base FGPIO peripheral base pointer (FGPIOA, FGPIOB, FGPIOC, and so on.)
pin FGPIO port pin number
config FGPIO pin configuration pointer

13.6.3.2 static void FGPIO_PinWrite ( FGPIO_Type ∗ base, uint32_t pin, uint8_t output )
[inline], [static]

Parameters

MCUXpresso SDK API Reference Manual


354 NXP Semiconductors
FGPIO Driver

base FGPIO peripheral base pointer (FGPIOA, FGPIOB, FGPIOC, and so on.)
pin FGPIO pin number
output FGPIOpin output logic level.
• 0: corresponding pin output low-logic level.
• 1: corresponding pin output high-logic level.

13.6.3.3 static void FGPIO_PortSet ( FGPIO_Type ∗ base, uint32_t mask ) [inline],


[static]

Parameters

base FGPIO peripheral base pointer (FGPIOA, FGPIOB, FGPIOC, and so on.)
mask FGPIO pin number macro

13.6.3.4 static void FGPIO_PortClear ( FGPIO_Type ∗ base, uint32_t mask ) [inline],


[static]

Parameters

base FGPIO peripheral base pointer (FGPIOA, FGPIOB, FGPIOC, and so on.)
mask FGPIO pin number macro

13.6.3.5 static void FGPIO_PortToggle ( FGPIO_Type ∗ base, uint32_t mask )


[inline], [static]

Parameters

base FGPIO peripheral base pointer (FGPIOA, FGPIOB, FGPIOC, and so on.)
mask FGPIO pin number macro

13.6.3.6 static uint32_t FGPIO_PinRead ( FGPIO_Type ∗ base, uint32_t pin ) [inline],


[static]

MCUXpresso SDK API Reference Manual


NXP Semiconductors 355
FGPIO Driver

Parameters

base FGPIO peripheral base pointer (FGPIOA, FGPIOB, FGPIOC, and so on.)
pin FGPIO pin number

Return values

FGPIO port input value


• 0: corresponding pin input low-logic level.
• 1: corresponding pin input high-logic level.

13.6.3.7 uint32_t FGPIO_PortGetInterruptFlags ( FGPIO_Type ∗ base )

If a pin is configured to generate the DMA request, the corresponding flag is cleared automatically at the
completion of the requested DMA transfer. Otherwise, the flag remains set until a logic one is written to
that flag. If configured for a level-sensitive interrupt that remains asserted, the flag is set again immediately.
Parameters

base FGPIO peripheral base pointer (FGPIOA, FGPIOB, FGPIOC, and so on.)

Return values

The current FGPIO port interrupt status flags, for example, 0x00010001 means
the pin 0 and 17 have the interrupt.

13.6.3.8 void FGPIO_PortClearInterruptFlags ( FGPIO_Type ∗ base, uint32_t mask )

Parameters

base FGPIO peripheral base pointer (FGPIOA, FGPIOB, FGPIOC, and so on.)
mask FGPIO pin number macro

MCUXpresso SDK API Reference Manual


356 NXP Semiconductors
Chapter 14
I2C: Inter-Integrated Circuit Driver
14.1 Overview
Modules
• I2C DMA Driver
• I2C Driver
• I2C FreeRTOS Driver
• I2C eDMA Driver

MCUXpresso SDK API Reference Manual


NXP Semiconductors 357
I2C Driver

14.2 I2C Driver


14.2.1 Overview

The MCUXpresso SDK provides a peripheral driver for the Inter-Integrated Circuit (I2C) module of MC-
UXpresso SDK devices.
The I2C driver includes functional APIs and transactional APIs.
Functional APIs target the low-level APIs. Functional APIs can be used for the I2C master/slave initializa-
tion/configuration/operation for optimization/customization purpose. Using the functional APIs requires
knowing the I2C master peripheral and how to organize functional APIs to meet the application require-
ments. The I2C functional operation groups provide the functional APIs set.
Transactional APIs target the high-level APIs. The transactional APIs can be used to enable the periph-
eral quickly and also in the application if the code size and performance of transactional APIs satisfy
the requirements. If the code size and performance are critical requirements, see the transactional API
implementation and write custom code using the functional APIs or accessing the hardware registers.
Transactional APIs support asynchronous transfer. This means that the functions I2C_MasterTransfer-
NonBlocking() set up the interrupt non-blocking transfer. When the transfer completes, the upper layer is
notified through a callback function with the status.

14.2.2 Typical use case

14.2.2.1 Master Operation in functional method

Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/i2c

14.2.2.2 Master Operation in interrupt transactional method

Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/i2c

14.2.2.3 Master Operation in DMA transactional method

Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/i2c

14.2.2.4 Slave Operation in functional method

Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/i2c

14.2.2.5 Slave Operation in interrupt transactional method

Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/i2c

MCUXpresso SDK API Reference Manual


358 NXP Semiconductors
I2C Driver

Data Structures

• struct i2c_master_config_t
I2C master user configuration. More...
• struct i2c_slave_config_t
I2C slave user configuration. More...
• struct i2c_master_transfer_t
I2C master transfer structure. More...
• struct i2c_master_handle_t
I2C master handle structure. More...
• struct i2c_slave_transfer_t
I2C slave transfer structure. More...
• struct i2c_slave_handle_t
I2C slave handle structure. More...

Macros

• #define I2C_WAIT_TIMEOUT 0U /∗ Define to zero means keep waiting until the flag is as-
sert/deassert. ∗/
Timeout times for waiting flag.
• #define I2C_MASTER_FACK_CONTROL 0U /∗ Default defines to zero means master will send
ack automatically. ∗/
Mater Fast ack control, control if master needs to manually write ack, this is used to low the speed of
transfer for SoCs with feature FSL_FEATURE_I2C_HAS_DOUBLE_BUFFERING.

Typedefs

• typedef void(∗ i2c_master_transfer_callback_t )(I2C_Type ∗base, i2c_master_handle_t ∗handle,


status_t status, void ∗userData)
I2C master transfer callback typedef.
• typedef void(∗ i2c_slave_transfer_callback_t )(I2C_Type ∗base, i2c_slave_transfer_t ∗xfer, void
∗userData)
I2C slave transfer callback typedef.

Enumerations

• enum _i2c_status {
kStatus_I2C_Busy = MAKE_STATUS(kStatusGroup_I2C, 0),
kStatus_I2C_Idle = MAKE_STATUS(kStatusGroup_I2C, 1),
kStatus_I2C_Nak = MAKE_STATUS(kStatusGroup_I2C, 2),
kStatus_I2C_ArbitrationLost = MAKE_STATUS(kStatusGroup_I2C, 3),
kStatus_I2C_Timeout = MAKE_STATUS(kStatusGroup_I2C, 4),
kStatus_I2C_Addr_Nak = MAKE_STATUS(kStatusGroup_I2C, 5) }
I2C status return codes.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 359
I2C Driver

• enum _i2c_flags {
kI2C_ReceiveNakFlag = I2C_S_RXAK_MASK,
kI2C_IntPendingFlag = I2C_S_IICIF_MASK,
kI2C_TransferDirectionFlag = I2C_S_SRW_MASK,
kI2C_RangeAddressMatchFlag = I2C_S_RAM_MASK,
kI2C_ArbitrationLostFlag = I2C_S_ARBL_MASK,
kI2C_BusBusyFlag = I2C_S_BUSY_MASK,
kI2C_AddressMatchFlag = I2C_S_IAAS_MASK,
kI2C_TransferCompleteFlag = I2C_S_TCF_MASK,
kI2C_StopDetectFlag = I2C_FLT_STOPF_MASK << 8,
kI2C_StartDetectFlag = I2C_FLT_STARTF_MASK << 8 }
I2C peripheral flags.
• enum _i2c_interrupt_enable {
kI2C_GlobalInterruptEnable = I2C_C1_IICIE_MASK,
kI2C_StartStopDetectInterruptEnable = I2C_FLT_SSIE_MASK }
I2C feature interrupt source.
• enum i2c_direction_t {
kI2C_Write = 0x0U,
kI2C_Read = 0x1U }
The direction of master and slave transfers.
• enum i2c_slave_address_mode_t {
kI2C_Address7bit = 0x0U,
kI2C_RangeMatch = 0X2U }
Addressing mode.
• enum _i2c_master_transfer_flags {
kI2C_TransferDefaultFlag = 0x0U,
kI2C_TransferNoStartFlag = 0x1U,
kI2C_TransferRepeatedStartFlag = 0x2U,
kI2C_TransferNoStopFlag = 0x4U }
I2C transfer control flag.
• enum i2c_slave_transfer_event_t {
kI2C_SlaveAddressMatchEvent = 0x01U,
kI2C_SlaveTransmitEvent = 0x02U,
kI2C_SlaveReceiveEvent = 0x04U,
kI2C_SlaveTransmitAckEvent = 0x08U,
kI2C_SlaveStartEvent = 0x10U,
kI2C_SlaveCompletionEvent = 0x20U,
kI2C_SlaveGenaralcallEvent = 0x40U,
kI2C_SlaveAllEvents }
Set of events sent to the callback for nonblocking slave transfers.

Driver version

• #define FSL_I2C_DRIVER_VERSION (MAKE_VERSION(2, 0, 7))


I2C driver version 2.0.7.

MCUXpresso SDK API Reference Manual


360 NXP Semiconductors
I2C Driver

Initialization and deinitialization

• void I2C_MasterInit (I2C_Type ∗base, const i2c_master_config_t ∗masterConfig, uint32_t src-


Clock_Hz)
Initializes the I2C peripheral.
• void I2C_SlaveInit (I2C_Type ∗base, const i2c_slave_config_t ∗slaveConfig, uint32_t srcClock_-
Hz)
Initializes the I2C peripheral.
• void I2C_MasterDeinit (I2C_Type ∗base)
De-initializes the I2C master peripheral.
• void I2C_SlaveDeinit (I2C_Type ∗base)
De-initializes the I2C slave peripheral.
• uint32_t I2C_GetInstance (I2C_Type ∗base)
Get instance number for I2C module.
• void I2C_MasterGetDefaultConfig (i2c_master_config_t ∗masterConfig)
Sets the I2C master configuration structure to default values.
• void I2C_SlaveGetDefaultConfig (i2c_slave_config_t ∗slaveConfig)
Sets the I2C slave configuration structure to default values.
• static void I2C_Enable (I2C_Type ∗base, bool enable)
Enables or disables the I2C peripheral operation.

Status

• uint32_t I2C_MasterGetStatusFlags (I2C_Type ∗base)


Gets the I2C status flags.
• static uint32_t I2C_SlaveGetStatusFlags (I2C_Type ∗base)
Gets the I2C status flags.
• static void I2C_MasterClearStatusFlags (I2C_Type ∗base, uint32_t statusMask)
Clears the I2C status flag state.
• static void I2C_SlaveClearStatusFlags (I2C_Type ∗base, uint32_t statusMask)
Clears the I2C status flag state.

Interrupts

• void I2C_EnableInterrupts (I2C_Type ∗base, uint32_t mask)


Enables I2C interrupt requests.
• void I2C_DisableInterrupts (I2C_Type ∗base, uint32_t mask)
Disables I2C interrupt requests.

DMA Control

• static void I2C_EnableDMA (I2C_Type ∗base, bool enable)


Enables/disables the I2C DMA interrupt.
• static uint32_t I2C_GetDataRegAddr (I2C_Type ∗base)
Gets the I2C tx/rx data register address.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 361
I2C Driver

Bus Operations

• void I2C_MasterSetBaudRate (I2C_Type ∗base, uint32_t baudRate_Bps, uint32_t srcClock_Hz)


Sets the I2C master transfer baud rate.
• status_t I2C_MasterStart (I2C_Type ∗base, uint8_t address, i2c_direction_t direction)
Sends a START on the I2C bus.
• status_t I2C_MasterStop (I2C_Type ∗base)
Sends a STOP signal on the I2C bus.
• status_t I2C_MasterRepeatedStart (I2C_Type ∗base, uint8_t address, i2c_direction_t direction)
Sends a REPEATED START on the I2C bus.
• status_t I2C_MasterWriteBlocking (I2C_Type ∗base, const uint8_t ∗txBuff, size_t txSize, uint32_t
flags)
Performs a polling send transaction on the I2C bus.
• status_t I2C_MasterReadBlocking (I2C_Type ∗base, uint8_t ∗rxBuff, size_t rxSize, uint32_t flags)
Performs a polling receive transaction on the I2C bus.
• status_t I2C_SlaveWriteBlocking (I2C_Type ∗base, const uint8_t ∗txBuff, size_t txSize)
Performs a polling send transaction on the I2C bus.
• status_t I2C_SlaveReadBlocking (I2C_Type ∗base, uint8_t ∗rxBuff, size_t rxSize)
Performs a polling receive transaction on the I2C bus.
• status_t I2C_MasterTransferBlocking (I2C_Type ∗base, i2c_master_transfer_t ∗xfer)
Performs a master polling transfer on the I2C bus.

Transactional

• void I2C_MasterTransferCreateHandle (I2C_Type ∗base, i2c_master_handle_t ∗handle, i2c_-


master_transfer_callback_t callback, void ∗userData)
Initializes the I2C handle which is used in transactional functions.
• status_t I2C_MasterTransferNonBlocking (I2C_Type ∗base, i2c_master_handle_t ∗handle, i2c_-
master_transfer_t ∗xfer)
Performs a master interrupt non-blocking transfer on the I2C bus.
• status_t I2C_MasterTransferGetCount (I2C_Type ∗base, i2c_master_handle_t ∗handle, size_t
∗count)
Gets the master transfer status during a interrupt non-blocking transfer.
• status_t I2C_MasterTransferAbort (I2C_Type ∗base, i2c_master_handle_t ∗handle)
Aborts an interrupt non-blocking transfer early.
• void I2C_MasterTransferHandleIRQ (I2C_Type ∗base, void ∗i2cHandle)
Master interrupt handler.
• void I2C_SlaveTransferCreateHandle (I2C_Type ∗base, i2c_slave_handle_t ∗handle, i2c_slave_-
transfer_callback_t callback, void ∗userData)
Initializes the I2C handle which is used in transactional functions.
• status_t I2C_SlaveTransferNonBlocking (I2C_Type ∗base, i2c_slave_handle_t ∗handle, uint32_t
eventMask)
Starts accepting slave transfers.
• void I2C_SlaveTransferAbort (I2C_Type ∗base, i2c_slave_handle_t ∗handle)
Aborts the slave transfer.
• status_t I2C_SlaveTransferGetCount (I2C_Type ∗base, i2c_slave_handle_t ∗handle, size_t ∗count)
Gets the slave transfer remaining bytes during a interrupt non-blocking transfer.
• void I2C_SlaveTransferHandleIRQ (I2C_Type ∗base, void ∗i2cHandle)
Slave interrupt handler.

MCUXpresso SDK API Reference Manual


362 NXP Semiconductors
I2C Driver

14.2.3 Data Structure Documentation

14.2.3.1 struct i2c_master_config_t

Data Fields
• bool enableMaster
Enables the I2C peripheral at initialization time.
• bool enableStopHold
Controls the stop hold enable.
• uint32_t baudRate_Bps
Baud rate configuration of I2C peripheral.
• uint8_t glitchFilterWidth
Controls the width of the glitch.

14.2.3.1.0.1 Field Documentation

14.2.3.1.0.1.1 bool i2c_master_config_t::enableMaster

14.2.3.1.0.1.2 bool i2c_master_config_t::enableStopHold

14.2.3.1.0.1.3 uint32_t i2c_master_config_t::baudRate_Bps

14.2.3.1.0.1.4 uint8_t i2c_master_config_t::glitchFilterWidth

14.2.3.2 struct i2c_slave_config_t

Data Fields
• bool enableSlave
Enables the I2C peripheral at initialization time.
• bool enableGeneralCall
Enables the general call addressing mode.
• bool enableWakeUp
Enables/disables waking up MCU from low-power mode.
• bool enableBaudRateCtl
Enables/disables independent slave baud rate on SCL in very fast I2C modes.
• uint16_t slaveAddress
A slave address configuration.
• uint16_t upperAddress
A maximum boundary slave address used in a range matching mode.
• i2c_slave_address_mode_t addressingMode
An addressing mode configuration of i2c_slave_address_mode_config_t.
• uint32_t sclStopHoldTime_ns
the delay from the rising edge of SCL (I2C clock) to the rising edge of SDA (I2C data) while SCL is high
(stop condition), SDA hold time and SCL start hold time are also configured according to the SCL stop
hold time.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 363
I2C Driver

14.2.3.2.0.2 Field Documentation

14.2.3.2.0.2.1 bool i2c_slave_config_t::enableSlave

14.2.3.2.0.2.2 bool i2c_slave_config_t::enableGeneralCall

14.2.3.2.0.2.3 bool i2c_slave_config_t::enableWakeUp

14.2.3.2.0.2.4 bool i2c_slave_config_t::enableBaudRateCtl

14.2.3.2.0.2.5 uint16_t i2c_slave_config_t::slaveAddress

14.2.3.2.0.2.6 uint16_t i2c_slave_config_t::upperAddress

14.2.3.2.0.2.7 i2c_slave_address_mode_t i2c_slave_config_t::addressingMode

14.2.3.2.0.2.8 uint32_t i2c_slave_config_t::sclStopHoldTime_ns

14.2.3.3 struct i2c_master_transfer_t

Data Fields
• uint32_t flags
A transfer flag which controls the transfer.
• uint8_t slaveAddress
7-bit slave address.
• i2c_direction_t direction
A transfer direction, read or write.
• uint32_t subaddress
A sub address.
• uint8_t subaddressSize
A size of the command buffer.
• uint8_t ∗volatile data
A transfer buffer.
• volatile size_t dataSize
A transfer size.

14.2.3.3.0.3 Field Documentation

14.2.3.3.0.3.1 uint32_t i2c_master_transfer_t::flags

14.2.3.3.0.3.2 uint8_t i2c_master_transfer_t::slaveAddress

14.2.3.3.0.3.3 i2c_direction_t i2c_master_transfer_t::direction

14.2.3.3.0.3.4 uint32_t i2c_master_transfer_t::subaddress

Transferred MSB first.

MCUXpresso SDK API Reference Manual


364 NXP Semiconductors
I2C Driver

14.2.3.3.0.3.5 uint8_t i2c_master_transfer_t::subaddressSize

14.2.3.3.0.3.6 uint8_t∗ volatile i2c_master_transfer_t::data

14.2.3.3.0.3.7 volatile size_t i2c_master_transfer_t::dataSize

14.2.3.4 struct _i2c_master_handle

I2C master handle typedef.

Data Fields
• i2c_master_transfer_t transfer
I2C master transfer copy.
• size_t transferSize
Total bytes to be transferred.
• uint8_t state
A transfer state maintained during transfer.
• i2c_master_transfer_callback_t completionCallback
A callback function called when the transfer is finished.
• void ∗ userData
A callback parameter passed to the callback function.

14.2.3.4.0.4 Field Documentation

14.2.3.4.0.4.1 i2c_master_transfer_t i2c_master_handle_t::transfer

14.2.3.4.0.4.2 size_t i2c_master_handle_t::transferSize

14.2.3.4.0.4.3 uint8_t i2c_master_handle_t::state

14.2.3.4.0.4.4 i2c_master_transfer_callback_t i2c_master_handle_t::completionCallback

14.2.3.4.0.4.5 void∗ i2c_master_handle_t::userData

14.2.3.5 struct i2c_slave_transfer_t

Data Fields
• i2c_slave_transfer_event_t event
A reason that the callback is invoked.
• uint8_t ∗volatile data
A transfer buffer.
• volatile size_t dataSize
A transfer size.
• status_t completionStatus
Success or error code describing how the transfer completed.
• size_t transferredCount
A number of bytes actually transferred since the start or since the last repeated start.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 365
I2C Driver

14.2.3.5.0.5 Field Documentation

14.2.3.5.0.5.1 i2c_slave_transfer_event_t i2c_slave_transfer_t::event

14.2.3.5.0.5.2 uint8_t∗ volatile i2c_slave_transfer_t::data

14.2.3.5.0.5.3 volatile size_t i2c_slave_transfer_t::dataSize

14.2.3.5.0.5.4 status_t i2c_slave_transfer_t::completionStatus

Only applies for kI2C_SlaveCompletionEvent.

14.2.3.5.0.5.5 size_t i2c_slave_transfer_t::transferredCount

14.2.3.6 struct _i2c_slave_handle

I2C slave handle typedef.

Data Fields
• volatile bool isBusy
Indicates whether a transfer is busy.
• i2c_slave_transfer_t transfer
I2C slave transfer copy.
• uint32_t eventMask
A mask of enabled events.
• i2c_slave_transfer_callback_t callback
A callback function called at the transfer event.
• void ∗ userData
A callback parameter passed to the callback.

MCUXpresso SDK API Reference Manual


366 NXP Semiconductors
I2C Driver

14.2.3.6.0.6 Field Documentation

14.2.3.6.0.6.1 volatile bool i2c_slave_handle_t::isBusy

14.2.3.6.0.6.2 i2c_slave_transfer_t i2c_slave_handle_t::transfer

14.2.3.6.0.6.3 uint32_t i2c_slave_handle_t::eventMask

14.2.3.6.0.6.4 i2c_slave_transfer_callback_t i2c_slave_handle_t::callback

14.2.3.6.0.6.5 void∗ i2c_slave_handle_t::userData

14.2.4 Macro Definition Documentation

14.2.4.1 #define FSL_I2C_DRIVER_VERSION (MAKE_VERSION(2, 0, 7))

14.2.4.2 #define I2C_WAIT_TIMEOUT 0U /∗ Define to zero means keep waiting until the
flag is assert/deassert. ∗/

14.2.5 Typedef Documentation

14.2.5.1 typedef void(∗ i2c_master_transfer_callback_t)(I2C_Type ∗base,


i2c_master_handle_t ∗handle, status_t status, void ∗userData)

14.2.5.2 typedef void(∗ i2c_slave_transfer_callback_t)(I2C_Type ∗base,


i2c_slave_transfer_t ∗xfer, void ∗userData)

14.2.6 Enumeration Type Documentation

14.2.6.1 enum _i2c_status

Enumerator
kStatus_I2C_Busy I2C is busy with current transfer.
kStatus_I2C_Idle Bus is Idle.
kStatus_I2C_Nak NAK received during transfer.
kStatus_I2C_ArbitrationLost Arbitration lost during transfer.
kStatus_I2C_Timeout Timeout poling status flags.
kStatus_I2C_Addr_Nak NAK received during the address probe.

14.2.6.2 enum _i2c_flags

The following status register flags can be cleared:


• kI2C_ArbitrationLostFlag

MCUXpresso SDK API Reference Manual


NXP Semiconductors 367
I2C Driver

• kI2C_IntPendingFlag
• kI2C_StartDetectFlag
• kI2C_StopDetectFlag

Note
These enumerations are meant to be OR’d together to form a bit mask.

Enumerator
kI2C_ReceiveNakFlag I2C receive NAK flag.
kI2C_IntPendingFlag I2C interrupt pending flag.
kI2C_TransferDirectionFlag I2C transfer direction flag.
kI2C_RangeAddressMatchFlag I2C range address match flag.
kI2C_ArbitrationLostFlag I2C arbitration lost flag.
kI2C_BusBusyFlag I2C bus busy flag.
kI2C_AddressMatchFlag I2C address match flag.
kI2C_TransferCompleteFlag I2C transfer complete flag.
kI2C_StopDetectFlag I2C stop detect flag.
kI2C_StartDetectFlag I2C start detect flag.

14.2.6.3 enum _i2c_interrupt_enable

Enumerator
kI2C_GlobalInterruptEnable I2C global interrupt.
kI2C_StartStopDetectInterruptEnable I2C start&stop detect interrupt.

14.2.6.4 enum i2c_direction_t

Enumerator
kI2C_Write Master transmits to the slave.
kI2C_Read Master receives from the slave.

14.2.6.5 enum i2c_slave_address_mode_t

Enumerator
kI2C_Address7bit 7-bit addressing mode.
kI2C_RangeMatch Range address match addressing mode.

MCUXpresso SDK API Reference Manual


368 NXP Semiconductors
I2C Driver

14.2.6.6 enum _i2c_master_transfer_flags

Enumerator
kI2C_TransferDefaultFlag A transfer starts with a start signal, stops with a stop signal.
kI2C_TransferNoStartFlag A transfer starts without a start signal, only support write only or
write+read with no start flag, do not support read only with no start flag.
kI2C_TransferRepeatedStartFlag A transfer starts with a repeated start signal.
kI2C_TransferNoStopFlag A transfer ends without a stop signal.

14.2.6.7 enum i2c_slave_transfer_event_t

These event enumerations are used for two related purposes. First, a bit mask created by OR’ing together
events is passed to I2C_SlaveTransferNonBlocking() to specify which events to enable. Then, when the
slave callback is invoked, it is passed the current event through its transfer parameter.

Note
These enumerations are meant to be OR’d together to form a bit mask of events.

Enumerator
kI2C_SlaveAddressMatchEvent Received the slave address after a start or repeated start.
kI2C_SlaveTransmitEvent A callback is requested to provide data to transmit (slave-transmitter
role).
kI2C_SlaveReceiveEvent A callback is requested to provide a buffer in which to place received data
(slave-receiver role).
kI2C_SlaveTransmitAckEvent A callback needs to either transmit an ACK or NACK.
kI2C_SlaveStartEvent A start/repeated start was detected.
kI2C_SlaveCompletionEvent A stop was detected or finished transfer, completing the transfer.
kI2C_SlaveGenaralcallEvent Received the general call address after a start or repeated start.
kI2C_SlaveAllEvents A bit mask of all available events.

14.2.7 Function Documentation

14.2.7.1 void I2C_MasterInit ( I2C_Type ∗ base, const i2c_master_config_t ∗


masterConfig, uint32_t srcClock_Hz )

Call this API to ungate the I2C clock and configure the I2C with master configuration.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 369
I2C Driver

Note
This API should be called at the beginning of the application. Otherwise, any operation to the I2C
module can cause a hard fault because the clock is not enabled. The configuration structure can be
custom filled or it can be set with default values by using the I2C_MasterGetDefaultConfig(). After
calling this API, the master is ready to transfer. This is an example.
* i2c_master_config_t config = {
* .enableMaster = true,
* .enableStopHold = false,
* .highDrive = false,
* .baudRate_Bps = 100000,
* .glitchFilterWidth = 0
* };
* I2C_MasterInit(I2C0, &config, 12000000U);
*

Parameters

base I2C base pointer


masterConfig A pointer to the master configuration structure
srcClock_Hz I2C peripheral clock frequency in Hz

14.2.7.2 void I2C_SlaveInit ( I2C_Type ∗ base, const i2c_slave_config_t ∗ slaveConfig,


uint32_t srcClock_Hz )

Call this API to ungate the I2C clock and initialize the I2C with the slave configuration.

Note
This API should be called at the beginning of the application. Otherwise, any operation to the I2C
module can cause a hard fault because the clock is not enabled. The configuration structure can
partly be set with default values by I2C_SlaveGetDefaultConfig() or it can be custom filled by the
user. This is an example.
* i2c_slave_config_t config = {
* .enableSlave = true,
* .enableGeneralCall = false,
* .addressingMode = kI2C_Address7bit,
* .slaveAddress = 0x1DU,
* .enableWakeUp = false,
* .enablehighDrive = false,
* .enableBaudRateCtl = false,
* .sclStopHoldTime_ns = 4000
* };
* I2C_SlaveInit(I2C0, &config, 12000000U);
*

MCUXpresso SDK API Reference Manual


370 NXP Semiconductors
I2C Driver

Parameters

base I2C base pointer


slaveConfig A pointer to the slave configuration structure
srcClock_Hz I2C peripheral clock frequency in Hz

14.2.7.3 void I2C_MasterDeinit ( I2C_Type ∗ base )

Call this API to gate the I2C clock. The I2C master module can’t work unless the I2C_MasterInit is called.
Parameters

base I2C base pointer

14.2.7.4 void I2C_SlaveDeinit ( I2C_Type ∗ base )

Calling this API gates the I2C clock. The I2C slave module can’t work unless the I2C_SlaveInit is called
to enable the clock.
Parameters

base I2C base pointer

14.2.7.5 uint32_t I2C_GetInstance ( I2C_Type ∗ base )

Parameters

base I2C peripheral base address.

14.2.7.6 void I2C_MasterGetDefaultConfig ( i2c_master_config_t ∗ masterConfig )

The purpose of this API is to get the configuration structure initialized for use in the I2C_Master-
Configure(). Use the initialized structure unchanged in the I2C_MasterConfigure() or modify the structure
before calling the I2C_MasterConfigure(). This is an example.

* i2c_master_config_t config;
* I2C_MasterGetDefaultConfig(&config);
*

MCUXpresso SDK API Reference Manual


NXP Semiconductors 371
I2C Driver

Parameters

masterConfig A pointer to the master configuration structure.

14.2.7.7 void I2C_SlaveGetDefaultConfig ( i2c_slave_config_t ∗ slaveConfig )

The purpose of this API is to get the configuration structure initialized for use in the I2C_SlaveConfigure().
Modify fields of the structure before calling the I2C_SlaveConfigure(). This is an example.

* i2c_slave_config_t config;
* I2C_SlaveGetDefaultConfig(&config);
*

Parameters

slaveConfig A pointer to the slave configuration structure.

14.2.7.8 static void I2C_Enable ( I2C_Type ∗ base, bool enable ) [inline], [static]

Parameters

base I2C base pointer


enable Pass true to enable and false to disable the module.

14.2.7.9 uint32_t I2C_MasterGetStatusFlags ( I2C_Type ∗ base )

Parameters

base I2C base pointer

Returns
status flag, use status flag to AND _i2c_flags to get the related status.

14.2.7.10 static uint32_t I2C_SlaveGetStatusFlags ( I2C_Type ∗ base ) [inline],


[static]

MCUXpresso SDK API Reference Manual


372 NXP Semiconductors
I2C Driver

Parameters

base I2C base pointer

Returns
status flag, use status flag to AND _i2c_flags to get the related status.

14.2.7.11 static void I2C_MasterClearStatusFlags ( I2C_Type ∗ base, uint32_t statusMask


) [inline], [static]

The following status register flags can be cleared kI2C_ArbitrationLostFlag and kI2C_IntPendingFlag.
Parameters

base I2C base pointer


statusMask The status flag mask, defined in type i2c_status_flag_t. The parameter can be any
combination of the following values:
• kI2C_StartDetectFlag (if available)
• kI2C_StopDetectFlag (if available)
• kI2C_ArbitrationLostFlag
• kI2C_IntPendingFlagFlag

14.2.7.12 static void I2C_SlaveClearStatusFlags ( I2C_Type ∗ base, uint32_t statusMask


) [inline], [static]

The following status register flags can be cleared kI2C_ArbitrationLostFlag and kI2C_IntPendingFlag
Parameters

base I2C base pointer


statusMask The status flag mask, defined in type i2c_status_flag_t. The parameter can be any
combination of the following values:
• kI2C_StartDetectFlag (if available)
• kI2C_StopDetectFlag (if available)
• kI2C_ArbitrationLostFlag
• kI2C_IntPendingFlagFlag

14.2.7.13 void I2C_EnableInterrupts ( I2C_Type ∗ base, uint32_t mask )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 373
I2C Driver

Parameters

base I2C base pointer


mask interrupt source The parameter can be combination of the following source if defined:
• kI2C_GlobalInterruptEnable
• kI2C_StopDetectInterruptEnable/kI2C_StartDetectInterruptEnable
• kI2C_SdaTimeoutInterruptEnable

14.2.7.14 void I2C_DisableInterrupts ( I2C_Type ∗ base, uint32_t mask )

Parameters

base I2C base pointer


mask interrupt source The parameter can be combination of the following source if defined:
• kI2C_GlobalInterruptEnable
• kI2C_StopDetectInterruptEnable/kI2C_StartDetectInterruptEnable
• kI2C_SdaTimeoutInterruptEnable

14.2.7.15 static void I2C_EnableDMA ( I2C_Type ∗ base, bool enable ) [inline],


[static]

Parameters

base I2C base pointer


enable true to enable, false to disable

14.2.7.16 static uint32_t I2C_GetDataRegAddr ( I2C_Type ∗ base ) [inline],


[static]

This API is used to provide a transfer address for I2C DMA transfer configuration.
Parameters

MCUXpresso SDK API Reference Manual


374 NXP Semiconductors
I2C Driver

base I2C base pointer

Returns
data register address

14.2.7.17 void I2C_MasterSetBaudRate ( I2C_Type ∗ base, uint32_t baudRate_Bps,


uint32_t srcClock_Hz )

Parameters

base I2C base pointer


baudRate_Bps the baud rate value in bps
srcClock_Hz Source clock

14.2.7.18 status_t I2C_MasterStart ( I2C_Type ∗ base, uint8_t address, i2c_direction_t


direction )

This function is used to initiate a new master mode transfer by sending the START signal. The slave
address is sent following the I2C START signal.
Parameters

base I2C peripheral base pointer


address 7-bit slave device address.
direction Master transfer directions(transmit/receive).

Return values

kStatus_Success Successfully send the start signal.


kStatus_I2C_Busy Current bus is busy.

14.2.7.19 status_t I2C_MasterStop ( I2C_Type ∗ base )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 375
I2C Driver

Return values

kStatus_Success Successfully send the stop signal.


kStatus_I2C_Timeout Send stop signal failed, timeout.

14.2.7.20 status_t I2C_MasterRepeatedStart ( I2C_Type ∗ base, uint8_t address,


i2c_direction_t direction )

Parameters

base I2C peripheral base pointer


address 7-bit slave device address.
direction Master transfer directions(transmit/receive).

Return values

kStatus_Success Successfully send the start signal.


kStatus_I2C_Busy Current bus is busy but not occupied by current I2C master.

14.2.7.21 status_t I2C_MasterWriteBlocking ( I2C_Type ∗ base, const uint8_t ∗ txBuff,


size_t txSize, uint32_t flags )

Parameters

base The I2C peripheral base pointer.


txBuff The pointer to the data to be transferred.
txSize The length in bytes of the data to be transferred.
flags Transfer control flag to decide whether need to send a stop, use kI2C_Transfer-
DefaultFlag to issue a stop and kI2C_TransferNoStop to not send a stop.

Return values

kStatus_Success Successfully complete the data transmission.


kStatus_I2C_Arbitration- Transfer error, arbitration lost.
Lost

MCUXpresso SDK API Reference Manual


376 NXP Semiconductors
I2C Driver

kStataus_I2C_Nak Transfer error, receive NAK during transfer.

14.2.7.22 status_t I2C_MasterReadBlocking ( I2C_Type ∗ base, uint8_t ∗ rxBuff, size_t


rxSize, uint32_t flags )

Note
The I2C_MasterReadBlocking function stops the bus before reading the final byte. Without stopping
the bus prior for the final read, the bus issues another read, resulting in garbage data being read into
the data register.

Parameters

base I2C peripheral base pointer.


rxBuff The pointer to the data to store the received data.
rxSize The length in bytes of the data to be received.
flags Transfer control flag to decide whether need to send a stop, use kI2C_Transfer-
DefaultFlag to issue a stop and kI2C_TransferNoStop to not send a stop.

Return values

kStatus_Success Successfully complete the data transmission.


kStatus_I2C_Timeout Send stop signal failed, timeout.

14.2.7.23 status_t I2C_SlaveWriteBlocking ( I2C_Type ∗ base, const uint8_t ∗ txBuff,


size_t txSize )

Parameters

base The I2C peripheral base pointer.


txBuff The pointer to the data to be transferred.
txSize The length in bytes of the data to be transferred.

Return values

MCUXpresso SDK API Reference Manual


NXP Semiconductors 377
I2C Driver

kStatus_Success Successfully complete the data transmission.


kStatus_I2C_Arbitration- Transfer error, arbitration lost.
Lost
kStataus_I2C_Nak Transfer error, receive NAK during transfer.

14.2.7.24 status_t I2C_SlaveReadBlocking ( I2C_Type ∗ base, uint8_t ∗ rxBuff, size_t


rxSize )

Parameters

base I2C peripheral base pointer.


rxBuff The pointer to the data to store the received data.
rxSize The length in bytes of the data to be received.

Return values

kStatus_Success Successfully complete data receive.


kStatus_I2C_Timeout Wait status flag timeout.

14.2.7.25 status_t I2C_MasterTransferBlocking ( I2C_Type ∗ base, i2c_master_transfer_t


∗ xfer )
Note
The API does not return until the transfer succeeds or fails due to arbitration lost or receiving a NAK.

Parameters

base I2C peripheral base address.


xfer Pointer to the transfer structure.

Return values

kStatus_Success Successfully complete the data transmission.

MCUXpresso SDK API Reference Manual


378 NXP Semiconductors
I2C Driver

kStatus_I2C_Busy Previous transmission still not finished.


kStatus_I2C_Timeout Transfer error, wait signal timeout.
kStatus_I2C_Arbitration- Transfer error, arbitration lost.
Lost
kStataus_I2C_Nak Transfer error, receive NAK during transfer.

14.2.7.26 void I2C_MasterTransferCreateHandle ( I2C_Type ∗ base, i2c_master_handle_t


∗ handle, i2c_master_transfer_callback_t callback, void ∗ userData )

Parameters

base I2C base pointer.


handle pointer to i2c_master_handle_t structure to store the transfer state.
callback pointer to user callback function.
userData user parameter passed to the callback function.

14.2.7.27 status_t I2C_MasterTransferNonBlocking ( I2C_Type ∗ base,


i2c_master_handle_t ∗ handle, i2c_master_transfer_t ∗ xfer )

Note
Calling the API returns immediately after transfer initiates. The user needs to call I2C_MasterGet-
TransferCount to poll the transfer status to check whether the transfer is finished. If the return status
is not kStatus_I2C_Busy, the transfer is finished.

Parameters

base I2C base pointer.


handle pointer to i2c_master_handle_t structure which stores the transfer state.
xfer pointer to i2c_master_transfer_t structure.

Return values

kStatus_Success Successfully start the data transmission.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 379
I2C Driver

kStatus_I2C_Busy Previous transmission still not finished.


kStatus_I2C_Timeout Transfer error, wait signal timeout.

14.2.7.28 status_t I2C_MasterTransferGetCount ( I2C_Type ∗ base, i2c_master_handle_t


∗ handle, size_t ∗ count )

Parameters

base I2C base pointer.


handle pointer to i2c_master_handle_t structure which stores the transfer state.
count Number of bytes transferred so far by the non-blocking transaction.

Return values

kStatus_InvalidArgument count is Invalid.


kStatus_Success Successfully return the count.

14.2.7.29 status_t I2C_MasterTransferAbort ( I2C_Type ∗ base, i2c_master_handle_t ∗


handle )

Note
This API can be called at any time when an interrupt non-blocking transfer initiates to abort the
transfer early.

Parameters

base I2C base pointer.


handle pointer to i2c_master_handle_t structure which stores the transfer state

Return values

kStatus_I2C_Timeout Timeout during polling flag.


kStatus_Success Successfully abort the transfer.

14.2.7.30 void I2C_MasterTransferHandleIRQ ( I2C_Type ∗ base, void ∗ i2cHandle )

MCUXpresso SDK API Reference Manual


380 NXP Semiconductors
I2C Driver

Parameters

base I2C base pointer.


i2cHandle pointer to i2c_master_handle_t structure.

14.2.7.31 void I2C_SlaveTransferCreateHandle ( I2C_Type ∗ base, i2c_slave_handle_t ∗


handle, i2c_slave_transfer_callback_t callback, void ∗ userData )

Parameters

base I2C base pointer.


handle pointer to i2c_slave_handle_t structure to store the transfer state.
callback pointer to user callback function.
userData user parameter passed to the callback function.

14.2.7.32 status_t I2C_SlaveTransferNonBlocking ( I2C_Type ∗ base, i2c_slave_handle_t


∗ handle, uint32_t eventMask )

Call this API after calling the I2C_SlaveInit() and I2C_SlaveTransferCreateHandle() to start processing
transactions driven by an I2C master. The slave monitors the I2C bus and passes events to the callback
that was passed into the call to I2C_SlaveTransferCreateHandle(). The callback is always invoked from
the interrupt context.
The set of events received by the callback is customizable. To do so, set the eventMask parameter to the
OR’d combination of i2c_slave_transfer_event_t enumerators for the events you wish to receive. The k-
I2C_SlaveTransmitEvent and #kLPI2C_SlaveReceiveEvent events are always enabled and do not need to
be included in the mask. Alternatively, pass 0 to get a default set of only the transmit and receive events
that are always enabled. In addition, the kI2C_SlaveAllEvents constant is provided as a convenient way
to enable all events.
Parameters

base The I2C peripheral base address.


handle Pointer to #i2c_slave_handle_t structure which stores the transfer state.
eventMask Bit mask formed by OR’ing together i2c_slave_transfer_event_t enumerators to spec-
ify which events to send to the callback. Other accepted values are 0 to get a default
set of only the transmit and receive events, and kI2C_SlaveAllEvents to enable all
events.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 381
I2C Driver

Return values

#kStatus_Success Slave transfers were successfully started.


kStatus_I2C_Busy Slave transfers have already been started on this handle.

14.2.7.33 void I2C_SlaveTransferAbort ( I2C_Type ∗ base, i2c_slave_handle_t ∗ handle )

Note
This API can be called at any time to stop slave for handling the bus events.

Parameters

base I2C base pointer.


handle pointer to i2c_slave_handle_t structure which stores the transfer state.

14.2.7.34 status_t I2C_SlaveTransferGetCount ( I2C_Type ∗ base, i2c_slave_handle_t ∗


handle, size_t ∗ count )

Parameters

base I2C base pointer.


handle pointer to i2c_slave_handle_t structure.
count Number of bytes transferred so far by the non-blocking transaction.

Return values

kStatus_InvalidArgument count is Invalid.


kStatus_Success Successfully return the count.

14.2.7.35 void I2C_SlaveTransferHandleIRQ ( I2C_Type ∗ base, void ∗ i2cHandle )

Parameters

MCUXpresso SDK API Reference Manual


382 NXP Semiconductors
I2C Driver

base I2C base pointer.


i2cHandle pointer to i2c_slave_handle_t structure which stores the transfer state

MCUXpresso SDK API Reference Manual


NXP Semiconductors 383
I2C eDMA Driver

14.3 I2C eDMA Driver


14.3.1 Overview

Data Structures

• struct i2c_master_edma_handle_t
I2C master eDMA transfer structure. More...

Typedefs

• typedef void(∗ i2c_master_edma_transfer_callback_t )(I2C_Type ∗base, i2c_master_edma_handle-


_t ∗handle, status_t status, void ∗userData)
I2C master eDMA transfer callback typedef.

Driver version

• #define FSL_I2C_EDMA_DRIVER_VERSION (MAKE_VERSION(2, 0, 7))


I2C EDMA driver version 2.0.7.

I2C Block eDMA Transfer Operation

• void I2C_MasterCreateEDMAHandle (I2C_Type ∗base, i2c_master_edma_handle_t ∗handle, i2c_-


master_edma_transfer_callback_t callback, void ∗userData, edma_handle_t ∗edmaHandle)
Initializes the I2C handle which is used in transactional functions.
• status_t I2C_MasterTransferEDMA (I2C_Type ∗base, i2c_master_edma_handle_t ∗handle, i2c_-
master_transfer_t ∗xfer)
Performs a master eDMA non-blocking transfer on the I2C bus.
• status_t I2C_MasterTransferGetCountEDMA (I2C_Type ∗base, i2c_master_edma_handle_-
t ∗handle, size_t ∗count)
Gets a master transfer status during the eDMA non-blocking transfer.
• void I2C_MasterTransferAbortEDMA (I2C_Type ∗base, i2c_master_edma_handle_t ∗handle)
Aborts a master eDMA non-blocking transfer early.

14.3.2 Data Structure Documentation

14.3.2.1 struct _i2c_master_edma_handle

I2C master eDMA handle typedef.

Data Fields
• i2c_master_transfer_t transfer

MCUXpresso SDK API Reference Manual


384 NXP Semiconductors
I2C eDMA Driver

I2C master transfer structure.


• size_t transferSize
Total bytes to be transferred.
• uint8_t nbytes
eDMA minor byte transfer count initially configured.
• uint8_t state
I2C master transfer status.
• edma_handle_t ∗ dmaHandle
The eDMA handler used.
• i2c_master_edma_transfer_callback_t completionCallback
A callback function called after the eDMA transfer is finished.
• void ∗ userData
A callback parameter passed to the callback function.

14.3.2.1.0.7 Field Documentation

14.3.2.1.0.7.1 i2c_master_transfer_t i2c_master_edma_handle_t::transfer

14.3.2.1.0.7.2 size_t i2c_master_edma_handle_t::transferSize

14.3.2.1.0.7.3 uint8_t i2c_master_edma_handle_t::nbytes

14.3.2.1.0.7.4 uint8_t i2c_master_edma_handle_t::state

14.3.2.1.0.7.5 edma_handle_t∗ i2c_master_edma_handle_t::dmaHandle

14.3.2.1.0.7.6 i2c_master_edma_transfer_callback_t i2c_master_edma_handle_t::completion-


Callback

14.3.2.1.0.7.7 void∗ i2c_master_edma_handle_t::userData

14.3.3 Macro Definition Documentation

14.3.3.1 #define FSL_I2C_EDMA_DRIVER_VERSION (MAKE_VERSION(2, 0, 7))

14.3.4 Typedef Documentation

14.3.4.1 typedef void(∗ i2c_master_edma_transfer_callback_t)(I2C_Type ∗base,


i2c_master_edma_handle_t ∗handle, status_t status, void ∗userData)

14.3.5 Function Documentation

14.3.5.1 void I2C_MasterCreateEDMAHandle ( I2C_Type ∗ base, i2c_master_edma_-


handle_t ∗ handle, i2c_master_edma_transfer_callback_t callback, void ∗
userData, edma_handle_t ∗ edmaHandle )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 385
I2C eDMA Driver

Parameters

base I2C peripheral base address.


handle A pointer to the i2c_master_edma_handle_t structure.
callback A pointer to the user callback function.
userData A user parameter passed to the callback function.
edmaHandle eDMA handle pointer.

14.3.5.2 status_t I2C_MasterTransferEDMA ( I2C_Type ∗ base, i2c_-


master_edma_handle_t ∗ handle, i2c_master_transfer_t ∗ xfer
)

Parameters

base I2C peripheral base address.


handle A pointer to the i2c_master_edma_handle_t structure.
xfer A pointer to the transfer structure of i2c_master_transfer_t.

Return values

kStatus_Success Successfully completed the data transmission.


kStatus_I2C_Busy A previous transmission is still not finished.
kStatus_I2C_Timeout Transfer error, waits for a signal timeout.
kStatus_I2C_Arbitration- Transfer error, arbitration lost.
Lost
kStataus_I2C_Nak Transfer error, receive NAK during transfer.

14.3.5.3 status_t I2C_MasterTransferGetCountEDMA ( I2C_Type ∗ base,


i2c_master_edma_handle_t ∗ handle, size_t ∗ count )

Parameters

base I2C peripheral base address.

MCUXpresso SDK API Reference Manual


386 NXP Semiconductors
I2C eDMA Driver

handle A pointer to the i2c_master_edma_handle_t structure.


count A number of bytes transferred by the non-blocking transaction.

14.3.5.4 void I2C_MasterTransferAbortEDMA ( I2C_Type ∗ base, i2c_master_edma_-


handle_t ∗ handle )

Parameters

base I2C peripheral base address.


handle A pointer to the i2c_master_edma_handle_t structure.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 387
I2C DMA Driver

14.4 I2C DMA Driver


14.4.1 Overview

Data Structures

• struct i2c_master_dma_handle_t
I2C master DMA transfer structure. More...

Typedefs

• typedef void(∗ i2c_master_dma_transfer_callback_t )(I2C_Type ∗base, i2c_master_dma_handle_t


∗handle, status_t status, void ∗userData)
I2C master DMA transfer callback typedef.

Driver version

• #define FSL_I2C_DMA_DRIVER_VERSION (MAKE_VERSION(2, 0, 7))


I2C DMA driver version 2.0.5.

I2C Block DMA Transfer Operation

• void I2C_MasterTransferCreateHandleDMA (I2C_Type ∗base, i2c_master_dma_handle_t ∗handle,


i2c_master_dma_transfer_callback_t callback, void ∗userData, dma_handle_t ∗dmaHandle)
Initializes the I2C handle which is used in transactional functions.
• status_t I2C_MasterTransferDMA (I2C_Type ∗base, i2c_master_dma_handle_t ∗handle, i2c_-
master_transfer_t ∗xfer)
Performs a master DMA non-blocking transfer on the I2C bus.
• status_t I2C_MasterTransferGetCountDMA (I2C_Type ∗base, i2c_master_dma_handle_t ∗handle,
size_t ∗count)
Gets a master transfer status during a DMA non-blocking transfer.
• void I2C_MasterTransferAbortDMA (I2C_Type ∗base, i2c_master_dma_handle_t ∗handle)
Aborts a master DMA non-blocking transfer early.

14.4.2 Data Structure Documentation

14.4.2.1 struct _i2c_master_dma_handle

I2C master DMA handle typedef.

Data Fields
• i2c_master_transfer_t transfer

MCUXpresso SDK API Reference Manual


388 NXP Semiconductors
I2C DMA Driver

I2C master transfer struct.


• size_t transferSize
Total bytes to be transferred.
• uint8_t state
I2C master transfer status.
• dma_handle_t ∗ dmaHandle
The DMA handler used.
• i2c_master_dma_transfer_callback_t completionCallback
A callback function called after the DMA transfer finished.
• void ∗ userData
A callback parameter passed to the callback function.

14.4.2.1.0.8 Field Documentation

14.4.2.1.0.8.1 i2c_master_transfer_t i2c_master_dma_handle_t::transfer

14.4.2.1.0.8.2 size_t i2c_master_dma_handle_t::transferSize

14.4.2.1.0.8.3 uint8_t i2c_master_dma_handle_t::state

14.4.2.1.0.8.4 dma_handle_t∗ i2c_master_dma_handle_t::dmaHandle

14.4.2.1.0.8.5 i2c_master_dma_transfer_callback_t i2c_master_dma_handle_t::completion-


Callback

14.4.2.1.0.8.6 void∗ i2c_master_dma_handle_t::userData

14.4.3 Macro Definition Documentation

14.4.3.1 #define FSL_I2C_DMA_DRIVER_VERSION (MAKE_VERSION(2, 0, 7))

14.4.4 Typedef Documentation

14.4.4.1 typedef void(∗ i2c_master_dma_transfer_callback_t)(I2C_Type ∗base,


i2c_master_dma_handle_t ∗handle, status_t status, void ∗userData)

14.4.5 Function Documentation

14.4.5.1 void I2C_MasterTransferCreateHandleDMA ( I2C_Type ∗ base,


i2c_master_dma_handle_t ∗ handle, i2c_master_dma_transfer_callback_t
callback, void ∗ userData, dma_handle_t ∗ dmaHandle )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 389
I2C DMA Driver

Parameters

base I2C peripheral base address


handle Pointer to the i2c_master_dma_handle_t structure
callback Pointer to the user callback function
userData A user parameter passed to the callback function
dmaHandle DMA handle pointer

14.4.5.2 status_t I2C_MasterTransferDMA ( I2C_Type ∗ base, i2c_master_dma_handle_t


∗ handle, i2c_master_transfer_t ∗ xfer )

Parameters

base I2C peripheral base address


handle A pointer to the i2c_master_dma_handle_t structure
xfer A pointer to the transfer structure of the i2c_master_transfer_t

Return values

kStatus_Success Successfully completes the data transmission.


kStatus_I2C_Busy A previous transmission is still not finished.
kStatus_I2C_Timeout A transfer error, waits for the signal timeout.
kStatus_I2C_Arbitration- A transfer error, arbitration lost.
Lost
kStataus_I2C_Nak A transfer error, receives NAK during transfer.

14.4.5.3 status_t I2C_MasterTransferGetCountDMA ( I2C_Type ∗ base,


i2c_master_dma_handle_t ∗ handle, size_t ∗ count )

Parameters

base I2C peripheral base address


handle A pointer to the i2c_master_dma_handle_t structure

MCUXpresso SDK API Reference Manual


390 NXP Semiconductors
I2C DMA Driver

count A number of bytes transferred so far by the non-blocking transaction.

14.4.5.4 void I2C_MasterTransferAbortDMA ( I2C_Type ∗ base, i2c_master_dma_handle_t


∗ handle )

Parameters

base I2C peripheral base address


handle A pointer to the i2c_master_dma_handle_t structure.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 391
I2C FreeRTOS Driver

14.5 I2C FreeRTOS Driver


14.5.1 Overview

Driver version

• #define FSL_I2C_FREERTOS_DRIVER_VERSION (MAKE_VERSION(2, 0, 7))


I2C freertos driver version 2.0.5.

I2C RTOS Operation

• status_t I2C_RTOS_Init (i2c_rtos_handle_t ∗handle, I2C_Type ∗base, const i2c_master_config_t


∗masterConfig, uint32_t srcClock_Hz)
Initializes I2C.
• status_t I2C_RTOS_Deinit (i2c_rtos_handle_t ∗handle)
Deinitializes the I2C.
• status_t I2C_RTOS_Transfer (i2c_rtos_handle_t ∗handle, i2c_master_transfer_t ∗transfer)
Performs the I2C transfer.

14.5.2 Macro Definition Documentation

14.5.2.1 #define FSL_I2C_FREERTOS_DRIVER_VERSION (MAKE_VERSION(2, 0, 7))

14.5.3 Function Documentation

14.5.3.1 status_t I2C_RTOS_Init ( i2c_rtos_handle_t ∗ handle, I2C_Type ∗ base, const


i2c_master_config_t ∗ masterConfig, uint32_t srcClock_Hz )

This function initializes the I2C module and the related RTOS context.
Parameters

handle The RTOS I2C handle, the pointer to an allocated space for RTOS context.
base The pointer base address of the I2C instance to initialize.
masterConfig The configuration structure to set-up I2C in master mode.
srcClock_Hz The frequency of an input clock of the I2C module.

Returns
status of the operation.

MCUXpresso SDK API Reference Manual


392 NXP Semiconductors
I2C FreeRTOS Driver

14.5.3.2 status_t I2C_RTOS_Deinit ( i2c_rtos_handle_t ∗ handle )

This function deinitializes the I2C module and the related RTOS context.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 393
I2C FreeRTOS Driver

Parameters

handle The RTOS I2C handle.

14.5.3.3 status_t I2C_RTOS_Transfer ( i2c_rtos_handle_t ∗ handle, i2c_master_transfer_t


∗ transfer )

This function performs the I2C transfer according to the data given in the transfer structure.
Parameters

handle The RTOS I2C handle.


transfer A structure specifying the transfer parameters.

Returns
status of the operation.

MCUXpresso SDK API Reference Manual


394 NXP Semiconductors
Chapter 15
LLWU: Low-Leakage Wakeup Unit Driver
15.1 Overview
The MCUXpresso SDK provides a peripheral driver for the Low-Leakage Wakeup Unit (LLWU) module
of MCUXpresso SDK devices. The LLWU module allows the user to select external pin sources and
internal modules as a wake-up source from low-leakage power modes.

15.2 External wakeup pins configurations


Configures the external wakeup pins’ working modes, gets, and clears the wake pin flags. External wakeup
pins are accessed by the pinIndex, which is started from 1. Numbers of the external pins depend on the
SoC configuration.

15.3 Internal wakeup modules configurations


Enables/disables the internal wakeup modules and gets the module flags. Internal modules are accessed
by moduleIndex, which is started from 1. Numbers of external pins depend the on SoC configuration.

15.4 Digital pin filter for external wakeup pin configurations


Configures the digital pin filter of the external wakeup pins’ working modes, gets, and clears the pin filter
flags. Digital pin filters are accessed by the filterIndex, which is started from 1. Numbers of external
pins depend on the SoC configuration.

Data Structures
• struct llwu_external_pin_filter_mode_t
An external input pin filter control structure. More...

Enumerations
• enum llwu_external_pin_mode_t {
kLLWU_ExternalPinDisable = 0U,
kLLWU_ExternalPinRisingEdge = 1U,
kLLWU_ExternalPinFallingEdge = 2U,
kLLWU_ExternalPinAnyEdge = 3U }
External input pin control modes.
• enum llwu_pin_filter_mode_t {
kLLWU_PinFilterDisable = 0U,
kLLWU_PinFilterRisingEdge = 1U,
kLLWU_PinFilterFallingEdge = 2U,
kLLWU_PinFilterAnyEdge = 3U }
Digital filter control modes.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 395
Enumeration Type Documentation

Driver version
• #define FSL_LLWU_DRIVER_VERSION (MAKE_VERSION(2, 0, 2))
LLWU driver version 2.0.2.

Low-Leakage Wakeup Unit Control APIs


• void LLWU_SetExternalWakeupPinMode (LLWU_Type ∗base, uint32_t pinIndex, llwu_external-
_pin_mode_t pinMode)
Sets the external input pin source mode.
• bool LLWU_GetExternalWakeupPinFlag (LLWU_Type ∗base, uint32_t pinIndex)
Gets the external wakeup source flag.
• void LLWU_ClearExternalWakeupPinFlag (LLWU_Type ∗base, uint32_t pinIndex)
Clears the external wakeup source flag.
• static void LLWU_EnableInternalModuleInterruptWakup (LLWU_Type ∗base, uint32_t module-
Index, bool enable)
Enables/disables the internal module source.
• static bool LLWU_GetInternalWakeupModuleFlag (LLWU_Type ∗base, uint32_t moduleIndex)
Gets the external wakeup source flag.
• void LLWU_SetPinFilterMode (LLWU_Type ∗base, uint32_t filterIndex, llwu_external_pin_filter-
_mode_t filterMode)
Sets the pin filter configuration.
• bool LLWU_GetPinFilterFlag (LLWU_Type ∗base, uint32_t filterIndex)
Gets the pin filter configuration.
• void LLWU_ClearPinFilterFlag (LLWU_Type ∗base, uint32_t filterIndex)
Clears the pin filter configuration.
• #define INTERNAL_WAKEUP_MODULE_FLAG_REG F3

15.5 Data Structure Documentation


15.5.1 struct llwu_external_pin_filter_mode_t

Data Fields

• uint32_t pinIndex
A pin number.
• llwu_pin_filter_mode_t filterMode
Filter mode.

15.6 Macro Definition Documentation


15.6.1 #define FSL_LLWU_DRIVER_VERSION (MAKE_VERSION(2, 0, 2))

15.7 Enumeration Type Documentation


15.7.1 enum llwu_external_pin_mode_t

Enumerator
kLLWU_ExternalPinDisable Pin disabled as a wakeup input.

MCUXpresso SDK API Reference Manual


396 NXP Semiconductors
Function Documentation

kLLWU_ExternalPinRisingEdge Pin enabled with the rising edge detection.


kLLWU_ExternalPinFallingEdge Pin enabled with the falling edge detection.
kLLWU_ExternalPinAnyEdge Pin enabled with any change detection.

15.7.2 enum llwu_pin_filter_mode_t

Enumerator
kLLWU_PinFilterDisable Filter disabled.
kLLWU_PinFilterRisingEdge Filter positive edge detection.
kLLWU_PinFilterFallingEdge Filter negative edge detection.
kLLWU_PinFilterAnyEdge Filter any edge detection.

15.8 Function Documentation


15.8.1 void LLWU_SetExternalWakeupPinMode ( LLWU_Type ∗ base, uint32_t
pinIndex, llwu_external_pin_mode_t pinMode )

This function sets the external input pin source mode that is used as a wake up source.
Parameters

base LLWU peripheral base address.


pinIndex A pin index to be enabled as an external wakeup source starting from 1.
pinMode A pin configuration mode defined in the llwu_external_pin_modes_t.

15.8.2 bool LLWU_GetExternalWakeupPinFlag ( LLWU_Type ∗ base, uint32_t


pinIndex )

This function checks the external pin flag to detect whether the MCU is woken up by the specific pin.
Parameters

base LLWU peripheral base address.


pinIndex A pin index, which starts from 1.

Returns
True if the specific pin is a wakeup source.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 397
Function Documentation

15.8.3 void LLWU_ClearExternalWakeupPinFlag ( LLWU_Type ∗ base, uint32_t


pinIndex )

This function clears the external wakeup source flag for a specific pin.

MCUXpresso SDK API Reference Manual


398 NXP Semiconductors
Function Documentation

Parameters

base LLWU peripheral base address.


pinIndex A pin index, which starts from 1.

15.8.4 static void LLWU_EnableInternalModuleInterruptWakup ( LLWU_Type ∗


base, uint32_t moduleIndex, bool enable ) [inline], [static]

This function enables/disables the internal module source mode that is used as a wake up source.
Parameters

base LLWU peripheral base address.


moduleIndex A module index to be enabled as an internal wakeup source starting from 1.
enable An enable or a disable setting

15.8.5 static bool LLWU_GetInternalWakeupModuleFlag ( LLWU_Type ∗ base,


uint32_t moduleIndex ) [inline], [static]

This function checks the external pin flag to detect whether the system is woken up by the specific pin.
Parameters

base LLWU peripheral base address.


moduleIndex A module index, which starts from 1.

Returns
True if the specific pin is a wake up source.

15.8.6 void LLWU_SetPinFilterMode ( LLWU_Type ∗ base, uint32_t filterIndex,


llwu_external_pin_filter_mode_t filterMode )

This function sets the pin filter configuration.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 399
Function Documentation

Parameters

base LLWU peripheral base address.


filterIndex A pin filter index used to enable/disable the digital filter, starting from 1.
filterMode A filter mode configuration

15.8.7 bool LLWU_GetPinFilterFlag ( LLWU_Type ∗ base, uint32_t filterIndex )

This function gets the pin filter flag.


Parameters

base LLWU peripheral base address.


filterIndex A pin filter index, which starts from 1.

Returns
True if the flag is a source of the existing low-leakage power mode.

15.8.8 void LLWU_ClearPinFilterFlag ( LLWU_Type ∗ base, uint32_t filterIndex )

This function clears the pin filter flag.


Parameters

base LLWU peripheral base address.


filterIndex A pin filter index to clear the flag, starting from 1.

MCUXpresso SDK API Reference Manual


400 NXP Semiconductors
Chapter 16
LPTMR: Low-Power Timer
16.1 Overview
The MCUXpresso SDK provides a driver for the Low-Power Timer (LPTMR) of MCUXpresso SDK
devices.

16.2 Function groups


The LPTMR driver supports operating the module as a time counter or as a pulse counter.

16.2.1 Initialization and deinitialization

The function LPTMR_Init() initializes the LPTMR with specified configurations. The function LPTMR_-
GetDefaultConfig() gets the default configurations. The initialization function configures the LPTMR for
a timer or a pulse counter mode mode. It also sets up the LPTMR’s free running mode operation and a
clock source.
The function LPTMR_DeInit() disables the LPTMR module and gates the module clock.

16.2.2 Timer period Operations

The function LPTMR_SetTimerPeriod() sets the timer period in units of count. Timers counts from 0 to
the count value set here.
The function LPTMR_GetCurrentTimerCount() reads the current timer counting value. This function
returns the real-time timer counting value ranging from 0 to a timer period.
The timer period operation function takes the count value in ticks. Call the utility macros provided in the
fsl_common.h file to convert to microseconds or milliseconds.

16.2.3 Start and Stop timer operations

The function LPTMR_StartTimer() starts the timer counting. After calling this function, the timer counts
up to the counter value set earlier by using the LPTMR_SetPeriod() function. Each time the timer reaches
the count value and increments, it generates a trigger pulse and sets the timeout interrupt flag. An interrupt
is also triggered if the timer interrupt is enabled.
The function LPTMR_StopTimer() stops the timer counting and resets the timer’s counter register.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 401
Typical use case

16.2.4 Status

Provides functions to get and clear the LPTMR status.

16.2.5 Interrupt

Provides functions to enable/disable LPTMR interrupts and get the currently enabled interrupts.

16.3 Typical use case


16.3.1 LPTMR tick example

Updates the LPTMR period and toggles an LED periodically. Refer to the driver examples codes located
at <SDK_ROOT>/boards/<BOARD>/driver_examples/lptmr

Data Structures
• struct lptmr_config_t
LPTMR config structure. More...

Enumerations
• enum lptmr_pin_select_t {
kLPTMR_PinSelectInput_0 = 0x0U,
kLPTMR_PinSelectInput_1 = 0x1U,
kLPTMR_PinSelectInput_2 = 0x2U,
kLPTMR_PinSelectInput_3 = 0x3U }
LPTMR pin selection used in pulse counter mode.
• enum lptmr_pin_polarity_t {
kLPTMR_PinPolarityActiveHigh = 0x0U,
kLPTMR_PinPolarityActiveLow = 0x1U }
LPTMR pin polarity used in pulse counter mode.
• enum lptmr_timer_mode_t {
kLPTMR_TimerModeTimeCounter = 0x0U,
kLPTMR_TimerModePulseCounter = 0x1U }
LPTMR timer mode selection.
• enum lptmr_prescaler_glitch_value_t {

MCUXpresso SDK API Reference Manual


402 NXP Semiconductors
Typical use case

kLPTMR_Prescale_Glitch_0 = 0x0U,
kLPTMR_Prescale_Glitch_1 = 0x1U,
kLPTMR_Prescale_Glitch_2 = 0x2U,
kLPTMR_Prescale_Glitch_3 = 0x3U,
kLPTMR_Prescale_Glitch_4 = 0x4U,
kLPTMR_Prescale_Glitch_5 = 0x5U,
kLPTMR_Prescale_Glitch_6 = 0x6U,
kLPTMR_Prescale_Glitch_7 = 0x7U,
kLPTMR_Prescale_Glitch_8 = 0x8U,
kLPTMR_Prescale_Glitch_9 = 0x9U,
kLPTMR_Prescale_Glitch_10 = 0xAU,
kLPTMR_Prescale_Glitch_11 = 0xBU,
kLPTMR_Prescale_Glitch_12 = 0xCU,
kLPTMR_Prescale_Glitch_13 = 0xDU,
kLPTMR_Prescale_Glitch_14 = 0xEU,
kLPTMR_Prescale_Glitch_15 = 0xFU }
LPTMR prescaler/glitch filter values.
• enum lptmr_prescaler_clock_select_t {
kLPTMR_PrescalerClock_0 = 0x0U,
kLPTMR_PrescalerClock_1 = 0x1U,
kLPTMR_PrescalerClock_2 = 0x2U,
kLPTMR_PrescalerClock_3 = 0x3U }
LPTMR prescaler/glitch filter clock select.
• enum lptmr_interrupt_enable_t { kLPTMR_TimerInterruptEnable = LPTMR_CSR_TIE_MASK }
List of the LPTMR interrupts.
• enum lptmr_status_flags_t { kLPTMR_TimerCompareFlag = LPTMR_CSR_TCF_MASK }
List of the LPTMR status flags.

Driver version
• #define FSL_LPTMR_DRIVER_VERSION (MAKE_VERSION(2, 0, 2))
Version 2.0.2.

Initialization and deinitialization


• void LPTMR_Init (LPTMR_Type ∗base, const lptmr_config_t ∗config)
Ungates the LPTMR clock and configures the peripheral for a basic operation.
• void LPTMR_Deinit (LPTMR_Type ∗base)
Gates the LPTMR clock.
• void LPTMR_GetDefaultConfig (lptmr_config_t ∗config)
Fills in the LPTMR configuration structure with default settings.

Interrupt Interface
• static void LPTMR_EnableInterrupts (LPTMR_Type ∗base, uint32_t mask)
Enables the selected LPTMR interrupts.
• static void LPTMR_DisableInterrupts (LPTMR_Type ∗base, uint32_t mask)
Disables the selected LPTMR interrupts.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 403
Data Structure Documentation

• static uint32_t LPTMR_GetEnabledInterrupts (LPTMR_Type ∗base)


Gets the enabled LPTMR interrupts.

Status Interface
• static uint32_t LPTMR_GetStatusFlags (LPTMR_Type ∗base)
Gets the LPTMR status flags.
• static void LPTMR_ClearStatusFlags (LPTMR_Type ∗base, uint32_t mask)
Clears the LPTMR status flags.

Read and write the timer period


• static void LPTMR_SetTimerPeriod (LPTMR_Type ∗base, uint32_t ticks)
Sets the timer period in units of count.
• static uint32_t LPTMR_GetCurrentTimerCount (LPTMR_Type ∗base)
Reads the current timer counting value.

Timer Start and Stop


• static void LPTMR_StartTimer (LPTMR_Type ∗base)
Starts the timer.
• static void LPTMR_StopTimer (LPTMR_Type ∗base)
Stops the timer.

16.4 Data Structure Documentation


16.4.1 struct lptmr_config_t

This structure holds the configuration settings for the LPTMR peripheral. To initialize this structure to
reasonable defaults, call the LPTMR_GetDefaultConfig() function and pass a pointer to your configuration
structure instance.
The configuration struct can be made constant so it resides in flash.

Data Fields

• lptmr_timer_mode_t timerMode
Time counter mode or pulse counter mode.
• lptmr_pin_select_t pinSelect
LPTMR pulse input pin select; used only in pulse counter mode.
• lptmr_pin_polarity_t pinPolarity
LPTMR pulse input pin polarity; used only in pulse counter mode.
• bool enableFreeRunning
True: enable free running, counter is reset on overflow False: counter is reset when the compare flag is
set.
• bool bypassPrescaler
True: bypass prescaler; false: use clock from prescaler.
• lptmr_prescaler_clock_select_t prescalerClockSource

MCUXpresso SDK API Reference Manual


404 NXP Semiconductors
Enumeration Type Documentation

LPTMR clock source.


• lptmr_prescaler_glitch_value_t value
Prescaler or glitch filter value.

16.5 Enumeration Type Documentation


16.5.1 enum lptmr_pin_select_t

Enumerator
kLPTMR_PinSelectInput_0 Pulse counter input 0 is selected.
kLPTMR_PinSelectInput_1 Pulse counter input 1 is selected.
kLPTMR_PinSelectInput_2 Pulse counter input 2 is selected.
kLPTMR_PinSelectInput_3 Pulse counter input 3 is selected.

16.5.2 enum lptmr_pin_polarity_t

Enumerator
kLPTMR_PinPolarityActiveHigh Pulse Counter input source is active-high.
kLPTMR_PinPolarityActiveLow Pulse Counter input source is active-low.

16.5.3 enum lptmr_timer_mode_t

Enumerator
kLPTMR_TimerModeTimeCounter Time Counter mode.
kLPTMR_TimerModePulseCounter Pulse Counter mode.

16.5.4 enum lptmr_prescaler_glitch_value_t

Enumerator
kLPTMR_Prescale_Glitch_0 Prescaler divide 2, glitch filter does not support this setting.
kLPTMR_Prescale_Glitch_1 Prescaler divide 4, glitch filter 2.
kLPTMR_Prescale_Glitch_2 Prescaler divide 8, glitch filter 4.
kLPTMR_Prescale_Glitch_3 Prescaler divide 16, glitch filter 8.
kLPTMR_Prescale_Glitch_4 Prescaler divide 32, glitch filter 16.
kLPTMR_Prescale_Glitch_5 Prescaler divide 64, glitch filter 32.
kLPTMR_Prescale_Glitch_6 Prescaler divide 128, glitch filter 64.
kLPTMR_Prescale_Glitch_7 Prescaler divide 256, glitch filter 128.
kLPTMR_Prescale_Glitch_8 Prescaler divide 512, glitch filter 256.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 405
Function Documentation

kLPTMR_Prescale_Glitch_9 Prescaler divide 1024, glitch filter 512.


kLPTMR_Prescale_Glitch_10 Prescaler divide 2048 glitch filter 1024.
kLPTMR_Prescale_Glitch_11 Prescaler divide 4096, glitch filter 2048.
kLPTMR_Prescale_Glitch_12 Prescaler divide 8192, glitch filter 4096.
kLPTMR_Prescale_Glitch_13 Prescaler divide 16384, glitch filter 8192.
kLPTMR_Prescale_Glitch_14 Prescaler divide 32768, glitch filter 16384.
kLPTMR_Prescale_Glitch_15 Prescaler divide 65536, glitch filter 32768.

16.5.5 enum lptmr_prescaler_clock_select_t

Note
Clock connections are SoC-specific

Enumerator
kLPTMR_PrescalerClock_0 Prescaler/glitch filter clock 0 selected.
kLPTMR_PrescalerClock_1 Prescaler/glitch filter clock 1 selected.
kLPTMR_PrescalerClock_2 Prescaler/glitch filter clock 2 selected.
kLPTMR_PrescalerClock_3 Prescaler/glitch filter clock 3 selected.

16.5.6 enum lptmr_interrupt_enable_t

Enumerator
kLPTMR_TimerInterruptEnable Timer interrupt enable.

16.5.7 enum lptmr_status_flags_t

Enumerator
kLPTMR_TimerCompareFlag Timer compare flag.

16.6 Function Documentation


16.6.1 void LPTMR_Init ( LPTMR_Type ∗ base, const lptmr_config_t ∗ config )

Note
This API should be called at the beginning of the application using the LPTMR driver.

MCUXpresso SDK API Reference Manual


406 NXP Semiconductors
Function Documentation

Parameters

base LPTMR peripheral base address


config A pointer to the LPTMR configuration structure.

16.6.2 void LPTMR_Deinit ( LPTMR_Type ∗ base )

Parameters

base LPTMR peripheral base address

16.6.3 void LPTMR_GetDefaultConfig ( lptmr_config_t ∗ config )

The default values are as follows.

* config->timerMode = kLPTMR_TimerModeTimeCounter;
* config->pinSelect = kLPTMR_PinSelectInput_0;
* config->pinPolarity = kLPTMR_PinPolarityActiveHigh;
* config->enableFreeRunning = false;
* config->bypassPrescaler = true;
* config->prescalerClockSource = kLPTMR_PrescalerClock_1;
* config->value = kLPTMR_Prescale_Glitch_0;
*

Parameters

config A pointer to the LPTMR configuration structure.

16.6.4 static void LPTMR_EnableInterrupts ( LPTMR_Type ∗ base, uint32_t mask )


[inline], [static]

Parameters

base LPTMR peripheral base address


mask The interrupts to enable. This is a logical OR of members of the enumeration lptmr-
_interrupt_enable_t

16.6.5 static void LPTMR_DisableInterrupts ( LPTMR_Type ∗ base, uint32_t mask


) [inline], [static]

MCUXpresso SDK API Reference Manual


NXP Semiconductors 407
Function Documentation

Parameters

base LPTMR peripheral base address


mask The interrupts to disable. This is a logical OR of members of the enumeration lptmr-
_interrupt_enable_t.

16.6.6 static uint32_t LPTMR_GetEnabledInterrupts ( LPTMR_Type ∗ base )


[inline], [static]

Parameters

base LPTMR peripheral base address

Returns
The enabled interrupts. This is the logical OR of members of the enumeration lptmr_interrupt_-
enable_t

16.6.7 static uint32_t LPTMR_GetStatusFlags ( LPTMR_Type ∗ base ) [inline],


[static]

Parameters

base LPTMR peripheral base address

Returns
The status flags. This is the logical OR of members of the enumeration lptmr_status_flags_t

16.6.8 static void LPTMR_ClearStatusFlags ( LPTMR_Type ∗ base, uint32_t mask


) [inline], [static]

Parameters

MCUXpresso SDK API Reference Manual


408 NXP Semiconductors
Function Documentation

base LPTMR peripheral base address


mask The status flags to clear. This is a logical OR of members of the enumeration lptmr_-
status_flags_t.

16.6.9 static void LPTMR_SetTimerPeriod ( LPTMR_Type ∗ base, uint32_t ticks )


[inline], [static]

Timers counts from 0 until it equals the count value set here. The count value is written to the CMR
register.

Note
1. The TCF flag is set with the CNR equals the count provided here and then increments.
2. Call the utility macros provided in the fsl_common.h to convert to ticks.

Parameters

base LPTMR peripheral base address


ticks A timer period in units of ticks, which should be equal or greater than 1.

16.6.10 static uint32_t LPTMR_GetCurrentTimerCount ( LPTMR_Type ∗ base )


[inline], [static]

This function returns the real-time timer counting value in a range from 0 to a timer period.

Note
Call the utility macros provided in the fsl_common.h to convert ticks to usec or msec.

Parameters

base LPTMR peripheral base address

Returns
The current counter value in ticks

MCUXpresso SDK API Reference Manual


NXP Semiconductors 409
Function Documentation

16.6.11 static void LPTMR_StartTimer ( LPTMR_Type ∗ base ) [inline],


[static]

After calling this function, the timer counts up to the CMR register value. Each time the timer reaches
the CMR value and then increments, it generates a trigger pulse and sets the timeout interrupt flag. An
interrupt is also triggered if the timer interrupt is enabled.
Parameters

base LPTMR peripheral base address

16.6.12 static void LPTMR_StopTimer ( LPTMR_Type ∗ base ) [inline],


[static]

This function stops the timer and resets the timer’s counter register.
Parameters

base LPTMR peripheral base address

MCUXpresso SDK API Reference Manual


410 NXP Semiconductors
Chapter 17
LPUART: Low Power UART Driver
17.1 Overview
Modules
• LPUART DMA Driver
• LPUART Driver
• LPUART FreeRTOS Driver
• LPUART eDMA Driver

MCUXpresso SDK API Reference Manual


NXP Semiconductors 411
LPUART Driver

17.2 LPUART Driver


17.2.1 Overview

The MCUXpresso SDK provides a peripheral driver for the Low Power UART (LPUART) module of
MCUXpresso SDK devices.

17.2.2 Typical use case

17.2.2.1 LPUART Operation

Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/lpuart

Data Structures

• struct lpuart_config_t
LPUART configuration structure. More...
• struct lpuart_transfer_t
LPUART transfer structure. More...
• struct lpuart_handle_t
LPUART handle structure. More...

Typedefs

• typedef void(∗ lpuart_transfer_callback_t )(LPUART_Type ∗base, lpuart_handle_t ∗handle, status-


_t status, void ∗userData)
LPUART transfer callback function.

MCUXpresso SDK API Reference Manual


412 NXP Semiconductors
LPUART Driver

Enumerations

• enum _lpuart_status {
kStatus_LPUART_TxBusy = MAKE_STATUS(kStatusGroup_LPUART, 0),
kStatus_LPUART_RxBusy = MAKE_STATUS(kStatusGroup_LPUART, 1),
kStatus_LPUART_TxIdle = MAKE_STATUS(kStatusGroup_LPUART, 2),
kStatus_LPUART_RxIdle = MAKE_STATUS(kStatusGroup_LPUART, 3),
kStatus_LPUART_TxWatermarkTooLarge = MAKE_STATUS(kStatusGroup_LPUART, 4),
kStatus_LPUART_RxWatermarkTooLarge = MAKE_STATUS(kStatusGroup_LPUART, 5),
kStatus_LPUART_FlagCannotClearManually = MAKE_STATUS(kStatusGroup_LPUART, 6),
kStatus_LPUART_Error = MAKE_STATUS(kStatusGroup_LPUART, 7),
kStatus_LPUART_RxRingBufferOverrun,
kStatus_LPUART_RxHardwareOverrun = MAKE_STATUS(kStatusGroup_LPUART, 9),
kStatus_LPUART_NoiseError = MAKE_STATUS(kStatusGroup_LPUART, 10),
kStatus_LPUART_FramingError = MAKE_STATUS(kStatusGroup_LPUART, 11),
kStatus_LPUART_ParityError = MAKE_STATUS(kStatusGroup_LPUART, 12),
kStatus_LPUART_BaudrateNotSupport,
kStatus_LPUART_IdleLineDetected = MAKE_STATUS(kStatusGroup_LPUART, 14) }
Error codes for the LPUART driver.
• enum lpuart_parity_mode_t {
kLPUART_ParityDisabled = 0x0U,
kLPUART_ParityEven = 0x2U,
kLPUART_ParityOdd = 0x3U }
LPUART parity mode.
• enum lpuart_data_bits_t { kLPUART_EightDataBits = 0x0U }
LPUART data bits count.
• enum lpuart_stop_bit_count_t {
kLPUART_OneStopBit = 0U,
kLPUART_TwoStopBit = 1U }
LPUART stop bit count.
• enum lpuart_idle_type_select_t {
kLPUART_IdleTypeStartBit = 0U,
kLPUART_IdleTypeStopBit = 1U }
LPUART idle flag type defines when the receiver starts counting.
• enum lpuart_idle_config_t {
kLPUART_IdleCharacter1 = 0U,
kLPUART_IdleCharacter2 = 1U,
kLPUART_IdleCharacter4 = 2U,
kLPUART_IdleCharacter8 = 3U,
kLPUART_IdleCharacter16 = 4U,
kLPUART_IdleCharacter32 = 5U,
kLPUART_IdleCharacter64 = 6U,
kLPUART_IdleCharacter128 = 7U }
LPUART idle detected configuration.
• enum _lpuart_interrupt_enable {

MCUXpresso SDK API Reference Manual


NXP Semiconductors 413
LPUART Driver

kLPUART_LinBreakInterruptEnable = (LPUART_BAUD_LBKDIE_MASK >> 8),


kLPUART_RxActiveEdgeInterruptEnable = (LPUART_BAUD_RXEDGIE_MASK >> 8),
kLPUART_TxDataRegEmptyInterruptEnable = (LPUART_CTRL_TIE_MASK),
kLPUART_TransmissionCompleteInterruptEnable = (LPUART_CTRL_TCIE_MASK),
kLPUART_RxDataRegFullInterruptEnable = (LPUART_CTRL_RIE_MASK),
kLPUART_IdleLineInterruptEnable = (LPUART_CTRL_ILIE_MASK),
kLPUART_RxOverrunInterruptEnable = (LPUART_CTRL_ORIE_MASK),
kLPUART_NoiseErrorInterruptEnable = (LPUART_CTRL_NEIE_MASK),
kLPUART_FramingErrorInterruptEnable = (LPUART_CTRL_FEIE_MASK),
kLPUART_ParityErrorInterruptEnable = (LPUART_CTRL_PEIE_MASK) }
LPUART interrupt configuration structure, default settings all disabled.
• enum _lpuart_flags {
kLPUART_TxDataRegEmptyFlag,
kLPUART_TransmissionCompleteFlag,
kLPUART_RxDataRegFullFlag,
kLPUART_IdleLineFlag = (LPUART_STAT_IDLE_MASK),
kLPUART_RxOverrunFlag = (LPUART_STAT_OR_MASK),
kLPUART_NoiseErrorFlag = (LPUART_STAT_NF_MASK),
kLPUART_FramingErrorFlag,
kLPUART_ParityErrorFlag = (LPUART_STAT_PF_MASK),
kLPUART_LinBreakFlag = (int)(LPUART_STAT_LBKDIF_MASK),
kLPUART_RxActiveEdgeFlag,
kLPUART_RxActiveFlag,
kLPUART_DataMatch1Flag = LPUART_STAT_MA1F_MASK,
kLPUART_DataMatch2Flag = LPUART_STAT_MA2F_MASK,
kLPUART_NoiseErrorInRxDataRegFlag,
kLPUART_ParityErrorInRxDataRegFlag }
LPUART status flags.

Driver version

• #define FSL_LPUART_DRIVER_VERSION (MAKE_VERSION(2, 2, 7))


LPUART driver version 2.2.7.

Initialization and deinitialization

• status_t LPUART_Init (LPUART_Type ∗base, const lpuart_config_t ∗config, uint32_t srcClock_-


Hz)
Initializes an LPUART instance with the user configuration structure and the peripheral clock.
• void LPUART_Deinit (LPUART_Type ∗base)
Deinitializes a LPUART instance.
• void LPUART_GetDefaultConfig (lpuart_config_t ∗config)
Gets the default configuration structure.
• status_t LPUART_SetBaudRate (LPUART_Type ∗base, uint32_t baudRate_Bps, uint32_t src-
Clock_Hz)

MCUXpresso SDK API Reference Manual


414 NXP Semiconductors
LPUART Driver

Sets the LPUART instance baudrate.

Status

• uint32_t LPUART_GetStatusFlags (LPUART_Type ∗base)


Gets LPUART status flags.
• status_t LPUART_ClearStatusFlags (LPUART_Type ∗base, uint32_t mask)
Clears status flags with a provided mask.

Interrupts

• void LPUART_EnableInterrupts (LPUART_Type ∗base, uint32_t mask)


Enables LPUART interrupts according to a provided mask.
• void LPUART_DisableInterrupts (LPUART_Type ∗base, uint32_t mask)
Disables LPUART interrupts according to a provided mask.
• uint32_t LPUART_GetEnabledInterrupts (LPUART_Type ∗base)
Gets enabled LPUART interrupts.
• static uint32_t LPUART_GetDataRegisterAddress (LPUART_Type ∗base)
Gets the LPUART data register address.
• static void LPUART_EnableTxDMA (LPUART_Type ∗base, bool enable)
Enables or disables the LPUART transmitter DMA request.
• static void LPUART_EnableRxDMA (LPUART_Type ∗base, bool enable)
Enables or disables the LPUART receiver DMA.

Bus Operations

• uint32_t LPUART_GetInstance (LPUART_Type ∗base)


Get the LPUART instance from peripheral base address.
• static void LPUART_EnableTx (LPUART_Type ∗base, bool enable)
Enables or disables the LPUART transmitter.
• static void LPUART_EnableRx (LPUART_Type ∗base, bool enable)
Enables or disables the LPUART receiver.
• static void LPUART_WriteByte (LPUART_Type ∗base, uint8_t data)
Writes to the transmitter register.
• static uint8_t LPUART_ReadByte (LPUART_Type ∗base)
Reads the receiver register.
• void LPUART_WriteBlocking (LPUART_Type ∗base, const uint8_t ∗data, size_t length)
Writes to the transmitter register using a blocking method.
• status_t LPUART_ReadBlocking (LPUART_Type ∗base, uint8_t ∗data, size_t length)
Reads the receiver data register using a blocking method.

Transactional

• void LPUART_TransferCreateHandle (LPUART_Type ∗base, lpuart_handle_t ∗handle, lpuart_-


transfer_callback_t callback, void ∗userData)
Initializes the LPUART handle.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 415
LPUART Driver

• status_t LPUART_TransferSendNonBlocking (LPUART_Type ∗base, lpuart_handle_t ∗handle,


lpuart_transfer_t ∗xfer)
Transmits a buffer of data using the interrupt method.
• void LPUART_TransferStartRingBuffer (LPUART_Type ∗base, lpuart_handle_t ∗handle, uint8_t
∗ringBuffer, size_t ringBufferSize)
Sets up the RX ring buffer.
• void LPUART_TransferStopRingBuffer (LPUART_Type ∗base, lpuart_handle_t ∗handle)
Aborts the background transfer and uninstalls the ring buffer.
• size_t LPUART_TransferGetRxRingBufferLength (LPUART_Type ∗base, lpuart_handle_-
t ∗handle)
Get the length of received data in RX ring buffer.
• void LPUART_TransferAbortSend (LPUART_Type ∗base, lpuart_handle_t ∗handle)
Aborts the interrupt-driven data transmit.
• status_t LPUART_TransferGetSendCount (LPUART_Type ∗base, lpuart_handle_t ∗handle, uint32-
_t ∗count)
Gets the number of bytes that have been written to the LPUART transmitter register.
• status_t LPUART_TransferReceiveNonBlocking (LPUART_Type ∗base, lpuart_handle_t ∗handle,
lpuart_transfer_t ∗xfer, size_t ∗receivedBytes)
Receives a buffer of data using the interrupt method.
• void LPUART_TransferAbortReceive (LPUART_Type ∗base, lpuart_handle_t ∗handle)
Aborts the interrupt-driven data receiving.
• status_t LPUART_TransferGetReceiveCount (LPUART_Type ∗base, lpuart_handle_t ∗handle,
uint32_t ∗count)
Gets the number of bytes that have been received.
• void LPUART_TransferHandleIRQ (LPUART_Type ∗base, lpuart_handle_t ∗handle)
LPUART IRQ handle function.
• void LPUART_TransferHandleErrorIRQ (LPUART_Type ∗base, lpuart_handle_t ∗handle)
LPUART Error IRQ handle function.

17.2.3 Data Structure Documentation

17.2.3.1 struct lpuart_config_t

Data Fields
• uint32_t baudRate_Bps
LPUART baud rate.
• lpuart_parity_mode_t parityMode
Parity mode, disabled (default), even, odd.
• lpuart_data_bits_t dataBitsCount
Data bits count, eight (default), seven.
• bool isMsb
Data bits order, LSB (default), MSB.
• lpuart_stop_bit_count_t stopBitCount
Number of stop bits, 1 stop bit (default) or 2 stop bits.
• lpuart_idle_type_select_t rxIdleType
RX IDLE type.
• lpuart_idle_config_t rxIdleConfig

MCUXpresso SDK API Reference Manual


416 NXP Semiconductors
LPUART Driver

RX IDLE configuration.
• bool enableTx
Enable TX.
• bool enableRx
Enable RX.

17.2.3.1.0.9 Field Documentation

17.2.3.1.0.9.1 lpuart_idle_type_select_t lpuart_config_t::rxIdleType

17.2.3.1.0.9.2 lpuart_idle_config_t lpuart_config_t::rxIdleConfig

17.2.3.2 struct lpuart_transfer_t

Data Fields
• uint8_t ∗ data
The buffer of data to be transfer.
• size_t dataSize
The byte count to be transfer.

17.2.3.2.0.10 Field Documentation

17.2.3.2.0.10.1 uint8_t∗ lpuart_transfer_t::data

17.2.3.2.0.10.2 size_t lpuart_transfer_t::dataSize

17.2.3.3 struct _lpuart_handle

Data Fields
• uint8_t ∗volatile txData
Address of remaining data to send.
• volatile size_t txDataSize
Size of the remaining data to send.
• size_t txDataSizeAll
Size of the data to send out.
• uint8_t ∗volatile rxData
Address of remaining data to receive.
• volatile size_t rxDataSize
Size of the remaining data to receive.
• size_t rxDataSizeAll
Size of the data to receive.
• uint8_t ∗ rxRingBuffer
Start address of the receiver ring buffer.
• size_t rxRingBufferSize
Size of the ring buffer.
• volatile uint16_t rxRingBufferHead
Index for the driver to store received data into ring buffer.
• volatile uint16_t rxRingBufferTail
Index for the user to get data from the ring buffer.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 417
LPUART Driver

• lpuart_transfer_callback_t callback
Callback function.
• void ∗ userData
LPUART callback function parameter.
• volatile uint8_t txState
TX transfer state.
• volatile uint8_t rxState
RX transfer state.

MCUXpresso SDK API Reference Manual


418 NXP Semiconductors
LPUART Driver

17.2.3.3.0.11 Field Documentation

17.2.3.3.0.11.1 uint8_t∗ volatile lpuart_handle_t::txData

17.2.3.3.0.11.2 volatile size_t lpuart_handle_t::txDataSize

17.2.3.3.0.11.3 size_t lpuart_handle_t::txDataSizeAll

17.2.3.3.0.11.4 uint8_t∗ volatile lpuart_handle_t::rxData

17.2.3.3.0.11.5 volatile size_t lpuart_handle_t::rxDataSize

17.2.3.3.0.11.6 size_t lpuart_handle_t::rxDataSizeAll

17.2.3.3.0.11.7 uint8_t∗ lpuart_handle_t::rxRingBuffer

17.2.3.3.0.11.8 size_t lpuart_handle_t::rxRingBufferSize

17.2.3.3.0.11.9 volatile uint16_t lpuart_handle_t::rxRingBufferHead

17.2.3.3.0.11.10 volatile uint16_t lpuart_handle_t::rxRingBufferTail

17.2.3.3.0.11.11 lpuart_transfer_callback_t lpuart_handle_t::callback

17.2.3.3.0.11.12 void∗ lpuart_handle_t::userData

17.2.3.3.0.11.13 volatile uint8_t lpuart_handle_t::txState

17.2.3.3.0.11.14 volatile uint8_t lpuart_handle_t::rxState

17.2.4 Macro Definition Documentation

17.2.4.1 #define FSL_LPUART_DRIVER_VERSION (MAKE_VERSION(2, 2, 7))

17.2.5 Typedef Documentation

17.2.5.1 typedef void(∗ lpuart_transfer_callback_t)(LPUART_Type ∗base, lpuart_handle_t


∗handle, status_t status, void ∗userData)

17.2.6 Enumeration Type Documentation

17.2.6.1 enum _lpuart_status

Enumerator
kStatus_LPUART_TxBusy TX busy.
kStatus_LPUART_RxBusy RX busy.
kStatus_LPUART_TxIdle LPUART transmitter is idle.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 419
LPUART Driver

kStatus_LPUART_RxIdle LPUART receiver is idle.


kStatus_LPUART_TxWatermarkTooLarge TX FIFO watermark too large.
kStatus_LPUART_RxWatermarkTooLarge RX FIFO watermark too large.
kStatus_LPUART_FlagCannotClearManually Some flag can’t manually clear.
kStatus_LPUART_Error Error happens on LPUART.
kStatus_LPUART_RxRingBufferOverrun LPUART RX software ring buffer overrun.
kStatus_LPUART_RxHardwareOverrun LPUART RX receiver overrun.
kStatus_LPUART_NoiseError LPUART noise error.
kStatus_LPUART_FramingError LPUART framing error.
kStatus_LPUART_ParityError LPUART parity error.
kStatus_LPUART_BaudrateNotSupport Baudrate is not support in current clock source.
kStatus_LPUART_IdleLineDetected IDLE flag.

17.2.6.2 enum lpuart_parity_mode_t

Enumerator
kLPUART_ParityDisabled Parity disabled.
kLPUART_ParityEven Parity enabled, type even, bit setting: PE|PT = 10.
kLPUART_ParityOdd Parity enabled, type odd, bit setting: PE|PT = 11.

17.2.6.3 enum lpuart_data_bits_t

Enumerator
kLPUART_EightDataBits Eight data bit.

17.2.6.4 enum lpuart_stop_bit_count_t

Enumerator
kLPUART_OneStopBit One stop bit.
kLPUART_TwoStopBit Two stop bits.

17.2.6.5 enum lpuart_idle_type_select_t

Enumerator
kLPUART_IdleTypeStartBit Start counting after a valid start bit.
kLPUART_IdleTypeStopBit Start counting after a stop bit.

MCUXpresso SDK API Reference Manual


420 NXP Semiconductors
LPUART Driver

17.2.6.6 enum lpuart_idle_config_t

This structure defines the number of idle characters that must be received before the IDLE flag is set.

Enumerator
kLPUART_IdleCharacter1 the number of idle characters.
kLPUART_IdleCharacter2 the number of idle characters.
kLPUART_IdleCharacter4 the number of idle characters.
kLPUART_IdleCharacter8 the number of idle characters.
kLPUART_IdleCharacter16 the number of idle characters.
kLPUART_IdleCharacter32 the number of idle characters.
kLPUART_IdleCharacter64 the number of idle characters.
kLPUART_IdleCharacter128 the number of idle characters.

17.2.6.7 enum _lpuart_interrupt_enable

This structure contains the settings for all LPUART interrupt configurations.

Enumerator
kLPUART_LinBreakInterruptEnable LIN break detect.
kLPUART_RxActiveEdgeInterruptEnable Receive Active Edge.
kLPUART_TxDataRegEmptyInterruptEnable Transmit data register empty.
kLPUART_TransmissionCompleteInterruptEnable Transmission complete.
kLPUART_RxDataRegFullInterruptEnable Receiver data register full.
kLPUART_IdleLineInterruptEnable Idle line.
kLPUART_RxOverrunInterruptEnable Receiver Overrun.
kLPUART_NoiseErrorInterruptEnable Noise error flag.
kLPUART_FramingErrorInterruptEnable Framing error flag.
kLPUART_ParityErrorInterruptEnable Parity error flag.

17.2.6.8 enum _lpuart_flags

This provides constants for the LPUART status flags for use in the LPUART functions.

Enumerator
kLPUART_TxDataRegEmptyFlag Transmit data register empty flag, sets when transmit buffer is
empty.
kLPUART_TransmissionCompleteFlag Transmission complete flag, sets when transmission activ-
ity complete.
kLPUART_RxDataRegFullFlag Receive data register full flag, sets when the receive data buffer is
full.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 421
LPUART Driver

kLPUART_IdleLineFlag Idle line detect flag, sets when idle line detected.
kLPUART_RxOverrunFlag Receive Overrun, sets when new data is received before data is read
from receive register.
kLPUART_NoiseErrorFlag Receive takes 3 samples of each received bit. If any of these samples
differ, noise flag sets
kLPUART_FramingErrorFlag Frame error flag, sets if logic 0 was detected where stop bit ex-
pected.
kLPUART_ParityErrorFlag If parity enabled, sets upon parity error detection.
kLPUART_LinBreakFlag LIN break detect interrupt flag, sets when LIN break char detected and
LIN circuit enabled.
kLPUART_RxActiveEdgeFlag Receive pin active edge interrupt flag, sets when active edge de-
tected.
kLPUART_RxActiveFlag Receiver Active Flag (RAF), sets at beginning of valid start bit.
kLPUART_DataMatch1Flag The next character to be read from LPUART_DATA matches MA1.
kLPUART_DataMatch2Flag The next character to be read from LPUART_DATA matches MA2.
kLPUART_NoiseErrorInRxDataRegFlag NOISY bit, sets if noise detected in current data word.
kLPUART_ParityErrorInRxDataRegFlag PARITY bit, sets if noise detected in current data word.

17.2.7 Function Documentation

17.2.7.1 status_t LPUART_Init ( LPUART_Type ∗ base, const lpuart_config_t ∗ config,


uint32_t srcClock_Hz )

This function configures the LPUART module with user-defined settings. Call the LPUART_GetDefault-
Config() function to configure the configuration structure and get the default configuration. The example
below shows how to use this API to configure the LPUART.

* lpuart_config_t lpuartConfig;
* lpuartConfig.baudRate_Bps = 115200U;
* lpuartConfig.parityMode = kLPUART_ParityDisabled;
* lpuartConfig.dataBitsCount = kLPUART_EightDataBits;
* lpuartConfig.isMsb = false;
* lpuartConfig.stopBitCount = kLPUART_OneStopBit;
* lpuartConfig.txFifoWatermark = 0;
* lpuartConfig.rxFifoWatermark = 1;
* LPUART_Init(LPUART1, &lpuartConfig, 20000000U);
*

Parameters

base LPUART peripheral base address.

MCUXpresso SDK API Reference Manual


422 NXP Semiconductors
LPUART Driver

config Pointer to a user-defined configuration structure.


srcClock_Hz LPUART clock source frequency in HZ.

Return values

kStatus_LPUART_- Baudrate is not support in current clock source.


BaudrateNotSupport
kStatus_Success LPUART initialize succeed

17.2.7.2 void LPUART_Deinit ( LPUART_Type ∗ base )

This function waits for transmit to complete, disables TX and RX, and disables the LPUART clock.
Parameters

base LPUART peripheral base address.

17.2.7.3 void LPUART_GetDefaultConfig ( lpuart_config_t ∗ config )

This function initializes the LPUART configuration structure to a default value. The default values are-
: lpuartConfig->baudRate_Bps = 115200U; lpuartConfig->parityMode = kLPUART_ParityDisabled;
lpuartConfig->dataBitsCount = kLPUART_EightDataBits; lpuartConfig->isMsb = false; lpuartConfig-
>stopBitCount = kLPUART_OneStopBit; lpuartConfig->txFifoWatermark = 0; lpuartConfig->rxFifo-
Watermark = 1; lpuartConfig->rxIdleType = kLPUART_IdleTypeStartBit; lpuartConfig->rxIdleConfig =
kLPUART_IdleCharacter1; lpuartConfig->enableTx = false; lpuartConfig->enableRx = false;
Parameters

config Pointer to a configuration structure.

17.2.7.4 status_t LPUART_SetBaudRate ( LPUART_Type ∗ base, uint32_t baudRate_Bps,


uint32_t srcClock_Hz )

This function configures the LPUART module baudrate. This function is used to update the LPUART
module baudrate after the LPUART module is initialized by the LPUART_Init.

* LPUART_SetBaudRate(LPUART1, 115200U, 20000000U);


*

MCUXpresso SDK API Reference Manual


NXP Semiconductors 423
LPUART Driver

Parameters

base LPUART peripheral base address.


baudRate_Bps LPUART baudrate to be set.
srcClock_Hz LPUART clock source frequency in HZ.

Return values

kStatus_LPUART_- Baudrate is not supported in the current clock source.


BaudrateNotSupport
kStatus_Success Set baudrate succeeded.

17.2.7.5 uint32_t LPUART_GetStatusFlags ( LPUART_Type ∗ base )

This function gets all LPUART status flags. The flags are returned as the logical OR value of the enu-
merators _lpuart_flags. To check for a specific status, compare the return value with enumerators in the
_lpuart_flags. For example, to check whether the TX is empty:

* if (kLPUART_TxDataRegEmptyFlag &
LPUART_GetStatusFlags(LPUART1))
* {
* ...
* }
*

Parameters

base LPUART peripheral base address.

Returns
LPUART status flags which are ORed by the enumerators in the _lpuart_flags.

17.2.7.6 status_t LPUART_ClearStatusFlags ( LPUART_Type ∗ base, uint32_t mask )

This function clears LPUART status flags with a provided mask. Automatically cleared flags can’t
be cleared by this function. Flags that can only cleared or set by hardware are: kLPUART_TxData-
RegEmptyFlag, kLPUART_TransmissionCompleteFlag, kLPUART_RxDataRegFullFlag, kLPUART_-
RxActiveFlag, kLPUART_NoiseErrorInRxDataRegFlag, kLPUART_ParityErrorInRxDataRegFlag, kL-
PUART_TxFifoEmptyFlag,kLPUART_RxFifoEmptyFlag Note: This API should be called when the Tx/-
Rx is idle, otherwise it takes no effects.

MCUXpresso SDK API Reference Manual


424 NXP Semiconductors
LPUART Driver

Parameters

base LPUART peripheral base address.


mask the status flags to be cleared. The user can use the enumerators in the _lpuart_status-
_flag_t to do the OR operation and get the mask.

Returns
0 succeed, others failed.

Return values

kStatus_LPUART_Flag- The flag can’t be cleared by this function but it is cleared automatically by
CannotClearManually hardware.
kStatus_Success Status in the mask are cleared.

17.2.7.7 void LPUART_EnableInterrupts ( LPUART_Type ∗ base, uint32_t mask )

This function enables the LPUART interrupts according to a provided mask. The mask is a logical OR of
enumeration members. See the _lpuart_interrupt_enable. This examples shows how to enable TX empty
interrupt and RX full interrupt:

* LPUART_EnableInterrupts(LPUART1,
kLPUART_TxDataRegEmptyInterruptEnable |
kLPUART_RxDataRegFullInterruptEnable);
*

Parameters

base LPUART peripheral base address.


mask The interrupts to enable. Logical OR of _uart_interrupt_enable.

17.2.7.8 void LPUART_DisableInterrupts ( LPUART_Type ∗ base, uint32_t mask )

This function disables the LPUART interrupts according to a provided mask. The mask is a logical OR of
enumeration members. See _lpuart_interrupt_enable. This example shows how to disable the TX empty
interrupt and RX full interrupt:

* LPUART_DisableInterrupts(LPUART1,
kLPUART_TxDataRegEmptyInterruptEnable |
kLPUART_RxDataRegFullInterruptEnable);
*

MCUXpresso SDK API Reference Manual


NXP Semiconductors 425
LPUART Driver

Parameters

base LPUART peripheral base address.


mask The interrupts to disable. Logical OR of _lpuart_interrupt_enable.

17.2.7.9 uint32_t LPUART_GetEnabledInterrupts ( LPUART_Type ∗ base )

This function gets the enabled LPUART interrupts. The enabled interrupts are returned as the logical OR
value of the enumerators _lpuart_interrupt_enable. To check a specific interrupt enable status, compare
the return value with enumerators in _lpuart_interrupt_enable. For example, to check whether the TX
empty interrupt is enabled:
* uint32_t enabledInterrupts = LPUART_GetEnabledInterrupts(LPUART1);
*
* if (kLPUART_TxDataRegEmptyInterruptEnable & enabledInterrupts)
* {
* ...
* }
*

Parameters

base LPUART peripheral base address.

Returns
LPUART interrupt flags which are logical OR of the enumerators in _lpuart_interrupt_enable.

17.2.7.10 static uint32_t LPUART_GetDataRegisterAddress ( LPUART_Type ∗ base )


[inline], [static]

This function returns the LPUART data register address, which is mainly used by the DMA/eDMA.
Parameters

base LPUART peripheral base address.

Returns
LPUART data register addresses which are used both by the transmitter and receiver.

17.2.7.11 static void LPUART_EnableTxDMA ( LPUART_Type ∗ base, bool enable )


[inline], [static]

This function enables or disables the transmit data register empty flag, STAT[TDRE], to generate DMA
requests.

MCUXpresso SDK API Reference Manual


426 NXP Semiconductors
LPUART Driver

Parameters

base LPUART peripheral base address.


enable True to enable, false to disable.

17.2.7.12 static void LPUART_EnableRxDMA ( LPUART_Type ∗ base, bool enable )


[inline], [static]

This function enables or disables the receiver data register full flag, STAT[RDRF], to generate DMA
requests.
Parameters

base LPUART peripheral base address.


enable True to enable, false to disable.

17.2.7.13 uint32_t LPUART_GetInstance ( LPUART_Type ∗ base )

Parameters

base LPUART peripheral base address.

Returns
LPUART instance.

17.2.7.14 static void LPUART_EnableTx ( LPUART_Type ∗ base, bool enable )


[inline], [static]

This function enables or disables the LPUART transmitter.


Parameters

base LPUART peripheral base address.


enable True to enable, false to disable.

17.2.7.15 static void LPUART_EnableRx ( LPUART_Type ∗ base, bool enable )


[inline], [static]

This function enables or disables the LPUART receiver.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 427
LPUART Driver

Parameters

base LPUART peripheral base address.


enable True to enable, false to disable.

17.2.7.16 static void LPUART_WriteByte ( LPUART_Type ∗ base, uint8_t data )


[inline], [static]

This function writes data to the transmitter register directly. The upper layer must ensure that the TX
register is empty or that the TX FIFO has room before calling this function.
Parameters

base LPUART peripheral base address.


data Data write to the TX register.

17.2.7.17 static uint8_t LPUART_ReadByte ( LPUART_Type ∗ base ) [inline],


[static]

This function reads data from the receiver register directly. The upper layer must ensure that the receiver
register is full or that the RX FIFO has data before calling this function.
Parameters

base LPUART peripheral base address.

Returns
Data read from data register.

17.2.7.18 void LPUART_WriteBlocking ( LPUART_Type ∗ base, const uint8_t ∗ data,


size_t length )

This function polls the transmitter register, waits for the register to be empty or for TX FIFO to have room,
and writes data to the transmitter buffer.

Note
This function does not check whether all data has been sent out to the bus. Before disabling the
transmitter, check the kLPUART_TransmissionCompleteFlag to ensure that the transmit is finished.

MCUXpresso SDK API Reference Manual


428 NXP Semiconductors
LPUART Driver

Parameters

base LPUART peripheral base address.


data Start address of the data to write.
length Size of the data to write.

17.2.7.19 status_t LPUART_ReadBlocking ( LPUART_Type ∗ base, uint8_t ∗ data, size_t


length )

This function polls the receiver register, waits for the receiver register full or receiver FIFO has data, and
reads data from the TX register.
Parameters

base LPUART peripheral base address.


data Start address of the buffer to store the received data.
length Size of the buffer.

Return values

kStatus_LPUART_Rx- Receiver overrun happened while receiving data.


HardwareOverrun
kStatus_LPUART_Noise- Noise error happened while receiving data.
Error
kStatus_LPUART_- Framing error happened while receiving data.
FramingError
kStatus_LPUART_Parity- Parity error happened while receiving data.
Error
kStatus_Success Successfully received all data.

17.2.7.20 void LPUART_TransferCreateHandle ( LPUART_Type ∗ base, lpuart_handle_t ∗


handle, lpuart_transfer_callback_t callback, void ∗ userData )

This function initializes the LPUART handle, which can be used for other LPUART transactional APIs.
Usually, for a specified LPUART instance, call this API once to get the initialized handle.
The LPUART driver supports the "background" receiving, which means that user can set up an RX ring
buffer optionally. Data received is stored into the ring buffer even when the user doesn’t call the LP-
UART_TransferReceiveNonBlocking() API. If there is already data received in the ring buffer, the user
can get the received data from the ring buffer directly. The ring buffer is disabled if passing NULL as
ringBuffer.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 429
LPUART Driver

Parameters

base LPUART peripheral base address.


handle LPUART handle pointer.
callback Callback function.
userData User data.

17.2.7.21 status_t LPUART_TransferSendNonBlocking ( LPUART_Type ∗ base,


lpuart_handle_t ∗ handle, lpuart_transfer_t ∗ xfer )

This function send data using an interrupt method. This is a non-blocking function, which returns directly
without waiting for all data written to the transmitter register. When all data is written to the TX register
in the ISR, the LPUART driver calls the callback function and passes the kStatus_LPUART_TxIdle as
status parameter.
Note
The kStatus_LPUART_TxIdle is passed to the upper layer when all data are written to the TX
register. However, there is no check to ensure that all the data sent out. Before disabling the T-
X, check the kLPUART_TransmissionCompleteFlag to ensure that the transmit is finished.

Parameters

base LPUART peripheral base address.


handle LPUART handle pointer.
xfer LPUART transfer structure, see lpuart_transfer_t.

Return values

kStatus_Success Successfully start the data transmission.


kStatus_LPUART_TxBusy Previous transmission still not finished, data not all written to the TX reg-
ister.
kStatus_InvalidArgument Invalid argument.

17.2.7.22 void LPUART_TransferStartRingBuffer ( LPUART_Type ∗ base, lpuart_handle_t


∗ handle, uint8_t ∗ ringBuffer, size_t ringBufferSize )

This function sets up the RX ring buffer to a specific UART handle.


When the RX ring buffer is used, data received is stored into the ring buffer even when the user doesn’t
call the UART_TransferReceiveNonBlocking() API. If there is already data received in the ring buffer, the
user can get the received data from the ring buffer directly.

MCUXpresso SDK API Reference Manual


430 NXP Semiconductors
LPUART Driver

Note
When using RX ring buffer, one byte is reserved for internal use. In other words, if ringBuffer-
Size is 32, then only 31 bytes are used for saving data.

Parameters

base LPUART peripheral base address.


handle LPUART handle pointer.
ringBuffer Start address of ring buffer for background receiving. Pass NULL to disable the ring
buffer.
ringBufferSize size of the ring buffer.

17.2.7.23 void LPUART_TransferStopRingBuffer ( LPUART_Type ∗ base, lpuart_handle_t


∗ handle )

This function aborts the background transfer and uninstalls the ring buffer.
Parameters

base LPUART peripheral base address.


handle LPUART handle pointer.

17.2.7.24 size_t LPUART_TransferGetRxRingBufferLength ( LPUART_Type ∗ base,


lpuart_handle_t ∗ handle )

Parameters

handle LPUART handle pointer.

Returns
Length of received data in RX ring buffer.

17.2.7.25 void LPUART_TransferAbortSend ( LPUART_Type ∗ base, lpuart_handle_t ∗


handle )

This function aborts the interrupt driven data sending. The user can get the remainBtyes to find out how
many bytes are not sent out.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 431
LPUART Driver

Parameters

base LPUART peripheral base address.


handle LPUART handle pointer.

17.2.7.26 status_t LPUART_TransferGetSendCount ( LPUART_Type ∗ base,


lpuart_handle_t ∗ handle, uint32_t ∗ count )

This function gets the number of bytes that have been written to LPUART TX register by an interrupt
method.
Parameters

base LPUART peripheral base address.


handle LPUART handle pointer.
count Send bytes count.

Return values

kStatus_NoTransferIn- No send in progress.


Progress
kStatus_InvalidArgument Parameter is invalid.
kStatus_Success Get successfully through the parameter count;

17.2.7.27 status_t LPUART_TransferReceiveNonBlocking ( LPUART_Type ∗ base,


lpuart_handle_t ∗ handle, lpuart_transfer_t ∗ xfer, size_t ∗ receivedBytes )

This function receives data using an interrupt method. This is a non-blocking function which returns
without waiting to ensure that all data are received. If the RX ring buffer is used and not empty, the data in
the ring buffer is copied and the parameter receivedBytes shows how many bytes are copied from the
ring buffer. After copying, if the data in the ring buffer is not enough for read, the receive request is saved
by the LPUART driver. When the new data arrives, the receive request is serviced first. When all data
is received, the LPUART driver notifies the upper layer through a callback function and passes a status
parameter kStatus_UART_RxIdle. For example, the upper layer needs 10 bytes but there are only 5 bytes
in ring buffer. The 5 bytes are copied to xfer->data, which returns with the parameter receivedBytes
set to 5. For the remaining 5 bytes, the newly arrived data is saved from xfer->data[5]. When 5 bytes are
received, the LPUART driver notifies the upper layer. If the RX ring buffer is not enabled, this function
enables the RX and RX interrupt to receive data to xfer->data. When all data is received, the upper layer
is notified.

MCUXpresso SDK API Reference Manual


432 NXP Semiconductors
LPUART Driver

Parameters

base LPUART peripheral base address.


handle LPUART handle pointer.
xfer LPUART transfer structure, see uart_transfer_t.
receivedBytes Bytes received from the ring buffer directly.

Return values

kStatus_Success Successfully queue the transfer into the transmit queue.


kStatus_LPUART_Rx- Previous receive request is not finished.
Busy
kStatus_InvalidArgument Invalid argument.

17.2.7.28 void LPUART_TransferAbortReceive ( LPUART_Type ∗ base, lpuart_handle_t ∗


handle )

This function aborts the interrupt-driven data receiving. The user can get the remainBytes to find out how
many bytes not received yet.
Parameters

base LPUART peripheral base address.


handle LPUART handle pointer.

17.2.7.29 status_t LPUART_TransferGetReceiveCount ( LPUART_Type ∗ base,


lpuart_handle_t ∗ handle, uint32_t ∗ count )

This function gets the number of bytes that have been received.
Parameters

base LPUART peripheral base address.


handle LPUART handle pointer.
count Receive bytes count.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 433
LPUART Driver

Return values

kStatus_NoTransferIn- No receive in progress.


Progress
kStatus_InvalidArgument Parameter is invalid.
kStatus_Success Get successfully through the parameter count;

17.2.7.30 void LPUART_TransferHandleIRQ ( LPUART_Type ∗ base, lpuart_handle_t ∗


handle )

This function handles the LPUART transmit and receive IRQ request.
Parameters

base LPUART peripheral base address.


handle LPUART handle pointer.

17.2.7.31 void LPUART_TransferHandleErrorIRQ ( LPUART_Type ∗ base, lpuart_handle_t


∗ handle )

This function handles the LPUART error IRQ request.


Parameters

base LPUART peripheral base address.


handle LPUART handle pointer.

MCUXpresso SDK API Reference Manual


434 NXP Semiconductors
LPUART DMA Driver

17.3 LPUART DMA Driver


17.3.1 Overview

Data Structures

• struct lpuart_dma_handle_t
LPUART DMA handle. More...

Typedefs

• typedef void(∗ lpuart_dma_transfer_callback_t )(LPUART_Type ∗base, lpuart_dma_handle_t


∗handle, status_t status, void ∗userData)
LPUART transfer callback function.

Driver version

• #define FSL_LPUART_DMA_DRIVER_VERSION (MAKE_VERSION(2, 2, 6))


LPUART DMA driver version 2.2.6.

EDMA transactional

• void LPUART_TransferCreateHandleDMA (LPUART_Type ∗base, lpuart_dma_handle_t ∗handle,


lpuart_dma_transfer_callback_t callback, void ∗userData, dma_handle_t ∗txDmaHandle, dma_-
handle_t ∗rxDmaHandle)
Initializes the LPUART handle which is used in transactional functions.
• status_t LPUART_TransferSendDMA (LPUART_Type ∗base, lpuart_dma_handle_t ∗handle,
lpuart_transfer_t ∗xfer)
Sends data using DMA.
• status_t LPUART_TransferReceiveDMA (LPUART_Type ∗base, lpuart_dma_handle_t ∗handle,
lpuart_transfer_t ∗xfer)
Receives data using DMA.
• void LPUART_TransferAbortSendDMA (LPUART_Type ∗base, lpuart_dma_handle_t ∗handle)
Aborts the sent data using DMA.
• void LPUART_TransferAbortReceiveDMA (LPUART_Type ∗base, lpuart_dma_handle_t ∗handle)
Aborts the received data using DMA.
• status_t LPUART_TransferGetSendCountDMA (LPUART_Type ∗base, lpuart_dma_handle_t
∗handle, uint32_t ∗count)
Gets the number of bytes written to the LPUART TX register.
• status_t LPUART_TransferGetReceiveCountDMA (LPUART_Type ∗base, lpuart_dma_handle_-
t ∗handle, uint32_t ∗count)
Gets the number of received bytes.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 435
LPUART DMA Driver

17.3.2 Data Structure Documentation

17.3.2.1 struct _lpuart_dma_handle

Data Fields
• lpuart_dma_transfer_callback_t callback
Callback function.
• void ∗ userData
LPUART callback function parameter.
• size_t rxDataSizeAll
Size of the data to receive.
• size_t txDataSizeAll
Size of the data to send out.
• dma_handle_t ∗ txDmaHandle
The DMA TX channel used.
• dma_handle_t ∗ rxDmaHandle
The DMA RX channel used.
• volatile uint8_t txState
TX transfer state.
• volatile uint8_t rxState
RX transfer state.

MCUXpresso SDK API Reference Manual


436 NXP Semiconductors
LPUART DMA Driver

17.3.2.1.0.12 Field Documentation

17.3.2.1.0.12.1 lpuart_dma_transfer_callback_t lpuart_dma_handle_t::callback

17.3.2.1.0.12.2 void∗ lpuart_dma_handle_t::userData

17.3.2.1.0.12.3 size_t lpuart_dma_handle_t::rxDataSizeAll

17.3.2.1.0.12.4 size_t lpuart_dma_handle_t::txDataSizeAll

17.3.2.1.0.12.5 dma_handle_t∗ lpuart_dma_handle_t::txDmaHandle

17.3.2.1.0.12.6 dma_handle_t∗ lpuart_dma_handle_t::rxDmaHandle

17.3.2.1.0.12.7 volatile uint8_t lpuart_dma_handle_t::txState

17.3.3 Macro Definition Documentation

17.3.3.1 #define FSL_LPUART_DMA_DRIVER_VERSION (MAKE_VERSION(2, 2, 6))

17.3.4 Typedef Documentation

17.3.4.1 typedef void(∗ lpuart_dma_transfer_callback_t)(LPUART_Type ∗base,


lpuart_dma_handle_t ∗handle, status_t status, void ∗userData)

17.3.5 Function Documentation

17.3.5.1 void LPUART_TransferCreateHandleDMA ( LPUART_Type ∗ base,


lpuart_dma_handle_t ∗ handle, lpuart_dma_transfer_callback_t callback, void ∗
userData, dma_handle_t ∗ txDmaHandle, dma_handle_t ∗ rxDmaHandle )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 437
LPUART DMA Driver

Parameters

base LPUART peripheral base address.


handle Pointer to lpuart_dma_handle_t structure.
callback Callback function.
userData User data.
txDmaHandle User-requested DMA handle for TX DMA transfer.
rxDmaHandle User-requested DMA handle for RX DMA transfer.

17.3.5.2 status_t LPUART_TransferSendDMA ( LPUART_Type ∗ base,


lpuart_dma_handle_t ∗ handle, lpuart_transfer_t ∗ xfer )

This function sends data using DMA. This is a non-blocking function, which returns right away. When all
data is sent, the send callback function is called.
Parameters

base LPUART peripheral base address.


handle LPUART handle pointer.
xfer LPUART DMA transfer structure. See lpuart_transfer_t.

Return values

kStatus_Success if succeed, others failed.


kStatus_LPUART_TxBusy Previous transfer on going.
kStatus_InvalidArgument Invalid argument.

17.3.5.3 status_t LPUART_TransferReceiveDMA ( LPUART_Type ∗ base,


lpuart_dma_handle_t ∗ handle, lpuart_transfer_t ∗ xfer )

This function receives data using DMA. This is a non-blocking function, which returns right away. When
all data is received, the receive callback function is called.
Parameters

MCUXpresso SDK API Reference Manual


438 NXP Semiconductors
LPUART DMA Driver

base LPUART peripheral base address.


handle Pointer to lpuart_dma_handle_t structure.
xfer LPUART DMA transfer structure. See lpuart_transfer_t.

Return values

kStatus_Success if succeed, others failed.


kStatus_LPUART_Rx- Previous transfer on going.
Busy
kStatus_InvalidArgument Invalid argument.

17.3.5.4 void LPUART_TransferAbortSendDMA ( LPUART_Type ∗ base,


lpuart_dma_handle_t ∗ handle )

This function aborts send data using DMA.


Parameters

base LPUART peripheral base address


handle Pointer to lpuart_dma_handle_t structure

17.3.5.5 void LPUART_TransferAbortReceiveDMA ( LPUART_Type ∗ base,


lpuart_dma_handle_t ∗ handle )

This function aborts the received data using DMA.


Parameters

base LPUART peripheral base address


handle Pointer to lpuart_dma_handle_t structure

17.3.5.6 status_t LPUART_TransferGetSendCountDMA ( LPUART_Type ∗ base,


lpuart_dma_handle_t ∗ handle, uint32_t ∗ count )

This function gets the number of bytes that have been written to LPUART TX register by DMA.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 439
LPUART DMA Driver

Parameters

base LPUART peripheral base address.


handle LPUART handle pointer.
count Send bytes count.

Return values

kStatus_NoTransferIn- No send in progress.


Progress
kStatus_InvalidArgument Parameter is invalid.
kStatus_Success Get successfully through the parameter count;

17.3.5.7 status_t LPUART_TransferGetReceiveCountDMA ( LPUART_Type ∗ base,


lpuart_dma_handle_t ∗ handle, uint32_t ∗ count )

This function gets the number of received bytes.


Parameters

base LPUART peripheral base address.


handle LPUART handle pointer.
count Receive bytes count.

Return values

kStatus_NoTransferIn- No receive in progress.


Progress
kStatus_InvalidArgument Parameter is invalid.
kStatus_Success Get successfully through the parameter count;

MCUXpresso SDK API Reference Manual


440 NXP Semiconductors
LPUART eDMA Driver

17.4 LPUART eDMA Driver


17.4.1 Overview

Data Structures

• struct lpuart_edma_handle_t
LPUART eDMA handle. More...

Typedefs

• typedef void(∗ lpuart_edma_transfer_callback_t )(LPUART_Type ∗base, lpuart_edma_handle_-


t ∗handle, status_t status, void ∗userData)
LPUART transfer callback function.

Driver version

• #define FSL_LPUART_EDMA_DRIVER_VERSION (MAKE_VERSION(2, 2, 7))


LPUART EDMA driver version 2.2.7.

eDMA transactional

• void LPUART_TransferCreateHandleEDMA (LPUART_Type ∗base, lpuart_edma_handle_-


t ∗handle, lpuart_edma_transfer_callback_t callback, void ∗userData, edma_handle_t ∗txEdma-
Handle, edma_handle_t ∗rxEdmaHandle)
Initializes the LPUART handle which is used in transactional functions.
• status_t LPUART_SendEDMA (LPUART_Type ∗base, lpuart_edma_handle_t ∗handle, lpuart_-
transfer_t ∗xfer)
Sends data using eDMA.
• status_t LPUART_ReceiveEDMA (LPUART_Type ∗base, lpuart_edma_handle_t ∗handle, lpuart_-
transfer_t ∗xfer)
Receives data using eDMA.
• void LPUART_TransferAbortSendEDMA (LPUART_Type ∗base, lpuart_edma_handle_t ∗handle)
Aborts the sent data using eDMA.
• void LPUART_TransferAbortReceiveEDMA (LPUART_Type ∗base, lpuart_edma_handle_-
t ∗handle)
Aborts the received data using eDMA.
• status_t LPUART_TransferGetSendCountEDMA (LPUART_Type ∗base, lpuart_edma_handle_-
t ∗handle, uint32_t ∗count)
Gets the number of bytes written to the LPUART TX register.
• status_t LPUART_TransferGetReceiveCountEDMA (LPUART_Type ∗base, lpuart_edma_handle-
_t ∗handle, uint32_t ∗count)
Gets the number of received bytes.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 441
LPUART eDMA Driver

17.4.2 Data Structure Documentation

17.4.2.1 struct _lpuart_edma_handle

Data Fields
• lpuart_edma_transfer_callback_t callback
Callback function.
• void ∗ userData
LPUART callback function parameter.
• size_t rxDataSizeAll
Size of the data to receive.
• size_t txDataSizeAll
Size of the data to send out.
• edma_handle_t ∗ txEdmaHandle
The eDMA TX channel used.
• edma_handle_t ∗ rxEdmaHandle
The eDMA RX channel used.
• uint8_t nbytes
eDMA minor byte transfer count initially configured.
• volatile uint8_t txState
TX transfer state.
• volatile uint8_t rxState
RX transfer state.

MCUXpresso SDK API Reference Manual


442 NXP Semiconductors
LPUART eDMA Driver

17.4.2.1.0.13 Field Documentation

17.4.2.1.0.13.1 lpuart_edma_transfer_callback_t lpuart_edma_handle_t::callback

17.4.2.1.0.13.2 void∗ lpuart_edma_handle_t::userData

17.4.2.1.0.13.3 size_t lpuart_edma_handle_t::rxDataSizeAll

17.4.2.1.0.13.4 size_t lpuart_edma_handle_t::txDataSizeAll

17.4.2.1.0.13.5 edma_handle_t∗ lpuart_edma_handle_t::txEdmaHandle

17.4.2.1.0.13.6 edma_handle_t∗ lpuart_edma_handle_t::rxEdmaHandle

17.4.2.1.0.13.7 uint8_t lpuart_edma_handle_t::nbytes

17.4.2.1.0.13.8 volatile uint8_t lpuart_edma_handle_t::txState

17.4.3 Macro Definition Documentation

17.4.3.1 #define FSL_LPUART_EDMA_DRIVER_VERSION (MAKE_VERSION(2, 2, 7))

17.4.4 Typedef Documentation

17.4.4.1 typedef void(∗ lpuart_edma_transfer_callback_t)(LPUART_Type ∗base,


lpuart_edma_handle_t ∗handle, status_t status, void ∗userData)

17.4.5 Function Documentation

17.4.5.1 void LPUART_TransferCreateHandleEDMA ( LPUART_Type ∗ base,


lpuart_edma_handle_t ∗ handle, lpuart_edma_transfer_callback_t callback, void
∗ userData, edma_handle_t ∗ txEdmaHandle, edma_handle_t ∗ rxEdmaHandle )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 443
LPUART eDMA Driver

Parameters

base LPUART peripheral base address.


handle Pointer to lpuart_edma_handle_t structure.
callback Callback function.
userData User data.
txEdmaHandle User requested DMA handle for TX DMA transfer.
rxEdmaHandle User requested DMA handle for RX DMA transfer.

17.4.5.2 status_t LPUART_SendEDMA ( LPUART_Type ∗ base, lpuart_edma_handle_t ∗


handle, lpuart_transfer_t ∗ xfer )

This function sends data using eDMA. This is a non-blocking function, which returns right away. When
all data is sent, the send callback function is called.
Parameters

base LPUART peripheral base address.


handle LPUART handle pointer.
xfer LPUART eDMA transfer structure. See lpuart_transfer_t.

Return values

kStatus_Success if succeed, others failed.


kStatus_LPUART_TxBusy Previous transfer on going.
kStatus_InvalidArgument Invalid argument.

17.4.5.3 status_t LPUART_ReceiveEDMA ( LPUART_Type ∗ base, lpuart_edma_handle_t


∗ handle, lpuart_transfer_t ∗ xfer )

This function receives data using eDMA. This is non-blocking function, which returns right away. When
all data is received, the receive callback function is called.
Parameters

MCUXpresso SDK API Reference Manual


444 NXP Semiconductors
LPUART eDMA Driver

base LPUART peripheral base address.


handle Pointer to lpuart_edma_handle_t structure.
xfer LPUART eDMA transfer structure, see lpuart_transfer_t.

Return values

kStatus_Success if succeed, others fail.


kStatus_LPUART_Rx- Previous transfer ongoing.
Busy
kStatus_InvalidArgument Invalid argument.

17.4.5.4 void LPUART_TransferAbortSendEDMA ( LPUART_Type ∗ base,


lpuart_edma_handle_t ∗ handle )

This function aborts the sent data using eDMA.


Parameters

base LPUART peripheral base address.


handle Pointer to lpuart_edma_handle_t structure.

17.4.5.5 void LPUART_TransferAbortReceiveEDMA ( LPUART_Type ∗ base,


lpuart_edma_handle_t ∗ handle )

This function aborts the received data using eDMA.


Parameters

base LPUART peripheral base address.


handle Pointer to lpuart_edma_handle_t structure.

17.4.5.6 status_t LPUART_TransferGetSendCountEDMA ( LPUART_Type ∗ base,


lpuart_edma_handle_t ∗ handle, uint32_t ∗ count )

This function gets the number of bytes written to the LPUART TX register by DMA.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 445
LPUART eDMA Driver

Parameters

base LPUART peripheral base address.


handle LPUART handle pointer.
count Send bytes count.

Return values

kStatus_NoTransferIn- No send in progress.


Progress
kStatus_InvalidArgument Parameter is invalid.
kStatus_Success Get successfully through the parameter count;

17.4.5.7 status_t LPUART_TransferGetReceiveCountEDMA ( LPUART_Type ∗ base,


lpuart_edma_handle_t ∗ handle, uint32_t ∗ count )

This function gets the number of received bytes.


Parameters

base LPUART peripheral base address.


handle LPUART handle pointer.
count Receive bytes count.

Return values

kStatus_NoTransferIn- No receive in progress.


Progress
kStatus_InvalidArgument Parameter is invalid.
kStatus_Success Get successfully through the parameter count;

MCUXpresso SDK API Reference Manual


446 NXP Semiconductors
LPUART FreeRTOS Driver

17.5 LPUART FreeRTOS Driver


17.5.1 Overview

Data Structures

• struct lpuart_rtos_config_t
LPUART RTOS configuration structure. More...

Driver version

• #define FSL_LPUART_FREERTOS_DRIVER_VERSION (MAKE_VERSION(2, 2, 6))


LPUART freertos driver version 2.2.6.

LPUART RTOS Operation

• int LPUART_RTOS_Init (lpuart_rtos_handle_t ∗handle, lpuart_handle_t ∗t_handle, const lpuart_-


rtos_config_t ∗cfg)
Initializes an LPUART instance for operation in RTOS.
• int LPUART_RTOS_Deinit (lpuart_rtos_handle_t ∗handle)
Deinitializes an LPUART instance for operation.

LPUART transactional Operation

• int LPUART_RTOS_Send (lpuart_rtos_handle_t ∗handle, const uint8_t ∗buffer, uint32_t length)


Sends data in the background.
• int LPUART_RTOS_Receive (lpuart_rtos_handle_t ∗handle, uint8_t ∗buffer, uint32_t length, size_t
∗received)
Receives data.

17.5.2 Data Structure Documentation

17.5.2.1 struct lpuart_rtos_config_t

Data Fields
• LPUART_Type ∗ base
UART base address.
• uint32_t srcclk
UART source clock in Hz.
• uint32_t baudrate
Desired communication speed.
• lpuart_parity_mode_t parity
Parity setting.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 447
LPUART FreeRTOS Driver

• lpuart_stop_bit_count_t stopbits
Number of stop bits to use.
• uint8_t ∗ buffer
Buffer for background reception.
• uint32_t buffer_size
Size of buffer for background reception.

17.5.3 Macro Definition Documentation

17.5.3.1 #define FSL_LPUART_FREERTOS_DRIVER_VERSION (MAKE_VERSION(2, 2,


6))

17.5.4 Function Documentation

17.5.4.1 int LPUART_RTOS_Init ( lpuart_rtos_handle_t ∗ handle, lpuart_handle_t ∗


t_handle, const lpuart_rtos_config_t ∗ cfg )

Parameters

handle The RTOS LPUART handle, the pointer to an allocated space for RTOS context.
t_handle The pointer to an allocated space to store the transactional layer internal state.
cfg The pointer to the parameters required to configure the LPUART after initialization.

Returns
0 succeed, others failed

17.5.4.2 int LPUART_RTOS_Deinit ( lpuart_rtos_handle_t ∗ handle )

This function deinitializes the LPUART module, sets all register value to the reset value, and releases the
resources.
Parameters

handle The RTOS LPUART handle.

17.5.4.3 int LPUART_RTOS_Send ( lpuart_rtos_handle_t ∗ handle, const uint8_t ∗ buffer,


uint32_t length )

This function sends data. It is an synchronous API. If the hardware buffer is full, the task is in the blocked
state.

MCUXpresso SDK API Reference Manual


448 NXP Semiconductors
LPUART FreeRTOS Driver

Parameters

handle The RTOS LPUART handle.


buffer The pointer to buffer to send.
length The number of bytes to send.

17.5.4.4 int LPUART_RTOS_Receive ( lpuart_rtos_handle_t ∗ handle, uint8_t ∗ buffer,


uint32_t length, size_t ∗ received )

This function receives data from LPUART. It is an synchronous API. If any data is immediately available
it is returned immediately and the number of bytes received.
Parameters

handle The RTOS LPUART handle.


buffer The pointer to buffer where to write received data.
length The number of bytes to receive.
received The pointer to a variable of size_t where the number of received data is filled.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 449
LPUART FreeRTOS Driver

MCUXpresso SDK API Reference Manual


450 NXP Semiconductors
Chapter 18
PIT: Periodic Interrupt Timer
18.1 Overview
The MCUXpresso SDK provides a driver for the Periodic Interrupt Timer (PIT) of MCUXpresso SDK
devices.

18.2 Function groups


The PIT driver supports operating the module as a time counter.

18.2.1 Initialization and deinitialization

The function PIT_Init() initializes the PIT with specified configurations. The function PIT_GetDefault-
Config() gets the default configurations. The initialization function configures the PIT operation in debug
mode.
The function PIT_SetTimerChainMode() configures the chain mode operation of each PIT channel.
The function PIT_Deinit() disables the PIT timers and disables the module clock.

18.2.2 Timer period Operations

The function PITR_SetTimerPeriod() sets the timer period in units of count. Timers begin counting down
from the value set by this function until it reaches 0.
The function PIT_GetCurrentTimerCount() reads the current timer counting value. This function returns
the real-time timer counting value, in a range from 0 to a timer period.
The timer period operation functions takes the count value in ticks. Users can call the utility macros
provided in fsl_common.h to convert to microseconds or milliseconds.

18.2.3 Start and Stop timer operations

The function PIT_StartTimer() starts the timer counting. After calling this function, the timer loads the
period value set earlier via the PIT_SetPeriod() function and starts counting down to 0. When the timer
reaches 0, it generates a trigger pulse and sets the timeout interrupt flag.
The function PIT_StopTimer() stops the timer counting.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 451
Typical use case

18.2.4 Status

Provides functions to get and clear the PIT status.

18.2.5 Interrupt

Provides functions to enable/disable PIT interrupts and get current enabled interrupts.

18.3 Typical use case


18.3.1 PIT tick example

Updates the PIT period and toggles an LED periodically. Refer to the driver examples codes located at
<SDK_ROOT>/boards/<BOARD>/driver_examples/pit

Data Structures
• struct pit_config_t
PIT configuration structure. More...

Enumerations
• enum pit_chnl_t {
kPIT_Chnl_0 = 0U,
kPIT_Chnl_1,
kPIT_Chnl_2,
kPIT_Chnl_3 }
List of PIT channels.
• enum pit_interrupt_enable_t { kPIT_TimerInterruptEnable = PIT_TCTRL_TIE_MASK }
List of PIT interrupts.
• enum pit_status_flags_t { kPIT_TimerFlag = PIT_TFLG_TIF_MASK }
List of PIT status flags.

Functions
• uint64_t PIT_GetLifetimeTimerCount (PIT_Type ∗base)
Reads the current lifetime counter value.

Driver version
• #define FSL_PIT_DRIVER_VERSION (MAKE_VERSION(2, 0, 2))
PIT Driver Version 2.0.2.

Initialization and deinitialization


• void PIT_Init (PIT_Type ∗base, const pit_config_t ∗config)

MCUXpresso SDK API Reference Manual


452 NXP Semiconductors
Data Structure Documentation

Ungates the PIT clock, enables the PIT module, and configures the peripheral for basic operations.
• void PIT_Deinit (PIT_Type ∗base)
Gates the PIT clock and disables the PIT module.
• static void PIT_GetDefaultConfig (pit_config_t ∗config)
Fills in the PIT configuration structure with the default settings.
• static void PIT_SetTimerChainMode (PIT_Type ∗base, pit_chnl_t channel, bool enable)
Enables or disables chaining a timer with the previous timer.

Interrupt Interface
• static void PIT_EnableInterrupts (PIT_Type ∗base, pit_chnl_t channel, uint32_t mask)
Enables the selected PIT interrupts.
• static void PIT_DisableInterrupts (PIT_Type ∗base, pit_chnl_t channel, uint32_t mask)
Disables the selected PIT interrupts.
• static uint32_t PIT_GetEnabledInterrupts (PIT_Type ∗base, pit_chnl_t channel)
Gets the enabled PIT interrupts.

Status Interface
• static uint32_t PIT_GetStatusFlags (PIT_Type ∗base, pit_chnl_t channel)
Gets the PIT status flags.
• static void PIT_ClearStatusFlags (PIT_Type ∗base, pit_chnl_t channel, uint32_t mask)
Clears the PIT status flags.

Read and Write the timer period


• static void PIT_SetTimerPeriod (PIT_Type ∗base, pit_chnl_t channel, uint32_t count)
Sets the timer period in units of count.
• static uint32_t PIT_GetCurrentTimerCount (PIT_Type ∗base, pit_chnl_t channel)
Reads the current timer counting value.

Timer Start and Stop


• static void PIT_StartTimer (PIT_Type ∗base, pit_chnl_t channel)
Starts the timer counting.
• static void PIT_StopTimer (PIT_Type ∗base, pit_chnl_t channel)
Stops the timer counting.

18.4 Data Structure Documentation


18.4.1 struct pit_config_t

This structure holds the configuration settings for the PIT peripheral. To initialize this structure to rea-
sonable defaults, call the PIT_GetDefaultConfig() function and pass a pointer to your config structure
instance.
The configuration structure can be made constant so it resides in flash.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 453
Function Documentation

Data Fields

• bool enableRunInDebug
true: Timers run in debug mode; false: Timers stop in debug mode

18.5 Enumeration Type Documentation


18.5.1 enum pit_chnl_t

Note
Actual number of available channels is SoC dependent

Enumerator
kPIT_Chnl_0 PIT channel number 0.
kPIT_Chnl_1 PIT channel number 1.
kPIT_Chnl_2 PIT channel number 2.
kPIT_Chnl_3 PIT channel number 3.

18.5.2 enum pit_interrupt_enable_t

Enumerator
kPIT_TimerInterruptEnable Timer interrupt enable.

18.5.3 enum pit_status_flags_t

Enumerator
kPIT_TimerFlag Timer flag.

18.6 Function Documentation


18.6.1 void PIT_Init ( PIT_Type ∗ base, const pit_config_t ∗ config )

Note
This API should be called at the beginning of the application using the PIT driver.

MCUXpresso SDK API Reference Manual


454 NXP Semiconductors
Function Documentation

Parameters

base PIT peripheral base address


config Pointer to the user’s PIT config structure

18.6.2 void PIT_Deinit ( PIT_Type ∗ base )

Parameters

base PIT peripheral base address

18.6.3 static void PIT_GetDefaultConfig ( pit_config_t ∗ config ) [inline],


[static]

The default values are as follows.

* config->enableRunInDebug = false;
*

Parameters

config Pointer to the configuration structure.

18.6.4 static void PIT_SetTimerChainMode ( PIT_Type ∗ base, pit_chnl_t channel,


bool enable ) [inline], [static]

When a timer has a chain mode enabled, it only counts after the previous timer has expired. If the timer
n-1 has counted down to 0, counter n decrements the value by one. Each timer is 32-bits, which allows the
developers to chain timers together and form a longer timer (64-bits and larger). The first timer (timer 0)
can’t be chained to any other timer.
Parameters

base PIT peripheral base address

MCUXpresso SDK API Reference Manual


NXP Semiconductors 455
Function Documentation

channel Timer channel number which is chained with the previous timer
enable Enable or disable chain. true: Current timer is chained with the previous timer. false:
Timer doesn’t chain with other timers.

18.6.5 static void PIT_EnableInterrupts ( PIT_Type ∗ base, pit_chnl_t channel,


uint32_t mask ) [inline], [static]

Parameters

base PIT peripheral base address


channel Timer channel number
mask The interrupts to enable. This is a logical OR of members of the enumeration pit_-
interrupt_enable_t

18.6.6 static void PIT_DisableInterrupts ( PIT_Type ∗ base, pit_chnl_t channel,


uint32_t mask ) [inline], [static]

Parameters

base PIT peripheral base address


channel Timer channel number
mask The interrupts to disable. This is a logical OR of members of the enumeration pit_-
interrupt_enable_t

18.6.7 static uint32_t PIT_GetEnabledInterrupts ( PIT_Type ∗ base, pit_chnl_t


channel ) [inline], [static]

Parameters

base PIT peripheral base address


channel Timer channel number

Returns
The enabled interrupts. This is the logical OR of members of the enumeration pit_interrupt_enable_t

MCUXpresso SDK API Reference Manual


456 NXP Semiconductors
Function Documentation

18.6.8 static uint32_t PIT_GetStatusFlags ( PIT_Type ∗ base, pit_chnl_t channel )


[inline], [static]

MCUXpresso SDK API Reference Manual


NXP Semiconductors 457
Function Documentation

Parameters

base PIT peripheral base address


channel Timer channel number

Returns
The status flags. This is the logical OR of members of the enumeration pit_status_flags_t

18.6.9 static void PIT_ClearStatusFlags ( PIT_Type ∗ base, pit_chnl_t channel,


uint32_t mask ) [inline], [static]

Parameters

base PIT peripheral base address


channel Timer channel number
mask The status flags to clear. This is a logical OR of members of the enumeration pit_-
status_flags_t

18.6.10 static void PIT_SetTimerPeriod ( PIT_Type ∗ base, pit_chnl_t channel,


uint32_t count ) [inline], [static]

Timers begin counting from the value set by this function until it reaches 0, then it generates an interrupt
and load this register value again. Writing a new value to this register does not restart the timer. Instead,
the value is loaded after the timer expires.

Note
Users can call the utility macros provided in fsl_common.h to convert to ticks.

Parameters

base PIT peripheral base address


channel Timer channel number

MCUXpresso SDK API Reference Manual


458 NXP Semiconductors
Function Documentation

count Timer period in units of ticks

18.6.11 static uint32_t PIT_GetCurrentTimerCount ( PIT_Type ∗ base, pit_chnl_t


channel ) [inline], [static]

This function returns the real-time timer counting value, in a range from 0 to a timer period.

Note
Users can call the utility macros provided in fsl_common.h to convert ticks to usec or msec.

Parameters

base PIT peripheral base address


channel Timer channel number

Returns
Current timer counting value in ticks

18.6.12 static void PIT_StartTimer ( PIT_Type ∗ base, pit_chnl_t channel )


[inline], [static]

After calling this function, timers load period value, count down to 0 and then load the respective start
value again. Each time a timer reaches 0, it generates a trigger pulse and sets the timeout interrupt flag.
Parameters

base PIT peripheral base address


channel Timer channel number.

18.6.13 static void PIT_StopTimer ( PIT_Type ∗ base, pit_chnl_t channel )


[inline], [static]

This function stops every timer counting. Timers reload their periods respectively after the next time they
call the PIT_DRV_StartTimer.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 459
Function Documentation

Parameters

base PIT peripheral base address


channel Timer channel number.

18.6.14 uint64_t PIT_GetLifetimeTimerCount ( PIT_Type ∗ base )

The lifetime timer is a 64-bit timer which chains timer 0 and timer 1 together. Timer 0 and 1 are chained
by calling the PIT_SetTimerChainMode before using this timer. The period of lifetime timer is equal to
the "period of timer 0 ∗ period of timer 1". For the 64-bit value, the higher 32-bit has the value of timer 1,
and the lower 32-bit has the value of timer 0.
Parameters

base PIT peripheral base address

Returns
Current lifetime timer value

MCUXpresso SDK API Reference Manual


460 NXP Semiconductors
Chapter 19
PMC: Power Management Controller
19.1 Overview
The MCUXpresso SDK provides a peripheral driver for the Power Management Controller (PMC) module
of MCUXpresso SDK devices. The PMC module contains internal voltage regulator, power on reset, low-
voltage detect system, and high-voltage detect system.

Data Structures
• struct pmc_low_volt_detect_config_t
Low-voltage Detect Configuration Structure. More...
• struct pmc_low_volt_warning_config_t
Low-voltage Warning Configuration Structure. More...
• struct pmc_bandgap_buffer_config_t
Bandgap Buffer configuration. More...

Enumerations
• enum pmc_low_volt_detect_volt_select_t {
kPMC_LowVoltDetectLowTrip = 0U,
kPMC_LowVoltDetectHighTrip = 1U }
Low-voltage Detect Voltage Select.
• enum pmc_low_volt_warning_volt_select_t {
kPMC_LowVoltWarningLowTrip = 0U,
kPMC_LowVoltWarningMid1Trip = 1U,
kPMC_LowVoltWarningMid2Trip = 2U,
kPMC_LowVoltWarningHighTrip = 3U }
Low-voltage Warning Voltage Select.

Driver version
• #define FSL_PMC_DRIVER_VERSION (MAKE_VERSION(2, 0, 1))
PMC driver version.

Power Management Controller Control APIs


• void PMC_ConfigureLowVoltDetect (PMC_Type ∗base, const pmc_low_volt_detect_config_-
t ∗config)
Configures the low-voltage detect setting.
• static bool PMC_GetLowVoltDetectFlag (PMC_Type ∗base)
Gets the Low-voltage Detect Flag status.
• static void PMC_ClearLowVoltDetectFlag (PMC_Type ∗base)
Acknowledges clearing the Low-voltage Detect flag.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 461
Data Structure Documentation

• void PMC_ConfigureLowVoltWarning (PMC_Type ∗base, const pmc_low_volt_warning_config_t


∗config)
Configures the low-voltage warning setting.
• static bool PMC_GetLowVoltWarningFlag (PMC_Type ∗base)
Gets the Low-voltage Warning Flag status.
• static void PMC_ClearLowVoltWarningFlag (PMC_Type ∗base)
Acknowledges the Low-voltage Warning flag.
• void PMC_ConfigureBandgapBuffer (PMC_Type ∗base, const pmc_bandgap_buffer_config_t
∗config)
Configures the PMC bandgap.
• static bool PMC_GetPeriphIOIsolationFlag (PMC_Type ∗base)
Gets the acknowledge Peripherals and I/O pads isolation flag.
• static void PMC_ClearPeriphIOIsolationFlag (PMC_Type ∗base)
Acknowledges the isolation flag to Peripherals and I/O pads.
• static bool PMC_IsRegulatorInRunRegulation (PMC_Type ∗base)
Gets the regulator regulation status.

19.2 Data Structure Documentation


19.2.1 struct pmc_low_volt_detect_config_t

Data Fields

• bool enableInt
Enable interrupt when Low-voltage detect.
• bool enableReset
Enable system reset when Low-voltage detect.
• pmc_low_volt_detect_volt_select_t voltSelect
Low-voltage detect trip point voltage selection.

19.2.2 struct pmc_low_volt_warning_config_t

Data Fields

• bool enableInt
Enable interrupt when low-voltage warning.
• pmc_low_volt_warning_volt_select_t voltSelect
Low-voltage warning trip point voltage selection.

19.2.3 struct pmc_bandgap_buffer_config_t

Data Fields

• bool enable
Enable bandgap buffer.
• bool enableInLowPowerMode

MCUXpresso SDK API Reference Manual


462 NXP Semiconductors
Function Documentation

Enable bandgap buffer in low-power mode.

19.2.3.0.0.14 Field Documentation

19.2.3.0.0.14.1 bool pmc_bandgap_buffer_config_t::enable

19.2.3.0.0.14.2 bool pmc_bandgap_buffer_config_t::enableInLowPowerMode

19.3 Macro Definition Documentation


19.3.1 #define FSL_PMC_DRIVER_VERSION (MAKE_VERSION(2, 0, 1))

Version 2.0.1.

19.4 Enumeration Type Documentation


19.4.1 enum pmc_low_volt_detect_volt_select_t

Enumerator
kPMC_LowVoltDetectLowTrip Low-trip point selected (VLVD = VLVDL )
kPMC_LowVoltDetectHighTrip High-trip point selected (VLVD = VLVDH )

19.4.2 enum pmc_low_volt_warning_volt_select_t

Enumerator
kPMC_LowVoltWarningLowTrip Low-trip point selected (VLVW = VLVW1)
kPMC_LowVoltWarningMid1Trip Mid 1 trip point selected (VLVW = VLVW2)
kPMC_LowVoltWarningMid2Trip Mid 2 trip point selected (VLVW = VLVW3)
kPMC_LowVoltWarningHighTrip High-trip point selected (VLVW = VLVW4)

19.5 Function Documentation


19.5.1 void PMC_ConfigureLowVoltDetect ( PMC_Type ∗ base, const
pmc_low_volt_detect_config_t ∗ config )

This function configures the low-voltage detect setting, including the trip point voltage setting, enables or
disables the interrupt, enables or disables the system reset.
Parameters

MCUXpresso SDK API Reference Manual


NXP Semiconductors 463
Function Documentation

base PMC peripheral base address.


config Low-voltage detect configuration structure.

19.5.2 static bool PMC_GetLowVoltDetectFlag ( PMC_Type ∗ base ) [inline],


[static]

This function reads the current LVDF status. If it returns 1, a low-voltage event is detected.
Parameters

base PMC peripheral base address.

Returns
Current low-voltage detect flag
• true: Low-voltage detected
• false: Low-voltage not detected

19.5.3 static void PMC_ClearLowVoltDetectFlag ( PMC_Type ∗ base ) [inline],


[static]

This function acknowledges the low-voltage detection errors (write 1 to clear LVDF).
Parameters

base PMC peripheral base address.

19.5.4 void PMC_ConfigureLowVoltWarning ( PMC_Type ∗ base, const


pmc_low_volt_warning_config_t ∗ config )

This function configures the low-voltage warning setting, including the trip point voltage setting and en-
abling or disabling the interrupt.
Parameters

MCUXpresso SDK API Reference Manual


464 NXP Semiconductors
Function Documentation

base PMC peripheral base address.


config Low-voltage warning configuration structure.

19.5.5 static bool PMC_GetLowVoltWarningFlag ( PMC_Type ∗ base ) [inline],


[static]

This function polls the current LVWF status. When 1 is returned, it indicates a low-voltage warning event.
LVWF is set when V Supply transitions below the trip point or after reset and V Supply is already below
the V LVW.
Parameters

base PMC peripheral base address.

Returns
Current LVWF status
• true: Low-voltage Warning Flag is set.
• false: the Low-voltage Warning does not happen.

19.5.6 static void PMC_ClearLowVoltWarningFlag ( PMC_Type ∗ base )


[inline], [static]

This function acknowledges the low voltage warning errors (write 1 to clear LVWF).
Parameters

base PMC peripheral base address.

19.5.7 void PMC_ConfigureBandgapBuffer ( PMC_Type ∗ base, const


pmc_bandgap_buffer_config_t ∗ config )

This function configures the PMC bandgap, including the drive select and behavior in low-power mode.
Parameters

MCUXpresso SDK API Reference Manual


NXP Semiconductors 465
Function Documentation

base PMC peripheral base address.


config Pointer to the configuration structure

19.5.8 static bool PMC_GetPeriphIOIsolationFlag ( PMC_Type ∗ base )


[inline], [static]

This function reads the Acknowledge Isolation setting that indicates whether certain peripherals and the
I/O pads are in a latched state as a result of having been in the VLLS mode.
Parameters

base PMC peripheral base address.


base Base address for current PMC instance.

Returns
ACK isolation 0 - Peripherals and I/O pads are in a normal run state. 1 - Certain peripherals and I/O
pads are in an isolated and latched state.

19.5.9 static void PMC_ClearPeriphIOIsolationFlag ( PMC_Type ∗ base )


[inline], [static]

This function clears the ACK Isolation flag. Writing one to this setting when it is set releases the I/O pads
and certain peripherals to their normal run mode state.
Parameters

base PMC peripheral base address.

19.5.10 static bool PMC_IsRegulatorInRunRegulation ( PMC_Type ∗ base )


[inline], [static]

This function returns the regulator to run a regulation status. It provides the current status of the internal
voltage regulator.

MCUXpresso SDK API Reference Manual


466 NXP Semiconductors
Function Documentation

Parameters

base PMC peripheral base address.


base Base address for current PMC instance.

Returns
Regulation status 0 - Regulator is in a stop regulation or in transition to/from the regulation. 1 -
Regulator is in a run regulation.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 467
Function Documentation

MCUXpresso SDK API Reference Manual


468 NXP Semiconductors
Chapter 20
PORT: Port Control and Interrupts
20.1 Overview
The MCUXpresso SDK provides a driver for the Port Control and Interrupts (PORT) module of MCU-
Xpresso SDK devices.

Data Structures
• struct port_pin_config_t
PORT pin configuration structure. More...

Enumerations
• enum _port_pull {
kPORT_PullDisable = 0U,
kPORT_PullDown = 2U,
kPORT_PullUp = 3U }
Internal resistor pull feature selection.
• enum _port_slew_rate {
kPORT_FastSlewRate = 0U,
kPORT_SlowSlewRate = 1U }
Slew rate selection.
• enum _port_passive_filter_enable {
kPORT_PassiveFilterDisable = 0U,
kPORT_PassiveFilterEnable = 1U }
Passive filter feature enable/disable.
• enum _port_drive_strength {
kPORT_LowDriveStrength = 0U,
kPORT_HighDriveStrength = 1U }
Configures the drive strength.
• enum port_mux_t {

MCUXpresso SDK API Reference Manual


NXP Semiconductors 469
Overview

kPORT_PinDisabledOrAnalog = 0U,
kPORT_MuxAsGpio = 1U,
kPORT_MuxAlt2 = 2U,
kPORT_MuxAlt3 = 3U,
kPORT_MuxAlt4 = 4U,
kPORT_MuxAlt5 = 5U,
kPORT_MuxAlt6 = 6U,
kPORT_MuxAlt7 = 7U,
kPORT_MuxAlt8 = 8U,
kPORT_MuxAlt9 = 9U,
kPORT_MuxAlt10 = 10U,
kPORT_MuxAlt11 = 11U,
kPORT_MuxAlt12 = 12U,
kPORT_MuxAlt13 = 13U,
kPORT_MuxAlt14 = 14U,
kPORT_MuxAlt15 = 15U }
Pin mux selection.
• enum port_interrupt_t {
kPORT_InterruptOrDMADisabled = 0x0U,
kPORT_DMARisingEdge = 0x1U,
kPORT_DMAFallingEdge = 0x2U,
kPORT_DMAEitherEdge = 0x3U,
kPORT_InterruptLogicZero = 0x8U,
kPORT_InterruptRisingEdge = 0x9U,
kPORT_InterruptFallingEdge = 0xAU,
kPORT_InterruptEitherEdge = 0xBU,
kPORT_InterruptLogicOne = 0xCU }
Configures the interrupt generation condition.

Driver version
• #define FSL_PORT_DRIVER_VERSION (MAKE_VERSION(2, 1, 0))
Version 2.1.0.

Configuration
• static void PORT_SetPinConfig (PORT_Type ∗base, uint32_t pin, const port_pin_config_t ∗config)
Sets the port PCR register.
• static void PORT_SetMultiplePinsConfig (PORT_Type ∗base, uint32_t mask, const port_pin_-
config_t ∗config)
Sets the port PCR register for multiple pins.
• static void PORT_SetPinMux (PORT_Type ∗base, uint32_t pin, port_mux_t mux)
Configures the pin muxing.

Interrupt
• static void PORT_SetPinInterruptConfig (PORT_Type ∗base, uint32_t pin, port_interrupt_t config)

MCUXpresso SDK API Reference Manual


470 NXP Semiconductors
Enumeration Type Documentation

Configures the port pin interrupt/DMA request.


• static void PORT_SetPinDriveStrength (PORT_Type ∗base, uint32_t pin, uint8_t strength)
Configures the port pin drive strength.
• static uint32_t PORT_GetPinsInterruptFlags (PORT_Type ∗base)
Reads the whole port status flag.
• static void PORT_ClearPinsInterruptFlags (PORT_Type ∗base, uint32_t mask)
Clears the multiple pin interrupt status flag.

20.2 Data Structure Documentation


20.2.1 struct port_pin_config_t

Data Fields

• uint16_t pullSelect: 2
No-pull/pull-down/pull-up select.
• uint16_t slewRate: 1
Fast/slow slew rate Configure.
• uint16_t passiveFilterEnable: 1
Passive filter enable/disable.
• uint16_t driveStrength: 1
Fast/slow drive strength configure.
• uint16_t mux: 3
Pin mux Configure.

20.3 Macro Definition Documentation


20.3.1 #define FSL_PORT_DRIVER_VERSION (MAKE_VERSION(2, 1, 0))

20.4 Enumeration Type Documentation


20.4.1 enum _port_pull

Enumerator
kPORT_PullDisable Internal pull-up/down resistor is disabled.
kPORT_PullDown Internal pull-down resistor is enabled.
kPORT_PullUp Internal pull-up resistor is enabled.

20.4.2 enum _port_slew_rate

Enumerator
kPORT_FastSlewRate Fast slew rate is configured.
kPORT_SlowSlewRate Slow slew rate is configured.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 471
Enumeration Type Documentation

20.4.3 enum _port_passive_filter_enable

Enumerator
kPORT_PassiveFilterDisable Passive input filter is disabled.
kPORT_PassiveFilterEnable Passive input filter is enabled.

20.4.4 enum _port_drive_strength

Enumerator
kPORT_LowDriveStrength Low-drive strength is configured.
kPORT_HighDriveStrength High-drive strength is configured.

20.4.5 enum port_mux_t

Enumerator
kPORT_PinDisabledOrAnalog Corresponding pin is disabled, but is used as an analog pin.
kPORT_MuxAsGpio Corresponding pin is configured as GPIO.
kPORT_MuxAlt2 Chip-specific.
kPORT_MuxAlt3 Chip-specific.
kPORT_MuxAlt4 Chip-specific.
kPORT_MuxAlt5 Chip-specific.
kPORT_MuxAlt6 Chip-specific.
kPORT_MuxAlt7 Chip-specific.
kPORT_MuxAlt8 Chip-specific.
kPORT_MuxAlt9 Chip-specific.
kPORT_MuxAlt10 Chip-specific.
kPORT_MuxAlt11 Chip-specific.
kPORT_MuxAlt12 Chip-specific.
kPORT_MuxAlt13 Chip-specific.
kPORT_MuxAlt14 Chip-specific.
kPORT_MuxAlt15 Chip-specific.

20.4.6 enum port_interrupt_t

Enumerator
kPORT_InterruptOrDMADisabled Interrupt/DMA request is disabled.
kPORT_DMARisingEdge DMA request on rising edge.
kPORT_DMAFallingEdge DMA request on falling edge.

MCUXpresso SDK API Reference Manual


472 NXP Semiconductors
Function Documentation

kPORT_DMAEitherEdge DMA request on either edge.


kPORT_InterruptLogicZero Interrupt when logic zero.
kPORT_InterruptRisingEdge Interrupt on rising edge.
kPORT_InterruptFallingEdge Interrupt on falling edge.
kPORT_InterruptEitherEdge Interrupt on either edge.
kPORT_InterruptLogicOne Interrupt when logic one.

20.5 Function Documentation


20.5.1 static void PORT_SetPinConfig ( PORT_Type ∗ base, uint32_t pin, const
port_pin_config_t ∗ config ) [inline], [static]

This is an example to define an input pin or output pin PCR configuration.

* // Define a digital input pin PCR configuration


* port_pin_config_t config = {
* kPORT_PullUp,
* kPORT_FastSlewRate,
* kPORT_PassiveFilterDisable,
* kPORT_OpenDrainDisable,
* kPORT_LowDriveStrength,
* kPORT_MuxAsGpio,
* kPORT_UnLockRegister,
* };
*

Parameters

base PORT peripheral base pointer.


pin PORT pin number.
config PORT PCR register configuration structure.

20.5.2 static void PORT_SetMultiplePinsConfig ( PORT_Type ∗ base, uint32_t


mask, const port_pin_config_t ∗ config ) [inline], [static]

This is an example to define input pins or output pins PCR configuration.

* // Define a digital input pin PCR configuration


* port_pin_config_t config = {
* kPORT_PullUp ,
* kPORT_PullEnable,
* kPORT_FastSlewRate,
* kPORT_PassiveFilterDisable,
* kPORT_OpenDrainDisable,
* kPORT_LowDriveStrength,
* kPORT_MuxAsGpio,
* kPORT_UnlockRegister,
* };
*

MCUXpresso SDK API Reference Manual


NXP Semiconductors 473
Function Documentation

Parameters

base PORT peripheral base pointer.


mask PORT pin number macro.
config PORT PCR register configuration structure.

20.5.3 static void PORT_SetPinMux ( PORT_Type ∗ base, uint32_t pin,


port_mux_t mux ) [inline], [static]

Parameters

base PORT peripheral base pointer.


pin PORT pin number.
mux pin muxing slot selection.
• kPORT_PinDisabledOrAnalog: Pin disabled or work in analog function.
• kPORT_MuxAsGpio : Set as GPIO.
• kPORT_MuxAlt2 : chip-specific.
• kPORT_MuxAlt3 : chip-specific.
• kPORT_MuxAlt4 : chip-specific.
• kPORT_MuxAlt5 : chip-specific.
• kPORT_MuxAlt6 : chip-specific.
• kPORT_MuxAlt7 : chip-specific. : This function is NOT recommended to
use together with the PORT_SetPinsConfig, because the PORT_SetPinsConfig
need to configure the pin mux anyway (Otherwise the pin mux is reset to zero :
kPORT_PinDisabledOrAnalog). This function is recommended to use to reset
the pin mux

20.5.4 static void PORT_SetPinInterruptConfig ( PORT_Type ∗ base, uint32_t pin,


port_interrupt_t config ) [inline], [static]

Parameters

base PORT peripheral base pointer.

MCUXpresso SDK API Reference Manual


474 NXP Semiconductors
Function Documentation

pin PORT pin number.


config PORT pin interrupt configuration.
• kPORT_InterruptOrDMADisabled: Interrupt/DMA request disabled.
• kPORT_DMARisingEdge : DMA request on rising edge(if the DMA requests
exit).
• kPORT_DMAFallingEdge: DMA request on falling edge(if the DMA requests
exit).
• kPORT_DMAEitherEdge : DMA request on either edge(if the DMA requests
exit).
• #kPORT_FlagRisingEdge : Flag sets on rising edge(if the Flag states exit).
• #kPORT_FlagFallingEdge : Flag sets on falling edge(if the Flag states exit).
• #kPORT_FlagEitherEdge : Flag sets on either edge(if the Flag states exit).
• kPORT_InterruptLogicZero : Interrupt when logic zero.
• kPORT_InterruptRisingEdge : Interrupt on rising edge.
• kPORT_InterruptFallingEdge: Interrupt on falling edge.
• kPORT_InterruptEitherEdge : Interrupt on either edge.
• kPORT_InterruptLogicOne : Interrupt when logic one.
• #kPORT_ActiveHighTriggerOutputEnable : Enable active high-trigger output
(if the trigger states exit).
• #kPORT_ActiveLowTriggerOutputEnable : Enable active low-trigger output
(if the trigger states exit).

20.5.5 static void PORT_SetPinDriveStrength ( PORT_Type ∗ base, uint32_t pin,


uint8_t strength ) [inline], [static]

Parameters

base PORT peripheral base pointer.


pin PORT pin number.
config PORT pin drive strength
• kPORT_LowDriveStrength = 0U - Low-drive strength is configured.
• kPORT_HighDriveStrength = 1U - High-drive strength is configured.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 475
Function Documentation

20.5.6 static uint32_t PORT_GetPinsInterruptFlags ( PORT_Type ∗ base )


[inline], [static]

If a pin is configured to generate the DMA request, the corresponding flag is cleared automatically at the
completion of the requested DMA transfer. Otherwise, the flag remains set until a logic one is written to
that flag. If configured for a level sensitive interrupt that remains asserted, the flag is set again immediately.
Parameters

base PORT peripheral base pointer.

Returns
Current port interrupt status flags, for example, 0x00010001 means the pin 0 and 16 have the inter-
rupt.

20.5.7 static void PORT_ClearPinsInterruptFlags ( PORT_Type ∗ base, uint32_t


mask ) [inline], [static]

Parameters

base PORT peripheral base pointer.


mask PORT pin number macro.

MCUXpresso SDK API Reference Manual


476 NXP Semiconductors
Chapter 21
RCM: Reset Control Module Driver
21.1 Overview
The MCUXpresso SDK provides a peripheral driver for the Reset Control Module (RCM) module of
MCUXpresso SDK devices.

Data Structures
• struct rcm_reset_pin_filter_config_t
Reset pin filter configuration. More...

Enumerations
• enum rcm_reset_source_t {
kRCM_SourceWakeup = RCM_SRS0_WAKEUP_MASK,
kRCM_SourceLvd = RCM_SRS0_LVD_MASK,
kRCM_SourceWdog = RCM_SRS0_WDOG_MASK,
kRCM_SourcePin = RCM_SRS0_PIN_MASK,
kRCM_SourcePor = RCM_SRS0_POR_MASK,
kRCM_SourceLockup = RCM_SRS1_LOCKUP_MASK << 8U,
kRCM_SourceSw = RCM_SRS1_SW_MASK << 8U,
kRCM_SourceMdmap = RCM_SRS1_MDM_AP_MASK << 8U,
kRCM_SourceSackerr = RCM_SRS1_SACKERR_MASK << 8U }
System Reset Source Name definitions.
• enum rcm_run_wait_filter_mode_t {
kRCM_FilterDisable = 0U,
kRCM_FilterBusClock = 1U,
kRCM_FilterLpoClock = 2U }
Reset pin filter select in Run and Wait modes.
• enum rcm_boot_rom_config_t {
kRCM_BootFlash = 0U,
kRCM_BootRomCfg0 = 1U,
kRCM_BootRomFopt = 2U,
kRCM_BootRomBoth = 3U }
Boot from ROM configuration.

Driver version
• #define FSL_RCM_DRIVER_VERSION (MAKE_VERSION(2, 0, 2))
RCM driver version 2.0.2.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 477
Enumeration Type Documentation

Reset Control Module APIs


• static uint32_t RCM_GetPreviousResetSources (RCM_Type ∗base)
Gets the reset source status which caused a previous reset.
• static uint32_t RCM_GetStickyResetSources (RCM_Type ∗base)
Gets the sticky reset source status.
• static void RCM_ClearStickyResetSources (RCM_Type ∗base, uint32_t sourceMasks)
Clears the sticky reset source status.
• void RCM_ConfigureResetPinFilter (RCM_Type ∗base, const rcm_reset_pin_filter_config_t
∗config)
Configures the reset pin filter.
• static rcm_boot_rom_config_t RCM_GetBootRomSource (RCM_Type ∗base)
Gets the ROM boot source.
• static void RCM_ClearBootRomSource (RCM_Type ∗base)
Clears the ROM boot source flag.
• void RCM_SetForceBootRomSource (RCM_Type ∗base, rcm_boot_rom_config_t config)
Forces the boot from ROM.

21.2 Data Structure Documentation


21.2.1 struct rcm_reset_pin_filter_config_t

Data Fields

• bool enableFilterInStop
Reset pin filter select in stop mode.
• rcm_run_wait_filter_mode_t filterInRunWait
Reset pin filter in run/wait mode.
• uint8_t busClockFilterCount
Reset pin bus clock filter width.

21.2.1.0.0.15 Field Documentation

21.2.1.0.0.15.1 bool rcm_reset_pin_filter_config_t::enableFilterInStop

21.2.1.0.0.15.2 rcm_run_wait_filter_mode_t rcm_reset_pin_filter_config_t::filterInRunWait

21.2.1.0.0.15.3 uint8_t rcm_reset_pin_filter_config_t::busClockFilterCount

21.3 Macro Definition Documentation


21.3.1 #define FSL_RCM_DRIVER_VERSION (MAKE_VERSION(2, 0, 2))

21.4 Enumeration Type Documentation


21.4.1 enum rcm_reset_source_t

Enumerator
kRCM_SourceWakeup Low-leakage wakeup reset.

MCUXpresso SDK API Reference Manual


478 NXP Semiconductors
Function Documentation

kRCM_SourceLvd Low-voltage detect reset.


kRCM_SourceWdog Watchdog reset.
kRCM_SourcePin External pin reset.
kRCM_SourcePor Power on reset.
kRCM_SourceLockup Core lock up reset.
kRCM_SourceSw Software reset.
kRCM_SourceMdmap MDM-AP system reset.
kRCM_SourceSackerr Parameter could get all reset flags.

21.4.2 enum rcm_run_wait_filter_mode_t

Enumerator
kRCM_FilterDisable All filtering disabled.
kRCM_FilterBusClock Bus clock filter enabled.
kRCM_FilterLpoClock LPO clock filter enabled.

21.4.3 enum rcm_boot_rom_config_t

Enumerator
kRCM_BootFlash Boot from flash.
kRCM_BootRomCfg0 Boot from boot ROM due to BOOTCFG0.
kRCM_BootRomFopt Boot from boot ROM due to FOPT[7].
kRCM_BootRomBoth Boot from boot ROM due to both BOOTCFG0 and FOPT[7].

21.5 Function Documentation


21.5.1 static uint32_t RCM_GetPreviousResetSources ( RCM_Type ∗ base )
[inline], [static]

This function gets the current reset source status. Use source masks defined in the rcm_reset_source_t to
get the desired source status.
This is an example.
* uint32_t resetStatus;
*
* To get all reset source statuses.
* resetStatus = RCM_GetPreviousResetSources(RCM) & kRCM_SourceAll;
*
* To test whether the MCU is reset using Watchdog.
* resetStatus = RCM_GetPreviousResetSources(RCM) &
kRCM_SourceWdog;
*
* To test multiple reset sources.
* resetStatus = RCM_GetPreviousResetSources(RCM) & (
kRCM_SourceWdog | kRCM_SourcePin);
*

MCUXpresso SDK API Reference Manual


NXP Semiconductors 479
Function Documentation

Parameters

base RCM peripheral base address.

Returns
All reset source status bit map.

21.5.2 static uint32_t RCM_GetStickyResetSources ( RCM_Type ∗ base )


[inline], [static]

This function gets the current reset source status that has not been cleared by software for a specific source.
This is an example.

* uint32_t resetStatus;
*
* To get all reset source statuses.
* resetStatus = RCM_GetStickyResetSources(RCM) & kRCM_SourceAll;
*
* To test whether the MCU is reset using Watchdog.
* resetStatus = RCM_GetStickyResetSources(RCM) &
kRCM_SourceWdog;
*
* To test multiple reset sources.
* resetStatus = RCM_GetStickyResetSources(RCM) & (
kRCM_SourceWdog | kRCM_SourcePin);
*

Parameters

base RCM peripheral base address.

Returns
All reset source status bit map.

21.5.3 static void RCM_ClearStickyResetSources ( RCM_Type ∗ base, uint32_t


sourceMasks ) [inline], [static]

This function clears the sticky system reset flags indicated by source masks.
This is an example.

* Clears multiple reset sources.


* RCM_ClearStickyResetSources(kRCM_SourceWdog |
kRCM_SourcePin);
*

MCUXpresso SDK API Reference Manual


480 NXP Semiconductors
Function Documentation

Parameters

base RCM peripheral base address.


sourceMasks reset source status bit map

21.5.4 void RCM_ConfigureResetPinFilter ( RCM_Type ∗ base, const


rcm_reset_pin_filter_config_t ∗ config )

This function sets the reset pin filter including the filter source, filter width, and so on.
Parameters

base RCM peripheral base address.


config Pointer to the configuration structure.

21.5.5 static rcm_boot_rom_config_t RCM_GetBootRomSource ( RCM_Type ∗


base ) [inline], [static]

This function gets the ROM boot source during the last chip reset.
Parameters

base RCM peripheral base address.

Returns
The ROM boot source.

21.5.6 static void RCM_ClearBootRomSource ( RCM_Type ∗ base ) [inline],


[static]

This function clears the ROM boot source flag.


Parameters

MCUXpresso SDK API Reference Manual


NXP Semiconductors 481
Function Documentation

base Register base address of RCM

21.5.7 void RCM_SetForceBootRomSource ( RCM_Type ∗ base,


rcm_boot_rom_config_t config )

This function forces booting from ROM during all subsequent system resets.
Parameters

base RCM peripheral base address.


config Boot configuration.

MCUXpresso SDK API Reference Manual


482 NXP Semiconductors
Chapter 22
RTC: Real Time Clock
22.1 Overview
The MCUXpresso SDK provides a driver for the Real Time Clock (RTC) of MCUXpresso SDK devices.

22.2 Function groups


The RTC driver supports operating the module as a time counter.

22.2.1 Initialization and deinitialization

The function RTC_Init() initializes the RTC with specified configurations. The function RTC_GetDefault-
Config() gets the default configurations.
The function RTC_Deinit() disables the RTC timer and disables the module clock.

22.2.2 Set & Get Datetime

The function RTC_SetDatetime() sets the timer period in seconds. Users pass in the details in date & time
format by using the below data structure.
Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/rtc
The function RTC_GetDatetime() reads the current timer value in seconds, converts it to date & time
format and stores it into a datetime structure passed in by the user.

22.2.3 Set & Get Alarm

The function RTC_SetAlarm() sets the alarm time period in seconds. Users pass in the details in date &
time format by using the datetime data structure.
The function RTC_GetAlarm() reads the alarm time in seconds, converts it to date & time format and
stores it into a datetime structure passed in by the user.

22.2.4 Start & Stop timer

The function RTC_StartTimer() starts the RTC time counter.


The function RTC_StopTimer() stops the RTC time counter.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 483
Typical use case

22.2.5 Status

Provides functions to get and clear the RTC status.

22.2.6 Interrupt

Provides functions to enable/disable RTC interrupts and get current enabled interrupts.

22.2.7 RTC Oscillator

Some SoC’s allow control of the RTC oscillator through the RTC module.
The function RTC_SetOscCapLoad() allows the user to modify the capacitor load configuration of the
RTC oscillator.

22.2.8 Monotonic Counter

Some SoC’s have a 64-bit Monotonic counter available in the RTC module.
The function RTC_SetMonotonicCounter() writes a 64-bit to the counter.
The function RTC_GetMonotonicCounter() reads the monotonic counter and returns the 64-bit counter
value to the user.
The function RTC_IncrementMonotonicCounter() increments the Monotonic Counter by one.

22.3 Typical use case


22.3.1 RTC tick example

Example to set the RTC current time and trigger an alarm. Refer to the driver examples codes located at
<SDK_ROOT>/boards/<BOARD>/driver_examples/rtc

Data Structures
• struct rtc_datetime_t
Structure is used to hold the date and time. More...
• struct rtc_config_t
RTC config structure. More...

Enumerations
• enum rtc_interrupt_enable_t {
kRTC_TimeInvalidInterruptEnable = (1U << 0U),
kRTC_TimeOverflowInterruptEnable = (1U << 1U),
kRTC_AlarmInterruptEnable = (1U << 2U),

MCUXpresso SDK API Reference Manual


484 NXP Semiconductors
Typical use case

kRTC_SecondsInterruptEnable = (1U << 3U) }


List of RTC interrupts.
• enum rtc_status_flags_t {
kRTC_TimeInvalidFlag = (1U << 0U),
kRTC_TimeOverflowFlag = (1U << 1U),
kRTC_AlarmFlag = (1U << 2U) }
List of RTC flags.
• enum rtc_osc_cap_load_t {
kRTC_Capacitor_2p = RTC_CR_SC2P_MASK,
kRTC_Capacitor_4p = RTC_CR_SC4P_MASK,
kRTC_Capacitor_8p = RTC_CR_SC8P_MASK,
kRTC_Capacitor_16p = RTC_CR_SC16P_MASK }
List of RTC Oscillator capacitor load settings.

Functions
• static void RTC_SetClockSource (RTC_Type ∗base)
Set RTC clock source.
• static void RTC_SetOscCapLoad (RTC_Type ∗base, uint32_t capLoad)
This function sets the specified capacitor configuration for the RTC oscillator.
• static void RTC_Reset (RTC_Type ∗base)
Performs a software reset on the RTC module.
• static void RTC_EnableWakeUpPin (RTC_Type ∗base, bool enable)
Enables or disables the RTC Wakeup Pin Operation.

Driver version
• #define FSL_RTC_DRIVER_VERSION (MAKE_VERSION(2, 2, 0))
Version 2.2.0.

Initialization and deinitialization


• void RTC_Init (RTC_Type ∗base, const rtc_config_t ∗config)
Ungates the RTC clock and configures the peripheral for basic operation.
• static void RTC_Deinit (RTC_Type ∗base)
Stops the timer and gate the RTC clock.
• void RTC_GetDefaultConfig (rtc_config_t ∗config)
Fills in the RTC config struct with the default settings.

Current Time & Alarm


• status_t RTC_SetDatetime (RTC_Type ∗base, const rtc_datetime_t ∗datetime)
Sets the RTC date and time according to the given time structure.
• void RTC_GetDatetime (RTC_Type ∗base, rtc_datetime_t ∗datetime)
Gets the RTC time and stores it in the given time structure.
• status_t RTC_SetAlarm (RTC_Type ∗base, const rtc_datetime_t ∗alarmTime)
Sets the RTC alarm time.
• void RTC_GetAlarm (RTC_Type ∗base, rtc_datetime_t ∗datetime)
Returns the RTC alarm time.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 485
Data Structure Documentation

Interrupt Interface
• void RTC_EnableInterrupts (RTC_Type ∗base, uint32_t mask)
Enables the selected RTC interrupts.
• void RTC_DisableInterrupts (RTC_Type ∗base, uint32_t mask)
Disables the selected RTC interrupts.
• uint32_t RTC_GetEnabledInterrupts (RTC_Type ∗base)
Gets the enabled RTC interrupts.

Status Interface
• uint32_t RTC_GetStatusFlags (RTC_Type ∗base)
Gets the RTC status flags.
• void RTC_ClearStatusFlags (RTC_Type ∗base, uint32_t mask)
Clears the RTC status flags.

Timer Start and Stop


• static void RTC_StartTimer (RTC_Type ∗base)
Starts the RTC time counter.
• static void RTC_StopTimer (RTC_Type ∗base)
Stops the RTC time counter.

22.4 Data Structure Documentation


22.4.1 struct rtc_datetime_t

Data Fields

• uint16_t year
Range from 1970 to 2099.
• uint8_t month
Range from 1 to 12.
• uint8_t day
Range from 1 to 31 (depending on month).
• uint8_t hour
Range from 0 to 23.
• uint8_t minute
Range from 0 to 59.
• uint8_t second
Range from 0 to 59.

MCUXpresso SDK API Reference Manual


486 NXP Semiconductors
Enumeration Type Documentation

22.4.1.0.0.16 Field Documentation

22.4.1.0.0.16.1 uint16_t rtc_datetime_t::year

22.4.1.0.0.16.2 uint8_t rtc_datetime_t::month

22.4.1.0.0.16.3 uint8_t rtc_datetime_t::day

22.4.1.0.0.16.4 uint8_t rtc_datetime_t::hour

22.4.1.0.0.16.5 uint8_t rtc_datetime_t::minute

22.4.1.0.0.16.6 uint8_t rtc_datetime_t::second

22.4.2 struct rtc_config_t

This structure holds the configuration settings for the RTC peripheral. To initialize this structure to rea-
sonable defaults, call the RTC_GetDefaultConfig() function and pass a pointer to your config structure
instance.
The config struct can be made const so it resides in flash

Data Fields

• bool wakeupSelect
true: Wakeup pin outputs the 32 KHz clock; false:Wakeup pin used to wakeup the chip
• bool updateMode
true: Registers can be written even when locked under certain conditions, false: No writes allowed when
registers are locked
• bool supervisorAccess
true: Non-supervisor accesses are allowed; false: Non-supervisor accesses are not supported
• uint32_t compensationInterval
Compensation interval that is written to the CIR field in RTC TCR Register.
• uint32_t compensationTime
Compensation time that is written to the TCR field in RTC TCR Register.

22.5 Enumeration Type Documentation


22.5.1 enum rtc_interrupt_enable_t

Enumerator
kRTC_TimeInvalidInterruptEnable Time invalid interrupt.
kRTC_TimeOverflowInterruptEnable Time overflow interrupt.
kRTC_AlarmInterruptEnable Alarm interrupt.
kRTC_SecondsInterruptEnable Seconds interrupt.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 487
Function Documentation

22.5.2 enum rtc_status_flags_t

Enumerator
kRTC_TimeInvalidFlag Time invalid flag.
kRTC_TimeOverflowFlag Time overflow flag.
kRTC_AlarmFlag Alarm flag.

22.5.3 enum rtc_osc_cap_load_t

Enumerator
kRTC_Capacitor_2p 2 pF capacitor load
kRTC_Capacitor_4p 4 pF capacitor load
kRTC_Capacitor_8p 8 pF capacitor load
kRTC_Capacitor_16p 16 pF capacitor load

22.6 Function Documentation


22.6.1 void RTC_Init ( RTC_Type ∗ base, const rtc_config_t ∗ config )

This function issues a software reset if the timer invalid flag is set.

Note
This API should be called at the beginning of the application using the RTC driver.

Parameters

base RTC peripheral base address


config Pointer to the user’s RTC configuration structure.

22.6.2 static void RTC_Deinit ( RTC_Type ∗ base ) [inline], [static]

Parameters

MCUXpresso SDK API Reference Manual


488 NXP Semiconductors
Function Documentation

base RTC peripheral base address

22.6.3 void RTC_GetDefaultConfig ( rtc_config_t ∗ config )

The default values are as follows.

* config->wakeupSelect = false;
* config->updateMode = false;
* config->supervisorAccess = false;
* config->compensationInterval = 0;
* config->compensationTime = 0;
*

Parameters

config Pointer to the user’s RTC configuration structure.

22.6.4 status_t RTC_SetDatetime ( RTC_Type ∗ base, const rtc_datetime_t ∗


datetime )

The RTC counter must be stopped prior to calling this function because writes to the RTC seconds register
fail if the RTC counter is running.
Parameters

base RTC peripheral base address


datetime Pointer to the structure where the date and time details are stored.

Returns
kStatus_Success: Success in setting the time and starting the RTC kStatus_InvalidArgument: Error
because the datetime format is incorrect

22.6.5 void RTC_GetDatetime ( RTC_Type ∗ base, rtc_datetime_t ∗ datetime )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 489
Function Documentation

Parameters

base RTC peripheral base address


datetime Pointer to the structure where the date and time details are stored.

22.6.6 status_t RTC_SetAlarm ( RTC_Type ∗ base, const rtc_datetime_t ∗


alarmTime )

The function checks whether the specified alarm time is greater than the present time. If not, the function
does not set the alarm and returns an error.
Parameters

base RTC peripheral base address


alarmTime Pointer to the structure where the alarm time is stored.

Returns
kStatus_Success: success in setting the RTC alarm kStatus_InvalidArgument: Error because the
alarm datetime format is incorrect kStatus_Fail: Error because the alarm time has already passed

22.6.7 void RTC_GetAlarm ( RTC_Type ∗ base, rtc_datetime_t ∗ datetime )

Parameters

base RTC peripheral base address


datetime Pointer to the structure where the alarm date and time details are stored.

22.6.8 void RTC_EnableInterrupts ( RTC_Type ∗ base, uint32_t mask )

Parameters

base RTC peripheral base address

MCUXpresso SDK API Reference Manual


490 NXP Semiconductors
Function Documentation

mask The interrupts to enable. This is a logical OR of members of the enumeration rtc_-
interrupt_enable_t

22.6.9 void RTC_DisableInterrupts ( RTC_Type ∗ base, uint32_t mask )

Parameters

base RTC peripheral base address


mask The interrupts to enable. This is a logical OR of members of the enumeration rtc_-
interrupt_enable_t

22.6.10 uint32_t RTC_GetEnabledInterrupts ( RTC_Type ∗ base )

Parameters

base RTC peripheral base address

Returns
The enabled interrupts. This is the logical OR of members of the enumeration rtc_interrupt_enable_t

22.6.11 uint32_t RTC_GetStatusFlags ( RTC_Type ∗ base )

Parameters

base RTC peripheral base address

Returns
The status flags. This is the logical OR of members of the enumeration rtc_status_flags_t

22.6.12 void RTC_ClearStatusFlags ( RTC_Type ∗ base, uint32_t mask )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 491
Function Documentation

Parameters

base RTC peripheral base address


mask The status flags to clear. This is a logical OR of members of the enumeration rtc_-
status_flags_t

22.6.13 static void RTC_SetClockSource ( RTC_Type ∗ base ) [inline],


[static]

Parameters

base RTC peripheral base address

Note
After setting this bit, wait the oscillator startup time before enabling the time counter to allow the
32.768 kHz clock time to stabilize.

22.6.14 static void RTC_StartTimer ( RTC_Type ∗ base ) [inline], [static]

After calling this function, the timer counter increments once a second provided SR[TOF] or SR[TIF] are
not set.
Parameters

base RTC peripheral base address

22.6.15 static void RTC_StopTimer ( RTC_Type ∗ base ) [inline], [static]

RTC’s seconds register can be written to only when the timer is stopped.
Parameters

base RTC peripheral base address

22.6.16 static void RTC_SetOscCapLoad ( RTC_Type ∗ base, uint32_t capLoad )


[inline], [static]

MCUXpresso SDK API Reference Manual


492 NXP Semiconductors
Function Documentation

Parameters

base RTC peripheral base address


capLoad Oscillator loads to enable. This is a logical OR of members of the enumeration rtc_-
osc_cap_load_t

22.6.17 static void RTC_Reset ( RTC_Type ∗ base ) [inline], [static]

This resets all RTC registers except for the SWR bit and the RTC_WAR and RTC_RAR registers. The
SWR bit is cleared by software explicitly clearing it.
Parameters

base RTC peripheral base address

22.6.18 static void RTC_EnableWakeUpPin ( RTC_Type ∗ base, bool enable )


[inline], [static]

This function enable or disable RTC Wakeup Pin. The wakeup pin is optional and not available on all
devices.
Parameters

base RTC_Type base pointer.


enable true to enable, false to disable.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 493
Function Documentation

MCUXpresso SDK API Reference Manual


494 NXP Semiconductors
Chapter 23
SAI: Serial Audio Interface
23.1 Overview
The MCUXpresso SDK provides a peripheral driver for the Serial Audio Interface (SAI) module of MC-
UXpresso SDK devices.
SAI driver includes functional APIs and transactional APIs.
Functional APIs target low-level APIs. Functional APIs can be used for SAI initialization, configuration
and operation, and for optimization and customization purposes. Using the functional API requires the
knowledge of the SAI peripheral and how to organize functional APIs to meet the application require-
ments. All functional API use the peripheral base address as the first parameter. SAI functional operation
groups provide the functional API set.
Transactional APIs target high-level APIs. Transactional APIs can be used to enable the peripheral and
in the application if the code size and performance of transactional APIs satisfy the requirements. If the
code size and performance are a critical requirement, see the transactional API implementation and write
a custom code. All transactional APIs use the sai_handle_t as the first parameter. Initialize the handle by
calling the SAI_TransferTxCreateHandle() or SAI_TransferRxCreateHandle() API.
Transactional APIs support asynchronous transfer. This means that the functions SAI_TransferSendNon-
Blocking() and SAI_TransferReceiveNonBlocking() set up the interrupt for data transfer. When the trans-
fer completes, the upper layer is notified through a callback function with the kStatus_SAI_TxIdle and
kStatus_SAI_RxIdle status.

23.2 Typical use case


23.2.1 SAI Send/receive using an interrupt method

Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/sai

23.2.2 SAI Send/receive using a DMA method

Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/sai

Modules
• SAI DMA Driver
• SAI Driver
• SAI EDMA Driver
• SAI SDMA Driver

MCUXpresso SDK API Reference Manual


NXP Semiconductors 495
SAI Driver

23.3 SAI Driver


23.3.1 Overview

Data Structures

• struct sai_config_t
SAI user configuration structure. More...
• struct sai_transfer_format_t
sai transfer format More...
• struct sai_master_clock_t
master clock configurations More...
• struct sai_fifo_t
sai fifo configurations More...
• struct sai_bit_clock_t
sai bit clock configurations More...
• struct sai_frame_sync_t
sai frame sync configurations More...
• struct sai_serial_data_t
sai serial data configurations More...
• struct sai_transceiver_t
sai transceiver configurations More...
• struct sai_transfer_t
SAI transfer structure. More...
• struct sai_handle_t
SAI handle structure. More...

Macros

• #define SAI_XFER_QUEUE_SIZE (4)


SAI transfer queue size, user can refine it according to use case.

Typedefs

• typedef void(∗ sai_transfer_callback_t )(I2S_Type ∗base, sai_handle_t ∗handle, status_t status, void
∗userData)
SAI transfer callback prototype.

MCUXpresso SDK API Reference Manual


496 NXP Semiconductors
SAI Driver

Enumerations

• enum _sai_status_t {
kStatus_SAI_TxBusy = MAKE_STATUS(kStatusGroup_SAI, 0),
kStatus_SAI_RxBusy = MAKE_STATUS(kStatusGroup_SAI, 1),
kStatus_SAI_TxError = MAKE_STATUS(kStatusGroup_SAI, 2),
kStatus_SAI_RxError = MAKE_STATUS(kStatusGroup_SAI, 3),
kStatus_SAI_QueueFull = MAKE_STATUS(kStatusGroup_SAI, 4),
kStatus_SAI_TxIdle = MAKE_STATUS(kStatusGroup_SAI, 5),
kStatus_SAI_RxIdle = MAKE_STATUS(kStatusGroup_SAI, 6) }
SAI return status.
• enum _sai_channel_mask {
kSAI_Channel0Mask = 1 << 0U,
kSAI_Channel1Mask = 1 << 1U,
kSAI_Channel2Mask = 1 << 2U,
kSAI_Channel3Mask = 1 << 3U,
kSAI_Channel4Mask = 1 << 4U,
kSAI_Channel5Mask = 1 << 5U,
kSAI_Channel6Mask = 1 << 6U,
kSAI_Channel7Mask = 1 << 7U }
• enum sai_protocol_t {
kSAI_BusLeftJustified = 0x0U,
kSAI_BusRightJustified,
kSAI_BusI2S,
kSAI_BusPCMA,
kSAI_BusPCMB }
Define the SAI bus type.
• enum sai_master_slave_t {
kSAI_Master = 0x0U,
kSAI_Slave = 0x1U,
kSAI_Bclk_Master_FrameSync_Slave = 0x2U,
kSAI_Bclk_Slave_FrameSync_Master = 0x3U }
Master or slave mode.
• enum sai_mono_stereo_t {
kSAI_Stereo = 0x0U,
kSAI_MonoRight,
kSAI_MonoLeft }
Mono or stereo audio format.
• enum sai_data_order_t {
kSAI_DataLSB = 0x0U,
kSAI_DataMSB }
SAI data order, MSB or LSB.
• enum sai_clock_polarity_t {
kSAI_PolarityActiveHigh = 0x0U,
kSAI_PolarityActiveLow,
kSAI_SampleOnFallingEdge = 0x0U,

MCUXpresso SDK API Reference Manual


NXP Semiconductors 497
SAI Driver

kSAI_SampleOnRisingEdge }
SAI clock polarity, active high or low.
• enum sai_sync_mode_t {
kSAI_ModeAsync = 0x0U,
kSAI_ModeSync }
Synchronous or asynchronous mode.
• enum sai_mclk_source_t {
kSAI_MclkSourceSysclk = 0x0U,
kSAI_MclkSourceSelect1,
kSAI_MclkSourceSelect2,
kSAI_MclkSourceSelect3 }
Mater clock source.
• enum sai_bclk_source_t {
kSAI_BclkSourceBusclk = 0x0U,
kSAI_BclkSourceMclkOption1 = 0x1U,
kSAI_BclkSourceMclkOption2 = 0x2U,
kSAI_BclkSourceMclkOption3 = 0x3U,
kSAI_BclkSourceMclkDiv = 0x1U,
kSAI_BclkSourceOtherSai0 = 0x2U,
kSAI_BclkSourceOtherSai1 = 0x3U }
Bit clock source.
• enum _sai_interrupt_enable_t {
kSAI_WordStartInterruptEnable,
kSAI_SyncErrorInterruptEnable = I2S_TCSR_SEIE_MASK,
kSAI_FIFOWarningInterruptEnable = I2S_TCSR_FWIE_MASK,
kSAI_FIFOErrorInterruptEnable = I2S_TCSR_FEIE_MASK }
The SAI interrupt enable flag.
• enum _sai_dma_enable_t { kSAI_FIFOWarningDMAEnable = I2S_TCSR_FWDE_MASK }
The DMA request sources.
• enum _sai_flags {
kSAI_WordStartFlag = I2S_TCSR_WSF_MASK,
kSAI_SyncErrorFlag = I2S_TCSR_SEF_MASK,
kSAI_FIFOErrorFlag = I2S_TCSR_FEF_MASK,
kSAI_FIFOWarningFlag = I2S_TCSR_FWF_MASK }
The SAI status flag.
• enum sai_reset_type_t {
kSAI_ResetTypeSoftware = I2S_TCSR_SR_MASK,
kSAI_ResetTypeFIFO = I2S_TCSR_FR_MASK,
kSAI_ResetAll = I2S_TCSR_SR_MASK | I2S_TCSR_FR_MASK }
The reset type.
• enum sai_fifo_packing_t {
kSAI_FifoPackingDisabled = 0x0U,
kSAI_FifoPacking8bit = 0x2U,
kSAI_FifoPacking16bit = 0x3U }
The SAI packing mode The mode includes 8 bit and 16 bit packing.
• enum sai_sample_rate_t {

MCUXpresso SDK API Reference Manual


498 NXP Semiconductors
SAI Driver

kSAI_SampleRate8KHz = 8000U,
kSAI_SampleRate11025Hz = 11025U,
kSAI_SampleRate12KHz = 12000U,
kSAI_SampleRate16KHz = 16000U,
kSAI_SampleRate22050Hz = 22050U,
kSAI_SampleRate24KHz = 24000U,
kSAI_SampleRate32KHz = 32000U,
kSAI_SampleRate44100Hz = 44100U,
kSAI_SampleRate48KHz = 48000U,
kSAI_SampleRate96KHz = 96000U,
kSAI_SampleRate192KHz = 192000U,
kSAI_SampleRate384KHz = 384000U }
Audio sample rate.
• enum sai_word_width_t {
kSAI_WordWidth8bits = 8U,
kSAI_WordWidth16bits = 16U,
kSAI_WordWidth24bits = 24U,
kSAI_WordWidth32bits = 32U }
Audio word width.
• enum sai_transceiver_type_t {
kSAI_Transmitter = 0U,
kSAI_Receiver = 1U }
sai transceiver type
• enum sai_frame_sync_len_t {
kSAI_FrameSyncLenOneBitClk = 0U,
kSAI_FrameSyncLenPerWordWidth = 1U }
sai frame sync len

Driver version

• #define FSL_SAI_DRIVER_VERSION (MAKE_VERSION(2, 2, 1))


Version 2.2.1.

Initialization and deinitialization

• void SAI_TxInit (I2S_Type ∗base, const sai_config_t ∗config)


Initializes the SAI Tx peripheral.
• void SAI_RxInit (I2S_Type ∗base, const sai_config_t ∗config)
Initializes the SAI Rx peripheral.
• void SAI_TxGetDefaultConfig (sai_config_t ∗config)
Sets the SAI Tx configuration structure to default values.
• void SAI_RxGetDefaultConfig (sai_config_t ∗config)
Sets the SAI Rx configuration structure to default values.
• void SAI_Init (I2S_Type ∗base)
Initializes the SAI peripheral.
• void SAI_Deinit (I2S_Type ∗base)

MCUXpresso SDK API Reference Manual


NXP Semiconductors 499
SAI Driver

De-initializes the SAI peripheral.


• void SAI_TxReset (I2S_Type ∗base)
Resets the SAI Tx.
• void SAI_RxReset (I2S_Type ∗base)
Resets the SAI Rx.
• void SAI_TxEnable (I2S_Type ∗base, bool enable)
Enables/disables the SAI Tx.
• void SAI_RxEnable (I2S_Type ∗base, bool enable)
Enables/disables the SAI Rx.
• static void SAI_TxSetBitClockDirection (I2S_Type ∗base, sai_master_slave_t masterSlave)
Set Rx bit clock direction.
• static void SAI_RxSetBitClockDirection (I2S_Type ∗base, sai_master_slave_t masterSlave)
Set Rx bit clock direction.
• static void SAI_RxSetFrameSyncDirection (I2S_Type ∗base, sai_master_slave_t masterSlave)
Set Rx frame sync direction.
• static void SAI_TxSetFrameSyncDirection (I2S_Type ∗base, sai_master_slave_t masterSlave)
Set Tx frame sync direction.
• void SAI_TxSetBitClockRate (I2S_Type ∗base, uint32_t sourceClockHz, uint32_t sampleRate,
uint32_t bitWidth, uint32_t channelNumbers)
Transmitter bit clock rate configurations.
• void SAI_RxSetBitClockRate (I2S_Type ∗base, uint32_t sourceClockHz, uint32_t sampleRate,
uint32_t bitWidth, uint32_t channelNumbers)
Receiver bit clock rate configurations.
• void SAI_TxSetBitclockConfig (I2S_Type ∗base, sai_master_slave_t masterSlave, sai_bit_clock_t
∗config)
Transmitter Bit clock configurations.
• void SAI_RxSetBitclockConfig (I2S_Type ∗base, sai_master_slave_t masterSlave, sai_bit_clock_t
∗config)
Receiver Bit clock configurations.
• void SAI_SetMasterClockConfig (I2S_Type ∗base, sai_master_clock_t ∗config)
Master clock configurations.
• void SAI_TxSetFifoConfig (I2S_Type ∗base, sai_fifo_t ∗config)
SAI transmitter fifo configurations.
• void SAI_RxSetFifoConfig (I2S_Type ∗base, sai_fifo_t ∗config)
SAI receiver fifo configurations.
• void SAI_TxSetFrameSyncConfig (I2S_Type ∗base, sai_master_slave_t masterSlave, sai_frame_-
sync_t ∗config)
SAI transmitter Frame sync configurations.
• void SAI_RxSetFrameSyncConfig (I2S_Type ∗base, sai_master_slave_t masterSlave, sai_frame_-
sync_t ∗config)
SAI receiver Frame sync configurations.
• void SAI_TxSetSerialDataConfig (I2S_Type ∗base, sai_serial_data_t ∗config)
SAI transmitter Serial data configurations.
• void SAI_RxSetSerialDataConfig (I2S_Type ∗base, sai_serial_data_t ∗config)
SAI receiver Serial data configurations.
• void SAI_TxSetConfig (I2S_Type ∗base, sai_transceiver_t ∗config)
SAI transmitter configurations.
• void SAI_RxSetConfig (I2S_Type ∗base, sai_transceiver_t ∗config)
SAI receiver configurations.
• void SAI_GetClassicI2SConfig (sai_transceiver_t ∗config, sai_word_width_t bitWidth, sai_mono_-

MCUXpresso SDK API Reference Manual


500 NXP Semiconductors
SAI Driver

stereo_t mode, uint32_t saiChannelMask)


Get classic I2S mode configurations.
• void SAI_GetLeftJustifiedConfig (sai_transceiver_t ∗config, sai_word_width_t bitWidth, sai_-
mono_stereo_t mode, uint32_t saiChannelMask)
Get left justified mode configurations.
• void SAI_GetRightJustifiedConfig (sai_transceiver_t ∗config, sai_word_width_t bitWidth, sai_-
mono_stereo_t mode, uint32_t saiChannelMask)
Get right justified mode configurations.
• void SAI_GetTDMConfig (sai_transceiver_t ∗config, sai_frame_sync_len_t frameSyncWidth, sai_-
word_width_t bitWidth, uint32_t dataWordNum, uint32_t saiChannelMask)
Get TDM mode configurations.
• void SAI_GetDSPConfig (sai_transceiver_t ∗config, sai_frame_sync_len_t frameSyncWidth, sai_-
word_width_t bitWidth, sai_mono_stereo_t mode, uint32_t saiChannelMask)
Get DSP mode configurations.

Status

• static uint32_t SAI_TxGetStatusFlag (I2S_Type ∗base)


Gets the SAI Tx status flag state.
• static void SAI_TxClearStatusFlags (I2S_Type ∗base, uint32_t mask)
Clears the SAI Tx status flag state.
• static uint32_t SAI_RxGetStatusFlag (I2S_Type ∗base)
Gets the SAI Tx status flag state.
• static void SAI_RxClearStatusFlags (I2S_Type ∗base, uint32_t mask)
Clears the SAI Rx status flag state.
• void SAI_TxSoftwareReset (I2S_Type ∗base, sai_reset_type_t type)
Do software reset or FIFO reset .
• void SAI_RxSoftwareReset (I2S_Type ∗base, sai_reset_type_t type)
Do software reset or FIFO reset .
• void SAI_TxSetChannelFIFOMask (I2S_Type ∗base, uint8_t mask)
Set the Tx channel FIFO enable mask.
• void SAI_RxSetChannelFIFOMask (I2S_Type ∗base, uint8_t mask)
Set the Rx channel FIFO enable mask.
• void SAI_TxSetDataOrder (I2S_Type ∗base, sai_data_order_t order)
Set the Tx data order.
• void SAI_RxSetDataOrder (I2S_Type ∗base, sai_data_order_t order)
Set the Rx data order.
• void SAI_TxSetBitClockPolarity (I2S_Type ∗base, sai_clock_polarity_t polarity)
Set the Tx data order.
• void SAI_RxSetBitClockPolarity (I2S_Type ∗base, sai_clock_polarity_t polarity)
Set the Rx data order.
• void SAI_TxSetFrameSyncPolarity (I2S_Type ∗base, sai_clock_polarity_t polarity)
Set the Tx data order.
• void SAI_RxSetFrameSyncPolarity (I2S_Type ∗base, sai_clock_polarity_t polarity)
Set the Rx data order.
• void SAI_TxSetFIFOPacking (I2S_Type ∗base, sai_fifo_packing_t pack)
Set Tx FIFO packing feature.
• void SAI_RxSetFIFOPacking (I2S_Type ∗base, sai_fifo_packing_t pack)
Set Rx FIFO packing feature.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 501
SAI Driver

• static void SAI_TxSetFIFOErrorContinue (I2S_Type ∗base, bool isEnabled)


Set Tx FIFO error continue.
• static void SAI_RxSetFIFOErrorContinue (I2S_Type ∗base, bool isEnabled)
Set Rx FIFO error continue.

Interrupts

• static void SAI_TxEnableInterrupts (I2S_Type ∗base, uint32_t mask)


Enables the SAI Tx interrupt requests.
• static void SAI_RxEnableInterrupts (I2S_Type ∗base, uint32_t mask)
Enables the SAI Rx interrupt requests.
• static void SAI_TxDisableInterrupts (I2S_Type ∗base, uint32_t mask)
Disables the SAI Tx interrupt requests.
• static void SAI_RxDisableInterrupts (I2S_Type ∗base, uint32_t mask)
Disables the SAI Rx interrupt requests.

DMA Control

• static void SAI_TxEnableDMA (I2S_Type ∗base, uint32_t mask, bool enable)


Enables/disables the SAI Tx DMA requests.
• static void SAI_RxEnableDMA (I2S_Type ∗base, uint32_t mask, bool enable)
Enables/disables the SAI Rx DMA requests.
• static uint32_t SAI_TxGetDataRegisterAddress (I2S_Type ∗base, uint32_t channel)
Gets the SAI Tx data register address.
• static uint32_t SAI_RxGetDataRegisterAddress (I2S_Type ∗base, uint32_t channel)
Gets the SAI Rx data register address.

Bus Operations

• void SAI_TxSetFormat (I2S_Type ∗base, sai_transfer_format_t ∗format, uint32_t mclkSource-


ClockHz, uint32_t bclkSourceClockHz)
Configures the SAI Tx audio format.
• void SAI_RxSetFormat (I2S_Type ∗base, sai_transfer_format_t ∗format, uint32_t mclkSource-
ClockHz, uint32_t bclkSourceClockHz)
Configures the SAI Rx audio format.
• void SAI_WriteBlocking (I2S_Type ∗base, uint32_t channel, uint32_t bitWidth, uint8_t ∗buffer,
uint32_t size)
Sends data using a blocking method.
• void SAI_WriteMultiChannelBlocking (I2S_Type ∗base, uint32_t channel, uint32_t channelMask,
uint32_t bitWidth, uint8_t ∗buffer, uint32_t size)
Sends data to multi channel using a blocking method.
• static void SAI_WriteData (I2S_Type ∗base, uint32_t channel, uint32_t data)
Writes data into SAI FIFO.
• void SAI_ReadBlocking (I2S_Type ∗base, uint32_t channel, uint32_t bitWidth, uint8_t ∗buffer,
uint32_t size)
Receives data using a blocking method.

MCUXpresso SDK API Reference Manual


502 NXP Semiconductors
SAI Driver

• void SAI_ReadMultiChannelBlocking (I2S_Type ∗base, uint32_t channel, uint32_t channelMask,


uint32_t bitWidth, uint8_t ∗buffer, uint32_t size)
Receives multi channel data using a blocking method.
• static uint32_t SAI_ReadData (I2S_Type ∗base, uint32_t channel)
Reads data from the SAI FIFO.

Transactional

• void SAI_TransferTxCreateHandle (I2S_Type ∗base, sai_handle_t ∗handle, sai_transfer_callback_t


callback, void ∗userData)
Initializes the SAI Tx handle.
• void SAI_TransferRxCreateHandle (I2S_Type ∗base, sai_handle_t ∗handle, sai_transfer_callback_t
callback, void ∗userData)
Initializes the SAI Rx handle.
• void SAI_TransferTxSetConfig (I2S_Type ∗base, sai_handle_t ∗handle, sai_transceiver_t ∗config)
SAI transmitter transfer configurations.
• void SAI_TransferRxSetConfig (I2S_Type ∗base, sai_handle_t ∗handle, sai_transceiver_t ∗config)
SAI receiver transfer configurations.
• status_t SAI_TransferTxSetFormat (I2S_Type ∗base, sai_handle_t ∗handle, sai_transfer_format_t
∗format, uint32_t mclkSourceClockHz, uint32_t bclkSourceClockHz)
Configures the SAI Tx audio format.
• status_t SAI_TransferRxSetFormat (I2S_Type ∗base, sai_handle_t ∗handle, sai_transfer_format_t
∗format, uint32_t mclkSourceClockHz, uint32_t bclkSourceClockHz)
Configures the SAI Rx audio format.
• status_t SAI_TransferSendNonBlocking (I2S_Type ∗base, sai_handle_t ∗handle, sai_transfer_-
t ∗xfer)
Performs an interrupt non-blocking send transfer on SAI.
• status_t SAI_TransferReceiveNonBlocking (I2S_Type ∗base, sai_handle_t ∗handle, sai_transfer_t
∗xfer)
Performs an interrupt non-blocking receive transfer on SAI.
• status_t SAI_TransferGetSendCount (I2S_Type ∗base, sai_handle_t ∗handle, size_t ∗count)
Gets a set byte count.
• status_t SAI_TransferGetReceiveCount (I2S_Type ∗base, sai_handle_t ∗handle, size_t ∗count)
Gets a received byte count.
• void SAI_TransferAbortSend (I2S_Type ∗base, sai_handle_t ∗handle)
Aborts the current send.
• void SAI_TransferAbortReceive (I2S_Type ∗base, sai_handle_t ∗handle)
Aborts the current IRQ receive.
• void SAI_TransferTerminateSend (I2S_Type ∗base, sai_handle_t ∗handle)
Terminate all SAI send.
• void SAI_TransferTerminateReceive (I2S_Type ∗base, sai_handle_t ∗handle)
Terminate all SAI receive.
• void SAI_TransferTxHandleIRQ (I2S_Type ∗base, sai_handle_t ∗handle)
Tx interrupt handler.
• void SAI_TransferRxHandleIRQ (I2S_Type ∗base, sai_handle_t ∗handle)
Tx interrupt handler.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 503
SAI Driver

23.3.2 Data Structure Documentation

23.3.2.1 struct sai_config_t

Data Fields
• sai_protocol_t protocol
Audio bus protocol in SAI.
• sai_sync_mode_t syncMode
SAI sync mode, control Tx/Rx clock sync.
• bool mclkOutputEnable
Master clock output enable, true means master clock divider enabled.
• sai_mclk_source_t mclkSource
Master Clock source.
• sai_bclk_source_t bclkSource
Bit Clock source.
• sai_master_slave_t masterSlave
Master or slave.

23.3.2.2 struct sai_transfer_format_t

Data Fields
• uint32_t sampleRate_Hz
Sample rate of audio data.
• uint32_t bitWidth
Data length of audio data, usually 8/16/24/32 bits.
• sai_mono_stereo_t stereo
Mono or stereo.
• uint8_t channel
Transfer start channel.
• uint8_t channelMask
enabled channel mask value, reference _sai_channel_mask
• uint8_t endChannel
end channel number
• uint8_t channelNums
Total enabled channel numbers.
• sai_protocol_t protocol
Which audio protocol used.
• bool isFrameSyncCompact
True means Frame sync length is configurable according to bitWidth, false means frame sync length is 64
times of bit clock.

MCUXpresso SDK API Reference Manual


504 NXP Semiconductors
SAI Driver

23.3.2.2.0.17 Field Documentation

23.3.2.2.0.17.1 bool sai_transfer_format_t::isFrameSyncCompact

23.3.2.3 struct sai_master_clock_t

Data Fields
• bool mclkOutputEnable
master clock output enable
• sai_mclk_source_t mclkSource
Master Clock source.
• uint32_t mclkHz
target mclk frequency
• uint32_t mclkSourceClkHz
mclk source frequency

23.3.2.4 struct sai_fifo_t

Data Fields
• bool fifoContinueOneError
fifo continues when error occur
• sai_fifo_packing_t fifoPacking
fifo packing mode

23.3.2.5 struct sai_bit_clock_t

Data Fields
• bool bclkSrcSwap
bit clock source swap
• bool bclkInputDelay
bit clock actually used by the transmitter is delayed by the pad output delay, this has effect of decreasing
the data input setup time, but increasing the data output valid time .
• sai_clock_polarity_t bclkPolarity
bit clock polarity
• sai_bclk_source_t bclkSource
bit Clock source

23.3.2.5.0.18 Field Documentation

23.3.2.5.0.18.1 bool sai_bit_clock_t::bclkInputDelay

23.3.2.6 struct sai_frame_sync_t

Data Fields
• uint8_t frameSyncWidth

MCUXpresso SDK API Reference Manual


NXP Semiconductors 505
SAI Driver

frame sync width in number of bit clocks


• bool frameSyncEarly
TRUE is frame sync assert one bit before the first bit of frame FALSE is frame sync assert with the first bit
of the frame.
• sai_clock_polarity_t frameSyncPolarity
frame sync polarity

23.3.2.7 struct sai_serial_data_t

Data Fields
• sai_data_order_t dataOrder
configure whether the LSB or MSB is transmitted first
• uint8_t dataWord0Length
configure the number of bits in the first word in each frame
• uint8_t dataWordNLength
configure the number of bits in the each word in each frame, except the first word
• uint8_t dataWordLength
used to record the data length for dma transfer
• uint8_t dataFirstBitShifted
Configure the bit index for the first bit transmitted for each word in the frame.
• uint8_t dataWordNum
configure the number of words in each frame
• uint32_t dataMaskedWord
configure whether the transmit word is masked

23.3.2.8 struct sai_transceiver_t

Data Fields
• sai_serial_data_t serialData
serial data configurations
• sai_frame_sync_t frameSync
ws configurations
• sai_bit_clock_t bitClock
bit clock configurations
• sai_fifo_t fifo
fifo configurations
• sai_master_slave_t masterSlave
transceiver is master or slave
• sai_sync_mode_t syncMode
transceiver sync mode
• uint8_t startChannel
Transfer start channel.
• uint8_t channelMask
enabled channel mask value, reference _sai_channel_mask
• uint8_t endChannel
end channel number
• uint8_t channelNums

MCUXpresso SDK API Reference Manual


506 NXP Semiconductors
SAI Driver

Total enabled channel numbers.

23.3.2.9 struct sai_transfer_t

Data Fields
• uint8_t ∗ data
Data start address to transfer.
• size_t dataSize
Transfer size.

23.3.2.9.0.19 Field Documentation

23.3.2.9.0.19.1 uint8_t∗ sai_transfer_t::data

23.3.2.9.0.19.2 size_t sai_transfer_t::dataSize

23.3.2.10 struct _sai_handle

Data Fields
• I2S_Type ∗ base
base address
• uint32_t state
Transfer status.
• sai_transfer_callback_t callback
Callback function called at transfer event.
• void ∗ userData
Callback parameter passed to callback function.
• uint8_t bitWidth
Bit width for transfer, 8/16/24/32 bits.
• uint8_t channel
Transfer start channel.
• uint8_t channelMask
enabled channel mask value, refernece _sai_channel_mask
• uint8_t endChannel
end channel number
• uint8_t channelNums
Total enabled channel numbers.
• sai_transfer_t saiQueue [SAI_XFER_QUEUE_SIZE]
Transfer queue storing queued transfer.
• size_t transferSize [SAI_XFER_QUEUE_SIZE]
Data bytes need to transfer.
• volatile uint8_t queueUser
Index for user to queue transfer.
• volatile uint8_t queueDriver
Index for driver to get the transfer data and size.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 507
SAI Driver

23.3.3 Macro Definition Documentation

23.3.3.1 #define SAI_XFER_QUEUE_SIZE (4)

23.3.4 Enumeration Type Documentation

23.3.4.1 enum _sai_status_t

Enumerator
kStatus_SAI_TxBusy SAI Tx is busy.
kStatus_SAI_RxBusy SAI Rx is busy.
kStatus_SAI_TxError SAI Tx FIFO error.
kStatus_SAI_RxError SAI Rx FIFO error.
kStatus_SAI_QueueFull SAI transfer queue is full.
kStatus_SAI_TxIdle SAI Tx is idle.
kStatus_SAI_RxIdle SAI Rx is idle.

23.3.4.2 enum _sai_channel_mask

Enumerator
kSAI_Channel0Mask channel 0 mask value
kSAI_Channel1Mask channel 1 mask value
kSAI_Channel2Mask channel 2 mask value
kSAI_Channel3Mask channel 3 mask value
kSAI_Channel4Mask channel 4 mask value
kSAI_Channel5Mask channel 5 mask value
kSAI_Channel6Mask channel 6 mask value
kSAI_Channel7Mask channel 7 mask value

23.3.4.3 enum sai_protocol_t

Enumerator
kSAI_BusLeftJustified Uses left justified format.
kSAI_BusRightJustified Uses right justified format.
kSAI_BusI2S Uses I2S format.
kSAI_BusPCMA Uses I2S PCM A format.
kSAI_BusPCMB Uses I2S PCM B format.

MCUXpresso SDK API Reference Manual


508 NXP Semiconductors
SAI Driver

23.3.4.4 enum sai_master_slave_t

Enumerator
kSAI_Master Master mode include bclk and frame sync.
kSAI_Slave Slave mode include bclk and frame sync.
kSAI_Bclk_Master_FrameSync_Slave bclk in master mode, frame sync in slave mode
kSAI_Bclk_Slave_FrameSync_Master bclk in slave mode, frame sync in master mode

23.3.4.5 enum sai_mono_stereo_t

Enumerator
kSAI_Stereo Stereo sound.
kSAI_MonoRight Only Right channel have sound.
kSAI_MonoLeft Only left channel have sound.

23.3.4.6 enum sai_data_order_t

Enumerator
kSAI_DataLSB LSB bit transferred first.
kSAI_DataMSB MSB bit transferred first.

23.3.4.7 enum sai_clock_polarity_t

Enumerator
kSAI_PolarityActiveHigh Drive outputs on rising edge.
kSAI_PolarityActiveLow Drive outputs on falling edge.
kSAI_SampleOnFallingEdge Sample inputs on falling edge.
kSAI_SampleOnRisingEdge Sample inputs on rising edge.

23.3.4.8 enum sai_sync_mode_t

Enumerator
kSAI_ModeAsync Asynchronous mode.
kSAI_ModeSync Synchronous mode (with receiver or transmit)

MCUXpresso SDK API Reference Manual


NXP Semiconductors 509
SAI Driver

23.3.4.9 enum sai_mclk_source_t

Enumerator
kSAI_MclkSourceSysclk Master clock from the system clock.
kSAI_MclkSourceSelect1 Master clock from source 1.
kSAI_MclkSourceSelect2 Master clock from source 2.
kSAI_MclkSourceSelect3 Master clock from source 3.

23.3.4.10 enum sai_bclk_source_t

Enumerator
kSAI_BclkSourceBusclk Bit clock using bus clock.
kSAI_BclkSourceMclkOption1 Bit clock MCLK option 1.
kSAI_BclkSourceMclkOption2 Bit clock MCLK option2.
kSAI_BclkSourceMclkOption3 Bit clock MCLK option3.
kSAI_BclkSourceMclkDiv Bit clock using master clock divider.
kSAI_BclkSourceOtherSai0 Bit clock from other SAI device.
kSAI_BclkSourceOtherSai1 Bit clock from other SAI device.

23.3.4.11 enum _sai_interrupt_enable_t

Enumerator
kSAI_WordStartInterruptEnable Word start flag, means the first word in a frame detected.
kSAI_SyncErrorInterruptEnable Sync error flag, means the sync error is detected.
kSAI_FIFOWarningInterruptEnable FIFO warning flag, means the FIFO is empty.
kSAI_FIFOErrorInterruptEnable FIFO error flag.

23.3.4.12 enum _sai_dma_enable_t

Enumerator
kSAI_FIFOWarningDMAEnable FIFO warning caused by the DMA request.

23.3.4.13 enum _sai_flags

Enumerator
kSAI_WordStartFlag Word start flag, means the first word in a frame detected.
kSAI_SyncErrorFlag Sync error flag, means the sync error is detected.
kSAI_FIFOErrorFlag FIFO error flag.
kSAI_FIFOWarningFlag FIFO warning flag.

MCUXpresso SDK API Reference Manual


510 NXP Semiconductors
SAI Driver

23.3.4.14 enum sai_reset_type_t

Enumerator
kSAI_ResetTypeSoftware Software reset, reset the logic state.
kSAI_ResetTypeFIFO FIFO reset, reset the FIFO read and write pointer.
kSAI_ResetAll All reset.

23.3.4.15 enum sai_fifo_packing_t

Enumerator
kSAI_FifoPackingDisabled Packing disabled.
kSAI_FifoPacking8bit 8 bit packing enabled
kSAI_FifoPacking16bit 16bit packing enabled

23.3.4.16 enum sai_sample_rate_t

Enumerator
kSAI_SampleRate8KHz Sample rate 8000 Hz.
kSAI_SampleRate11025Hz Sample rate 11025 Hz.
kSAI_SampleRate12KHz Sample rate 12000 Hz.
kSAI_SampleRate16KHz Sample rate 16000 Hz.
kSAI_SampleRate22050Hz Sample rate 22050 Hz.
kSAI_SampleRate24KHz Sample rate 24000 Hz.
kSAI_SampleRate32KHz Sample rate 32000 Hz.
kSAI_SampleRate44100Hz Sample rate 44100 Hz.
kSAI_SampleRate48KHz Sample rate 48000 Hz.
kSAI_SampleRate96KHz Sample rate 96000 Hz.
kSAI_SampleRate192KHz Sample rate 192000 Hz.
kSAI_SampleRate384KHz Sample rate 384000 Hz.

23.3.4.17 enum sai_word_width_t

Enumerator
kSAI_WordWidth8bits Audio data width 8 bits.
kSAI_WordWidth16bits Audio data width 16 bits.
kSAI_WordWidth24bits Audio data width 24 bits.
kSAI_WordWidth32bits Audio data width 32 bits.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 511
SAI Driver

23.3.4.18 enum sai_transceiver_type_t

Enumerator
kSAI_Transmitter sai transmitter
kSAI_Receiver sai receiver

23.3.4.19 enum sai_frame_sync_len_t

Enumerator
kSAI_FrameSyncLenOneBitClk 1 bit clock frame sync len for DSP mode
kSAI_FrameSyncLenPerWordWidth Frame sync length decided by word width.

23.3.5 Function Documentation

23.3.5.1 void SAI_TxInit ( I2S_Type ∗ base, const sai_config_t ∗ config )

Ungates the SAI clock, resets the module, and configures SAI Tx with a configuration structure. The
configuration structure can be custom filled or set with default values by SAI_TxGetDefaultConfig().

Note
This API should be called at the beginning of the application to use the SAI driver. Otherwise,
accessing the SAIM module can cause a hard fault because the clock is not enabled.

Parameters

base SAI base pointer


config SAI configuration structure.

23.3.5.2 void SAI_RxInit ( I2S_Type ∗ base, const sai_config_t ∗ config )

Ungates the SAI clock, resets the module, and configures the SAI Rx with a configuration structure. The
configuration structure can be custom filled or set with default values by SAI_RxGetDefaultConfig().

Note
This API should be called at the beginning of the application to use the SAI driver. Otherwise,
accessing the SAI module can cause a hard fault because the clock is not enabled.

MCUXpresso SDK API Reference Manual


512 NXP Semiconductors
SAI Driver

Parameters

base SAI base pointer


config SAI configuration structure.

23.3.5.3 void SAI_TxGetDefaultConfig ( sai_config_t ∗ config )

This API initializes the configuration structure for use in SAI_TxConfig(). The initialized structure can
remain unchanged in SAI_TxConfig(), or it can be modified before calling SAI_TxConfig(). This is an
example.

sai_config_t config;
SAI_TxGetDefaultConfig(&config);

Parameters

config pointer to master configuration structure

23.3.5.4 void SAI_RxGetDefaultConfig ( sai_config_t ∗ config )

This API initializes the configuration structure for use in SAI_RxConfig(). The initialized structure can
remain unchanged in SAI_RxConfig() or it can be modified before calling SAI_RxConfig(). This is an
example.

sai_config_t config;
SAI_RxGetDefaultConfig(&config);

Parameters

config pointer to master configuration structure

23.3.5.5 void SAI_Init ( I2S_Type ∗ base )

This API gates the SAI clock. The SAI module can’t operate unless SAI_Init is called to enable the clock.
Parameters

MCUXpresso SDK API Reference Manual


NXP Semiconductors 513
SAI Driver

base SAI base pointer.

23.3.5.6 void SAI_Deinit ( I2S_Type ∗ base )

This API gates the SAI clock. The SAI module can’t operate unless SAI_TxInit or SAI_RxInit is called
to enable the clock.
Parameters

base SAI base pointer.

23.3.5.7 void SAI_TxReset ( I2S_Type ∗ base )

This function enables the software reset and FIFO reset of SAI Tx. After reset, clear the reset bit.
Parameters

base SAI base pointer

23.3.5.8 void SAI_RxReset ( I2S_Type ∗ base )

This function enables the software reset and FIFO reset of SAI Rx. After reset, clear the reset bit.
Parameters

base SAI base pointer

23.3.5.9 void SAI_TxEnable ( I2S_Type ∗ base, bool enable )

Parameters

base SAI base pointer.


enable True means enable SAI Tx, false means disable.

23.3.5.10 void SAI_RxEnable ( I2S_Type ∗ base, bool enable )

MCUXpresso SDK API Reference Manual


514 NXP Semiconductors
SAI Driver

Parameters

base SAI base pointer.


enable True means enable SAI Rx, false means disable.

23.3.5.11 static void SAI_TxSetBitClockDirection ( I2S_Type ∗ base, sai_master_slave_t


masterSlave ) [inline], [static]

Select bit clock direction, master or slave.


Parameters

base SAI base pointer.


masterSlave reference sai_master_slave_t.

23.3.5.12 static void SAI_RxSetBitClockDirection ( I2S_Type ∗ base, sai_master_slave_t


masterSlave ) [inline], [static]

Select bit clock direction, master or slave.


Parameters

base SAI base pointer.


masterSlave reference sai_master_slave_t.

23.3.5.13 static void SAI_RxSetFrameSyncDirection ( I2S_Type ∗ base,


sai_master_slave_t masterSlave ) [inline], [static]

Select frame sync direction, master or slave.


Parameters

base SAI base pointer.


masterSlave reference sai_master_slave_t.

23.3.5.14 static void SAI_TxSetFrameSyncDirection ( I2S_Type ∗ base,


sai_master_slave_t masterSlave ) [inline], [static]

Select frame sync direction, master or slave.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 515
SAI Driver

Parameters

base SAI base pointer.


masterSlave reference sai_master_slave_t.

23.3.5.15 void SAI_TxSetBitClockRate ( I2S_Type ∗ base, uint32_t sourceClockHz,


uint32_t sampleRate, uint32_t bitWidth, uint32_t channelNumbers )

Parameters

base SAI base pointer.


sourceClock- clock source frequency.
Hz,bit
sampleRate audio data sample rate.
bitWidth,audio data bitWidth.
channel- channel numbers.
Numbers,audio

23.3.5.16 void SAI_RxSetBitClockRate ( I2S_Type ∗ base, uint32_t sourceClockHz,


uint32_t sampleRate, uint32_t bitWidth, uint32_t channelNumbers )

Parameters

base SAI base pointer.


sourceClock- clock source frequency.
Hz,bit
sampleRate audio data sample rate.
bitWidth,audio data bitWidth.
channel- channel numbers.
Numbers,audio

23.3.5.17 void SAI_TxSetBitclockConfig ( I2S_Type ∗ base, sai_master_slave_t


masterSlave, sai_bit_clock_t ∗ config )

MCUXpresso SDK API Reference Manual


516 NXP Semiconductors
SAI Driver

Parameters

base SAI base pointer.


masterSlave master or slave.
config bit clock other configurations, can be NULL in slave mode.

23.3.5.18 void SAI_RxSetBitclockConfig ( I2S_Type ∗ base, sai_master_slave_t


masterSlave, sai_bit_clock_t ∗ config )

Parameters

base SAI base pointer.


masterSlave master or slave.
config bit clock other configurations, can be NULL in slave mode.

23.3.5.19 void SAI_SetMasterClockConfig ( I2S_Type ∗ base, sai_master_clock_t ∗ config


)

Parameters

base SAI base pointer.


config master clock configurations.

23.3.5.20 void SAI_TxSetFifoConfig ( I2S_Type ∗ base, sai_fifo_t ∗ config )

Parameters

base SAI base pointer.


config fifo configurations.

23.3.5.21 void SAI_RxSetFifoConfig ( I2S_Type ∗ base, sai_fifo_t ∗ config )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 517
SAI Driver

Parameters

base SAI base pointer.


config fifo configurations.

23.3.5.22 void SAI_TxSetFrameSyncConfig ( I2S_Type ∗ base, sai_master_slave_t


masterSlave, sai_frame_sync_t ∗ config )

Parameters

base SAI base pointer.


masterSlave master or slave.
config frame sync configurations, can be NULL in slave mode.

23.3.5.23 void SAI_RxSetFrameSyncConfig ( I2S_Type ∗ base, sai_master_slave_t


masterSlave, sai_frame_sync_t ∗ config )

Parameters

base SAI base pointer.


masterSlave master or slave.
config frame sync configurations, can be NULL in slave mode.

23.3.5.24 void SAI_TxSetSerialDataConfig ( I2S_Type ∗ base, sai_serial_data_t ∗ config )

Parameters

base SAI base pointer.


config serial data configurations.

23.3.5.25 void SAI_RxSetSerialDataConfig ( I2S_Type ∗ base, sai_serial_data_t ∗ config )

MCUXpresso SDK API Reference Manual


518 NXP Semiconductors
SAI Driver

Parameters

base SAI base pointer.


config serial data configurations.

23.3.5.26 void SAI_TxSetConfig ( I2S_Type ∗ base, sai_transceiver_t ∗ config )

Parameters

base SAI base pointer.


config transmitter configurations.

23.3.5.27 void SAI_RxSetConfig ( I2S_Type ∗ base, sai_transceiver_t ∗ config )

Parameters

base SAI base pointer.


config receiver configurations.

23.3.5.28 void SAI_GetClassicI2SConfig ( sai_transceiver_t ∗ config, sai_word_width_t


bitWidth, sai_mono_stereo_t mode, uint32_t saiChannelMask )

Parameters

config transceiver configurations.


bitWidth audio data bitWidth.
mode audio data channel.
saiChannel- mask value of the channel to be enable.
Mask

23.3.5.29 void SAI_GetLeftJustifiedConfig ( sai_transceiver_t ∗ config, sai_word_width_t


bitWidth, sai_mono_stereo_t mode, uint32_t saiChannelMask )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 519
SAI Driver

Parameters

config transceiver configurations.


bitWidth audio data bitWidth.
mode audio data channel.
saiChannel- mask value of the channel to be enable.
Mask

23.3.5.30 void SAI_GetRightJustifiedConfig ( sai_transceiver_t ∗ config,


sai_word_width_t bitWidth, sai_mono_stereo_t mode, uint32_t saiChannelMask
)

Parameters

config transceiver configurations.


bitWidth audio data bitWidth.
mode audio data channel.
saiChannel- mask value of the channel to be enable.
Mask

23.3.5.31 void SAI_GetTDMConfig ( sai_transceiver_t ∗ config, sai_frame_sync_len_t


frameSyncWidth, sai_word_width_t bitWidth, uint32_t dataWordNum, uint32_t
saiChannelMask )

Parameters

config transceiver configurations.


frameSync- length of frame sync.
Width
bitWidth audio data word width.
dataWordNum word number in one frame.
saiChannel- mask value of the channel to be enable.
Mask

MCUXpresso SDK API Reference Manual


520 NXP Semiconductors
SAI Driver

23.3.5.32 void SAI_GetDSPConfig ( sai_transceiver_t ∗ config, sai_frame_sync_len_t


frameSyncWidth, sai_word_width_t bitWidth, sai_mono_stereo_t mode,
uint32_t saiChannelMask )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 521
SAI Driver

Parameters

config transceiver configurations.


frameSync- length of frame sync.
Width
bitWidth audio data bitWidth.
mode audio data channel.
saiChannel- mask value of the channel to enable.
Mask

23.3.5.33 static uint32_t SAI_TxGetStatusFlag ( I2S_Type ∗ base ) [inline],


[static]

Parameters

base SAI base pointer

Returns
SAI Tx status flag value. Use the Status Mask to get the status value needed.

23.3.5.34 static void SAI_TxClearStatusFlags ( I2S_Type ∗ base, uint32_t mask )


[inline], [static]

Parameters

base SAI base pointer


mask State mask. It can be a combination of the following source if defined:
• kSAI_WordStartFlag
• kSAI_SyncErrorFlag
• kSAI_FIFOErrorFlag

23.3.5.35 static uint32_t SAI_RxGetStatusFlag ( I2S_Type ∗ base ) [inline],


[static]

MCUXpresso SDK API Reference Manual


522 NXP Semiconductors
SAI Driver

Parameters

base SAI base pointer

Returns
SAI Rx status flag value. Use the Status Mask to get the status value needed.

23.3.5.36 static void SAI_RxClearStatusFlags ( I2S_Type ∗ base, uint32_t mask )


[inline], [static]

Parameters

base SAI base pointer


mask State mask. It can be a combination of the following sources if defined.
• kSAI_WordStartFlag
• kSAI_SyncErrorFlag
• kSAI_FIFOErrorFlag

23.3.5.37 void SAI_TxSoftwareReset ( I2S_Type ∗ base, sai_reset_type_t type )

FIFO reset means clear all the data in the FIFO, and make the FIFO pointer both to 0. Software reset
means clear the Tx internal logic, including the bit clock, frame count etc. But software reset will not
clear any configuration registers like TCR1∼TCR5. This function will also clear all the error flags such
as FIFO error, sync error etc.
Parameters

base SAI base pointer


type Reset type, FIFO reset or software reset

23.3.5.38 void SAI_RxSoftwareReset ( I2S_Type ∗ base, sai_reset_type_t type )

FIFO reset means clear all the data in the FIFO, and make the FIFO pointer both to 0. Software reset
means clear the Rx internal logic, including the bit clock, frame count etc. But software reset will not
clear any configuration registers like RCR1∼RCR5. This function will also clear all the error flags such
as FIFO error, sync error etc.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 523
SAI Driver

Parameters

base SAI base pointer


type Reset type, FIFO reset or software reset

23.3.5.39 void SAI_TxSetChannelFIFOMask ( I2S_Type ∗ base, uint8_t mask )

Parameters

base SAI base pointer


mask Channel enable mask, 0 means all channel FIFO disabled, 1 means channel 0 enabled,
3 means both channel 0 and channel 1 enabled.

23.3.5.40 void SAI_RxSetChannelFIFOMask ( I2S_Type ∗ base, uint8_t mask )

Parameters

base SAI base pointer


mask Channel enable mask, 0 means all channel FIFO disabled, 1 means channel 0 enabled,
3 means both channel 0 and channel 1 enabled.

23.3.5.41 void SAI_TxSetDataOrder ( I2S_Type ∗ base, sai_data_order_t order )

Parameters

base SAI base pointer


order Data order MSB or LSB

23.3.5.42 void SAI_RxSetDataOrder ( I2S_Type ∗ base, sai_data_order_t order )

Parameters

base SAI base pointer


order Data order MSB or LSB

MCUXpresso SDK API Reference Manual


524 NXP Semiconductors
SAI Driver

23.3.5.43 void SAI_TxSetBitClockPolarity ( I2S_Type ∗ base, sai_clock_polarity_t polarity


)

MCUXpresso SDK API Reference Manual


NXP Semiconductors 525
SAI Driver

Parameters

base SAI base pointer


order Data order MSB or LSB

23.3.5.44 void SAI_RxSetBitClockPolarity ( I2S_Type ∗ base, sai_clock_polarity_t polarity


)

Parameters

base SAI base pointer


order Data order MSB or LSB

23.3.5.45 void SAI_TxSetFrameSyncPolarity ( I2S_Type ∗ base, sai_clock_polarity_t


polarity )

Parameters

base SAI base pointer


order Data order MSB or LSB

23.3.5.46 void SAI_RxSetFrameSyncPolarity ( I2S_Type ∗ base, sai_clock_polarity_t


polarity )

Parameters

base SAI base pointer


order Data order MSB or LSB

23.3.5.47 void SAI_TxSetFIFOPacking ( I2S_Type ∗ base, sai_fifo_packing_t pack )

Parameters

base SAI base pointer.


pack FIFO pack type. It is element of sai_fifo_packing_t.

MCUXpresso SDK API Reference Manual


526 NXP Semiconductors
SAI Driver

23.3.5.48 void SAI_RxSetFIFOPacking ( I2S_Type ∗ base, sai_fifo_packing_t pack )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 527
SAI Driver

Parameters

base SAI base pointer.


pack FIFO pack type. It is element of sai_fifo_packing_t.

23.3.5.49 static void SAI_TxSetFIFOErrorContinue ( I2S_Type ∗ base, bool isEnabled )


[inline], [static]

FIFO error continue mode means SAI will keep running while FIFO error occurred. If this feature not
enabled, SAI will hang and users need to clear FEF flag in TCSR register.
Parameters

base SAI base pointer.


isEnabled Is FIFO error continue enabled, true means enable, false means disable.

23.3.5.50 static void SAI_RxSetFIFOErrorContinue ( I2S_Type ∗ base, bool isEnabled )


[inline], [static]

FIFO error continue mode means SAI will keep running while FIFO error occurred. If this feature not
enabled, SAI will hang and users need to clear FEF flag in RCSR register.
Parameters

base SAI base pointer.


isEnabled Is FIFO error continue enabled, true means enable, false means disable.

23.3.5.51 static void SAI_TxEnableInterrupts ( I2S_Type ∗ base, uint32_t mask )


[inline], [static]

Parameters

base SAI base pointer


mask interrupt source The parameter can be a combination of the following sources if de-
fined.
• kSAI_WordStartInterruptEnable
• kSAI_SyncErrorInterruptEnable
• kSAI_FIFOWarningInterruptEnable
• kSAI_FIFORequestInterruptEnable
• kSAI_FIFOErrorInterruptEnable

MCUXpresso SDK API Reference Manual


528 NXP Semiconductors
SAI Driver

23.3.5.52 static void SAI_RxEnableInterrupts ( I2S_Type ∗ base, uint32_t mask )


[inline], [static]

Parameters

base SAI base pointer


mask interrupt source The parameter can be a combination of the following sources if de-
fined.
• kSAI_WordStartInterruptEnable
• kSAI_SyncErrorInterruptEnable
• kSAI_FIFOWarningInterruptEnable
• kSAI_FIFORequestInterruptEnable
• kSAI_FIFOErrorInterruptEnable

23.3.5.53 static void SAI_TxDisableInterrupts ( I2S_Type ∗ base, uint32_t mask )


[inline], [static]

Parameters

base SAI base pointer


mask interrupt source The parameter can be a combination of the following sources if de-
fined.
• kSAI_WordStartInterruptEnable
• kSAI_SyncErrorInterruptEnable
• kSAI_FIFOWarningInterruptEnable
• kSAI_FIFORequestInterruptEnable
• kSAI_FIFOErrorInterruptEnable

23.3.5.54 static void SAI_RxDisableInterrupts ( I2S_Type ∗ base, uint32_t mask )


[inline], [static]

MCUXpresso SDK API Reference Manual


NXP Semiconductors 529
SAI Driver

Parameters

base SAI base pointer


mask interrupt source The parameter can be a combination of the following sources if de-
fined.
• kSAI_WordStartInterruptEnable
• kSAI_SyncErrorInterruptEnable
• kSAI_FIFOWarningInterruptEnable
• kSAI_FIFORequestInterruptEnable
• kSAI_FIFOErrorInterruptEnable

23.3.5.55 static void SAI_TxEnableDMA ( I2S_Type ∗ base, uint32_t mask, bool enable )
[inline], [static]

Parameters

base SAI base pointer


mask DMA source The parameter can be combination of the following sources if defined.
• kSAI_FIFOWarningDMAEnable
• kSAI_FIFORequestDMAEnable

enable True means enable DMA, false means disable DMA.

23.3.5.56 static void SAI_RxEnableDMA ( I2S_Type ∗ base, uint32_t mask, bool enable )
[inline], [static]

Parameters

base SAI base pointer


mask DMA source The parameter can be a combination of the following sources if defined.
• kSAI_FIFOWarningDMAEnable
• kSAI_FIFORequestDMAEnable

MCUXpresso SDK API Reference Manual


530 NXP Semiconductors
SAI Driver

enable True means enable DMA, false means disable DMA.

23.3.5.57 static uint32_t SAI_TxGetDataRegisterAddress ( I2S_Type ∗ base, uint32_t


channel ) [inline], [static]

This API is used to provide a transfer address for the SAI DMA transfer configuration.
Parameters

base SAI base pointer.


channel Which data channel used.

Returns
data register address.

23.3.5.58 static uint32_t SAI_RxGetDataRegisterAddress ( I2S_Type ∗ base, uint32_t


channel ) [inline], [static]

This API is used to provide a transfer address for the SAI DMA transfer configuration.
Parameters

base SAI base pointer.


channel Which data channel used.

Returns
data register address.

23.3.5.59 void SAI_TxSetFormat ( I2S_Type ∗ base, sai_transfer_format_t ∗ format,


uint32_t mclkSourceClockHz, uint32_t bclkSourceClockHz )

The audio format can be changed at run-time. This function configures the sample rate and audio data
format to be transferred.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 531
SAI Driver

Parameters

base SAI base pointer.


format Pointer to the SAI audio data format structure.
mclkSource- SAI master clock source frequency in Hz.
ClockHz
bclkSource- SAI bit clock source frequency in Hz. If the bit clock source is a master clock, this
ClockHz value should equal the masterClockHz.

23.3.5.60 void SAI_RxSetFormat ( I2S_Type ∗ base, sai_transfer_format_t ∗ format,


uint32_t mclkSourceClockHz, uint32_t bclkSourceClockHz )

The audio format can be changed at run-time. This function configures the sample rate and audio data
format to be transferred.
Parameters

base SAI base pointer.


format Pointer to the SAI audio data format structure.
mclkSource- SAI master clock source frequency in Hz.
ClockHz
bclkSource- SAI bit clock source frequency in Hz. If the bit clock source is a master clock, this
ClockHz value should equal the masterClockHz.

23.3.5.61 void SAI_WriteBlocking ( I2S_Type ∗ base, uint32_t channel, uint32_t bitWidth,


uint8_t ∗ buffer, uint32_t size )

Note
This function blocks by polling until data is ready to be sent.

Parameters

base SAI base pointer.


channel Data channel used.

MCUXpresso SDK API Reference Manual


532 NXP Semiconductors
SAI Driver

bitWidth How many bits in an audio word; usually 8/16/24/32 bits.


buffer Pointer to the data to be written.
size Bytes to be written.

23.3.5.62 void SAI_WriteMultiChannelBlocking ( I2S_Type ∗ base, uint32_t channel,


uint32_t channelMask, uint32_t bitWidth, uint8_t ∗ buffer, uint32_t size )

Note
This function blocks by polling until data is ready to be sent.

Parameters

base SAI base pointer.


channel Data channel used.
channelMask channel mask.
bitWidth How many bits in an audio word; usually 8/16/24/32 bits.
buffer Pointer to the data to be written.
size Bytes to be written.

23.3.5.63 static void SAI_WriteData ( I2S_Type ∗ base, uint32_t channel, uint32_t data )
[inline], [static]

Parameters

base SAI base pointer.


channel Data channel used.
data Data needs to be written.

23.3.5.64 void SAI_ReadBlocking ( I2S_Type ∗ base, uint32_t channel, uint32_t bitWidth,


uint8_t ∗ buffer, uint32_t size )

Note
This function blocks by polling until data is ready to be sent.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 533
SAI Driver

Parameters

base SAI base pointer.


channel Data channel used.
bitWidth How many bits in an audio word; usually 8/16/24/32 bits.
buffer Pointer to the data to be read.
size Bytes to be read.

23.3.5.65 void SAI_ReadMultiChannelBlocking ( I2S_Type ∗ base, uint32_t channel,


uint32_t channelMask, uint32_t bitWidth, uint8_t ∗ buffer, uint32_t size )

Note
This function blocks by polling until data is ready to be sent.

Parameters

base SAI base pointer.


channel Data channel used.
channelMask channel mask.
bitWidth How many bits in an audio word; usually 8/16/24/32 bits.
buffer Pointer to the data to be read.
size Bytes to be read.

23.3.5.66 static uint32_t SAI_ReadData ( I2S_Type ∗ base, uint32_t channel )


[inline], [static]

Parameters

base SAI base pointer.


channel Data channel used.

Returns
Data in SAI FIFO.

MCUXpresso SDK API Reference Manual


534 NXP Semiconductors
SAI Driver

23.3.5.67 void SAI_TransferTxCreateHandle ( I2S_Type ∗ base, sai_handle_t ∗ handle,


sai_transfer_callback_t callback, void ∗ userData )

This function initializes the Tx handle for the SAI Tx transactional APIs. Call this function once to get
the handle initialized.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 535
SAI Driver

Parameters

base SAI base pointer


handle SAI handle pointer.
callback Pointer to the user callback function.
userData User parameter passed to the callback function

23.3.5.68 void SAI_TransferRxCreateHandle ( I2S_Type ∗ base, sai_handle_t ∗ handle,


sai_transfer_callback_t callback, void ∗ userData )

This function initializes the Rx handle for the SAI Rx transactional APIs. Call this function once to get
the handle initialized.
Parameters

base SAI base pointer.


handle SAI handle pointer.
callback Pointer to the user callback function.
userData User parameter passed to the callback function.

23.3.5.69 void SAI_TransferTxSetConfig ( I2S_Type ∗ base, sai_handle_t ∗ handle,


sai_transceiver_t ∗ config )

This function initializes the Tx, include bit clock, frame sync, master clock, serial data and fifo configura-
tions.
Parameters

base SAI base pointer.


handle SAI handle pointer.
config tranmitter configurations.

23.3.5.70 void SAI_TransferRxSetConfig ( I2S_Type ∗ base, sai_handle_t ∗ handle,


sai_transceiver_t ∗ config )

This function initializes the Rx, include bit clock, frame sync, master clock, serial data and fifo configura-
tions.

MCUXpresso SDK API Reference Manual


536 NXP Semiconductors
SAI Driver

Parameters

base SAI base pointer.


handle SAI handle pointer.
config receiver configurations.

23.3.5.71 status_t SAI_TransferTxSetFormat ( I2S_Type ∗ base, sai_handle_t ∗ handle,


sai_transfer_format_t ∗ format, uint32_t mclkSourceClockHz, uint32_t
bclkSourceClockHz )

The audio format can be changed at run-time. This function configures the sample rate and audio data
format to be transferred.
Parameters

base SAI base pointer.


handle SAI handle pointer.
format Pointer to the SAI audio data format structure.
mclkSource- SAI master clock source frequency in Hz.
ClockHz
bclkSource- SAI bit clock source frequency in Hz. If a bit clock source is a master clock, this
ClockHz value should equal the masterClockHz in format.

Returns
Status of this function. Return value is the status_t.

23.3.5.72 status_t SAI_TransferRxSetFormat ( I2S_Type ∗ base, sai_handle_t ∗ handle,


sai_transfer_format_t ∗ format, uint32_t mclkSourceClockHz, uint32_t
bclkSourceClockHz )

The audio format can be changed at run-time. This function configures the sample rate and audio data
format to be transferred.
Parameters

MCUXpresso SDK API Reference Manual


NXP Semiconductors 537
SAI Driver

base SAI base pointer.


handle SAI handle pointer.
format Pointer to the SAI audio data format structure.
mclkSource- SAI master clock source frequency in Hz.
ClockHz
bclkSource- SAI bit clock source frequency in Hz. If a bit clock source is a master clock, this
ClockHz value should equal the masterClockHz in format.

Returns
Status of this function. Return value is one of status_t.

23.3.5.73 status_t SAI_TransferSendNonBlocking ( I2S_Type ∗ base, sai_handle_t ∗


handle, sai_transfer_t ∗ xfer )

Note
This API returns immediately after the transfer initiates. Call the SAI_TxGetTransferStatusIRQ to
poll the transfer status and check whether the transfer is finished. If the return status is not kStatus_-
SAI_Busy, the transfer is finished.

Parameters

base SAI base pointer.


handle Pointer to the sai_handle_t structure which stores the transfer state.
xfer Pointer to the sai_transfer_t structure.

Return values

kStatus_Success Successfully started the data receive.


kStatus_SAI_TxBusy Previous receive still not finished.
kStatus_InvalidArgument The input parameter is invalid.

23.3.5.74 status_t SAI_TransferReceiveNonBlocking ( I2S_Type ∗ base, sai_handle_t ∗


handle, sai_transfer_t ∗ xfer )

Note
This API returns immediately after the transfer initiates. Call the SAI_RxGetTransferStatusIRQ to
poll the transfer status and check whether the transfer is finished. If the return status is not kStatus_-
SAI_Busy, the transfer is finished.

MCUXpresso SDK API Reference Manual


538 NXP Semiconductors
SAI Driver

Parameters

base SAI base pointer


handle Pointer to the sai_handle_t structure which stores the transfer state.
xfer Pointer to the sai_transfer_t structure.

Return values

kStatus_Success Successfully started the data receive.


kStatus_SAI_RxBusy Previous receive still not finished.
kStatus_InvalidArgument The input parameter is invalid.

23.3.5.75 status_t SAI_TransferGetSendCount ( I2S_Type ∗ base, sai_handle_t ∗ handle,


size_t ∗ count )

Parameters

base SAI base pointer.


handle Pointer to the sai_handle_t structure which stores the transfer state.
count Bytes count sent.

Return values

kStatus_Success Succeed get the transfer count.


kStatus_NoTransferIn- There is not a non-blocking transaction currently in progress.
Progress

23.3.5.76 status_t SAI_TransferGetReceiveCount ( I2S_Type ∗ base, sai_handle_t ∗


handle, size_t ∗ count )

Parameters

base SAI base pointer.


handle Pointer to the sai_handle_t structure which stores the transfer state.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 539
SAI Driver

count Bytes count received.

Return values

kStatus_Success Succeed get the transfer count.


kStatus_NoTransferIn- There is not a non-blocking transaction currently in progress.
Progress

23.3.5.77 void SAI_TransferAbortSend ( I2S_Type ∗ base, sai_handle_t ∗ handle )

Note
This API can be called any time when an interrupt non-blocking transfer initiates to abort the transfer
early.

Parameters

base SAI base pointer.


handle Pointer to the sai_handle_t structure which stores the transfer state.

23.3.5.78 void SAI_TransferAbortReceive ( I2S_Type ∗ base, sai_handle_t ∗ handle )

Note
This API can be called when an interrupt non-blocking transfer initiates to abort the transfer early.

Parameters

base SAI base pointer


handle Pointer to the sai_handle_t structure which stores the transfer state.

23.3.5.79 void SAI_TransferTerminateSend ( I2S_Type ∗ base, sai_handle_t ∗ handle )

This function will clear all transfer slots buffered in the sai queue. If users only want to abort the current
transfer slot, please call SAI_TransferAbortSend.

MCUXpresso SDK API Reference Manual


540 NXP Semiconductors
SAI Driver

Parameters

base SAI base pointer.


handle SAI eDMA handle pointer.

23.3.5.80 void SAI_TransferTerminateReceive ( I2S_Type ∗ base, sai_handle_t ∗ handle )

This function will clear all transfer slots buffered in the sai queue. If users only want to abort the current
transfer slot, please call SAI_TransferAbortReceive.
Parameters

base SAI base pointer.


handle SAI eDMA handle pointer.

23.3.5.81 void SAI_TransferTxHandleIRQ ( I2S_Type ∗ base, sai_handle_t ∗ handle )

Parameters

base SAI base pointer.


handle Pointer to the sai_handle_t structure.

23.3.5.82 void SAI_TransferRxHandleIRQ ( I2S_Type ∗ base, sai_handle_t ∗ handle )

Parameters

base SAI base pointer.


handle Pointer to the sai_handle_t structure.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 541
SAI DMA Driver

23.4 SAI DMA Driver


23.4.1 Overview

Data Structures

• struct sai_dma_handle_t
SAI DMA transfer handle, users should not touch the content of the handle. More...

Typedefs

• typedef void(∗ sai_dma_callback_t )(I2S_Type ∗base, sai_dma_handle_t ∗handle, status_t status,


void ∗userData)
Define SAI DMA callback.

Driver version

• #define FSL_SAI_DMA_DRIVER_VERSION (MAKE_VERSION(2, 2, 0))


Version 2.2.0.

DMA Transactional

• void SAI_TransferTxCreateHandleDMA (I2S_Type ∗base, sai_dma_handle_t ∗handle, sai_dma_-


callback_t callback, void ∗userData, dma_handle_t ∗dmaHandle)
Initializes the SAI master DMA handle.
• void SAI_TransferRxCreateHandleDMA (I2S_Type ∗base, sai_dma_handle_t ∗handle, sai_dma_-
callback_t callback, void ∗userData, dma_handle_t ∗dmaHandle)
Initializes the SAI slave DMA handle.
• void SAI_TransferTxSetFormatDMA (I2S_Type ∗base, sai_dma_handle_t ∗handle, sai_transfer_-
format_t ∗format, uint32_t mclkSourceClockHz, uint32_t bclkSourceClockHz)
Configures the SAI Tx audio format.
• void SAI_TransferRxSetFormatDMA (I2S_Type ∗base, sai_dma_handle_t ∗handle, sai_transfer_-
format_t ∗format, uint32_t mclkSourceClockHz, uint32_t bclkSourceClockHz)
Configures the SAI Rx audio format.
• status_t SAI_TransferSendDMA (I2S_Type ∗base, sai_dma_handle_t ∗handle, sai_transfer_t ∗xfer)
Performs a non-blocking SAI transfer using DMA.
• status_t SAI_TransferReceiveDMA (I2S_Type ∗base, sai_dma_handle_t ∗handle, sai_transfer_-
t ∗xfer)
Performs a non-blocking SAI transfer using DMA.
• void SAI_TransferAbortSendDMA (I2S_Type ∗base, sai_dma_handle_t ∗handle)
Aborts a SAI transfer using DMA.
• void SAI_TransferAbortReceiveDMA (I2S_Type ∗base, sai_dma_handle_t ∗handle)
Aborts a SAI transfer using DMA.
• status_t SAI_TransferGetSendCountDMA (I2S_Type ∗base, sai_dma_handle_t ∗handle, size_-
t ∗count)

MCUXpresso SDK API Reference Manual


542 NXP Semiconductors
SAI DMA Driver

Gets byte count sent by SAI.


• status_t SAI_TransferGetReceiveCountDMA (I2S_Type ∗base, sai_dma_handle_t ∗handle, size_t
∗count)
Gets byte count received by SAI.
• void SAI_TransferTxSetConfigDMA (I2S_Type ∗base, sai_dma_handle_t ∗handle, sai_transceiver-
_t ∗saiConfig)
Configures the SAI Tx.
• void SAI_TransferRxSetConfigDMA (I2S_Type ∗base, sai_dma_handle_t ∗handle, sai_transceiver-
_t ∗saiConfig)
Configures the SAI Rx.

23.4.2 Data Structure Documentation

23.4.2.1 struct _sai_dma_handle

Data Fields
• dma_handle_t ∗ dmaHandle
DMA handler for SAI send.
• uint8_t bytesPerFrame
Bytes in a frame.
• uint8_t channel
Which Data channel SAI use.
• uint32_t state
SAI DMA transfer internal state.
• sai_dma_callback_t callback
Callback for users while transfer finish or error occurred.
• void ∗ userData
User callback parameter.
• sai_transfer_t saiQueue [SAI_XFER_QUEUE_SIZE]
Transfer queue storing queued transfer.
• size_t transferSize [SAI_XFER_QUEUE_SIZE]
Data bytes need to transfer.
• volatile uint8_t queueUser
Index for user to queue transfer.
• volatile uint8_t queueDriver
Index for driver to get the transfer data and size.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 543
SAI DMA Driver

23.4.2.1.0.20 Field Documentation

23.4.2.1.0.20.1 sai_transfer_t sai_dma_handle_t::saiQueue[SAI_XFER_QUEUE_SIZE]

23.4.2.1.0.20.2 volatile uint8_t sai_dma_handle_t::queueUser

23.4.3 Function Documentation

23.4.3.1 void SAI_TransferTxCreateHandleDMA ( I2S_Type ∗ base, sai_dma_handle_t


∗ handle, sai_dma_callback_t callback, void ∗ userData, dma_handle_t ∗
dmaHandle )

This function initializes the SAI master DMA handle, which can be used for other SAI master transactional
APIs. Usually, for a specified SAI instance, call this API once to get the initialized handle.

MCUXpresso SDK API Reference Manual


544 NXP Semiconductors
SAI DMA Driver

Parameters

base SAI base pointer.


handle SAI DMA handle pointer.
base SAI peripheral base address.
callback Pointer to user callback function.
userData User parameter passed to the callback function.
dmaHandle DMA handle pointer, this handle shall be static allocated by users.

23.4.3.2 void SAI_TransferRxCreateHandleDMA ( I2S_Type ∗ base, sai_dma_handle_t


∗ handle, sai_dma_callback_t callback, void ∗ userData, dma_handle_t ∗
dmaHandle )

This function initializes the SAI slave DMA handle, which can be used for other SAI master transactional
APIs. Usually, for a specified SAI instance, call this API once to get the initialized handle.
Parameters

base SAI base pointer.


handle SAI DMA handle pointer.
base SAI peripheral base address.
callback Pointer to user callback function.
userData User parameter passed to the callback function.
dmaHandle DMA handle pointer, this handle shall be static allocated by users.

23.4.3.3 void SAI_TransferTxSetFormatDMA ( I2S_Type ∗ base, sai_dma_handle_t ∗


handle, sai_transfer_format_t ∗ format, uint32_t mclkSourceClockHz, uint32_t
bclkSourceClockHz )

The audio format can be changed at run-time. This function configures the sample rate and audio data
format to be transferred. This function also sets the eDMA parameter according to the format.
Parameters

base SAI base pointer.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 545
SAI DMA Driver

handle SAI DMA handle pointer.


format Pointer to SAI audio data format structure.
mclkSource- SAI master clock source frequency in Hz.
ClockHz
bclkSource- SAI bit clock source frequency in Hz. If bit clock source is master. clock, this value
ClockHz should equals to masterClockHz in format.

Return values

kStatus_Success Audio format set successfully.


kStatus_InvalidArgument The input arguments is invalid.

23.4.3.4 void SAI_TransferRxSetFormatDMA ( I2S_Type ∗ base, sai_dma_handle_t ∗


handle, sai_transfer_format_t ∗ format, uint32_t mclkSourceClockHz, uint32_t
bclkSourceClockHz )

The audio format can be changed at run-time. This function configures the sample rate and audio data
format to be transferred. This function also sets eDMA parameter according to format.
Parameters

base SAI base pointer.


handle SAI DMA handle pointer.
format Pointer to SAI audio data format structure.
mclkSource- SAI master clock source frequency in Hz.
ClockHz
bclkSource- SAI bit clock source frequency in Hz. If bit clock source is master. clock, this value
ClockHz should equals to masterClockHz in format.

Return values

kStatus_Success Audio format set successfully.


kStatus_InvalidArgument The input arguments is invalid.

23.4.3.5 status_t SAI_TransferSendDMA ( I2S_Type ∗ base, sai_dma_handle_t ∗ handle,


sai_transfer_t ∗ xfer )

MCUXpresso SDK API Reference Manual


546 NXP Semiconductors
SAI DMA Driver

Note
This interface returns immediately after the transfer initiates. Call the SAI_GetTransferStatus to poll
the transfer status to check whether the SAI transfer finished.

Parameters

base SAI base pointer.


handle SAI DMA handle pointer.
xfer Pointer to DMA transfer structure.

Return values

kStatus_Success Successfully start the data receive.


kStatus_SAI_TxBusy Previous receive still not finished.
kStatus_InvalidArgument The input parameter is invalid.

23.4.3.6 status_t SAI_TransferReceiveDMA ( I2S_Type ∗ base, sai_dma_handle_t ∗


handle, sai_transfer_t ∗ xfer )

Note
This interface returns immediately after transfer initiates. Call SAI_GetTransferStatus to poll the
transfer status to check whether the SAI transfer is finished.

Parameters

base SAI base pointer


handle SAI DMA handle pointer.
xfer Pointer to DMA transfer structure.

Return values

kStatus_Success Successfully start the data receive.


kStatus_SAI_RxBusy Previous receive still not finished.
kStatus_InvalidArgument The input parameter is invalid.

23.4.3.7 void SAI_TransferAbortSendDMA ( I2S_Type ∗ base, sai_dma_handle_t ∗ handle


)

MCUXpresso SDK API Reference Manual


NXP Semiconductors 547
SAI DMA Driver

Parameters

base SAI base pointer.


handle SAI DMA handle pointer.

23.4.3.8 void SAI_TransferAbortReceiveDMA ( I2S_Type ∗ base, sai_dma_handle_t ∗


handle )

Parameters

base SAI base pointer.


handle SAI DMA handle pointer.

23.4.3.9 status_t SAI_TransferGetSendCountDMA ( I2S_Type ∗ base, sai_dma_handle_t


∗ handle, size_t ∗ count )

Parameters

base SAI base pointer.


handle SAI DMA handle pointer.
count Bytes count sent by SAI.

Return values

kStatus_Success Succeed get the transfer count.


kStatus_NoTransferIn- There is not a non-blocking transaction currently in progress.
Progress

23.4.3.10 status_t SAI_TransferGetReceiveCountDMA ( I2S_Type ∗ base,


sai_dma_handle_t ∗ handle, size_t ∗ count )

Parameters

base SAI base pointer.

MCUXpresso SDK API Reference Manual


548 NXP Semiconductors
SAI DMA Driver

handle SAI DMA handle pointer.


count Bytes count received by SAI.

Return values

kStatus_Success Succeed get the transfer count.


kStatus_NoTransferIn- There is not a non-blocking transaction currently in progress.
Progress

23.4.3.11 void SAI_TransferTxSetConfigDMA ( I2S_Type ∗ base, sai_dma_handle_t ∗


handle, sai_transceiver_t ∗ saiConfig )

Parameters

base SAI base pointer.


handle SAI DMA handle pointer.
saiConfig sai configurations.

23.4.3.12 void SAI_TransferRxSetConfigDMA ( I2S_Type ∗ base, sai_dma_handle_t ∗


handle, sai_transceiver_t ∗ saiConfig )

Parameters

base SAI base pointer.


handle SAI DMA handle pointer.
saiConfig sai configurations.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 549
SAI EDMA Driver

23.5 SAI EDMA Driver


23.5.1 Overview

Data Structures

• struct sai_edma_handle_t
SAI DMA transfer handle, users should not touch the content of the handle. More...

Typedefs

• typedef void(∗ sai_edma_callback_t )(I2S_Type ∗base, sai_edma_handle_t ∗handle, status_t status,


void ∗userData)
SAI eDMA transfer callback function for finish and error.

Driver version

• #define FSL_SAI_EDMA_DRIVER_VERSION (MAKE_VERSION(2, 2, 0))


Version 2.2.0.

eDMA Transactional

• void SAI_TransferTxCreateHandleEDMA (I2S_Type ∗base, sai_edma_handle_t ∗handle, sai_-


edma_callback_t callback, void ∗userData, edma_handle_t ∗dmaHandle)
Initializes the SAI eDMA handle.
• void SAI_TransferRxCreateHandleEDMA (I2S_Type ∗base, sai_edma_handle_t ∗handle, sai_-
edma_callback_t callback, void ∗userData, edma_handle_t ∗dmaHandle)
Initializes the SAI Rx eDMA handle.
• void SAI_TransferTxSetFormatEDMA (I2S_Type ∗base, sai_edma_handle_t ∗handle, sai_transfer-
_format_t ∗format, uint32_t mclkSourceClockHz, uint32_t bclkSourceClockHz)
Configures the SAI Tx audio format.
• void SAI_TransferRxSetFormatEDMA (I2S_Type ∗base, sai_edma_handle_t ∗handle, sai_transfer-
_format_t ∗format, uint32_t mclkSourceClockHz, uint32_t bclkSourceClockHz)
Configures the SAI Rx audio format.
• void SAI_TransferTxSetConfigEDMA (I2S_Type ∗base, sai_edma_handle_t ∗handle, sai_-
transceiver_t ∗saiConfig)
Configures the SAI Tx.
• void SAI_TransferRxSetConfigEDMA (I2S_Type ∗base, sai_edma_handle_t ∗handle, sai_-
transceiver_t ∗saiConfig)
Configures the SAI Rx.
• status_t SAI_TransferSendEDMA (I2S_Type ∗base, sai_edma_handle_t ∗handle, sai_transfer_-
t ∗xfer)
Performs a non-blocking SAI transfer using DMA.
• status_t SAI_TransferReceiveEDMA (I2S_Type ∗base, sai_edma_handle_t ∗handle, sai_transfer_t
∗xfer)

MCUXpresso SDK API Reference Manual


550 NXP Semiconductors
SAI EDMA Driver

Performs a non-blocking SAI receive using eDMA.


• void SAI_TransferTerminateSendEDMA (I2S_Type ∗base, sai_edma_handle_t ∗handle)
Terminate all SAI send.
• void SAI_TransferTerminateReceiveEDMA (I2S_Type ∗base, sai_edma_handle_t ∗handle)
Terminate all SAI receive.
• void SAI_TransferAbortSendEDMA (I2S_Type ∗base, sai_edma_handle_t ∗handle)
Aborts a SAI transfer using eDMA.
• void SAI_TransferAbortReceiveEDMA (I2S_Type ∗base, sai_edma_handle_t ∗handle)
Aborts a SAI receive using eDMA.
• status_t SAI_TransferGetSendCountEDMA (I2S_Type ∗base, sai_edma_handle_t ∗handle, size_t
∗count)
Gets byte count sent by SAI.
• status_t SAI_TransferGetReceiveCountEDMA (I2S_Type ∗base, sai_edma_handle_t ∗handle, size-
_t ∗count)
Gets byte count received by SAI.

23.5.2 Data Structure Documentation

23.5.2.1 struct _sai_edma_handle

Data Fields
• edma_handle_t ∗ dmaHandle
DMA handler for SAI send.
• uint8_t nbytes
eDMA minor byte transfer count initially configured.
• uint8_t bytesPerFrame
Bytes in a frame.
• uint8_t channel
Which data channel.
• uint8_t count
The transfer data count in a DMA request.
• uint32_t state
Internal state for SAI eDMA transfer.
• sai_edma_callback_t callback
Callback for users while transfer finish or error occurs.
• void ∗ userData
User callback parameter.
• uint8_t tcd [(SAI_XFER_QUEUE_SIZE+1U)∗sizeof(edma_tcd_t)]
TCD pool for eDMA transfer.
• sai_transfer_t saiQueue [SAI_XFER_QUEUE_SIZE]
Transfer queue storing queued transfer.
• size_t transferSize [SAI_XFER_QUEUE_SIZE]
Data bytes need to transfer.
• volatile uint8_t queueUser
Index for user to queue transfer.
• volatile uint8_t queueDriver
Index for driver to get the transfer data and size.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 551
SAI EDMA Driver

23.5.2.1.0.21 Field Documentation

23.5.2.1.0.21.1 uint8_t sai_edma_handle_t::nbytes

23.5.2.1.0.21.2 uint8_t sai_edma_handle_t::tcd[(SAI_XFER_QUEUE_SIZE+1U)∗sizeof(edma_-


tcd_t)]

23.5.2.1.0.21.3 sai_transfer_t sai_edma_handle_t::saiQueue[SAI_XFER_QUEUE_SIZE]

23.5.2.1.0.21.4 volatile uint8_t sai_edma_handle_t::queueUser

23.5.3 Function Documentation

23.5.3.1 void SAI_TransferTxCreateHandleEDMA ( I2S_Type ∗ base, sai_edma_handle_t


∗ handle, sai_edma_callback_t callback, void ∗ userData, edma_handle_t ∗
dmaHandle )

This function initializes the SAI master DMA handle, which can be used for other SAI master transactional
APIs. Usually, for a specified SAI instance, call this API once to get the initialized handle.

MCUXpresso SDK API Reference Manual


552 NXP Semiconductors
SAI EDMA Driver

Parameters

base SAI base pointer.


handle SAI eDMA handle pointer.
base SAI peripheral base address.
callback Pointer to user callback function.
userData User parameter passed to the callback function.
dmaHandle eDMA handle pointer, this handle shall be static allocated by users.

23.5.3.2 void SAI_TransferRxCreateHandleEDMA ( I2S_Type ∗ base, sai_edma_handle_t


∗ handle, sai_edma_callback_t callback, void ∗ userData, edma_handle_t ∗
dmaHandle )

This function initializes the SAI slave DMA handle, which can be used for other SAI master transactional
APIs. Usually, for a specified SAI instance, call this API once to get the initialized handle.
Parameters

base SAI base pointer.


handle SAI eDMA handle pointer.
base SAI peripheral base address.
callback Pointer to user callback function.
userData User parameter passed to the callback function.
dmaHandle eDMA handle pointer, this handle shall be static allocated by users.

23.5.3.3 void SAI_TransferTxSetFormatEDMA ( I2S_Type ∗ base, sai_edma_handle_t ∗


handle, sai_transfer_format_t ∗ format, uint32_t mclkSourceClockHz, uint32_t
bclkSourceClockHz )

The audio format can be changed at run-time. This function configures the sample rate and audio data for-
mat to be transferred. This function also sets the eDMA parameter according to formatting requirements.
Parameters

base SAI base pointer.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 553
SAI EDMA Driver

handle SAI eDMA handle pointer.


format Pointer to SAI audio data format structure.
mclkSource- SAI master clock source frequency in Hz.
ClockHz
bclkSource- SAI bit clock source frequency in Hz. If bit clock source is master clock, this value
ClockHz should equals to masterClockHz in format.

Return values

kStatus_Success Audio format set successfully.


kStatus_InvalidArgument The input argument is invalid.

23.5.3.4 void SAI_TransferRxSetFormatEDMA ( I2S_Type ∗ base, sai_edma_handle_t ∗


handle, sai_transfer_format_t ∗ format, uint32_t mclkSourceClockHz, uint32_t
bclkSourceClockHz )

The audio format can be changed at run-time. This function configures the sample rate and audio data for-
mat to be transferred. This function also sets the eDMA parameter according to formatting requirements.
Parameters

base SAI base pointer.


handle SAI eDMA handle pointer.
format Pointer to SAI audio data format structure.
mclkSource- SAI master clock source frequency in Hz.
ClockHz
bclkSource- SAI bit clock source frequency in Hz. If a bit clock source is the master clock, this
ClockHz value should equal to masterClockHz in format.

Return values

kStatus_Success Audio format set successfully.


kStatus_InvalidArgument The input argument is invalid.

23.5.3.5 void SAI_TransferTxSetConfigEDMA ( I2S_Type ∗ base, sai_edma_handle_t ∗


handle, sai_transceiver_t ∗ saiConfig )

MCUXpresso SDK API Reference Manual


554 NXP Semiconductors
SAI EDMA Driver

Parameters

base SAI base pointer.


handle SAI eDMA handle pointer.
saiConfig sai configurations.

23.5.3.6 void SAI_TransferRxSetConfigEDMA ( I2S_Type ∗ base, sai_edma_handle_t ∗


handle, sai_transceiver_t ∗ saiConfig )

Parameters

base SAI base pointer.


handle SAI eDMA handle pointer.
saiConfig sai configurations.

23.5.3.7 status_t SAI_TransferSendEDMA ( I2S_Type ∗ base, sai_edma_handle_t ∗


handle, sai_transfer_t ∗ xfer )

Note
This interface returns immediately after the transfer initiates. Call SAI_GetTransferStatus to poll the
transfer status and check whether the SAI transfer is finished.

Parameters

base SAI base pointer.


handle SAI eDMA handle pointer.
xfer Pointer to the DMA transfer structure.

Return values

kStatus_Success Start a SAI eDMA send successfully.


kStatus_InvalidArgument The input argument is invalid.
kStatus_TxBusy SAI is busy sending data.

23.5.3.8 status_t SAI_TransferReceiveEDMA ( I2S_Type ∗ base, sai_edma_handle_t ∗


handle, sai_transfer_t ∗ xfer )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 555
SAI EDMA Driver

Note
This interface returns immediately after the transfer initiates. Call the SAI_GetReceiveRemaining-
Bytes to poll the transfer status and check whether the SAI transfer is finished.

Parameters

base SAI base pointer


handle SAI eDMA handle pointer.
xfer Pointer to DMA transfer structure.

Return values

kStatus_Success Start a SAI eDMA receive successfully.


kStatus_InvalidArgument The input argument is invalid.
kStatus_RxBusy SAI is busy receiving data.

23.5.3.9 void SAI_TransferTerminateSendEDMA ( I2S_Type ∗ base, sai_edma_handle_t ∗


handle )

This function will clear all transfer slots buffered in the sai queue. If users only want to abort the current
transfer slot, please call SAI_TransferAbortSendEDMA.
Parameters

base SAI base pointer.


handle SAI eDMA handle pointer.

23.5.3.10 void SAI_TransferTerminateReceiveEDMA ( I2S_Type ∗ base,


sai_edma_handle_t ∗ handle )

This function will clear all transfer slots buffered in the sai queue. If users only want to abort the current
transfer slot, please call SAI_TransferAbortReceiveEDMA.
Parameters

base SAI base pointer.

MCUXpresso SDK API Reference Manual


556 NXP Semiconductors
SAI EDMA Driver

handle SAI eDMA handle pointer.

23.5.3.11 void SAI_TransferAbortSendEDMA ( I2S_Type ∗ base, sai_edma_handle_t ∗


handle )

This function only aborts the current transfer slots, the other transfer slots’ information still kept in the
handler. If users want to terminate all transfer slots, just call SAI_TransferTerminateSendEDMA.
Parameters

base SAI base pointer.


handle SAI eDMA handle pointer.

23.5.3.12 void SAI_TransferAbortReceiveEDMA ( I2S_Type ∗ base, sai_edma_handle_t ∗


handle )

This function only aborts the current transfer slots, the other transfer slots’ information still kept in the
handler. If users want to terminate all transfer slots, just call SAI_TransferTerminateReceiveEDMA.
Parameters

base SAI base pointer


handle SAI eDMA handle pointer.

23.5.3.13 status_t SAI_TransferGetSendCountEDMA ( I2S_Type ∗ base,


sai_edma_handle_t ∗ handle, size_t ∗ count )

Parameters

base SAI base pointer.


handle SAI eDMA handle pointer.
count Bytes count sent by SAI.

Return values

kStatus_Success Succeed get the transfer count.


kStatus_NoTransferIn- There is no non-blocking transaction in progress.
Progress

MCUXpresso SDK API Reference Manual


NXP Semiconductors 557
SAI EDMA Driver

23.5.3.14 status_t SAI_TransferGetReceiveCountEDMA ( I2S_Type ∗ base,


sai_edma_handle_t ∗ handle, size_t ∗ count )

MCUXpresso SDK API Reference Manual


558 NXP Semiconductors
SAI EDMA Driver

Parameters

base SAI base pointer


handle SAI eDMA handle pointer.
count Bytes count received by SAI.

Return values

kStatus_Success Succeed get the transfer count.


kStatus_NoTransferIn- There is no non-blocking transaction in progress.
Progress

MCUXpresso SDK API Reference Manual


NXP Semiconductors 559
SAI SDMA Driver

23.6 SAI SDMA Driver


23.6.1 Overview

Data Structures

• struct sai_sdma_handle_t
SAI DMA transfer handle, users should not touch the content of the handle. More...

Typedefs

• typedef void(∗ sai_sdma_callback_t )(I2S_Type ∗base, sai_sdma_handle_t ∗handle, status_t status,


void ∗userData)
SAI SDMA transfer callback function for finish and error.

Driver version

• #define FSL_SAI_SDMA_DRIVER_VERSION (MAKE_VERSION(2, 2, 0))


Version 2.2.0.

SDMA Transactional

• void SAI_TransferTxCreateHandleSDMA (I2S_Type ∗base, sai_sdma_handle_t ∗handle, sai_-


sdma_callback_t callback, void ∗userData, sdma_handle_t ∗dmaHandle, uint32_t eventSource)
Initializes the SAI SDMA handle.
• void SAI_TransferRxCreateHandleSDMA (I2S_Type ∗base, sai_sdma_handle_t ∗handle, sai_-
sdma_callback_t callback, void ∗userData, sdma_handle_t ∗dmaHandle, uint32_t eventSource)
Initializes the SAI Rx SDMA handle.
• void SAI_TransferTxSetFormatSDMA (I2S_Type ∗base, sai_sdma_handle_t ∗handle, sai_transfer-
_format_t ∗format, uint32_t mclkSourceClockHz, uint32_t bclkSourceClockHz)
Configures the SAI Tx audio format.
• void SAI_TransferRxSetFormatSDMA (I2S_Type ∗base, sai_sdma_handle_t ∗handle, sai_transfer-
_format_t ∗format, uint32_t mclkSourceClockHz, uint32_t bclkSourceClockHz)
Configures the SAI Rx audio format.
• status_t SAI_TransferSendSDMA (I2S_Type ∗base, sai_sdma_handle_t ∗handle, sai_transfer_-
t ∗xfer)
Performs a non-blocking SAI transfer using DMA.
• status_t SAI_TransferReceiveSDMA (I2S_Type ∗base, sai_sdma_handle_t ∗handle, sai_transfer_t
∗xfer)
Performs a non-blocking SAI receive using SDMA.
• void SAI_TransferAbortSendSDMA (I2S_Type ∗base, sai_sdma_handle_t ∗handle)
Aborts a SAI transfer using SDMA.
• void SAI_TransferAbortReceiveSDMA (I2S_Type ∗base, sai_sdma_handle_t ∗handle)
Aborts a SAI receive using SDMA.

MCUXpresso SDK API Reference Manual


560 NXP Semiconductors
SAI SDMA Driver

• void SAI_TransferRxSetConfigSDMA (I2S_Type ∗base, sai_sdma_handle_t ∗handle, sai_-


transceiver_t ∗saiConfig)
brief Configures the SAI RX.
• void SAI_TransferTxSetConfigSDMA (I2S_Type ∗base, sai_sdma_handle_t ∗handle, sai_-
transceiver_t ∗saiConfig)
brief Configures the SAI Tx.

23.6.2 Data Structure Documentation

23.6.2.1 struct _sai_sdma_handle

Data Fields
• sdma_handle_t ∗ dmaHandle
DMA handler for SAI send.
• uint8_t bytesPerFrame
Bytes in a frame.
• uint8_t channel
start data channel
• uint8_t channelNums
total transfer channel numbers, used for multififo
• uint8_t channelMask
enabled channel mask value, refernece _sai_channel_mask
• uint8_t fifoOffset
fifo address offset between multifo
• uint8_t count
The transfer data count in a DMA request.
• uint32_t state
Internal state for SAI SDMA transfer.
• uint32_t eventSource
SAI event source number.
• sai_sdma_callback_t callback
Callback for users while transfer finish or error occurs.
• void ∗ userData
User callback parameter.
• sdma_buffer_descriptor_t bdPool [SAI_XFER_QUEUE_SIZE]
BD pool for SDMA transfer.
• sai_transfer_t saiQueue [SAI_XFER_QUEUE_SIZE]
Transfer queue storing queued transfer.
• size_t transferSize [SAI_XFER_QUEUE_SIZE]
Data bytes need to transfer.
• volatile uint8_t queueUser
Index for user to queue transfer.
• volatile uint8_t queueDriver
Index for driver to get the transfer data and size.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 561
SAI SDMA Driver

23.6.2.1.0.22 Field Documentation

23.6.2.1.0.22.1 sdma_buffer_descriptor_t sai_sdma_handle_t::bdPool[SAI_XFER_QUEUE_SIZ-


E]

23.6.2.1.0.22.2 sai_transfer_t sai_sdma_handle_t::saiQueue[SAI_XFER_QUEUE_SIZE]

23.6.2.1.0.22.3 volatile uint8_t sai_sdma_handle_t::queueUser

23.6.3 Function Documentation

23.6.3.1 void SAI_TransferTxCreateHandleSDMA ( I2S_Type ∗ base, sai_sdma_handle_t


∗ handle, sai_sdma_callback_t callback, void ∗ userData, sdma_handle_t ∗
dmaHandle, uint32_t eventSource )

This function initializes the SAI master DMA handle, which can be used for other SAI master transactional
APIs. Usually, for a specified SAI instance, call this API once to get the initialized handle.

MCUXpresso SDK API Reference Manual


562 NXP Semiconductors
SAI SDMA Driver

Parameters

base SAI base pointer.


handle SAI SDMA handle pointer.
base SAI peripheral base address.
callback Pointer to user callback function.
userData User parameter passed to the callback function.
dmaHandle SDMA handle pointer, this handle shall be static allocated by users.

23.6.3.2 void SAI_TransferRxCreateHandleSDMA ( I2S_Type ∗ base, sai_sdma_handle_t


∗ handle, sai_sdma_callback_t callback, void ∗ userData, sdma_handle_t ∗
dmaHandle, uint32_t eventSource )

This function initializes the SAI slave DMA handle, which can be used for other SAI master transactional
APIs. Usually, for a specified SAI instance, call this API once to get the initialized handle.
Parameters

base SAI base pointer.


handle SAI SDMA handle pointer.
base SAI peripheral base address.
callback Pointer to user callback function.
userData User parameter passed to the callback function.
dmaHandle SDMA handle pointer, this handle shall be static allocated by users.

23.6.3.3 void SAI_TransferTxSetFormatSDMA ( I2S_Type ∗ base, sai_sdma_handle_t ∗


handle, sai_transfer_format_t ∗ format, uint32_t mclkSourceClockHz, uint32_t
bclkSourceClockHz )

The audio format can be changed at run-time. This function configures the sample rate and audio data for-
mat to be transferred. This function also sets the SDMA parameter according to formatting requirements.
Parameters

base SAI base pointer.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 563
SAI SDMA Driver

handle SAI SDMA handle pointer.


format Pointer to SAI audio data format structure.
mclkSource- SAI master clock source frequency in Hz.
ClockHz
bclkSource- SAI bit clock source frequency in Hz. If bit clock source is master clock, this value
ClockHz should equals to masterClockHz in format.

Return values

kStatus_Success Audio format set successfully.


kStatus_InvalidArgument The input argument is invalid.

23.6.3.4 void SAI_TransferRxSetFormatSDMA ( I2S_Type ∗ base, sai_sdma_handle_t ∗


handle, sai_transfer_format_t ∗ format, uint32_t mclkSourceClockHz, uint32_t
bclkSourceClockHz )

The audio format can be changed at run-time. This function configures the sample rate and audio data for-
mat to be transferred. This function also sets the SDMA parameter according to formatting requirements.
Parameters

base SAI base pointer.


handle SAI SDMA handle pointer.
format Pointer to SAI audio data format structure.
mclkSource- SAI master clock source frequency in Hz.
ClockHz
bclkSource- SAI bit clock source frequency in Hz. If a bit clock source is the master clock, this
ClockHz value should equal to masterClockHz in format.

Return values

kStatus_Success Audio format set successfully.


kStatus_InvalidArgument The input argument is invalid.

23.6.3.5 status_t SAI_TransferSendSDMA ( I2S_Type ∗ base, sai_sdma_handle_t ∗


handle, sai_transfer_t ∗ xfer )

MCUXpresso SDK API Reference Manual


564 NXP Semiconductors
SAI SDMA Driver

Note
This interface returns immediately after the transfer initiates. Call SAI_GetTransferStatus to poll the
transfer status and check whether the SAI transfer is finished.

Parameters

base SAI base pointer.


handle SAI SDMA handle pointer.
xfer Pointer to the DMA transfer structure.

Return values

kStatus_Success Start a SAI SDMA send successfully.


kStatus_InvalidArgument The input argument is invalid.
kStatus_TxBusy SAI is busy sending data.

23.6.3.6 status_t SAI_TransferReceiveSDMA ( I2S_Type ∗ base, sai_sdma_handle_t ∗


handle, sai_transfer_t ∗ xfer )

Note
This interface returns immediately after the transfer initiates. Call the SAI_GetReceiveRemaining-
Bytes to poll the transfer status and check whether the SAI transfer is finished.

Parameters

base SAI base pointer


handle SAI SDMA handle pointer.
xfer Pointer to DMA transfer structure.

Return values

kStatus_Success Start a SAI SDMA receive successfully.


kStatus_InvalidArgument The input argument is invalid.
kStatus_RxBusy SAI is busy receiving data.

23.6.3.7 void SAI_TransferAbortSendSDMA ( I2S_Type ∗ base, sai_sdma_handle_t ∗


handle )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 565
SAI SDMA Driver

Parameters

base SAI base pointer.


handle SAI SDMA handle pointer.

23.6.3.8 void SAI_TransferAbortReceiveSDMA ( I2S_Type ∗ base, sai_sdma_handle_t ∗


handle )

Parameters

base SAI base pointer


handle SAI SDMA handle pointer.

23.6.3.9 void SAI_TransferRxSetConfigSDMA ( I2S_Type ∗ base, sai_sdma_handle_t ∗


handle, sai_transceiver_t ∗ saiConfig )

param base SAI base pointer. param handle SAI SDMA handle pointer. param saiConig sai configurations.

23.6.3.10 void SAI_TransferTxSetConfigSDMA ( I2S_Type ∗ base, sai_sdma_handle_t ∗


handle, sai_transceiver_t ∗ saiConfig )

param base SAI base pointer. param handle SAI SDMA handle pointer. param saiConig sai configurations.

MCUXpresso SDK API Reference Manual


566 NXP Semiconductors
Chapter 24
SIM: System Integration Module Driver
24.1 Overview
The MCUXpresso SDK provides a peripheral driver for the System Integration Module (SIM) of MCU-
Xpresso SDK devices.

Data Structures
• struct sim_uid_t
Unique ID. More...

Enumerations
• enum _sim_usb_volt_reg_enable_mode {
kSIM_UsbVoltRegEnable = (int)SIM_SOPT1_USBREGEN_MASK,
kSIM_UsbVoltRegEnableInLowPower = SIM_SOPT1_USBVSTBY_MASK,
kSIM_UsbVoltRegEnableInStop = SIM_SOPT1_USBSSTBY_MASK,
kSIM_UsbVoltRegEnableInAllModes }
USB voltage regulator enable setting.
• enum _sim_flash_mode {
kSIM_FlashDisableInWait = SIM_FCFG1_FLASHDOZE_MASK,
kSIM_FlashDisable = SIM_FCFG1_FLASHDIS_MASK }
Flash enable mode.

Functions
• void SIM_SetUsbVoltRegulatorEnableMode (uint32_t mask)
Sets the USB voltage regulator setting.
• void SIM_GetUniqueId (sim_uid_t ∗uid)
Gets the unique identification register value.
• static void SIM_SetFlashMode (uint8_t mode)
Sets the flash enable mode.

Driver version
• #define FSL_SIM_DRIVER_VERSION (MAKE_VERSION(2, 1, 0))
Driver version 2.0.0.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 567
Function Documentation

24.2 Data Structure Documentation


24.2.1 struct sim_uid_t

Data Fields

• uint32_t MH
UIDMH.
• uint32_t ML
UIDML.
• uint32_t L
UIDL.

24.2.1.0.0.23 Field Documentation

24.2.1.0.0.23.1 uint32_t sim_uid_t::MH

24.2.1.0.0.23.2 uint32_t sim_uid_t::ML

24.2.1.0.0.23.3 uint32_t sim_uid_t::L

24.3 Enumeration Type Documentation


24.3.1 enum _sim_usb_volt_reg_enable_mode

Enumerator
kSIM_UsbVoltRegEnable Enable voltage regulator.
kSIM_UsbVoltRegEnableInLowPower Enable voltage regulator in VLPR/VLPW modes.
kSIM_UsbVoltRegEnableInStop Enable voltage regulator in STOP/VLPS/LLS/VLLS modes.
kSIM_UsbVoltRegEnableInAllModes Enable voltage regulator in all power modes.

24.3.2 enum _sim_flash_mode

Enumerator
kSIM_FlashDisableInWait Disable flash in wait mode.
kSIM_FlashDisable Disable flash in normal mode.

24.4 Function Documentation


24.4.1 void SIM_SetUsbVoltRegulatorEnableMode ( uint32_t mask )

This function configures whether the USB voltage regulator is enabled in normal RUN mode, STOP/-
VLPS/LLS/VLLS modes, and VLPR/VLPW modes. The configurations are passed in as mask value of
_sim_usb_volt_reg_enable_mode. For example, to enable USB voltage regulator in RUN/VLPR/VLPW
modes and disable in STOP/VLPS/LLS/VLLS mode, use:

MCUXpresso SDK API Reference Manual


568 NXP Semiconductors
Function Documentation

SIM_SetUsbVoltRegulatorEnableMode(kSIM_UsbVoltRegEnable | kSIM_UsbVoltRegEnableInLow-
Power);

MCUXpresso SDK API Reference Manual


NXP Semiconductors 569
Function Documentation

Parameters

mask USB voltage regulator enable setting.

24.4.2 void SIM_GetUniqueId ( sim_uid_t ∗ uid )

Parameters

uid Pointer to the structure to save the UID value.

24.4.3 static void SIM_SetFlashMode ( uint8_t mode ) [inline], [static]

Parameters

mode The mode to set; see _sim_flash_mode for mode details.

MCUXpresso SDK API Reference Manual


570 NXP Semiconductors
Chapter 25
SLCD: Segment LCD Driver
25.1 Overview
The MCUXpresso SDK provides a peripheral driver for the Segment LCD (SLCD) module of MCU-
Xpresso SDK devices. The SLCD module is a CMOS charge pump voltage inverter that is designed for
low voltage and low-power operation. SLCD is designed to generate the appropriate waveforms to drive
multiplexed numeric, alphanumeric, or custom segment LCD panels. SLCD also has several timing and
control settings that can be software-configured depending on the application’s requirements. Timing and
control consists of registers and control logic for the following:
1. LCD frame frequency
2. Duty cycle selection
3. Front plane/back plane selection and enabling
4. Blink modes and frequency
5. Operation in low-power modes
After the SLCD general initialization, the SLCD_SetBackPlanePhase(), SLCD_SetFrontPlaneSegments(),
and SLCD_SetFrontPlaneOnePhase() are used to set the special back/front Plane to make SLCD display
correctly. Then, the independent display control APIs, SLCD_StartDisplay() and SLCD_StopDisplay(),
start and stop the SLCD display.
The SLCD_StartBlinkMode() and SLCD_StopBlinkMode() are provided for the runtime special blink
mode control. To get the SLCD fault detection result, call the SLCD_GetFaultDetectCounter().

25.2 Typical use case


25.2.1 SLCD Initialization operation

Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/slcd

Data Structures
• struct slcd_fault_detect_config_t
SLCD fault frame detection configuration structure. More...
• struct slcd_clock_config_t
SLCD clock configuration structure. More...
• struct slcd_config_t
SLCD configuration structure. More...

MCUXpresso SDK API Reference Manual


NXP Semiconductors 571
Typical use case

Enumerations
• enum slcd_power_supply_option_t {
kSLCD_InternalVll3UseChargePump,
kSLCD_ExternalVll3UseResistorBiasNetwork,
kSLCD_ExteranlVll3UseChargePump,
kSLCD_InternalVll1UseChargePump }
SLCD power supply option.
• enum slcd_regulated_voltage_trim_t {
kSLCD_RegulatedVolatgeTrim00 = 0U,
kSLCD_RegulatedVolatgeTrim01,
kSLCD_RegulatedVolatgeTrim02,
kSLCD_RegulatedVolatgeTrim03,
kSLCD_RegulatedVolatgeTrim04,
kSLCD_RegulatedVolatgeTrim05,
kSLCD_RegulatedVolatgeTrim06,
kSLCD_RegulatedVolatgeTrim07,
kSLCD_RegulatedVolatgeTrim08,
kSLCD_RegulatedVolatgeTrim09,
kSLCD_RegulatedVolatgeTrim10,
kSLCD_RegulatedVolatgeTrim11,
kSLCD_RegulatedVolatgeTrim12,
kSLCD_RegulatedVolatgeTrim13,
kSLCD_RegulatedVolatgeTrim14,
kSLCD_RegulatedVolatgeTrim15 }
SLCD regulated voltage trim parameter, be used to meet the desired contrast.
• enum slcd_load_adjust_t {
kSLCD_LowLoadOrFastestClkSrc = 0U,
kSLCD_LowLoadOrIntermediateClkSrc,
kSLCD_HighLoadOrIntermediateClkSrc,
kSLCD_HighLoadOrSlowestClkSrc }
SLCD load adjust to handle different LCD glass capacitance or configure the LCD charge pump clock
source.
• enum slcd_clock_src_t {
kSLCD_DefaultClk = 0U,
kSLCD_AlternateClk1 = 1U,
kSLCD_AlternateClk2 = 3U }
SLCD clock source.
• enum slcd_alt_clock_div_t {
kSLCD_AltClkDivFactor1 = 0U,
kSLCD_AltClkDivFactor64,
kSLCD_AltClkDivFactor256,
kSLCD_AltClkDivFactor512 }
SLCD alternate clock divider.
• enum slcd_clock_prescaler_t {

MCUXpresso SDK API Reference Manual


572 NXP Semiconductors
Typical use case

kSLCD_ClkPrescaler00 = 0U,
kSLCD_ClkPrescaler01,
kSLCD_ClkPrescaler02,
kSLCD_ClkPrescaler03,
kSLCD_ClkPrescaler04,
kSLCD_ClkPrescaler05,
kSLCD_ClkPrescaler06,
kSLCD_ClkPrescaler07 }
SLCD clock prescaler to generate frame frequency.
• enum slcd_duty_cycle_t {
kSLCD_1Div1DutyCycle = 0U,
kSLCD_1Div2DutyCycle,
kSLCD_1Div3DutyCycle,
kSLCD_1Div4DutyCycle,
kSLCD_1Div5DutyCycle,
kSLCD_1Div6DutyCycle,
kSLCD_1Div7DutyCycle,
kSLCD_1Div8DutyCycle }
SLCD duty cycle.
• enum slcd_phase_type_t {
kSLCD_NoPhaseActivate = 0x00U,
kSLCD_PhaseAActivate = 0x01U,
kSLCD_PhaseBActivate = 0x02U,
kSLCD_PhaseCActivate = 0x04U,
kSLCD_PhaseDActivate = 0x08U,
kSLCD_PhaseEActivate = 0x10U,
kSLCD_PhaseFActivate = 0x20U,
kSLCD_PhaseGActivate = 0x40U,
kSLCD_PhaseHActivate = 0x80U }
SLCD segment phase type.
• enum slcd_phase_index_t {
kSLCD_PhaseAIndex = 0x0U,
kSLCD_PhaseBIndex = 0x1U,
kSLCD_PhaseCIndex = 0x2U,
kSLCD_PhaseDIndex = 0x3U,
kSLCD_PhaseEIndex = 0x4U,
kSLCD_PhaseFIndex = 0x5U,
kSLCD_PhaseGIndex = 0x6U,
kSLCD_PhaseHIndex = 0x7U }
SLCD segment phase bit index.
• enum slcd_display_mode_t {
kSLCD_NormalMode = 0U,
kSLCD_AlternateMode,
kSLCD_BlankMode }
SLCD display mode.
• enum slcd_blink_mode_t {

MCUXpresso SDK API Reference Manual


NXP Semiconductors 573
Typical use case

kSLCD_BlankDisplayBlink = 0U,
kSLCD_AltDisplayBlink }
SLCD blink mode.
• enum slcd_blink_rate_t {
kSLCD_BlinkRate00 = 0U,
kSLCD_BlinkRate01,
kSLCD_BlinkRate02,
kSLCD_BlinkRate03,
kSLCD_BlinkRate04,
kSLCD_BlinkRate05,
kSLCD_BlinkRate06,
kSLCD_BlinkRate07 }
SLCD blink rate.
• enum slcd_fault_detect_clock_prescaler_t {
kSLCD_FaultSampleFreqDivider1 = 0U,
kSLCD_FaultSampleFreqDivider2,
kSLCD_FaultSampleFreqDivider4,
kSLCD_FaultSampleFreqDivider8,
kSLCD_FaultSampleFreqDivider16,
kSLCD_FaultSampleFreqDivider32,
kSLCD_FaultSampleFreqDivider64,
kSLCD_FaultSampleFreqDivider128 }
SLCD fault detect clock prescaler.
• enum slcd_fault_detect_sample_window_width_t {
kSLCD_FaultDetectWindowWidth4SampleClk = 0U,
kSLCD_FaultDetectWindowWidth8SampleClk,
kSLCD_FaultDetectWindowWidth16SampleClk,
kSLCD_FaultDetectWindowWidth32SampleClk,
kSLCD_FaultDetectWindowWidth64SampleClk,
kSLCD_FaultDetectWindowWidth128SampleClk,
kSLCD_FaultDetectWindowWidth256SampleClk,
kSLCD_FaultDetectWindowWidth512SampleClk }
SLCD fault detect sample window width.
• enum slcd_interrupt_enable_t { kSLCD_FaultDetectCompleteInterrupt = 1U }
SLCD interrupt source.
• enum slcd_lowpower_behavior {
kSLCD_EnabledInWaitStop = 0,
kSLCD_EnabledInWaitOnly,
kSLCD_EnabledInStopOnly,
kSLCD_DisabledInWaitStop }
SLCD behavior in low power mode.

Driver version
• #define FSL_SLCD_DRIVER_VERSION (MAKE_VERSION(2, 0, 1))
SLCD driver version 2.0.1.

MCUXpresso SDK API Reference Manual


574 NXP Semiconductors
Data Structure Documentation

Initialization and deinitialization


• void SLCD_Init (LCD_Type ∗base, slcd_config_t ∗configure)
Initializes the SLCD, ungates the module clock, initializes the power setting, enables all used plane pins,
and sets with interrupt and work mode with the configuration.
• void SLCD_Deinit (LCD_Type ∗base)
Deinitializes the SLCD module, gates the module clock, disables an interrupt, and displays the SLCD.
• void SLCD_GetDefaultConfig (slcd_config_t ∗configure)
Gets the SLCD default configuration structure.

Plane Setting and Display Control


• static void SLCD_StartDisplay (LCD_Type ∗base)
Enables the SLCD controller, starts generation, and displays the front plane and back plane waveform.
• static void SLCD_StopDisplay (LCD_Type ∗base)
Stops the SLCD controller.
• void SLCD_StartBlinkMode (LCD_Type ∗base, slcd_blink_mode_t mode, slcd_blink_rate_t rate)
Starts the SLCD blink mode.
• static void SLCD_StopBlinkMode (LCD_Type ∗base)
Stops the SLCD blink mode.
• static void SLCD_SetBackPlanePhase (LCD_Type ∗base, uint32_t pinIndx, slcd_phase_type_-
t phase)
Sets the SLCD back plane pin phase.
• static void SLCD_SetFrontPlaneSegments (LCD_Type ∗base, uint32_t pinIndx, uint8_t operation)
Sets the SLCD front plane segment operation for a front plane pin.
• static void SLCD_SetFrontPlaneOnePhase (LCD_Type ∗base, uint32_t pinIndx, slcd_phase_index-
_t phaseIndx, bool enable)
Sets one SLCD front plane pin for one phase.
• static void SLCD_EnablePadSafeState (LCD_Type ∗base, bool enable)
Enables/disables the SLCD pad safe state.
• static uint32_t SLCD_GetFaultDetectCounter (LCD_Type ∗base)
Gets the SLCD fault detect counter.

Interrupts.
• void SLCD_EnableInterrupts (LCD_Type ∗base, uint32_t mask)
Enables the SLCD interrupt.
• void SLCD_DisableInterrupts (LCD_Type ∗base, uint32_t mask)
Disables the SLCD interrupt.
• uint32_t SLCD_GetInterruptStatus (LCD_Type ∗base)
Gets the SLCD interrupt status flag.
• void SLCD_ClearInterruptStatus (LCD_Type ∗base, uint32_t mask)
Clears the SLCD interrupt events status flag.

25.3 Data Structure Documentation


25.3.1 struct slcd_fault_detect_config_t

Data Fields

• bool faultDetectIntEnable

MCUXpresso SDK API Reference Manual


NXP Semiconductors 575
Data Structure Documentation

Fault frame detection interrupt enable flag.


• bool faultDetectBackPlaneEnable
True means the pin id fault detected is back plane otherwise front plane.
• uint8_t faultDetectPinIndex
Fault detected pin id from 0 to 63.
• slcd_fault_detect_clock_prescaler_t faultPrescaler
Fault detect clock prescaler.
• slcd_fault_detect_sample_window_width_t width
Fault detect sample window width.

25.3.1.0.0.24 Field Documentation

25.3.1.0.0.24.1 bool slcd_fault_detect_config_t::faultDetectIntEnable

25.3.1.0.0.24.2 bool slcd_fault_detect_config_t::faultDetectBackPlaneEnable

25.3.1.0.0.24.3 uint8_t slcd_fault_detect_config_t::faultDetectPinIndex

25.3.1.0.0.24.4 slcd_fault_detect_clock_prescaler_t slcd_fault_detect_config_t::faultPrescaler

25.3.1.0.0.24.5 slcd_fault_detect_sample_window_width_t slcd_fault_detect_config_t::width

25.3.2 struct slcd_clock_config_t

Data Fields

• slcd_clock_src_t clkSource
Clock source.
• slcd_alt_clock_div_t altClkDivider
The divider to divide the alternate clock used for alternate clock source.
• slcd_clock_prescaler_t clkPrescaler
Clock prescaler.
• bool fastFrameRateEnable
Fast frame rate enable flag.

25.3.2.0.0.25 Field Documentation

25.3.2.0.0.25.1 slcd_clock_src_t slcd_clock_config_t::clkSource

"slcd_clock_src_t" is recommended to be used. The SLCD is optimized to operate using a 32.768kHz


clock input.

MCUXpresso SDK API Reference Manual


576 NXP Semiconductors
Data Structure Documentation

25.3.2.0.0.25.2 slcd_alt_clock_div_t slcd_clock_config_t::altClkDivider

25.3.2.0.0.25.3 slcd_clock_prescaler_t slcd_clock_config_t::clkPrescaler

25.3.2.0.0.25.4 bool slcd_clock_config_t::fastFrameRateEnable

25.3.3 struct slcd_config_t

Data Fields

• slcd_power_supply_option_t powerSupply
Power supply option.
• slcd_regulated_voltage_trim_t voltageTrim
Regulated voltage trim used for the internal regulator VIREG to adjust to facilitate contrast control.
• slcd_clock_config_t ∗ clkConfig
Clock configure.
• slcd_display_mode_t displayMode
SLCD display mode.
• slcd_load_adjust_t loadAdjust
Load adjust to handle glass capacitance.
• slcd_duty_cycle_t dutyCycle
Duty cycle.
• slcd_lowpower_behavior lowPowerBehavior
SLCD behavior in low power mode.
• uint32_t slcdLowPinEnabled
Setting enabled SLCD pin 0 ∼ pin 31.
• uint32_t slcdHighPinEnabled
Setting enabled SLCD pin 32 ∼ pin 63.
• uint32_t backPlaneLowPin
Setting back plane pin 0 ∼ pin 31.
• uint32_t backPlaneHighPin
Setting back plane pin 32 ∼ pin 63.
• slcd_fault_detect_config_t ∗ faultConfig
Fault frame detection configure.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 577
Enumeration Type Documentation

25.3.3.0.0.26 Field Documentation

25.3.3.0.0.26.1 slcd_power_supply_option_t slcd_config_t::powerSupply

25.3.3.0.0.26.2 slcd_regulated_voltage_trim_t slcd_config_t::voltageTrim

25.3.3.0.0.26.3 slcd_clock_config_t∗ slcd_config_t::clkConfig

25.3.3.0.0.26.4 slcd_display_mode_t slcd_config_t::displayMode

25.3.3.0.0.26.5 slcd_load_adjust_t slcd_config_t::loadAdjust

25.3.3.0.0.26.6 slcd_duty_cycle_t slcd_config_t::dutyCycle

25.3.3.0.0.26.7 slcd_lowpower_behavior slcd_config_t::lowPowerBehavior

25.3.3.0.0.26.8 uint32_t slcd_config_t::slcdLowPinEnabled

Setting bit n to 1 means enable pin n.

25.3.3.0.0.26.9 uint32_t slcd_config_t::slcdHighPinEnabled

Setting bit n to 1 means enable pin (n + 32).

25.3.3.0.0.26.10 uint32_t slcd_config_t::backPlaneLowPin

Setting bit n to 1 means setting pin n as back plane. It should never have the same bit setting as the
frontPlane Pin.

25.3.3.0.0.26.11 uint32_t slcd_config_t::backPlaneHighPin

Setting bit n to 1 means setting pin (n + 32) as back plane. It should never have the same bit setting as the
frontPlane Pin.

25.3.3.0.0.26.12 slcd_fault_detect_config_t∗ slcd_config_t::faultConfig

If not requirement, set to NULL.

25.4 Macro Definition Documentation


25.4.1 #define FSL_SLCD_DRIVER_VERSION (MAKE_VERSION(2, 0, 1))

25.5 Enumeration Type Documentation


25.5.1 enum slcd_power_supply_option_t

Enumerator
kSLCD_InternalVll3UseChargePump VLL3 connected to VDD internally, charge pump is used to
generate VLL1 and VLL2.

MCUXpresso SDK API Reference Manual


578 NXP Semiconductors
Enumeration Type Documentation

kSLCD_ExternalVll3UseResistorBiasNetwork VLL3 is driven externally and resistor bias network


is used to generate VLL1 and VLL2.
kSLCD_ExteranlVll3UseChargePump VLL3 is driven externally and charge pump is used to gen-
erate VLL1 and VLL2.
kSLCD_InternalVll1UseChargePump VIREG is connected to VLL1 internally and charge pump is
used to generate VLL2 and VLL3.

25.5.2 enum slcd_regulated_voltage_trim_t

Enumerator
kSLCD_RegulatedVolatgeTrim00 Increase the voltage to 0.91 V.
kSLCD_RegulatedVolatgeTrim01 Increase the voltage to 1.01 V.
kSLCD_RegulatedVolatgeTrim02 Increase the voltage to 0.96 V.
kSLCD_RegulatedVolatgeTrim03 Increase the voltage to 1.06 V.
kSLCD_RegulatedVolatgeTrim04 Increase the voltage to 0.93 V.
kSLCD_RegulatedVolatgeTrim05 Increase the voltage to 1.02 V.
kSLCD_RegulatedVolatgeTrim06 Increase the voltage to 0.98 V.
kSLCD_RegulatedVolatgeTrim07 Increase the voltage to 1.08 V.
kSLCD_RegulatedVolatgeTrim08 Increase the voltage to 0.92 V.
kSLCD_RegulatedVolatgeTrim09 Increase the voltage to 1.02 V.
kSLCD_RegulatedVolatgeTrim10 Increase the voltage to 0.97 V.
kSLCD_RegulatedVolatgeTrim11 Increase the voltage to 1.07 V.
kSLCD_RegulatedVolatgeTrim12 Increase the voltage to 0.94 V.
kSLCD_RegulatedVolatgeTrim13 Increase the voltage to 1.05 V.
kSLCD_RegulatedVolatgeTrim14 Increase the voltage to 0.99 V.
kSLCD_RegulatedVolatgeTrim15 Increase the voltage to 1.09 V.

25.5.3 enum slcd_load_adjust_t

Adjust the LCD glass capacitance if resistor bias network is enabled: kSLCD_LowLoadOrFastestClkSrc
- Low load (LCD glass capacitance 2000pF or lower. LCD or GPIO function can be used on VLL1,V-
LL2,Vcap1 and Vcap2 pins) kSLCD_LowLoadOrIntermediateClkSrc - low load (LCD glass capacitance
2000pF or lower. LCD or GPIO function can be used on VLL1,VLL2,Vcap1 and Vcap2 pins) kSLCD-
_HighLoadOrIntermediateClkSrc - high load (LCD glass capacitance 8000pF or lower. LCD or GPIO
function can be used on Vcap1 and Vcap2 pins) kSLCD_HighLoadOrSlowestClkSrc - high load (LC-
D glass capacitance 8000pF or lower LCD or GPIO function can be used on Vcap1 and Vcap2 pins)
Adjust clock for charge pump if charge pump is enabled: kSLCD_LowLoadOrFastestClkSrc - Fasten
clock source (LCD glass capacitance 8000pF or 4000pF or lower if Fast Frame Rate is set) kSLCD_-
LowLoadOrIntermediateClkSrc - Intermediate clock source (LCD glass capacitance 4000pF or 2000pF
or lower if Fast Frame Rate is set) kSLCD_HighLoadOrIntermediateClkSrc - Intermediate clock source

MCUXpresso SDK API Reference Manual


NXP Semiconductors 579
Enumeration Type Documentation

(LCD glass capacitance 2000pF or 1000pF or lower if Fast Frame Rate is set) kSLCD_HighLoadOr-
SlowestClkSrc - slowest clock source (LCD glass capacitance 1000pF or 500pF or lower if Fast Frame
Rate is set)

Enumerator
kSLCD_LowLoadOrFastestClkSrc Adjust in low load or selects fastest clock.
kSLCD_LowLoadOrIntermediateClkSrc Adjust in low load or selects intermediate clock.
kSLCD_HighLoadOrIntermediateClkSrc Adjust in high load or selects intermediate clock.
kSLCD_HighLoadOrSlowestClkSrc Adjust in high load or selects slowest clock.

25.5.4 enum slcd_clock_src_t

Enumerator
kSLCD_DefaultClk Select default clock ERCLK32K.
kSLCD_AlternateClk1 Select alternate clock source 1 : MCGIRCLK.
kSLCD_AlternateClk2 Select alternate clock source 2 : OSCERCLK.

25.5.5 enum slcd_alt_clock_div_t

Enumerator
kSLCD_AltClkDivFactor1 No divide for alternate clock.
kSLCD_AltClkDivFactor64 Divide alternate clock with factor 64.
kSLCD_AltClkDivFactor256 Divide alternate clock with factor 256.
kSLCD_AltClkDivFactor512 Divide alternate clock with factor 512.

25.5.6 enum slcd_clock_prescaler_t

Enumerator
kSLCD_ClkPrescaler00 Prescaler 0.
kSLCD_ClkPrescaler01 Prescaler 1.
kSLCD_ClkPrescaler02 Prescaler 2.
kSLCD_ClkPrescaler03 Prescaler 3.
kSLCD_ClkPrescaler04 Prescaler 4.
kSLCD_ClkPrescaler05 Prescaler 5.
kSLCD_ClkPrescaler06 Prescaler 6.
kSLCD_ClkPrescaler07 Prescaler 7.

MCUXpresso SDK API Reference Manual


580 NXP Semiconductors
Enumeration Type Documentation

25.5.7 enum slcd_duty_cycle_t

Enumerator
kSLCD_1Div1DutyCycle LCD use 1 BP 1/1 duty cycle.
kSLCD_1Div2DutyCycle LCD use 2 BP 1/2 duty cycle.
kSLCD_1Div3DutyCycle LCD use 3 BP 1/3 duty cycle.
kSLCD_1Div4DutyCycle LCD use 4 BP 1/4 duty cycle.
kSLCD_1Div5DutyCycle LCD use 5 BP 1/5 duty cycle.
kSLCD_1Div6DutyCycle LCD use 6 BP 1/6 duty cycle.
kSLCD_1Div7DutyCycle LCD use 7 BP 1/7 duty cycle.
kSLCD_1Div8DutyCycle LCD use 8 BP 1/8 duty cycle.

25.5.8 enum slcd_phase_type_t

Enumerator
kSLCD_NoPhaseActivate LCD wareform no phase activates.
kSLCD_PhaseAActivate LCD waveform phase A activates.
kSLCD_PhaseBActivate LCD waveform phase B activates.
kSLCD_PhaseCActivate LCD waveform phase C activates.
kSLCD_PhaseDActivate LCD waveform phase D activates.
kSLCD_PhaseEActivate LCD waveform phase E activates.
kSLCD_PhaseFActivate LCD waveform phase F activates.
kSLCD_PhaseGActivate LCD waveform phase G activates.
kSLCD_PhaseHActivate LCD waveform phase H activates.

25.5.9 enum slcd_phase_index_t

Enumerator
kSLCD_PhaseAIndex LCD phase A bit index.
kSLCD_PhaseBIndex LCD phase B bit index.
kSLCD_PhaseCIndex LCD phase C bit index.
kSLCD_PhaseDIndex LCD phase D bit index.
kSLCD_PhaseEIndex LCD phase E bit index.
kSLCD_PhaseFIndex LCD phase F bit index.
kSLCD_PhaseGIndex LCD phase G bit index.
kSLCD_PhaseHIndex LCD phase H bit index.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 581
Enumeration Type Documentation

25.5.10 enum slcd_display_mode_t

Enumerator
kSLCD_NormalMode LCD Normal display mode.
kSLCD_AlternateMode LCD Alternate display mode. For four back planes or less.
kSLCD_BlankMode LCD Blank display mode.

25.5.11 enum slcd_blink_mode_t

Enumerator
kSLCD_BlankDisplayBlink Display blank during the blink period.
kSLCD_AltDisplayBlink Display alternate display during the blink period if duty cycle is lower than
5.

25.5.12 enum slcd_blink_rate_t

Enumerator
kSLCD_BlinkRate00 SLCD blink rate is LCD clock/((2∧ 12)).
kSLCD_BlinkRate01 SLCD blink rate is LCD clock/((2∧ 13)).
kSLCD_BlinkRate02 SLCD blink rate is LCD clock/((2∧ 14)).
kSLCD_BlinkRate03 SLCD blink rate is LCD clock/((2∧ 15)).
kSLCD_BlinkRate04 SLCD blink rate is LCD clock/((2∧ 16)).
kSLCD_BlinkRate05 SLCD blink rate is LCD clock/((2∧ 17)).
kSLCD_BlinkRate06 SLCD blink rate is LCD clock/((2∧ 18)).
kSLCD_BlinkRate07 SLCD blink rate is LCD clock/((2∧ 19)).

25.5.13 enum slcd_fault_detect_clock_prescaler_t

Enumerator
kSLCD_FaultSampleFreqDivider1 Fault detect sample clock frequency is 1/1 bus clock.
kSLCD_FaultSampleFreqDivider2 Fault detect sample clock frequency is 1/2 bus clock.
kSLCD_FaultSampleFreqDivider4 Fault detect sample clock frequency is 1/4 bus clock.
kSLCD_FaultSampleFreqDivider8 Fault detect sample clock frequency is 1/8 bus clock.
kSLCD_FaultSampleFreqDivider16 Fault detect sample clock frequency is 1/16 bus clock.
kSLCD_FaultSampleFreqDivider32 Fault detect sample clock frequency is 1/32 bus clock.
kSLCD_FaultSampleFreqDivider64 Fault detect sample clock frequency is 1/64 bus clock.
kSLCD_FaultSampleFreqDivider128 Fault detect sample clock frequency is 1/128 bus clock.

MCUXpresso SDK API Reference Manual


582 NXP Semiconductors
Function Documentation

25.5.14 enum slcd_fault_detect_sample_window_width_t

Enumerator
kSLCD_FaultDetectWindowWidth4SampleClk Sample window width is 4 sample clock cycles.
kSLCD_FaultDetectWindowWidth8SampleClk Sample window width is 8 sample clock cycles.
kSLCD_FaultDetectWindowWidth16SampleClk Sample window width is 16 sample clock cycles.
kSLCD_FaultDetectWindowWidth32SampleClk Sample window width is 32 sample clock cycles.
kSLCD_FaultDetectWindowWidth64SampleClk Sample window width is 64 sample clock cycles.
kSLCD_FaultDetectWindowWidth128SampleClk Sample window width is 128 sample clock cy-
cles.
kSLCD_FaultDetectWindowWidth256SampleClk Sample window width is 256 sample clock cy-
cles.
kSLCD_FaultDetectWindowWidth512SampleClk Sample window width is 512 sample clock cy-
cles.

25.5.15 enum slcd_interrupt_enable_t

Enumerator
kSLCD_FaultDetectCompleteInterrupt SLCD fault detection complete interrupt source.

25.5.16 enum slcd_lowpower_behavior

Enumerator
kSLCD_EnabledInWaitStop SLCD works in wait and stop mode.
kSLCD_EnabledInWaitOnly SLCD works in wait mode and is disabled in stop mode.
kSLCD_EnabledInStopOnly SLCD works in stop mode and is disabled in wait mode.
kSLCD_DisabledInWaitStop SLCD is disabled in stop mode and wait mode.

25.6 Function Documentation


25.6.1 void SLCD_Init ( LCD_Type ∗ base, slcd_config_t ∗ configure )

Parameters

MCUXpresso SDK API Reference Manual


NXP Semiconductors 583
Function Documentation

base SLCD peripheral base address.


configure SLCD configuration pointer. For the configuration structure, many parameters have
the default setting and the SLCD_Getdefaultconfig() is provided to get them. Use
it verified for their applications. The others have no default settings, such as "clk-
Config", and must be provided by the application before calling the SLCD_Init()
API.

25.6.2 void SLCD_Deinit ( LCD_Type ∗ base )

Parameters

base SLCD peripheral base address.

25.6.3 void SLCD_GetDefaultConfig ( slcd_config_t ∗ configure )

The purpose of this API is to get default parameters of the configuration structure for the SLCD_Init().
Use these initialized parameters unchanged in SLCD_Init() or modify fields of the structure before the
calling SLCD_Init(). All default parameters of the configure structuration are listed.

config.displayMode = kSLCD_NormalMode; // SLCD normal mode


config.powerSupply = kSLCD_InternalVll3UseChargePump; // Use charge
pump internal VLL3
config.voltageTrim = kSLCD_RegulatedVolatgeTrim00;
config.lowPowerBehavior = kSLCD_EnabledInWaitStop; // Work on low power mode
config.interruptSrc = 0; // No interrupt source is enabled
config.faultConfig = NULL; // Fault detection is disabled
config.frameFreqIntEnable = false;

Parameters

configure The SLCD configuration structure pointer.

25.6.4 static void SLCD_StartDisplay ( LCD_Type ∗ base ) [inline], [static]

Parameters

MCUXpresso SDK API Reference Manual


584 NXP Semiconductors
Function Documentation

base SLCD peripheral base address.

25.6.5 static void SLCD_StopDisplay ( LCD_Type ∗ base ) [inline], [static]

There is no waveform generator and all enabled pins only output a low value.
Parameters

base SLCD peripheral base address.

25.6.6 void SLCD_StartBlinkMode ( LCD_Type ∗ base, slcd_blink_mode_t mode,


slcd_blink_rate_t rate )

Parameters

base SLCD peripheral base address.


mode SLCD blink mode.
rate SLCD blink rate.

25.6.7 static void SLCD_StopBlinkMode ( LCD_Type ∗ base ) [inline],


[static]

Parameters

base SLCD peripheral base address.

25.6.8 static void SLCD_SetBackPlanePhase ( LCD_Type ∗ base, uint32_t pinIndx,


slcd_phase_type_t phase ) [inline], [static]

This function sets the SLCD back plane pin phase. "kSLCD_PhaseXActivate" setting means the phase X
is active for the back plane pin. "kSLCD_NoPhaseActivate" setting means there is no phase active for the
back plane pin. For example, set the back plane pin 20 for phase A.

* SLCD_SetBackPlanePhase(LCD, 20, kSLCD_PhaseAActivate);


*

MCUXpresso SDK API Reference Manual


NXP Semiconductors 585
Function Documentation

Parameters

base SLCD peripheral base address.


pinIndx SLCD back plane pin index. Range from 0 to 63.
phase The phase activates for the back plane pin.

25.6.9 static void SLCD_SetFrontPlaneSegments ( LCD_Type ∗ base, uint32_t


pinIndx, uint8_t operation ) [inline], [static]

This function sets the SLCD front plane segment on or off operation. Each bit turns on or off the segments
associated with the front plane pin in the following pattern: HGFEDCBA (most significant bit controls
segment H and least significant bit controls segment A). For example, turn on the front plane pin 20 for
phase B and phase C.

* SLCD_SetFrontPlaneSegments(LCD, 20, (
kSLCD_PhaseBActivate | kSLCD_PhaseCActivate));
*

Parameters

base SLCD peripheral base address.


pinIndx SLCD back plane pin index. Range from 0 to 63.
operation The operation for the segment on the front plane pin. This is a logical OR of the
enumeration :: slcd_phase_type_t.

25.6.10 static void SLCD_SetFrontPlaneOnePhase ( LCD_Type ∗ base, uint32_t


pinIndx, slcd_phase_index_t phaseIndx, bool enable ) [inline],
[static]

This function can be used to set one phase on or off for the front plane pin. It can be call many times to
set the plane pin for different phase indexes. For example, turn on the front plane pin 20 for phase B and
phase C.

* SLCD_SetFrontPlaneOnePhase(LCD, 20,
kSLCD_PhaseBIndex, true);
* SLCD_SetFrontPlaneOnePhase(LCD, 20,
kSLCD_PhaseCIndex, true);
*

MCUXpresso SDK API Reference Manual


586 NXP Semiconductors
Function Documentation

Parameters

base SLCD peripheral base address.


pinIndx SLCD back plane pin index. Range from 0 to 63.
phaseIndx The phase bit index slcd_phase_index_t.
enable True to turn on the segment for phaseIndx phase false to turn off the segment for
phaseIndx phase.

25.6.11 static void SLCD_EnablePadSafeState ( LCD_Type ∗ base, bool enable )


[inline], [static]

Forces the safe state on the LCD pad controls. All LCD front plane and backplane functions are disabled.
Parameters

base SLCD peripheral base address.


enable True enable, false disable.

25.6.12 static uint32_t SLCD_GetFaultDetectCounter ( LCD_Type ∗ base )


[inline], [static]

This function gets the number of samples inside the fault detection sample window.
Parameters

base SLCD peripheral base address.

Returns
The fault detect counter. The maximum return value is 255. If the maximum 255 returns, the
overflow may happen. Reconfigure the fault detect sample window and fault detect clock prescaler
for proper sampling.

25.6.13 void SLCD_EnableInterrupts ( LCD_Type ∗ base, uint32_t mask )

For example, to enable fault detect complete interrupt and frame frequency interrupt, for FSL_FEATUR-
E_SLCD_HAS_FRAME_FREQUENCY_INTERRUPT enabled case, do the following.
* SLCD_EnableInterrupts(LCD,
kSLCD_FaultDetectCompleteInterrupt | kSLCD_FrameFreqInterrupt);
*

MCUXpresso SDK API Reference Manual


NXP Semiconductors 587
Function Documentation

Parameters

base SLCD peripheral base address.


mask SLCD interrupts to enable. This is a logical OR of the enumeration :: slcd_interrupt-
_enable_t.

25.6.14 void SLCD_DisableInterrupts ( LCD_Type ∗ base, uint32_t mask )

For example, to disable fault detect complete interrupt and frame frequency interrupt, for FSL_FEATUR-
E_SLCD_HAS_FRAME_FREQUENCY_INTERRUPT enabled case, do the following.

* SLCD_DisableInterrupts(LCD,
kSLCD_FaultDetectCompleteInterrupt | kSLCD_FrameFreqInterrupt);
*

Parameters

base SLCD peripheral base address.


mask SLCD interrupts to disable. This is a logical OR of the enumeration :: slcd_interrupt-
_enable_t.

25.6.15 uint32_t SLCD_GetInterruptStatus ( LCD_Type ∗ base )

Parameters

base SLCD peripheral base address.

Returns
The event status of the interrupt source. This is the logical OR of members of the enumeration ::
slcd_interrupt_enable_t.

25.6.16 void SLCD_ClearInterruptStatus ( LCD_Type ∗ base, uint32_t mask )

MCUXpresso SDK API Reference Manual


588 NXP Semiconductors
Function Documentation

Parameters

base SLCD peripheral base address.


mask SLCD interrupt source to be cleared. This is the logical OR of members of the enu-
meration :: slcd_interrupt_enable_t.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 589
Function Documentation

MCUXpresso SDK API Reference Manual


590 NXP Semiconductors
Chapter 26
SMC: System Mode Controller Driver
26.1 Overview
The MCUXpresso SDK provides a peripheral driver for the System Mode Controller (SMC) module of
MCUXpresso SDK devices. The SMC module sequences the system in and out of all low-power stop and
run modes.
API functions are provided to configure the system for working in a dedicated power mode. For different
power modes, SMC_SetPowerModexxx() function accepts different parameters. System power mode state
transitions are not available between power modes. For details about available transitions, see the power
mode transitions section in the SoC reference manual.

26.2 Typical use case


26.2.1 Enter wait or stop modes

SMC driver provides APIs to set MCU to different wait modes and stop modes. Pre and post functions are
used for setting the modes. The pre functions and post functions are used as follows.
Disable/enable the interrupt through PRIMASK. This is an example use case. The application sets the
wakeup interrupt and calls SMC function SMC_SetPowerModeStop to set the MCU to STOP mode, but
the wakeup interrupt happens so quickly that the ISR completes before the function SMC_SetPowerMode-
Stop. As a result, the MCU enters the STOP mode and never is woken up by the interrupt. In this use
case, the application first disables the interrupt through PRIMASK, sets the wakeup interrupt, and enters
the STOP mode. After wakeup, enable the interrupt through PRIMASK. The MCU can still be woken up
by disabling the interrupt through PRIMASK. The pre and post functions handle the PRIMASK.

SMC_PreEnterStopModes();

/* Enable the wakeup interrupt here. */

SMC_SetPowerModeStop(SMC, kSMC_PartialStop);

SMC_PostExitStopModes();

For legacy Kinetis, when entering stop modes, the flash speculation might be interrupted. As a result, the
prefetched code or data might be broken. To make sure the flash is idle when entring the stop modes, smc
driver allocates a RAM region, the code to enter stop modes are excuted in RAM, thus the flash is idle
and no prefetch is performed while entring stop modes. Application should make sure that, the rw data of
fsl_smc.c is located in memory region which is not powered off in stop modes, especially LLS2 modes.
For STOP, VLPS, and LLS3, the whole RAM are powered up, so after woken up, the RAM function
could continue excuting. For VLLS mode, the system resets after woken up, the RAM content might be
re-initialized. For LLS2 mode, only part of RAM are powered on, so application must make sure that, the

MCUXpresso SDK API Reference Manual


NXP Semiconductors 591
Typical use case

rw data of fsl_smc.c is located in memory region which is not powered off, otherwise after woken up, the
MCU could not get right code to excute.

Data Structures
• struct smc_power_mode_vlls_config_t
SMC Very Low-Leakage Stop power mode configuration. More...

Enumerations
• enum smc_power_mode_protection_t {
kSMC_AllowPowerModeVlls = SMC_PMPROT_AVLLS_MASK,
kSMC_AllowPowerModeLls = SMC_PMPROT_ALLS_MASK,
kSMC_AllowPowerModeVlp = SMC_PMPROT_AVLP_MASK,
kSMC_AllowPowerModeAll }
Power Modes Protection.
• enum smc_power_state_t {
kSMC_PowerStateRun = 0x01U << 0U,
kSMC_PowerStateStop = 0x01U << 1U,
kSMC_PowerStateVlpr = 0x01U << 2U,
kSMC_PowerStateVlpw = 0x01U << 3U,
kSMC_PowerStateVlps = 0x01U << 4U,
kSMC_PowerStateLls = 0x01U << 5U,
kSMC_PowerStateVlls = 0x01U << 6U }
Power Modes in PMSTAT.
• enum smc_run_mode_t {
kSMC_RunNormal = 0U,
kSMC_RunVlpr = 2U }
Run mode definition.
• enum smc_stop_mode_t {
kSMC_StopNormal = 0U,
kSMC_StopVlps = 2U,
kSMC_StopLls = 3U,
kSMC_StopVlls = 4U }
Stop mode definition.
• enum smc_stop_submode_t {
kSMC_StopSub0 = 0U,
kSMC_StopSub1 = 1U,
kSMC_StopSub2 = 2U,
kSMC_StopSub3 = 3U }
VLLS/LLS stop sub mode definition.
• enum smc_partial_stop_option_t {
kSMC_PartialStop = 0U,
kSMC_PartialStop1 = 1U,
kSMC_PartialStop2 = 2U }
Partial STOP option.
• enum _smc_status { kStatus_SMC_StopAbort = MAKE_STATUS(kStatusGroup_POWER, 0) }

MCUXpresso SDK API Reference Manual


592 NXP Semiconductors
Data Structure Documentation

SMC configuration status.

Driver version
• #define FSL_SMC_DRIVER_VERSION (MAKE_VERSION(2, 0, 5))
SMC driver version 2.0.5.

System mode controller APIs


• static void SMC_SetPowerModeProtection (SMC_Type ∗base, uint8_t allowedModes)
Configures all power mode protection settings.
• static smc_power_state_t SMC_GetPowerModeState (SMC_Type ∗base)
Gets the current power mode status.
• void SMC_PreEnterStopModes (void)
Prepares to enter stop modes.
• void SMC_PostExitStopModes (void)
Recovers after wake up from stop modes.
• void SMC_PreEnterWaitModes (void)
Prepares to enter wait modes.
• void SMC_PostExitWaitModes (void)
Recovers after wake up from stop modes.
• status_t SMC_SetPowerModeRun (SMC_Type ∗base)
Configures the system to RUN power mode.
• status_t SMC_SetPowerModeWait (SMC_Type ∗base)
Configures the system to WAIT power mode.
• status_t SMC_SetPowerModeStop (SMC_Type ∗base, smc_partial_stop_option_t option)
Configures the system to Stop power mode.
• status_t SMC_SetPowerModeVlpr (SMC_Type ∗base)
Configures the system to VLPR power mode.
• status_t SMC_SetPowerModeVlpw (SMC_Type ∗base)
Configures the system to VLPW power mode.
• status_t SMC_SetPowerModeVlps (SMC_Type ∗base)
Configures the system to VLPS power mode.
• status_t SMC_SetPowerModeLls (SMC_Type ∗base)
Configures the system to LLS power mode.
• status_t SMC_SetPowerModeVlls (SMC_Type ∗base, const smc_power_mode_vlls_config_t
∗config)
Configures the system to VLLS power mode.

26.3 Data Structure Documentation


26.3.1 struct smc_power_mode_vlls_config_t

Data Fields

• smc_stop_submode_t subMode
Very Low-leakage Stop sub-mode.
• bool enablePorDetectInVlls0
Enable Power on reset detect in VLLS mode.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 593
Enumeration Type Documentation

26.4 Macro Definition Documentation


26.4.1 #define FSL_SMC_DRIVER_VERSION (MAKE_VERSION(2, 0, 5))

26.5 Enumeration Type Documentation


26.5.1 enum smc_power_mode_protection_t

Enumerator
kSMC_AllowPowerModeVlls Allow Very-low-leakage Stop Mode.
kSMC_AllowPowerModeLls Allow Low-leakage Stop Mode.
kSMC_AllowPowerModeVlp Allow Very-Low-power Mode.
kSMC_AllowPowerModeAll Allow all power mode.

26.5.2 enum smc_power_state_t

Enumerator
kSMC_PowerStateRun 0000_0001 - Current power mode is RUN
kSMC_PowerStateStop 0000_0010 - Current power mode is STOP
kSMC_PowerStateVlpr 0000_0100 - Current power mode is VLPR
kSMC_PowerStateVlpw 0000_1000 - Current power mode is VLPW
kSMC_PowerStateVlps 0001_0000 - Current power mode is VLPS
kSMC_PowerStateLls 0010_0000 - Current power mode is LLS
kSMC_PowerStateVlls 0100_0000 - Current power mode is VLLS

26.5.3 enum smc_run_mode_t

Enumerator
kSMC_RunNormal Normal RUN mode.
kSMC_RunVlpr Very-low-power RUN mode.

26.5.4 enum smc_stop_mode_t

Enumerator
kSMC_StopNormal Normal STOP mode.
kSMC_StopVlps Very-low-power STOP mode.
kSMC_StopLls Low-leakage Stop mode.
kSMC_StopVlls Very-low-leakage Stop mode.

MCUXpresso SDK API Reference Manual


594 NXP Semiconductors
Function Documentation

26.5.5 enum smc_stop_submode_t

Enumerator
kSMC_StopSub0 Stop submode 0, for VLLS0/LLS0.
kSMC_StopSub1 Stop submode 1, for VLLS1/LLS1.
kSMC_StopSub2 Stop submode 2, for VLLS2/LLS2.
kSMC_StopSub3 Stop submode 3, for VLLS3/LLS3.

26.5.6 enum smc_partial_stop_option_t

Enumerator
kSMC_PartialStop STOP - Normal Stop mode.
kSMC_PartialStop1 Partial Stop with both system and bus clocks disabled.
kSMC_PartialStop2 Partial Stop with system clock disabled and bus clock enabled.

26.5.7 enum _smc_status

Enumerator
kStatus_SMC_StopAbort Entering Stop mode is abort.

26.6 Function Documentation


26.6.1 static void SMC_SetPowerModeProtection ( SMC_Type ∗ base, uint8_t
allowedModes ) [inline], [static]

This function configures the power mode protection settings for supported power modes in the specified
chip family. The available power modes are defined in the smc_power_mode_protection_t. This should
be done at an early system level initialization stage. See the reference manual for details. This register can
only write once after the power reset.
The allowed modes are passed as bit map. For example, to allow LLS and VLLS, use SMC_SetPower-
ModeProtection(kSMC_AllowPowerModeVlls | kSMC_AllowPowerModeVlps). To allow all modes, use
SMC_SetPowerModeProtection(kSMC_AllowPowerModeAll).
Parameters

MCUXpresso SDK API Reference Manual


NXP Semiconductors 595
Function Documentation

base SMC peripheral base address.


allowedModes Bitmap of the allowed power modes.

26.6.2 static smc_power_state_t SMC_GetPowerModeState ( SMC_Type ∗ base )


[inline], [static]

This function returns the current power mode status. After the application switches the power mode, it
should always check the status to check whether it runs into the specified mode or not. The application
should check this mode before switching to a different mode. The system requires that only certain modes
can switch to other specific modes. See the reference manual for details and the smc_power_state_t for
information about the power status.
Parameters

base SMC peripheral base address.

Returns
Current power mode status.

26.6.3 void SMC_PreEnterStopModes ( void )

This function should be called before entering STOP/VLPS/LLS/VLLS modes.

26.6.4 void SMC_PostExitStopModes ( void )

This function should be called after wake up from STOP/VLPS/LLS/VLLS modes. It is used with SMC-
_PreEnterStopModes.

26.6.5 void SMC_PreEnterWaitModes ( void )

This function should be called before entering WAIT/VLPW modes.

26.6.6 void SMC_PostExitWaitModes ( void )

This function should be called after wake up from WAIT/VLPW modes. It is used with SMC_PreEnter-
WaitModes.

MCUXpresso SDK API Reference Manual


596 NXP Semiconductors
Function Documentation

26.6.7 status_t SMC_SetPowerModeRun ( SMC_Type ∗ base )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 597
Function Documentation

Parameters

base SMC peripheral base address.

Returns
SMC configuration error code.

26.6.8 status_t SMC_SetPowerModeWait ( SMC_Type ∗ base )

Parameters

base SMC peripheral base address.

Returns
SMC configuration error code.

26.6.9 status_t SMC_SetPowerModeStop ( SMC_Type ∗ base,


smc_partial_stop_option_t option )

Parameters

base SMC peripheral base address.


option Partial Stop mode option.

Returns
SMC configuration error code.

26.6.10 status_t SMC_SetPowerModeVlpr ( SMC_Type ∗ base )

Parameters

MCUXpresso SDK API Reference Manual


598 NXP Semiconductors
Function Documentation

base SMC peripheral base address.

Returns
SMC configuration error code.

26.6.11 status_t SMC_SetPowerModeVlpw ( SMC_Type ∗ base )

Parameters

base SMC peripheral base address.

Returns
SMC configuration error code.

26.6.12 status_t SMC_SetPowerModeVlps ( SMC_Type ∗ base )

Parameters

base SMC peripheral base address.

Returns
SMC configuration error code.

26.6.13 status_t SMC_SetPowerModeLls ( SMC_Type ∗ base )

Parameters

base SMC peripheral base address.

Returns
SMC configuration error code.

26.6.14 status_t SMC_SetPowerModeVlls ( SMC_Type ∗ base, const


smc_power_mode_vlls_config_t ∗ config )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 599
Function Documentation

Parameters

base SMC peripheral base address.


config The VLLS power mode configuration structure.

Returns
SMC configuration error code.

MCUXpresso SDK API Reference Manual


600 NXP Semiconductors
Chapter 27
SPI: Serial Peripheral Interface Driver
27.1 Overview
Modules
• SPI DMA Driver
• SPI Driver
• SPI FreeRTOS driver

MCUXpresso SDK API Reference Manual


NXP Semiconductors 601
SPI Driver

27.2 SPI Driver


27.2.1 Overview

SPI driver includes functional APIs and transactional APIs.


Functional APIs are feature/property target low level APIs. Functional APIs can be used for SPI initializa-
tion/configuration/operation for optimization/customization purpose. Using the functional API requires
the knowledge of the SPI peripheral and how to organize functional APIs to meet the application require-
ments. All functional API use the peripheral base address as the first parameter. SPI functional operation
groups provide the functional API set.
Transactional APIs are transaction target high level APIs. Transactional APIs can be used to enable the
peripheral and in the application if the code size and performance of transactional APIs satisfy the require-
ments. If the code size and performance are a critical requirement, see the transactional API implementa-
tion and write a custom code. All transactional APIs use the spi_handle_t as the first parameter. Initialize
the handle by calling the SPI_MasterTransferCreateHandle() or SPI_SlaveTransferCreateHandle() API.
Transactional APIs support asynchronous transfer. This means that the functions SPI_MasterTransferNon-
Blocking() and SPI_SlaveTransferNonBlocking() set up the interrupt for data transfer. When the transfer
completes, the upper layer is notified through a callback function with the kStatus_SPI_Idle status.

27.2.2 Typical use case

27.2.2.1 SPI master transfer using an interrupt method

Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/spi

27.2.2.2 SPI Send/receive using a DMA method

Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/spi

Data Structures

• struct spi_master_config_t
SPI master user configure structure. More...
• struct spi_slave_config_t
SPI slave user configure structure. More...
• struct spi_transfer_t
SPI transfer structure. More...
• struct spi_master_handle_t
SPI transfer handle structure. More...

MCUXpresso SDK API Reference Manual


602 NXP Semiconductors
SPI Driver

Macros

• #define SPI_DUMMYDATA (0xFFU)


SPI dummy transfer data, the data is sent while txBuff is NULL.

Typedefs

• typedef spi_master_handle_t spi_slave_handle_t


Slave handle is the same with master handle.
• typedef void(∗ spi_master_callback_t )(SPI_Type ∗base, spi_master_handle_t ∗handle, status_t sta-
tus, void ∗userData)
SPI master callback for finished transmit.
• typedef void(∗ spi_slave_callback_t )(SPI_Type ∗base, spi_slave_handle_t ∗handle, status_t status,
void ∗userData)
SPI master callback for finished transmit.

Enumerations

• enum _spi_status {
kStatus_SPI_Busy = MAKE_STATUS(kStatusGroup_SPI, 0),
kStatus_SPI_Idle = MAKE_STATUS(kStatusGroup_SPI, 1),
kStatus_SPI_Error = MAKE_STATUS(kStatusGroup_SPI, 2) }
Return status for the SPI driver.
• enum spi_clock_polarity_t {
kSPI_ClockPolarityActiveHigh = 0x0U,
kSPI_ClockPolarityActiveLow }
SPI clock polarity configuration.
• enum spi_clock_phase_t {
kSPI_ClockPhaseFirstEdge = 0x0U,
kSPI_ClockPhaseSecondEdge }
SPI clock phase configuration.
• enum spi_shift_direction_t {
kSPI_MsbFirst = 0x0U,
kSPI_LsbFirst }
SPI data shifter direction options.
• enum spi_ss_output_mode_t {
kSPI_SlaveSelectAsGpio = 0x0U,
kSPI_SlaveSelectFaultInput = 0x2U,
kSPI_SlaveSelectAutomaticOutput = 0x3U }
SPI slave select output mode options.
• enum spi_pin_mode_t {
kSPI_PinModeNormal = 0x0U,
kSPI_PinModeInput = 0x1U,
kSPI_PinModeOutput = 0x3U }
SPI pin mode options.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 603
SPI Driver

• enum spi_data_bitcount_mode_t {
kSPI_8BitMode = 0x0U,
kSPI_16BitMode }
SPI data length mode options.
• enum _spi_interrupt_enable {
kSPI_RxFullAndModfInterruptEnable = 0x1U,
kSPI_TxEmptyInterruptEnable = 0x2U,
kSPI_MatchInterruptEnable = 0x4U,
kSPI_RxFifoNearFullInterruptEnable = 0x8U,
kSPI_TxFifoNearEmptyInterruptEnable = 0x10U }
SPI interrupt sources.
• enum _spi_flags {
kSPI_RxBufferFullFlag = SPI_S_SPRF_MASK,
kSPI_MatchFlag = SPI_S_SPMF_MASK,
kSPI_TxBufferEmptyFlag = SPI_S_SPTEF_MASK,
kSPI_ModeFaultFlag = SPI_S_MODF_MASK,
kSPI_RxFifoNearFullFlag = SPI_S_RNFULLF_MASK,
kSPI_TxFifoNearEmptyFlag = SPI_S_TNEAREF_MASK,
kSPI_TxFifoFullFlag = SPI_S_TXFULLF_MASK,
kSPI_RxFifoEmptyFlag = SPI_S_RFIFOEF_MASK,
kSPI_TxFifoError = SPI_CI_TXFERR_MASK << 8U,
kSPI_RxFifoError = SPI_CI_RXFERR_MASK << 8U,
kSPI_TxOverflow = SPI_CI_TXFOF_MASK << 8U,
kSPI_RxOverflow = SPI_CI_RXFOF_MASK << 8U }
SPI status flags.
• enum spi_w1c_interrupt_t {
kSPI_RxFifoFullClearInterrupt = SPI_CI_SPRFCI_MASK,
kSPI_TxFifoEmptyClearInterrupt = SPI_CI_SPTEFCI_MASK,
kSPI_RxNearFullClearInterrupt = SPI_CI_RNFULLFCI_MASK,
kSPI_TxNearEmptyClearInterrupt = SPI_CI_TNEAREFCI_MASK }
SPI FIFO write-1-to-clear interrupt flags.
• enum spi_txfifo_watermark_t {
kSPI_TxFifoOneFourthEmpty = 0,
kSPI_TxFifoOneHalfEmpty = 1 }
SPI TX FIFO watermark settings.
• enum spi_rxfifo_watermark_t {
kSPI_RxFifoThreeFourthsFull = 0,
kSPI_RxFifoOneHalfFull = 1 }
SPI RX FIFO watermark settings.
• enum _spi_dma_enable_t {
kSPI_TxDmaEnable = SPI_C2_TXDMAE_MASK,
kSPI_RxDmaEnable = SPI_C2_RXDMAE_MASK,
kSPI_DmaAllEnable = (SPI_C2_TXDMAE_MASK | SPI_C2_RXDMAE_MASK) }
SPI DMA source.

MCUXpresso SDK API Reference Manual


604 NXP Semiconductors
SPI Driver

Variables

• volatile uint8_t g_spiDummyData [ ]


Global variable for dummy data value setting.

Driver version

• #define FSL_SPI_DRIVER_VERSION (MAKE_VERSION(2, 0, 4))


SPI driver version 2.0.3.

Initialization and deinitialization

• void SPI_MasterGetDefaultConfig (spi_master_config_t ∗config)


Sets the SPI master configuration structure to default values.
• void SPI_MasterInit (SPI_Type ∗base, const spi_master_config_t ∗config, uint32_t srcClock_Hz)
Initializes the SPI with master configuration.
• void SPI_SlaveGetDefaultConfig (spi_slave_config_t ∗config)
Sets the SPI slave configuration structure to default values.
• void SPI_SlaveInit (SPI_Type ∗base, const spi_slave_config_t ∗config)
Initializes the SPI with slave configuration.
• void SPI_Deinit (SPI_Type ∗base)
De-initializes the SPI.
• static void SPI_Enable (SPI_Type ∗base, bool enable)
Enables or disables the SPI.

Status

• uint32_t SPI_GetStatusFlags (SPI_Type ∗base)


Gets the status flag.
• static void SPI_ClearInterrupt (SPI_Type ∗base, uint32_t mask)
Clear the interrupt if enable INCTLR.

Interrupts

• void SPI_EnableInterrupts (SPI_Type ∗base, uint32_t mask)


Enables the interrupt for the SPI.
• void SPI_DisableInterrupts (SPI_Type ∗base, uint32_t mask)
Disables the interrupt for the SPI.

DMA Control

• static void SPI_EnableDMA (SPI_Type ∗base, uint32_t mask, bool enable)


Enables the DMA source for SPI.
• static uint32_t SPI_GetDataRegisterAddress (SPI_Type ∗base)

MCUXpresso SDK API Reference Manual


NXP Semiconductors 605
SPI Driver

Gets the SPI tx/rx data register address.

Bus Operations

• uint32_t SPI_GetInstance (SPI_Type ∗base)


Get the instance for SPI module.
• static void SPI_SetPinMode (SPI_Type ∗base, spi_pin_mode_t pinMode)
Sets the pin mode for transfer.
• void SPI_MasterSetBaudRate (SPI_Type ∗base, uint32_t baudRate_Bps, uint32_t srcClock_Hz)
Sets the baud rate for SPI transfer.
• static void SPI_SetMatchData (SPI_Type ∗base, uint32_t matchData)
Sets the match data for SPI.
• void SPI_EnableFIFO (SPI_Type ∗base, bool enable)
Enables or disables the FIFO if there is a FIFO.
• void SPI_WriteBlocking (SPI_Type ∗base, uint8_t ∗buffer, size_t size)
Sends a buffer of data bytes using a blocking method.
• void SPI_WriteData (SPI_Type ∗base, uint16_t data)
Writes a data into the SPI data register.
• uint16_t SPI_ReadData (SPI_Type ∗base)
Gets a data from the SPI data register.
• void SPI_SetDummyData (SPI_Type ∗base, uint8_t dummyData)
Set up the dummy data.

Transactional

• void SPI_MasterTransferCreateHandle (SPI_Type ∗base, spi_master_handle_t ∗handle, spi_master-


_callback_t callback, void ∗userData)
Initializes the SPI master handle.
• status_t SPI_MasterTransferBlocking (SPI_Type ∗base, spi_transfer_t ∗xfer)
Transfers a block of data using a polling method.
• status_t SPI_MasterTransferNonBlocking (SPI_Type ∗base, spi_master_handle_t ∗handle, spi_-
transfer_t ∗xfer)
Performs a non-blocking SPI interrupt transfer.
• status_t SPI_MasterTransferGetCount (SPI_Type ∗base, spi_master_handle_t ∗handle, size_t
∗count)
Gets the bytes of the SPI interrupt transferred.
• void SPI_MasterTransferAbort (SPI_Type ∗base, spi_master_handle_t ∗handle)
Aborts an SPI transfer using interrupt.
• void SPI_MasterTransferHandleIRQ (SPI_Type ∗base, spi_master_handle_t ∗handle)
Interrupts the handler for the SPI.
• void SPI_SlaveTransferCreateHandle (SPI_Type ∗base, spi_slave_handle_t ∗handle, spi_slave_-
callback_t callback, void ∗userData)
Initializes the SPI slave handle.
• static status_t SPI_SlaveTransferNonBlocking (SPI_Type ∗base, spi_slave_handle_t ∗handle, spi_-
transfer_t ∗xfer)
Performs a non-blocking SPI slave interrupt transfer.
• static status_t SPI_SlaveTransferGetCount (SPI_Type ∗base, spi_slave_handle_t ∗handle, size_t
∗count)

MCUXpresso SDK API Reference Manual


606 NXP Semiconductors
SPI Driver

Gets the bytes of the SPI interrupt transferred.


• static void SPI_SlaveTransferAbort (SPI_Type ∗base, spi_slave_handle_t ∗handle)
Aborts an SPI slave transfer using interrupt.
• void SPI_SlaveTransferHandleIRQ (SPI_Type ∗base, spi_slave_handle_t ∗handle)
Interrupts a handler for the SPI slave.

27.2.3 Data Structure Documentation

27.2.3.1 struct spi_master_config_t

Data Fields
• bool enableMaster
Enable SPI at initialization time.
• bool enableStopInWaitMode
SPI stop in wait mode.
• spi_clock_polarity_t polarity
Clock polarity.
• spi_clock_phase_t phase
Clock phase.
• spi_shift_direction_t direction
MSB or LSB.
• spi_data_bitcount_mode_t dataMode
8bit or 16bit mode
• spi_txfifo_watermark_t txWatermark
Tx watermark settings.
• spi_rxfifo_watermark_t rxWatermark
Rx watermark settings.
• spi_ss_output_mode_t outputMode
SS pin setting.
• spi_pin_mode_t pinMode
SPI pin mode select.
• uint32_t baudRate_Bps
Baud Rate for SPI in Hz.

27.2.3.2 struct spi_slave_config_t

Data Fields
• bool enableSlave
Enable SPI at initialization time.
• bool enableStopInWaitMode
SPI stop in wait mode.
• spi_clock_polarity_t polarity
Clock polarity.
• spi_clock_phase_t phase
Clock phase.
• spi_shift_direction_t direction

MCUXpresso SDK API Reference Manual


NXP Semiconductors 607
SPI Driver

MSB or LSB.
• spi_data_bitcount_mode_t dataMode
8bit or 16bit mode
• spi_txfifo_watermark_t txWatermark
Tx watermark settings.
• spi_rxfifo_watermark_t rxWatermark
Rx watermark settings.
• spi_pin_mode_t pinMode
SPI pin mode select.

27.2.3.3 struct spi_transfer_t

Data Fields
• uint8_t ∗ txData
Send buffer.
• uint8_t ∗ rxData
Receive buffer.
• size_t dataSize
Transfer bytes.
• uint32_t flags
SPI control flag, useless to SPI.

27.2.3.3.0.27 Field Documentation

27.2.3.3.0.27.1 uint32_t spi_transfer_t::flags

27.2.3.4 struct _spi_master_handle

Data Fields
• uint8_t ∗volatile txData
Transfer buffer.
• uint8_t ∗volatile rxData
Receive buffer.
• volatile size_t txRemainingBytes
Send data remaining in bytes.
• volatile size_t rxRemainingBytes
Receive data remaining in bytes.
• volatile uint32_t state
SPI internal state.
• size_t transferSize
Bytes to be transferred.
• uint8_t bytePerFrame
SPI mode, 2bytes or 1byte in a frame.
• uint8_t watermark
Watermark value for SPI transfer.
• spi_master_callback_t callback
SPI callback.
• void ∗ userData

MCUXpresso SDK API Reference Manual


608 NXP Semiconductors
SPI Driver

Callback parameter.

27.2.4 Macro Definition Documentation

27.2.4.1 #define FSL_SPI_DRIVER_VERSION (MAKE_VERSION(2, 0, 4))

27.2.4.2 #define SPI_DUMMYDATA (0xFFU)

27.2.5 Enumeration Type Documentation

27.2.5.1 enum _spi_status

Enumerator
kStatus_SPI_Busy SPI bus is busy.
kStatus_SPI_Idle SPI is idle.
kStatus_SPI_Error SPI error.

27.2.5.2 enum spi_clock_polarity_t

Enumerator
kSPI_ClockPolarityActiveHigh Active-high SPI clock (idles low).
kSPI_ClockPolarityActiveLow Active-low SPI clock (idles high).

27.2.5.3 enum spi_clock_phase_t

Enumerator
kSPI_ClockPhaseFirstEdge First edge on SPSCK occurs at the middle of the first cycle of a data
transfer.
kSPI_ClockPhaseSecondEdge First edge on SPSCK occurs at the start of the first cycle of a data
transfer.

27.2.5.4 enum spi_shift_direction_t

Enumerator
kSPI_MsbFirst Data transfers start with most significant bit.
kSPI_LsbFirst Data transfers start with least significant bit.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 609
SPI Driver

27.2.5.5 enum spi_ss_output_mode_t

Enumerator
kSPI_SlaveSelectAsGpio Slave select pin configured as GPIO.
kSPI_SlaveSelectFaultInput Slave select pin configured for fault detection.
kSPI_SlaveSelectAutomaticOutput Slave select pin configured for automatic SPI output.

27.2.5.6 enum spi_pin_mode_t

Enumerator
kSPI_PinModeNormal Pins operate in normal, single-direction mode.
kSPI_PinModeInput Bidirectional mode. Master: MOSI pin is input; Slave: MISO pin is input.
kSPI_PinModeOutput Bidirectional mode. Master: MOSI pin is output; Slave: MISO pin is output.

27.2.5.7 enum spi_data_bitcount_mode_t

Enumerator
kSPI_8BitMode 8-bit data transmission mode
kSPI_16BitMode 16-bit data transmission mode

27.2.5.8 enum _spi_interrupt_enable

Enumerator
kSPI_RxFullAndModfInterruptEnable Receive buffer full (SPRF) and mode fault (MODF) inter-
rupt.
kSPI_TxEmptyInterruptEnable Transmit buffer empty interrupt.
kSPI_MatchInterruptEnable Match interrupt.
kSPI_RxFifoNearFullInterruptEnable Receive FIFO nearly full interrupt.
kSPI_TxFifoNearEmptyInterruptEnable Transmit FIFO nearly empty interrupt.

27.2.5.9 enum _spi_flags

Enumerator
kSPI_RxBufferFullFlag Read buffer full flag.
kSPI_MatchFlag Match flag.
kSPI_TxBufferEmptyFlag Transmit buffer empty flag.
kSPI_ModeFaultFlag Mode fault flag.
kSPI_RxFifoNearFullFlag Rx FIFO near full.

MCUXpresso SDK API Reference Manual


610 NXP Semiconductors
SPI Driver

kSPI_TxFifoNearEmptyFlag Tx FIFO near empty.


kSPI_TxFifoFullFlag Tx FIFO full.
kSPI_RxFifoEmptyFlag Rx FIFO empty.
kSPI_TxFifoError Tx FIFO error.
kSPI_RxFifoError Rx FIFO error.
kSPI_TxOverflow Tx FIFO Overflow.
kSPI_RxOverflow Rx FIFO Overflow.

27.2.5.10 enum spi_w1c_interrupt_t

Enumerator
kSPI_RxFifoFullClearInterrupt Receive FIFO full interrupt.
kSPI_TxFifoEmptyClearInterrupt Transmit FIFO empty interrupt.
kSPI_RxNearFullClearInterrupt Receive FIFO nearly full interrupt.
kSPI_TxNearEmptyClearInterrupt Transmit FIFO nearly empty interrupt.

27.2.5.11 enum spi_txfifo_watermark_t

Enumerator
kSPI_TxFifoOneFourthEmpty SPI tx watermark at 1/4 FIFO size.
kSPI_TxFifoOneHalfEmpty SPI tx watermark at 1/2 FIFO size.

27.2.5.12 enum spi_rxfifo_watermark_t

Enumerator
kSPI_RxFifoThreeFourthsFull SPI rx watermark at 3/4 FIFO size.
kSPI_RxFifoOneHalfFull SPI rx watermark at 1/2 FIFO size.

27.2.5.13 enum _spi_dma_enable_t

Enumerator
kSPI_TxDmaEnable Tx DMA request source.
kSPI_RxDmaEnable Rx DMA request source.
kSPI_DmaAllEnable All DMA request source.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 611
SPI Driver

27.2.6 Function Documentation

27.2.6.1 void SPI_MasterGetDefaultConfig ( spi_master_config_t ∗ config )

The purpose of this API is to get the configuration structure initialized for use in SPI_MasterInit(). User
may use the initialized structure unchanged in SPI_MasterInit(), or modify some fields of the structure
before calling SPI_MasterInit(). After calling this API, the master is ready to transfer. Example:

spi_master_config_t config;
SPI_MasterGetDefaultConfig(&config);

Parameters

config pointer to master config structure

27.2.6.2 void SPI_MasterInit ( SPI_Type ∗ base, const spi_master_config_t ∗ config,


uint32_t srcClock_Hz )

The configuration structure can be filled by user from scratch, or be set with default values by SPI_Master-
GetDefaultConfig(). After calling this API, the slave is ready to transfer. Example

spi_master_config_t config = {
.baudRate_Bps = 400000,
...
};
SPI_MasterInit(SPI0, &config);

Parameters

base SPI base pointer


config pointer to master configuration structure
srcClock_Hz Source clock frequency.

27.2.6.3 void SPI_SlaveGetDefaultConfig ( spi_slave_config_t ∗ config )

The purpose of this API is to get the configuration structure initialized for use in SPI_SlaveInit(). Modify
some fields of the structure before calling SPI_SlaveInit(). Example:

spi_slave_config_t config;
SPI_SlaveGetDefaultConfig(&config);

MCUXpresso SDK API Reference Manual


612 NXP Semiconductors
SPI Driver

Parameters

config pointer to slave configuration structure

27.2.6.4 void SPI_SlaveInit ( SPI_Type ∗ base, const spi_slave_config_t ∗ config )

The configuration structure can be filled by user from scratch or be set with default values by SPI_Slave-
GetDefaultConfig(). After calling this API, the slave is ready to transfer. Example

spi_slave_config_t config = {
.polarity = kSPIClockPolarity_ActiveHigh;
.phase = kSPIClockPhase_FirstEdge;
.direction = kSPIMsbFirst;
...
};
SPI_MasterInit(SPI0, &config);

Parameters

base SPI base pointer


config pointer to master configuration structure

27.2.6.5 void SPI_Deinit ( SPI_Type ∗ base )

Calling this API resets the SPI module, gates the SPI clock. The SPI module can’t work unless calling the
SPI_MasterInit/SPI_SlaveInit to initialize module.
Parameters

base SPI base pointer

27.2.6.6 static void SPI_Enable ( SPI_Type ∗ base, bool enable ) [inline], [static]

Parameters

base SPI base pointer


enable pass true to enable module, false to disable module

27.2.6.7 uint32_t SPI_GetStatusFlags ( SPI_Type ∗ base )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 613
SPI Driver

Parameters

base SPI base pointer

Returns
SPI Status, use status flag to AND _spi_flags could get the related status.

27.2.6.8 static void SPI_ClearInterrupt ( SPI_Type ∗ base, uint32_t mask ) [inline],


[static]

Parameters

base SPI base pointer


interrupt Interrupt need to be cleared The parameter could be any combination of the following
values:
• kSPIRxFifoFullClearInt
• kSPITxFifoEmptyClearInt
• kSPIRxNearFullClearInt
• kSPITxNearEmptyClearInt

27.2.6.9 void SPI_EnableInterrupts ( SPI_Type ∗ base, uint32_t mask )

Parameters

base SPI base pointer


mask SPI interrupt source. The parameter can be any combination of the following values:
• kSPI_RxFullAndModfInterruptEnable
• kSPI_TxEmptyInterruptEnable
• kSPI_MatchInterruptEnable
• kSPI_RxFifoNearFullInterruptEnable
• kSPI_TxFifoNearEmptyInterruptEnable

27.2.6.10 void SPI_DisableInterrupts ( SPI_Type ∗ base, uint32_t mask )

MCUXpresso SDK API Reference Manual


614 NXP Semiconductors
SPI Driver

Parameters

base SPI base pointer


mask SPI interrupt source. The parameter can be any combination of the following values:
• kSPI_RxFullAndModfInterruptEnable
• kSPI_TxEmptyInterruptEnable
• kSPI_MatchInterruptEnable
• kSPI_RxFifoNearFullInterruptEnable
• kSPI_TxFifoNearEmptyInterruptEnable

27.2.6.11 static void SPI_EnableDMA ( SPI_Type ∗ base, uint32_t mask, bool enable )
[inline], [static]

Parameters

base SPI base pointer


source SPI DMA source.
enable True means enable DMA, false means disable DMA

27.2.6.12 static uint32_t SPI_GetDataRegisterAddress ( SPI_Type ∗ base ) [inline],


[static]

This API is used to provide a transfer address for the SPI DMA transfer configuration.
Parameters

base SPI base pointer

Returns
data register address

27.2.6.13 uint32_t SPI_GetInstance ( SPI_Type ∗ base )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 615
SPI Driver

Parameters

base SPI base address

27.2.6.14 static void SPI_SetPinMode ( SPI_Type ∗ base, spi_pin_mode_t pinMode )


[inline], [static]

Parameters

base SPI base pointer


pinMode pin mode for transfer AND #_spi_pin_mode could get the related configuration.

27.2.6.15 void SPI_MasterSetBaudRate ( SPI_Type ∗ base, uint32_t baudRate_Bps,


uint32_t srcClock_Hz )

This is only used in master.


Parameters

base SPI base pointer


baudRate_Bps baud rate needed in Hz.
srcClock_Hz SPI source clock frequency in Hz.

27.2.6.16 static void SPI_SetMatchData ( SPI_Type ∗ base, uint32_t matchData )


[inline], [static]

The match data is a hardware comparison value. When the value received in the SPI receive data buffer
equals the hardware comparison value, the SPI Match Flag in the S register (S[SPMF]) sets. This can also
generate an interrupt if the enable bit sets.
Parameters

base SPI base pointer


matchData Match data.

27.2.6.17 void SPI_EnableFIFO ( SPI_Type ∗ base, bool enable )

MCUXpresso SDK API Reference Manual


616 NXP Semiconductors
SPI Driver

Parameters

base SPI base pointer


enable True means enable FIFO, false means disable FIFO.

27.2.6.18 void SPI_WriteBlocking ( SPI_Type ∗ base, uint8_t ∗ buffer, size_t size )

Note
This function blocks via polling until all bytes have been sent.

Parameters

base SPI base pointer


buffer The data bytes to send
size The number of data bytes to send

27.2.6.19 void SPI_WriteData ( SPI_Type ∗ base, uint16_t data )

Parameters

base SPI base pointer


data needs to be write.

27.2.6.20 uint16_t SPI_ReadData ( SPI_Type ∗ base )

Parameters

base SPI base pointer

Returns
Data in the register.

27.2.6.21 void SPI_SetDummyData ( SPI_Type ∗ base, uint8_t dummyData )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 617
SPI Driver

Parameters

base SPI peripheral address.


dummyData Data to be transferred when tx buffer is NULL.

27.2.6.22 void SPI_MasterTransferCreateHandle ( SPI_Type ∗ base, spi_master_handle_t


∗ handle, spi_master_callback_t callback, void ∗ userData )

This function initializes the SPI master handle which can be used for other SPI master transactional APIs.
Usually, for a specified SPI instance, call this API once to get the initialized handle.
Parameters

base SPI peripheral base address.


handle SPI handle pointer.
callback Callback function.
userData User data.

27.2.6.23 status_t SPI_MasterTransferBlocking ( SPI_Type ∗ base, spi_transfer_t ∗ xfer )

Parameters

base SPI base pointer


xfer pointer to spi_xfer_config_t structure

Return values

kStatus_Success Successfully start a transfer.


kStatus_InvalidArgument Input argument is invalid.

27.2.6.24 status_t SPI_MasterTransferNonBlocking ( SPI_Type ∗ base,


spi_master_handle_t ∗ handle, spi_transfer_t ∗ xfer )

Note
The API immediately returns after transfer initialization is finished. Call SPI_GetStatusIRQ() to get
the transfer status.
If SPI transfer data frame size is 16 bits, the transfer size cannot be an odd number.

MCUXpresso SDK API Reference Manual


618 NXP Semiconductors
SPI Driver

Parameters

base SPI peripheral base address.


handle pointer to spi_master_handle_t structure which stores the transfer state
xfer pointer to spi_xfer_config_t structure

Return values

kStatus_Success Successfully start a transfer.


kStatus_InvalidArgument Input argument is invalid.
kStatus_SPI_Busy SPI is not idle, is running another transfer.

27.2.6.25 status_t SPI_MasterTransferGetCount ( SPI_Type ∗ base, spi_master_handle_t


∗ handle, size_t ∗ count )

Parameters

base SPI peripheral base address.


handle Pointer to SPI transfer handle, this should be a static variable.
count Transferred bytes of SPI master.

Return values

kStatus_SPI_Success Succeed get the transfer count.


kStatus_NoTransferIn- There is not a non-blocking transaction currently in progress.
Progress

27.2.6.26 void SPI_MasterTransferAbort ( SPI_Type ∗ base, spi_master_handle_t ∗


handle )

Parameters

base SPI peripheral base address.


handle Pointer to SPI transfer handle, this should be a static variable.

27.2.6.27 void SPI_MasterTransferHandleIRQ ( SPI_Type ∗ base, spi_master_handle_t ∗


handle )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 619
SPI Driver

Parameters

base SPI peripheral base address.


handle pointer to spi_master_handle_t structure which stores the transfer state.

27.2.6.28 void SPI_SlaveTransferCreateHandle ( SPI_Type ∗ base, spi_slave_handle_t ∗


handle, spi_slave_callback_t callback, void ∗ userData )

This function initializes the SPI slave handle which can be used for other SPI slave transactional APIs.
Usually, for a specified SPI instance, call this API once to get the initialized handle.
Parameters

base SPI peripheral base address.


handle SPI handle pointer.
callback Callback function.
userData User data.

27.2.6.29 static status_t SPI_SlaveTransferNonBlocking ( SPI_Type ∗ base,


spi_slave_handle_t ∗ handle, spi_transfer_t ∗ xfer ) [inline], [static]
Note
The API returns immediately after the transfer initialization is finished. Call SPI_GetStatusIRQ() to
get the transfer status.
If SPI transfer data frame size is 16 bits, the transfer size cannot be an odd number.

Parameters

base SPI peripheral base address.


handle pointer to spi_master_handle_t structure which stores the transfer state
xfer pointer to spi_xfer_config_t structure

Return values

kStatus_Success Successfully start a transfer.

MCUXpresso SDK API Reference Manual


620 NXP Semiconductors
SPI Driver

kStatus_InvalidArgument Input argument is invalid.


kStatus_SPI_Busy SPI is not idle, is running another transfer.

27.2.6.30 static status_t SPI_SlaveTransferGetCount ( SPI_Type ∗ base,


spi_slave_handle_t ∗ handle, size_t ∗ count ) [inline], [static]

Parameters

base SPI peripheral base address.


handle Pointer to SPI transfer handle, this should be a static variable.
count Transferred bytes of SPI slave.

Return values

kStatus_SPI_Success Succeed get the transfer count.


kStatus_NoTransferIn- There is not a non-blocking transaction currently in progress.
Progress

27.2.6.31 static void SPI_SlaveTransferAbort ( SPI_Type ∗ base, spi_slave_handle_t ∗


handle ) [inline], [static]

Parameters

base SPI peripheral base address.


handle Pointer to SPI transfer handle, this should be a static variable.

27.2.6.32 void SPI_SlaveTransferHandleIRQ ( SPI_Type ∗ base, spi_slave_handle_t ∗


handle )

Parameters

base SPI peripheral base address.


handle pointer to spi_slave_handle_t structure which stores the transfer state

MCUXpresso SDK API Reference Manual


NXP Semiconductors 621
SPI Driver

27.2.7 Variable Documentation

27.2.7.1 volatile uint8_t g_spiDummyData[ ]

MCUXpresso SDK API Reference Manual


622 NXP Semiconductors
SPI DMA Driver

27.3 SPI DMA Driver


27.3.1 Overview

This section describes the programming interface of the SPI DMA driver.

Data Structures

• struct spi_dma_handle_t
SPI DMA transfer handle, users should not touch the content of the handle. More...

Typedefs

• typedef void(∗ spi_dma_callback_t )(SPI_Type ∗base, spi_dma_handle_t ∗handle, status_t status,


void ∗userData)
SPI DMA callback called at the end of transfer.

Driver version

• #define FSL_SPI_DMA_DRIVER_VERSION (MAKE_VERSION(2, 0, 4))


SPI DMA driver version 2.0.4.

DMA Transactional

• void SPI_MasterTransferCreateHandleDMA (SPI_Type ∗base, spi_dma_handle_t ∗handle, spi_-


dma_callback_t callback, void ∗userData, dma_handle_t ∗txHandle, dma_handle_t ∗rxHandle)
Initialize the SPI master DMA handle.
• status_t SPI_MasterTransferDMA (SPI_Type ∗base, spi_dma_handle_t ∗handle, spi_transfer_-
t ∗xfer)
Perform a non-blocking SPI transfer using DMA.
• void SPI_MasterTransferAbortDMA (SPI_Type ∗base, spi_dma_handle_t ∗handle)
Abort a SPI transfer using DMA.
• status_t SPI_MasterTransferGetCountDMA (SPI_Type ∗base, spi_dma_handle_t ∗handle, size_-
t ∗count)
Get the transferred bytes for SPI slave DMA.
• static void SPI_SlaveTransferCreateHandleDMA (SPI_Type ∗base, spi_dma_handle_t ∗handle, spi-
_dma_callback_t callback, void ∗userData, dma_handle_t ∗txHandle, dma_handle_t ∗rxHandle)
Initialize the SPI slave DMA handle.
• static status_t SPI_SlaveTransferDMA (SPI_Type ∗base, spi_dma_handle_t ∗handle, spi_transfer_t
∗xfer)
Perform a non-blocking SPI transfer using DMA.
• static void SPI_SlaveTransferAbortDMA (SPI_Type ∗base, spi_dma_handle_t ∗handle)
Abort a SPI transfer using DMA.
• static status_t SPI_SlaveTransferGetCountDMA (SPI_Type ∗base, spi_dma_handle_t ∗handle, size-
_t ∗count)

MCUXpresso SDK API Reference Manual


NXP Semiconductors 623
SPI DMA Driver

Get the transferred bytes for SPI slave DMA.

27.3.2 Data Structure Documentation

27.3.2.1 struct _spi_dma_handle

Data Fields
• bool txInProgress
Send transfer finished.
• bool rxInProgress
Receive transfer finished.
• dma_handle_t ∗ txHandle
DMA handler for SPI send.
• dma_handle_t ∗ rxHandle
DMA handler for SPI receive.
• uint8_t bytesPerFrame
Bytes in a frame for SPI transfer.
• spi_dma_callback_t callback
Callback for SPI DMA transfer.
• void ∗ userData
User Data for SPI DMA callback.
• uint32_t state
Internal state of SPI DMA transfer.
• size_t transferSize
Bytes need to be transfer.

27.3.3 Macro Definition Documentation

27.3.3.1 #define FSL_SPI_DMA_DRIVER_VERSION (MAKE_VERSION(2, 0, 4))

27.3.4 Typedef Documentation

27.3.4.1 typedef void(∗ spi_dma_callback_t)(SPI_Type ∗base, spi_dma_handle_t ∗handle,


status_t status, void ∗userData)

27.3.5 Function Documentation

27.3.5.1 void SPI_MasterTransferCreateHandleDMA ( SPI_Type ∗ base, spi_dma_handle_t


∗ handle, spi_dma_callback_t callback, void ∗ userData, dma_handle_t ∗
txHandle, dma_handle_t ∗ rxHandle )

This function initializes the SPI master DMA handle which can be used for other SPI master transactional
APIs. Usually, for a specified SPI instance, user need only call this API once to get the initialized handle.

MCUXpresso SDK API Reference Manual


624 NXP Semiconductors
SPI DMA Driver

Parameters

base SPI peripheral base address.


handle SPI handle pointer.
callback User callback function called at the end of a transfer.
userData User data for callback.
txHandle DMA handle pointer for SPI Tx, the handle shall be static allocated by users.
rxHandle DMA handle pointer for SPI Rx, the handle shall be static allocated by users.

27.3.5.2 status_t SPI_MasterTransferDMA ( SPI_Type ∗ base, spi_dma_handle_t ∗


handle, spi_transfer_t ∗ xfer )

Note
This interface returned immediately after transfer initiates, users should call SPI_GetTransferStatus
to poll the transfer status to check whether SPI transfer finished.

Parameters

base SPI peripheral base address.


handle SPI DMA handle pointer.
xfer Pointer to dma transfer structure.

Return values

kStatus_Success Successfully start a transfer.


kStatus_InvalidArgument Input argument is invalid.
kStatus_SPI_Busy SPI is not idle, is running another transfer.

27.3.5.3 void SPI_MasterTransferAbortDMA ( SPI_Type ∗ base, spi_dma_handle_t ∗


handle )

Parameters

MCUXpresso SDK API Reference Manual


NXP Semiconductors 625
SPI DMA Driver

base SPI peripheral base address.


handle SPI DMA handle pointer.

27.3.5.4 status_t SPI_MasterTransferGetCountDMA ( SPI_Type ∗ base, spi_dma_handle_t


∗ handle, size_t ∗ count )

Parameters

base SPI peripheral base address.


handle SPI DMA handle pointer.
count Transferred bytes.

Return values

kStatus_SPI_Success Succeed get the transfer count.


kStatus_NoTransferIn- There is not a non-blocking transaction currently in progress.
Progress

27.3.5.5 static void SPI_SlaveTransferCreateHandleDMA ( SPI_Type ∗ base,


spi_dma_handle_t ∗ handle, spi_dma_callback_t callback, void ∗ userData,
dma_handle_t ∗ txHandle, dma_handle_t ∗ rxHandle ) [inline], [static]

This function initializes the SPI slave DMA handle which can be used for other SPI master transactional
APIs. Usually, for a specified SPI instance, user need only call this API once to get the initialized handle.
Parameters

base SPI peripheral base address.


handle SPI handle pointer.
callback User callback function called at the end of a transfer.
userData User data for callback.
txHandle DMA handle pointer for SPI Tx, the handle shall be static allocated by users.
rxHandle DMA handle pointer for SPI Rx, the handle shall be static allocated by users.

27.3.5.6 static status_t SPI_SlaveTransferDMA ( SPI_Type ∗ base, spi_dma_handle_t ∗


handle, spi_transfer_t ∗ xfer ) [inline], [static]

MCUXpresso SDK API Reference Manual


626 NXP Semiconductors
SPI DMA Driver

Note
This interface returned immediately after transfer initiates, users should call SPI_GetTransferStatus
to poll the transfer status to check whether SPI transfer finished.

Parameters

base SPI peripheral base address.


handle SPI DMA handle pointer.
xfer Pointer to dma transfer structure.

Return values

kStatus_Success Successfully start a transfer.


kStatus_InvalidArgument Input argument is invalid.
kStatus_SPI_Busy SPI is not idle, is running another transfer.

27.3.5.7 static void SPI_SlaveTransferAbortDMA ( SPI_Type ∗ base, spi_dma_handle_t ∗


handle ) [inline], [static]

Parameters

base SPI peripheral base address.


handle SPI DMA handle pointer.

27.3.5.8 static status_t SPI_SlaveTransferGetCountDMA ( SPI_Type ∗ base,


spi_dma_handle_t ∗ handle, size_t ∗ count ) [inline], [static]

Parameters

base SPI peripheral base address.


handle SPI DMA handle pointer.
count Transferred bytes.

Return values

MCUXpresso SDK API Reference Manual


NXP Semiconductors 627
SPI DMA Driver

kStatus_SPI_Success Succeed get the transfer count.


kStatus_NoTransferIn- There is not a non-blocking transaction currently in progress.
Progress

MCUXpresso SDK API Reference Manual


628 NXP Semiconductors
SPI FreeRTOS driver

27.4 SPI FreeRTOS driver


27.4.1 Overview

This section describes the programming interface of the SPI FreeRTOS driver.

Driver version

• #define FSL_SPI_FREERTOS_DRIVER_VERSION (MAKE_VERSION(2, 0, 4))


SPI freertos driver version 2.0.4.

SPI RTOS Operation

• status_t SPI_RTOS_Init (spi_rtos_handle_t ∗handle, SPI_Type ∗base, const spi_master_config_t


∗masterConfig, uint32_t srcClock_Hz)
Initializes SPI.
• status_t SPI_RTOS_Deinit (spi_rtos_handle_t ∗handle)
Deinitializes the SPI.
• status_t SPI_RTOS_Transfer (spi_rtos_handle_t ∗handle, spi_transfer_t ∗transfer)
Performs SPI transfer.

27.4.2 Macro Definition Documentation

27.4.2.1 #define FSL_SPI_FREERTOS_DRIVER_VERSION (MAKE_VERSION(2, 0, 4))

27.4.3 Function Documentation

27.4.3.1 status_t SPI_RTOS_Init ( spi_rtos_handle_t ∗ handle, SPI_Type ∗ base, const


spi_master_config_t ∗ masterConfig, uint32_t srcClock_Hz )

This function initializes the SPI module and related RTOS context.
Parameters

handle The RTOS SPI handle, the pointer to an allocated space for RTOS context.
base The pointer base address of the SPI instance to initialize.
masterConfig Configuration structure to set-up SPI in master mode.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 629
SPI FreeRTOS driver

srcClock_Hz Frequency of input clock of the SPI module.

Returns
status of the operation.

27.4.3.2 status_t SPI_RTOS_Deinit ( spi_rtos_handle_t ∗ handle )

This function deinitializes the SPI module and related RTOS context.
Parameters

handle The RTOS SPI handle.

27.4.3.3 status_t SPI_RTOS_Transfer ( spi_rtos_handle_t ∗ handle, spi_transfer_t ∗


transfer )

This function performs an SPI transfer according to data given in the transfer structure.
Parameters

handle The RTOS SPI handle.


transfer Structure specifying the transfer parameters.

Returns
status of the operation.

MCUXpresso SDK API Reference Manual


630 NXP Semiconductors
Chapter 28
TPM: Timer PWM Module
28.1 Overview
The MCUXpresso SDK provides a driver for the Timer PWM Module (TPM) of MCUXpresso SDK
devices.
The TPM driver supports the generation of PWM signals, input capture, and output compare modes.
On some SoCs, the driver supports the generation of combined PWM signals, dual-edge capture, and
quadrature decoder modes. The driver also supports configuring each of the TPM fault inputs. The fault
input is available only on some SoCs.
The function TPM_Init() initializes the TPM with a specified configurations. The function TPM_Get-
DefaultConfig() gets the default configurations. On some SoCs, the initialization function issues a software
reset to reset the TPM internal logic. The initialization function configures the TPM’s behavior when it
receives a trigger input and its operation in doze and debug modes.
The function TPM_Deinit() disables the TPM counter and turns off the module clock.
The function TPM_SetupPwm() sets up TPM channels for the PWM output. The function can set up the
PWM signal properties for multiple channels. Each channel has its own tpm_chnl_pwm_signal_param_t
structure that is used to specify the output signals duty cycle and level-mode. However, the same PWM
period and PWM mode is applied to all channels requesting a PWM output. The signal duty cycle is
provided as a percentage of the PWM period. Its value should be between 0 and 100 where 0=inactive
signal (0% duty cycle) and 100=always active signal (100% duty cycle). When generating a combined
PWM signal, the channel number passed refers to a channel pair number, for example 0 refers to channel
0 and 1, 1 refers to channels 2 and 3.
The function TPM_UpdatePwmDutycycle() updates the PWM signal duty cycle of a particular TPM chan-
nel.
The function TPM_UpdateChnlEdgeLevelSelect() updates the level select bits of a particular TPM chan-
nel. This can be used to disable the PWM output when making changes to the PWM signal.
The function TPM_SetupInputCapture() sets up a TPM channel for input capture. The user can specify
the capture edge.
The function TPM_SetupDualEdgeCapture() can be used to measure the pulse width of a signal. This is
available only for certain SoCs. A channel pair is used during the capture with the input signal coming
through a channel that can be configured. The user can specify the capture edge for each channel and any
filter value to be used when processing the input signal.
The function TPM_SetupOutputCompare() sets up a TPM channel for output comparison. The user can
specify the channel output on a successful comparison and a comparison value.
The function TPM_SetupQuadDecode() sets up TPM channels 0 and 1 for quad decode, which is available
only for certain SoCs. The user can specify the quad decode mode, polarity, and filter properties for each

MCUXpresso SDK API Reference Manual


NXP Semiconductors 631
Typical use case

input signal.
The function TPM_SetupFault() sets up the properties for each fault, which is available only for certain
SoCs. The user can specify the fault polarity and whether to use a filter on a fault input. The overall fault
filter value and fault control mode are set up during initialization.
Provides functions to get and clear the TPM status.
Provides functions to enable/disable TPM interrupts and get current enabled interrupts.

28.2 Typical use case


28.2.1 PWM output

Output the PWM signal on 2 TPM channels with different duty cycles. Periodically update the PW-
M signal duty cycle. Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOAR-
D>/driver_examples/tpm

Data Structures
• struct tpm_chnl_pwm_signal_param_t
Options to configure a TPM channel’s PWM signal. More...
• struct tpm_config_t
TPM config structure. More...

Enumerations
• enum tpm_chnl_t {
kTPM_Chnl_0 = 0U,
kTPM_Chnl_1,
kTPM_Chnl_2,
kTPM_Chnl_3,
kTPM_Chnl_4,
kTPM_Chnl_5,
kTPM_Chnl_6,
kTPM_Chnl_7 }
List of TPM channels.
• enum tpm_pwm_mode_t {
kTPM_EdgeAlignedPwm = 0U,
kTPM_CenterAlignedPwm }
TPM PWM operation modes.
• enum tpm_pwm_level_select_t {
kTPM_NoPwmSignal = 0U,
kTPM_LowTrue,
kTPM_HighTrue }
TPM PWM output pulse mode: high-true, low-true or no output.
• enum tpm_trigger_select_t
Trigger options available.

MCUXpresso SDK API Reference Manual


632 NXP Semiconductors
Typical use case

• enum tpm_trigger_source_t {
kTPM_TriggerSource_External = 0U,
kTPM_TriggerSource_Internal }
Trigger source options available.
• enum tpm_output_compare_mode_t {
kTPM_NoOutputSignal = (1U << TPM_CnSC_MSA_SHIFT),
kTPM_ToggleOnMatch = ((1U << TPM_CnSC_MSA_SHIFT) | (1U << TPM_CnSC_ELSA_S-
HIFT)),
kTPM_ClearOnMatch = ((1U << TPM_CnSC_MSA_SHIFT) | (2U << TPM_CnSC_ELSA_SH-
IFT)),
kTPM_SetOnMatch = ((1U << TPM_CnSC_MSA_SHIFT) | (3U << TPM_CnSC_ELSA_SHIF-
T)),
kTPM_HighPulseOutput = ((3U << TPM_CnSC_MSA_SHIFT) | (1U << TPM_CnSC_ELSA_-
SHIFT)),
kTPM_LowPulseOutput = ((3U << TPM_CnSC_MSA_SHIFT) | (2U << TPM_CnSC_ELSA_S-
HIFT)) }
TPM output compare modes.
• enum tpm_input_capture_edge_t {
kTPM_RisingEdge = (1U << TPM_CnSC_ELSA_SHIFT),
kTPM_FallingEdge = (2U << TPM_CnSC_ELSA_SHIFT),
kTPM_RiseAndFallEdge = (3U << TPM_CnSC_ELSA_SHIFT) }
TPM input capture edge.
• enum tpm_clock_source_t {
kTPM_SystemClock = 1U,
kTPM_ExternalClock }
TPM clock source selection.
• enum tpm_clock_prescale_t {
kTPM_Prescale_Divide_1 = 0U,
kTPM_Prescale_Divide_2,
kTPM_Prescale_Divide_4,
kTPM_Prescale_Divide_8,
kTPM_Prescale_Divide_16,
kTPM_Prescale_Divide_32,
kTPM_Prescale_Divide_64,
kTPM_Prescale_Divide_128 }
TPM prescale value selection for the clock source.
• enum tpm_interrupt_enable_t {
kTPM_Chnl0InterruptEnable = (1U << 0),
kTPM_Chnl1InterruptEnable = (1U << 1),
kTPM_Chnl2InterruptEnable = (1U << 2),
kTPM_Chnl3InterruptEnable = (1U << 3),
kTPM_Chnl4InterruptEnable = (1U << 4),
kTPM_Chnl5InterruptEnable = (1U << 5),
kTPM_Chnl6InterruptEnable = (1U << 6),
kTPM_Chnl7InterruptEnable = (1U << 7),
kTPM_TimeOverflowInterruptEnable = (1U << 8) }

MCUXpresso SDK API Reference Manual


NXP Semiconductors 633
Typical use case

List of TPM interrupts.


• enum tpm_status_flags_t {
kTPM_Chnl0Flag = (1U << 0),
kTPM_Chnl1Flag = (1U << 1),
kTPM_Chnl2Flag = (1U << 2),
kTPM_Chnl3Flag = (1U << 3),
kTPM_Chnl4Flag = (1U << 4),
kTPM_Chnl5Flag = (1U << 5),
kTPM_Chnl6Flag = (1U << 6),
kTPM_Chnl7Flag = (1U << 7),
kTPM_TimeOverflowFlag = (1U << 8) }
List of TPM flags.

Driver version
• #define FSL_TPM_DRIVER_VERSION (MAKE_VERSION(2, 0, 4))
Version 2.0.4.

Initialization and deinitialization


• void TPM_Init (TPM_Type ∗base, const tpm_config_t ∗config)
Ungates the TPM clock and configures the peripheral for basic operation.
• void TPM_Deinit (TPM_Type ∗base)
Stops the counter and gates the TPM clock.
• void TPM_GetDefaultConfig (tpm_config_t ∗config)
Fill in the TPM config struct with the default settings.

Channel mode operations


• status_t TPM_SetupPwm (TPM_Type ∗base, const tpm_chnl_pwm_signal_param_t ∗chnlParams,
uint8_t numOfChnls, tpm_pwm_mode_t mode, uint32_t pwmFreq_Hz, uint32_t srcClock_Hz)
Configures the PWM signal parameters.
• void TPM_UpdatePwmDutycycle (TPM_Type ∗base, tpm_chnl_t chnlNumber, tpm_pwm_mode_t
currentPwmMode, uint8_t dutyCyclePercent)
Update the duty cycle of an active PWM signal.
• void TPM_UpdateChnlEdgeLevelSelect (TPM_Type ∗base, tpm_chnl_t chnlNumber, uint8_t level)
Update the edge level selection for a channel.
• void TPM_SetupInputCapture (TPM_Type ∗base, tpm_chnl_t chnlNumber, tpm_input_capture_-
edge_t captureMode)
Enables capturing an input signal on the channel using the function parameters.
• void TPM_SetupOutputCompare (TPM_Type ∗base, tpm_chnl_t chnlNumber, tpm_output_-
compare_mode_t compareMode, uint32_t compareValue)
Configures the TPM to generate timed pulses.

Interrupt Interface
• void TPM_EnableInterrupts (TPM_Type ∗base, uint32_t mask)
Enables the selected TPM interrupts.
• void TPM_DisableInterrupts (TPM_Type ∗base, uint32_t mask)

MCUXpresso SDK API Reference Manual


634 NXP Semiconductors
Data Structure Documentation

Disables the selected TPM interrupts.


• uint32_t TPM_GetEnabledInterrupts (TPM_Type ∗base)
Gets the enabled TPM interrupts.

Status Interface
• static uint32_t TPM_GetStatusFlags (TPM_Type ∗base)
Gets the TPM status flags.
• static void TPM_ClearStatusFlags (TPM_Type ∗base, uint32_t mask)
Clears the TPM status flags.

Read and write the timer period


• static void TPM_SetTimerPeriod (TPM_Type ∗base, uint32_t ticks)
Sets the timer period in units of ticks.
• static uint32_t TPM_GetCurrentTimerCount (TPM_Type ∗base)
Reads the current timer counting value.

Timer Start and Stop


• static void TPM_StartTimer (TPM_Type ∗base, tpm_clock_source_t clockSource)
Starts the TPM counter.
• static void TPM_StopTimer (TPM_Type ∗base)
Stops the TPM counter.

28.3 Data Structure Documentation


28.3.1 struct tpm_chnl_pwm_signal_param_t

Data Fields

• tpm_chnl_t chnlNumber
TPM channel to configure.
• tpm_pwm_level_select_t level
PWM output active level select.
• uint8_t dutyCyclePercent
PWM pulse width, value should be between 0 to 100 0=inactive signal(0% duty cycle)...

28.3.1.0.0.28 Field Documentation

28.3.1.0.0.28.1 tpm_chnl_t tpm_chnl_pwm_signal_param_t::chnlNumber

In combined mode (available in some SoC’s, this represents the channel pair number

28.3.1.0.0.28.2 uint8_t tpm_chnl_pwm_signal_param_t::dutyCyclePercent

100=always active signal (100% duty cycle)

MCUXpresso SDK API Reference Manual


NXP Semiconductors 635
Enumeration Type Documentation

28.3.2 struct tpm_config_t

This structure holds the configuration settings for the TPM peripheral. To initialize this structure to rea-
sonable defaults, call the TPM_GetDefaultConfig() function and pass a pointer to your config structure
instance.
The config struct can be made const so it resides in flash

Data Fields

• tpm_clock_prescale_t prescale
Select TPM clock prescale value.
• bool useGlobalTimeBase
true: Use of an external global time base is enabled; false: disabled
• tpm_trigger_select_t triggerSelect
Input trigger to use for controlling the counter operation.
• tpm_trigger_source_t triggerSource
Decides if we use external or internal trigger.
• bool enableDoze
true: TPM counter is paused in doze mode; false: TPM counter continues in doze mode
• bool enableDebugMode
true: TPM counter continues in debug mode; false: TPM counter is paused in debug mode
• bool enableReloadOnTrigger
true: TPM counter is reloaded on trigger; false: TPM counter not reloaded
• bool enableStopOnOverflow
true: TPM counter stops after overflow; false: TPM counter continues running after overflow
• bool enableStartOnTrigger
true: TPM counter only starts when a trigger is detected; false: TPM counter starts immediately
• bool enablePauseOnTrigger
true: TPM counter will pause while trigger remains asserted; false: TPM counter continues running

28.3.2.0.0.29 Field Documentation

28.3.2.0.0.29.1 tpm_trigger_source_t tpm_config_t::triggerSource

28.4 Enumeration Type Documentation


28.4.1 enum tpm_chnl_t

Note
Actual number of available channels is SoC dependent

Enumerator
kTPM_Chnl_0 TPM channel number 0.
kTPM_Chnl_1 TPM channel number 1.
kTPM_Chnl_2 TPM channel number 2.
kTPM_Chnl_3 TPM channel number 3.

MCUXpresso SDK API Reference Manual


636 NXP Semiconductors
Enumeration Type Documentation

kTPM_Chnl_4 TPM channel number 4.


kTPM_Chnl_5 TPM channel number 5.
kTPM_Chnl_6 TPM channel number 6.
kTPM_Chnl_7 TPM channel number 7.

28.4.2 enum tpm_pwm_mode_t

Enumerator
kTPM_EdgeAlignedPwm Edge aligned PWM.
kTPM_CenterAlignedPwm Center aligned PWM.

28.4.3 enum tpm_pwm_level_select_t

Enumerator
kTPM_NoPwmSignal No PWM output on pin.
kTPM_LowTrue Low true pulses.
kTPM_HighTrue High true pulses.

28.4.4 enum tpm_trigger_select_t

This is used for both internal & external trigger sources (external option available in certain SoC’s)

Note
The actual trigger options available is SoC-specific.

28.4.5 enum tpm_trigger_source_t

Note
This selection is available only on some SoC’s. For SoC’s without this selection, the only trigger
source available is internal triger.

Enumerator
kTPM_TriggerSource_External Use external trigger input.
kTPM_TriggerSource_Internal Use internal trigger.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 637
Enumeration Type Documentation

28.4.6 enum tpm_output_compare_mode_t

Enumerator
kTPM_NoOutputSignal No channel output when counter reaches CnV.
kTPM_ToggleOnMatch Toggle output.
kTPM_ClearOnMatch Clear output.
kTPM_SetOnMatch Set output.
kTPM_HighPulseOutput Pulse output high.
kTPM_LowPulseOutput Pulse output low.

28.4.7 enum tpm_input_capture_edge_t

Enumerator
kTPM_RisingEdge Capture on rising edge only.
kTPM_FallingEdge Capture on falling edge only.
kTPM_RiseAndFallEdge Capture on rising or falling edge.

28.4.8 enum tpm_clock_source_t

Enumerator
kTPM_SystemClock System clock.
kTPM_ExternalClock External clock.

28.4.9 enum tpm_clock_prescale_t

Enumerator
kTPM_Prescale_Divide_1 Divide by 1.
kTPM_Prescale_Divide_2 Divide by 2.
kTPM_Prescale_Divide_4 Divide by 4.
kTPM_Prescale_Divide_8 Divide by 8.
kTPM_Prescale_Divide_16 Divide by 16.
kTPM_Prescale_Divide_32 Divide by 32.
kTPM_Prescale_Divide_64 Divide by 64.
kTPM_Prescale_Divide_128 Divide by 128.

MCUXpresso SDK API Reference Manual


638 NXP Semiconductors
Function Documentation

28.4.10 enum tpm_interrupt_enable_t

Enumerator
kTPM_Chnl0InterruptEnable Channel 0 interrupt.
kTPM_Chnl1InterruptEnable Channel 1 interrupt.
kTPM_Chnl2InterruptEnable Channel 2 interrupt.
kTPM_Chnl3InterruptEnable Channel 3 interrupt.
kTPM_Chnl4InterruptEnable Channel 4 interrupt.
kTPM_Chnl5InterruptEnable Channel 5 interrupt.
kTPM_Chnl6InterruptEnable Channel 6 interrupt.
kTPM_Chnl7InterruptEnable Channel 7 interrupt.
kTPM_TimeOverflowInterruptEnable Time overflow interrupt.

28.4.11 enum tpm_status_flags_t

Enumerator
kTPM_Chnl0Flag Channel 0 flag.
kTPM_Chnl1Flag Channel 1 flag.
kTPM_Chnl2Flag Channel 2 flag.
kTPM_Chnl3Flag Channel 3 flag.
kTPM_Chnl4Flag Channel 4 flag.
kTPM_Chnl5Flag Channel 5 flag.
kTPM_Chnl6Flag Channel 6 flag.
kTPM_Chnl7Flag Channel 7 flag.
kTPM_TimeOverflowFlag Time overflow flag.

28.5 Function Documentation


28.5.1 void TPM_Init ( TPM_Type ∗ base, const tpm_config_t ∗ config )

Note
This API should be called at the beginning of the application using the TPM driver.

Parameters

base TPM peripheral base address

MCUXpresso SDK API Reference Manual


NXP Semiconductors 639
Function Documentation

config Pointer to user’s TPM config structure.

28.5.2 void TPM_Deinit ( TPM_Type ∗ base )

Parameters

base TPM peripheral base address

28.5.3 void TPM_GetDefaultConfig ( tpm_config_t ∗ config )

The default values are:

* config->prescale = kTPM_Prescale_Divide_1;
* config->useGlobalTimeBase = false;
* config->dozeEnable = false;
* config->dbgMode = false;
* config->enableReloadOnTrigger = false;
* config->enableStopOnOverflow = false;
* config->enableStartOnTrigger = false;
*#if FSL_FEATURE_TPM_HAS_PAUSE_COUNTER_ON_TRIGGER
* config->enablePauseOnTrigger = false;
*#endif
* config->triggerSelect = kTPM_Trigger_Select_0;
*#if FSL_FEATURE_TPM_HAS_EXTERNAL_TRIGGER_SELECTION
* config->triggerSource = kTPM_TriggerSource_External;
*#endif
*

Parameters

config Pointer to user’s TPM config structure.

28.5.4 status_t TPM_SetupPwm ( TPM_Type ∗ base, const tpm_chnl_pwm_signal-


_param_t ∗ chnlParams, uint8_t numOfChnls, tpm_pwm_mode_t mode,
uint32_t pwmFreq_Hz, uint32_t srcClock_Hz )

User calls this function to configure the PWM signals period, mode, dutycycle and edge. Use this function
to configure all the TPM channels that will be used to output a PWM signal

MCUXpresso SDK API Reference Manual


640 NXP Semiconductors
Function Documentation

Parameters

base TPM peripheral base address


chnlParams Array of PWM channel parameters to configure the channel(s)
numOfChnls Number of channels to configure, this should be the size of the array passed in
mode PWM operation mode, options available in enumeration tpm_pwm_mode_t
pwmFreq_Hz PWM signal frequency in Hz
srcClock_Hz TPM counter clock in Hz

Returns
kStatus_Success if the PWM setup was successful, kStatus_Error on failure

28.5.5 void TPM_UpdatePwmDutycycle ( TPM_Type ∗ base, tpm_chnl_t


chnlNumber, tpm_pwm_mode_t currentPwmMode, uint8_t
dutyCyclePercent )

Parameters

base TPM peripheral base address


chnlNumber The channel number. In combined mode, this represents the channel pair number
currentPwm- The current PWM mode set during PWM setup
Mode
dutyCycle- New PWM pulse width, value should be between 0 to 100 0=inactive signal(0% duty
Percent cycle)... 100=active signal (100% duty cycle)

28.5.6 void TPM_UpdateChnlEdgeLevelSelect ( TPM_Type ∗ base, tpm_chnl_t


chnlNumber, uint8_t level )

Parameters

base TPM peripheral base address

MCUXpresso SDK API Reference Manual


NXP Semiconductors 641
Function Documentation

chnlNumber The channel number


level The level to be set to the ELSnB:ELSnA field; valid values are 00, 01, 10, 11. See the
appropriate SoC reference manual for details about this field.

28.5.7 void TPM_SetupInputCapture ( TPM_Type ∗ base, tpm_chnl_t chnlNumber,


tpm_input_capture_edge_t captureMode )

When the edge specified in the captureMode argument occurs on the channel, the TPM counter is captured
into the CnV register. The user has to read the CnV register separately to get this value.
Parameters

base TPM peripheral base address


chnlNumber The channel number
captureMode Specifies which edge to capture

28.5.8 void TPM_SetupOutputCompare ( TPM_Type ∗ base, tpm_chnl_t


chnlNumber, tpm_output_compare_mode_t compareMode, uint32_t
compareValue )

When the TPM counter matches the value of compareVal argument (this is written into CnV reg), the
channel output is changed based on what is specified in the compareMode argument.
Parameters

base TPM peripheral base address


chnlNumber The channel number
compareMode Action to take on the channel output when the compare condition is met
compareValue Value to be programmed in the CnV register.

28.5.9 void TPM_EnableInterrupts ( TPM_Type ∗ base, uint32_t mask )

Parameters

MCUXpresso SDK API Reference Manual


642 NXP Semiconductors
Function Documentation

base TPM peripheral base address


mask The interrupts to enable. This is a logical OR of members of the enumeration tpm_-
interrupt_enable_t

28.5.10 void TPM_DisableInterrupts ( TPM_Type ∗ base, uint32_t mask )

Parameters

base TPM peripheral base address


mask The interrupts to disable. This is a logical OR of members of the enumeration tpm_-
interrupt_enable_t

28.5.11 uint32_t TPM_GetEnabledInterrupts ( TPM_Type ∗ base )

Parameters

base TPM peripheral base address

Returns
The enabled interrupts. This is the logical OR of members of the enumeration tpm_interrupt_enable-
_t

28.5.12 static uint32_t TPM_GetStatusFlags ( TPM_Type ∗ base ) [inline],


[static]

Parameters

base TPM peripheral base address

Returns
The status flags. This is the logical OR of members of the enumeration tpm_status_flags_t

28.5.13 static void TPM_ClearStatusFlags ( TPM_Type ∗ base, uint32_t mask )


[inline], [static]

MCUXpresso SDK API Reference Manual


NXP Semiconductors 643
Function Documentation

Parameters

base TPM peripheral base address


mask The status flags to clear. This is a logical OR of members of the enumeration tpm_-
status_flags_t

28.5.14 static void TPM_SetTimerPeriod ( TPM_Type ∗ base, uint32_t ticks )


[inline], [static]

Timers counts from 0 until it equals the count value set here. The count value is written to the MOD
register.

Note
1. This API allows the user to use the TPM module as a timer. Do not mix usage of this API with
TPM’s PWM setup API’s.
2. Call the utility macros provided in the fsl_common.h to convert usec or msec to ticks.

Parameters

base TPM peripheral base address


ticks A timer period in units of ticks, which should be equal or greater than 1.

28.5.15 static uint32_t TPM_GetCurrentTimerCount ( TPM_Type ∗ base )


[inline], [static]

This function returns the real-time timer counting value in a range from 0 to a timer period.

Note
Call the utility macros provided in the fsl_common.h to convert ticks to usec or msec.

Parameters

base TPM peripheral base address

Returns
The current counter value in ticks

MCUXpresso SDK API Reference Manual


644 NXP Semiconductors
Function Documentation

28.5.16 static void TPM_StartTimer ( TPM_Type ∗ base, tpm_clock_source_t


clockSource ) [inline], [static]

MCUXpresso SDK API Reference Manual


NXP Semiconductors 645
Function Documentation

Parameters

base TPM peripheral base address


clockSource TPM clock source; once clock source is set the counter will start running

28.5.17 static void TPM_StopTimer ( TPM_Type ∗ base ) [inline], [static]

Parameters

base TPM peripheral base address

MCUXpresso SDK API Reference Manual


646 NXP Semiconductors
Chapter 29
UART: Universal Asynchronous Receiver/Transmitter Driver
29.1 Overview
Modules
• UART DMA Driver
• UART Driver
• UART FreeRTOS Driver
• UART eDMA Driver

MCUXpresso SDK API Reference Manual


NXP Semiconductors 647
UART Driver

29.2 UART Driver


29.2.1 Overview

The MCUXpresso SDK provides a peripheral driver for the Universal Asynchronous Receiver/Transmitter
(UART) module of MCUXpresso SDK devices.
The UART driver includes functional APIs and transactional APIs.
Functional APIs are used for UART initialization/configuration/operation for optimization/customization
purpose. Using the functional API requires the knowledge of the UART peripheral and how to organize
functional APIs to meet the application requirements. All functional APIs use the peripheral base address
as the first parameter. UART functional operation groups provide the functional API set.
Transactional APIs can be used to enable the peripheral quickly and in the application if the code size
and performance of transactional APIs can satisfy the requirements. If the code size and performance are
critical requirements, see the transactional API implementation and write custom code. All transactional
APIs use the uart_handle_t as the second parameter. Initialize the handle by calling the UART_Transfer-
CreateHandle() API.
Transactional APIs support asynchronous transfer, which means that the functions UART_TransferSend-
NonBlocking() and UART_TransferReceiveNonBlocking() set up an interrupt for data transfer. When the
transfer completes, the upper layer is notified through a callback function with the kStatus_UART_TxIdle
and kStatus_UART_RxIdle.
Transactional receive APIs support the ring buffer. Prepare the memory for the ring buffer and pass in the
start address and size while calling the UART_TransferCreateHandle(). If passing NULL, the ring buffer
feature is disabled. When the ring buffer is enabled, the received data is saved to the ring buffer in the
background. The UART_TransferReceiveNonBlocking() function first gets data from the ring buffer. If
the ring buffer does not have enough data, the function first returns the data in the ring buffer and then
saves the received data to user memory. When all data is received, the upper layer is informed through a
callback with the kStatus_UART_RxIdle.
If the receive ring buffer is full, the upper layer is informed through a callback with the kStatus_UART-
_RxRingBufferOverrun. In the callback function, the upper layer reads data out from the ring buffer. If
not, existing data is overwritten by the new data.
The ring buffer size is specified when creating the handle. Note that one byte is reserved for the ring buffer
maintenance. When creating handle using the following code.
Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/uart
In this example, the buffer size is 32, but only 31 bytes are used for saving data.

29.2.2 Typical use case

29.2.2.1 UART Send/receive using a polling method

Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/uart

MCUXpresso SDK API Reference Manual


648 NXP Semiconductors
UART Driver

29.2.2.2 UART Send/receive using an interrupt method

Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/uart

29.2.2.3 UART Receive using the ringbuffer feature

Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/uart

29.2.2.4 UART Send/Receive using the DMA method

Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/uart

Data Structures

• struct uart_config_t
UART configuration structure. More...
• struct uart_transfer_t
UART transfer structure. More...
• struct uart_handle_t
UART handle structure. More...

Typedefs

• typedef void(∗ uart_transfer_callback_t )(UART_Type ∗base, uart_handle_t ∗handle, status_t sta-


tus, void ∗userData)
UART transfer callback function.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 649
UART Driver

Enumerations

• enum _uart_status {
kStatus_UART_TxBusy = MAKE_STATUS(kStatusGroup_UART, 0),
kStatus_UART_RxBusy = MAKE_STATUS(kStatusGroup_UART, 1),
kStatus_UART_TxIdle = MAKE_STATUS(kStatusGroup_UART, 2),
kStatus_UART_RxIdle = MAKE_STATUS(kStatusGroup_UART, 3),
kStatus_UART_TxWatermarkTooLarge = MAKE_STATUS(kStatusGroup_UART, 4),
kStatus_UART_RxWatermarkTooLarge = MAKE_STATUS(kStatusGroup_UART, 5),
kStatus_UART_FlagCannotClearManually,
kStatus_UART_Error = MAKE_STATUS(kStatusGroup_UART, 7),
kStatus_UART_RxRingBufferOverrun = MAKE_STATUS(kStatusGroup_UART, 8),
kStatus_UART_RxHardwareOverrun = MAKE_STATUS(kStatusGroup_UART, 9),
kStatus_UART_NoiseError = MAKE_STATUS(kStatusGroup_UART, 10),
kStatus_UART_FramingError = MAKE_STATUS(kStatusGroup_UART, 11),
kStatus_UART_ParityError = MAKE_STATUS(kStatusGroup_UART, 12),
kStatus_UART_BaudrateNotSupport,
kStatus_UART_IdleLineDetected = MAKE_STATUS(kStatusGroup_UART, 14) }
Error codes for the UART driver.
• enum uart_parity_mode_t {
kUART_ParityDisabled = 0x0U,
kUART_ParityEven = 0x2U,
kUART_ParityOdd = 0x3U }
UART parity mode.
• enum uart_stop_bit_count_t {
kUART_OneStopBit = 0U,
kUART_TwoStopBit = 1U }
UART stop bit count.
• enum uart_idle_type_select_t {
kUART_IdleTypeStartBit = 0U,
kUART_IdleTypeStopBit = 1U }
UART idle type select.
• enum _uart_interrupt_enable {
kUART_RxActiveEdgeInterruptEnable = (UART_BDH_RXEDGIE_MASK),
kUART_TxDataRegEmptyInterruptEnable = (UART_C2_TIE_MASK << 8),
kUART_TransmissionCompleteInterruptEnable = (UART_C2_TCIE_MASK << 8),
kUART_RxDataRegFullInterruptEnable = (UART_C2_RIE_MASK << 8),
kUART_IdleLineInterruptEnable = (UART_C2_ILIE_MASK << 8),
kUART_RxOverrunInterruptEnable = (UART_C3_ORIE_MASK << 16),
kUART_NoiseErrorInterruptEnable = (UART_C3_NEIE_MASK << 16),
kUART_FramingErrorInterruptEnable = (UART_C3_FEIE_MASK << 16),
kUART_ParityErrorInterruptEnable = (UART_C3_PEIE_MASK << 16) }
UART interrupt configuration structure, default settings all disabled.
• enum _uart_flags {

MCUXpresso SDK API Reference Manual


650 NXP Semiconductors
UART Driver

kUART_TxDataRegEmptyFlag = (UART_S1_TDRE_MASK),
kUART_TransmissionCompleteFlag = (UART_S1_TC_MASK),
kUART_RxDataRegFullFlag = (UART_S1_RDRF_MASK),
kUART_IdleLineFlag = (UART_S1_IDLE_MASK),
kUART_RxOverrunFlag = (UART_S1_OR_MASK),
kUART_NoiseErrorFlag = (UART_S1_NF_MASK),
kUART_FramingErrorFlag = (UART_S1_FE_MASK),
kUART_ParityErrorFlag = (UART_S1_PF_MASK),
kUART_RxActiveEdgeFlag,
kUART_RxActiveFlag }
UART status flags.

Functions

• uint32_t UART_GetInstance (UART_Type ∗base)


Get the UART instance from peripheral base address.

Driver version

• #define FSL_UART_DRIVER_VERSION (MAKE_VERSION(2, 1, 6))


UART driver version 2.1.6.

Initialization and deinitialization

• status_t UART_Init (UART_Type ∗base, const uart_config_t ∗config, uint32_t srcClock_Hz)


Initializes a UART instance with a user configuration structure and peripheral clock.
• void UART_Deinit (UART_Type ∗base)
Deinitializes a UART instance.
• void UART_GetDefaultConfig (uart_config_t ∗config)
Gets the default configuration structure.
• status_t UART_SetBaudRate (UART_Type ∗base, uint32_t baudRate_Bps, uint32_t srcClock_Hz)
Sets the UART instance baud rate.

Status

• uint32_t UART_GetStatusFlags (UART_Type ∗base)


Gets UART status flags.
• status_t UART_ClearStatusFlags (UART_Type ∗base, uint32_t mask)
Clears status flags with the provided mask.

Interrupts

• void UART_EnableInterrupts (UART_Type ∗base, uint32_t mask)

MCUXpresso SDK API Reference Manual


NXP Semiconductors 651
UART Driver

Enables UART interrupts according to the provided mask.


• void UART_DisableInterrupts (UART_Type ∗base, uint32_t mask)
Disables the UART interrupts according to the provided mask.
• uint32_t UART_GetEnabledInterrupts (UART_Type ∗base)
Gets the enabled UART interrupts.

DMA Control

• static uint32_t UART_GetDataRegisterAddress (UART_Type ∗base)


Gets the UART data register address.
• static void UART_EnableTxDMA (UART_Type ∗base, bool enable)
Enables or disables the UART transmitter DMA request.
• static void UART_EnableRxDMA (UART_Type ∗base, bool enable)
Enables or disables the UART receiver DMA.

Bus Operations

• static void UART_EnableTx (UART_Type ∗base, bool enable)


Enables or disables the UART transmitter.
• static void UART_EnableRx (UART_Type ∗base, bool enable)
Enables or disables the UART receiver.
• static void UART_WriteByte (UART_Type ∗base, uint8_t data)
Writes to the TX register.
• static uint8_t UART_ReadByte (UART_Type ∗base)
Reads the RX register directly.
• void UART_WriteBlocking (UART_Type ∗base, const uint8_t ∗data, size_t length)
Writes to the TX register using a blocking method.
• status_t UART_ReadBlocking (UART_Type ∗base, uint8_t ∗data, size_t length)
Read RX data register using a blocking method.

Transactional

• void UART_TransferCreateHandle (UART_Type ∗base, uart_handle_t ∗handle, uart_transfer_-


callback_t callback, void ∗userData)
Initializes the UART handle.
• void UART_TransferStartRingBuffer (UART_Type ∗base, uart_handle_t ∗handle, uint8_t ∗ring-
Buffer, size_t ringBufferSize)
Sets up the RX ring buffer.
• void UART_TransferStopRingBuffer (UART_Type ∗base, uart_handle_t ∗handle)
Aborts the background transfer and uninstalls the ring buffer.
• size_t UART_TransferGetRxRingBufferLength (uart_handle_t ∗handle)
Get the length of received data in RX ring buffer.
• status_t UART_TransferSendNonBlocking (UART_Type ∗base, uart_handle_t ∗handle, uart_-
transfer_t ∗xfer)
Transmits a buffer of data using the interrupt method.
• void UART_TransferAbortSend (UART_Type ∗base, uart_handle_t ∗handle)
Aborts the interrupt-driven data transmit.

MCUXpresso SDK API Reference Manual


652 NXP Semiconductors
UART Driver

• status_t UART_TransferGetSendCount (UART_Type ∗base, uart_handle_t ∗handle, uint32_t


∗count)
Gets the number of bytes written to the UART TX register.
• status_t UART_TransferReceiveNonBlocking (UART_Type ∗base, uart_handle_t ∗handle, uart_-
transfer_t ∗xfer, size_t ∗receivedBytes)
Receives a buffer of data using an interrupt method.
• void UART_TransferAbortReceive (UART_Type ∗base, uart_handle_t ∗handle)
Aborts the interrupt-driven data receiving.
• status_t UART_TransferGetReceiveCount (UART_Type ∗base, uart_handle_t ∗handle, uint32_-
t ∗count)
Gets the number of bytes that have been received.
• void UART_TransferHandleIRQ (UART_Type ∗base, uart_handle_t ∗handle)
UART IRQ handle function.
• void UART_TransferHandleErrorIRQ (UART_Type ∗base, uart_handle_t ∗handle)
UART Error IRQ handle function.

29.2.3 Data Structure Documentation

29.2.3.1 struct uart_config_t

Data Fields
• uint32_t baudRate_Bps
UART baud rate.
• uart_parity_mode_t parityMode
Parity mode, disabled (default), even, odd.
• uart_idle_type_select_t idleType
IDLE type select.
• bool enableTx
Enable TX.
• bool enableRx
Enable RX.

29.2.3.1.0.30 Field Documentation

29.2.3.1.0.30.1 uart_idle_type_select_t uart_config_t::idleType

29.2.3.2 struct uart_transfer_t

Data Fields
• uint8_t ∗ data
The buffer of data to be transfer.
• size_t dataSize
The byte count to be transfer.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 653
UART Driver

29.2.3.2.0.31 Field Documentation

29.2.3.2.0.31.1 uint8_t∗ uart_transfer_t::data

29.2.3.2.0.31.2 size_t uart_transfer_t::dataSize

29.2.3.3 struct _uart_handle

Data Fields
• uint8_t ∗volatile txData
Address of remaining data to send.
• volatile size_t txDataSize
Size of the remaining data to send.
• size_t txDataSizeAll
Size of the data to send out.
• uint8_t ∗volatile rxData
Address of remaining data to receive.
• volatile size_t rxDataSize
Size of the remaining data to receive.
• size_t rxDataSizeAll
Size of the data to receive.
• uint8_t ∗ rxRingBuffer
Start address of the receiver ring buffer.
• size_t rxRingBufferSize
Size of the ring buffer.
• volatile uint16_t rxRingBufferHead
Index for the driver to store received data into ring buffer.
• volatile uint16_t rxRingBufferTail
Index for the user to get data from the ring buffer.
• uart_transfer_callback_t callback
Callback function.
• void ∗ userData
UART callback function parameter.
• volatile uint8_t txState
TX transfer state.
• volatile uint8_t rxState
RX transfer state.

MCUXpresso SDK API Reference Manual


654 NXP Semiconductors
UART Driver

29.2.3.3.0.32 Field Documentation

29.2.3.3.0.32.1 uint8_t∗ volatile uart_handle_t::txData

29.2.3.3.0.32.2 volatile size_t uart_handle_t::txDataSize

29.2.3.3.0.32.3 size_t uart_handle_t::txDataSizeAll

29.2.3.3.0.32.4 uint8_t∗ volatile uart_handle_t::rxData

29.2.3.3.0.32.5 volatile size_t uart_handle_t::rxDataSize

29.2.3.3.0.32.6 size_t uart_handle_t::rxDataSizeAll

29.2.3.3.0.32.7 uint8_t∗ uart_handle_t::rxRingBuffer

29.2.3.3.0.32.8 size_t uart_handle_t::rxRingBufferSize

29.2.3.3.0.32.9 volatile uint16_t uart_handle_t::rxRingBufferHead

29.2.3.3.0.32.10 volatile uint16_t uart_handle_t::rxRingBufferTail

29.2.3.3.0.32.11 uart_transfer_callback_t uart_handle_t::callback

29.2.3.3.0.32.12 void∗ uart_handle_t::userData

29.2.3.3.0.32.13 volatile uint8_t uart_handle_t::txState

29.2.4 Macro Definition Documentation

29.2.4.1 #define FSL_UART_DRIVER_VERSION (MAKE_VERSION(2, 1, 6))

29.2.5 Typedef Documentation

29.2.5.1 typedef void(∗ uart_transfer_callback_t)(UART_Type ∗base, uart_handle_t


∗handle, status_t status, void ∗userData)

29.2.6 Enumeration Type Documentation

29.2.6.1 enum _uart_status

Enumerator
kStatus_UART_TxBusy Transmitter is busy.
kStatus_UART_RxBusy Receiver is busy.
kStatus_UART_TxIdle UART transmitter is idle.
kStatus_UART_RxIdle UART receiver is idle.
kStatus_UART_TxWatermarkTooLarge TX FIFO watermark too large.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 655
UART Driver

kStatus_UART_RxWatermarkTooLarge RX FIFO watermark too large.


kStatus_UART_FlagCannotClearManually UART flag can’t be manually cleared.
kStatus_UART_Error Error happens on UART.
kStatus_UART_RxRingBufferOverrun UART RX software ring buffer overrun.
kStatus_UART_RxHardwareOverrun UART RX receiver overrun.
kStatus_UART_NoiseError UART noise error.
kStatus_UART_FramingError UART framing error.
kStatus_UART_ParityError UART parity error.
kStatus_UART_BaudrateNotSupport Baudrate is not support in current clock source.
kStatus_UART_IdleLineDetected UART IDLE line detected.

29.2.6.2 enum uart_parity_mode_t

Enumerator
kUART_ParityDisabled Parity disabled.
kUART_ParityEven Parity enabled, type even, bit setting: PE|PT = 10.
kUART_ParityOdd Parity enabled, type odd, bit setting: PE|PT = 11.

29.2.6.3 enum uart_stop_bit_count_t

Enumerator
kUART_OneStopBit One stop bit.
kUART_TwoStopBit Two stop bits.

29.2.6.4 enum uart_idle_type_select_t

Enumerator
kUART_IdleTypeStartBit Start counting after a valid start bit.
kUART_IdleTypeStopBit Start counting after a stop bit.

29.2.6.5 enum _uart_interrupt_enable

This structure contains the settings for all of the UART interrupt configurations.

Enumerator
kUART_RxActiveEdgeInterruptEnable RX active edge interrupt.
kUART_TxDataRegEmptyInterruptEnable Transmit data register empty interrupt.
kUART_TransmissionCompleteInterruptEnable Transmission complete interrupt.

MCUXpresso SDK API Reference Manual


656 NXP Semiconductors
UART Driver

kUART_RxDataRegFullInterruptEnable Receiver data register full interrupt.


kUART_IdleLineInterruptEnable Idle line interrupt.
kUART_RxOverrunInterruptEnable Receiver overrun interrupt.
kUART_NoiseErrorInterruptEnable Noise error flag interrupt.
kUART_FramingErrorInterruptEnable Framing error flag interrupt.
kUART_ParityErrorInterruptEnable Parity error flag interrupt.

29.2.6.6 enum _uart_flags

This provides constants for the UART status flags for use in the UART functions.
Enumerator
kUART_TxDataRegEmptyFlag TX data register empty flag.
kUART_TransmissionCompleteFlag Transmission complete flag.
kUART_RxDataRegFullFlag RX data register full flag.
kUART_IdleLineFlag Idle line detect flag.
kUART_RxOverrunFlag RX overrun flag.
kUART_NoiseErrorFlag RX takes 3 samples of each received bit. If any of these samples differ,
noise flag sets
kUART_FramingErrorFlag Frame error flag, sets if logic 0 was detected where stop bit expected.
kUART_ParityErrorFlag If parity enabled, sets upon parity error detection.
kUART_RxActiveEdgeFlag RX pin active edge interrupt flag,sets when active edge detected.
kUART_RxActiveFlag Receiver Active Flag (RAF), sets at beginning of valid start bit.

29.2.7 Function Documentation

29.2.7.1 uint32_t UART_GetInstance ( UART_Type ∗ base )

Parameters

base UART peripheral base address.

Returns
UART instance.

29.2.7.2 status_t UART_Init ( UART_Type ∗ base, const uart_config_t ∗ config, uint32_t


srcClock_Hz )

This function configures the UART module with the user-defined settings. The user can configure the
configuration structure and also get the default configuration by using the UART_GetDefaultConfig()
function. The example below shows how to use this API to configure UART.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 657
UART Driver

* uart_config_t uartConfig;
* uartConfig.baudRate_Bps = 115200U;
* uartConfig.parityMode = kUART_ParityDisabled;
* uartConfig.stopBitCount = kUART_OneStopBit;
* uartConfig.txFifoWatermark = 0;
* uartConfig.rxFifoWatermark = 1;
* UART_Init(UART1, &uartConfig, 20000000U);
*

Parameters

base UART peripheral base address.


config Pointer to the user-defined configuration structure.
srcClock_Hz UART clock source frequency in HZ.

Return values

kStatus_UART_Baudrate- Baudrate is not support in current clock source.


NotSupport
kStatus_Success Status UART initialize succeed

29.2.7.3 void UART_Deinit ( UART_Type ∗ base )

This function waits for TX complete, disables TX and RX, and disables the UART clock.
Parameters

base UART peripheral base address.

29.2.7.4 void UART_GetDefaultConfig ( uart_config_t ∗ config )

This function initializes the UART configuration structure to a default value. The default values are
as follows. uartConfig->baudRate_Bps = 115200U; uartConfig->bitCountPerChar = kUART_8BitsPer-
Char; uartConfig->parityMode = kUART_ParityDisabled; uartConfig->stopBitCount = kUART_One-
StopBit; uartConfig->txFifoWatermark = 0; uartConfig->rxFifoWatermark = 1; uartConfig->idleType =
kUART_IdleTypeStartBit; uartConfig->enableTx = false; uartConfig->enableRx = false;
Parameters

MCUXpresso SDK API Reference Manual


658 NXP Semiconductors
UART Driver

config Pointer to configuration structure.

29.2.7.5 status_t UART_SetBaudRate ( UART_Type ∗ base, uint32_t baudRate_Bps,


uint32_t srcClock_Hz )

This function configures the UART module baud rate. This function is used to update the UART module
baud rate after the UART module is initialized by the UART_Init.

* UART_SetBaudRate(UART1, 115200U, 20000000U);


*

Parameters

base UART peripheral base address.


baudRate_Bps UART baudrate to be set.
srcClock_Hz UART clock source frequency in Hz.

Return values

kStatus_UART_Baudrate- Baudrate is not support in the current clock source.


NotSupport
kStatus_Success Set baudrate succeeded.

29.2.7.6 uint32_t UART_GetStatusFlags ( UART_Type ∗ base )

This function gets all UART status flags. The flags are returned as the logical OR value of the enumerators
_uart_flags. To check a specific status, compare the return value with enumerators in _uart_flags. For
example, to check whether the TX is empty, do the following.

* if (kUART_TxDataRegEmptyFlag & UART_GetStatusFlags(UART1))


* {
* ...
* }
*

Parameters

MCUXpresso SDK API Reference Manual


NXP Semiconductors 659
UART Driver

base UART peripheral base address.

Returns
UART status flags which are ORed by the enumerators in the _uart_flags.

29.2.7.7 status_t UART_ClearStatusFlags ( UART_Type ∗ base, uint32_t mask )

This function clears UART status flags with a provided mask. An automatically cleared flag can’t be
cleared by this function. These flags can only be cleared or set by hardware. kUART_TxDataRegEmpty-
Flag, kUART_TransmissionCompleteFlag, kUART_RxDataRegFullFlag, kUART_RxActiveFlag, kUA-
RT_NoiseErrorInRxDataRegFlag, kUART_ParityErrorInRxDataRegFlag, kUART_TxFifoEmptyFlag,k-
UART_RxFifoEmptyFlag Note that this API should be called when the Tx/Rx is idle. Otherwise it has no
effect.
Parameters

base UART peripheral base address.


mask The status flags to be cleared; it is logical OR value of _uart_flags.

Return values

kStatus_UART_Flag- The flag can’t be cleared by this function but it is cleared automatically by
CannotClearManually hardware.
kStatus_Success Status in the mask is cleared.

29.2.7.8 void UART_EnableInterrupts ( UART_Type ∗ base, uint32_t mask )

This function enables the UART interrupts according to the provided mask. The mask is a logical OR of
enumeration members. See _uart_interrupt_enable. For example, to enable TX empty interrupt and RX
full interrupt, do the following.

* UART_EnableInterrupts(UART1,
kUART_TxDataRegEmptyInterruptEnable |
kUART_RxDataRegFullInterruptEnable);
*

MCUXpresso SDK API Reference Manual


660 NXP Semiconductors
UART Driver

Parameters

base UART peripheral base address.


mask The interrupts to enable. Logical OR of _uart_interrupt_enable.

29.2.7.9 void UART_DisableInterrupts ( UART_Type ∗ base, uint32_t mask )

This function disables the UART interrupts according to the provided mask. The mask is a logical OR of
enumeration members. See _uart_interrupt_enable. For example, to disable TX empty interrupt and RX
full interrupt do the following.

* UART_DisableInterrupts(UART1,
kUART_TxDataRegEmptyInterruptEnable |
kUART_RxDataRegFullInterruptEnable);
*

Parameters

base UART peripheral base address.


mask The interrupts to disable. Logical OR of _uart_interrupt_enable.

29.2.7.10 uint32_t UART_GetEnabledInterrupts ( UART_Type ∗ base )

This function gets the enabled UART interrupts. The enabled interrupts are returned as the logical OR
value of the enumerators _uart_interrupt_enable. To check a specific interrupts enable status, compare
the return value with enumerators in _uart_interrupt_enable. For example, to check whether TX empty
interrupt is enabled, do the following.

* uint32_t enabledInterrupts = UART_GetEnabledInterrupts(UART1);


*
* if (kUART_TxDataRegEmptyInterruptEnable & enabledInterrupts)
* {
* ...
* }
*

Parameters

base UART peripheral base address.

Returns
UART interrupt flags which are logical OR of the enumerators in _uart_interrupt_enable.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 661
UART Driver

29.2.7.11 static uint32_t UART_GetDataRegisterAddress ( UART_Type ∗ base )


[inline], [static]

This function returns the UART data register address, which is mainly used by DMA/eDMA.

MCUXpresso SDK API Reference Manual


662 NXP Semiconductors
UART Driver

Parameters

base UART peripheral base address.

Returns
UART data register addresses which are used both by the transmitter and the receiver.

29.2.7.12 static void UART_EnableTxDMA ( UART_Type ∗ base, bool enable )


[inline], [static]

This function enables or disables the transmit data register empty flag, S1[TDRE], to generate the DMA
requests.
Parameters

base UART peripheral base address.


enable True to enable, false to disable.

29.2.7.13 static void UART_EnableRxDMA ( UART_Type ∗ base, bool enable )


[inline], [static]

This function enables or disables the receiver data register full flag, S1[RDRF], to generate DMA requests.
Parameters

base UART peripheral base address.


enable True to enable, false to disable.

29.2.7.14 static void UART_EnableTx ( UART_Type ∗ base, bool enable ) [inline],


[static]

This function enables or disables the UART transmitter.


Parameters

MCUXpresso SDK API Reference Manual


NXP Semiconductors 663
UART Driver

base UART peripheral base address.


enable True to enable, false to disable.

29.2.7.15 static void UART_EnableRx ( UART_Type ∗ base, bool enable ) [inline],


[static]

This function enables or disables the UART receiver.


Parameters

base UART peripheral base address.


enable True to enable, false to disable.

29.2.7.16 static void UART_WriteByte ( UART_Type ∗ base, uint8_t data ) [inline],


[static]

This function writes data to the TX register directly. The upper layer must ensure that the TX register is
empty or TX FIFO has empty room before calling this function.
Parameters

base UART peripheral base address.


data The byte to write.

29.2.7.17 static uint8_t UART_ReadByte ( UART_Type ∗ base ) [inline], [static]

This function reads data from the RX register directly. The upper layer must ensure that the RX register is
full or that the TX FIFO has data before calling this function.
Parameters

base UART peripheral base address.

MCUXpresso SDK API Reference Manual


664 NXP Semiconductors
UART Driver

Returns
The byte read from UART data register.

29.2.7.18 void UART_WriteBlocking ( UART_Type ∗ base, const uint8_t ∗ data, size_t


length )

This function polls the TX register, waits for the TX register to be empty or for the TX FIFO to have room
and writes data to the TX buffer.

Note
This function does not check whether all data is sent out to the bus. Before disabling the TX, check
kUART_TransmissionCompleteFlag to ensure that the TX is finished.

Parameters

base UART peripheral base address.


data Start address of the data to write.
length Size of the data to write.

29.2.7.19 status_t UART_ReadBlocking ( UART_Type ∗ base, uint8_t ∗ data, size_t


length )

This function polls the RX register, waits for the RX register to be full or for RX FIFO to have data, and
reads data from the TX register.
Parameters

base UART peripheral base address.


data Start address of the buffer to store the received data.
length Size of the buffer.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 665
UART Driver

Return values

kStatus_UART_Rx- Receiver overrun occurred while receiving data.


HardwareOverrun
kStatus_UART_Noise- A noise error occurred while receiving data.
Error
kStatus_UART_Framing- A framing error occurred while receiving data.
Error
kStatus_UART_Parity- A parity error occurred while receiving data.
Error
kStatus_Success Successfully received all data.

29.2.7.20 void UART_TransferCreateHandle ( UART_Type ∗ base, uart_handle_t ∗ handle,


uart_transfer_callback_t callback, void ∗ userData )

This function initializes the UART handle which can be used for other UART transactional APIs. Usually,
for a specified UART instance, call this API once to get the initialized handle.
Parameters

base UART peripheral base address.


handle UART handle pointer.
callback The callback function.
userData The parameter of the callback function.

29.2.7.21 void UART_TransferStartRingBuffer ( UART_Type ∗ base, uart_handle_t ∗


handle, uint8_t ∗ ringBuffer, size_t ringBufferSize )

This function sets up the RX ring buffer to a specific UART handle.


When the RX ring buffer is used, data received are stored into the ring buffer even when the user doesn’t
call the UART_TransferReceiveNonBlocking() API. If data is already received in the ring buffer, the user
can get the received data from the ring buffer directly.

Note
When using the RX ring buffer, one byte is reserved for internal use. In other words, if ring-
BufferSize is 32, only 31 bytes are used for saving data.

MCUXpresso SDK API Reference Manual


666 NXP Semiconductors
UART Driver

Parameters

base UART peripheral base address.


handle UART handle pointer.
ringBuffer Start address of the ring buffer for background receiving. Pass NULL to disable the
ring buffer.
ringBufferSize Size of the ring buffer.

29.2.7.22 void UART_TransferStopRingBuffer ( UART_Type ∗ base, uart_handle_t ∗


handle )

This function aborts the background transfer and uninstalls the ring buffer.
Parameters

base UART peripheral base address.


handle UART handle pointer.

29.2.7.23 size_t UART_TransferGetRxRingBufferLength ( uart_handle_t ∗ handle )

Parameters

handle UART handle pointer.

Returns
Length of received data in RX ring buffer.

29.2.7.24 status_t UART_TransferSendNonBlocking ( UART_Type ∗ base, uart_handle_t


∗ handle, uart_transfer_t ∗ xfer )

This function sends data using an interrupt method. This is a non-blocking function, which returns directly
without waiting for all data to be written to the TX register. When all data is written to the TX register
in the ISR, the UART driver calls the callback function and passes the kStatus_UART_TxIdle as status
parameter.

Note
The kStatus_UART_TxIdle is passed to the upper layer when all data is written to the TX register.
However, it does not ensure that all data is sent out. Before disabling the TX, check the kUART_-
TransmissionCompleteFlag to ensure that the TX is finished.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 667
UART Driver

Parameters

base UART peripheral base address.


handle UART handle pointer.
xfer UART transfer structure. See uart_transfer_t.

Return values

kStatus_Success Successfully start the data transmission.


kStatus_UART_TxBusy Previous transmission still not finished; data not all written to TX register
yet.
kStatus_InvalidArgument Invalid argument.

29.2.7.25 void UART_TransferAbortSend ( UART_Type ∗ base, uart_handle_t ∗ handle )

This function aborts the interrupt-driven data sending. The user can get the remainBytes to find out how
many bytes are not sent out.
Parameters

base UART peripheral base address.


handle UART handle pointer.

29.2.7.26 status_t UART_TransferGetSendCount ( UART_Type ∗ base, uart_handle_t ∗


handle, uint32_t ∗ count )

This function gets the number of bytes written to the UART TX register by using the interrupt method.
Parameters

base UART peripheral base address.


handle UART handle pointer.
count Send bytes count.

Return values

kStatus_NoTransferIn- No send in progress.


Progress
kStatus_InvalidArgument The parameter is invalid.
kStatus_Success Get successfully through the parameter count;

MCUXpresso SDK API Reference Manual


668 NXP Semiconductors
UART Driver

29.2.7.27 status_t UART_TransferReceiveNonBlocking ( UART_Type ∗ base,


uart_handle_t ∗ handle, uart_transfer_t ∗ xfer, size_t ∗ receivedBytes )

This function receives data using an interrupt method. This is a non-blocking function, which returns
without waiting for all data to be received. If the RX ring buffer is used and not empty, the data in the ring
buffer is copied and the parameter receivedBytes shows how many bytes are copied from the ring
buffer. After copying, if the data in the ring buffer is not enough to read, the receive request is saved by the
UART driver. When the new data arrives, the receive request is serviced first. When all data is received,
the UART driver notifies the upper layer through a callback function and passes the status parameter k-
Status_UART_RxIdle. For example, the upper layer needs 10 bytes but there are only 5 bytes in the ring
buffer. The 5 bytes are copied to the xfer->data and this function returns with the parameter received-
Bytes set to 5. For the left 5 bytes, newly arrived data is saved from the xfer->data[5]. When 5 bytes
are received, the UART driver notifies the upper layer. If the RX ring buffer is not enabled, this function
enables the RX and RX interrupt to receive data to the xfer->data. When all data is received, the upper
layer is notified.
Parameters

base UART peripheral base address.


handle UART handle pointer.
xfer UART transfer structure, see uart_transfer_t.
receivedBytes Bytes received from the ring buffer directly.

Return values

kStatus_Success Successfully queue the transfer into transmit queue.


kStatus_UART_RxBusy Previous receive request is not finished.
kStatus_InvalidArgument Invalid argument.

29.2.7.28 void UART_TransferAbortReceive ( UART_Type ∗ base, uart_handle_t ∗ handle


)

This function aborts the interrupt-driven data receiving. The user can get the remainBytes to know how
many bytes are not received yet.
Parameters

base UART peripheral base address.


handle UART handle pointer.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 669
UART Driver

29.2.7.29 status_t UART_TransferGetReceiveCount ( UART_Type ∗ base, uart_handle_t ∗


handle, uint32_t ∗ count )

This function gets the number of bytes that have been received.

MCUXpresso SDK API Reference Manual


670 NXP Semiconductors
UART Driver

Parameters

base UART peripheral base address.


handle UART handle pointer.
count Receive bytes count.

Return values

kStatus_NoTransferIn- No receive in progress.


Progress
kStatus_InvalidArgument Parameter is invalid.
kStatus_Success Get successfully through the parameter count;

29.2.7.30 void UART_TransferHandleIRQ ( UART_Type ∗ base, uart_handle_t ∗ handle )

This function handles the UART transmit and receive IRQ request.
Parameters

base UART peripheral base address.


handle UART handle pointer.

29.2.7.31 void UART_TransferHandleErrorIRQ ( UART_Type ∗ base, uart_handle_t ∗


handle )

This function handles the UART error IRQ request.


Parameters

base UART peripheral base address.


handle UART handle pointer.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 671
UART DMA Driver

29.3 UART DMA Driver


29.3.1 Overview

Data Structures

• struct uart_dma_handle_t
UART DMA handle. More...

Typedefs

• typedef void(∗ uart_dma_transfer_callback_t )(UART_Type ∗base, uart_dma_handle_t ∗handle,


status_t status, void ∗userData)
UART transfer callback function.

Driver version

• #define FSL_UART_DMA_DRIVER_VERSION (MAKE_VERSION(2, 1, 6))


UART DMA driver version 2.1.6.

eDMA transactional

• void UART_TransferCreateHandleDMA (UART_Type ∗base, uart_dma_handle_t ∗handle, uart_-


dma_transfer_callback_t callback, void ∗userData, dma_handle_t ∗txDmaHandle, dma_handle_t
∗rxDmaHandle)
Initializes the UART handle which is used in transactional functions and sets the callback.
• status_t UART_TransferSendDMA (UART_Type ∗base, uart_dma_handle_t ∗handle, uart_-
transfer_t ∗xfer)
Sends data using DMA.
• status_t UART_TransferReceiveDMA (UART_Type ∗base, uart_dma_handle_t ∗handle, uart_-
transfer_t ∗xfer)
Receives data using DMA.
• void UART_TransferAbortSendDMA (UART_Type ∗base, uart_dma_handle_t ∗handle)
Aborts the send data using DMA.
• void UART_TransferAbortReceiveDMA (UART_Type ∗base, uart_dma_handle_t ∗handle)
Aborts the received data using DMA.
• status_t UART_TransferGetSendCountDMA (UART_Type ∗base, uart_dma_handle_t ∗handle,
uint32_t ∗count)
Gets the number of bytes written to UART TX register.
• status_t UART_TransferGetReceiveCountDMA (UART_Type ∗base, uart_dma_handle_t ∗handle,
uint32_t ∗count)
Gets the number of bytes that have been received.

MCUXpresso SDK API Reference Manual


672 NXP Semiconductors
UART DMA Driver

29.3.2 Data Structure Documentation

29.3.2.1 struct _uart_dma_handle

Data Fields
• UART_Type ∗ base
UART peripheral base address.
• uart_dma_transfer_callback_t callback
Callback function.
• void ∗ userData
UART callback function parameter.
• size_t rxDataSizeAll
Size of the data to receive.
• size_t txDataSizeAll
Size of the data to send out.
• dma_handle_t ∗ txDmaHandle
The DMA TX channel used.
• dma_handle_t ∗ rxDmaHandle
The DMA RX channel used.
• volatile uint8_t txState
TX transfer state.
• volatile uint8_t rxState
RX transfer state.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 673
UART DMA Driver

29.3.2.1.0.33 Field Documentation

29.3.2.1.0.33.1 UART_Type∗ uart_dma_handle_t::base

29.3.2.1.0.33.2 uart_dma_transfer_callback_t uart_dma_handle_t::callback

29.3.2.1.0.33.3 void∗ uart_dma_handle_t::userData

29.3.2.1.0.33.4 size_t uart_dma_handle_t::rxDataSizeAll

29.3.2.1.0.33.5 size_t uart_dma_handle_t::txDataSizeAll

29.3.2.1.0.33.6 dma_handle_t∗ uart_dma_handle_t::txDmaHandle

29.3.2.1.0.33.7 dma_handle_t∗ uart_dma_handle_t::rxDmaHandle

29.3.2.1.0.33.8 volatile uint8_t uart_dma_handle_t::txState

29.3.3 Macro Definition Documentation

29.3.3.1 #define FSL_UART_DMA_DRIVER_VERSION (MAKE_VERSION(2, 1, 6))

29.3.4 Typedef Documentation

29.3.4.1 typedef void(∗ uart_dma_transfer_callback_t)(UART_Type ∗base,


uart_dma_handle_t ∗handle, status_t status, void ∗userData)

29.3.5 Function Documentation

29.3.5.1 void UART_TransferCreateHandleDMA ( UART_Type ∗ base, uart_dma_handle_t


∗ handle, uart_dma_transfer_callback_t callback, void ∗ userData,
dma_handle_t ∗ txDmaHandle, dma_handle_t ∗ rxDmaHandle )

MCUXpresso SDK API Reference Manual


674 NXP Semiconductors
UART DMA Driver

Parameters

base UART peripheral base address.


handle Pointer to the uart_dma_handle_t structure.
callback UART callback, NULL means no callback.
userData User callback function data.
rxDmaHandle User requested DMA handle for the RX DMA transfer.
txDmaHandle User requested DMA handle for the TX DMA transfer.

29.3.5.2 status_t UART_TransferSendDMA ( UART_Type ∗ base, uart_dma_handle_t ∗


handle, uart_transfer_t ∗ xfer )

This function sends data using DMA. This is non-blocking function, which returns right away. When all
data is sent, the send callback function is called.
Parameters

base UART peripheral base address.


handle UART handle pointer.
xfer UART DMA transfer structure. See uart_transfer_t.

Return values

kStatus_Success if succeeded; otherwise failed.


kStatus_UART_TxBusy Previous transfer ongoing.
kStatus_InvalidArgument Invalid argument.

29.3.5.3 status_t UART_TransferReceiveDMA ( UART_Type ∗ base, uart_dma_handle_t ∗


handle, uart_transfer_t ∗ xfer )

This function receives data using DMA. This is non-blocking function, which returns right away. When
all data is received, the receive callback function is called.
Parameters

MCUXpresso SDK API Reference Manual


NXP Semiconductors 675
UART DMA Driver

base UART peripheral base address.


handle Pointer to the uart_dma_handle_t structure.
xfer UART DMA transfer structure. See uart_transfer_t.

Return values

kStatus_Success if succeeded; otherwise failed.


kStatus_UART_RxBusy Previous transfer on going.
kStatus_InvalidArgument Invalid argument.

29.3.5.4 void UART_TransferAbortSendDMA ( UART_Type ∗ base, uart_dma_handle_t ∗


handle )

This function aborts the sent data using DMA.


Parameters

base UART peripheral base address.


handle Pointer to uart_dma_handle_t structure.

29.3.5.5 void UART_TransferAbortReceiveDMA ( UART_Type ∗ base, uart_dma_handle_t


∗ handle )

This function abort receive data which using DMA.


Parameters

base UART peripheral base address.


handle Pointer to uart_dma_handle_t structure.

29.3.5.6 status_t UART_TransferGetSendCountDMA ( UART_Type ∗ base,


uart_dma_handle_t ∗ handle, uint32_t ∗ count )

This function gets the number of bytes written to UART TX register by DMA.

MCUXpresso SDK API Reference Manual


676 NXP Semiconductors
UART DMA Driver

Parameters

base UART peripheral base address.


handle UART handle pointer.
count Send bytes count.

Return values

kStatus_NoTransferIn- No send in progress.


Progress
kStatus_InvalidArgument Parameter is invalid.
kStatus_Success Get successfully through the parameter count;

29.3.5.7 status_t UART_TransferGetReceiveCountDMA ( UART_Type ∗ base,


uart_dma_handle_t ∗ handle, uint32_t ∗ count )

This function gets the number of bytes that have been received.
Parameters

base UART peripheral base address.


handle UART handle pointer.
count Receive bytes count.

Return values

kStatus_NoTransferIn- No receive in progress.


Progress
kStatus_InvalidArgument Parameter is invalid.
kStatus_Success Get successfully through the parameter count;

MCUXpresso SDK API Reference Manual


NXP Semiconductors 677
UART eDMA Driver

29.4 UART eDMA Driver


29.4.1 Overview

Data Structures

• struct uart_edma_handle_t
UART eDMA handle. More...

Typedefs

• typedef void(∗ uart_edma_transfer_callback_t )(UART_Type ∗base, uart_edma_handle_t ∗handle,


status_t status, void ∗userData)
UART transfer callback function.

Driver version

• #define FSL_UART_EDMA_DRIVER_VERSION (MAKE_VERSION(2, 1, 6))


UART EDMA driver version 2.1.6.

eDMA transactional

• void UART_TransferCreateHandleEDMA (UART_Type ∗base, uart_edma_handle_t ∗handle, uart-


_edma_transfer_callback_t callback, void ∗userData, edma_handle_t ∗txEdmaHandle, edma_-
handle_t ∗rxEdmaHandle)
Initializes the UART handle which is used in transactional functions.
• status_t UART_SendEDMA (UART_Type ∗base, uart_edma_handle_t ∗handle, uart_transfer_-
t ∗xfer)
Sends data using eDMA.
• status_t UART_ReceiveEDMA (UART_Type ∗base, uart_edma_handle_t ∗handle, uart_transfer_t
∗xfer)
Receives data using eDMA.
• void UART_TransferAbortSendEDMA (UART_Type ∗base, uart_edma_handle_t ∗handle)
Aborts the sent data using eDMA.
• void UART_TransferAbortReceiveEDMA (UART_Type ∗base, uart_edma_handle_t ∗handle)
Aborts the receive data using eDMA.
• status_t UART_TransferGetSendCountEDMA (UART_Type ∗base, uart_edma_handle_t ∗handle,
uint32_t ∗count)
Gets the number of bytes that have been written to UART TX register.
• status_t UART_TransferGetReceiveCountEDMA (UART_Type ∗base, uart_edma_handle_-
t ∗handle, uint32_t ∗count)
Gets the number of received bytes.

MCUXpresso SDK API Reference Manual


678 NXP Semiconductors
UART eDMA Driver

29.4.2 Data Structure Documentation

29.4.2.1 struct _uart_edma_handle

Data Fields
• uart_edma_transfer_callback_t callback
Callback function.
• void ∗ userData
UART callback function parameter.
• size_t rxDataSizeAll
Size of the data to receive.
• size_t txDataSizeAll
Size of the data to send out.
• edma_handle_t ∗ txEdmaHandle
The eDMA TX channel used.
• edma_handle_t ∗ rxEdmaHandle
The eDMA RX channel used.
• uint8_t nbytes
eDMA minor byte transfer count initially configured.
• volatile uint8_t txState
TX transfer state.
• volatile uint8_t rxState
RX transfer state.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 679
UART eDMA Driver

29.4.2.1.0.34 Field Documentation

29.4.2.1.0.34.1 uart_edma_transfer_callback_t uart_edma_handle_t::callback

29.4.2.1.0.34.2 void∗ uart_edma_handle_t::userData

29.4.2.1.0.34.3 size_t uart_edma_handle_t::rxDataSizeAll

29.4.2.1.0.34.4 size_t uart_edma_handle_t::txDataSizeAll

29.4.2.1.0.34.5 edma_handle_t∗ uart_edma_handle_t::txEdmaHandle

29.4.2.1.0.34.6 edma_handle_t∗ uart_edma_handle_t::rxEdmaHandle

29.4.2.1.0.34.7 uint8_t uart_edma_handle_t::nbytes

29.4.2.1.0.34.8 volatile uint8_t uart_edma_handle_t::txState

29.4.3 Macro Definition Documentation

29.4.3.1 #define FSL_UART_EDMA_DRIVER_VERSION (MAKE_VERSION(2, 1, 6))

29.4.4 Typedef Documentation

29.4.4.1 typedef void(∗ uart_edma_transfer_callback_t)(UART_Type ∗base,


uart_edma_handle_t ∗handle, status_t status, void ∗userData)

29.4.5 Function Documentation

29.4.5.1 void UART_TransferCreateHandleEDMA ( UART_Type ∗ base,


uart_edma_handle_t ∗ handle, uart_edma_transfer_callback_t callback, void ∗
userData, edma_handle_t ∗ txEdmaHandle, edma_handle_t ∗ rxEdmaHandle )

MCUXpresso SDK API Reference Manual


680 NXP Semiconductors
UART eDMA Driver

Parameters

base UART peripheral base address.


handle Pointer to the uart_edma_handle_t structure.
callback UART callback, NULL means no callback.
userData User callback function data.
rxEdmaHandle User-requested DMA handle for RX DMA transfer.
txEdmaHandle User-requested DMA handle for TX DMA transfer.

29.4.5.2 status_t UART_SendEDMA ( UART_Type ∗ base, uart_edma_handle_t ∗ handle,


uart_transfer_t ∗ xfer )

This function sends data using eDMA. This is a non-blocking function, which returns right away. When
all data is sent, the send callback function is called.
Parameters

base UART peripheral base address.


handle UART handle pointer.
xfer UART eDMA transfer structure. See uart_transfer_t.

Return values

kStatus_Success if succeeded; otherwise failed.


kStatus_UART_TxBusy Previous transfer ongoing.
kStatus_InvalidArgument Invalid argument.

29.4.5.3 status_t UART_ReceiveEDMA ( UART_Type ∗ base, uart_edma_handle_t ∗


handle, uart_transfer_t ∗ xfer )

This function receives data using eDMA. This is a non-blocking function, which returns right away. When
all data is received, the receive callback function is called.
Parameters

MCUXpresso SDK API Reference Manual


NXP Semiconductors 681
UART eDMA Driver

base UART peripheral base address.


handle Pointer to the uart_edma_handle_t structure.
xfer UART eDMA transfer structure. See uart_transfer_t.

Return values

kStatus_Success if succeeded; otherwise failed.


kStatus_UART_RxBusy Previous transfer ongoing.
kStatus_InvalidArgument Invalid argument.

29.4.5.4 void UART_TransferAbortSendEDMA ( UART_Type ∗ base, uart_edma_handle_t


∗ handle )

This function aborts sent data using eDMA.


Parameters

base UART peripheral base address.


handle Pointer to the uart_edma_handle_t structure.

29.4.5.5 void UART_TransferAbortReceiveEDMA ( UART_Type ∗ base,


uart_edma_handle_t ∗ handle )

This function aborts receive data using eDMA.


Parameters

base UART peripheral base address.


handle Pointer to the uart_edma_handle_t structure.

29.4.5.6 status_t UART_TransferGetSendCountEDMA ( UART_Type ∗ base,


uart_edma_handle_t ∗ handle, uint32_t ∗ count )

This function gets the number of bytes that have been written to UART TX register by DMA.

MCUXpresso SDK API Reference Manual


682 NXP Semiconductors
UART eDMA Driver

Parameters

base UART peripheral base address.


handle UART handle pointer.
count Send bytes count.

Return values

kStatus_NoTransferIn- No send in progress.


Progress
kStatus_InvalidArgument Parameter is invalid.
kStatus_Success Get successfully through the parameter count;

29.4.5.7 status_t UART_TransferGetReceiveCountEDMA ( UART_Type ∗ base,


uart_edma_handle_t ∗ handle, uint32_t ∗ count )

This function gets the number of received bytes.


Parameters

base UART peripheral base address.


handle UART handle pointer.
count Receive bytes count.

Return values

kStatus_NoTransferIn- No receive in progress.


Progress
kStatus_InvalidArgument Parameter is invalid.
kStatus_Success Get successfully through the parameter count;

MCUXpresso SDK API Reference Manual


NXP Semiconductors 683
UART FreeRTOS Driver

29.5 UART FreeRTOS Driver


29.5.1 Overview

Data Structures

• struct uart_rtos_config_t
UART configuration structure. More...

Driver version

• #define FSL_UART_FREERTOS_DRIVER_VERSION (MAKE_VERSION(2, 1, 6))


UART freertos driver version 2.1.6.

UART RTOS Operation

• int UART_RTOS_Init (uart_rtos_handle_t ∗handle, uart_handle_t ∗t_handle, const uart_rtos_-


config_t ∗cfg)
Initializes a UART instance for operation in RTOS.
• int UART_RTOS_Deinit (uart_rtos_handle_t ∗handle)
Deinitializes a UART instance for operation.

UART transactional Operation

• int UART_RTOS_Send (uart_rtos_handle_t ∗handle, const uint8_t ∗buffer, uint32_t length)


Sends data in the background.
• int UART_RTOS_Receive (uart_rtos_handle_t ∗handle, uint8_t ∗buffer, uint32_t length, size_t
∗received)
Receives data.

29.5.2 Data Structure Documentation

29.5.2.1 struct uart_rtos_config_t

Data Fields
• UART_Type ∗ base
UART base address.
• uint32_t srcclk
UART source clock in Hz.
• uint32_t baudrate
Desired communication speed.
• uart_parity_mode_t parity
Parity setting.

MCUXpresso SDK API Reference Manual


684 NXP Semiconductors
UART FreeRTOS Driver

• uart_stop_bit_count_t stopbits
Number of stop bits to use.
• uint8_t ∗ buffer
Buffer for background reception.
• uint32_t buffer_size
Size of buffer for background reception.

29.5.3 Macro Definition Documentation

29.5.3.1 #define FSL_UART_FREERTOS_DRIVER_VERSION (MAKE_VERSION(2, 1, 6))

29.5.4 Function Documentation

29.5.4.1 int UART_RTOS_Init ( uart_rtos_handle_t ∗ handle, uart_handle_t ∗ t_handle,


const uart_rtos_config_t ∗ cfg )

Parameters

handle The RTOS UART handle, the pointer to an allocated space for RTOS context.
t_handle The pointer to the allocated space to store the transactional layer internal state.
cfg The pointer to the parameters required to configure the UART after initialization.

Returns
0 succeed; otherwise fail.

29.5.4.2 int UART_RTOS_Deinit ( uart_rtos_handle_t ∗ handle )

This function deinitializes the UART module, sets all register values to reset value, and frees the resources.
Parameters

handle The RTOS UART handle.

29.5.4.3 int UART_RTOS_Send ( uart_rtos_handle_t ∗ handle, const uint8_t ∗ buffer,


uint32_t length )

This function sends data. It is a synchronous API. If the hardware buffer is full, the task is in the blocked
state.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 685
UART FreeRTOS Driver

Parameters

handle The RTOS UART handle.


buffer The pointer to the buffer to send.
length The number of bytes to send.

29.5.4.4 int UART_RTOS_Receive ( uart_rtos_handle_t ∗ handle, uint8_t ∗ buffer,


uint32_t length, size_t ∗ received )

This function receives data from UART. It is a synchronous API. If data is immediately available, it is
returned immediately and the number of bytes received.
Parameters

handle The RTOS UART handle.


buffer The pointer to the buffer to write received data.
length The number of bytes to receive.
received The pointer to a variable of size_t where the number of received data is filled.

MCUXpresso SDK API Reference Manual


686 NXP Semiconductors
Chapter 30
VREF: Voltage Reference Driver
30.1 Overview
The MCUXpresso SDK provides a peripheral driver for the Crossbar Voltage Reference (VREF) block of
MCUXpresso SDK devices.
The Voltage Reference(VREF) supplies an accurate 1.2 V voltage output that can be trimmed in 0.5 mV
steps. VREF can be used in applications to provide a reference voltage to external devices and to internal
analog peripherals, such as the ADC, DAC, or CMP. The voltage reference has operating modes that
provide different levels of supply rejection and power consumption.
To configure the VREF driver, configure vref_config_t structure in one of two ways.
1. Use the VREF_GetDefaultConfig() function.
2. Set the parameter in the vref_config_t structure.
To initialize the VREF driver, call the VREF_Init() function and pass a pointer to the vref_config_t struc-
ture.
To de-initialize the VREF driver, call the VREF_Deinit() function.

30.2 Typical use case and example


This example shows how to generate a reference voltage by using the VREF module.
Refer to the driver examples codes located at <SDK_ROOT>/boards/<BOARD>/driver_examples/vref

Data Structures
• struct vref_config_t
The description structure for the VREF module. More...

Enumerations
• enum vref_buffer_mode_t {
kVREF_ModeBandgapOnly = 0U,
kVREF_ModeHighPowerBuffer = 1U,
kVREF_ModeLowPowerBuffer = 2U }
VREF modes.

Driver version
• #define FSL_VREF_DRIVER_VERSION (MAKE_VERSION(2, 1, 1))
Version 2.1.1.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 687
Function Documentation

VREF functional operation


• void VREF_Init (VREF_Type ∗base, const vref_config_t ∗config)
Enables the clock gate and configures the VREF module according to the configuration structure.
• void VREF_Deinit (VREF_Type ∗base)
Stops and disables the clock for the VREF module.
• void VREF_GetDefaultConfig (vref_config_t ∗config)
Initializes the VREF configuration structure.
• void VREF_SetTrimVal (VREF_Type ∗base, uint8_t trimValue)
Sets a TRIM value for the reference voltage.
• static uint8_t VREF_GetTrimVal (VREF_Type ∗base)
Reads the value of the TRIM meaning output voltage.

30.3 Data Structure Documentation


30.3.1 struct vref_config_t

Data Fields

• vref_buffer_mode_t bufferMode
Buffer mode selection.

30.4 Macro Definition Documentation


30.4.1 #define FSL_VREF_DRIVER_VERSION (MAKE_VERSION(2, 1, 1))

30.5 Enumeration Type Documentation


30.5.1 enum vref_buffer_mode_t

Enumerator
kVREF_ModeBandgapOnly Bandgap on only, for stabilization and startup.
kVREF_ModeHighPowerBuffer High-power buffer mode enabled.
kVREF_ModeLowPowerBuffer Low-power buffer mode enabled.

30.6 Function Documentation


30.6.1 void VREF_Init ( VREF_Type ∗ base, const vref_config_t ∗ config )

This function must be called before calling all other VREF driver functions, read/write registers, and con-
figurations with user-defined settings. The example below shows how to set up vref_config_t parameters
and how to call the VREF_Init function by passing in these parameters. This is an example.

* vref_config_t vrefConfig;
* vrefConfig.bufferMode = kVREF_ModeHighPowerBuffer;
* vrefConfig.enableExternalVoltRef = false;
* vrefConfig.enableLowRef = false;
* VREF_Init(VREF, &vrefConfig);
*

MCUXpresso SDK API Reference Manual


688 NXP Semiconductors
Function Documentation

Parameters

base VREF peripheral address.


config Pointer to the configuration structure.

30.6.2 void VREF_Deinit ( VREF_Type ∗ base )

This function should be called to shut down the module. This is an example.

* vref_config_t vrefUserConfig;
* VREF_Init(VREF);
* VREF_GetDefaultConfig(&vrefUserConfig);
* ...
* VREF_Deinit(VREF);
*

Parameters

base VREF peripheral address.

30.6.3 void VREF_GetDefaultConfig ( vref_config_t ∗ config )

This function initializes the VREF configuration structure to default values. This is an example.

* vrefConfig->bufferMode = kVREF_ModeHighPowerBuffer;
* vrefConfig->enableExternalVoltRef = false;
* vrefConfig->enableLowRef = false;
*

Parameters

config Pointer to the initialization structure.

30.6.4 void VREF_SetTrimVal ( VREF_Type ∗ base, uint8_t trimValue )

This function sets a TRIM value for the reference voltage. Note that the TRIM value maximum is 0x3F.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 689
Function Documentation

Parameters

base VREF peripheral address.


trimValue Value of the trim register to set the output reference voltage (maximum 0x3F (6-bit)).

30.6.5 static uint8_t VREF_GetTrimVal ( VREF_Type ∗ base ) [inline],


[static]

This function gets the TRIM value from the TRM register.
Parameters

base VREF peripheral address.

Returns
Six-bit value of trim setting.

MCUXpresso SDK API Reference Manual


690 NXP Semiconductors
Chapter 31
Clock Driver
31.1 Overview
The MCUXpresso SDK provides APIs for MCUXpresso SDK devices’ clock operation.

Modules
• Multipurpose Clock Generator Lite (MCGLITE)

MCUXpresso SDK API Reference Manual


NXP Semiconductors 691
Multipurpose Clock Generator Lite (MCGLITE)

31.2 Multipurpose Clock Generator Lite (MCGLITE)


The MCUXpresso SDK provides a peripheral driver for the MCG_Lite module of MCUXpresso SDK
devices.

31.2.1 Function description

The MCG_Lite driver provides three kinds of APIs:


1. APIs to get the MCG_Lite frequency.
2. APIs for MCG_Lite mode.
3. APIs for OSC setup.

31.2.1.1 MCG_Lite clock frequency

The CLOCK_GetOutClkFreq(), CLOCK_GetInternalRefClkFreq() and CLOCK_GetPeriphClkFreq()


functions are used to get the frequency of MCGOUTCLK, MCGIRCLK, and MCGPCLK based on the
current hardware setting.

31.2.1.2 MCG_Lite mode

The function CLOCK_GetMode() gets the current MCG_Lite mode.


The function CLOCK_SetMcgliteConfig() sets the MCG_Lite to a desired configuration. The MCG_Lite
cannot switch between the LIRC2M and LIRC8M. Instead, the function switches to the HIRC mode first
and then switches to the target mode.

31.2.1.3 OSC configuration

To enable the OSC clock, the MCG_Lite is needed together with the OSC module. The function CLOCK-
_InitOsc0() uses the MCG_Lite and the OSC to initialize the OSC. The OSC should be configured based
on the board design.

MCUXpresso SDK API Reference Manual


692 NXP Semiconductors
Chapter 32
DMA Manager
32.1 Overview
DMA Manager provides a series of functions to manage the DMAMUX instances and channels.

32.2 Function groups


32.2.1 DMAMGR Initialization and De-initialization

This function group initializes and deinitializes the DMA Manager.

32.2.2 DMAMGR Operation

This function group requests/releases the DMAMUX channel and configures the channel request source.

32.3 Typical use case


32.3.1 DMAMGR static channel allocattion

uint8_t channel;
dmamanager_handle_t dmamanager_handle;

/* Initialize DMAMGR */
DMAMGR_Init(&dmamanager_handle, EXAMPLE_DMA_BASEADDR, DMA_CHANNEL_NUMBER, startChannel);
/* Request a DMAMUX channel by static allocate mechanism */
channel = kDMAMGR_STATIC_ALLOCATE;
DMAMGR_RequestChannel(&dmamanager_handle, kDmaRequestMux0AlwaysOn63, channel, &handle)
;

32.3.2 DMAMGR dynamic channel allocation

uint8_t channel;
dmamanager_handle_t dmamanager_handle;

/* Initialize DMAMGR */
DMAMGR_Init(&dmamanager_handle, EXAMPLE_DMA_BASEADDR, DMA_CHANNEL_NUMBER, startChannel);
/* Request a DMAMUX channel by Dynamic allocate mechanism */
channel = DMAMGR_DYNAMIC_ALLOCATE;
DMAMGR_RequestChannel(&dmamanager_handle, kDmaRequestMux0AlwaysOn63, channel, &handle)
;

Data Structures
• struct dmamanager_handle_t
dmamanager handle typedef. More...

MCUXpresso SDK API Reference Manual


NXP Semiconductors 693
Data Structure Documentation

Macros
• #define DMAMGR_DYNAMIC_ALLOCATE 0xFFU
Dynamic channel allocation mechanism.

Enumerations
• enum _dma_manager_status {
kStatus_DMAMGR_ChannelOccupied = MAKE_STATUS(kStatusGroup_DMAMGR, 0),
kStatus_DMAMGR_ChannelNotUsed = MAKE_STATUS(kStatusGroup_DMAMGR, 1),
kStatus_DMAMGR_NoFreeChannel = MAKE_STATUS(kStatusGroup_DMAMGR, 2) }
DMA manager status.

DMAMGR Initialization and De-initialization


• void DMAMGR_Init (dmamanager_handle_t ∗dmamanager_handle, DMA_Type ∗dma_base,
uint32_t channelNum, uint32_t startChannel)
Initializes the DMA manager.
• void DMAMGR_Deinit (dmamanager_handle_t ∗dmamanager_handle)
Deinitializes the DMA manager.

DMAMGR Operation
• status_t DMAMGR_RequestChannel (dmamanager_handle_t ∗dmamanager_handle, uint32_t
requestSource, uint32_t channel, void ∗handle)
Requests a DMA channel.
• status_t DMAMGR_ReleaseChannel (dmamanager_handle_t ∗dmamanager_handle, void ∗handle)
Releases a DMA channel.
• bool DMAMGR_IsChannelOccupied (dmamanager_handle_t ∗dmamanager_handle, uint32_t
channel)
Get a DMA channel status.

32.4 Data Structure Documentation


32.4.1 struct dmamanager_handle_t

Note
The contents of this structure are private and subject to change.

This dma manager handle structure is used to store the parameters transfered by users.And users shall not
free the memory before calling DMAMGR_Deinit, also shall not modify the contents of the memory.

Data Fields

• void ∗ dma_base
Peripheral DMA instance.
• uint32_t channelNum

MCUXpresso SDK API Reference Manual


694 NXP Semiconductors
Function Documentation

Channel numbers for the DMA instance which need to be managed by dma manager.
• uint32_t startChannel
The start channel that can be managed by dma manager,users need to transfer it with a certain number or
NULL.
• bool s_DMAMGR_Channels [64]
The s_DMAMGR_Channels is used to store dma manager state.
• uint32_t DmamuxInstanceStart
The DmamuxInstance is used to calculate the DMAMUX Instance according to the DMA Instance.
• uint32_t multiple
The multiple is used to calculate the multiple between DMAMUX count and DMA count.

32.4.1.0.0.35 Field Documentation

32.4.1.0.0.35.1 void∗ dmamanager_handle_t::dma_base

32.4.1.0.0.35.2 uint32_t dmamanager_handle_t::channelNum

32.4.1.0.0.35.3 uint32_t dmamanager_handle_t::startChannel

32.4.1.0.0.35.4 bool dmamanager_handle_t::s_DMAMGR_Channels[64]

32.4.1.0.0.35.5 uint32_t dmamanager_handle_t::DmamuxInstanceStart

32.4.1.0.0.35.6 uint32_t dmamanager_handle_t::multiple

32.5 Macro Definition Documentation


32.5.1 #define DMAMGR_DYNAMIC_ALLOCATE 0xFFU

32.6 Enumeration Type Documentation


32.6.1 enum _dma_manager_status

Enumerator
kStatus_DMAMGR_ChannelOccupied Channel has been occupied.
kStatus_DMAMGR_ChannelNotUsed Channel has not been used.
kStatus_DMAMGR_NoFreeChannel All channels have been occupied.

32.7 Function Documentation


32.7.1 void DMAMGR_Init ( dmamanager_handle_t ∗ dmamanager_handle,
DMA_Type ∗ dma_base, uint32_t channelNum, uint32_t startChannel )

This function initializes the DMA manager, ungates the DMAMUX clocks, and initializes the eDMA or
DMA peripherals.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 695
Function Documentation

Parameters

dmamanager_- DMA manager handle pointer, this structure is maintained by dma manager inter-
handle nal,users only need to transfer the structure to the function. And users shall not free
the memory before calling DMAMGR_Deinit, also shall not modify the contents of
the memory.
dma_base Peripheral DMA instance base pointer.
dmamux_base Peripheral DMAMUX instance base pointer.
channelNum Channel numbers for the DMA instance which need to be managed by dma manager.
startChannel The start channel that can be managed by dma manager.

32.7.2 void DMAMGR_Deinit ( dmamanager_handle_t ∗ dmamanager_handle )

This function deinitializes the DMA manager, disables the DMAMUX channels, gates the DMAMUX
clocks, and deinitializes the eDMA or DMA peripherals.
Parameters

dmamanager_- DMA manager handle pointer, this structure is maintained by dma manager inter-
handle nal,users only need to transfer the structure to the function. And users shall not free
the memory before calling DMAMGR_Deinit, also shall not modify the contents of
the memory.

32.7.3 status_t DMAMGR_RequestChannel ( dmamanager_handle_t ∗


dmamanager_handle, uint32_t requestSource, uint32_t channel, void ∗
handle )

This function requests a DMA channel which is not occupied. The two channels to allocate the mechanism
are dynamic and static channels. For the dynamic allocation mechanism (channe = DMAMGR_DYNAM-
IC_ALLOCATE), DMAMGR allocates a DMA channel according to the given request source and start-
Channel and then configures it. For static allocation mechanism, DMAMGR configures the given channel
according to the given request source and channel number.

MCUXpresso SDK API Reference Manual


696 NXP Semiconductors
Function Documentation

Parameters

dmamanager_- DMA manager handle pointer, this structure is maintained by dma manager inter-
handle nal,users only need to transfer the structure to the function. And users shall not free
the memory before calling DMAMGR_Deinit, also shall not modify the contents of
the memory.
requestSource DMA channel request source number. See the soc.h, see the enum dma_request_-
source_t
channel The channel number users want to occupy. If using the dynamic channel allocate
mechanism, set the channel equal to DMAMGR_DYNAMIC_ALLOCATE.
handle DMA or eDMA handle pointer.

Return values

kStatus_Success In a dynamic/static channel allocation mechanism, allocate the DMAMUX


channel successfully.
kStatus_DMAMGR_No- In a dynamic channel allocation mechanism, all DMAMUX channels are
FreeChannel occupied.
kStatus_DMAMGR_- In a static channel allocation mechanism, the given channel is occupied.
ChannelOccupied

32.7.4 status_t DMAMGR_ReleaseChannel ( dmamanager_handle_t ∗


dmamanager_handle, void ∗ handle )

This function releases an occupied DMA channel.


Parameters

dmamanager_- DMA manager handle pointer, this structure is maintained by dma manager inter-
handle nal,users only need to transfer the structure to the function. And users shall not free
the memory before calling DMAMGR_Deinit, also shall not modify the contents of
the memory.
handle DMA or eDMA handle pointer.

Return values

MCUXpresso SDK API Reference Manual


NXP Semiconductors 697
Function Documentation

kStatus_Success Releases the given channel successfully.


kStatus_DMAMGR_- The given channel to be released had not been used before.
ChannelNotUsed

32.7.5 bool DMAMGR_IsChannelOccupied ( dmamanager_handle_t ∗


dmamanager_handle, uint32_t channel )

This function get a DMA channel status. Return 0 indicates the channel has not been used, return 1
indicates the channel has been occupied.
Parameters

dmamanager_- DMA manager handle pointer, this structure is maintained by dma manager inter-
handle nal,users only need to transfer the structure to the function. And users shall not free
the memory before calling DMAMGR_Deinit, also shall not modify the contents of
the memory.
channel The channel number that users want get its status.

MCUXpresso SDK API Reference Manual


698 NXP Semiconductors
Chapter 33
Secure Digital Card/Embedded MultiMedia Card/SDIO card
33.1 Overview
The MCUXpresso SDK provides drivers to access the Secure Digital Card ,Embedded MultiMedia Card
and sdio card based on the SDHC/USDHC/SDIF driver.

Modules
• HOST adapter Driver
• MMC Card Driver
• SD Card Driver
• SDIO Card Driver

Data Structures
• struct sdio_fbr_t
sdio card FBR register More...
• struct sdio_common_cis_t
sdio card common CIS More...
• struct sdio_func_cis_t
sdio card function CIS More...
• struct sd_status_t
SD card status. More...
• struct sd_cid_t
SD card CID register. More...
• struct sd_csd_t
SD card CSD register. More...
• struct sd_scr_t
SD card SCR register. More...
• struct mmc_cid_t
MMC card CID register. More...
• struct mmc_csd_t
MMC card CSD register. More...
• struct mmc_extended_csd_t
MMC card Extended CSD register (unit: byte). More...
• struct mmc_extended_csd_config_t
MMC Extended CSD configuration. More...
• struct mmc_boot_config_t
MMC card boot configuration definition. More...

Macros
• #define FSL_SDMMC_DRIVER_VERSION (MAKE_VERSION(2U, 2U, 11U)) /∗2.2.11∗/
Middleware version.
• #define SWAP_WORD_BYTE_SEQUENCE(x) (__REV(x))

MCUXpresso SDK API Reference Manual


NXP Semiconductors 699
Overview

Reverse byte sequence in uint32_t.


• #define SWAP_HALF_WROD_BYTE_SEQUENCE(x) (__REV16(x))
Reverse byte sequence for each half word in uint32_t.
• #define FSL_SDMMC_MAX_VOLTAGE_RETRIES (1000U)
Maximum loop count to check the card operation voltage range.
• #define FSL_SDMMC_MAX_CMD_RETRIES (10U)
Maximum loop count to send the cmd.
• #define FSL_SDMMC_DEFAULT_BLOCK_SIZE (512U)
Default block size.
• #define SDMMC_GLOBAL_BUFFER_SIZE (128U)
SDMMC global data buffer size, word unit.
• #define SDMMC_ENABLE_SOFTWARE_TUNING (0U)
SDMMC enable software tuning.
• #define SDMMC_LOG(format,...)
SD/MMC error log.
• #define SDMMC_CLOCK_400KHZ (400000U)
SD/MMC card initialization clock frequency.
• #define SD_CLOCK_25MHZ (25000000U)
SD card bus frequency 1 in high-speed mode.
• #define SD_CLOCK_50MHZ (50000000U)
SD card bus frequency 2 in high-speed mode.
• #define SD_CLOCK_100MHZ (100000000U)
SD card bus frequency in SDR50 mode.
• #define SD_CLOCK_208MHZ (208000000U)
SD card bus frequency in SDR104 mode.
• #define MMC_CLOCK_26MHZ (26000000U)
MMC card bus frequency 1 in high-speed mode.
• #define MMC_CLOCK_52MHZ (52000000U)
MMC card bus frequency 2 in high-speed mode.
• #define MMC_CLOCK_DDR52 (52000000U)
MMC card bus frequency in high-speed DDR52 mode.
• #define MMC_CLOCK_HS200 (200000000U)
MMC card bus frequency in high-speed HS200 mode.
• #define MMC_CLOCK_HS400 (400000000U)
MMC card bus frequency in high-speed HS400 mode.
• #define SDMMC_MASK(bit) (1U << (bit))
mask convert
• #define SDMMC_R1_ALL_ERROR_FLAG
R1 all the error flag.
• #define SDMMC_R1_CURRENT_STATE(x) (((x)&0x00001E00U) >> 9U)
R1: current state.
• #define SDSPI_R7_VERSION_SHIFT (28U)
The bit mask for COMMAND VERSION field in R7.
• #define SDSPI_R7_VERSION_MASK (0xFU)
The bit mask for COMMAND VERSION field in R7.
• #define SDSPI_R7_VOLTAGE_SHIFT (8U)
The bit shift for VOLTAGE ACCEPTED field in R7.
• #define SDSPI_R7_VOLTAGE_MASK (0xFU)
The bit mask for VOLTAGE ACCEPTED field in R7.
• #define SDSPI_R7_VOLTAGE_27_36_MASK (0x1U << SDSPI_R7_VOLTAGE_SHIFT)
The bit mask for VOLTAGE 2.7V to 3.6V field in R7.

MCUXpresso SDK API Reference Manual


700 NXP Semiconductors
Overview

• #define SDSPI_R7_ECHO_SHIFT (0U)


The bit shift for ECHO field in R7.
• #define SDSPI_R7_ECHO_MASK (0xFFU)
The bit mask for ECHO field in R7.
• #define SDSPI_DATA_ERROR_TOKEN_MASK (0xFU)
Data error token mask.
• #define SDSPI_DATA_RESPONSE_TOKEN_MASK (0x1FU)
Mask for data response bits.
• #define SDIO_CCCR_REG_NUMBER (0x16U)
sdio card cccr register number
• #define SDIO_IO_READY_TIMEOUT_UNIT (10U)
sdio IO ready timeout steps
• #define SDIO_CMD_ARGUMENT_RW_POS (31U)
read/write flag position
• #define SDIO_CMD_ARGUMENT_FUNC_NUM_POS (28U)
function number position
• #define SDIO_DIRECT_CMD_ARGUMENT_RAW_POS (27U)
direct raw flag position
• #define SDIO_CMD_ARGUMENT_REG_ADDR_POS (9U)
direct reg addr position
• #define SDIO_CMD_ARGUMENT_REG_ADDR_MASK (0x1FFFFU)
direct reg addr mask
• #define SDIO_DIRECT_CMD_DATA_MASK (0xFFU)
data mask
• #define SDIO_EXTEND_CMD_ARGUMENT_BLOCK_MODE_POS (27U)
extended command argument block mode bit position
• #define SDIO_EXTEND_CMD_ARGUMENT_OP_CODE_POS (26U)
extended command argument OP Code bit position
• #define SDIO_EXTEND_CMD_BLOCK_MODE_MASK (0x08000000U)
block mode mask
• #define SDIO_EXTEND_CMD_OP_CODE_MASK (0x04000000U)
op code mask
• #define SDIO_EXTEND_CMD_COUNT_MASK (0x1FFU)
byte/block count mask
• #define SDIO_MAX_BLOCK_SIZE (2048U)
max block size
• #define SDIO_FBR_BASE(x) (x ∗ 0x100U)
function basic register
• #define SDIO_TPL_CODE_END (0xFFU)
tuple end
• #define SDIO_TPL_CODE_MANIFID (0x20U)
manufacturer ID
• #define SDIO_TPL_CODE_FUNCID (0x21U)
function ID
• #define SDIO_TPL_CODE_FUNCE (0x22U)
function extension tuple
• #define SDIO_OCR_VOLTAGE_WINDOW_MASK (0xFFFFU << 8U)
sdio ocr voltage window mask
• #define SDIO_OCR_IO_NUM_MASK (7U << kSDIO_OcrIONumber)
sdio ocr reigster IO NUMBER mask
• #define SDIO_CCCR_SUPPORT_HIGHSPEED (1u << 9U)

MCUXpresso SDK API Reference Manual


NXP Semiconductors 701
Overview

UHS timing mode flag.


• #define SDIO_CCCR_DRIVER_TYPE_MASK (3U << 4U)
Driver type flag.
• #define SDIO_CCCR_ASYNC_INT_MASK (1U)
aync interrupt flag
• #define SDIO_CCCR_SUPPORT_8BIT_BUS (1U << 18U)
8 bit data bus flag
• #define MMC_OCR_V170TO195_SHIFT (7U)
The bit mask for VOLTAGE WINDOW 1.70V to 1.95V field in OCR.
• #define MMC_OCR_V170TO195_MASK (0x00000080U)
The bit mask for VOLTAGE WINDOW 1.70V to 1.95V field in OCR.
• #define MMC_OCR_V200TO260_SHIFT (8U)
The bit shift for VOLTAGE WINDOW 2.00V to 2.60V field in OCR.
• #define MMC_OCR_V200TO260_MASK (0x00007F00U)
The bit mask for VOLTAGE WINDOW 2.00V to 2.60V field in OCR.
• #define MMC_OCR_V270TO360_SHIFT (15U)
The bit shift for VOLTAGE WINDOW 2.70V to 3.60V field in OCR.
• #define MMC_OCR_V270TO360_MASK (0x00FF8000U)
The bit mask for VOLTAGE WINDOW 2.70V to 3.60V field in OCR.
• #define MMC_OCR_ACCESS_MODE_SHIFT (29U)
The bit shift for ACCESS MODE field in OCR.
• #define MMC_OCR_ACCESS_MODE_MASK (0x60000000U)
The bit mask for ACCESS MODE field in OCR.
• #define MMC_OCR_BUSY_SHIFT (31U)
The bit shift for BUSY field in OCR.
• #define MMC_OCR_BUSY_MASK (1U << MMC_OCR_BUSY_SHIFT)
The bit mask for BUSY field in OCR.
• #define MMC_TRANSFER_SPEED_FREQUENCY_UNIT_SHIFT (0U)
The bit shift for FREQUENCY UNIT field in TRANSFER SPEED(TRAN-SPEED in Extended CSD)
• #define MMC_TRANSFER_SPEED_FREQUENCY_UNIT_MASK (0x07U)
The bit mask for FRQEUENCY UNIT in TRANSFER SPEED.
• #define MMC_TRANSFER_SPEED_MULTIPLIER_SHIFT (3U)
The bit shift for MULTIPLIER field in TRANSFER SPEED.
• #define MMC_TRANSFER_SPEED_MULTIPLIER_MASK (0x78U)
The bit mask for MULTIPLIER field in TRANSFER SPEED.
• #define READ_MMC_TRANSFER_SPEED_FREQUENCY_UNIT(CSD) (((CSD.transferSpeed)
& MMC_TRANSFER_SPEED_FREQUENCY_UNIT_MASK) >> MMC_TRANSFER_SPEED-
_FREQUENCY_UNIT_SHIFT)
Read the value of FREQUENCY UNIT in TRANSFER SPEED.
• #define READ_MMC_TRANSFER_SPEED_MULTIPLIER(CSD) (((CSD.transferSpeed) & MM-
C_TRANSFER_SPEED_MULTIPLIER_MASK) >> MMC_TRANSFER_SPEED_MULTIPLIE-
R_SHIFT)
Read the value of MULTIPLER filed in TRANSFER SPEED.
• #define MMC_POWER_CLASS_4BIT_MASK (0x0FU)
The power class value bit mask when bus in 4 bit mode.
• #define MMC_POWER_CLASS_8BIT_MASK (0xF0U)
The power class current value bit mask when bus in 8 bit mode.
• #define MMC_DATA_BUS_WIDTH_TYPE_NUMBER (3U)
The number of data bus width type.
• #define MMC_PARTITION_CONFIG_PARTITION_ACCESS_SHIFT (0U)
The bit shift for PARTITION ACCESS filed in BOOT CONFIG (BOOT_CONFIG in Extend CSD)

MCUXpresso SDK API Reference Manual


702 NXP Semiconductors
Overview

• #define MMC_PARTITION_CONFIG_PARTITION_ACCESS_MASK (0x00000007U)


The bit mask for PARTITION ACCESS field in BOOT CONFIG.
• #define MMC_PARTITION_CONFIG_PARTITION_ENABLE_SHIFT (3U)
The bit shift for PARTITION ENABLE field in BOOT CONFIG.
• #define MMC_PARTITION_CONFIG_PARTITION_ENABLE_MASK (0x00000038U)
The bit mask for PARTITION ENABLE field in BOOT CONFIG.
• #define MMC_PARTITION_CONFIG_BOOT_ACK_SHIFT (6U)
The bit shift for ACK field in BOOT CONFIG.
• #define MMC_PARTITION_CONFIG_BOOT_ACK_MASK (0x00000040U)
The bit mask for ACK field in BOOT CONFIG.
• #define MMC_BOOT_BUS_CONDITION_BUS_WIDTH_SHIFT (0U)
The bit shift for BOOT BUS WIDTH field in BOOT CONFIG.
• #define MMC_BOOT_BUS_CONDITION_BUS_WIDTH_MASK (3U)
The bit mask for BOOT BUS WIDTH field in BOOT CONFIG.
• #define MMC_BOOT_BUS_CONDITION_RESET_BUS_CONDITION_SHIFT (2U)
The bit shift for BOOT BUS WIDTH RESET field in BOOT CONFIG.
• #define MMC_BOOT_BUS_CONDITION_RESET_BUS_CONDITION_MASK (4U)
The bit mask for BOOT BUS WIDTH RESET field in BOOT CONFIG.
• #define MMC_BOOT_BUS_CONDITION_BOOT_MODE_MASK (0x18U)
The bit mask for BOOT BUS WIDTH RESET field in BOOT CONFIG.
• #define MMC_EXTENDED_CSD_BYTES (512U)
The length of Extended CSD register, unit as bytes.
• #define MMC_DEFAULT_RELATIVE_ADDRESS (2U)
MMC card default relative address.
• #define SD_PRODUCT_NAME_BYTES (5U)
SD card product name length united as bytes.
• #define SD_AU_START_VALUE (1U)
SD AU start value.
• #define SD_UHS_AU_START_VALUE (7U)
SD UHS AU start value.
• #define SD_TRANSFER_SPEED_RATE_UNIT_SHIFT (0U)
The bit shift for RATE UNIT field in TRANSFER SPEED.
• #define SD_TRANSFER_SPEED_RATE_UNIT_MASK (0x07U)
The bit mask for RATE UNIT field in TRANSFER SPEED.
• #define SD_TRANSFER_SPEED_TIME_VALUE_SHIFT (2U)
The bit shift for TIME VALUE field in TRANSFER SPEED.
• #define SD_TRANSFER_SPEED_TIME_VALUE_MASK (0x78U)
The bit mask for TIME VALUE field in TRANSFER SPEED.
• #define SD_RD_TRANSFER_SPEED_RATE_UNIT(x) (((x.transferSpeed) & SD_TRANSFER_-
SPEED_RATE_UNIT_MASK) >> SD_TRANSFER_SPEED_RATE_UNIT_SHIFT)
Read the value of FREQUENCY UNIT in TRANSFER SPEED field.
• #define SD_RD_TRANSFER_SPEED_TIME_VALUE(x) (((x.transferSpeed) & SD_TRANSFER-
_SPEED_TIME_VALUE_MASK) >> SD_TRANSFER_SPEED_TIME_VALUE_SHIFT)
Read the value of TIME VALUE in TRANSFER SPEED field.
• #define MMC_PRODUCT_NAME_BYTES (6U)
MMC card product name length united as bytes.
• #define MMC_SWITCH_COMMAND_SET_SHIFT (0U)
The bit shift for COMMAND SET field in SWITCH command.
• #define MMC_SWITCH_COMMAND_SET_MASK (0x00000007U)
The bit mask for COMMAND set field in SWITCH command.
• #define MMC_SWITCH_VALUE_SHIFT (8U)

MCUXpresso SDK API Reference Manual


NXP Semiconductors 703
Overview

The bit shift for VALUE field in SWITCH command.


• #define MMC_SWITCH_VALUE_MASK (0x0000FF00U)
The bit mask for VALUE field in SWITCH command.
• #define MMC_SWITCH_BYTE_INDEX_SHIFT (16U)
The bit shift for BYTE INDEX field in SWITCH command.
• #define MMC_SWITCH_BYTE_INDEX_MASK (0x00FF0000U)
The bit mask for BYTE INDEX field in SWITCH command.
• #define MMC_SWITCH_ACCESS_MODE_SHIFT (24U)
The bit shift for ACCESS MODE field in SWITCH command.
• #define MMC_SWTICH_ACCESS_MODE_MASK (0x03000000U)
The bit mask for ACCESS MODE field in SWITCH command.

Enumerations
• enum _sdmmc_status {
kStatus_SDMMC_NotSupportYet = MAKE_STATUS(kStatusGroup_SDMMC, 0U),
kStatus_SDMMC_TransferFailed = MAKE_STATUS(kStatusGroup_SDMMC, 1U),
kStatus_SDMMC_SetCardBlockSizeFailed = MAKE_STATUS(kStatusGroup_SDMMC, 2U),
kStatus_SDMMC_HostNotSupport = MAKE_STATUS(kStatusGroup_SDMMC, 3U),
kStatus_SDMMC_CardNotSupport = MAKE_STATUS(kStatusGroup_SDMMC, 4U),
kStatus_SDMMC_AllSendCidFailed = MAKE_STATUS(kStatusGroup_SDMMC, 5U),
kStatus_SDMMC_SendRelativeAddressFailed = MAKE_STATUS(kStatusGroup_SDMMC, 6U),
kStatus_SDMMC_SendCsdFailed = MAKE_STATUS(kStatusGroup_SDMMC, 7U),
kStatus_SDMMC_SelectCardFailed = MAKE_STATUS(kStatusGroup_SDMMC, 8U),
kStatus_SDMMC_SendScrFailed = MAKE_STATUS(kStatusGroup_SDMMC, 9U),
kStatus_SDMMC_SetDataBusWidthFailed = MAKE_STATUS(kStatusGroup_SDMMC, 10U),
kStatus_SDMMC_GoIdleFailed = MAKE_STATUS(kStatusGroup_SDMMC, 11U),
kStatus_SDMMC_HandShakeOperationConditionFailed,
kStatus_SDMMC_SendApplicationCommandFailed,
kStatus_SDMMC_SwitchFailed = MAKE_STATUS(kStatusGroup_SDMMC, 14U),
kStatus_SDMMC_StopTransmissionFailed = MAKE_STATUS(kStatusGroup_SDMMC, 15U),
kStatus_SDMMC_WaitWriteCompleteFailed = MAKE_STATUS(kStatusGroup_SDMMC, 16U),
kStatus_SDMMC_SetBlockCountFailed = MAKE_STATUS(kStatusGroup_SDMMC, 17U),
kStatus_SDMMC_SetRelativeAddressFailed = MAKE_STATUS(kStatusGroup_SDMMC, 18U),
kStatus_SDMMC_SwitchBusTimingFailed = MAKE_STATUS(kStatusGroup_SDMMC, 19U),
kStatus_SDMMC_SendExtendedCsdFailed = MAKE_STATUS(kStatusGroup_SDMMC, 20U),
kStatus_SDMMC_ConfigureBootFailed = MAKE_STATUS(kStatusGroup_SDMMC, 21U),
kStatus_SDMMC_ConfigureExtendedCsdFailed = MAKE_STATUS(kStatusGroup_SDMMC, 22-
U),
kStatus_SDMMC_EnableHighCapacityEraseFailed,
kStatus_SDMMC_SendTestPatternFailed = MAKE_STATUS(kStatusGroup_SDMMC, 24U),
kStatus_SDMMC_ReceiveTestPatternFailed = MAKE_STATUS(kStatusGroup_SDMMC, 25U),
kStatus_SDMMC_SDIO_ResponseError = MAKE_STATUS(kStatusGroup_SDMMC, 26U),
kStatus_SDMMC_SDIO_InvalidArgument,
kStatus_SDMMC_SDIO_SendOperationConditionFail,
kStatus_SDMMC_InvalidVoltage = MAKE_STATUS(kStatusGroup_SDMMC, 29U),
kStatus_SDMMC_SDIO_SwitchHighSpeedFail = MAKE_STATUS(kStatusGroup_SDMMC, 30-

MCUXpresso SDK API Reference Manual


704 NXP Semiconductors
Overview

U),
kStatus_SDMMC_SDIO_ReadCISFail = MAKE_STATUS(kStatusGroup_SDMMC, 31U),
kStatus_SDMMC_SDIO_InvalidCard = MAKE_STATUS(kStatusGroup_SDMMC, 32U),
kStatus_SDMMC_TuningFail = MAKE_STATUS(kStatusGroup_SDMMC, 33U),
kStatus_SDMMC_SwitchVoltageFail = MAKE_STATUS(kStatusGroup_SDMMC, 34U),
kStatus_SDMMC_SwitchVoltage18VFail33VSuccess = MAKE_STATUS(kStatusGroup_SDMM-
C, 35U),
kStatus_SDMMC_ReTuningRequest = MAKE_STATUS(kStatusGroup_SDMMC, 36U),
kStatus_SDMMC_SetDriverStrengthFail = MAKE_STATUS(kStatusGroup_SDMMC, 37U),
kStatus_SDMMC_SetPowerClassFail = MAKE_STATUS(kStatusGroup_SDMMC, 38U),
kStatus_SDMMC_HostNotReady = MAKE_STATUS(kStatusGroup_SDMMC, 39U),
kStatus_SDMMC_CardDetectFailed = MAKE_STATUS(kStatusGroup_SDMMC, 40U),
kStatus_SDMMC_AuSizeNotSetProperly = MAKE_STATUS(kStatusGroup_SDMMC, 41U) }
SD/MMC card API’s running status.
• enum sdmmc_operation_voltage_t {
kCARD_OperationVoltageNone = 0U,
kCARD_OperationVoltage330V = 1U,
kCARD_OperationVoltage300V = 2U,
kCARD_OperationVoltage180V = 3U }
card operation voltage
• enum _sdmmc_r1_card_status_flag {
kSDMMC_R1OutOfRangeFlag = 31,
kSDMMC_R1AddressErrorFlag = 30,
kSDMMC_R1BlockLengthErrorFlag = 29,
kSDMMC_R1EraseSequenceErrorFlag = 28,
kSDMMC_R1EraseParameterErrorFlag = 27,
kSDMMC_R1WriteProtectViolationFlag = 26,
kSDMMC_R1CardIsLockedFlag = 25,
kSDMMC_R1LockUnlockFailedFlag = 24,
kSDMMC_R1CommandCrcErrorFlag = 23,
kSDMMC_R1IllegalCommandFlag = 22,
kSDMMC_R1CardEccFailedFlag = 21,
kSDMMC_R1CardControllerErrorFlag = 20,
kSDMMC_R1ErrorFlag = 19,
kSDMMC_R1CidCsdOverwriteFlag = 16,
kSDMMC_R1WriteProtectEraseSkipFlag = 15,
kSDMMC_R1CardEccDisabledFlag = 14,
kSDMMC_R1EraseResetFlag = 13,
kSDMMC_R1ReadyForDataFlag = 8,
kSDMMC_R1SwitchErrorFlag = 7,
kSDMMC_R1ApplicationCommandFlag = 5,
kSDMMC_R1AuthenticationSequenceErrorFlag = 3 }
Card status bit in R1.
• enum sdmmc_r1_current_state_t {

MCUXpresso SDK API Reference Manual


NXP Semiconductors 705
Overview

kSDMMC_R1StateIdle = 0U,
kSDMMC_R1StateReady = 1U,
kSDMMC_R1StateIdentify = 2U,
kSDMMC_R1StateStandby = 3U,
kSDMMC_R1StateTransfer = 4U,
kSDMMC_R1StateSendData = 5U,
kSDMMC_R1StateReceiveData = 6U,
kSDMMC_R1StateProgram = 7U,
kSDMMC_R1StateDisconnect = 8U }
CURRENT_STATE filed in R1.
• enum _sdspi_r1_error_status_flag {
kSDSPI_R1InIdleStateFlag = (1U << 0U),
kSDSPI_R1EraseResetFlag = (1U << 1U),
kSDSPI_R1IllegalCommandFlag = (1U << 2U),
kSDSPI_R1CommandCrcErrorFlag = (1U << 3U),
kSDSPI_R1EraseSequenceErrorFlag = (1U << 4U),
kSDSPI_R1AddressErrorFlag = (1U << 5U),
kSDSPI_R1ParameterErrorFlag = (1U << 6U) }
Error bit in SPI mode R1.
• enum _sdspi_r2_error_status_flag {
kSDSPI_R2CardLockedFlag = (1U << 0U),
kSDSPI_R2WriteProtectEraseSkip = (1U << 1U),
kSDSPI_R2LockUnlockFailed = (1U << 1U),
kSDSPI_R2ErrorFlag = (1U << 2U),
kSDSPI_R2CardControllerErrorFlag = (1U << 3U),
kSDSPI_R2CardEccFailedFlag = (1U << 4U),
kSDSPI_R2WriteProtectViolationFlag = (1U << 5U),
kSDSPI_R2EraseParameterErrorFlag = (1U << 6U),
kSDSPI_R2OutOfRangeFlag = (1U << 7U),
kSDSPI_R2CsdOverwriteFlag = (1U << 7U) }
Error bit in SPI mode R2.
• enum _sdspi_data_error_token {
kSDSPI_DataErrorTokenError = (1U << 0U),
kSDSPI_DataErrorTokenCardControllerError = (1U << 1U),
kSDSPI_DataErrorTokenCardEccFailed = (1U << 2U),
kSDSPI_DataErrorTokenOutOfRange = (1U << 3U) }
Data Error Token mask bit.
• enum sdspi_data_token_t {
kSDSPI_DataTokenBlockRead = 0xFEU,
kSDSPI_DataTokenSingleBlockWrite = 0xFEU,
kSDSPI_DataTokenMultipleBlockWrite = 0xFCU,
kSDSPI_DataTokenStopTransfer = 0xFDU }
Data Token.
• enum sdspi_data_response_token_t {
kSDSPI_DataResponseTokenAccepted = 0x05U,
kSDSPI_DataResponseTokenCrcError = 0x0BU,

MCUXpresso SDK API Reference Manual


706 NXP Semiconductors
Overview

kSDSPI_DataResponseTokenWriteError = 0x0DU }
Data Response Token.
• enum sd_command_t {
kSD_SendRelativeAddress = 3U,
kSD_Switch = 6U,
kSD_SendInterfaceCondition = 8U,
kSD_VoltageSwitch = 11U,
kSD_SpeedClassControl = 20U,
kSD_EraseWriteBlockStart = 32U,
kSD_EraseWriteBlockEnd = 33U,
kSD_SendTuningBlock = 19U }
SD card individual commands.
• enum sdspi_command_t { kSDSPI_CommandCrc = 59U }
SDSPI individual commands.
• enum sd_application_command_t {
kSD_ApplicationSetBusWdith = 6U,
kSD_ApplicationStatus = 13U,
kSD_ApplicationSendNumberWriteBlocks = 22U,
kSD_ApplicationSetWriteBlockEraseCount = 23U,
kSD_ApplicationSendOperationCondition = 41U,
kSD_ApplicationSetClearCardDetect = 42U,
kSD_ApplicationSendScr = 51U }
SD card individual application commands.
• enum _sdmmc_command_class {
kSDMMC_CommandClassBasic = (1U << 0U),
kSDMMC_CommandClassBlockRead = (1U << 2U),
kSDMMC_CommandClassBlockWrite = (1U << 4U),
kSDMMC_CommandClassErase = (1U << 5U),
kSDMMC_CommandClassWriteProtect = (1U << 6U),
kSDMMC_CommandClassLockCard = (1U << 7U),
kSDMMC_CommandClassApplicationSpecific = (1U << 8U),
kSDMMC_CommandClassInputOutputMode = (1U << 9U),
kSDMMC_CommandClassSwitch = (1U << 10U) }
SD card command class.
• enum _sd_ocr_flag {

MCUXpresso SDK API Reference Manual


NXP Semiconductors 707
Overview

kSD_OcrPowerUpBusyFlag = 31,
kSD_OcrHostCapacitySupportFlag = 30,
kSD_OcrCardCapacitySupportFlag = kSD_OcrHostCapacitySupportFlag,
kSD_OcrSwitch18RequestFlag = 24,
kSD_OcrSwitch18AcceptFlag = kSD_OcrSwitch18RequestFlag,
kSD_OcrVdd27_28Flag = 15,
kSD_OcrVdd28_29Flag = 16,
kSD_OcrVdd29_30Flag = 17,
kSD_OcrVdd30_31Flag = 18,
kSD_OcrVdd31_32Flag = 19,
kSD_OcrVdd32_33Flag = 20,
kSD_OcrVdd33_34Flag = 21,
kSD_OcrVdd34_35Flag = 22,
kSD_OcrVdd35_36Flag = 23 }
OCR register in SD card.
• enum _sd_specification_version {
kSD_SpecificationVersion1_0 = (1U << 0U),
kSD_SpecificationVersion1_1 = (1U << 1U),
kSD_SpecificationVersion2_0 = (1U << 2U),
kSD_SpecificationVersion3_0 = (1U << 3U) }
SD card specification version number.
• enum sd_data_bus_width_t {
kSD_DataBusWidth1Bit = 0U,
kSD_DataBusWidth4Bit = 1U }
SD card bus width.
• enum sd_switch_mode_t {
kSD_SwitchCheck = 0U,
kSD_SwitchSet = 1U }
SD card switch mode.
• enum _sd_csd_flag {
kSD_CsdReadBlockPartialFlag = (1U << 0U),
kSD_CsdWriteBlockMisalignFlag = (1U << 1U),
kSD_CsdReadBlockMisalignFlag = (1U << 2U),
kSD_CsdDsrImplementedFlag = (1U << 3U),
kSD_CsdEraseBlockEnabledFlag = (1U << 4U),
kSD_CsdWriteProtectGroupEnabledFlag = (1U << 5U),
kSD_CsdWriteBlockPartialFlag = (1U << 6U),
kSD_CsdFileFormatGroupFlag = (1U << 7U),
kSD_CsdCopyFlag = (1U << 8U),
kSD_CsdPermanentWriteProtectFlag = (1U << 9U),
kSD_CsdTemporaryWriteProtectFlag = (1U << 10U) }
SD card CSD register flags.
• enum _sd_scr_flag {
kSD_ScrDataStatusAfterErase = (1U << 0U),
kSD_ScrSdSpecification3 = (1U << 1U) }
SD card SCR register flags.

MCUXpresso SDK API Reference Manual


708 NXP Semiconductors
Overview

• enum _sd_timing_function {
kSD_FunctionSDR12Deafult = 0U,
kSD_FunctionSDR25HighSpeed = 1U,
kSD_FunctionSDR50 = 2U,
kSD_FunctionSDR104 = 3U,
kSD_FunctionDDR50 = 4U }
SD timing function number.
• enum _sd_group_num {
kSD_GroupTimingMode = 0U,
kSD_GroupCommandSystem = 1U,
kSD_GroupDriverStrength = 2U,
kSD_GroupCurrentLimit = 3U }
SD group number.
• enum sd_timing_mode_t {
kSD_TimingSDR12DefaultMode = 0U,
kSD_TimingSDR25HighSpeedMode = 1U,
kSD_TimingSDR50Mode = 2U,
kSD_TimingSDR104Mode = 3U,
kSD_TimingDDR50Mode = 4U }
SD card timing mode flags.
• enum sd_driver_strength_t {
kSD_DriverStrengthTypeB = 0U,
kSD_DriverStrengthTypeA = 1U,
kSD_DriverStrengthTypeC = 2U,
kSD_DriverStrengthTypeD = 3U }
SD card driver strength.
• enum sd_max_current_t {
kSD_CurrentLimit200MA = 0U,
kSD_CurrentLimit400MA = 1U,
kSD_CurrentLimit600MA = 2U,
kSD_CurrentLimit800MA = 3U }
SD card current limit.
• enum sdmmc_command_t {

MCUXpresso SDK API Reference Manual


NXP Semiconductors 709
Overview

kSDMMC_GoIdleState = 0U,
kSDMMC_AllSendCid = 2U,
kSDMMC_SetDsr = 4U,
kSDMMC_SelectCard = 7U,
kSDMMC_SendCsd = 9U,
kSDMMC_SendCid = 10U,
kSDMMC_StopTransmission = 12U,
kSDMMC_SendStatus = 13U,
kSDMMC_GoInactiveState = 15U,
kSDMMC_SetBlockLength = 16U,
kSDMMC_ReadSingleBlock = 17U,
kSDMMC_ReadMultipleBlock = 18U,
kSDMMC_SetBlockCount = 23U,
kSDMMC_WriteSingleBlock = 24U,
kSDMMC_WriteMultipleBlock = 25U,
kSDMMC_ProgramCsd = 27U,
kSDMMC_SetWriteProtect = 28U,
kSDMMC_ClearWriteProtect = 29U,
kSDMMC_SendWriteProtect = 30U,
kSDMMC_Erase = 38U,
kSDMMC_LockUnlock = 42U,
kSDMMC_ApplicationCommand = 55U,
kSDMMC_GeneralCommand = 56U,
kSDMMC_ReadOcr = 58U }
SD/MMC card common commands.
• enum _sdio_cccr_reg {

MCUXpresso SDK API Reference Manual


710 NXP Semiconductors
Overview

kSDIO_RegCCCRSdioVer = 0x00U,
kSDIO_RegSDVersion = 0x01U,
kSDIO_RegIOEnable = 0x02U,
kSDIO_RegIOReady = 0x03U,
kSDIO_RegIOIntEnable = 0x04U,
kSDIO_RegIOIntPending = 0x05U,
kSDIO_RegIOAbort = 0x06U,
kSDIO_RegBusInterface = 0x07U,
kSDIO_RegCardCapability = 0x08U,
kSDIO_RegCommonCISPointer = 0x09U,
kSDIO_RegBusSuspend = 0x0C,
kSDIO_RegFunctionSelect = 0x0DU,
kSDIO_RegExecutionFlag = 0x0EU,
kSDIO_RegReadyFlag = 0x0FU,
kSDIO_RegFN0BlockSizeLow = 0x10U,
kSDIO_RegFN0BlockSizeHigh = 0x11U,
kSDIO_RegPowerControl = 0x12U,
kSDIO_RegBusSpeed = 0x13U,
kSDIO_RegUHSITimingSupport = 0x14U,
kSDIO_RegDriverStrength = 0x15U,
kSDIO_RegInterruptExtension = 0x16U }
sdio card cccr register addr
• enum sdio_command_t {
kSDIO_SendRelativeAddress = 3U,
kSDIO_SendOperationCondition = 5U,
kSDIO_SendInterfaceCondition = 8U,
kSDIO_RWIODirect = 52U,
kSDIO_RWIOExtended = 53U }
sdio card individual commands
• enum sdio_func_num_t {
kSDIO_FunctionNum0,
kSDIO_FunctionNum1,
kSDIO_FunctionNum2,
kSDIO_FunctionNum3,
kSDIO_FunctionNum4,
kSDIO_FunctionNum5,
kSDIO_FunctionNum6,
kSDIO_FunctionNum7,
kSDIO_FunctionMemory }
sdio card individual commands
• enum _sdio_status_flag {

MCUXpresso SDK API Reference Manual


NXP Semiconductors 711
Overview

kSDIO_StatusCmdCRCError = 0x8000U,
kSDIO_StatusIllegalCmd = 0x4000U,
kSDIO_StatusR6Error = 0x2000U,
kSDIO_StatusError = 0x0800U,
kSDIO_StatusFunctionNumError = 0x0200U,
kSDIO_StatusOutofRange = 0x0100U }
sdio command response flag
• enum _sdio_ocr_flag {
kSDIO_OcrPowerUpBusyFlag = 31,
kSDIO_OcrIONumber = 28,
kSDIO_OcrMemPresent = 27,
kSDIO_OcrVdd20_21Flag = 8,
kSDIO_OcrVdd21_22Flag = 9,
kSDIO_OcrVdd22_23Flag = 10,
kSDIO_OcrVdd23_24Flag = 11,
kSDIO_OcrVdd24_25Flag = 12,
kSDIO_OcrVdd25_26Flag = 13,
kSDIO_OcrVdd26_27Flag = 14,
kSDIO_OcrVdd27_28Flag = 15,
kSDIO_OcrVdd28_29Flag = 16,
kSDIO_OcrVdd29_30Flag = 17,
kSDIO_OcrVdd30_31Flag = 18,
kSDIO_OcrVdd31_32Flag = 19,
kSDIO_OcrVdd32_33Flag = 20,
kSDIO_OcrVdd33_34Flag = 21,
kSDIO_OcrVdd34_35Flag = 22,
kSDIO_OcrVdd35_36Flag = 23 }
sdio operation condition flag
• enum _sdio_capability_flag {
kSDIO_CCCRSupportDirectCmdDuringDataTrans = (1U << 0U),
kSDIO_CCCRSupportMultiBlock = (1U << 1U),
kSDIO_CCCRSupportReadWait = (1U << 2U),
kSDIO_CCCRSupportSuspendResume = (1U << 3U),
kSDIO_CCCRSupportIntDuring4BitDataTrans = (1U << 4U),
kSDIO_CCCRSupportLowSpeed1Bit = (1U << 6U),
kSDIO_CCCRSupportLowSpeed4Bit = (1U << 7U),
kSDIO_CCCRSupportMasterPowerControl = (1U << 8U),
kSDIO_CCCRSupportHighSpeed = (1U << 9U),
kSDIO_CCCRSupportContinuousSPIInt = (1U << 10U) }
sdio capability flag
• enum _sdio_fbr_flag {
kSDIO_FBRSupportCSA = (1U << 0U),
kSDIO_FBRSupportPowerSelection = (1U << 1U) }
sdio fbr flag
• enum sdio_bus_width_t {

MCUXpresso SDK API Reference Manual


712 NXP Semiconductors
Overview

kSDIO_DataBus1Bit = 0x00U,
kSDIO_DataBus4Bit = 0X02U,
kSDIO_DataBus8Bit = 0X03U }
sdio bus width
• enum mmc_command_t {
kMMC_SendOperationCondition = 1U,
kMMC_SetRelativeAddress = 3U,
kMMC_SleepAwake = 5U,
kMMC_Switch = 6U,
kMMC_SendExtendedCsd = 8U,
kMMC_ReadDataUntilStop = 11U,
kMMC_BusTestRead = 14U,
kMMC_SendingBusTest = 19U,
kMMC_WriteDataUntilStop = 20U,
kMMC_SendTuningBlock = 21U,
kMMC_ProgramCid = 26U,
kMMC_EraseGroupStart = 35U,
kMMC_EraseGroupEnd = 36U,
kMMC_FastInputOutput = 39U,
kMMC_GoInterruptState = 40U }
MMC card individual commands.
• enum mmc_classified_voltage_t {
kMMC_ClassifiedVoltageHigh = 0U,
kMMC_ClassifiedVoltageDual = 1U }
MMC card classified as voltage range.
• enum mmc_classified_density_t { kMMC_ClassifiedDensityWithin2GB = 0U }
MMC card classified as density level.
• enum mmc_access_mode_t {
kMMC_AccessModeByte = 0U,
kMMC_AccessModeSector = 2U }
MMC card access mode(Access mode in OCR).
• enum mmc_voltage_window_t {
kMMC_VoltageWindowNone = 0U,
kMMC_VoltageWindow120 = 0x01U,
kMMC_VoltageWindow170to195 = 0x02U,
kMMC_VoltageWindows270to360 = 0x1FFU }
MMC card voltage window(VDD voltage window in OCR).
• enum mmc_csd_structure_version_t {
kMMC_CsdStrucureVersion10 = 0U,
kMMC_CsdStrucureVersion11 = 1U,
kMMC_CsdStrucureVersion12 = 2U,
kMMC_CsdStrucureVersionInExtcsd = 3U }
CSD structure version(CSD_STRUCTURE in CSD).
• enum mmc_specification_version_t {

MCUXpresso SDK API Reference Manual


NXP Semiconductors 713
Overview

kMMC_SpecificationVersion0 = 0U,
kMMC_SpecificationVersion1 = 1U,
kMMC_SpecificationVersion2 = 2U,
kMMC_SpecificationVersion3 = 3U,
kMMC_SpecificationVersion4 = 4U }
MMC card specification version(SPEC_VERS in CSD).
• enum _mmc_extended_csd_revision {
kMMC_ExtendedCsdRevision10 = 0U,
kMMC_ExtendedCsdRevision11 = 1U,
kMMC_ExtendedCsdRevision12 = 2U,
kMMC_ExtendedCsdRevision13 = 3U,
kMMC_ExtendedCsdRevision14 = 4U,
kMMC_ExtendedCsdRevision15 = 5U,
kMMC_ExtendedCsdRevision16 = 6U,
kMMC_ExtendedCsdRevision17 = 7U }
MMC card Extended CSD fix version(EXT_CSD_REV in Extended CSD)
• enum mmc_command_set_t {
kMMC_CommandSetStandard = 0U,
kMMC_CommandSet1 = 1U,
kMMC_CommandSet2 = 2U,
kMMC_CommandSet3 = 3U,
kMMC_CommandSet4 = 4U }
MMC card command set(COMMAND_SET in Extended CSD)
• enum _mmc_support_boot_mode {
kMMC_SupportAlternateBoot = 1U,
kMMC_SupportDDRBoot = 2U,
kMMC_SupportHighSpeedBoot = 4U }
boot support(BOOT_INFO in Extended CSD)
• enum mmc_high_speed_timing_t {
kMMC_HighSpeedTimingNone = 0U,
kMMC_HighSpeedTiming = 1U,
kMMC_HighSpeed200Timing = 2U,
kMMC_HighSpeed400Timing = 3U }
MMC card high-speed timing(HS_TIMING in Extended CSD)
• enum mmc_data_bus_width_t {
kMMC_DataBusWidth1bit = 0U,
kMMC_DataBusWidth4bit = 1U,
kMMC_DataBusWidth8bit = 2U,
kMMC_DataBusWidth4bitDDR = 5U,
kMMC_DataBusWidth8bitDDR = 6U }
MMC card data bus width(BUS_WIDTH in Extended CSD)
• enum mmc_boot_partition_enable_t {
kMMC_BootPartitionEnableNot = 0U,
kMMC_BootPartitionEnablePartition1 = 1U,
kMMC_BootPartitionEnablePartition2 = 2U,
kMMC_BootPartitionEnableUserAera = 7U }

MCUXpresso SDK API Reference Manual


714 NXP Semiconductors
Overview

MMC card boot partition enabled(BOOT_PARTITION_ENABLE in Extended CSD)


• enum mmc_boot_timing_mode_t {
kMMC_BootModeSDRWithDefaultTiming = 0U << 3U,
kMMC_BootModeSDRWithHighSpeedTiming = 1U << 3U,
kMMC_BootModeDDRTiming = 2U << 3U }
boot mode configuration Note: HS200 & HS400 is not support during BOOT operation.
• enum mmc_boot_partition_wp_t {
kMMC_BootPartitionWPDisable = 0x50U,
kMMC_BootPartitionPwrWPToBothPartition,
kMMC_BootPartitionPermWPToBothPartition = 0x04U,
kMMC_BootPartitionPwrWPToPartition1 = (1U << 7U) | 1U,
kMMC_BootPartitionPwrWPToPartition2 = (1U << 7U) | 3U,
kMMC_BootPartitionPermWPToPartition1,
kMMC_BootPartitionPermWPToPartition2,
kMMC_BootPartitionPermWPToPartition1PwrWPToPartition2,
kMMC_BootPartitionPermWPToPartition2PwrWPToPartition1 }
MMC card boot partition write protect configurations All the bits in BOOT_WP register, except the two
R/W bits B_PERM_WP_DIS and B_PERM_WP_EN, shall only be written once per power cycle.The pro-
tection mdde intended for both boot areas will be set with a single write.
• enum _mmc_boot_partition_wp_status {
kMMC_BootPartitionNotProtected = 0U,
kMMC_BootPartitionPwrProtected = 1U,
kMMC_BootPartitionPermProtected = 2U }
MMC card boot partition write protect status.
• enum mmc_access_partition_t {
kMMC_AccessPartitionUserAera = 0U,
kMMC_AccessPartitionBoot1 = 1U,
kMMC_AccessPartitionBoot2 = 2U,
kMMC_AccessRPMB = 3U,
kMMC_AccessGeneralPurposePartition1 = 4U,
kMMC_AccessGeneralPurposePartition2 = 5U,
kMMC_AccessGeneralPurposePartition3 = 6U,
kMMC_AccessGeneralPurposePartition4 = 7U }
MMC card partition to be accessed(BOOT_PARTITION_ACCESS in Extended CSD)
• enum _mmc_csd_flag {
kMMC_CsdReadBlockPartialFlag = (1U << 0U),
kMMC_CsdWriteBlockMisalignFlag = (1U << 1U),
kMMC_CsdReadBlockMisalignFlag = (1U << 2U),
kMMC_CsdDsrImplementedFlag = (1U << 3U),
kMMC_CsdWriteProtectGroupEnabledFlag = (1U << 4U),
kMMC_CsdWriteBlockPartialFlag = (1U << 5U),
kMMC_ContentProtectApplicationFlag = (1U << 6U),
kMMC_CsdFileFormatGroupFlag = (1U << 7U),
kMMC_CsdCopyFlag = (1U << 8U),
kMMC_CsdPermanentWriteProtectFlag = (1U << 9U),
kMMC_CsdTemporaryWriteProtectFlag = (1U << 10U) }

MCUXpresso SDK API Reference Manual


NXP Semiconductors 715
Overview

MMC card CSD register flags.


• enum mmc_extended_csd_access_mode_t {
kMMC_ExtendedCsdAccessModeCommandSet = 0U,
kMMC_ExtendedCsdAccessModeSetBits = 1U,
kMMC_ExtendedCsdAccessModeClearBits = 2U,
kMMC_ExtendedCsdAccessModeWriteBits = 3U }
Extended CSD register access mode(Access mode in CMD6).
• enum mmc_extended_csd_index_t {
kMMC_ExtendedCsdIndexBootPartitionWP = 173U,
kMMC_ExtendedCsdIndexEraseGroupDefinition = 175U,
kMMC_ExtendedCsdIndexBootBusConditions = 177U,
kMMC_ExtendedCsdIndexBootConfigWP = 178U,
kMMC_ExtendedCsdIndexPartitionConfig = 179U,
kMMC_ExtendedCsdIndexBusWidth = 183U,
kMMC_ExtendedCsdIndexHighSpeedTiming = 185U,
kMMC_ExtendedCsdIndexPowerClass = 187U,
kMMC_ExtendedCsdIndexCommandSet = 191U }
EXT CSD byte index.
• enum _mmc_driver_strength {
kMMC_DriverStrength0 = 0U,
kMMC_DriverStrength1 = 1U,
kMMC_DriverStrength2 = 2U,
kMMC_DriverStrength3 = 3U,
kMMC_DriverStrength4 = 4U }
mmc driver strength
• enum mmc_extended_csd_flags_t {
kMMC_ExtCsdExtPartitionSupport = (1 << 0U),
kMMC_ExtCsdEnhancePartitionSupport = (1 << 1U),
kMMC_ExtCsdPartitioningSupport = (1 << 2U),
kMMC_ExtCsdPrgCIDCSDInDDRModeSupport = (1 << 3U),
kMMC_ExtCsdBKOpsSupport = (1 << 4U),
kMMC_ExtCsdDataTagSupport = (1 << 5U),
kMMC_ExtCsdModeOperationCodeSupport = (1 << 6U) }
mmc extended csd flags
• enum _mmc_boot_mode {
kMMC_BootModeNormal = 0U,
kMMC_BootModeAlternative = 1U }
MMC card boot mode.

common function
• status_t SDMMC_SelectCard (SDMMCHOST_TYPE ∗base, SDMMCHOST_TRANSFER_FUN-
CTION transfer, uint32_t relativeAddress, bool isSelected)
Selects the card to put it into transfer state.
• status_t SDMMC_SendApplicationCommand (SDMMCHOST_TYPE ∗base, SDMMCHOST_TR-
ANSFER_FUNCTION transfer, uint32_t relativeAddress)
Sends an application command.

MCUXpresso SDK API Reference Manual


716 NXP Semiconductors
Data Structure Documentation

• status_t SDMMC_SetBlockCount (SDMMCHOST_TYPE ∗base, SDMMCHOST_TRANSFER_-


FUNCTION transfer, uint32_t blockCount)
Sets the block count.
• status_t SDMMC_GoIdle (SDMMCHOST_TYPE ∗base, SDMMCHOST_TRANSFER_FUNCTI-
ON transfer)
Sets the card to be idle state.
• status_t SDMMC_SetBlockSize (SDMMCHOST_TYPE ∗base, SDMMCHOST_TRANSFER_F-
UNCTION transfer, uint32_t blockSize)
Sets data block size.
• status_t SDMMC_SetCardInactive (SDMMCHOST_TYPE ∗base, SDMMCHOST_TRANSFER_-
FUNCTION transfer)
Sets card to inactive status.
• void SDMMC_Delay (uint32_t num)
provide a simple delay function for sdmmc
• status_t SDMMC_SwitchVoltage (SDMMCHOST_TYPE ∗base, SDMMCHOST_TRANSFER_F-
UNCTION transfer)
provide a voltage switch function for SD/SDIO card
• status_t SDMMC_SwitchToVoltage (SDMMCHOST_TYPE ∗base, SDMMCHOST_TRANSFER-
_FUNCTION transfer, sdmmchost_card_switch_voltage_t switchVoltageFunc)
provide a voltage switch function for SD/SDIO card
• status_t SDMMC_ExecuteTuning (SDMMCHOST_TYPE ∗base, SDMMCHOST_TRANSFER_-
FUNCTION transfer, uint32_t tuningCmd, uint32_t blockSize)
excute tuning

33.2 Data Structure Documentation


33.2.1 struct sdio_fbr_t

Data Fields

• uint8_t flags
current io flags
• uint8_t ioStdFunctionCode
current io standard function code
• uint8_t ioExtFunctionCode
current io extended function code
• uint32_t ioPointerToCIS
current io pointer to CIS
• uint32_t ioPointerToCSA
current io pointer to CSA
• uint16_t ioBlockSize
current io block size

MCUXpresso SDK API Reference Manual


NXP Semiconductors 717
Data Structure Documentation

33.2.2 struct sdio_common_cis_t

Data Fields

• uint16_t mID
manufacturer code
• uint16_t mInfo
manufacturer information
• uint8_t funcID
function ID
• uint16_t fn0MaxBlkSize
function 0 max block size
• uint8_t maxTransSpeed
max data transfer speed for all function

33.2.3 struct sdio_func_cis_t

Data Fields

• uint8_t funcID
function ID
• uint8_t funcInfo
function info
• uint8_t ioVersion
level of application specification this io support
• uint32_t cardPSN
product serial number
• uint32_t ioCSASize
avaliable CSA size for io
• uint8_t ioCSAProperty
CSA property.
• uint16_t ioMaxBlockSize
io max transfer data size
• uint32_t ioOCR
io ioeration condition
• uint8_t ioOPMinPwr
min current in operation mode
• uint8_t ioOPAvgPwr
average current in operation mode
• uint8_t ioOPMaxPwr
max current in operation mode
• uint8_t ioSBMinPwr
min current in standby mode
• uint8_t ioSBAvgPwr
average current in standby mode
• uint8_t ioSBMaxPwr
max current in standby mode
• uint16_t ioMinBandWidth

MCUXpresso SDK API Reference Manual


718 NXP Semiconductors
Data Structure Documentation

io min transfer bandwidth


• uint16_t ioOptimumBandWidth
io optimum transfer bandwidth
• uint16_t ioReadyTimeout
timeout value from enalbe to ready
• uint16_t ioHighCurrentAvgCurrent
the average peak current (mA)
when IO operating in high current mode
• uint16_t ioHighCurrentMaxCurrent
the max peak current (mA)
when IO operating in high current mode
• uint16_t ioLowCurrentAvgCurrent
the average peak current (mA)
when IO operating in lower current mode
• uint16_t ioLowCurrentMaxCurrent
the max peak current (mA)
when IO operating in lower current mode

33.2.4 struct sd_status_t

Data Fields

• uint8_t busWidth
current buswidth
• uint8_t secureMode
secured mode
• uint16_t cardType
sdcard type
• uint32_t protectedSize
size of protected area
• uint8_t speedClass
speed class of card
• uint8_t performanceMove
Performance of move indicated by 1[MB/S]step.
• uint8_t auSize
size of AU
• uint16_t eraseSize
number of AUs to be erased at a time
• uint8_t eraseTimeout
timeout value for erasing areas specified by UNIT OF ERASE AU
• uint8_t eraseOffset
fixed offset value added to erase time
• uint8_t uhsSpeedGrade
speed grade for UHS mode
• uint8_t uhsAuSize
size of AU for UHS mode

MCUXpresso SDK API Reference Manual


NXP Semiconductors 719
Data Structure Documentation

33.2.5 struct sd_cid_t

Data Fields

• uint8_t manufacturerID
Manufacturer ID [127:120].
• uint16_t applicationID
OEM/Application ID [119:104].
• uint8_t productName [SD_PRODUCT_NAME_BYTES]
Product name [103:64].
• uint8_t productVersion
Product revision [63:56].
• uint32_t productSerialNumber
Product serial number [55:24].
• uint16_t manufacturerData
Manufacturing date [19:8].

33.2.6 struct sd_csd_t

Data Fields

• uint8_t csdStructure
CSD structure [127:126].
• uint8_t dataReadAccessTime1
Data read access-time-1 [119:112].
• uint8_t dataReadAccessTime2
Data read access-time-2 in clock cycles (NSAC∗100) [111:104].
• uint8_t transferSpeed
Maximum data transfer rate [103:96].
• uint16_t cardCommandClass
Card command classes [95:84].
• uint8_t readBlockLength
Maximum read data block length [83:80].
• uint16_t flags
Flags in _sd_csd_flag.
• uint32_t deviceSize
Device size [73:62].
• uint8_t readCurrentVddMin
Maximum read current at VDD min [61:59].
• uint8_t readCurrentVddMax
Maximum read current at VDD max [58:56].
• uint8_t writeCurrentVddMin
Maximum write current at VDD min [55:53].
• uint8_t writeCurrentVddMax
Maximum write current at VDD max [52:50].
• uint8_t deviceSizeMultiplier
Device size multiplier [49:47].
• uint8_t eraseSectorSize

MCUXpresso SDK API Reference Manual


720 NXP Semiconductors
Data Structure Documentation

Erase sector size [45:39].


• uint8_t writeProtectGroupSize
Write protect group size [38:32].
• uint8_t writeSpeedFactor
Write speed factor [28:26].
• uint8_t writeBlockLength
Maximum write data block length [25:22].
• uint8_t fileFormat
File format [11:10].

33.2.7 struct sd_scr_t

Data Fields

• uint8_t scrStructure
SCR Structure [63:60].
• uint8_t sdSpecification
SD memory card specification version [59:56].
• uint16_t flags
SCR flags in _sd_scr_flag.
• uint8_t sdSecurity
Security specification supported [54:52].
• uint8_t sdBusWidths
Data bus widths supported [51:48].
• uint8_t extendedSecurity
Extended security support [46:43].
• uint8_t commandSupport
Command support bits [33:32] 33-support CMD23, 32-support cmd20.
• uint32_t reservedForManufacturer
reserved for manufacturer usage [31:0]

33.2.8 struct mmc_cid_t

Data Fields

• uint8_t manufacturerID
Manufacturer ID.
• uint16_t applicationID
OEM/Application ID.
• uint8_t productName [MMC_PRODUCT_NAME_BYTES]
Product name.
• uint8_t productVersion
Product revision.
• uint32_t productSerialNumber
Product serial number.
• uint8_t manufacturerData
Manufacturing date.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 721
Data Structure Documentation

33.2.9 struct mmc_csd_t

Data Fields

• uint8_t csdStructureVersion
CSD structure [127:126].
• uint8_t systemSpecificationVersion
System specification version [125:122].
• uint8_t dataReadAccessTime1
Data read access-time 1 [119:112].
• uint8_t dataReadAccessTime2
Data read access-time 2 in CLOCK cycles (NSAC∗100) [111:104].
• uint8_t transferSpeed
Max.
• uint16_t cardCommandClass
card command classes [95:84]
• uint8_t readBlockLength
Max.
• uint16_t flags
Contain flags in _mmc_csd_flag.
• uint16_t deviceSize
Device size [73:62].
• uint8_t readCurrentVddMin
Max.
• uint8_t readCurrentVddMax
Max.
• uint8_t writeCurrentVddMin
Max.
• uint8_t writeCurrentVddMax
Max.
• uint8_t deviceSizeMultiplier
Device size multiplier [49:47].
• uint8_t eraseGroupSize
Erase group size [46:42].
• uint8_t eraseGroupSizeMultiplier
Erase group size multiplier [41:37].
• uint8_t writeProtectGroupSize
Write protect group size [36:32].
• uint8_t defaultEcc
Manufacturer default ECC [30:29].
• uint8_t writeSpeedFactor
Write speed factor [28:26].
• uint8_t maxWriteBlockLength
Max.
• uint8_t fileFormat
File format [11:10].
• uint8_t eccCode
ECC code [9:8].

MCUXpresso SDK API Reference Manual


722 NXP Semiconductors
Data Structure Documentation

33.2.9.0.0.36 Field Documentation

33.2.9.0.0.36.1 uint8_t mmc_csd_t::transferSpeed

bus clock frequency [103:96]

33.2.9.0.0.36.2 uint8_t mmc_csd_t::readBlockLength

read data block length [83:80]

33.2.9.0.0.36.3 uint8_t mmc_csd_t::readCurrentVddMin

read current @ VDD min [61:59]

33.2.9.0.0.36.4 uint8_t mmc_csd_t::readCurrentVddMax

read current @ VDD max [58:56]

33.2.9.0.0.36.5 uint8_t mmc_csd_t::writeCurrentVddMin

write current @ VDD min [55:53]

33.2.9.0.0.36.6 uint8_t mmc_csd_t::writeCurrentVddMax

write current @ VDD max [52:50]

33.2.9.0.0.36.7 uint8_t mmc_csd_t::maxWriteBlockLength

write data block length [25:22]

33.2.10 struct mmc_extended_csd_t

Data Fields

• uint8_t partitionAttribute
< secure removal type[16]
• uint8_t userWP
< max enhance area size [159-157]
• uint8_t bootPartitionWP
boot write protect register[173]
• uint8_t bootWPStatus
boot write protect status register[174]
• uint8_t highDensityEraseGroupDefinition
High-density erase group definition [175].
• uint8_t bootDataBusConditions
Boot bus conditions [177].
• uint8_t bootConfigProtect
Boot config protection [178].
• uint8_t partitionConfig

MCUXpresso SDK API Reference Manual


NXP Semiconductors 723
Data Structure Documentation

Boot configuration [179].


• uint8_t eraseMemoryContent
Erased memory content [181].
• uint8_t dataBusWidth
Data bus width mode [183].
• uint8_t highSpeedTiming
High-speed interface timing [185].
• uint8_t powerClass
Power class [187].
• uint8_t commandSetRevision
Command set revision [189].
• uint8_t commandSet
Command set [191].
• uint8_t extendecCsdVersion
Extended CSD revision [192].
• uint8_t csdStructureVersion
CSD structure version [194].
• uint8_t cardType
Card Type [196].
• uint8_t ioDriverStrength
IO driver strength [197].
• uint8_t powerClass52MHz195V
< out of interrupt busy timing [198]
• uint8_t powerClass26MHz195V
Power Class for 26MHz @ 1.95V [201].
• uint8_t powerClass52MHz360V
Power Class for 52MHz @ 3.6V [202].
• uint8_t powerClass26MHz360V
Power Class for 26MHz @ 3.6V [203].
• uint8_t minimumReadPerformance4Bit26MHz
Minimum Read Performance for 4bit at 26MHz [205].
• uint8_t minimumWritePerformance4Bit26MHz
Minimum Write Performance for 4bit at 26MHz [206].
• uint8_t minimumReadPerformance8Bit26MHz4Bit52MHz
Minimum read Performance for 8bit at 26MHz/4bit @52MHz [207].
• uint8_t minimumWritePerformance8Bit26MHz4Bit52MHz
Minimum Write Performance for 8bit at 26MHz/4bit @52MHz [208].
• uint8_t minimumReadPerformance8Bit52MHz
Minimum Read Performance for 8bit at 52MHz [209].
• uint8_t minimumWritePerformance8Bit52MHz
Minimum Write Performance for 8bit at 52MHz [210].
• uint32_t sectorCount
Sector Count [215:212].
• uint8_t sleepAwakeTimeout
< sleep notification timeout [216]
• uint8_t sleepCurrentVCCQ
< Production state awareness timeout [218]
• uint8_t sleepCurrentVCC
Sleep current (VCC) [220].
• uint8_t highCapacityWriteProtectGroupSize
High-capacity write protect group size [221].

MCUXpresso SDK API Reference Manual


724 NXP Semiconductors
Data Structure Documentation

• uint8_t reliableWriteSectorCount
Reliable write sector count [222].
• uint8_t highCapacityEraseTimeout
High-capacity erase timeout [223].
• uint8_t highCapacityEraseUnitSize
High-capacity erase unit size [224].
• uint8_t accessSize
Access size [225].
• uint8_t minReadPerformance8bitAt52MHZDDR
< secure trim multiplier[229]
• uint8_t minWritePerformance8bitAt52MHZDDR
Minimum write performance for 8bit at DDR 52MHZ[235].
• uint8_t powerClass200MHZVCCQ130VVCC360V
power class for 200MHZ, at VCCQ= 1.3V,VCC=3.6V[236]
• uint8_t powerClass200MHZVCCQ195VVCC360V
power class for 200MHZ, at VCCQ= 1.95V,VCC=3.6V[237]
• uint8_t powerClass52MHZDDR195V
power class for 52MHZ,DDR at Vcc 1.95V[238]
• uint8_t powerClass52MHZDDR360V
power class for 52MHZ,DDR at Vcc 3.6V[239]
• uint32_t cacheSize
< 1st initialization time after partitioning[241]
• uint8_t powerClass200MHZDDR360V
power class for 200MHZ, DDR at VCC=2.6V[253]
• uint8_t extPartitionSupport
< fw VERSION [261-254]
• uint8_t supportedCommandSet
< large unit size[495]

33.2.10.0.0.37 Field Documentation

33.2.10.0.0.37.1 uint8_t mmc_extended_csd_t::partitionAttribute

< product state awareness enablement[17]


< max preload data size[21-18]
< pre-load data size[25-22]
< FFU status [26]
< mode operation code[29]
< mode config [30]
< control to turn on/off cache[33]
< power off notification[34]
< packed cmd fail index [35]
< packed cmd status[36]
< context configuration[51-37]
< extended partitions attribut[53-52]

MCUXpresso SDK API Reference Manual


NXP Semiconductors 725
Data Structure Documentation

< exception events status[55-54]


< exception events control[57-56]
< number of group to be released[58]
< class 6 command control[59]
< 1st initiallization after disabling sector size emu[60]
< sector size[61]
< sector size emulation[62]
< native sector size[63]
< period wakeup [131]
< package case temperature is controlled[132]
< production state awareness[133]
< enhanced user data start addr [139-136]
< enhanced user data area size[142-140]
< general purpose partition size[154-143] partition attribute [156]

33.2.10.0.0.37.2 uint8_t mmc_extended_csd_t::userWP

< HPI management [161]


< write reliability parameter register[166]
< write reliability setting register[167]
< RPMB size multi [168]
< FW configuration[169] user write protect register[171]

33.2.10.0.0.37.3 uint8_t mmc_extended_csd_t::powerClass52MHz195V

< partition switch timing [199] Power Class for 52MHz @ 1.95V [200]

33.2.10.0.0.37.4 uint8_t mmc_extended_csd_t::sleepAwakeTimeout

Sleep/awake timeout [217]

33.2.10.0.0.37.5 uint8_t mmc_extended_csd_t::sleepCurrentVCCQ

Sleep current (VCCQ) [219]

33.2.10.0.0.37.6 uint8_t mmc_extended_csd_t::minReadPerformance8bitAt52MHZDDR

< secure erase multiplier[230]


< secure feature support[231]
< trim multiplier[232] Minimum read performance for 8bit at DDR 52MHZ[234]

MCUXpresso SDK API Reference Manual


726 NXP Semiconductors
Data Structure Documentation

33.2.10.0.0.37.7 uint32_t mmc_extended_csd_t::cacheSize

< correct prg sectors number[245-242]


< background operations status[246]
< power off notification timeout[247]
< generic CMD6 timeout[248] cache size[252-249]

33.2.10.0.0.37.8 uint8_t mmc_extended_csd_t::extPartitionSupport

< device version[263-262]


< optimal trim size[264]
< optimal write size[265]
< optimal read size[266]
< pre EOL information[267]
< device life time estimation typeA[268]
< device life time estimation typeB[269]
< number of FW sectors correctly programmed[305-302]
< FFU argument[490-487]
< operation code timeout[491]
< support mode [493] extended partition attribute support[494]

33.2.10.0.0.37.9 uint8_t mmc_extended_csd_t::supportedCommandSet

< context management capability[496]


< tag resource size[497]
< tag unit size[498]
< max packed write cmd[500]
< max packed read cmd[501]
< HPI feature[503] Supported Command Sets [504]

33.2.11 struct mmc_extended_csd_config_t

Data Fields

• mmc_command_set_t commandSet
Command set.
• uint8_t ByteValue
The value to set.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 727
Data Structure Documentation

• uint8_t ByteIndex
The byte index in Extended CSD(mmc_extended_csd_index_t)
• mmc_extended_csd_access_mode_t accessMode
Access mode.

33.2.12 struct mmc_boot_config_t

Data Fields

• bool enableBootAck
Enable boot ACK.
• mmc_boot_partition_enable_t bootPartition
Boot partition.
• mmc_boot_timing_mode_t bootTimingMode
boot mode
• mmc_data_bus_width_t bootDataBusWidth
Boot data bus width.
• bool retainBootbusCondition
If retain boot bus width and boot mode conditions.
• bool pwrBootConfigProtection
Disable the change of boot configuration register bits from at this point
until next power cycle or next H/W reset operation
• bool premBootConfigProtection
Disable the change of boot configuration register bits permanently.
• mmc_boot_partition_wp_t bootPartitionWP
boot partition write protect configurations

MCUXpresso SDK API Reference Manual


728 NXP Semiconductors
Enumeration Type Documentation

33.3 Macro Definition Documentation


33.3.1 #define FSL_SDMMC_DRIVER_VERSION (MAKE_VERSION(2U, 2U, 11U))
/∗2.2.11∗/

33.3.2 #define SDMMC_LOG( format, ... )

33.3.3 #define READ_MMC_TRANSFER_SPEED_FREQUENCY_UNIT( CSD


) (((CSD.transferSpeed) & MMC_TRANSFER_SPEED_FREQUENCY_UNI-
T_MASK) >> MMC_TRANSFER_SPEED_FREQUENCY_UNIT_SHIFT)

33.3.4 #define READ_MMC_TRANSFER_SPEED_MULTIPLIER( CSD ) (((CSD.-


transferSpeed) & MMC_TRANSFER_SPEED_MULTIPLIER_MASK) >>
MMC_TRANSFER_SPEED_MULTIPLIER_SHIFT)

33.3.5 #define MMC_EXTENDED_CSD_BYTES (512U)

33.3.6 #define SD_PRODUCT_NAME_BYTES (5U)

33.3.7 #define MMC_PRODUCT_NAME_BYTES (6U)

33.3.8 #define MMC_SWITCH_COMMAND_SET_SHIFT (0U)

33.3.9 #define MMC_SWITCH_COMMAND_SET_MASK (0x00000007U)

33.4 Enumeration Type Documentation


33.4.1 enum _sdmmc_status

Enumerator
kStatus_SDMMC_NotSupportYet Haven’t supported.
kStatus_SDMMC_TransferFailed Send command failed.
kStatus_SDMMC_SetCardBlockSizeFailed Set block size failed.
kStatus_SDMMC_HostNotSupport Host doesn’t support.
kStatus_SDMMC_CardNotSupport Card doesn’t support.
kStatus_SDMMC_AllSendCidFailed Send CID failed.
kStatus_SDMMC_SendRelativeAddressFailed Send relative address failed.
kStatus_SDMMC_SendCsdFailed Send CSD failed.
kStatus_SDMMC_SelectCardFailed Select card failed.
kStatus_SDMMC_SendScrFailed Send SCR failed.
kStatus_SDMMC_SetDataBusWidthFailed Set bus width failed.
kStatus_SDMMC_GoIdleFailed Go idle failed.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 729
Enumeration Type Documentation

kStatus_SDMMC_HandShakeOperationConditionFailed Send Operation Condition failed.


kStatus_SDMMC_SendApplicationCommandFailed Send application command failed.
kStatus_SDMMC_SwitchFailed Switch command failed.
kStatus_SDMMC_StopTransmissionFailed Stop transmission failed.
kStatus_SDMMC_WaitWriteCompleteFailed Wait write complete failed.
kStatus_SDMMC_SetBlockCountFailed Set block count failed.
kStatus_SDMMC_SetRelativeAddressFailed Set relative address failed.
kStatus_SDMMC_SwitchBusTimingFailed Switch high speed failed.
kStatus_SDMMC_SendExtendedCsdFailed Send EXT_CSD failed.
kStatus_SDMMC_ConfigureBootFailed Configure boot failed.
kStatus_SDMMC_ConfigureExtendedCsdFailed Configure EXT_CSD failed.
kStatus_SDMMC_EnableHighCapacityEraseFailed Enable high capacity erase failed.
kStatus_SDMMC_SendTestPatternFailed Send test pattern failed.
kStatus_SDMMC_ReceiveTestPatternFailed Receive test pattern failed.
kStatus_SDMMC_SDIO_ResponseError sdio response error
kStatus_SDMMC_SDIO_InvalidArgument sdio invalid argument response error
kStatus_SDMMC_SDIO_SendOperationConditionFail sdio send operation condition fail
kStatus_SDMMC_InvalidVoltage invaild voltage
kStatus_SDMMC_SDIO_SwitchHighSpeedFail switch to high speed fail
kStatus_SDMMC_SDIO_ReadCISFail read CIS fail
kStatus_SDMMC_SDIO_InvalidCard invaild SDIO card
kStatus_SDMMC_TuningFail tuning fail
kStatus_SDMMC_SwitchVoltageFail switch voltage fail
kStatus_SDMMC_SwitchVoltage18VFail33VSuccess switch voltage fail
kStatus_SDMMC_ReTuningRequest retuning request
kStatus_SDMMC_SetDriverStrengthFail set driver strength fail
kStatus_SDMMC_SetPowerClassFail set power class fail
kStatus_SDMMC_HostNotReady host controller not ready
kStatus_SDMMC_CardDetectFailed card detect failed
kStatus_SDMMC_AuSizeNotSetProperly AU size not set properly.

33.4.2 enum sdmmc_operation_voltage_t

Enumerator
kCARD_OperationVoltageNone indicate current voltage setting is not setting by suser
kCARD_OperationVoltage330V card operation voltage around 3.3v
kCARD_OperationVoltage300V card operation voltage around 3.0v
kCARD_OperationVoltage180V card operation voltage around 1.8v

MCUXpresso SDK API Reference Manual


730 NXP Semiconductors
Enumeration Type Documentation

33.4.3 enum _sdmmc_r1_card_status_flag

Enumerator
kSDMMC_R1OutOfRangeFlag Out of range status bit.
kSDMMC_R1AddressErrorFlag Address error status bit.
kSDMMC_R1BlockLengthErrorFlag Block length error status bit.
kSDMMC_R1EraseSequenceErrorFlag Erase sequence error status bit.
kSDMMC_R1EraseParameterErrorFlag Erase parameter error status bit.
kSDMMC_R1WriteProtectViolationFlag Write protection violation status bit.
kSDMMC_R1CardIsLockedFlag Card locked status bit.
kSDMMC_R1LockUnlockFailedFlag lock/unlock error status bit
kSDMMC_R1CommandCrcErrorFlag CRC error status bit.
kSDMMC_R1IllegalCommandFlag Illegal command status bit.
kSDMMC_R1CardEccFailedFlag Card ecc error status bit.
kSDMMC_R1CardControllerErrorFlag Internal card controller error status bit.
kSDMMC_R1ErrorFlag A general or an unknown error status bit.
kSDMMC_R1CidCsdOverwriteFlag Cid/csd overwrite status bit.
kSDMMC_R1WriteProtectEraseSkipFlag Write protection erase skip status bit.
kSDMMC_R1CardEccDisabledFlag Card ecc disabled status bit.
kSDMMC_R1EraseResetFlag Erase reset status bit.
kSDMMC_R1ReadyForDataFlag Ready for data status bit.
kSDMMC_R1SwitchErrorFlag Switch error status bit.
kSDMMC_R1ApplicationCommandFlag Application command enabled status bit.
kSDMMC_R1AuthenticationSequenceErrorFlag error in the sequence of authentication process

33.4.4 enum sdmmc_r1_current_state_t

Enumerator
kSDMMC_R1StateIdle R1: current state: idle.
kSDMMC_R1StateReady R1: current state: ready.
kSDMMC_R1StateIdentify R1: current state: identification.
kSDMMC_R1StateStandby R1: current state: standby.
kSDMMC_R1StateTransfer R1: current state: transfer.
kSDMMC_R1StateSendData R1: current state: sending data.
kSDMMC_R1StateReceiveData R1: current state: receiving data.
kSDMMC_R1StateProgram R1: current state: programming.
kSDMMC_R1StateDisconnect R1: current state: disconnect.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 731
Enumeration Type Documentation

33.4.5 enum _sdspi_r1_error_status_flag

Enumerator
kSDSPI_R1InIdleStateFlag In idle state.
kSDSPI_R1EraseResetFlag Erase reset.
kSDSPI_R1IllegalCommandFlag Illegal command.
kSDSPI_R1CommandCrcErrorFlag Com crc error.
kSDSPI_R1EraseSequenceErrorFlag Erase sequence error.
kSDSPI_R1AddressErrorFlag Address error.
kSDSPI_R1ParameterErrorFlag Parameter error.

33.4.6 enum _sdspi_r2_error_status_flag

Enumerator
kSDSPI_R2CardLockedFlag Card is locked.
kSDSPI_R2WriteProtectEraseSkip Write protect erase skip.
kSDSPI_R2LockUnlockFailed Lock/unlock command failed.
kSDSPI_R2ErrorFlag Unknown error.
kSDSPI_R2CardControllerErrorFlag Card controller error.
kSDSPI_R2CardEccFailedFlag Card ecc failed.
kSDSPI_R2WriteProtectViolationFlag Write protect violation.
kSDSPI_R2EraseParameterErrorFlag Erase parameter error.
kSDSPI_R2OutOfRangeFlag Out of range.
kSDSPI_R2CsdOverwriteFlag CSD overwrite.

33.4.7 enum _sdspi_data_error_token

Enumerator
kSDSPI_DataErrorTokenError Data error.
kSDSPI_DataErrorTokenCardControllerError Card controller error.
kSDSPI_DataErrorTokenCardEccFailed Card ecc error.
kSDSPI_DataErrorTokenOutOfRange Out of range.

33.4.8 enum sdspi_data_token_t

Enumerator
kSDSPI_DataTokenBlockRead Single block read, multiple block read.
kSDSPI_DataTokenSingleBlockWrite Single block write.

MCUXpresso SDK API Reference Manual


732 NXP Semiconductors
Enumeration Type Documentation

kSDSPI_DataTokenMultipleBlockWrite Multiple block write.


kSDSPI_DataTokenStopTransfer Stop transmission.

33.4.9 enum sdspi_data_response_token_t

Enumerator
kSDSPI_DataResponseTokenAccepted Data accepted.
kSDSPI_DataResponseTokenCrcError Data rejected due to CRC error.
kSDSPI_DataResponseTokenWriteError Data rejected due to write error.

33.4.10 enum sd_command_t

Enumerator
kSD_SendRelativeAddress Send Relative Address.
kSD_Switch Switch Function.
kSD_SendInterfaceCondition Send Interface Condition.
kSD_VoltageSwitch Voltage Switch.
kSD_SpeedClassControl Speed Class control.
kSD_EraseWriteBlockStart Write Block Start.
kSD_EraseWriteBlockEnd Write Block End.
kSD_SendTuningBlock Send Tuning Block.

33.4.11 enum sdspi_command_t

Enumerator
kSDSPI_CommandCrc Command crc protection on/off.

33.4.12 enum sd_application_command_t

Enumerator
kSD_ApplicationSetBusWdith Set Bus Width.
kSD_ApplicationStatus Send SD status.
kSD_ApplicationSendNumberWriteBlocks Send Number Of Written Blocks.
kSD_ApplicationSetWriteBlockEraseCount Set Write Block Erase Count.
kSD_ApplicationSendOperationCondition Send Operation Condition.
kSD_ApplicationSetClearCardDetect Set Connnect/Disconnect pull up on detect pin.
kSD_ApplicationSendScr Send Scr.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 733
Enumeration Type Documentation

33.4.13 enum _sdmmc_command_class

Enumerator
kSDMMC_CommandClassBasic Card command class 0.
kSDMMC_CommandClassBlockRead Card command class 2.
kSDMMC_CommandClassBlockWrite Card command class 4.
kSDMMC_CommandClassErase Card command class 5.
kSDMMC_CommandClassWriteProtect Card command class 6.
kSDMMC_CommandClassLockCard Card command class 7.
kSDMMC_CommandClassApplicationSpecific Card command class 8.
kSDMMC_CommandClassInputOutputMode Card command class 9.
kSDMMC_CommandClassSwitch Card command class 10.

33.4.14 enum _sd_ocr_flag

Enumerator
kSD_OcrPowerUpBusyFlag Power up busy status.
kSD_OcrHostCapacitySupportFlag Card capacity status.
kSD_OcrCardCapacitySupportFlag Card capacity status.
kSD_OcrSwitch18RequestFlag Switch to 1.8V request.
kSD_OcrSwitch18AcceptFlag Switch to 1.8V accepted.
kSD_OcrVdd27_28Flag VDD 2.7-2.8.
kSD_OcrVdd28_29Flag VDD 2.8-2.9.
kSD_OcrVdd29_30Flag VDD 2.9-3.0.
kSD_OcrVdd30_31Flag VDD 2.9-3.0.
kSD_OcrVdd31_32Flag VDD 3.0-3.1.
kSD_OcrVdd32_33Flag VDD 3.1-3.2.
kSD_OcrVdd33_34Flag VDD 3.2-3.3.
kSD_OcrVdd34_35Flag VDD 3.3-3.4.
kSD_OcrVdd35_36Flag VDD 3.4-3.5.

33.4.15 enum _sd_specification_version

Enumerator
kSD_SpecificationVersion1_0 SD card version 1.0-1.01.
kSD_SpecificationVersion1_1 SD card version 1.10.
kSD_SpecificationVersion2_0 SD card version 2.00.
kSD_SpecificationVersion3_0 SD card version 3.0.

MCUXpresso SDK API Reference Manual


734 NXP Semiconductors
Enumeration Type Documentation

33.4.16 enum sd_data_bus_width_t

Enumerator
kSD_DataBusWidth1Bit SD data bus width 1-bit mode.
kSD_DataBusWidth4Bit SD data bus width 4-bit mode.

33.4.17 enum sd_switch_mode_t

Enumerator
kSD_SwitchCheck SD switch mode 0: check function.
kSD_SwitchSet SD switch mode 1: set function.

33.4.18 enum _sd_csd_flag

Enumerator
kSD_CsdReadBlockPartialFlag Partial blocks for read allowed [79:79].
kSD_CsdWriteBlockMisalignFlag Write block misalignment [78:78].
kSD_CsdReadBlockMisalignFlag Read block misalignment [77:77].
kSD_CsdDsrImplementedFlag DSR implemented [76:76].
kSD_CsdEraseBlockEnabledFlag Erase single block enabled [46:46].
kSD_CsdWriteProtectGroupEnabledFlag Write protect group enabled [31:31].
kSD_CsdWriteBlockPartialFlag Partial blocks for write allowed [21:21].
kSD_CsdFileFormatGroupFlag File format group [15:15].
kSD_CsdCopyFlag Copy flag [14:14].
kSD_CsdPermanentWriteProtectFlag Permanent write protection [13:13].
kSD_CsdTemporaryWriteProtectFlag Temporary write protection [12:12].

33.4.19 enum _sd_scr_flag

Enumerator
kSD_ScrDataStatusAfterErase Data status after erases [55:55].
kSD_ScrSdSpecification3 Specification version 3.00 or higher [47:47].

33.4.20 enum _sd_timing_function

Enumerator
kSD_FunctionSDR12Deafult SDR12 mode & default.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 735
Enumeration Type Documentation

kSD_FunctionSDR25HighSpeed SDR25 & high speed.


kSD_FunctionSDR50 SDR50 mode.
kSD_FunctionSDR104 SDR104 mode.
kSD_FunctionDDR50 DDR50 mode.

33.4.21 enum _sd_group_num

Enumerator
kSD_GroupTimingMode acess mode group
kSD_GroupCommandSystem command system group
kSD_GroupDriverStrength driver strength group
kSD_GroupCurrentLimit current limit group

33.4.22 enum sd_timing_mode_t

Enumerator
kSD_TimingSDR12DefaultMode Identification mode & SDR12.
kSD_TimingSDR25HighSpeedMode High speed mode & SDR25.
kSD_TimingSDR50Mode SDR50 mode.
kSD_TimingSDR104Mode SDR104 mode.
kSD_TimingDDR50Mode DDR50 mode.

33.4.23 enum sd_driver_strength_t

Enumerator
kSD_DriverStrengthTypeB default driver strength
kSD_DriverStrengthTypeA driver strength TYPE A
kSD_DriverStrengthTypeC driver strength TYPE C
kSD_DriverStrengthTypeD driver strength TYPE D

33.4.24 enum sd_max_current_t

Enumerator
kSD_CurrentLimit200MA default current limit
kSD_CurrentLimit400MA current limit to 400MA
kSD_CurrentLimit600MA current limit to 600MA
kSD_CurrentLimit800MA current limit to 800MA

MCUXpresso SDK API Reference Manual


736 NXP Semiconductors
Enumeration Type Documentation

33.4.25 enum sdmmc_command_t

Enumerator
kSDMMC_GoIdleState Go Idle State.
kSDMMC_AllSendCid All Send CID.
kSDMMC_SetDsr Set DSR.
kSDMMC_SelectCard Select Card.
kSDMMC_SendCsd Send CSD.
kSDMMC_SendCid Send CID.
kSDMMC_StopTransmission Stop Transmission.
kSDMMC_SendStatus Send Status.
kSDMMC_GoInactiveState Go Inactive State.
kSDMMC_SetBlockLength Set Block Length.
kSDMMC_ReadSingleBlock Read Single Block.
kSDMMC_ReadMultipleBlock Read Multiple Block.
kSDMMC_SetBlockCount Set Block Count.
kSDMMC_WriteSingleBlock Write Single Block.
kSDMMC_WriteMultipleBlock Write Multiple Block.
kSDMMC_ProgramCsd Program CSD.
kSDMMC_SetWriteProtect Set Write Protect.
kSDMMC_ClearWriteProtect Clear Write Protect.
kSDMMC_SendWriteProtect Send Write Protect.
kSDMMC_Erase Erase.
kSDMMC_LockUnlock Lock Unlock.
kSDMMC_ApplicationCommand Send Application Command.
kSDMMC_GeneralCommand General Purpose Command.
kSDMMC_ReadOcr Read OCR.

33.4.26 enum _sdio_cccr_reg

Enumerator
kSDIO_RegCCCRSdioVer CCCR & SDIO version.
kSDIO_RegSDVersion SD version.
kSDIO_RegIOEnable io enable register
kSDIO_RegIOReady io ready register
kSDIO_RegIOIntEnable io interrupt enable register
kSDIO_RegIOIntPending io interrupt pending register
kSDIO_RegIOAbort io abort register
kSDIO_RegBusInterface bus interface register
kSDIO_RegCardCapability card capability register
kSDIO_RegCommonCISPointer common CIS pointer register
kSDIO_RegBusSuspend bus suspend register

MCUXpresso SDK API Reference Manual


NXP Semiconductors 737
Enumeration Type Documentation

kSDIO_RegFunctionSelect function select register


kSDIO_RegExecutionFlag execution flag register
kSDIO_RegReadyFlag ready flag register
kSDIO_RegFN0BlockSizeLow FN0 block size register.
kSDIO_RegFN0BlockSizeHigh FN0 block size register.
kSDIO_RegPowerControl power control register
kSDIO_RegBusSpeed bus speed register
kSDIO_RegUHSITimingSupport UHS-I timing support register.
kSDIO_RegDriverStrength Driver strength register.
kSDIO_RegInterruptExtension Interrupt extension register.

33.4.27 enum sdio_command_t

Enumerator
kSDIO_SendRelativeAddress send relative address
kSDIO_SendOperationCondition send operation condition
kSDIO_SendInterfaceCondition send interface condition
kSDIO_RWIODirect read/write IO direct command
kSDIO_RWIOExtended read/write IO extended command

33.4.28 enum sdio_func_num_t

Enumerator
kSDIO_FunctionNum0 sdio function0
kSDIO_FunctionNum1 sdio function1
kSDIO_FunctionNum2 sdio function2
kSDIO_FunctionNum3 sdio function3
kSDIO_FunctionNum4 sdio function4
kSDIO_FunctionNum5 sdio function5
kSDIO_FunctionNum6 sdio function6
kSDIO_FunctionNum7 sdio function7
kSDIO_FunctionMemory for combo card

33.4.29 enum _sdio_status_flag

Enumerator
kSDIO_StatusCmdCRCError the CRC check of the previous cmd fail
kSDIO_StatusIllegalCmd cmd illegal for the card state

MCUXpresso SDK API Reference Manual


738 NXP Semiconductors
Enumeration Type Documentation

kSDIO_StatusR6Error special for R6 error status


kSDIO_StatusError A general or an unknown error occurred.
kSDIO_StatusFunctionNumError invail function error
kSDIO_StatusOutofRange cmd argument was out of the allowed range

33.4.30 enum _sdio_ocr_flag

Enumerator
kSDIO_OcrPowerUpBusyFlag Power up busy status.
kSDIO_OcrIONumber number of IO function
kSDIO_OcrMemPresent memory present flag
kSDIO_OcrVdd20_21Flag VDD 2.0-2.1.
kSDIO_OcrVdd21_22Flag VDD 2.1-2.2.
kSDIO_OcrVdd22_23Flag VDD 2.2-2.3.
kSDIO_OcrVdd23_24Flag VDD 2.3-2.4.
kSDIO_OcrVdd24_25Flag VDD 2.4-2.5.
kSDIO_OcrVdd25_26Flag VDD 2.5-2.6.
kSDIO_OcrVdd26_27Flag VDD 2.6-2.7.
kSDIO_OcrVdd27_28Flag VDD 2.7-2.8.
kSDIO_OcrVdd28_29Flag VDD 2.8-2.9.
kSDIO_OcrVdd29_30Flag VDD 2.9-3.0.
kSDIO_OcrVdd30_31Flag VDD 2.9-3.0.
kSDIO_OcrVdd31_32Flag VDD 3.0-3.1.
kSDIO_OcrVdd32_33Flag VDD 3.1-3.2.
kSDIO_OcrVdd33_34Flag VDD 3.2-3.3.
kSDIO_OcrVdd34_35Flag VDD 3.3-3.4.
kSDIO_OcrVdd35_36Flag VDD 3.4-3.5.

33.4.31 enum _sdio_capability_flag

Enumerator
kSDIO_CCCRSupportDirectCmdDuringDataTrans support direct cmd during data transfer
kSDIO_CCCRSupportMultiBlock support multi block mode
kSDIO_CCCRSupportReadWait support read wait
kSDIO_CCCRSupportSuspendResume support suspend resume
kSDIO_CCCRSupportIntDuring4BitDataTrans support interrupt during 4-bit data transfer
kSDIO_CCCRSupportLowSpeed1Bit support low speed 1bit mode
kSDIO_CCCRSupportLowSpeed4Bit support low speed 4bit mode
kSDIO_CCCRSupportMasterPowerControl support master power control
kSDIO_CCCRSupportHighSpeed support high speed
kSDIO_CCCRSupportContinuousSPIInt support continuous SPI interrupt

MCUXpresso SDK API Reference Manual


NXP Semiconductors 739
Enumeration Type Documentation

33.4.32 enum _sdio_fbr_flag

Enumerator
kSDIO_FBRSupportCSA function support CSA
kSDIO_FBRSupportPowerSelection function support power selection

33.4.33 enum sdio_bus_width_t

Enumerator
kSDIO_DataBus1Bit 1 bit bus mode
kSDIO_DataBus4Bit 4 bit bus mode
kSDIO_DataBus8Bit 8 bit bus mode

33.4.34 enum mmc_command_t

Enumerator
kMMC_SendOperationCondition Send Operation Condition.
kMMC_SetRelativeAddress Set Relative Address.
kMMC_SleepAwake Sleep Awake.
kMMC_Switch Switch.
kMMC_SendExtendedCsd Send EXT_CSD.
kMMC_ReadDataUntilStop Read Data Until Stop.
kMMC_BusTestRead Test Read.
kMMC_SendingBusTest test bus width cmd
kMMC_WriteDataUntilStop Write Data Until Stop.
kMMC_SendTuningBlock MMC sending tuning block.
kMMC_ProgramCid Program CID.
kMMC_EraseGroupStart Erase Group Start.
kMMC_EraseGroupEnd Erase Group End.
kMMC_FastInputOutput Fast IO.
kMMC_GoInterruptState Go interrupt State.

33.4.35 enum mmc_classified_voltage_t

Enumerator
kMMC_ClassifiedVoltageHigh High-voltage MMC card.
kMMC_ClassifiedVoltageDual Dual-voltage MMC card.

MCUXpresso SDK API Reference Manual


740 NXP Semiconductors
Enumeration Type Documentation

33.4.36 enum mmc_classified_density_t

Enumerator
kMMC_ClassifiedDensityWithin2GB Density byte is less than or equal 2GB.

33.4.37 enum mmc_access_mode_t

Enumerator
kMMC_AccessModeByte The card should be accessed as byte.
kMMC_AccessModeSector The card should be accessed as sector.

33.4.38 enum mmc_voltage_window_t

Enumerator
kMMC_VoltageWindowNone voltage window is not define by user
kMMC_VoltageWindow120 Voltage window is 1.20V.
kMMC_VoltageWindow170to195 Voltage window is 1.70V to 1.95V.
kMMC_VoltageWindows270to360 Voltage window is 2.70V to 3.60V.

33.4.39 enum mmc_csd_structure_version_t

Enumerator
kMMC_CsdStrucureVersion10 CSD version No. 1.0
kMMC_CsdStrucureVersion11 CSD version No. 1.1
kMMC_CsdStrucureVersion12 CSD version No. 1.2
kMMC_CsdStrucureVersionInExtcsd Version coded in Extended CSD.

33.4.40 enum mmc_specification_version_t

Enumerator
kMMC_SpecificationVersion0 Allocated by MMCA.
kMMC_SpecificationVersion1 Allocated by MMCA.
kMMC_SpecificationVersion2 Allocated by MMCA.
kMMC_SpecificationVersion3 Allocated by MMCA.
kMMC_SpecificationVersion4 Version 4.1/4.2/4.3/4.41-4.5-4.51-5.0.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 741
Enumeration Type Documentation

33.4.41 enum _mmc_extended_csd_revision

Enumerator
kMMC_ExtendedCsdRevision10 Revision 1.0.
kMMC_ExtendedCsdRevision11 Revision 1.1.
kMMC_ExtendedCsdRevision12 Revision 1.2.
kMMC_ExtendedCsdRevision13 Revision 1.3 MMC4.3.
kMMC_ExtendedCsdRevision14 Revision 1.4 obsolete.
kMMC_ExtendedCsdRevision15 Revision 1.5 MMC4.41.
kMMC_ExtendedCsdRevision16 Revision 1.6 MMC4.5.
kMMC_ExtendedCsdRevision17 Revision 1.7 MMC5.0.

33.4.42 enum mmc_command_set_t

Enumerator
kMMC_CommandSetStandard Standard MMC.
kMMC_CommandSet1 Command set 1.
kMMC_CommandSet2 Command set 2.
kMMC_CommandSet3 Command set 3.
kMMC_CommandSet4 Command set 4.

33.4.43 enum _mmc_support_boot_mode

Enumerator
kMMC_SupportAlternateBoot support alternative boot mode
kMMC_SupportDDRBoot support DDR boot mode
kMMC_SupportHighSpeedBoot support high speed boot mode

33.4.44 enum mmc_high_speed_timing_t

Enumerator
kMMC_HighSpeedTimingNone MMC card using none high-speed timing.
kMMC_HighSpeedTiming MMC card using high-speed timing.
kMMC_HighSpeed200Timing MMC card high speed 200 timing.
kMMC_HighSpeed400Timing MMC card high speed 400 timing.

MCUXpresso SDK API Reference Manual


742 NXP Semiconductors
Enumeration Type Documentation

33.4.45 enum mmc_data_bus_width_t

Enumerator
kMMC_DataBusWidth1bit MMC data bus width is 1 bit.
kMMC_DataBusWidth4bit MMC data bus width is 4 bits.
kMMC_DataBusWidth8bit MMC data bus width is 8 bits.
kMMC_DataBusWidth4bitDDR MMC data bus width is 4 bits ddr.
kMMC_DataBusWidth8bitDDR MMC data bus width is 8 bits ddr.

33.4.46 enum mmc_boot_partition_enable_t

Enumerator
kMMC_BootPartitionEnableNot Device not boot enabled (default)
kMMC_BootPartitionEnablePartition1 Boot partition 1 enabled for boot.
kMMC_BootPartitionEnablePartition2 Boot partition 2 enabled for boot.
kMMC_BootPartitionEnableUserAera User area enabled for boot.

33.4.47 enum mmc_boot_timing_mode_t

Enumerator
kMMC_BootModeSDRWithDefaultTiming boot mode single data rate with backward compatiable
timings
kMMC_BootModeSDRWithHighSpeedTiming boot mode single data rate with high speed timing
kMMC_BootModeDDRTiming boot mode dual date rate

33.4.48 enum mmc_boot_partition_wp_t

Enumerator
kMMC_BootPartitionWPDisable boot partition write protection disable
kMMC_BootPartitionPwrWPToBothPartition power on period write protection apply to both boot
partitions
kMMC_BootPartitionPermWPToBothPartition permanent write protection apply to both boot par-
titions
kMMC_BootPartitionPwrWPToPartition1 power on period write protection apply to partition1
kMMC_BootPartitionPwrWPToPartition2 power on period write protection apply to partition2
kMMC_BootPartitionPermWPToPartition1 permanent write protection apply to partition1
kMMC_BootPartitionPermWPToPartition2 permanent write protection apply to partition2

MCUXpresso SDK API Reference Manual


NXP Semiconductors 743
Enumeration Type Documentation

kMMC_BootPartitionPermWPToPartition1PwrWPToPartition2 permanent write protection apply


to partition1, power on period write protection apply to partition2
kMMC_BootPartitionPermWPToPartition2PwrWPToPartition1 permanent write protection apply
to partition2, power on period write protection apply to partition1

33.4.49 enum _mmc_boot_partition_wp_status

Enumerator
kMMC_BootPartitionNotProtected boot partition not protected
kMMC_BootPartitionPwrProtected boot partition is power on period write protected
kMMC_BootPartitionPermProtected boot partition is permanently protected

33.4.50 enum mmc_access_partition_t

Enumerator
kMMC_AccessPartitionUserAera No access to boot partition (default), normal partition.
kMMC_AccessPartitionBoot1 Read/Write boot partition 1.
kMMC_AccessPartitionBoot2 Read/Write boot partition 2.
kMMC_AccessRPMB Replay protected mem block.
kMMC_AccessGeneralPurposePartition1 access to general purpose partition 1
kMMC_AccessGeneralPurposePartition2 access to general purpose partition 2
kMMC_AccessGeneralPurposePartition3 access to general purpose partition 3
kMMC_AccessGeneralPurposePartition4 access to general purpose partition 4

33.4.51 enum _mmc_csd_flag

Enumerator
kMMC_CsdReadBlockPartialFlag Partial blocks for read allowed.
kMMC_CsdWriteBlockMisalignFlag Write block misalignment.
kMMC_CsdReadBlockMisalignFlag Read block misalignment.
kMMC_CsdDsrImplementedFlag DSR implemented.
kMMC_CsdWriteProtectGroupEnabledFlag Write protect group enabled.
kMMC_CsdWriteBlockPartialFlag Partial blocks for write allowed.
kMMC_ContentProtectApplicationFlag Content protect application.
kMMC_CsdFileFormatGroupFlag File format group.
kMMC_CsdCopyFlag Copy flag.
kMMC_CsdPermanentWriteProtectFlag Permanent write protection.
kMMC_CsdTemporaryWriteProtectFlag Temporary write protection.

MCUXpresso SDK API Reference Manual


744 NXP Semiconductors
Enumeration Type Documentation

33.4.52 enum mmc_extended_csd_access_mode_t

Enumerator
kMMC_ExtendedCsdAccessModeCommandSet Command set related setting.
kMMC_ExtendedCsdAccessModeSetBits Set bits in specific byte in Extended CSD.
kMMC_ExtendedCsdAccessModeClearBits Clear bits in specific byte in Extended CSD.
kMMC_ExtendedCsdAccessModeWriteBits Write a value to specific byte in Extended CSD.

33.4.53 enum mmc_extended_csd_index_t

Enumerator
kMMC_ExtendedCsdIndexBootPartitionWP Boot partition write protect.
kMMC_ExtendedCsdIndexEraseGroupDefinition Erase Group Def.
kMMC_ExtendedCsdIndexBootBusConditions Boot Bus conditions.
kMMC_ExtendedCsdIndexBootConfigWP Boot config write protect.
kMMC_ExtendedCsdIndexPartitionConfig Partition Config, before BOOT_CONFIG.
kMMC_ExtendedCsdIndexBusWidth Bus Width.
kMMC_ExtendedCsdIndexHighSpeedTiming High-speed Timing.
kMMC_ExtendedCsdIndexPowerClass Power Class.
kMMC_ExtendedCsdIndexCommandSet Command Set.

33.4.54 enum _mmc_driver_strength

Enumerator
kMMC_DriverStrength0 Driver type0 ,nominal impedance 50ohm.
kMMC_DriverStrength1 Driver type1 ,nominal impedance 33ohm.
kMMC_DriverStrength2 Driver type2 ,nominal impedance 66ohm.
kMMC_DriverStrength3 Driver type3 ,nominal impedance 100ohm.
kMMC_DriverStrength4 Driver type4 ,nominal impedance 40ohm.

33.4.55 enum mmc_extended_csd_flags_t

Enumerator
kMMC_ExtCsdExtPartitionSupport partitioning support[160]
kMMC_ExtCsdEnhancePartitionSupport partitioning support[160]
kMMC_ExtCsdPartitioningSupport partitioning support[160]
kMMC_ExtCsdPrgCIDCSDInDDRModeSupport CMD26 and CMD27 are support dual data rate
[130].

MCUXpresso SDK API Reference Manual


NXP Semiconductors 745
Function Documentation

kMMC_ExtCsdBKOpsSupport background operation feature support [502]


kMMC_ExtCsdDataTagSupport data tag support[499]
kMMC_ExtCsdModeOperationCodeSupport mode operation code support[493]

33.4.56 enum _mmc_boot_mode

Enumerator
kMMC_BootModeNormal Normal boot.
kMMC_BootModeAlternative Alternative boot.

33.5 Function Documentation


33.5.1 status_t SDMMC_SelectCard ( SDMMCHOST_TYPE ∗ base,
SDMMCHOST_TRANSFER_FUNCTION transfer, uint32_t relativeAddress,
bool isSelected )

Parameters

base SDMMCHOST peripheral base address.


transfer SDMMCHOST transfer function.
relativeAddress Relative address.
isSelected True to put card into transfer state.

Return values

kStatus_SDMMC_- Transfer failed.


TransferFailed
kStatus_Success Operate successfully.

33.5.2 status_t SDMMC_SendApplicationCommand ( SDMMCHOST_TYPE ∗ base,


SDMMCHOST_TRANSFER_FUNCTION transfer, uint32_t relativeAddress )

Parameters

MCUXpresso SDK API Reference Manual


746 NXP Semiconductors
Function Documentation

base SDMMCHOST peripheral base address.


transfer SDMMCHOST transfer function.
relativeAddress Card relative address.

Return values

kStatus_SDMMC_- Transfer failed.


TransferFailed
kStatus_SDMMC_Card- Card doesn’t support.
NotSupport
kStatus_Success Operate successfully.

33.5.3 status_t SDMMC_SetBlockCount ( SDMMCHOST_TYPE ∗ base,


SDMMCHOST_TRANSFER_FUNCTION transfer, uint32_t blockCount )

Parameters

base SDMMCHOST peripheral base address.


transfer SDMMCHOST transfer function.
blockCount Block count.

Return values

kStatus_SDMMC_- Transfer failed.


TransferFailed
kStatus_Success Operate successfully.

33.5.4 status_t SDMMC_GoIdle ( SDMMCHOST_TYPE ∗ base,


SDMMCHOST_TRANSFER_FUNCTION transfer )

Parameters

base SDMMCHOST peripheral base address.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 747
Function Documentation

transfer SDMMCHOST transfer function.

Return values

kStatus_SDMMC_- Transfer failed.


TransferFailed
kStatus_Success Operate successfully.

33.5.5 status_t SDMMC_SetBlockSize ( SDMMCHOST_TYPE ∗ base,


SDMMCHOST_TRANSFER_FUNCTION transfer, uint32_t blockSize )

Parameters

base SDMMCHOST peripheral base address.


transfer SDMMCHOST transfer function.
blockSize Block size.

Return values

kStatus_SDMMC_- Transfer failed.


TransferFailed
kStatus_Success Operate successfully.

33.5.6 status_t SDMMC_SetCardInactive ( SDMMCHOST_TYPE ∗ base,


SDMMCHOST_TRANSFER_FUNCTION transfer )

Parameters

base SDMMCHOST peripheral base address.


transfer SDMMCHOST transfer function.

Return values

kStatus_SDMMC_- Transfer failed.


TransferFailed

MCUXpresso SDK API Reference Manual


748 NXP Semiconductors
Function Documentation

kStatus_Success Operate successfully.

33.5.7 void SDMMC_Delay ( uint32_t num )

Parameters

num Delay num∗10000.

33.5.8 status_t SDMMC_SwitchVoltage ( SDMMCHOST_TYPE ∗ base,


SDMMCHOST_TRANSFER_FUNCTION transfer )

Parameters

base SDMMCHOST peripheral base address.


transfer SDMMCHOST transfer function.

33.5.9 status_t SDMMC_SwitchToVoltage ( SDMMCHOST_TYPE ∗ base, SDMMCH-


OST_TRANSFER_FUNCTION transfer, sdmmchost_card_switch_voltage_t
switchVoltageFunc )

Parameters

base SDMMCHOST peripheral base address.


transfer SDMMCHOST transfer function.
switchVoltage- voltage switch function.
Func

Returns
error code.

33.5.10 status_t SDMMC_ExecuteTuning ( SDMMCHOST_TYPE ∗ base,


SDMMCHOST_TRANSFER_FUNCTION transfer, uint32_t tuningCmd,
uint32_t blockSize )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 749
Function Documentation

Parameters

base SDMMCHOST peripheral base address.


transfer Host transfer function
tuningCmd Tuning cmd
blockSize Tuning block size

MCUXpresso SDK API Reference Manual


750 NXP Semiconductors
SDIO Card Driver

33.6 SDIO Card Driver


33.6.1 Overview

The SDIO card driver provide card initialization/IO direct and extend command interface.

33.6.2 SDIO CARD Operation

error log support

Not support yet

User configuable

Board dependency

Typical use case

Data Structures
• struct sdio_card_t
SDIO card state. More...

Macros

• #define FSL_SDIO_DRIVER_VERSION (MAKE_VERSION(2U, 2U, 11U)) /∗2.2.11∗/


Middleware version.
• #define FSL_SDIO_MAX_IO_NUMS (7U)
sdio device support maximum IO number

Typedefs

• typedef void(∗ sdio_io_irq_handler_t )(sdio_card_t ∗card, uint32_t func)


sdio io handler

Enumerations

• enum sdio_io_direction_t {
kSDIO_IORead = 0U,
kSDIO_IOWrite = 1U }
sdio io read/write direction

MCUXpresso SDK API Reference Manual


NXP Semiconductors 751
SDIO Card Driver

Variables

• SDMMCHOST_CONFIG sdio_card_t::host
Host information.
• sdiocard_usr_param_t sdio_card_t::usrParam
user parameter
• bool sdio_card_t::noInternalAlign
use this flag to disable sdmmc align.
• bool sdio_card_t::isHostReady
use this flag to indicate if need host re-init or not
• bool sdio_card_t::memPresentFlag
indicate if memory present
• uint32_t sdio_card_t::busClock_Hz
SD bus clock frequency united in Hz.
• uint32_t sdio_card_t::relativeAddress
Relative address of the card.
• uint8_t sdio_card_t::sdVersion
SD version.
• sd_timing_mode_t sdio_card_t::currentTiming
current timing mode
• sd_driver_strength_t sdio_card_t::driverStrength
driver strength
• sd_max_current_t sdio_card_t::maxCurrent
card current limit
• sdmmc_operation_voltage_t sdio_card_t::operationVoltage
card operation voltage
• uint8_t sdio_card_t::sdioVersion
SDIO version.
• uint8_t sdio_card_t::cccrVersioin
CCCR version.
• uint8_t sdio_card_t::ioTotalNumber
total number of IO function
• uint32_t sdio_card_t::cccrflags
Flags in _sd_card_flag.
• uint32_t sdio_card_t::io0blockSize
record the io0 block size
• uint32_t sdio_card_t::ocr
Raw OCR content, only 24bit avalible for SDIO card.
• uint32_t sdio_card_t::commonCISPointer
point to common CIS
• sdio_common_cis_t sdio_card_t::commonCIS
CIS table.
• sdio_fbr_t sdio_card_t::ioFBR [FSL_SDIO_MAX_IO_NUMS]
FBR table.
• sdio_func_cis_t sdio_card_t::funcCIS [FSL_SDIO_MAX_IO_NUMS]
function CIS table
• sdio_io_irq_handler_t sdio_card_t::ioIRQHandler [FSL_SDIO_MAX_IO_NUMS]
io IRQ handler
• uint8_t sdio_card_t::ioIntIndex
used to record current enabled io interrupt index
• uint8_t sdio_card_t::ioIntNums

MCUXpresso SDK API Reference Manual


752 NXP Semiconductors
SDIO Card Driver

used to record total enabled io interrupt numbers

Initialization and deinitialization

• status_t SDIO_Init (sdio_card_t ∗card)


SDIO card init function.
• void SDIO_Deinit (sdio_card_t ∗card)
SDIO card deinit, include card and host deinit.
• status_t SDIO_CardInit (sdio_card_t ∗card)
Initializes the card.
• void SDIO_CardDeinit (sdio_card_t ∗card)
Deinitializes the card.
• status_t SDIO_HostInit (sdio_card_t ∗card)
initialize the host.
• void SDIO_HostDeinit (sdio_card_t ∗card)
Deinitializes the host.
• void SDIO_HostReset (SDMMCHOST_CONFIG ∗host)
reset the host.
• void SDIO_PowerOnCard (SDMMCHOST_TYPE ∗base, const sdmmchost_pwr_card_t ∗pwr)
power on card.
• void SDIO_PowerOffCard (SDMMCHOST_TYPE ∗base, const sdmmchost_pwr_card_t ∗pwr)
power on card.
• status_t SDIO_CardInActive (sdio_card_t ∗card)
set SDIO card to inactive state
• status_t SDIO_GetCardCapability (sdio_card_t ∗card, sdio_func_num_t func)
get SDIO card capability
• status_t SDIO_SetBlockSize (sdio_card_t ∗card, sdio_func_num_t func, uint32_t blockSize)
set SDIO card block size
• status_t SDIO_CardReset (sdio_card_t ∗card)
set SDIO card reset
• status_t SDIO_SetDataBusWidth (sdio_card_t ∗card, sdio_bus_width_t busWidth)
set SDIO card data bus width
• status_t SDIO_SwitchToHighSpeed (sdio_card_t ∗card)
switch the card to high speed
• status_t SDIO_ReadCIS (sdio_card_t ∗card, sdio_func_num_t func, const uint32_t ∗tupleList,
uint32_t tupleNum)
read SDIO card CIS for each function
• status_t SDIO_WaitCardDetectStatus (SDMMCHOST_TYPE ∗hostBase, const sdmmchost_detect-
_card_t ∗cd, bool waitCardStatus)
sdio wait card detect function.
• bool SDIO_IsCardPresent (sdio_card_t ∗card)
sdio card present check function.

IO operations

• status_t SDIO_IO_Write_Direct (sdio_card_t ∗card, sdio_func_num_t func, uint32_t regAddr,


uint8_t ∗data, bool raw)
IO direct write transfer function.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 753
SDIO Card Driver

• status_t SDIO_IO_Read_Direct (sdio_card_t ∗card, sdio_func_num_t func, uint32_t regAddr,


uint8_t ∗data)
IO direct read transfer function.
• status_t SDIO_IO_RW_Direct (sdio_card_t ∗card, sdio_io_direction_t direction, sdio_func_num_t
func, uint32_t regAddr, uint8_t dataIn, uint8_t ∗dataOut)
IO direct read/write transfer function.
• status_t SDIO_IO_Write_Extended (sdio_card_t ∗card, sdio_func_num_t func, uint32_t regAddr,
uint8_t ∗buffer, uint32_t count, uint32_t flags)
IO extended write transfer function.
• status_t SDIO_IO_Read_Extended (sdio_card_t ∗card, sdio_func_num_t func, uint32_t regAddr,
uint8_t ∗buffer, uint32_t count, uint32_t flags)
IO extended read transfer function.
• status_t SDIO_EnableIOInterrupt (sdio_card_t ∗card, sdio_func_num_t func, bool enable)
enable IO interrupt
• status_t SDIO_EnableIO (sdio_card_t ∗card, sdio_func_num_t func, bool enable)
enable IO and wait IO ready
• status_t SDIO_SelectIO (sdio_card_t ∗card, sdio_func_num_t func)
select IO
• status_t SDIO_AbortIO (sdio_card_t ∗card, sdio_func_num_t func)
Abort IO transfer.
• status_t SDIO_SetDriverStrength (sdio_card_t ∗card, sd_driver_strength_t driverStrength)
Set driver strength.
• status_t SDIO_EnableAsyncInterrupt (sdio_card_t ∗card, bool enable)
Enable/Disable Async interrupt.
• status_t SDIO_GetPendingInterrupt (sdio_card_t ∗card, uint8_t ∗pendingInt)
Get pending interrupt.
• status_t SDIO_IO_Transfer (sdio_card_t ∗card, sdio_command_t cmd, uint32_t argument, uint32_t
blockSize, uint8_t ∗txData, uint8_t ∗rxData, uint16_t dataSize, uint32_t ∗response)
sdio card io transfer function.
• void SDIO_SetIOIRQHandler (sdio_card_t ∗card, sdio_func_num_t func, sdio_io_irq_handler_-
t handler)
sdio set io IRQ handler.

33.6.3 Data Structure Documentation

33.6.3.1 struct _sdio_card

sdio card descriptor


Define the card structure including the necessary fields to identify and describe the card.

Data Fields
• SDMMCHOST_CONFIG host
Host information.
• sdiocard_usr_param_t usrParam
user parameter
• bool noInternalAlign

MCUXpresso SDK API Reference Manual


754 NXP Semiconductors
SDIO Card Driver

use this flag to disable sdmmc align.


• bool isHostReady
use this flag to indicate if need host re-init or not
• bool memPresentFlag
indicate if memory present
• uint32_t busClock_Hz
SD bus clock frequency united in Hz.
• uint32_t relativeAddress
Relative address of the card.
• uint8_t sdVersion
SD version.
• sd_timing_mode_t currentTiming
current timing mode
• sd_driver_strength_t driverStrength
driver strength
• sd_max_current_t maxCurrent
card current limit
• sdmmc_operation_voltage_t operationVoltage
card operation voltage
• uint8_t sdioVersion
SDIO version.
• uint8_t cccrVersioin
CCCR version.
• uint8_t ioTotalNumber
total number of IO function
• uint32_t cccrflags
Flags in _sd_card_flag.
• uint32_t io0blockSize
record the io0 block size
• uint32_t ocr
Raw OCR content, only 24bit avalible for SDIO card.
• uint32_t commonCISPointer
point to common CIS
• sdio_common_cis_t commonCIS
CIS table.
• sdio_fbr_t ioFBR [FSL_SDIO_MAX_IO_NUMS]
FBR table.
• sdio_func_cis_t funcCIS [FSL_SDIO_MAX_IO_NUMS]
function CIS table
• sdio_io_irq_handler_t ioIRQHandler [FSL_SDIO_MAX_IO_NUMS]
io IRQ handler
• uint8_t ioIntIndex
used to record current enabled io interrupt index
• uint8_t ioIntNums
used to record total enabled io interrupt numbers

MCUXpresso SDK API Reference Manual


NXP Semiconductors 755
SDIO Card Driver

33.6.4 Macro Definition Documentation

33.6.4.1 #define FSL_SDIO_DRIVER_VERSION (MAKE_VERSION(2U, 2U, 11U))


/∗2.2.11∗/

33.6.5 Enumeration Type Documentation

33.6.5.1 enum sdio_io_direction_t

Enumerator
kSDIO_IORead io read
kSDIO_IOWrite io write

33.6.6 Function Documentation

33.6.6.1 status_t SDIO_Init ( sdio_card_t ∗ card )

Parameters

card Card descriptor.

Return values

kStatus_SDMMC_Go-
IdleFailed
kStatus_SDMMC_Hand-
ShakeOperation-
ConditionFailed
kStatus_SDMMC_SDIO-
_InvalidCard
kStatus_SDMMC_SDIO-
_InvalidVoltage
kStatus_SDMMC_Send-
RelativeAddressFailed

MCUXpresso SDK API Reference Manual


756 NXP Semiconductors
SDIO Card Driver

kStatus_SDMMC_Select-
CardFailed
kStatus_SDMMC_SDIO-
_SwitchHighSpeedFail
kStatus_SDMMC_SDIO-
_ReadCISFail
kStatus_SDMMC_-
TransferFailed
kStatus_Success

33.6.6.2 void SDIO_Deinit ( sdio_card_t ∗ card )

Parameters

card Card descriptor.

33.6.6.3 status_t SDIO_CardInit ( sdio_card_t ∗ card )

This function initializes the card only, make sure the host is ready when call this function, otherwise it will
return kStatus_SDMMC_HostNotReady.
Parameters

card Card descriptor.

Return values

kStatus_SDMMC_Host- host is not ready.


NotReady
kStatus_SDMMC_Go- Go idle failed.
IdleFailed
kStatus_SDMMC_Not- Card not support.
SupportYet

MCUXpresso SDK API Reference Manual


NXP Semiconductors 757
SDIO Card Driver

kStatus_SDMMC_Send- Send operation condition failed.


OperationCondition-
Failed
kStatus_SDMMC_All- Send CID failed.
SendCidFailed
kStatus_SDMMC_Send- Send relative address failed.
RelativeAddressFailed
kStatus_SDMMC_Send- Send CSD failed.
CsdFailed
kStatus_SDMMC_Select- Send SELECT_CARD command failed.
CardFailed
kStatus_SDMMC_Send- Send SCR failed.
ScrFailed
kStatus_SDMMC_SetBus- Set bus width failed.
WidthFailed
kStatus_SDMMC_Switch- Switch high speed failed.
HighSpeedFailed
kStatus_SDMMC_Set- Set card block size failed.
CardBlockSizeFailed
kStatus_Success Operate successfully.

33.6.6.4 void SDIO_CardDeinit ( sdio_card_t ∗ card )

This function deinitializes the specific card.


Parameters

card Card descriptor.

33.6.6.5 status_t SDIO_HostInit ( sdio_card_t ∗ card )

This function deinitializes the specific host.


Parameters

MCUXpresso SDK API Reference Manual


758 NXP Semiconductors
SDIO Card Driver

card Card descriptor.

33.6.6.6 void SDIO_HostDeinit ( sdio_card_t ∗ card )

This function deinitializes the host.


Parameters

card Card descriptor.

33.6.6.7 void SDIO_HostReset ( SDMMCHOST_CONFIG ∗ host )

This function reset the specific host.


Parameters

host host descriptor.

33.6.6.8 void SDIO_PowerOnCard ( SDMMCHOST_TYPE ∗ base, const


sdmmchost_pwr_card_t ∗ pwr )

The power on operation depend on host or the user define power on function.
Parameters

base host base address.


pwr user define power control configuration

33.6.6.9 void SDIO_PowerOffCard ( SDMMCHOST_TYPE ∗ base, const


sdmmchost_pwr_card_t ∗ pwr )

The power off operation depend on host or the user define power on function.
Parameters

MCUXpresso SDK API Reference Manual


NXP Semiconductors 759
SDIO Card Driver

base host base address.


pwr user define power control configuration

33.6.6.10 status_t SDIO_CardInActive ( sdio_card_t ∗ card )

Parameters

card Card descriptor.

Return values

kStatus_SDMMC_-
TransferFailed
kStatus_Success

33.6.6.11 status_t SDIO_GetCardCapability ( sdio_card_t ∗ card, sdio_func_num_t func )

Parameters

card Card descriptor.


function IO number

Return values

kStatus_SDMMC_-
TransferFailed
kStatus_Success

33.6.6.12 status_t SDIO_SetBlockSize ( sdio_card_t ∗ card, sdio_func_num_t func,


uint32_t blockSize )

Parameters

card Card descriptor.

MCUXpresso SDK API Reference Manual


760 NXP Semiconductors
SDIO Card Driver

function io number
block size

Return values

kStatus_SDMMC_Set-
CardBlockSizeFailed
kStatus_SDMMC_SDIO-
_InvalidArgument
kStatus_Success

33.6.6.13 status_t SDIO_CardReset ( sdio_card_t ∗ card )

Parameters

card Card descriptor.

Return values

kStatus_SDMMC_-
TransferFailed
kStatus_Success

33.6.6.14 status_t SDIO_SetDataBusWidth ( sdio_card_t ∗ card, sdio_bus_width_t


busWidth )

Parameters

card Card descriptor.


data bus width

Return values

kStatus_SDMMC_-
TransferFailed

MCUXpresso SDK API Reference Manual


NXP Semiconductors 761
SDIO Card Driver

kStatus_Success

33.6.6.15 status_t SDIO_SwitchToHighSpeed ( sdio_card_t ∗ card )

Parameters

card Card descriptor.

Return values

kStatus_SDMMC_-
TransferFailed
kStatus_SDMMC_SDIO-
_SwitchHighSpeedFail
kStatus_Success

33.6.6.16 status_t SDIO_ReadCIS ( sdio_card_t ∗ card, sdio_func_num_t func, const


uint32_t ∗ tupleList, uint32_t tupleNum )

Parameters

card Card descriptor.


function io number
tuple code list
tuple code number

Return values

kStatus_SDMMC_SDIO-
_ReadCISFail
kStatus_SDMMC_-
TransferFailed

MCUXpresso SDK API Reference Manual


762 NXP Semiconductors
SDIO Card Driver

kStatus_Success

33.6.6.17 status_t SDIO_WaitCardDetectStatus ( SDMMCHOST_TYPE ∗ hostBase, const


sdmmchost_detect_card_t ∗ cd, bool waitCardStatus )

Detect card through GPIO, CD, DATA3.


Parameters

card card descriptor.


card detect configuration
waitCardStatus wait card detect status

33.6.6.18 bool SDIO_IsCardPresent ( sdio_card_t ∗ card )

Parameters

card card descriptor.

33.6.6.19 status_t SDIO_IO_Write_Direct ( sdio_card_t ∗ card, sdio_func_num_t func,


uint32_t regAddr, uint8_t ∗ data, bool raw )

Parameters

card Card descriptor.


function IO numner
register address
the data pinter to write
raw flag, indicate read after write or write only

Return values

kStatus_SDMMC_-
TransferFailed

MCUXpresso SDK API Reference Manual


NXP Semiconductors 763
SDIO Card Driver

kStatus_Success

33.6.6.20 status_t SDIO_IO_Read_Direct ( sdio_card_t ∗ card, sdio_func_num_t func,


uint32_t regAddr, uint8_t ∗ data )

Parameters

card Card descriptor.


function IO number
register address
data pointer to read

Return values

kStatus_SDMMC_-
TransferFailed
kStatus_Success

33.6.6.21 status_t SDIO_IO_RW_Direct ( sdio_card_t ∗ card, sdio_io_direction_t


direction, sdio_func_num_t func, uint32_t regAddr, uint8_t dataIn, uint8_t ∗
dataOut )

Parameters

card Card descriptor.


direction io access direction, please reference sdio_io_direction_t.
function IO number
register address
dataIn data to write
dataOut data pointer for readback data, support both for read and write, when application want
readback the data after write command, dataOut should not be NULL.

Return values

MCUXpresso SDK API Reference Manual


764 NXP Semiconductors
SDIO Card Driver

kStatus_SDMMC_-
TransferFailed
kStatus_Success

33.6.6.22 status_t SDIO_IO_Write_Extended ( sdio_card_t ∗ card, sdio_func_num_t func,


uint32_t regAddr, uint8_t ∗ buffer, uint32_t count, uint32_t flags )

Parameters

card Card descriptor.


function IO number
register address
data buffer to write
data count
write flags

Return values

kStatus_SDMMC_-
TransferFailed
kStatus_SDMMC_SDIO-
_InvalidArgument
kStatus_Success

33.6.6.23 status_t SDIO_IO_Read_Extended ( sdio_card_t ∗ card, sdio_func_num_t func,


uint32_t regAddr, uint8_t ∗ buffer, uint32_t count, uint32_t flags )

Parameters

card Card descriptor.


function IO number
register address
data buffer to read
data count
write flags

MCUXpresso SDK API Reference Manual


NXP Semiconductors 765
SDIO Card Driver

Return values

kStatus_SDMMC_-
TransferFailed
kStatus_SDMMC_SDIO-
_InvalidArgument
kStatus_Success

33.6.6.24 status_t SDIO_EnableIOInterrupt ( sdio_card_t ∗ card, sdio_func_num_t func,


bool enable )

Parameters

card Card descriptor.


function IO number
enable/disable flag

Return values

kStatus_SDMMC_-
TransferFailed
kStatus_Success

33.6.6.25 status_t SDIO_EnableIO ( sdio_card_t ∗ card, sdio_func_num_t func, bool


enable )

Parameters

card Card descriptor.


function IO number
enable/disable flag

Return values

kStatus_SDMMC_-
TransferFailed
kStatus_Success

MCUXpresso SDK API Reference Manual


766 NXP Semiconductors
SDIO Card Driver

33.6.6.26 status_t SDIO_SelectIO ( sdio_card_t ∗ card, sdio_func_num_t func )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 767
SDIO Card Driver

Parameters

card Card descriptor.


function IO number

Return values

kStatus_SDMMC_-
TransferFailed
kStatus_Success

33.6.6.27 status_t SDIO_AbortIO ( sdio_card_t ∗ card, sdio_func_num_t func )

Parameters

card Card descriptor.


function IO number

Return values

kStatus_SDMMC_-
TransferFailed
kStatus_Success

33.6.6.28 status_t SDIO_SetDriverStrength ( sdio_card_t ∗ card, sd_driver_strength_t


driverStrength )

Parameters

card Card descriptor.


driverStrength target driver strength.

Return values

kStatus_SDMMC_-
TransferFailed
kStatus_Success

MCUXpresso SDK API Reference Manual


768 NXP Semiconductors
SDIO Card Driver

33.6.6.29 status_t SDIO_EnableAsyncInterrupt ( sdio_card_t ∗ card, bool enable )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 769
SDIO Card Driver

Parameters

card Card descriptor.


func function io number.
enable true is enable, false is disable.

Return values

kStatus_SDMMC_-
TransferFailed
kStatus_Success

33.6.6.30 status_t SDIO_GetPendingInterrupt ( sdio_card_t ∗ card, uint8_t ∗ pendingInt )

Parameters

card Card descriptor.


pendingInt pointer store pending interrupt

Return values

kStatus_SDMMC_-
TransferFailed
kStatus_Success

33.6.6.31 status_t SDIO_IO_Transfer ( sdio_card_t ∗ card, sdio_command_t cmd,


uint32_t argument, uint32_t blockSize, uint8_t ∗ txData, uint8_t ∗ rxData,
uint16_t dataSize, uint32_t ∗ response )

This function can be used for trnansfer direct/extend command. Please pay attention to the non-align data
buffer address transfer, if data buffer address can not meet host controller internal DMA requirement, sdio
driver will try to use internal align buffer if data size is not bigger than internal buffer size, Align address
transfer always can get a better performance, so if application want sdio driver make sure buffer address
align, please redefine the SDMMC_GLOBAL_BUFFER_SIZE macro to a value which is big enough for
your application.

MCUXpresso SDK API Reference Manual


770 NXP Semiconductors
SDIO Card Driver

Parameters

card card descriptor.


cmd command to transfer
argument argument to transfer
blockSize used for block mode.
txData tx buffer pointer or NULL
rxData rx buffer pointer or NULL
dataSize transfer data size
response reponse pointer, if application want read response back, please set it to a NON-NULL
pointer.

33.6.6.32 void SDIO_SetIOIRQHandler ( sdio_card_t ∗ card, sdio_func_num_t func,


sdio_io_irq_handler_t handler )

Parameters

card card descriptor.


func function io number.
handler,io IRQ handler.

33.6.7 Variable Documentation

33.6.7.1 bool sdio_card_t::noInternalAlign

If disable, sdmmc will not make sure the data buffer address is word align, otherwise all the transfer are
align to low level driver

MCUXpresso SDK API Reference Manual


NXP Semiconductors 771
SD Card Driver

33.7 SD Card Driver


33.7.1 Overview

The SDCARD driver provide card initialization/read/write/erase interface.

33.7.2 SD CARD Operation

error log support

Lots of error log has been added to sd relate functions, if error occurs during initial/read/write, please
enable the error log print functionality with #define SDMMC_ENABLE_LOG_PRINT 1 And rerun the
project then user can check what kind of error happened.

User configurable
typedef struct _sd_card
{
SDMMCHOST_CONFIG host;
sdcard_usr_param_t usrParam;
bool isHostReady;
bool noInteralAlign;
uint32_t busClock_Hz;
uint32_t relativeAddress;
uint32_t version;
uint32_t flags;
uint32_t rawCid[4U];
uint32_t rawCsd[4U];
uint32_t rawScr[2U];
uint32_t ocr;
sd_cid_t cid;
sd_csd_t csd;
sd_scr_t scr;
uint32_t blockCount;
uint32_t blockSize;
sd_timing_mode_t currentTiming;
sd_driver_strength_t driverStrength;
sd_max_current_t maxCurrent;
sdmmc_operation_voltage_t operationVoltage;
} sd_card_t;

Part of The variables above is user configurable,


1. SDMMCHOST_CONFIG host Application need to provide host controller base address and the
host’s source clock frequency.
2. sdcard_usr_param_t usrParam Two member in the userParam structure, a. cd-which allow applica-
tion define the card insert/remove callback function, redefine the card detect timeout ms and also
allow application determine how to detect card. b. pwr-which allow application redefine the power
on/off function and the power on/off delay ms. However, sdmmc always use the default setting if
application not define it in application. The default setting is depend on the macro defined in the
board.h.

MCUXpresso SDK API Reference Manual


772 NXP Semiconductors
SD Card Driver

3. bool noInteralAlign Sdmmc include an address align internal buffer(to use host controller internal
DMA), to improve read/write performance while application cannot make sure the data address used
to read/write is align, set it to true will achieve a better performance.
4. sd_timing_mode_t currentTiming It is used to indicate the currentTiming the card is working on,
however sdmmc also support preset timing mode, then sdmmc will try to switch to this timing first,
if failed, a valid timing will switch to automatically. Generally, user may not set this variable if you
don’t know what kind of timing the card support, sdmmc will switch to the highest timing which the
card support.
5. sd_driver_strength_t driverStrength Choose a valid card driver strength if application required and
call SD_SetDriverStrength in application.
6. sd_max_current_t maxCurrent Choose a valid card current if application required and call SD_Set-
MaxCurrent in application.

Board dependency

Sdmmc depend on some board specific settings, such as card detect - which is used to detect card, the card
active level is determine by the socket you are using, low level is active usually, but some socket use high
as active, please set the macro #define BOARD_xxxx_CARD_INSERT_CD_LEVEL (0U) According to
your board specific if you cannot detect card even if card is inserted.
power control - Macro for USDHC only, SDHC/SDIF support high speed timing only, so please ignore
the power reset pin for SDHC/SDIF. which is used to reset card power for UHS card, to make UHS timing
work properly, please make sure the power reset pin is configured properly in board.h. #define BOARD_-
SD_POWER_RESET_GPIO (GPIO1) #define BOARD_SD_POWER_RESET_GPIO_PIN (5U) #define
BOARD_USDHC_SDCARD_POWER_CONTROL_INIT() \
pin configurations - Function for USDHC only. which is used to switch the signal pin configurations
include driver strength/speed mode dynamiclly for different timing mode, reference the function defined
in board.c void BOARD_SD_Pin_Config(uint32_t speed, uint32_t strength)

Typical use case

∼∼∼∼∼{.c} /∗ Save host information. ∗/ card->host.base = BOARD_SDHC_BASEADDR; card-


>host.sourceClock_Hz = CLOCK_GetFreq(BOARD_SDHC_CLKSRC);
/∗Redefine the cd and pwr in the application if required∗/ card->usrParam.cd = card->usrParam.pwr =
/∗ intial the host controller ∗/ SD_HostInit(card); /∗wait card inserted, before detect card you can power
off card first and power on again after card inserted, such as∗/ SD_PowerOffCard(card->host.base, card-
>usrParam.pwr); SD_WaitCardDetectStatus(card->host.base, card->usrParam.cd, true); SD_PowerOn-
Card(card->host.base, card->usrParam.pwr); /∗call card initial function∗/ SD_CardInit(card);
/∗ Or you can call below function directly, it is a highlevel init function which will include host initial-
ize,card detect, card initial ∗/
/∗ Init card. ∗/ if (SD_Init(card)) { PRINTF("\r\nSD card init failed.\r\n"); }
/∗ after initialization finised, access the card with below functions. ∗/

MCUXpresso SDK API Reference Manual


NXP Semiconductors 773
SD Card Driver

while (true) { if (kStatus_Success != SD_WriteBlocks(card, g_dataWrite, DATA_BLOCK_START, D-


ATA_BLOCK_COUNT)) { PRINTF("Write multiple data blocks failed.\r\n"); } if (kStatus_Success !=
SD_ReadBlocks(card, g_dataRead, DATA_BLOCK_START, DATA_BLOCK_COUNT)) { PRINTF("-
Read multiple data blocks failed.\r\n"); }
if (kStatus_Success != SD_EraseBlocks(card, DATA_BLOCK_START, DATA_BLOCK_COUNT)) {
PRINTF("Erase multiple data blocks failed.\r\n"); } }
SD_Deinit(card); ∗/
/∗!

Data Structures

• struct sd_card_t
SD card state. More...

Enumerations

• enum _sd_card_flag {
kSD_SupportHighCapacityFlag = (1U << 1U),
kSD_Support4BitWidthFlag = (1U << 2U),
kSD_SupportSdhcFlag = (1U << 3U),
kSD_SupportSdxcFlag = (1U << 4U),
kSD_SupportVoltage180v = (1U << 5U),
kSD_SupportSetBlockCountCmd = (1U << 6U),
kSD_SupportSpeedClassControlCmd = (1U << 7U) }
SD card flags.

SDCARD Function

• status_t SD_Init (sd_card_t ∗card)


Initializes the card on a specific host controller.
• void SD_Deinit (sd_card_t ∗card)
Deinitializes the card.
• status_t SD_CardInit (sd_card_t ∗card)
Initializes the card.
• void SD_CardDeinit (sd_card_t ∗card)
Deinitializes the card.
• status_t SD_HostInit (sd_card_t ∗card)
initialize the host.
• void SD_HostDeinit (sd_card_t ∗card)
Deinitializes the host.
• void SD_HostReset (SDMMCHOST_CONFIG ∗host)
reset the host.
• void SD_PowerOnCard (SDMMCHOST_TYPE ∗base, const sdmmchost_pwr_card_t ∗pwr)
power on card.

MCUXpresso SDK API Reference Manual


774 NXP Semiconductors
SD Card Driver

• void SD_PowerOffCard (SDMMCHOST_TYPE ∗base, const sdmmchost_pwr_card_t ∗pwr)


power off card.
• status_t SD_WaitCardDetectStatus (SDMMCHOST_TYPE ∗hostBase, const sdmmchost_detect_-
card_t ∗cd, bool waitCardStatus)
sd wait card detect function.
• bool SD_IsCardPresent (sd_card_t ∗card)
sd card present check function.
• bool SD_CheckReadOnly (sd_card_t ∗card)
Checks whether the card is write-protected.
• status_t SD_SelectCard (sd_card_t ∗card, bool isSelected)
Send SELECT_CARD command to set the card to be transfer state or not.
• status_t SD_ReadStatus (sd_card_t ∗card)
Send ACMD13 to get the card current status.
• status_t SD_ReadBlocks (sd_card_t ∗card, uint8_t ∗buffer, uint32_t startBlock, uint32_t block-
Count)
Reads blocks from the specific card.
• status_t SD_WriteBlocks (sd_card_t ∗card, const uint8_t ∗buffer, uint32_t startBlock, uint32_t
blockCount)
Writes blocks of data to the specific card.
• status_t SD_EraseBlocks (sd_card_t ∗card, uint32_t startBlock, uint32_t blockCount)
Erases blocks of the specific card.
• status_t SD_SetDriverStrength (sd_card_t ∗card, sd_driver_strength_t driverStrength)
select card driver strength select card driver strength
• status_t SD_SetMaxCurrent (sd_card_t ∗card, sd_max_current_t maxCurrent)
select max current select max operation current

33.7.3 Data Structure Documentation

33.7.3.1 struct sd_card_t

Define the card structure including the necessary fields to identify and describe the card.

Data Fields
• SDMMCHOST_CONFIG host
Host information.
• sdcard_usr_param_t usrParam
user parameter
• bool isHostReady
use this flag to indicate if need host re-init or not
• bool noInteralAlign
use this flag to disable sdmmc align.
• uint32_t busClock_Hz
SD bus clock frequency united in Hz.
• uint32_t relativeAddress
Relative address of the card.
• uint32_t version
Card version.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 775
SD Card Driver

• uint32_t flags
Flags in _sd_card_flag.
• uint32_t rawCid [4U]
Raw CID content.
• uint32_t rawCsd [4U]
Raw CSD content.
• uint32_t rawScr [2U]
Raw CSD content.
• uint32_t ocr
Raw OCR content.
• sd_cid_t cid
CID.
• sd_csd_t csd
CSD.
• sd_scr_t scr
SCR.
• sd_status_t stat
sd 512 bit status
• uint32_t blockCount
Card total block number.
• uint32_t blockSize
Card block size.
• sd_timing_mode_t currentTiming
current timing mode
• sd_driver_strength_t driverStrength
driver strength
• sd_max_current_t maxCurrent
card current limit
• sdmmc_operation_voltage_t operationVoltage
card operation voltage

33.7.3.1.0.38 Field Documentation

33.7.3.1.0.38.1 bool sd_card_t::noInteralAlign

If disable, sdmmc will not make sure the data buffer address is word align, otherwise all the transfer are
align to low level driver

33.7.4 Enumeration Type Documentation

33.7.4.1 enum _sd_card_flag

Enumerator
kSD_SupportHighCapacityFlag Support high capacity.
kSD_Support4BitWidthFlag Support 4-bit data width.
kSD_SupportSdhcFlag Card is SDHC.
kSD_SupportSdxcFlag Card is SDXC.
kSD_SupportVoltage180v card support 1.8v voltage

MCUXpresso SDK API Reference Manual


776 NXP Semiconductors
SD Card Driver

kSD_SupportSetBlockCountCmd card support cmd23 flag


kSD_SupportSpeedClassControlCmd card support speed class control flag

33.7.5 Function Documentation

33.7.5.1 status_t SD_Init ( sd_card_t ∗ card )

This function initializes the card on a specific host controller, it is consist of host init, card detect, card init
function, however user can ignore this high level function, instead of use the low level function, such as
SD_CardInit, SD_HostInit, SD_CardDetect.
Parameters

card Card descriptor.

Return values

kStatus_SDMMC_Host- host is not ready.


NotReady
kStatus_SDMMC_Go- Go idle failed.
IdleFailed
kStatus_SDMMC_Not- Card not support.
SupportYet
kStatus_SDMMC_Send- Send operation condition failed.
OperationCondition-
Failed
kStatus_SDMMC_All- Send CID failed.
SendCidFailed
kStatus_SDMMC_Send- Send relative address failed.
RelativeAddressFailed
kStatus_SDMMC_Send- Send CSD failed.
CsdFailed
kStatus_SDMMC_Select- Send SELECT_CARD command failed.
CardFailed

MCUXpresso SDK API Reference Manual


NXP Semiconductors 777
SD Card Driver

kStatus_SDMMC_Send- Send SCR failed.


ScrFailed
kStatus_SDMMC_SetBus- Set bus width failed.
WidthFailed
kStatus_SDMMC_Switch- Switch high speed failed.
HighSpeedFailed
kStatus_SDMMC_Set- Set card block size failed.
CardBlockSizeFailed
kStatus_Success Operate successfully.

33.7.5.2 void SD_Deinit ( sd_card_t ∗ card )

Parameters

card Card descriptor.

33.7.5.3 status_t SD_CardInit ( sd_card_t ∗ card )

This function initializes the card only, make sure the host is ready when call this function, otherwise it will
return kStatus_SDMMC_HostNotReady.
Parameters

card Card descriptor.

Return values

kStatus_SDMMC_Host- host is not ready.


NotReady
kStatus_SDMMC_Go- Go idle failed.
IdleFailed
kStatus_SDMMC_Not- Card not support.
SupportYet

MCUXpresso SDK API Reference Manual


778 NXP Semiconductors
SD Card Driver

kStatus_SDMMC_Send- Send operation condition failed.


OperationCondition-
Failed
kStatus_SDMMC_All- Send CID failed.
SendCidFailed
kStatus_SDMMC_Send- Send relative address failed.
RelativeAddressFailed
kStatus_SDMMC_Send- Send CSD failed.
CsdFailed
kStatus_SDMMC_Select- Send SELECT_CARD command failed.
CardFailed
kStatus_SDMMC_Send- Send SCR failed.
ScrFailed
kStatus_SDMMC_SetBus- Set bus width failed.
WidthFailed
kStatus_SDMMC_Switch- Switch high speed failed.
HighSpeedFailed
kStatus_SDMMC_Set- Set card block size failed.
CardBlockSizeFailed
kStatus_Success Operate successfully.

33.7.5.4 void SD_CardDeinit ( sd_card_t ∗ card )

This function deinitializes the specific card.


Parameters

card Card descriptor.

33.7.5.5 status_t SD_HostInit ( sd_card_t ∗ card )

This function deinitializes the specific host.


Parameters

MCUXpresso SDK API Reference Manual


NXP Semiconductors 779
SD Card Driver

card Card descriptor.

33.7.5.6 void SD_HostDeinit ( sd_card_t ∗ card )

This function deinitializes the host.


Parameters

card Card descriptor.

33.7.5.7 void SD_HostReset ( SDMMCHOST_CONFIG ∗ host )

This function reset the specific host.


Parameters

host host descriptor.

33.7.5.8 void SD_PowerOnCard ( SDMMCHOST_TYPE ∗ base, const


sdmmchost_pwr_card_t ∗ pwr )

The power on operation depend on host or the user define power on function.
Parameters

base host base address.


pwr user define power control configuration

33.7.5.9 void SD_PowerOffCard ( SDMMCHOST_TYPE ∗ base, const


sdmmchost_pwr_card_t ∗ pwr )

The power off operation depend on host or the user define power on function.
Parameters

MCUXpresso SDK API Reference Manual


780 NXP Semiconductors
SD Card Driver

base host base address.


pwr user define power control configuration

33.7.5.10 status_t SD_WaitCardDetectStatus ( SDMMCHOST_TYPE ∗ hostBase, const


sdmmchost_detect_card_t ∗ cd, bool waitCardStatus )

Detect card through GPIO, CD, DATA3.


Parameters

card card descriptor.


card detect configuration
waitCardStatus wait card detect status

33.7.5.11 bool SD_IsCardPresent ( sd_card_t ∗ card )

Parameters

card card descriptor.

33.7.5.12 bool SD_CheckReadOnly ( sd_card_t ∗ card )

This function checks if the card is write-protected via the CSD register.
Parameters

card The specific card.

Return values

true Card is read only.


false Card isn’t read only.

33.7.5.13 status_t SD_SelectCard ( sd_card_t ∗ card, bool isSelected )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 781
SD Card Driver

Parameters

card Card descriptor.


isSelected True to set the card into transfer state, false to disselect.

Return values

kStatus_SDMMC_- Transfer failed.


TransferFailed
kStatus_Success Operate successfully.

33.7.5.14 status_t SD_ReadStatus ( sd_card_t ∗ card )

Parameters

card Card descriptor.

Return values

kStatus_SDMMC_- Transfer failed.


TransferFailed
kStatus_SDMMC_Send- send application command failed.
ApplicationCommand-
Failed
kStatus_Success Operate successfully.

33.7.5.15 status_t SD_ReadBlocks ( sd_card_t ∗ card, uint8_t ∗ buffer, uint32_t


startBlock, uint32_t blockCount )

This function reads blocks from the specific card with default block size defined by the SDHC_CARD_-
DEFAULT_BLOCK_SIZE.
Parameters

card Card descriptor.


buffer The buffer to save the data read from card.

MCUXpresso SDK API Reference Manual


782 NXP Semiconductors
SD Card Driver

startBlock The start block index.


blockCount The number of blocks to read.

Return values

kStatus_InvalidArgument Invalid argument.


kStatus_SDMMC_Card- Card not support.
NotSupport
kStatus_SDMMC_Not- Not support now.
SupportYet
kStatus_SDMMC_Wait- Send status failed.
WriteCompleteFailed
kStatus_SDMMC_- Transfer failed.
TransferFailed
kStatus_SDMMC_Stop- Stop transmission failed.
TransmissionFailed
kStatus_Success Operate successfully.

33.7.5.16 status_t SD_WriteBlocks ( sd_card_t ∗ card, const uint8_t ∗ buffer, uint32_t


startBlock, uint32_t blockCount )

This function writes blocks to the specific card with default block size 512 bytes.
Parameters

card Card descriptor.


buffer The buffer holding the data to be written to the card.
startBlock The start block index.
blockCount The number of blocks to write.

Return values

kStatus_InvalidArgument Invalid argument.


kStatus_SDMMC_Not- Not support now.
SupportYet

MCUXpresso SDK API Reference Manual


NXP Semiconductors 783
SD Card Driver

kStatus_SDMMC_Card- Card not support.


NotSupport
kStatus_SDMMC_Wait- Send status failed.
WriteCompleteFailed
kStatus_SDMMC_- Transfer failed.
TransferFailed
kStatus_SDMMC_Stop- Stop transmission failed.
TransmissionFailed
kStatus_Success Operate successfully.

33.7.5.17 status_t SD_EraseBlocks ( sd_card_t ∗ card, uint32_t startBlock, uint32_t


blockCount )

This function erases blocks of the specific card with default block size 512 bytes.
Parameters

card Card descriptor.


startBlock The start block index.
blockCount The number of blocks to erase.

Return values

kStatus_InvalidArgument Invalid argument.


kStatus_SDMMC_Wait- Send status failed.
WriteCompleteFailed
kStatus_SDMMC_- Transfer failed.
TransferFailed
kStatus_SDMMC_Wait- Send status failed.
WriteCompleteFailed
kStatus_Success Operate successfully.

33.7.5.18 status_t SD_SetDriverStrength ( sd_card_t ∗ card, sd_driver_strength_t


driverStrength )

MCUXpresso SDK API Reference Manual


784 NXP Semiconductors
SD Card Driver

Parameters

card Card descriptor.


driverStrength Driver strength

33.7.5.19 status_t SD_SetMaxCurrent ( sd_card_t ∗ card, sd_max_current_t maxCurrent


)

Parameters

card Card descriptor.


maxCurrent Max current

MCUXpresso SDK API Reference Manual


NXP Semiconductors 785
MMC Card Driver

33.8 MMC Card Driver


33.8.1 Overview

The MMCCARD driver provide card initialization/read/write/erase interface.

33.8.2 MMC CARD Operation

error log support

Not support yet

User configuable

Board dependency

Typical use case

∼∼∼∼∼{.c}

/* Save host information.

Data Structures

• struct mmc_card_t
mmc card state More...

Enumerations

• enum _mmc_card_flag {
kMMC_SupportHighSpeed26MHZFlag = (1U << 0U),
kMMC_SupportHighSpeed52MHZFlag = (1U << 1U),
kMMC_SupportHighSpeedDDR52MHZ180V300VFlag = (1 << 2U),
kMMC_SupportHighSpeedDDR52MHZ120VFlag = (1 << 3U),
kMMC_SupportHS200200MHZ180VFlag = (1 << 4U),
kMMC_SupportHS200200MHZ120VFlag = (1 << 5U),
kMMC_SupportHS400DDR200MHZ180VFlag = (1 << 6U),
kMMC_SupportHS400DDR200MHZ120VFlag = (1 << 7U),
kMMC_SupportHighCapacityFlag = (1U << 8U),
kMMC_SupportAlternateBootFlag = (1U << 9U),
kMMC_SupportDDRBootFlag = (1U << 10U),
kMMC_SupportHighSpeedBootFlag = (1U << 11U) }
MMC card flags.

MCUXpresso SDK API Reference Manual


786 NXP Semiconductors
MMC Card Driver

MMCCARD Function

• status_t MMC_Init (mmc_card_t ∗card)


Initializes the MMC card and host.
• void MMC_Deinit (mmc_card_t ∗card)
Deinitializes the card and host.
• status_t MMC_CardInit (mmc_card_t ∗card)
intialize the card.
• void MMC_CardDeinit (mmc_card_t ∗card)
Deinitializes the card.
• status_t MMC_HostInit (mmc_card_t ∗card)
initialize the host.
• void MMC_HostDeinit (mmc_card_t ∗card)
Deinitializes the host.
• void MMC_HostReset (SDMMCHOST_CONFIG ∗host)
reset the host.
• void MMC_PowerOnCard (SDMMCHOST_TYPE ∗base, const sdmmchost_pwr_card_t ∗pwr)
power on card.
• void MMC_PowerOffCard (SDMMCHOST_TYPE ∗base, const sdmmchost_pwr_card_t ∗pwr)
power off card.
• bool MMC_CheckReadOnly (mmc_card_t ∗card)
Checks if the card is read-only.
• status_t MMC_ReadBlocks (mmc_card_t ∗card, uint8_t ∗buffer, uint32_t startBlock, uint32_-
t blockCount)
Reads data blocks from the card.
• status_t MMC_WriteBlocks (mmc_card_t ∗card, const uint8_t ∗buffer, uint32_t startBlock, uint32-
_t blockCount)
Writes data blocks to the card.
• status_t MMC_EraseGroups (mmc_card_t ∗card, uint32_t startGroup, uint32_t endGroup)
Erases groups of the card.
• status_t MMC_SelectPartition (mmc_card_t ∗card, mmc_access_partition_t partitionNumber)
Selects the partition to access.
• status_t MMC_SetBootConfig (mmc_card_t ∗card, const mmc_boot_config_t ∗config)
Configures the boot activity of the card.
• status_t MMC_StartBoot (mmc_card_t ∗card, const mmc_boot_config_t ∗mmcConfig, uint8_-
t ∗buffer, SDMMCHOST_BOOT_CONFIG ∗hostConfig)
MMC card start boot.
• status_t MMC_SetBootConfigWP (mmc_card_t ∗card, uint8_t wp)
MMC card set boot configuration write protect.
• status_t MMC_ReadBootData (mmc_card_t ∗card, uint8_t ∗buffer, SDMMCHOST_BOOT_CON-
FIG ∗hostConfig)
MMC card continous read boot data.
• status_t MMC_StopBoot (mmc_card_t ∗card, uint32_t bootMode)
MMC card stop boot mode.
• status_t MMC_SetBootPartitionWP (mmc_card_t ∗card, mmc_boot_partition_wp_t bootPartition-
WP)
MMC card set boot partition write protect.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 787
MMC Card Driver

33.8.3 Data Structure Documentation

33.8.3.1 struct mmc_card_t

Define the card structure including the necessary fields to identify and describe the card.

Data Fields
• SDMMCHOST_CONFIG host
Host information.
• mmccard_usr_param_t usrParam
user parameter
• bool isHostReady
Use this flag to indicate if need host re-init or not.
• bool noInteralAlign
use this flag to disable sdmmc align.
• uint32_t busClock_Hz
MMC bus clock united in Hz.
• uint32_t relativeAddress
Relative address of the card.
• bool enablePreDefinedBlockCount
Enable PRE-DEFINED block count when read/write.
• uint32_t flags
Capability flag in _mmc_card_flag.
• uint32_t rawCid [4U]
Raw CID content.
• uint32_t rawCsd [4U]
Raw CSD content.
• uint32_t rawExtendedCsd [MMC_EXTENDED_CSD_BYTES/4U]
Raw MMC Extended CSD content.
• uint32_t ocr
Raw OCR content.
• mmc_cid_t cid
CID.
• mmc_csd_t csd
CSD.
• mmc_extended_csd_t extendedCsd
Extended CSD.
• uint32_t blockSize
Card block size.
• uint32_t userPartitionBlocks
Card total block number in user partition.
• uint32_t bootPartitionBlocks
Boot partition size united as block size.
• uint32_t eraseGroupBlocks
Erase group size united as block size.
• mmc_access_partition_t currentPartition
Current access partition.
• mmc_voltage_window_t hostVoltageWindowVCCQ
Host IO voltage window.

MCUXpresso SDK API Reference Manual


788 NXP Semiconductors
MMC Card Driver

• mmc_voltage_window_t hostVoltageWindowVCC
application must set this value according to board specific
• mmc_high_speed_timing_t busTiming
indicate the current work timing mode
• mmc_data_bus_width_t busWidth
indicate the current work bus width

33.8.3.1.0.39 Field Documentation

33.8.3.1.0.39.1 bool mmc_card_t::noInteralAlign

If disable, sdmmc will not make sure the data buffer address is word align, otherwise all the transfer are
align to low level driver

33.8.4 Enumeration Type Documentation

33.8.4.1 enum _mmc_card_flag

Enumerator
kMMC_SupportHighSpeed26MHZFlag Support high speed 26MHZ.
kMMC_SupportHighSpeed52MHZFlag Support high speed 52MHZ.
kMMC_SupportHighSpeedDDR52MHZ180V300VFlag ddr 52MHZ 1.8V or 3.0V
kMMC_SupportHighSpeedDDR52MHZ120VFlag DDR 52MHZ 1.2V.
kMMC_SupportHS200200MHZ180VFlag HS200 ,200MHZ,1.8V.
kMMC_SupportHS200200MHZ120VFlag HS200, 200MHZ, 1.2V.
kMMC_SupportHS400DDR200MHZ180VFlag HS400, DDR, 200MHZ,1.8V.
kMMC_SupportHS400DDR200MHZ120VFlag HS400, DDR, 200MHZ,1.2V.
kMMC_SupportHighCapacityFlag Support high capacity.
kMMC_SupportAlternateBootFlag Support alternate boot.
kMMC_SupportDDRBootFlag support DDR boot flag
kMMC_SupportHighSpeedBootFlag support high speed boot flag

33.8.5 Function Documentation

33.8.5.1 status_t MMC_Init ( mmc_card_t ∗ card )

Parameters

MCUXpresso SDK API Reference Manual


NXP Semiconductors 789
MMC Card Driver

card Card descriptor.

Return values

kStatus_SDMMC_Host- host is not ready.


NotReady
kStatus_SDMMC_Go- Go idle failed.
IdleFailed
kStatus_SDMMC_Send- Send operation condition failed.
OperationCondition-
Failed
kStatus_SDMMC_All- Send CID failed.
SendCidFailed
kStatus_SDMMC_Set- Set relative address failed.
RelativeAddressFailed
kStatus_SDMMC_Send- Send CSD failed.
CsdFailed
kStatus_SDMMC_Card- Card not support.
NotSupport
kStatus_SDMMC_Select- Send SELECT_CARD command failed.
CardFailed
kStatus_SDMMC_Send- Send EXT_CSD failed.
ExtendedCsdFailed
kStatus_SDMMC_SetBus- Set bus width failed.
WidthFailed
kStatus_SDMMC_Switch- Switch high speed failed.
HighSpeedFailed
kStatus_SDMMC_Set- Set card block size failed.
CardBlockSizeFailed
kStatus_Success Operate successfully.

33.8.5.2 void MMC_Deinit ( mmc_card_t ∗ card )

Parameters

MCUXpresso SDK API Reference Manual


790 NXP Semiconductors
MMC Card Driver

card Card descriptor.

33.8.5.3 status_t MMC_CardInit ( mmc_card_t ∗ card )

Parameters

card Card descriptor.

Return values

kStatus_SDMMC_Host- host is not ready.


NotReady
kStatus_SDMMC_Go- Go idle failed.
IdleFailed
kStatus_SDMMC_Send- Send operation condition failed.
OperationCondition-
Failed
kStatus_SDMMC_All- Send CID failed.
SendCidFailed
kStatus_SDMMC_Set- Set relative address failed.
RelativeAddressFailed
kStatus_SDMMC_Send- Send CSD failed.
CsdFailed
kStatus_SDMMC_Card- Card not support.
NotSupport
kStatus_SDMMC_Select- Send SELECT_CARD command failed.
CardFailed
kStatus_SDMMC_Send- Send EXT_CSD failed.
ExtendedCsdFailed
kStatus_SDMMC_SetBus- Set bus width failed.
WidthFailed

MCUXpresso SDK API Reference Manual


NXP Semiconductors 791
MMC Card Driver

kStatus_SDMMC_Switch- Switch high speed failed.


HighSpeedFailed
kStatus_SDMMC_Set- Set card block size failed.
CardBlockSizeFailed
kStatus_Success Operate successfully.

33.8.5.4 void MMC_CardDeinit ( mmc_card_t ∗ card )

Parameters

card Card descriptor.

33.8.5.5 status_t MMC_HostInit ( mmc_card_t ∗ card )

This function deinitializes the specific host.


Parameters

card Card descriptor.

33.8.5.6 void MMC_HostDeinit ( mmc_card_t ∗ card )

This function deinitializes the host.


Parameters

card Card descriptor.

33.8.5.7 void MMC_HostReset ( SDMMCHOST_CONFIG ∗ host )

This function reset the specific host.


Parameters

host host descriptor.

MCUXpresso SDK API Reference Manual


792 NXP Semiconductors
MMC Card Driver

33.8.5.8 void MMC_PowerOnCard ( SDMMCHOST_TYPE ∗ base, const


sdmmchost_pwr_card_t ∗ pwr )

The power on operation depend on host or the user define power on function.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 793
MMC Card Driver

Parameters

base host base address.


pwr user define power control configuration

33.8.5.9 void MMC_PowerOffCard ( SDMMCHOST_TYPE ∗ base, const


sdmmchost_pwr_card_t ∗ pwr )

The power off operation depend on host or the user define power on function.
Parameters

base host base address.


pwr user define power control configuration

33.8.5.10 bool MMC_CheckReadOnly ( mmc_card_t ∗ card )

Parameters

card Card descriptor.

Return values

true Card is read only.


false Card isn’t read only.

33.8.5.11 status_t MMC_ReadBlocks ( mmc_card_t ∗ card, uint8_t ∗ buffer, uint32_t


startBlock, uint32_t blockCount )

Parameters

card Card descriptor.


buffer The buffer to save data.
startBlock The start block index.

MCUXpresso SDK API Reference Manual


794 NXP Semiconductors
MMC Card Driver

blockCount The number of blocks to read.

Return values

kStatus_InvalidArgument Invalid argument.


kStatus_SDMMC_Card- Card not support.
NotSupport
kStatus_SDMMC_Set- Set block count failed.
BlockCountFailed
kStatus_SDMMC_- Transfer failed.
TransferFailed
kStatus_SDMMC_Stop- Stop transmission failed.
TransmissionFailed
kStatus_Success Operate successfully.

33.8.5.12 status_t MMC_WriteBlocks ( mmc_card_t ∗ card, const uint8_t ∗ buffer,


uint32_t startBlock, uint32_t blockCount )

Parameters

card Card descriptor.


buffer The buffer to save data blocks.
startBlock Start block number to write.
blockCount Block count.

Return values

kStatus_InvalidArgument Invalid argument.


kStatus_SDMMC_Not- Not support now.
SupportYet
kStatus_SDMMC_Set- Set block count failed.
BlockCountFailed
kStatus_SDMMC_Wait- Send status failed.
WriteCompleteFailed

MCUXpresso SDK API Reference Manual


NXP Semiconductors 795
MMC Card Driver

kStatus_SDMMC_- Transfer failed.


TransferFailed
kStatus_SDMMC_Stop- Stop transmission failed.
TransmissionFailed
kStatus_Success Operate successfully.

33.8.5.13 status_t MMC_EraseGroups ( mmc_card_t ∗ card, uint32_t startGroup,


uint32_t endGroup )

Erase group is the smallest erase unit in MMC card. The erase range is [startGroup, endGroup].
Parameters

card Card descriptor.


startGroup Start group number.
endGroup End group number.

Return values

kStatus_InvalidArgument Invalid argument.


kStatus_SDMMC_Wait- Send status failed.
WriteCompleteFailed
kStatus_SDMMC_- Transfer failed.
TransferFailed
kStatus_Success Operate successfully.

33.8.5.14 status_t MMC_SelectPartition ( mmc_card_t ∗ card, mmc_access_partition_t


partitionNumber )

Parameters

card Card descriptor.


partition- The partition number.
Number

MCUXpresso SDK API Reference Manual


796 NXP Semiconductors
MMC Card Driver

Return values

kStatus_SDMMC_- Configure EXT_CSD failed.


ConfigureExtendedCsd-
Failed
kStatus_Success Operate successfully.

33.8.5.15 status_t MMC_SetBootConfig ( mmc_card_t ∗ card, const mmc_boot_config_t


∗ config )

Parameters

card Card descriptor.


config Boot configuration structure.

Return values

kStatus_SDMMC_Not- Not support now.


SupportYet
kStatus_SDMMC_- Configure EXT_CSD failed.
ConfigureExtendedCsd-
Failed
kStatus_SDMMC_- Configure boot failed.
ConfigureBootFailed
kStatus_Success Operate successfully.

33.8.5.16 status_t MMC_StartBoot ( mmc_card_t ∗ card, const mmc_boot_config_t ∗


mmcConfig, uint8_t ∗ buffer, SDMMCHOST_BOOT_CONFIG ∗ hostConfig )

Parameters

card Card descriptor.


mmcConfig mmc Boot configuration structure.
buffer address to recieve data.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 797
MMC Card Driver

hostConfig host boot configurations.

Return values

kStatus_Fail fail.
kStatus_SDMMC_- transfer fail.
TransferFailed
kStatus_SDMMC_Go- reset card fail.
IdleFailed
kStatus_Success Operate successfully.

33.8.5.17 status_t MMC_SetBootConfigWP ( mmc_card_t ∗ card, uint8_t wp )

Parameters

card Card descriptor.


wp write protect value.

33.8.5.18 status_t MMC_ReadBootData ( mmc_card_t ∗ card, uint8_t ∗ buffer,


SDMMCHOST_BOOT_CONFIG ∗ hostConfig )

Parameters

card Card descriptor.


buffer buffer address.
hostConfig host boot configurations.

33.8.5.19 status_t MMC_StopBoot ( mmc_card_t ∗ card, uint32_t bootMode )

Parameters

card Card descriptor.

MCUXpresso SDK API Reference Manual


798 NXP Semiconductors
MMC Card Driver

bootMode boot mode.

33.8.5.20 status_t MMC_SetBootPartitionWP ( mmc_card_t ∗ card,


mmc_boot_partition_wp_t bootPartitionWP )

Parameters

card Card descriptor.


bootPartition- boot partition write protect value.
WP

MCUXpresso SDK API Reference Manual


NXP Semiconductors 799
HOST adapter Driver

33.9 HOST adapter Driver


33.9.1 Overview

The host adapter driver provide adapter for polling/interrupt/freertos mode.

Data Structures

• struct sdmmchost_detect_card_t
sd card detect More...
• struct sdmmchost_pwr_card_t
card power control More...
• struct sdmmchost_card_int_t
card interrupt application callback More...
• struct sdmmchost_card_switch_voltage_func_t
card switch voltage function collection More...
• struct sdmmhostcard_usr_param_t
card user parameter, user can define the parameter according the board, card capability More...

Macros

• #define SDMMCHOST_NOT_SUPPORT 0U
use this define to indicate the host not support feature
• #define SDMMCHOST_SUPPORT 1U
use this define to indicate the host support feature

Typedefs

• typedef void(∗ sdmmchost_cd_callback_t )(bool isInserted, void ∗userData)


card detect callback definition
• typedef void(∗ sdmmchost_pwr_t )(void)
card power control function pointer
• typedef void(∗ sdmmchost_card_int_callback_t )(void ∗userData)
card interrupt function pointer
• typedef void(∗ sdmmchost_card_switch_voltage_t )(void)
card switch voltage function pointer
• typedef sdmmhostcard_usr_param_t sdcard_usr_param_t
@ brief specifiy card user parameter name

Enumerations

• enum _sdmmchost_endian_mode {
kSDMMCHOST_EndianModeBig = 0U,
kSDMMCHOST_EndianModeHalfWordBig = 1U,
kSDMMCHOST_EndianModeLittle = 2U }

MCUXpresso SDK API Reference Manual


800 NXP Semiconductors
HOST adapter Driver

host Endian mode corresponding to driver define


• enum sdmmchost_detect_card_type_t {
kSDMMCHOST_DetectCardByGpioCD,
kSDMMCHOST_DetectCardByHostCD,
kSDMMCHOST_DetectCardByHostDATA3 }
sd card detect type

adaptor function

• static status_t SDMMCHOST_NotSupport (void ∗parameter)


host not support function, this function is used for host not support feature
• status_t SDMMCHOST_WaitCardDetectStatus (SDMMCHOST_TYPE ∗hostBase, const sdmmchost-
_detect_card_t ∗cd, bool waitCardStatus)
Detect card insert, only need for SD cases.
• bool SDMMCHOST_IsCardPresent (void)
check card is present or not.
• status_t SDMMCHOST_Init (SDMMCHOST_CONFIG ∗host, void ∗userData)
Init host controller.
• void SDMMCHOST_Reset (SDMMCHOST_TYPE ∗base)
reset host controller.
• void SDMMCHOST_ErrorRecovery (SDMMCHOST_TYPE ∗base)
host controller error recovery.
• void SDMMCHOST_Deinit (void ∗host)
Deinit host controller.
• void SDMMCHOST_PowerOffCard (SDMMCHOST_TYPE ∗base, const sdmmchost_pwr_card_t
∗pwr)
host power off card function.
• void SDMMCHOST_PowerOnCard (SDMMCHOST_TYPE ∗base, const sdmmchost_pwr_card_t
∗pwr)
host power on card function.
• void SDMMCHOST_Delay (uint32_t milliseconds)
SDMMC host delay function.

33.9.2 Data Structure Documentation

33.9.2.1 struct sdmmchost_detect_card_t

Data Fields
• sdmmchost_detect_card_type_t cdType
card detect type
• uint32_t cdTimeOut_ms
card detect timeout which allow 0 - 0xFFFFFFF, value 0 will return im
0xFFFFFFFF will block until card is insert
• sdmmchost_cd_callback_t cardInserted
card inserted callback which is meaningful for interrupt case
• sdmmchost_cd_callback_t cardRemoved

MCUXpresso SDK API Reference Manual


NXP Semiconductors 801
HOST adapter Driver

card removed callback which is meaningful for interrupt case


• void ∗ userData
user data

33.9.2.2 struct sdmmchost_pwr_card_t

Data Fields
• sdmmchost_pwr_t powerOn
power on function pointer
• uint32_t powerOnDelay_ms
power on delay
• sdmmchost_pwr_t powerOff
power off function pointer
• uint32_t powerOffDelay_ms
power off delay

33.9.2.3 struct sdmmchost_card_int_t

Data Fields
• void ∗ userData
user data
• sdmmchost_card_int_callback_t cardInterrupt
card int call back

33.9.2.4 struct sdmmchost_card_switch_voltage_func_t

Data Fields
• sdmmchost_card_switch_voltage_t cardSignalLine1V8
switch to 1.8v function pointer
• sdmmchost_card_switch_voltage_t cardSignalLine3V3
switch to 3.3V function pointer

33.9.2.5 struct sdmmhostcard_usr_param_t

Data Fields
• const sdmmchost_detect_card_t ∗ cd
card detect type
• const sdmmchost_pwr_card_t ∗ pwr
power control configuration
• const sdmmchost_card_int_t ∗ cardInt
call back function for card interrupt
• const
sdmmchost_card_switch_voltage_func_t ∗ cardVoltage

MCUXpresso SDK API Reference Manual


802 NXP Semiconductors
HOST adapter Driver

card voltage switch function

33.9.3 Enumeration Type Documentation

33.9.3.1 enum _sdmmchost_endian_mode

Enumerator
kSDMMCHOST_EndianModeBig Big endian mode.
kSDMMCHOST_EndianModeHalfWordBig Half word big endian mode.
kSDMMCHOST_EndianModeLittle Little endian mode.

33.9.3.2 enum sdmmchost_detect_card_type_t

Enumerator
kSDMMCHOST_DetectCardByGpioCD sd card detect by CD pin through GPIO
kSDMMCHOST_DetectCardByHostCD sd card detect by CD pin through host
kSDMMCHOST_DetectCardByHostDATA3 sd card detect by DAT3 pin through host

33.9.4 Function Documentation

33.9.4.1 static status_t SDMMCHOST_NotSupport ( void ∗ parameter ) [inline],


[static]

Parameters

void parameter ,used to avoid build warning

Return values

kStatus_Fail,host do not suppport

33.9.4.2 status_t SDMMCHOST_WaitCardDetectStatus ( SDMMCHOST_TYPE ∗ hostBase,


const sdmmchost_detect_card_t ∗ cd, bool waitCardStatus )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 803
HOST adapter Driver

Parameters

base the pointer to host base address


cd card detect configuration
waitCardStatus status which user want to wait

Return values

kStatus_Success detect card insert


kStatus_Fail card insert event fail

33.9.4.3 bool SDMMCHOST_IsCardPresent ( void )

Return values

true card is present


false card is not present

33.9.4.4 status_t SDMMCHOST_Init ( SDMMCHOST_CONFIG ∗ host, void ∗ userData )

Parameters

host the pointer to host structure in card structure.


userData specific user data

Return values

kStatus_Success host init success


kStatus_Fail event fail

33.9.4.5 void SDMMCHOST_Reset ( SDMMCHOST_TYPE ∗ base )

Parameters

MCUXpresso SDK API Reference Manual


804 NXP Semiconductors
HOST adapter Driver

host base address.

33.9.4.6 void SDMMCHOST_ErrorRecovery ( SDMMCHOST_TYPE ∗ base )

Parameters

host base address.

33.9.4.7 void SDMMCHOST_Deinit ( void ∗ host )

Parameters

host the pointer to host structure in card structure.

33.9.4.8 void SDMMCHOST_PowerOffCard ( SDMMCHOST_TYPE ∗ base, const


sdmmchost_pwr_card_t ∗ pwr )

Parameters

base host base address.


pwr depend on user define power configuration.

33.9.4.9 void SDMMCHOST_PowerOnCard ( SDMMCHOST_TYPE ∗ base, const


sdmmchost_pwr_card_t ∗ pwr )

Parameters

base host base address.


pwr depend on user define power configuration.

33.9.4.10 void SDMMCHOST_Delay ( uint32_t milliseconds )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 805
HOST adapter Driver

Parameters

milliseconds delay counter.

MCUXpresso SDK API Reference Manual


806 NXP Semiconductors
Chapter 34
SPI based Secure Digital Card (SDSPI)
34.1 Overview
The MCUXpresso SDK provides a driver to access the Secure Digital Card based on the SPI driver.

Function groups
This function group implements the SD card functional API in the SPI mode.

Typical use case


/* SPI_Init(). */

/* Register the SDSPI driver callback. */

/* Initializes card. */
if (kStatus_Success != SDSPI_Init(card))
{
SDSPI_Deinit(card)
return;
}

/* Read/Write card */
memset(g_testWriteBuffer, 0x17U, sizeof(g_testWriteBuffer));

while (true)
{
memset(g_testReadBuffer, 0U, sizeof(g_testReadBuffer));

SDSPI_WriteBlocks(card, g_testWriteBuffer, TEST_START_BLOCK, TEST_BLOCK_COUNT);

SDSPI_ReadBlocks(card, g_testReadBuffer, TEST_START_BLOCK, TEST_BLOCK_COUNT);

if (memcmp(g_testReadBuffer, g_testReadBuffer, sizeof(g_testWriteBuffer)))


{
break;
}
}

Data Structures
• struct sdspi_host_t
SDSPI host state. More...
• struct sdspi_card_t
SD Card Structure. More...

MCUXpresso SDK API Reference Manual


NXP Semiconductors 807
Overview

Enumerations
• enum _sdspi_status {
kStatus_SDSPI_SetFrequencyFailed = MAKE_STATUS(kStatusGroup_SDSPI, 0U),
kStatus_SDSPI_ExchangeFailed = MAKE_STATUS(kStatusGroup_SDSPI, 1U),
kStatus_SDSPI_WaitReadyFailed = MAKE_STATUS(kStatusGroup_SDSPI, 2U),
kStatus_SDSPI_ResponseError = MAKE_STATUS(kStatusGroup_SDSPI, 3U),
kStatus_SDSPI_WriteProtected = MAKE_STATUS(kStatusGroup_SDSPI, 4U),
kStatus_SDSPI_GoIdleFailed = MAKE_STATUS(kStatusGroup_SDSPI, 5U),
kStatus_SDSPI_SendCommandFailed = MAKE_STATUS(kStatusGroup_SDSPI, 6U),
kStatus_SDSPI_ReadFailed = MAKE_STATUS(kStatusGroup_SDSPI, 7U),
kStatus_SDSPI_WriteFailed = MAKE_STATUS(kStatusGroup_SDSPI, 8U),
kStatus_SDSPI_SendInterfaceConditionFailed,
kStatus_SDSPI_SendOperationConditionFailed,
kStatus_SDSPI_ReadOcrFailed = MAKE_STATUS(kStatusGroup_SDSPI, 11U),
kStatus_SDSPI_SetBlockSizeFailed = MAKE_STATUS(kStatusGroup_SDSPI, 12U),
kStatus_SDSPI_SendCsdFailed = MAKE_STATUS(kStatusGroup_SDSPI, 13U),
kStatus_SDSPI_SendCidFailed = MAKE_STATUS(kStatusGroup_SDSPI, 14U),
kStatus_SDSPI_StopTransmissionFailed = MAKE_STATUS(kStatusGroup_SDSPI, 15U),
kStatus_SDSPI_SendApplicationCommandFailed,
kStatus_SDSPI_InvalidVoltage = MAKE_STATUS(kStatusGroup_SDSPI, 17U),
kStatus_SDSPI_SwitchCmdFail = MAKE_STATUS(kStatusGroup_SDSPI, 18U),
kStatus_SDSPI_NotSupportYet = MAKE_STATUS(kStatusGroup_SDSPI, 19U) }
SDSPI API status.
• enum _sdspi_card_flag {
kSDSPI_SupportHighCapacityFlag = (1U << 0U),
kSDSPI_SupportSdhcFlag = (1U << 1U),
kSDSPI_SupportSdxcFlag = (1U << 2U),
kSDSPI_SupportSdscFlag = (1U << 3U) }
SDSPI card flag.
• enum _sdspi_response_type {
kSDSPI_ResponseTypeR1 = 0U,
kSDSPI_ResponseTypeR1b = 1U,
kSDSPI_ResponseTypeR2 = 2U,
kSDSPI_ResponseTypeR3 = 3U,
kSDSPI_ResponseTypeR7 = 4U }
SDSPI response type.
• enum _sdspi_cmd {
kSDSPI_CmdGoIdle = kSDMMC_GoIdleState << 8U | kSDSPI_ResponseTypeR1,
kSDSPI_CmdCrc = kSDSPI_CommandCrc << 8U | kSDSPI_ResponseTypeR1,
kSDSPI_CmdSendInterfaceCondition }
SDSPI command type.

SDSPI Function
• status_t SDSPI_Init (sdspi_card_t ∗card)
Initializes the card on a specific SPI instance.

MCUXpresso SDK API Reference Manual


808 NXP Semiconductors
Data Structure Documentation

• void SDSPI_Deinit (sdspi_card_t ∗card)


Deinitializes the card.
• bool SDSPI_CheckReadOnly (sdspi_card_t ∗card)
Checks whether the card is write-protected.
• status_t SDSPI_ReadBlocks (sdspi_card_t ∗card, uint8_t ∗buffer, uint32_t startBlock, uint32_-
t blockCount)
Reads blocks from the specific card.
• status_t SDSPI_WriteBlocks (sdspi_card_t ∗card, uint8_t ∗buffer, uint32_t startBlock, uint32_t
blockCount)
Writes blocks of data to the specific card.
• status_t SDSPI_SendCid (sdspi_card_t ∗card)
Send GET-CID command In our sdspi init function, this function is removed for better code size, if id
information is needed, you can call it after the init function directly.
• status_t SDSPI_SendPreErase (sdspi_card_t ∗card, uint32_t blockCount)
Multiple blocks write pre-erase function.
• status_t SDSPI_EraseBlocks (sdspi_card_t ∗card, uint32_t startBlock, uint32_t blockCount)
Block erase function.
• status_t SDSPI_SwitchToHighSpeed (sdspi_card_t ∗card)
Switch to high speed function.

34.2 Data Structure Documentation


34.2.1 struct sdspi_host_t

Data Fields

• uint32_t busBaudRate
Bus baud rate.
• status_t(∗ setFrequency )(uint32_t frequency)
Set frequency of SPI.
• status_t(∗ exchange )(uint8_t ∗in, uint8_t ∗out, uint32_t size)
Exchange data over SPI.

34.2.2 struct sdspi_card_t

Define the card structure including the necessary fields to identify and describe the card.

Data Fields

• sdspi_host_t ∗ host
Host state information.
• uint32_t relativeAddress
Relative address of the card.
• uint32_t flags
Flags defined in _sdspi_card_flag.
• uint8_t rawCid [16U]
Raw CID content.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 809
Enumeration Type Documentation

• uint8_t rawCsd [16U]


Raw CSD content.
• uint8_t rawScr [8U]
Raw SCR content.
• uint32_t ocr
Raw OCR content.
• sd_cid_t cid
CID.
• sd_csd_t csd
CSD.
• sd_scr_t scr
SCR.
• uint32_t blockCount
Card total block number.
• uint32_t blockSize
Card block size.

34.2.2.0.0.40 Field Documentation

34.2.2.0.0.40.1 uint32_t sdspi_card_t::flags

34.3 Enumeration Type Documentation


34.3.1 enum _sdspi_status

Enumerator
kStatus_SDSPI_SetFrequencyFailed Set frequency failed.
kStatus_SDSPI_ExchangeFailed Exchange data on SPI bus failed.
kStatus_SDSPI_WaitReadyFailed Wait card ready failed.
kStatus_SDSPI_ResponseError Response is error.
kStatus_SDSPI_WriteProtected Write protected.
kStatus_SDSPI_GoIdleFailed Go idle failed.
kStatus_SDSPI_SendCommandFailed Send command failed.
kStatus_SDSPI_ReadFailed Read data failed.
kStatus_SDSPI_WriteFailed Write data failed.
kStatus_SDSPI_SendInterfaceConditionFailed Send interface condition failed.
kStatus_SDSPI_SendOperationConditionFailed Send operation condition failed.
kStatus_SDSPI_ReadOcrFailed Read OCR failed.
kStatus_SDSPI_SetBlockSizeFailed Set block size failed.
kStatus_SDSPI_SendCsdFailed Send CSD failed.
kStatus_SDSPI_SendCidFailed Send CID failed.
kStatus_SDSPI_StopTransmissionFailed Stop transmission failed.
kStatus_SDSPI_SendApplicationCommandFailed Send application command failed.
kStatus_SDSPI_InvalidVoltage invaild supply voltage
kStatus_SDSPI_SwitchCmdFail switch command crc protection on/off
kStatus_SDSPI_NotSupportYet not support

MCUXpresso SDK API Reference Manual


810 NXP Semiconductors
Function Documentation

34.3.2 enum _sdspi_card_flag

Enumerator
kSDSPI_SupportHighCapacityFlag Card is high capacity.
kSDSPI_SupportSdhcFlag Card is SDHC.
kSDSPI_SupportSdxcFlag Card is SDXC.
kSDSPI_SupportSdscFlag Card is SDSC.

34.3.3 enum _sdspi_response_type

Enumerator
kSDSPI_ResponseTypeR1 Response 1.
kSDSPI_ResponseTypeR1b Response 1 with busy.
kSDSPI_ResponseTypeR2 Response 2.
kSDSPI_ResponseTypeR3 Response 3.
kSDSPI_ResponseTypeR7 Response 7.

34.3.4 enum _sdspi_cmd

Enumerator
kSDSPI_CmdGoIdle command go idle
kSDSPI_CmdCrc command crc protection
kSDSPI_CmdSendInterfaceCondition command send interface condition

34.4 Function Documentation


34.4.1 status_t SDSPI_Init ( sdspi_card_t ∗ card )

This function initializes the card on a specific SPI instance.


Parameters

card Card descriptor

Return values

MCUXpresso SDK API Reference Manual


NXP Semiconductors 811
Function Documentation

kStatus_SDSPI_Set- Set frequency failed.


FrequencyFailed
kStatus_SDSPI_GoIdle- Go idle failed.
Failed
kStatus_SDSPI_Send- Send interface condition failed.
InterfaceConditionFailed
kStatus_SDSPI_Send- Send operation condition failed.
OperationCondition-
Failed
kStatus_Timeout Send command timeout.
kStatus_SDSPI_Not- Not support yet.
SupportYet
kStatus_SDSPI_ReadOcr- Read OCR failed.
Failed
kStatus_SDSPI_SetBlock- Set block size failed.
SizeFailed
kStatus_SDSPI_SendCsd- Send CSD failed.
Failed
kStatus_SDSPI_SendCid- Send CID failed.
Failed
kStatus_Success Operate successfully.

34.4.2 void SDSPI_Deinit ( sdspi_card_t ∗ card )

This function deinitializes the specific card.


Parameters

card Card descriptor

34.4.3 bool SDSPI_CheckReadOnly ( sdspi_card_t ∗ card )

This function checks if the card is write-protected via CSD register.

MCUXpresso SDK API Reference Manual


812 NXP Semiconductors
Function Documentation

Parameters

card Card descriptor.

Return values

true Card is read only.


false Card isn’t read only.

34.4.4 status_t SDSPI_ReadBlocks ( sdspi_card_t ∗ card, uint8_t ∗ buffer, uint32_t


startBlock, uint32_t blockCount )

This function reads blocks from specific card.


Parameters

card Card descriptor.


buffer the buffer to hold the data read from card
startBlock the start block index
blockCount the number of blocks to read

Return values

kStatus_SDSPI_Send- Send command failed.


CommandFailed
kStatus_SDSPI_Read- Read data failed.
Failed
kStatus_SDSPI_Stop- Stop transmission failed.
TransmissionFailed
kStatus_Success Operate successfully.

34.4.5 status_t SDSPI_WriteBlocks ( sdspi_card_t ∗ card, uint8_t ∗ buffer, uint32_t


startBlock, uint32_t blockCount )

This function writes blocks to specific card

MCUXpresso SDK API Reference Manual


NXP Semiconductors 813
Function Documentation

Parameters

card Card descriptor.


buffer the buffer holding the data to be written to the card
startBlock the start block index
blockCount the number of blocks to write

Return values

kStatus_SDSPI_Write- Card is write protected.


Protected
kStatus_SDSPI_Send- Send command failed.
CommandFailed
kStatus_SDSPI_- Response is error.
ResponseError
kStatus_SDSPI_Write- Write data failed.
Failed
kStatus_SDSPI_- Exchange data over SPI failed.
ExchangeFailed
kStatus_SDSPI_Wait- Wait card to be ready status failed.
ReadyFailed
kStatus_Success Operate successfully.

34.4.6 status_t SDSPI_SendCid ( sdspi_card_t ∗ card )

Parameters

card Card descriptor.

Return values

kStatus_SDSPI_Send- Send command failed.


CommandFailed

MCUXpresso SDK API Reference Manual


814 NXP Semiconductors
Function Documentation

kStatus_SDSPI_Read- Read data blocks failed.


Failed
kStatus_Success Operate successfully.

34.4.7 status_t SDSPI_SendPreErase ( sdspi_card_t ∗ card, uint32_t blockCount )

This function should be called before SDSPI_WriteBlocks, it is used to set the number of the write blocks
to be pre-erased before writing.
Parameters

card Card descriptor.


blockCount the block counts to be write.

Return values

kStatus_SDSPI_Send- Send command failed.


CommandFailed
kStatus_SDSPI_Send-
ApplicationCommand-
Failed
kStatus_SDSPI_-
ResponseError
kStatus_Success Operate successfully.

34.4.8 status_t SDSPI_EraseBlocks ( sdspi_card_t ∗ card, uint32_t startBlock,


uint32_t blockCount )

Parameters

card Card descriptor.


startBlock start block address to be erase.
blockCount the block counts to be erase.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 815
Function Documentation

Return values

kStatus_SDSPI_Wait- Wait ready failed.


ReadyFailed
kStatus_SDSPI_Send- Send command failed.
CommandFailed
kStatus_Success Operate successfully.

34.4.9 status_t SDSPI_SwitchToHighSpeed ( sdspi_card_t ∗ card )

This function can be called after SDSPI_Init function if target board’s layout support >25MHZ spi bau-
drate, otherwise this function is useless.Be careful with call this function, code size and stack usage will
be enlarge.
Parameters

card Card descriptor.

Return values

kStatus_Fail switch failed.


kStatus_Success Operate successfully.

MCUXpresso SDK API Reference Manual


816 NXP Semiconductors
Chapter 35
Debug Console
35.1 Overview
This chapter describes the programming interface of the debug console driver.
The debug console enables debug log messages to be output via the specified peripheral with frequency of
the peripheral source clock and base address at the specified baud rate. Additionally, it provides input and
output functions to scan and print formatted data. The below picture shows the laylout of debug console.

Figure 35.1.1: Debug console overview

35.2 Function groups


35.2.1 Initialization

To initialize the debug console, call the DbgConsole_Init() function with these parameters. This function
automatically enables the module and the clock.

status_t DbgConsole_Init(uint8_t instance, uint32_t baudRate,


serial_port_type_t device, uint32_t clkSrcFreq);

Select the supported debug console hardware device type, such as

typedef enum _serial_port_type


{
kSerialPort_Uart = 1U,

MCUXpresso SDK API Reference Manual


NXP Semiconductors 817
Function groups

kSerialPort_UsbCdc,
kSerialPort_Swo,
kSerialPort_UsbCdcVirtual,
} serial_port_type_t;

After the initialization is successful, stdout and stdin are connected to the selected peripheral.
This example shows how to call the DbgConsole_Init() given the user configuration structure.

DbgConsole_Init(BOARD_DEBUG_UART_INSTANCE, BOARD_DEBUG_UART_BAUDRATE, BOARD_DEBUG_UART_TYPE,


BOARD_DEBUG_UART_CLK_FREQ);

35.2.2 Advanced Feature

The debug console provides input and output functions to scan and print formatted data.
• Support a format specifier for PRINTF following this prototype " %[flags][width][.precision][length]specifier",
which is explained below

flags Description
- Left-justified within the given field width. Right-
justified is the default.
+ Forces to precede the result with a plus or minus
sign (+ or -) even for positive numbers. By default,
only negative numbers are preceded with a - sign.
(space) If no sign is written, a blank space is inserted be-
fore the value.
# Used with o, x, or X specifiers the value is pre-
ceded with 0, 0x, or 0X respectively for values
other than zero. Used with e, E and f, it forces
the written output to contain a decimal point even
if no digits would follow. By default, if no digits
follow, no decimal point is written. Used with g or
G the result is the same as with e or E but trailing
zeros are not removed.
0 Left-pads the number with zeroes (0) instead of
spaces, where padding is specified (see width sub-
specifier).

MCUXpresso SDK API Reference Manual


818 NXP Semiconductors
Function groups

Width Description
(number) A minimum number of characters to be printed. If
the value to be printed is shorter than this number,
the result is padded with blank spaces. The value
is not truncated even if the result is larger.
∗ The width is not specified in the format string, but
as an additional integer value argument preceding
the argument that has to be formatted.

.precision Description
.number For integer specifiers (d, i, o, u, x, X) precision
specifies the minimum number of digits to be writ-
ten. If the value to be written is shorter than this
number, the result is padded with leading zeros.
The value is not truncated even if the result is
longer. A precision of 0 means that no character
is written for the value 0. For e, E, and f speci-
fiers this is the number of digits to be printed after
the decimal point. For g and G specifiers This
is the maximum number of significant digits to be
printed. For s this is the maximum number of
characters to be printed. By default, all characters
are printed until the ending null character is en-
countered. For c type it has no effect. When no
precision is specified, the default is 1. If the period
is specified without an explicit value for precision,
0 is assumed.
.∗ The precision is not specified in the format string,
but as an additional integer value argument pre-
ceding the argument that has to be formatted.

length Description
Do not support

specifier Description
d or i Signed decimal integer
f Decimal floating point
F Decimal floating point capital letters
x Unsigned hexadecimal integer

MCUXpresso SDK API Reference Manual


NXP Semiconductors 819
Function groups

specifier Description
X Unsigned hexadecimal integer capital letters
o Signed octal
b Binary value
p Pointer address
u Unsigned decimal integer
c Character
s String of characters
n Nothing printed

• Support a format specifier for SCANF following this prototype " %[∗][width][length]specifier",
which is explained below

∗ Description
An optional starting asterisk indicates that the data is to be read from the stream but ignored. In other
words, it is not stored in the corresponding argument.

width Description
This specifies the maximum number of characters to be read in the current reading operation.

length Description
hh The argument is interpreted as a signed charac-
ter or unsigned character (only applies to integer
specifiers: i, d, o, u, x, and X).
h The argument is interpreted as a short integer
or unsigned short integer (only applies to integer
specifiers: i, d, o, u, x, and X).
l The argument is interpreted as a long integer or
unsigned long integer for integer specifiers (i, d,
o, u, x, and X) and as a wide character or wide
character string for specifiers c and s.
ll The argument is interpreted as a long long integer
or unsigned long long integer for integer specifiers
(i, d, o, u, x, and X) and as a wide character or
wide character string for specifiers c and s.
L The argument is interpreted as a long double (only
applies to floating point specifiers: e, E, f, g, and
G).

MCUXpresso SDK API Reference Manual


820 NXP Semiconductors
Function groups

length Description
j or z or t Not supported

specifier Qualifying Input Type of argument


c Single character: Reads the next char ∗
character. If a width different
from 1 is specified, the function
reads width characters and stores
them in the successive locations
of the array passed as argument.
No null character is appended at
the end.
i Integer: : Number optionally int ∗
preceded with a + or - sign
d Decimal integer: Number op- int ∗
tionally preceded with a + or -
sign
a, A, e, E, f, F, g, G Floating point: Decimal number float ∗
containing a decimal point, op-
tionally preceded by a + or - sign
and optionally followed by the
e or E character and a decimal
number. Two examples of valid
entries are -732.103 and 7.12e4
o Octal Integer: int ∗
s String of characters. This reads char ∗
subsequent characters until a
white space is found (white
space characters are considered
to be blank, newline, and tab).
u Unsigned decimal integer. unsigned int ∗

The debug console has its own printf/scanf/putchar/getchar functions which are defined in the header file.

int DbgConsole_Printf(const char *fmt_s, ...);


int DbgConsole_Putchar(int ch);
int DbgConsole_Scanf(char *fmt_ptr, ...);
int DbgConsole_Getchar(void);

This utility supports selecting toolchain’s printf/scanf or the MCUXpresso SDK printf/scanf.

#if SDK_DEBUGCONSOLE /* Select printf, scanf, putchar, getchar of SDK version. */

MCUXpresso SDK API Reference Manual


NXP Semiconductors 821
Typical use case

#define PRINTF DbgConsole_Printf


#define SCANF DbgConsole_Scanf
#define PUTCHAR DbgConsole_Putchar
#define GETCHAR DbgConsole_Getchar
#else /* Select printf, scanf, putchar, getchar of toolchain. */
#define PRINTF printf
#define SCANF scanf
#define PUTCHAR putchar
#define GETCHAR getchar
#endif /* SDK_DEBUGCONSOLE */

35.3 Typical use case


Some examples use the PUTCHAR & GETCHAR function

ch = GETCHAR();
PUTCHAR(ch);

Some examples use the PRINTF function

Statement prints the string format.

PRINTF("%s %s\r\n", "Hello", "world!");

Statement prints the hexadecimal format/

PRINTF("0x%02X hexadecimal number equivalents 255", 255);

Statement prints the decimal floating point and unsigned decimal.

PRINTF("Execution timer: %s\n\rTime: %u ticks %2.5f milliseconds\n\rDONE\n\r", "1 day", 86400, 86.4);

Some examples use the SCANF function

PRINTF("Enter a decimal number: ");


SCANF("%d", &i);
PRINTF("\r\nYou have entered %d.\r\n", i, i);
PRINTF("Enter a hexadecimal number: ");
SCANF("%x", &i);
PRINTF("\r\nYou have entered 0x%X (%d).\r\n", i, i);

Print out failure messages using MCUXpresso SDK __assert_func:

void __assert_func(const char *file, int line, const char *func, const char *failedExpr)
{
PRINTF("ASSERT ERROR \" %s \": file \"%s\" Line \"%d\" function name \"%s\" \n", failedExpr, file
, line, func);
for (;;)
{}
}

MCUXpresso SDK API Reference Manual


822 NXP Semiconductors
Typical use case

Note:

To use ’printf’ and ’scanf’ for GNUC Base, add file ’fsl_sbrk.c’ in path: ..\{package}\devices\{subset}\utilities\fsl-
_sbrk.c to your project.

Modules
• SWO
• Semihosting

Macros
• #define DEBUGCONSOLE_REDIRECT_TO_TOOLCHAIN 0U
Definition select redirect toolchain printf, scanf to uart or not.
• #define DEBUGCONSOLE_REDIRECT_TO_SDK 1U
Select SDK version printf, scanf.
• #define DEBUGCONSOLE_DISABLE 2U
Disable debugconsole function.
• #define SDK_DEBUGCONSOLE 1U
Definition to select sdk or toolchain printf, scanf.
• #define SDK_DEBUGCONSOLE_UART
Definition to select redirect toolchain printf, scanf to uart or not.
• #define PRINTF DbgConsole_Printf
Definition to select redirect toolchain printf, scanf to uart or not.

Typedefs
• typedef void(∗ printfCb )(char ∗buf, int32_t ∗indicator, char val, int len)
A function pointer which is used when format printf log.

Functions
• int StrFormatPrintf (const char ∗fmt, va_list ap, char ∗buf, printfCb cb)
This function outputs its parameters according to a formatted string.
• int StrFormatScanf (const char ∗line_ptr, char ∗format, va_list args_ptr)
Converts an input line of ASCII characters based upon a provided string format.

Variables
• serial_handle_t g_serialHandle
serial manager handle

Initialization
• status_t DbgConsole_Init (uint8_t instance, uint32_t baudRate, serial_port_type_t device, uint32_t
clkSrcFreq)
Initializes the peripheral used for debug messages.
• status_t DbgConsole_Deinit (void)
De-initializes the peripheral used for debug messages.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 823
Function Documentation

• int DbgConsole_Printf (const char ∗formatString,...)


Writes formatted output to the standard output stream.
• int DbgConsole_Putchar (int ch)
Writes a character to stdout.
• int DbgConsole_Scanf (char ∗formatString,...)
Reads formatted data from the standard input stream.
• int DbgConsole_Getchar (void)
Reads a character from standard input.
• status_t DbgConsole_Flush (void)
Debug console flush.

35.4 Macro Definition Documentation


35.4.1 #define DEBUGCONSOLE_REDIRECT_TO_TOOLCHAIN 0U

Select toolchain printf and scanf.

35.4.2 #define DEBUGCONSOLE_REDIRECT_TO_SDK 1U

35.4.3 #define DEBUGCONSOLE_DISABLE 2U

35.4.4 #define SDK_DEBUGCONSOLE 1U

The macro only support to be redefined in project setting.

35.4.5 #define SDK_DEBUGCONSOLE_UART

35.4.6 #define PRINTF DbgConsole_Printf

if SDK_DEBUGCONSOLE defined to 0,it represents select toolchain printf, scanf. if SDK_DEBUGCO-


NSOLE defined to 1,it represents select SDK version printf, scanf. if SDK_DEBUGCONSOLE defined
to 2,it represents disable debugconsole function.

35.5 Function Documentation


35.5.1 status_t DbgConsole_Init ( uint8_t instance, uint32_t baudRate,
serial_port_type_t device, uint32_t clkSrcFreq )

Call this function to enable debug log messages to be output via the specified peripheral initialized by the
serial manager module. After this function has returned, stdout and stdin are connected to the selected
peripheral.

MCUXpresso SDK API Reference Manual


824 NXP Semiconductors
Function Documentation

Parameters

instance The instance of the module.


baudRate The desired baud rate in bits per second.
device Low level device type for the debug console, can be one of the following.
• kSerialPort_Uart,
• kSerialPort_UsbCdc
• kSerialPort_UsbCdcVirtual.

clkSrcFreq Frequency of peripheral source clock.

Returns
Indicates whether initialization was successful or not.

Return values

kStatus_Success Execution successfully

35.5.2 status_t DbgConsole_Deinit ( void )

Call this function to disable debug log messages to be output via the specified peripheral initialized by the
serial manager module.

Returns
Indicates whether de-initialization was successful or not.

35.5.3 int DbgConsole_Printf ( const char ∗ formatString, ... )

Call this function to write a formatted output to the standard output stream.
Parameters

formatString Format control string.

Returns
Returns the number of characters printed or a negative value if an error occurs.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 825
Function Documentation

35.5.4 int DbgConsole_Putchar ( int ch )

Call this function to write a character to stdout.

MCUXpresso SDK API Reference Manual


826 NXP Semiconductors
Function Documentation

Parameters

ch Character to be written.

Returns
Returns the character written.

35.5.5 int DbgConsole_Scanf ( char ∗ formatString, ... )

Call this function to read formatted data from the standard input stream.

Note
Due the limitation in the BM OSA environment (CPU is blocked in the function, other tasks will not
be scheduled), the function cannot be used when the DEBUG_CONSOLE_TRANSFER_NON_B-
LOCKING is set in the BM OSA environment. And an error is returned when the function called in
this case. The suggestion is that polling the non-blocking function DbgConsole_TryGetchar to get
the input char.

Parameters

formatString Format control string.

Returns
Returns the number of fields successfully converted and assigned.

35.5.6 int DbgConsole_Getchar ( void )

Call this function to read a character from standard input.

Note
Due the limitation in the BM OSA environment (CPU is blocked in the function, other tasks will not
be scheduled), the function cannot be used when the DEBUG_CONSOLE_TRANSFER_NON_B-
LOCKING is set in the BM OSA environment. And an error is returned when the function called in
this case. The suggestion is that polling the non-blocking function DbgConsole_TryGetchar to get
the input char.

Returns
Returns the character read.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 827
Function Documentation

35.5.7 status_t DbgConsole_Flush ( void )

Call this function to wait the tx buffer empty. If interrupt transfer is using, make sure the global IRQ is
enable before call this function This function should be called when 1, before enter power down mode 2,
log is required to print to terminal immediately

Returns
Indicates whether wait idle was successful or not.

35.5.8 int StrFormatPrintf ( const char ∗ fmt, va_list ap, char ∗ buf, printfCb cb )

Note
I/O is performed by calling given function pointer using following (∗func_ptr)(c);

Parameters

in fmt Format string for printf.


in ap Arguments to printf.
in buf pointer to the buffer
cb print callbck function pointer

Returns
Number of characters to be print

35.5.9 int StrFormatScanf ( const char ∗ line_ptr, char ∗ format, va_list args_ptr )

Parameters

in line_ptr The input line of ASCII data.


in format Format first points to the format string.
in args_ptr The list of parameters.

Returns
Number of input items converted and assigned.

MCUXpresso SDK API Reference Manual


828 NXP Semiconductors
Function Documentation

Return values

IO_EOF When line_ptr is empty string "".

MCUXpresso SDK API Reference Manual


NXP Semiconductors 829
Semihosting

35.6 Semihosting
Semihosting is a mechanism for ARM targets to communicate input/output requests from application code
to a host computer running a debugger. This mechanism can be used, for example, to enable functions in
the C library, such as printf() and scanf(), to use the screen and keyboard of the host rather than having a
screen and keyboard on the target system.

35.6.1 Guide Semihosting for IAR

NOTE: After the setting both "printf" and "scanf" are available for debugging, if you want use PRINTF
with semihosting, please make sure the SDK_DEBUGCONSOLE is disabled.

Step 1: Setting up the environment


1. To set debugger options, choose Project>Options. In the Debugger category, click the Setup tab.
2. Select Run to main and click OK. This ensures that the debug session starts by running the main
function.
3. The project is now ready to be built.

Step 2: Building the project


1. Compile and link the project by choosing Project>Make or F7.
2. Alternatively, click the Make button on the tool bar. The Make command compiles and links those
files that have been modified.

Step 3: Starting semihosting


1. Choose "Semihosting_IAR" project -> "Options" -> "Debugger" -> "J-Link/J-Trace".
2. Choose tab "J-Link/J-Trace" -> "Connection" tab -> "SWD".
3. Choose tab "General Options" -> "Library Configurations", select Semihosted, select Via semihost-
ing.
1. Make sure the SDK_DEBUGCONSOLE_UART is not defined, remove the default definition in
fsl_debug_console.h.
1. Start the project by choosing Project>Download and Debug.
2. Choose View>Terminal I/O to display the output from the I/O operations.

35.6.2 Guide Semihosting for Keil µVision

NOTE: Semihosting is not support by MDK-ARM, use the retargeting functionality of MDK-ARM in-
stead.

MCUXpresso SDK API Reference Manual


830 NXP Semiconductors
Semihosting

35.6.3 Guide Semihosting for MCUXpresso IDE

Step 1: Setting up the environment


1. To set debugger options, choose Project>Properties. select the setting category.
2. Select Tool Settings, unfold MCU C Compile.
3. Select Preprocessor item.
4. Set SDK_DEBUGCONSOLE=0, if set SDK_DEBUGCONSOLE=1, the log will be redirect to the
UART.

Step 2: Building the project


1. Compile and link the project.

Step 3: Starting semihosting


1. Download and debug the project.
2. When the project runs successfully, the result can be seen in the Console window.
Semihosting can also be selected through the "Quick settings" menu in the left bottom window, Quick
settings->SDK Debug Console->Semihost console.

35.6.4 Guide Semihosting for ARMGCC

Step 1: Setting up the environment


1. Turn on "J-LINK GDB Server" -> Select suitable "Target device" -> "OK".
2. Turn on "PuTTY". Set up as follows.
• "Host Name (or IP address)" : localhost
• "Port" :2333
• "Connection type" : Telet.
• Click "Open".
3. Increase "Heap/Stack" for GCC to 0x2000:
Add to "CMakeLists.txt"
SET(CMAKE_EXE_LINKER_FLAGS_RELEASE "${CMAKE_EXE_LINKER_FLAGS_RELEASE}
--defsym=__stack_size__=0x2000")
SET(CMAKE_EXE_LINKER_FLAGS_DEBUG "${CMAKE_EXE_LINKER_FLAGS_DEBUG} --
defsym=__stack_size__=0x2000")
SET(CMAKE_EXE_LINKER_FLAGS_DEBUG "${CMAKE_EXE_LINKER_FLAGS_DEBUG} --
defsym=__heap_size__=0x2000")
SET(CMAKE_EXE_LINKER_FLAGS_RELEASE "${CMAKE_EXE_LINKER_FLAGS_RELEASE}
--defsym=__heap_size__=0x2000")

MCUXpresso SDK API Reference Manual


NXP Semiconductors 831
Semihosting

Step 2: Building the project


1. Change "CMakeLists.txt":
Change "SET(CMAKE_EXE_LINKER_FLAGS_RELEASE "${CMAKE_EXE_LINKER_FLA-
GS_RELEASE} –specs=nano.specs")"
to "SET(CMAKE_EXE_LINKER_FLAGS_RELEASE "${CMAKE_EXE_LINKER_FLAGS_R-
ELEASE} –specs=rdimon.specs")"
Replace paragraph
SET(CMAKE_EXE_LINKER_FLAGS_DEBUG "${CMAKE_EXE_LINKER_FLAGS_DEBU-
G} -fno-common")
SET(CMAKE_EXE_LINKER_FLAGS_DEBUG "${CMAKE_EXE_LINKER_FLAGS_DEBU-
G} -ffunction-sections")
SET(CMAKE_EXE_LINKER_FLAGS_DEBUG "${CMAKE_EXE_LINKER_FLAGS_DEBU-
G} -fdata-sections")
SET(CMAKE_EXE_LINKER_FLAGS_DEBUG "${CMAKE_EXE_LINKER_FLAGS_DEBU-
G} -ffreestanding")
SET(CMAKE_EXE_LINKER_FLAGS_DEBUG "${CMAKE_EXE_LINKER_FLAGS_DEBU-
G} -fno-builtin")
SET(CMAKE_EXE_LINKER_FLAGS_DEBUG "${CMAKE_EXE_LINKER_FLAGS_DEBU-
G} -mthumb")
SET(CMAKE_EXE_LINKER_FLAGS_DEBUG "${CMAKE_EXE_LINKER_FLAGS_DEBU-
G} -mapcs")
SET(CMAKE_EXE_LINKER_FLAGS_DEBUG "${CMAKE_EXE_LINKER_FLAGS_DEBU-
G} -Xlinker")
SET(CMAKE_EXE_LINKER_FLAGS_DEBUG "${CMAKE_EXE_LINKER_FLAGS_DEBU-
G} --gc-sections")
SET(CMAKE_EXE_LINKER_FLAGS_DEBUG "${CMAKE_EXE_LINKER_FLAGS_DEBU-
G} -Xlinker")
SET(CMAKE_EXE_LINKER_FLAGS_DEBUG "${CMAKE_EXE_LINKER_FLAGS_DEBU-
G} -static")
SET(CMAKE_EXE_LINKER_FLAGS_DEBUG "${CMAKE_EXE_LINKER_FLAGS_DEBU-
G} -Xlinker")
SET(CMAKE_EXE_LINKER_FLAGS_DEBUG "${CMAKE_EXE_LINKER_FLAGS_DEBU-
G} -z")
SET(CMAKE_EXE_LINKER_FLAGS_DEBUG "${CMAKE_EXE_LINKER_FLAGS_DEBU-
G} -Xlinker")
SET(CMAKE_EXE_LINKER_FLAGS_DEBUG "${CMAKE_EXE_LINKER_FLAGS_DEBU-
G} muldefs")
To
SET(CMAKE_EXE_LINKER_FLAGS_DEBUG "${CMAKE_EXE_LINKER_FLAGS_DEBU-
G} --specs=rdimon.specs ")
Remove
target_link_libraries(semihosting_ARMGCC.elf debug nosys)
2. Run "build_debug.bat" to build project

MCUXpresso SDK API Reference Manual


832 NXP Semiconductors
Semihosting

Step 3: Starting semihosting


(a) Download the image and set as follows.
cd D:\mcu-sdk-2.0-origin\boards\twrk64f120m\driver_examples\semihosting\armgcc\debug
d:
C:\PROGRA~2\GNUTOO~1\4BD65~1.920\bin\arm-none-eabi-gdb.exe
target remote localhost:2331
monitor reset
monitor semihosting enable
monitor semihosting thumbSWI 0xAB
monitor semihosting IOClient 1
monitor flash device = MK64FN1M0xxx12
load semihosting_ARMGCC.elf
monitor reg pc = (0x00000004)
monitor reg sp = (0x00000000)
continue

(b) After the setting, press "enter". The PuTTY window now shows the printf() output.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 833
SWO

35.7 SWO
Serial wire output is a mechanism for ARM targets to output signal from core through a single pin. Some
IDEs also support SWO, such IAR and KEIL, both input and output are supported, see below for details.

35.7.1 Guide SWO for SDK

NOTE: After the setting both "printf" and "PRINTF" are available for debugging, JlinkSWOViewer can
be used to capture the output log.

Step 1: Setting up the environment


1. Define SERIAL_PORT_TYPE_SWO in your project settings.
2. Prepare code, the port and baudrate can be decided by application, clkSrcFreq should be mcu core
clock frequency:
DbgConsole_Init(instance, baudRate, SERIAL_PORT_TYPE_SWO, clkSrcFreq);

3. Use PRINTF or printf to print some thing in application.

Step 2: Building the project


Step 3: Download and run project

35.7.1.1 Guide SWO for IAR

NOTE: After the setting both "printf" and "scanf" are available for debugging.

Step 1: Setting up the environment


1. Choose project -> "Options" -> "Debugger" -> "J-Link/J-Trace".
2. Choose tab "J-Link/J-Trace" -> "Connection" tab -> "SWD".
3. Choose tab "General Options" -> "Library Configurations", select Semihosted, select Via SWO.
4. To configure the hardware’s generation of trace data, click the SWO Configuration button available
in the SWO Configuration dialog box. The value of the CPU clock option must reflect the frequency
of the CPU clock speed at which the application executes. Note also that the settings you make are
preserved between debug sessions. To decrease the amount of transmissions on the communication
channel, you can disable the Timestamp option. Alternatively, set a lower rate for PC Sampling or
use a higher SWO clock frequency.
5. Open the SWO Trace window from J-LINK,and click the Activate button to enable trace data col-
lection.
6. There are three cases for this SDK_DEBUGCONSOLE_UART whether or not defined. a: if use
uppercase PRINTF to output log,The SDK_DEBUGCONSOLE_UART defined or not defined will
not effect debug function. b: if use lowercase printf to output log and defined SDK_DEBUGCON-
SOLE_UART to zero,then debug function ok. c: if use lowercase printf to output log and defined
SDK_DEBUGCONSOLE_UART to one,then debug function ok.

MCUXpresso SDK API Reference Manual


834 NXP Semiconductors
SWO

NOTE: Case a or c only apply at example which enable swo function,the SDK_DEBUGCONSOLE_U-
ART definition in fsl_debug_console.h. For case a and c, Do and not do the above third step will be not
affect function.
1. Start the project by choosing Project>Download and Debug.

Step 2: Building the project


Step 3: Starting swo
1. Download and debug application.
2. Choose View -> Terminal I/O to display the output from the I/O operations.
3. Run application.

35.7.2 Guide SWO for Keil µVision

NOTE: After the setting both "printf" and "scanf" are available for debugging.

Step 1: Setting up the environment


1. There are three cases for this SDK_DEBUGCONSOLE_UART whether or not defined. a: if use
uppercase PRINTF to output log,the SDK_DEBUGCONSOLE_UART definition does not affect the
functionality and skip the second step directly. b: if use lowercase printf to output log and defined
SDK_DEBUGCONSOLE_UART to zero,then start the second step. c: if use lowercase printf to
output log and defined SDK_DEBUGCONSOLE_UART to one,then skip the second step directly.
NOTE: Case a or c only apply at example which enable swo function,the SDK_DEBUGCONSOLE_U-
ART definition in fsl_debug_console.h.
1. In menu bar, click Management Run-Time Environment icon, select Compiler, unfold I/O, enable
STDERR/STDIN/STDOUT and set the variant to ITM.
2. Open Project>Options for target or using Alt+F7 or click.
3. Select “Debug” tab, select “J-Link/J-Trace Cortex” and click “Setting button”.
4. Select “Debug” tab and choose Port:SW, then select "Trace" tab, choose "Enable" and click O-
K, please make sure the Core clock is set correctly, enable autodetect max SWO clk, enable ITM
Stimulus Ports 0.

Step 3: Building the project


1. Compile and link the project by choosing Project>Build Target or using F7.

Step 4: Run the project


1. Choose “Debug” on menu bar or Ctrl F5.
2. In menu bar, choose "Serial Window" and click to "Debug (printf) Viewer".
3. Run line by line to see result in Console Window.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 835
SWO

35.7.3 Guide SWO for MCUXpresso IDE

NOTE: MCUX support SWO for LPC-Link2 debug probe only.

35.7.4 Guide SWO for ARMGCC

NOTE: ARMGCC has no library support SWO.

MCUXpresso SDK API Reference Manual


836 NXP Semiconductors
Chapter 36
Notification Framework
36.1 Overview
This section describes the programming interface of the Notifier driver.

36.2 Notifier Overview


The Notifier provides a configuration dynamic change service. Based on this service, applications can
switch between pre-defined configurations. The Notifier enables drivers and applications to register call-
back functions to this framework. Each time that the configuration is changed, drivers and applications
receive a notification and change their settings. To simplify, the Notifier only supports the static callback
registration. This means that, for applications, all callback functions are collected into a static table and
passed to the Notifier.
These are the steps for the configuration transition.
1. Before configuration transition, the Notifier sends a "BEFORE" message to the callback table. When
this message is received, IP drivers should check whether any current processes can be stopped and
stop them. If the processes cannot be stopped, the callback function returns an error.
The Notifier supports two types of transition policies, a graceful policy and a forceful policy. When
the graceful policy is used, if some callbacks return an error while sending a "BEFORE" message,
the configuration transition stops and the Notifier sends a "RECOVER" message to all drivers that
have stopped. Then, these drivers can recover the previous status and continue to work. When the
forceful policy is used, drivers are stopped forcefully.
2. After the "BEFORE" message is processed successfully, the system switches to the new configura-
tion.
3. After the configuration changes, the Notifier sends an "AFTER" message to the callback table to
notify drivers that the configuration transition is finished.
This example shows how to use the Notifier in the Power Manager application.

#include "fsl_notifier.h"

// Definition of the Power Manager callback.


status_t callback0(notifier_notification_block_t *notify, void *data)
{

status_t ret = kStatus_Success;

...
...
...

return ret;
}
// Definition of the Power Manager user function.
status_t APP_PowerModeSwitch(notifier_user_config_t *targetConfig, void *userData)
{

MCUXpresso SDK API Reference Manual


NXP Semiconductors 837
Notifier Overview

...
...
...
}
...
...
...
...
...
// Main function.
int main(void)
{
// Define a notifier handle.
notifier_handle_t powerModeHandle;

// Callback configuration.
user_callback_data_t callbackData0;

notifier_callback_config_t callbackCfg0 = {callback0,


kNOTIFIER_CallbackBeforeAfter,
(void *)&callbackData0};

notifier_callback_config_t callbacks[] = {callbackCfg0};

// Power mode configurations.


power_user_config_t vlprConfig;
power_user_config_t stopConfig;

notifier_user_config_t *powerConfigs[] = {&vlprConfig, &stopConfig};

// Definition of a transition to and out the power modes.


vlprConfig.mode = kAPP_PowerModeVlpr;
vlprConfig.enableLowPowerWakeUpOnInterrupt = false;

stopConfig = vlprConfig;
stopConfig.mode = kAPP_PowerModeStop;

// Create Notifier handle.


NOTIFIER_CreateHandle(&powerModeHandle, powerConfigs, 2U, callbacks, 1U,
APP_PowerModeSwitch, NULL);
...
...
// Power mode switch.
NOTIFIER_switchConfig(&powerModeHandle, targetConfigIndex,
kNOTIFIER_PolicyAgreement);
}

Data Structures
• struct notifier_notification_block_t
notification block passed to the registered callback function. More...
• struct notifier_callback_config_t
Callback configuration structure. More...
• struct notifier_handle_t
Notifier handle structure. More...

Typedefs
• typedef void notifier_user_config_t
Notifier user configuration type.
• typedef status_t(∗ notifier_user_function_t )(notifier_user_config_t ∗targetConfig, void ∗userData)
Notifier user function prototype Use this function to execute specific operations in configuration switch.

MCUXpresso SDK API Reference Manual


838 NXP Semiconductors
Data Structure Documentation

• typedef status_t(∗ notifier_callback_t )(notifier_notification_block_t ∗notify, void ∗data)


Callback prototype.

Enumerations
• enum _notifier_status {
kStatus_NOTIFIER_ErrorNotificationBefore,
kStatus_NOTIFIER_ErrorNotificationAfter }
Notifier error codes.
• enum notifier_policy_t {
kNOTIFIER_PolicyAgreement,
kNOTIFIER_PolicyForcible }
Notifier policies.
• enum notifier_notification_type_t {
kNOTIFIER_NotifyRecover = 0x00U,
kNOTIFIER_NotifyBefore = 0x01U,
kNOTIFIER_NotifyAfter = 0x02U }
Notification type.
• enum notifier_callback_type_t {
kNOTIFIER_CallbackBefore = 0x01U,
kNOTIFIER_CallbackAfter = 0x02U,
kNOTIFIER_CallbackBeforeAfter = 0x03U }
The callback type, which indicates kinds of notification the callback handles.

Functions
• status_t NOTIFIER_CreateHandle (notifier_handle_t ∗notifierHandle, notifier_user_config_t
∗∗configs, uint8_t configsNumber, notifier_callback_config_t ∗callbacks, uint8_t callbacksNumber,
notifier_user_function_t userFunction, void ∗userData)
Creates a Notifier handle.
• status_t NOTIFIER_SwitchConfig (notifier_handle_t ∗notifierHandle, uint8_t configIndex, notifier-
_policy_t policy)
Switches the configuration according to a pre-defined structure.
• uint8_t NOTIFIER_GetErrorCallbackIndex (notifier_handle_t ∗notifierHandle)
This function returns the last failed notification callback.

36.3 Data Structure Documentation


36.3.1 struct notifier_notification_block_t

Data Fields

• notifier_user_config_t ∗ targetConfig
Pointer to target configuration.
• notifier_policy_t policy
Configure transition policy.
• notifier_notification_type_t notifyType
Configure notification type.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 839
Data Structure Documentation

36.3.1.0.0.41 Field Documentation

36.3.1.0.0.41.1 notifier_user_config_t∗ notifier_notification_block_t::targetConfig

36.3.1.0.0.41.2 notifier_policy_t notifier_notification_block_t::policy

36.3.1.0.0.41.3 notifier_notification_type_t notifier_notification_block_t::notifyType

36.3.2 struct notifier_callback_config_t

This structure holds the configuration of callbacks. Callbacks of this type are expected to be statically
allocated. This structure contains the following application-defined data. callback - pointer to the callback
function callbackType - specifies when the callback is called callbackData - pointer to the data passed to
the callback.

Data Fields

• notifier_callback_t callback
Pointer to the callback function.
• notifier_callback_type_t callbackType
Callback type.
• void ∗ callbackData
Pointer to the data passed to the callback.

36.3.2.0.0.42 Field Documentation

36.3.2.0.0.42.1 notifier_callback_t notifier_callback_config_t::callback

36.3.2.0.0.42.2 notifier_callback_type_t notifier_callback_config_t::callbackType

36.3.2.0.0.42.3 void∗ notifier_callback_config_t::callbackData

36.3.3 struct notifier_handle_t

Notifier handle structure. Contains data necessary for the Notifier proper function. Stores references to
registered configurations, callbacks, information about their numbers, user function, user data, and other
internal data. NOTIFIER_CreateHandle() must be called to initialize this handle.

Data Fields

• notifier_user_config_t ∗∗ configsTable
Pointer to configure table.
• uint8_t configsNumber
Number of configurations.
• notifier_callback_config_t ∗ callbacksTable
Pointer to callback table.

MCUXpresso SDK API Reference Manual


840 NXP Semiconductors
Typedef Documentation

• uint8_t callbacksNumber
Maximum number of callback configurations.
• uint8_t errorCallbackIndex
Index of callback returns error.
• uint8_t currentConfigIndex
Index of current configuration.
• notifier_user_function_t userFunction
User function.
• void ∗ userData
User data passed to user function.

36.3.3.0.0.43 Field Documentation

36.3.3.0.0.43.1 notifier_user_config_t∗∗ notifier_handle_t::configsTable

36.3.3.0.0.43.2 uint8_t notifier_handle_t::configsNumber

36.3.3.0.0.43.3 notifier_callback_config_t∗ notifier_handle_t::callbacksTable

36.3.3.0.0.43.4 uint8_t notifier_handle_t::callbacksNumber

36.3.3.0.0.43.5 uint8_t notifier_handle_t::errorCallbackIndex

36.3.3.0.0.43.6 uint8_t notifier_handle_t::currentConfigIndex

36.3.3.0.0.43.7 notifier_user_function_t notifier_handle_t::userFunction

36.3.3.0.0.43.8 void∗ notifier_handle_t::userData

36.4 Typedef Documentation


36.4.1 typedef void notifier_user_config_t

Reference of the user defined configuration is stored in an array; the notifier switches between these
configurations based on this array.

36.4.2 typedef status_t(∗ notifier_user_function_t)(notifier_user_config_t


∗targetConfig, void ∗userData)

Before and after this function execution, different notification is sent to registered callbacks. If this func-
tion returns any error code, NOTIFIER_SwitchConfig() exits.
Parameters

MCUXpresso SDK API Reference Manual


NXP Semiconductors 841
Enumeration Type Documentation

targetConfig target Configuration.


userData Refers to other specific data passed to user function.

Returns
An error code or kStatus_Success.

36.4.3 typedef status_t(∗ notifier_callback_t)(notifier_notification_block_t ∗notify,


void ∗data)

Declaration of a callback. It is common for registered callbacks. Reference to function of this type is part
of the notifier_callback_config_t callback configuration structure. Depending on callback type, function
of this prototype is called (see NOTIFIER_SwitchConfig()) before configuration switch, after it or in both
use cases to notify about the switch progress (see notifier_callback_type_t). When called, the type of the
notification is passed as a parameter along with the reference to the target configuration structure (see
notifier_notification_block_t) and any data passed during the callback registration. When notified before
the configuration switch, depending on the configuration switch policy (see notifier_policy_t), the callback
may deny the execution of the user function by returning an error code different than kStatus_Success (see
NOTIFIER_SwitchConfig()).
Parameters

notify Notification block.


data Callback data. Refers to the data passed during callback registration. Intended to pass
any driver or application data such as internal state information.

Returns
An error code or kStatus_Success.

36.5 Enumeration Type Documentation


36.5.1 enum _notifier_status

Used as return value of Notifier functions.

Enumerator
kStatus_NOTIFIER_ErrorNotificationBefore An error occurs during send "BEFORE" notifica-
tion.
kStatus_NOTIFIER_ErrorNotificationAfter An error occurs during send "AFTER" notification.

MCUXpresso SDK API Reference Manual


842 NXP Semiconductors
Enumeration Type Documentation

36.5.2 enum notifier_policy_t

Defines whether the user function execution is forced or not. For kNOTIFIER_PolicyForcible, the user
function is executed regardless of the callback results, while kNOTIFIER_PolicyAgreement policy is used
to exit NOTIFIER_SwitchConfig() when any of the callbacks returns error code. See also NOTIFIER_-
SwitchConfig() description.

Enumerator
kNOTIFIER_PolicyAgreement NOTIFIER_SwitchConfig() method is exited when any of the call-
backs returns error code.
kNOTIFIER_PolicyForcible The user function is executed regardless of the results.

36.5.3 enum notifier_notification_type_t

Used to notify registered callbacks

Enumerator
kNOTIFIER_NotifyRecover Notify IP to recover to previous work state.
kNOTIFIER_NotifyBefore Notify IP that configuration setting is going to change.
kNOTIFIER_NotifyAfter Notify IP that configuration setting has been changed.

36.5.4 enum notifier_callback_type_t

Used in the callback configuration structure (notifier_callback_config_t) to specify when the registered
callback is called during configuration switch initiated by the NOTIFIER_SwitchConfig(). Callback can
be invoked in following situations.
• Before the configuration switch (Callback return value can affect NOTIFIER_SwitchConfig() exe-
cution. See the NOTIFIER_SwitchConfig() and notifier_policy_t documentation).
• After an unsuccessful attempt to switch configuration
• After a successful configuration switch

Enumerator
kNOTIFIER_CallbackBefore Callback handles BEFORE notification.
kNOTIFIER_CallbackAfter Callback handles AFTER notification.
kNOTIFIER_CallbackBeforeAfter Callback handles BEFORE and AFTER notification.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 843
Function Documentation

36.6 Function Documentation


36.6.1 status_t NOTIFIER_CreateHandle ( notifier_handle_t ∗ notifierHandle,
notifier_user_config_t ∗∗ configs, uint8_t configsNumber, notifier_callback-
_config_t ∗ callbacks, uint8_t callbacksNumber, notifier_user_function_t
userFunction, void ∗ userData )

MCUXpresso SDK API Reference Manual


844 NXP Semiconductors
Function Documentation

Parameters

notifierHandle A pointer to the notifier handle.


configs A pointer to an array with references to all configurations which is handled by the
Notifier.
configsNumber Number of configurations. Size of the configuration array.
callbacks A pointer to an array of callback configurations. If there are no callbacks to register
during Notifier initialization, use NULL value.
callbacks- Number of registered callbacks. Size of the callbacks array.
Number
userFunction User function.
userData User data passed to user function.

Returns
An error Code or kStatus_Success.

36.6.2 status_t NOTIFIER_SwitchConfig ( notifier_handle_t ∗ notifierHandle,


uint8_t configIndex, notifier_policy_t policy )

This function sets the system to the target configuration. Before transition, the Notifier sends notifications
to all callbacks registered to the callback table. Callbacks are invoked in the following order: All registered
callbacks are notified ordered by index in the callbacks array. The same order is used for before and after
switch notifications. The notifications before the configuration switch can be used to obtain confirmation
about the change from registered callbacks. If any registered callback denies the configuration change,
further execution of this function depends on the notifier policy: the configuration change is either forced
(kNOTIFIER_PolicyForcible) or exited (kNOTIFIER_PolicyAgreement). When configuration change is
forced, the result of the before switch notifications are ignored. If an agreement is required, if any call-
back returns an error code, further notifications before switch notifications are cancelled and all already
notified callbacks are re-invoked. The index of the callback which returned error code during pre-switch
notifications is stored (any error codes during callbacks re-invocation are ignored) and NOTIFIER_Get-
ErrorCallback() can be used to get it. Regardless of the policies, if any callback returns an error code,
an error code indicating in which phase the error occurred is returned when NOTIFIER_SwitchConfig()
exits.
Parameters

MCUXpresso SDK API Reference Manual


NXP Semiconductors 845
Function Documentation

notifierHandle pointer to notifier handle


configIndex Index of the target configuration.
policy Transaction policy, kNOTIFIER_PolicyAgreement or kNOTIFIER_PolicyForcible.

Returns
An error code or kStatus_Success.

36.6.3 uint8_t NOTIFIER_GetErrorCallbackIndex ( notifier_handle_t ∗


notifierHandle )

This function returns an index of the last callback that failed during the configuration switch while the last
NOTIFIER_SwitchConfig() was called. If the last NOTIFIER_SwitchConfig() call ended successfully
value equal to callbacks number is returned. The returned value represents an index in the array of static
call-backs.
Parameters

notifierHandle Pointer to the notifier handle

Returns
Callback Index of the last failed callback or value equal to callbacks count.

MCUXpresso SDK API Reference Manual


846 NXP Semiconductors
Chapter 37
Shell
37.1 Overview
This part describes the programming interface of the Shell middleware. Shell controls MCUs by com-
mands via the specified communication peripheral based on the debug console driver.

37.2 Function groups


37.2.1 Initialization

To initialize the Shell middleware, call the SHELL_Init() function with these parameters. This function
automatically enables the middleware.

void SHELL_Init(p_shell_context_t context, send_data_cb_t send_cb, recv_data_cb_t recv_cb, char *


prompt);

Then, after the initialization was successful, call a command to control MCUs.
This example shows how to call the SHELL_Init() given the user configuration structure.

SHELL_Init(&user_context, SHELL_SendDataCallback, SHELL_ReceiveDataCallback, "SHELL>> ");

37.2.2 Advanced Feature

• Support to get a character from standard input devices.


static uint8_t GetChar(p_shell_context_t context);

Commands Description
Help Lists all commands which are supported by Shell.
Exit Exits the Shell program.
strCompare Compares the two input strings.

Input character Description


A Gets the latest command in the history.
B Gets the first command in the history.
C Replaces one character at the right of the pointer.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 847
Function groups

Input character Description


D Replaces one character at the left of the pointer.
Run AutoComplete function
Run cmdProcess function

Clears a command.

37.2.3 Shell Operation

SHELL_Init(&user_context, SHELL_SendDataCallback, SHELL_ReceiveDataCallback, "SHELL>> ");


SHELL_Main(&user_context);

Data Structures
• struct shell_command_t
User command data configuration structure. More...

Macros
• #define SHELL_NON_BLOCKING_MODE SERIAL_MANAGER_NON_BLOCKING_MODE
Whether use non-blocking mode.
• #define SHELL_AUTO_COMPLETE (1U)
Macro to set on/off auto-complete feature.
• #define SHELL_BUFFER_SIZE (64U)
Macro to set console buffer size.
• #define SHELL_MAX_ARGS (8U)
Macro to set maximum arguments in command.
• #define SHELL_HISTORY_COUNT (3U)
Macro to set maximum count of history commands.
• #define SHELL_IGNORE_PARAMETER_COUNT (0xFF)
Macro to bypass arguments check.
• #define SHELL_HANDLE_SIZE (520U)
The handle size of the shell module.
• #define SHELL_COMMAND_DEFINE(command, descriptor, callback, paramCount)
Defines the shell command structure.
• #define SHELL_COMMAND(command) &g_shellCommand##command
Gets the shell command pointer.

Typedefs
• typedef void ∗ shell_handle_t
The handle of the shell module.
• typedef shell_status_t(∗ cmd_function_t )(shell_handle_t shellHandle, int32_t argc, char ∗∗argv)
User command function prototype.

MCUXpresso SDK API Reference Manual


848 NXP Semiconductors
Data Structure Documentation

Enumerations
• enum shell_status_t {
kStatus_SHELL_Success = kStatus_Success,
kStatus_SHELL_Error = MAKE_STATUS(kStatusGroup_SHELL, 1),
kStatus_SHELL_OpenWriteHandleFailed = MAKE_STATUS(kStatusGroup_SHELL, 2),
kStatus_SHELL_OpenReadHandleFailed = MAKE_STATUS(kStatusGroup_SHELL, 3) }

Shell functional operation


• shell_status_t SHELL_Init (shell_handle_t shellHandle, serial_handle_t serialHandle, char
∗prompt)
Initializes the shell module.
• shell_status_t SHELL_RegisterCommand (shell_handle_t shellHandle, shell_command_t ∗shell-
Command)
Registers the shell command.
• shell_status_t SHELL_UnregisterCommand (shell_command_t ∗shellCommand)
Unregisters the shell command.
• shell_status_t SHELL_Write (shell_handle_t shellHandle, char ∗buffer, uint32_t length)
Sends data to the shell output stream.
• int SHELL_Printf (shell_handle_t shellHandle, const char ∗formatString,...)
Writes formatted output to the shell output stream.
• void SHELL_Task (shell_handle_t shellHandle)
The task function for Shell.

37.3 Data Structure Documentation


37.3.1 struct shell_command_t

Data Fields

• const char ∗ pcCommand


The command that is executed.
• char ∗ pcHelpString
String that describes how to use the command.
• const cmd_function_t pFuncCallBack
A pointer to the callback function that returns the output generated by the command.
• uint8_t cExpectedNumberOfParameters
Commands expect a fixed number of parameters, which may be zero.
• list_element_t link
link of the element

37.3.1.0.0.44 Field Documentation

37.3.1.0.0.44.1 const char∗ shell_command_t::pcCommand

For example "help". It must be all lower case.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 849
Macro Definition Documentation

37.3.1.0.0.44.2 char∗ shell_command_t::pcHelpString

It should start with the command itself, and end with "\r\n". For example "help: Returns a list of all the
commands\r\n".

37.3.1.0.0.44.3 const cmd_function_t shell_command_t::pFuncCallBack

37.3.1.0.0.44.4 uint8_t shell_command_t::cExpectedNumberOfParameters

37.4 Macro Definition Documentation


37.4.1 #define SHELL_NON_BLOCKING_MODE SERIAL_MANAGER_NON_BLOCK-
ING_MODE

37.4.2 #define SHELL_AUTO_COMPLETE (1U)

37.4.3 #define SHELL_BUFFER_SIZE (64U)

37.4.4 #define SHELL_MAX_ARGS (8U)

37.4.5 #define SHELL_HISTORY_COUNT (3U)

37.4.6 #define SHELL_HANDLE_SIZE (520U)

It is the sum of the SHELL_HISTORY_COUNT ∗ SHELL_BUFFER_SIZE + SHELL_BUFFER_SIZE


+ SERIAL_MANAGER_READ_HANDLE_SIZE + SERIAL_MANAGER_WRITE_HANDLE_SIZE

37.4.7 #define SHELL_COMMAND_DEFINE( command, descriptor, callback,


paramCount )

Value:

\
shell_command_t g_shellCommand##command = { \
(#command), (descriptor), (callback), (paramCount), {0}, \
}

This macro is used to define the shell command structure shell_command_t. And then uses the macro SH-
ELL_COMMAND to get the command structure pointer. The macro should not be used in any function.
This is a example,

* SHELL_COMMAND_DEFINE(exit, "\r\n\"exit\": Exit program\r\n", SHELL_ExitCommand, 0);


* SHELL_RegisterCommand(s_shellHandle, SHELL_COMMAND(exit));
*

MCUXpresso SDK API Reference Manual


850 NXP Semiconductors
Function Documentation

Parameters

command The command string of the command. The double quotes do not need. Such as exit
for "exit", help for "Help", read for "read".
descriptor The description of the command is used for showing the command usage when "help"
is typing.
callback The callback of the command is used to handle the command line when the input
command is matched.
paramCount The max parameter count of the current command.

37.4.8 #define SHELL_COMMAND( command ) &g_shellCommand##command

This macro is used to get the shell command pointer. The macro should not be used before the macro
SHELL_COMMAND_DEFINE is used.
Parameters

command The command string of the command. The double quotes do not need. Such as exit
for "exit", help for "Help", read for "read".

37.5 Typedef Documentation


37.5.1 typedef shell_status_t(∗ cmd_function_t)(shell_handle_t shellHandle, int32_t
argc, char ∗∗argv)

37.6 Enumeration Type Documentation


37.6.1 enum shell_status_t

Enumerator
kStatus_SHELL_Success Success.
kStatus_SHELL_Error Failed.
kStatus_SHELL_OpenWriteHandleFailed Open write handle failed.
kStatus_SHELL_OpenReadHandleFailed Open read handle failed.

37.7 Function Documentation


37.7.1 shell_status_t SHELL_Init ( shell_handle_t shellHandle, serial_handle_t
serialHandle, char ∗ prompt )

This function must be called before calling all other Shell functions. Call operation the Shell commands
with user-defined settings. The example below shows how to set up the Shell and how to call the SHELL-
_Init function by passing in these parameters. This is an example.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 851
Function Documentation

* static uint8_t s_shellHandleBuffer[SHELL_HANDLE_SIZE];


* static shell_handle_t s_shellHandle = &s_shellHandleBuffer[0];
* SHELL_Init(s_shellHandle, s_serialHandle, "Test@SHELL>");
*

Parameters

shellHandle Pointer to point to a memory space of size SHELL_HANDLE_SIZE allocated by the


caller.
serialHandle The serial manager module handle pointer.
prompt The string prompt pointer of Shell. Only the global variable can be passed.

Return values

kStatus_SHELL_Success The shell initialization succeed.


kStatus_SHELL_Error An error occurred when the shell is initialized.
kStatus_SHELL_Open- Open the write handle failed.
WriteHandleFailed
kStatus_SHELL_Open- Open the read handle failed.
ReadHandleFailed

37.7.2 shell_status_t SHELL_RegisterCommand ( shell_handle_t shellHandle,


shell_command_t ∗ shellCommand )

This function is used to register the shell command by using the command configuration #shell_command-
_config_t. This is a example,

* SHELL_COMMAND_DEFINE(exit, "\r\n\"exit\": Exit program\r\n", SHELL_ExitCommand, 0);


* SHELL_RegisterCommand(s_shellHandle, SHELL_COMMAND(exit));
*

Parameters

shellHandle The shell module handle pointer.


command The command element.

Return values

MCUXpresso SDK API Reference Manual


852 NXP Semiconductors
Function Documentation

kStatus_SHELL_Success Successfully register the command.


kStatus_SHELL_Error An error occurred.

37.7.3 shell_status_t SHELL_UnregisterCommand ( shell_command_t ∗


shellCommand )

This function is used to unregister the shell command.


Parameters

command The command element.

Return values

kStatus_SHELL_Success Successfully unregister the command.

37.7.4 shell_status_t SHELL_Write ( shell_handle_t shellHandle, char ∗ buffer,


uint32_t length )

This function is used to send data to the shell output stream.


Parameters

shellHandle The shell module handle pointer.


buffer Start address of the data to write.
length Length of the data to write.

Return values

kStatus_SHELL_Success Successfully send data.


kStatus_SHELL_Error An error occurred.

37.7.5 int SHELL_Printf ( shell_handle_t shellHandle, const char ∗ formatString,


... )

Call this function to write a formatted output to the shell output stream.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 853
Function Documentation

Parameters

shellHandle The shell module handle pointer.


formatString Format string.

Returns
Returns the number of characters printed or a negative value if an error occurs.

37.7.6 void SHELL_Task ( shell_handle_t shellHandle )

The task function for Shell; The function should be polled by upper layer. This function does not return
until Shell command exit was called.
Parameters

shellHandle The shell module handle pointer.

MCUXpresso SDK API Reference Manual


854 NXP Semiconductors
Chapter 38
OSA_Adapter: Operatin System Abstraction Adapter
38.1 Overview
Modules
• OSA BM
• OSA FreeRTOS

Data Structures
• struct osa_task_def_t
Thread Definition structure contains startup information of a thread. More...
• struct osa_thread_link_handle_t
Thread Link Definition structure . More...
• struct osa_time_def_t
Definition structure contains timer parameters. More...

Macros
• #define USE_RTOS (0)

• #define osaWaitForever_c ((uint32_t)(-1))


Constant to pass as timeout value in order to wait indefinitely.

Typedefs
• typedef uint16_t osa_task_priority_t

• typedef void ∗ osa_task_handle_t


Type for a task handler.
• typedef void ∗ osa_task_param_t
Type for the parameter to be passed to the task at its creation.
• typedef void(∗ osa_task_ptr_t )(osa_task_param_t task_param)
Type for task pointer.
• typedef void ∗ osa_semaphore_handle_t
Type for the semaphore handler.
• typedef void ∗ osa_mutex_handle_t
Type for the mutex handler.
• typedef void ∗ osa_event_handle_t
Type for the event handler.
• typedef uint32_t osa_event_flags_t
Type for an event flags group, bit 32 is reserved.
• typedef void ∗ osa_msg_handle_t
Message definition.
• typedef void ∗ osa_msgq_handle_t

MCUXpresso SDK API Reference Manual


NXP Semiconductors 855
Overview

Type for the message queue handler.


• typedef void ∗ osa_timer_handle_t
Type for the Timer handler.
• typedef void(∗ osa_timer_fct_ptr_t )(void const ∗argument)
Type for the Timer callback function pointer.

Enumerations
• enum osa_timer_t {
KOSA_TimerOnce = 0,
KOSA_TimerPeriodic = 1 }
Type for the timer definition.
• enum osa_status_t {
KOSA_StatusSuccess = kStatus_Success,
KOSA_StatusError = MAKE_STATUS(kStatusGroup_OSA, 1),
KOSA_StatusTimeout = MAKE_STATUS(kStatusGroup_OSA, 2),
KOSA_StatusIdle = MAKE_STATUS(kStatusGroup_OSA, 3) }
Defines the return status of OSA’s functions.

Task management
Public functions
• osa_status_t OSA_TaskCreate (osa_task_handle_t taskHandle, osa_task_def_t ∗thread_def, osa_-
task_param_t task_param)
Creates a task.
• osa_task_handle_t OSA_TaskGetCurrentHandle (void)
Gets the handler of active task.
• osa_status_t OSA_TaskYield (void)
Puts the active task to the end of scheduler’s queue.
• osa_task_priority_t OSA_TaskGetPriority (osa_task_handle_t taskHandle)
Gets the priority of a task.
• osa_status_t OSA_TaskSetPriority (osa_task_handle_t taskHandle, osa_task_priority_t task-
Priority)
Sets the priority of a task.
• osa_status_t OSA_TaskDestroy (osa_task_handle_t taskHandle)
Destroys a previously created task.
• osa_status_t OSA_SemaphoreCreate (osa_semaphore_handle_t semaphoreHandle, uint32_t init-
Value)
Creates a semaphore with a given value.
• osa_status_t OSA_SemaphoreDestroy (osa_semaphore_handle_t semaphoreHandle)
Destroys a previously created semaphore.
• osa_status_t OSA_SemaphoreWait (osa_semaphore_handle_t semaphoreHandle, uint32_t millisec)
Pending a semaphore with timeout.
• osa_status_t OSA_SemaphorePost (osa_semaphore_handle_t semaphoreHandle)
Signals for someone waiting on the semaphore to wake up.
• osa_status_t OSA_MutexCreate (osa_mutex_handle_t mutexHandle)
Create an unlocked mutex.
• osa_status_t OSA_MutexLock (osa_mutex_handle_t mutexHandle, uint32_t millisec)
Waits for a mutex and locks it.

MCUXpresso SDK API Reference Manual


856 NXP Semiconductors
Data Structure Documentation

• osa_status_t OSA_MutexUnlock (osa_mutex_handle_t mutexHandle)


Unlocks a previously locked mutex.
• osa_status_t OSA_MutexDestroy (osa_mutex_handle_t mutexHandle)
Destroys a previously created mutex.
• osa_status_t OSA_EventCreate (osa_event_handle_t eventHandle, uint8_t autoClear)
Initializes an event object with all flags cleared.
• osa_status_t OSA_EventSet (osa_event_handle_t eventHandle, osa_event_flags_t flagsToSet)
Sets one or more event flags.
• osa_status_t OSA_EventClear (osa_event_handle_t eventHandle, osa_event_flags_t flagsToClear)
Clears one or more flags.
• osa_status_t OSA_EventWait (osa_event_handle_t eventHandle, osa_event_flags_t flagsToWait,
uint8_t waitAll, uint32_t millisec, osa_event_flags_t ∗pSetFlags)
Waits for specified event flags to be set.
• osa_status_t OSA_EventDestroy (osa_event_handle_t eventHandle)
Destroys a previously created event object.
• osa_status_t OSA_MsgQCreate (osa_msgq_handle_t msgqHandle, uint32_t msgNo)
Initializes a message queue.
• osa_status_t OSA_MsgQPut (osa_msgq_handle_t msgqHandle, osa_msg_handle_t pMessage)
Puts a message at the end of the queue.
• osa_status_t OSA_MsgQGet (osa_msgq_handle_t msgqHandle, osa_msg_handle_t pMessage,
uint32_t millisec)
Reads and remove a message at the head of the queue.
• osa_status_t OSA_MsgQDestroy (osa_msgq_handle_t msgqHandle)
Destroys a previously created queue.
• void OSA_InterruptEnable (void)
Enable all interrupts.
• void OSA_InterruptDisable (void)
Disable all interrupts.
• void OSA_EnableIRQGlobal (void)
Enable all interrupts using PRIMASK.
• void OSA_DisableIRQGlobal (void)
Disable all interrupts using PRIMASK.
• void OSA_TimeDelay (uint32_t millisec)
Delays execution for a number of milliseconds.
• uint32_t OSA_TimeGetMsec (void)
This function gets current time in milliseconds.
• void OSA_InstallIntHandler (uint32_t IRQNumber, void(∗handler)(void))
Installs the interrupt handler.

38.2 Data Structure Documentation


38.2.1 struct osa_task_def_t

Data Fields

• osa_task_ptr_t pthread
start address of thread function
• uint32_t tpriority
initial thread priority
• uint32_t instances

MCUXpresso SDK API Reference Manual


NXP Semiconductors 857
Typedef Documentation

maximum number of instances of that thread function


• uint32_t stacksize
stack size requirements in bytes; 0 is default stack size
• uint32_t ∗ tstack
stack pointer
• void ∗ tlink
link pointer
• uint8_t ∗ tname
name pointer
• uint8_t useFloat
is use float

38.2.2 struct osa_thread_link_t

Data Fields

• uint8_t link [12]


link
• osa_task_handle_t osThreadId
thread id
• osa_task_def_t ∗ osThreadDefHandle
pointer of thread define handle
• uint32_t ∗ osThreadStackHandle
pointer of thread stack handle

38.2.3 struct osa_time_def_t

38.3 Macro Definition Documentation


38.3.1 #define USE_RTOS (0)

Public macros

38.3.2 #define osaWaitForever_c ((uint32_t)(-1))

38.4 Typedef Documentation


38.4.1 typedef uint16_t osa_task_priority_t

Public type definitions


Type for the Task Priority

MCUXpresso SDK API Reference Manual


858 NXP Semiconductors
Function Documentation

38.4.2 typedef void(∗ osa_task_ptr_t)(osa_task_param_t task_param)

Task prototype declaration

38.4.3 typedef uint32_t osa_event_flags_t

38.4.4 typedef void∗ osa_msg_handle_t

38.4.5 typedef void(∗ osa_timer_fct_ptr_t)(void const ∗argument)

38.5 Enumeration Type Documentation


38.5.1 enum osa_timer_t

Enumerator
KOSA_TimerOnce one-shot timer
KOSA_TimerPeriodic repeating timer

38.5.2 enum osa_status_t

Enumerator
KOSA_StatusSuccess Success.
KOSA_StatusError Failed.
KOSA_StatusTimeout Timeout occurs while waiting.
KOSA_StatusIdle Used for bare metal only, the wait object is not ready and timeout still not occur.

38.6 Function Documentation


38.6.1 osa_status_t OSA_TaskCreate ( osa_task_handle_t taskHandle,
osa_task_def_t ∗ thread_def, osa_task_param_t task_param )

This function is used to create task based on the resources defined by the macro OSA_TASK_DEFINE.
Parameters

taskHandle Pointer to a memory space of size #OSA_TASK_HANDLE_SIZE allocated by the


caller, task handle.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 859
Function Documentation

thread_def pointer to theosa_task_def_t structure which defines the task.


task_param Pointer to be passed to the task when it is created.

Return values

KOSA_StatusSuccess The task is successfully created.


KOSA_StatusError The task can not be created. Example:
uint8_t taskHandle[OSA_TASK_HANDLE_SIZE];
OSA_TASK_DEFINE( Job1, OSA_PRIORITY_HIGH, 1, 800, 0);
OSA_TaskCreate((osa_task_handle_t)taskHandle, OSA_TASK(Job1), (
osa_task_param_t)NULL);

38.6.2 osa_task_handle_t OSA_TaskGetCurrentHandle ( void )

Returns
Handler to current active task.

38.6.3 osa_status_t OSA_TaskYield ( void )

When a task calls this function, it gives up the CPU and puts itself to the end of a task ready list.
Return values

KOSA_StatusSuccess The function is called successfully.


KOSA_StatusError Error occurs with this function.

38.6.4 osa_task_priority_t OSA_TaskGetPriority ( osa_task_handle_t taskHandle )

Parameters

taskHandle The handler of the task whose priority is received.

Returns
Task’s priority.

MCUXpresso SDK API Reference Manual


860 NXP Semiconductors
Function Documentation

38.6.5 osa_status_t OSA_TaskSetPriority ( osa_task_handle_t taskHandle,


osa_task_priority_t taskPriority )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 861
Function Documentation

Parameters

taskHandle The handler of the task whose priority is set.


taskPriority The priority to set.

Return values

KOSA_StatusSuccess Task’s priority is set successfully.


KOSA_StatusError Task’s priority can not be set.

38.6.6 osa_status_t OSA_TaskDestroy ( osa_task_handle_t taskHandle )

Parameters

taskHandle The handler of the task to destroy.

Return values

KOSA_StatusSuccess The task was successfully destroyed.


KOSA_StatusError Task destruction failed or invalid parameter.

38.6.7 osa_status_t OSA_SemaphoreCreate ( osa_semaphore_handle_t


semaphoreHandle, uint32_t initValue )

This function creates a semaphore and sets the value to the parameter initValue.
Parameters

semaphore- Pointer to a memory space of size #OSA_SEM_HANDLE_SIZE allocated by the


Handle caller, semaphore handle.
initValue Initial value the semaphore will be set to.

Return values

KOSA_StatusSuccess the new semaphore if the semaphore is created successfully.

MCUXpresso SDK API Reference Manual


862 NXP Semiconductors
Function Documentation

KOSA_StatusError if the semaphore can not be created.

38.6.8 osa_status_t OSA_SemaphoreDestroy ( osa_semaphore_handle_t


semaphoreHandle )

Parameters

semaphore- The semaphore handle.


Handle

Return values

KOSA_StatusSuccess The semaphore is successfully destroyed.


KOSA_StatusError The semaphore can not be destroyed.

38.6.9 osa_status_t OSA_SemaphoreWait ( osa_semaphore_handle_t


semaphoreHandle, uint32_t millisec )

This function checks the semaphore’s counting value. If it is positive, decreases it and returns KOSA_-
StatusSuccess. Otherwise, a timeout is used to wait.
Parameters

semaphore- The semaphore handle.


Handle
millisec The maximum number of milliseconds to wait if semaphore is not positive. Pass
osaWaitForever_c to wait indefinitely, pass 0 will return KOSA_StatusTimeout im-
mediately.

Return values

KOSA_StatusSuccess The semaphore is received.


KOSA_StatusTimeout The semaphore is not received within the specified ’timeout’.
KOSA_StatusError An incorrect parameter was passed.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 863
Function Documentation

38.6.10 osa_status_t OSA_SemaphorePost ( osa_semaphore_handle_t


semaphoreHandle )

Wakes up one task that is waiting on the semaphore. If no task is waiting, increases the semaphore’s
counting value.

MCUXpresso SDK API Reference Manual


864 NXP Semiconductors
Function Documentation

Parameters

semaphore- The semaphore handle to signal.


Handle

Return values

KOSA_StatusSuccess The semaphore is successfully signaled.


KOSA_StatusError The object can not be signaled or invalid parameter.

38.6.11 osa_status_t OSA_MutexCreate ( osa_mutex_handle_t mutexHandle )

This function creates a non-recursive mutex and sets it to unlocked status.


Parameters

mutexHandle Pointer to a memory space of size #OSA_MUTEX_HANDLE_SIZE allocated by the


caller, mutex handle.

Return values

KOSA_StatusSuccess the new mutex if the mutex is created successfully.


KOSA_StatusError if the mutex can not be created.

38.6.12 osa_status_t OSA_MutexLock ( osa_mutex_handle_t mutexHandle,


uint32_t millisec )

This function checks the mutex’s status. If it is unlocked, locks it and returns the KOSA_StatusSuccess.
Otherwise, waits for a timeout in milliseconds to lock.
Parameters

mutexHandle The mutex handle.


millisec The maximum number of milliseconds to wait for the mutex. If the mutex is locked,
Pass the value osaWaitForever_c will wait indefinitely, pass 0 will return KOSA_-
StatusTimeout immediately.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 865
Function Documentation

Return values

KOSA_StatusSuccess The mutex is locked successfully.


KOSA_StatusTimeout Timeout occurred.
KOSA_StatusError Incorrect parameter was passed.

Note
This is non-recursive mutex, a task can not try to lock the mutex it has locked.

38.6.13 osa_status_t OSA_MutexUnlock ( osa_mutex_handle_t mutexHandle )

Parameters

mutexHandle The mutex handle.

Return values

KOSA_StatusSuccess The mutex is successfully unlocked.


KOSA_StatusError The mutex can not be unlocked or invalid parameter.

38.6.14 osa_status_t OSA_MutexDestroy ( osa_mutex_handle_t mutexHandle )

Parameters

mutexHandle The mutex handle.

Return values

KOSA_StatusSuccess The mutex is successfully destroyed.


KOSA_StatusError The mutex can not be destroyed.

38.6.15 osa_status_t OSA_EventCreate ( osa_event_handle_t eventHandle, uint8_t


autoClear )

This function creates an event object and set its clear mode. If autoClear is TRUE, when a task gets the
event flags, these flags will be cleared automatically. Otherwise these flags must be cleared manually.

MCUXpresso SDK API Reference Manual


866 NXP Semiconductors
Function Documentation

Parameters

eventHandle Pointer to a memory space of size #OSA_EVENT_HANDLE_SIZE allocated by the


caller, Event handle.
autoClear TRUE The event is auto-clear. FALSE The event manual-clear

Return values

KOSA_StatusSuccess the new event if the event is created successfully.


KOSA_StatusError if the event can not be created.

38.6.16 osa_status_t OSA_EventSet ( osa_event_handle_t eventHandle,


osa_event_flags_t flagsToSet )

Sets specified flags of an event object.


Parameters

eventHandle The event handle.


flagsToSet Flags to be set.

Return values

KOSA_StatusSuccess The flags were successfully set.


KOSA_StatusError An incorrect parameter was passed.

38.6.17 osa_status_t OSA_EventClear ( osa_event_handle_t eventHandle,


osa_event_flags_t flagsToClear )

Clears specified flags of an event object.


Parameters

eventHandle The event handle.


flagsToClear Flags to be clear.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 867
Function Documentation

Return values

KOSA_StatusSuccess The flags were successfully cleared.


KOSA_StatusError An incorrect parameter was passed.

38.6.18 osa_status_t OSA_EventWait ( osa_event_handle_t eventHandle,


osa_event_flags_t flagsToWait, uint8_t waitAll, uint32_t millisec,
osa_event_flags_t ∗ pSetFlags )

This function waits for a combination of flags to be set in an event object. Applications can wait for any/all
bits to be set. Also this function could obtain the flags who wakeup the waiting task.
Parameters

eventHandle The event handle.


flagsToWait Flags that to wait.
waitAll Wait all flags or any flag to be set.
millisec The maximum number of milliseconds to wait for the event. If the wait condition
is not met, pass osaWaitForever_c will wait indefinitely, pass 0 will return KOSA_-
StatusTimeout immediately.
setFlags Flags that wakeup the waiting task are obtained by this parameter.

Return values

KOSA_StatusSuccess The wait condition met and function returns successfully.


KOSA_StatusTimeout Has not met wait condition within timeout.
KOSA_StatusError An incorrect parameter was passed.

Note
Please pay attention to the flags bit width, FreeRTOS uses the most significant 8 bis as control bits,
so do not wait these bits while using FreeRTOS.

38.6.19 osa_status_t OSA_EventDestroy ( osa_event_handle_t eventHandle )

MCUXpresso SDK API Reference Manual


868 NXP Semiconductors
Function Documentation

Parameters

eventHandle The event handle.

Return values

KOSA_StatusSuccess The event is successfully destroyed.


KOSA_StatusError Event destruction failed.

38.6.20 osa_status_t OSA_MsgQCreate ( osa_msgq_handle_t msgqHandle,


uint32_t msgNo )

This function allocates memory for and initializes a message queue. Message queue elements are hard-
coded as void∗.
Parameters

msgqHandle Pointer to a memory space of size #(OSA_MSGQ_HANDLE_SIZE + msgNo∗OSA-


_MSG_HANDLE_SIZE) allocated by the caller, message queue handle.
msgNo :number of messages the message queue should accommodate.

Return values

KOSA_StatusSuccess Message queue successfully Create.


KOSA_StatusError Message queue create failure.

38.6.21 osa_status_t OSA_MsgQPut ( osa_msgq_handle_t msgqHandle,


osa_msg_handle_t pMessage )

This function puts a message to the end of the message queue. If the queue is full, this function returns the
KOSA_StatusError;
Parameters

msgqHandle Message Queue handler.


pMessage Pointer to the message to be put into the queue.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 869
Function Documentation

Return values

KOSA_StatusSuccess Message successfully put into the queue.


KOSA_StatusError The queue was full or an invalid parameter was passed.

38.6.22 osa_status_t OSA_MsgQGet ( osa_msgq_handle_t msgqHandle,


osa_msg_handle_t pMessage, uint32_t millisec )

This function gets a message from the head of the message queue. If the queue is empty, timeout is used
to wait.
Parameters

msgqHandle Message Queue handler.


pMessage Pointer to a memory to save the message.
millisec The number of milliseconds to wait for a message. If the queue is empty, pass osa-
WaitForever_c will wait indefinitely, pass 0 will return KOSA_StatusTimeout imme-
diately.

Return values

KOSA_StatusSuccess Message successfully obtained from the queue.


KOSA_StatusTimeout The queue remains empty after timeout.
KOSA_StatusError Invalid parameter.

38.6.23 osa_status_t OSA_MsgQDestroy ( osa_msgq_handle_t msgqHandle )

Parameters

msgqHandle Message Queue handler.

Return values

KOSA_StatusSuccess The queue was successfully destroyed.

MCUXpresso SDK API Reference Manual


870 NXP Semiconductors
Function Documentation

KOSA_StatusError Message queue destruction failed.

38.6.24 void OSA_TimeDelay ( uint32_t millisec )

Parameters

millisec The time in milliseconds to wait.

38.6.25 uint32_t OSA_TimeGetMsec ( void )

Return values

current time in milliseconds

38.6.26 void OSA_InstallIntHandler ( uint32_t IRQNumber, void(∗)(void) handler )

Parameters

IRQNumber IRQ number of the interrupt.


handler The interrupt handler to install.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 871
OSA BM

38.7 OSA BM
38.7.1 Overview

Data Structures

• struct semaphore_t
Type for an semaphore. More...
• struct mutex_t
Type for a mutex. More...
• struct task_control_block_t
Task control block for bare metal. More...
• struct event_t
Type for an event object. More...
• struct msg_queue_t
Type for a message queue. More...

Macros

• #define FSL_OSA_BM_TIMER_NONE 0U
Bare Metal does not use timer.
• #define FSL_OSA_BM_TIMER_SYSTICK 1U
Bare Metal uses SYSTICK as timer.
• #define FSL_OSA_BM_TIMER_CONFIG FSL_OSA_BM_TIMER_SYSTICK
Configure what timer is used in Bare Metal.
• #define OSA_WAIT_FOREVER 0xFFFFFFFFU
Constant to pass as timeout value in order to wait indefinitely.
• #define TASK_MAX_NUM 7
How many tasks can the bare metal support.
• #define FSL_OSA_TIME_RANGE 0xFFFFFFFFU
OSA’s time range in millisecond, OSA time wraps if exceeds this value.
• #define OSA_DEFAULT_INT_HANDLER ((osa_int_handler_t)(&DefaultISR))
The default interrupt handler installed in vector table.

Typedefs

• typedef void ∗ task_param_t


Type for task parameter.
• typedef void(∗ task_t )(task_param_t param)
Type for a task handler, returned by the OSA_TaskCreate function.
• typedef task_control_block_t ∗ task_handler_t
Type for a task pointer.
• typedef uint32_t task_stack_t
Type for a task stack.
• typedef uint32_t event_flags_t
Type for an event flags group, bit 32 is reserved.
• typedef msg_queue_t ∗ msg_queue_handler_t
Type for a message queue handler.

MCUXpresso SDK API Reference Manual


872 NXP Semiconductors
OSA BM

Functions

• void DefaultISR (void)


The default interrupt handler installed in vector table.

Thread management

• #define PRIORITY_OSA_TO_RTOS(osa_prio) (osa_prio)


Defines a task.
• #define PRIORITY_RTOS_TO_OSA(rtos_prio) (rtos_prio)

38.7.2 Data Structure Documentation

38.7.2.1 struct semaphore_t

Data Fields
• uint32_t time_start
The time to start timeout.
• uint32_t timeout
Timeout to wait in milliseconds.
• volatile bool isWaiting
Is any task waiting for a timeout on this object.
• volatile uint8_t semCount
The count value of the object.

38.7.2.2 struct mutex_t

Data Fields
• uint32_t time_start
The time to start timeout.
• uint32_t timeout
Timeout to wait in milliseconds.
• volatile bool isWaiting
Is any task waiting for a timeout on this mutex.
• volatile bool isLocked
Is the object locked or not.

38.7.2.3 struct task_control_block_t

Data Fields
• osa_task_ptr_t p_func
Task’s entry.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 873
OSA BM

• osa_task_priority_t priority
Task’s priority.
• osa_task_param_t param
Task’s parameter.
• bool haveToRun
Task was signaled.

38.7.2.4 struct event_t

Data Fields
• uint32_t time_start
The time to start timeout.
• uint32_t timeout
Timeout to wait in milliseconds.
• volatile event_flags_t flags
The flags status.
• task_handler_t waitingTask
Handler to the waiting task.
• bool autoClear
Auto clear or manual clear.
• volatile bool isWaiting
Is any task waiting for a timeout on this event.

38.7.2.5 struct msg_queue_t

Data Fields
• volatile bool isWaiting
Is any task waiting for a timeout.
• uint32_t time_start
The time to start timeout.
• uint32_t timeout
Timeout to wait in milliseconds.
• task_handler_t waitingTask
Handler to the waiting task.
• uint32_t ∗ queueMem
Points to the queue memory.
• uint16_t number
The number of messages in the queue.
• uint16_t max
The max number of queue messages.
• uint16_t head
Index of the next message to be read.
• uint16_t tail
Index of the next place to write to.

MCUXpresso SDK API Reference Manual


874 NXP Semiconductors
OSA BM

38.7.3 Macro Definition Documentation

38.7.3.1 #define FSL_OSA_BM_TIMER_NONE 0U

38.7.3.2 #define FSL_OSA_BM_TIMER_SYSTICK 1U

38.7.3.3 #define FSL_OSA_BM_TIMER_CONFIG FSL_OSA_BM_TIMER_SYSTICK

38.7.3.4 #define OSA_WAIT_FOREVER 0xFFFFFFFFU

38.7.3.5 #define TASK_MAX_NUM 7

38.7.3.6 #define FSL_OSA_TIME_RANGE 0xFFFFFFFFU

38.7.3.7 #define OSA_DEFAULT_INT_HANDLER ((osa_int_handler_t)(&DefaultISR))

38.7.3.8 #define PRIORITY_OSA_TO_RTOS( osa_prio ) (osa_prio)

This macro defines resources for a task statically. Then, the OSA_TaskCreate creates the task based-on
these resources.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 875
OSA BM

Parameters

task The task function.


stackSize The stack size this task needs in bytes.

38.7.4 Function Documentation

38.7.4.1 void DefaultISR ( void )

MCUXpresso SDK API Reference Manual


876 NXP Semiconductors
OSA FreeRTOS

38.8 OSA FreeRTOS


38.8.1 Overview

Macros

• #define OSA_WAIT_FOREVER 0xFFFFFFFFU


Constant to pass as timeout value in order to wait indefinitely.
• #define FSL_OSA_TIME_RANGE 0xFFFFFFFFU
OSA’s time range in millisecond, OSA time wraps if exceeds this value.
• #define OSA_DEFAULT_INT_HANDLER ((osa_int_handler_t)(&DefaultISR))
The default interrupt handler installed in vector table.
• #define OSA_MAX_ISR_CRITICAL_SECTION_DEPTH 0x8U
The Max depth of Enter/Exist Critical could be nested in interrupt.

Typedefs

• typedef TaskHandle_t task_handler_t


Type for a task handler, returned by the OSA_TaskCreate function.
• typedef portSTACK_TYPE task_stack_t
Type for a task stack.
• typedef void ∗ task_param_t
Type for task parameter.
• typedef EventBits_t event_flags_t
Type for an event flags object.

Thread management

• #define PRIORITY_OSA_TO_RTOS(osa_prio) ((UBaseType_t)configMAX_PRIORITIES - (osa-


_prio)-2U)
To provide unified task piority for upper layer, OSA layer makes conversion.
• #define PRIORITY_RTOS_TO_OSA(rtos_prio) ((UBaseType_t)configMAX_PRIORITIES -
(rtos_prio)-2U)

Message queues

• #define MSG_QUEUE_DECLARE(name, number, size) msg_queue_t ∗name = NULL


This macro statically reserves the memory required for the queue.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 877
OSA FreeRTOS

38.8.2 Macro Definition Documentation

38.8.2.1 #define OSA_WAIT_FOREVER 0xFFFFFFFFU

38.8.2.2 #define FSL_OSA_TIME_RANGE 0xFFFFFFFFU

38.8.2.3 #define OSA_DEFAULT_INT_HANDLER ((osa_int_handler_t)(&DefaultISR))

38.8.2.4 #define OSA_MAX_ISR_CRITICAL_SECTION_DEPTH 0x8U

38.8.2.5 #define MSG_QUEUE_DECLARE( name, number, size ) msg_queue_t ∗name =


NULL

MCUXpresso SDK API Reference Manual


878 NXP Semiconductors
OSA FreeRTOS

Parameters

name Identifier for the memory region.


number Number of elements in the queue.
size Size of every elements in words.

38.8.3 Typedef Documentation

38.8.3.1 typedef TaskHandle_t task_handler_t

38.8.3.2 typedef portSTACK_TYPE task_stack_t

38.8.3.3 typedef EventBits_t event_flags_t

MCUXpresso SDK API Reference Manual


NXP Semiconductors 879
OSA FreeRTOS

MCUXpresso SDK API Reference Manual


880 NXP Semiconductors
Chapter 39
Serial Manager
39.1 Overview
This chapter describes the programming interface of the serial manager component.
The serial manager component provides a series of APIs to operate different serial port types. The port
types it supports are UART, USB CDC and SWO.

Modules
• Serial Port SWO
• Serial Port USB
• Serial Port Uart
• Serial Port Virtual USB

Data Structures
• struct serial_manager_config_t
serial manager config structure More...
• struct serial_manager_callback_message_t
Callback message structure. More...

Macros
• #define SERIAL_PORT_TYPE_UART (1U)
Enable or disable uart port (1 - enable, 0 - disable)
• #define SERIAL_PORT_TYPE_USBCDC (0U)
Enable or disable USB CDC port (1 - enable, 0 - disable)
• #define SERIAL_PORT_TYPE_SWO (0U)
Enable or disable SWO port (1 - enable, 0 - disable)
• #define SERIAL_PORT_TYPE_USBCDC_VIRTUAL (0U)
Enable or disable USB CDC virtual port (1 - enable, 0 - disable)
• #define SERIAL_MANAGER_WRITE_HANDLE_SIZE (4U)
Set serial manager write handle size.
• #define SERIAL_MANAGER_HANDLE_SIZE (SERIAL_MANAGER_HANDLE_SIZE_TEMP
+ 12U)
SERIAL_PORT_UART_HANDLE_SIZE/SERIAL_PORT_USB_CDC_HANDLE_SIZE + serial manager
dedicated size.

Typedefs
• typedef void(∗ serial_manager_callback_t )(void ∗callbackParam, serial_manager_callback_-
message_t ∗message, serial_manager_status_t status)
callback function

MCUXpresso SDK API Reference Manual


NXP Semiconductors 881
Overview

Enumerations
• enum serial_port_type_t {
kSerialPort_Uart = 1U,
kSerialPort_UsbCdc,
kSerialPort_Swo,
kSerialPort_UsbCdcVirtual }
serial port type
• enum serial_manager_status_t {
kStatus_SerialManager_Success = kStatus_Success,
kStatus_SerialManager_Error = MAKE_STATUS(kStatusGroup_SERIALMANAGER, 1),
kStatus_SerialManager_Busy = MAKE_STATUS(kStatusGroup_SERIALMANAGER, 2),
kStatus_SerialManager_Notify = MAKE_STATUS(kStatusGroup_SERIALMANAGER, 3),
kStatus_SerialManager_Canceled,
kStatus_SerialManager_HandleConflict = MAKE_STATUS(kStatusGroup_SERIALMANAGER,
5),
kStatus_SerialManager_RingBufferOverflow }
serial manager error code

Functions
• serial_manager_status_t SerialManager_Init (serial_handle_t serialHandle, serial_manager_config-
_t ∗config)
Initializes a serial manager module with the serial manager handle and the user configuration structure.
• serial_manager_status_t SerialManager_Deinit (serial_handle_t serialHandle)
De-initializes the serial manager module instance.
• serial_manager_status_t SerialManager_OpenWriteHandle (serial_handle_t serialHandle, serial_-
write_handle_t writeHandle)
Opens a writing handle for the serial manager module.
• serial_manager_status_t SerialManager_CloseWriteHandle (serial_write_handle_t writeHandle)
Closes a writing handle for the serial manager module.
• serial_manager_status_t SerialManager_OpenReadHandle (serial_handle_t serialHandle, serial_-
read_handle_t readHandle)
Opens a reading handle for the serial manager module.
• serial_manager_status_t SerialManager_CloseReadHandle (serial_read_handle_t readHandle)
Closes a reading for the serial manager module.
• serial_manager_status_t SerialManager_WriteBlocking (serial_write_handle_t writeHandle, uint8-
_t ∗buffer, uint32_t length)
Transmits data with the blocking mode.
• serial_manager_status_t SerialManager_ReadBlocking (serial_read_handle_t readHandle, uint8_t
∗buffer, uint32_t length)
Reads data with the blocking mode.
• serial_manager_status_t SerialManager_EnterLowpower (serial_handle_t serialHandle)
Prepares to enter low power consumption.
• serial_manager_status_t SerialManager_ExitLowpower (serial_handle_t serialHandle)
Restores from low power consumption.

MCUXpresso SDK API Reference Manual


882 NXP Semiconductors
Enumeration Type Documentation

39.2 Data Structure Documentation


39.2.1 struct serial_manager_config_t

Data Fields

• uint8_t ∗ ringBuffer
Ring buffer address, it is used to buffer data received by the hardware.
• uint32_t ringBufferSize
The size of the ring buffer.
• serial_port_type_t type
Serial port type.
• void ∗ portConfig
Serial port configuration.

39.2.1.0.0.45 Field Documentation

39.2.1.0.0.45.1 uint8_t∗ serial_manager_config_t::ringBuffer

Besides, the memory space cannot be free during the lifetime of the serial manager module.

39.2.2 struct serial_manager_callback_message_t

Data Fields

• uint8_t ∗ buffer
Transferred buffer.
• uint32_t length
Transferred data length.

39.3 Enumeration Type Documentation


39.3.1 enum serial_port_type_t

Enumerator
kSerialPort_Uart Serial port UART.
kSerialPort_UsbCdc Serial port USB CDC.
kSerialPort_Swo Serial port SWO.
kSerialPort_UsbCdcVirtual Serial port USB CDC Virtual.

39.3.2 enum serial_manager_status_t

Enumerator
kStatus_SerialManager_Success Success.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 883
Function Documentation

kStatus_SerialManager_Error Failed.
kStatus_SerialManager_Busy Busy.
kStatus_SerialManager_Notify Ring buffer is not empty.
kStatus_SerialManager_Canceled the non-blocking request is canceled
kStatus_SerialManager_HandleConflict The handle is opened.
kStatus_SerialManager_RingBufferOverflow The ring buffer is overflowed.

39.4 Function Documentation


39.4.1 serial_manager_status_t SerialManager_Init ( serial_handle_t serialHandle,
serial_manager_config_t ∗ config )

This function configures the Serial Manager module with user-defined settings. The user can configure
the configuration structure. The parameter serialHandle is a pointer to point to a memory space of size
SERIAL_MANAGER_HANDLE_SIZE allocated by the caller. The Serial Manager module supports two
types of serial port, UART (includes UART, USART, LPSCI, LPUART, etc) and USB CDC. Please refer
to serial_port_type_t for serial port setting. These two types can be set by using serial_manager_config_t.
Example below shows how to use this API to configure the Serial Manager. For UART,
* #define SERIAL_MANAGER_RING_BUFFER_SIZE (256U)
* static uint8_t s_serialHandleBuffer[SERIAL_MANAGER_HANDLE_SIZE];
* static serial_handle_t s_serialHandle = &s_serialHandleBuffer[0];
* static uint8_t s_ringBuffer[SERIAL_MANAGER_RING_BUFFER_SIZE];
*
* serial_manager_config_t config;
* serial_port_uart_config_t uartConfig;
* config.type = kSerialPort_Uart;
* config.ringBuffer = &s_ringBuffer[0];
* config.ringBufferSize = SERIAL_MANAGER_RING_BUFFER_SIZE;
* uartConfig.instance = 0;
* uartConfig.clockRate = 24000000;
* uartConfig.baudRate = 115200;
* uartConfig.parityMode = kSerialManager_UartParityDisabled;
* uartConfig.stopBitCount = kSerialManager_UartOneStopBit;
* uartConfig.enableRx = 1;
* uartConfig.enableTx = 1;
* config.portConfig = &uartConfig;
* SerialManager_Init(s_serialHandle, &config);
*

For USB CDC,


* #define SERIAL_MANAGER_RING_BUFFER_SIZE (256U)
* static uint8_t s_serialHandleBuffer[SERIAL_MANAGER_HANDLE_SIZE];
* static serial_handle_t s_serialHandle = &s_serialHandleBuffer[0];
* static uint8_t s_ringBuffer[SERIAL_MANAGER_RING_BUFFER_SIZE];
*
* serial_manager_config_t config;
* serial_port_usb_cdc_config_t usbCdcConfig;
* config.type = kSerialPort_UsbCdc;
* config.ringBuffer = &s_ringBuffer[0];
* config.ringBufferSize = SERIAL_MANAGER_RING_BUFFER_SIZE;
* usbCdcConfig.controllerIndex =
kSerialManager_UsbControllerKhci0;
* config.portConfig = &usbCdcConfig;
* SerialManager_Init(s_serialHandle, &config);
*

MCUXpresso SDK API Reference Manual


884 NXP Semiconductors
Function Documentation

Parameters

serialHandle Pointer to point to a memory space of size SERIAL_MANAGER_HANDLE_SIZE


allocated by the caller.
config Pointer to user-defined configuration structure.

Return values

kStatus_SerialManager_- An error occurred.


Error
kStatus_SerialManager_- The Serial Manager module initialization succeed.
Success

39.4.2 serial_manager_status_t SerialManager_Deinit ( serial_handle_t


serialHandle )

This function de-initializes the serial manager module instance. If the opened writing or reading handle is
not closed, the function will return kStatus_SerialManager_Busy.
Parameters

serialHandle The serial manager module handle pointer.

Return values

kStatus_SerialManager_- The serial manager de-initialization succeed.


Success
kStatus_SerialManager_- Opened reading or writing handle is not closed.
Busy

39.4.3 serial_manager_status_t SerialManager_OpenWriteHandle ( serial_handle_t


serialHandle, serial_write_handle_t writeHandle )

This function Opens a writing handle for the serial manager module. If the serial manager needs to be
used in different tasks, the task should open a dedicated write handle for itself by calling SerialManager-
_OpenWriteHandle. Since there can only one buffer for transmission for the writing handle at the same
time, multiple writing handles need to be opened when the multiple transmission is needed for a task.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 885
Function Documentation

Parameters

serialHandle The serial manager module handle pointer.


writeHandle The serial manager module writing handle pointer.

Return values

kStatus_SerialManager_- An error occurred.


Error
kStatus_SerialManager_- The writing handle was opened.
HandleConflict
kStatus_SerialManager_- The writing handle is opened.
Success
Example below shows how to use this API to write data. For task 1,

* static uint8_t s_serialWriteHandleBuffer1[SERIAL_MANAGER_WRITE_HANDLE_SIZE


];
* static serial_write_handle_t s_serialWriteHandle1 = &s_serialWriteHandleBuffer1[0];
* static uint8_t s_nonBlockingWelcome1[] = "This is non-blocking writing log for task1!\r\n";
* SerialManager_OpenWriteHandle(serialHandle, s_serialWriteHandle1);
* SerialManager_InstallTxCallback(s_serialWriteHandle1, Task1_SerialManagerTxCallback,
s_serialWriteHandle1);
* SerialManager_WriteNonBlocking(s_serialWriteHandle1, s_nonBlockingWelcome1, sizeof(
s_nonBlockingWelcome1) - 1);
*

For task 2,

* static uint8_t s_serialWriteHandleBuffer2[SERIAL_MANAGER_WRITE_HANDLE_SIZE


];
* static serial_write_handle_t s_serialWriteHandle2 = &s_serialWriteHandleBuffer2[0];
* static uint8_t s_nonBlockingWelcome2[] = "This is non-blocking writing log for task2!\r\n";
* SerialManager_OpenWriteHandle(serialHandle, s_serialWriteHandle2);
* SerialManager_InstallTxCallback(s_serialWriteHandle2, Task2_SerialManagerTxCallback,
s_serialWriteHandle2);
* SerialManager_WriteNonBlocking(s_serialWriteHandle2, s_nonBlockingWelcome2, sizeof(
s_nonBlockingWelcome2) - 1);
*

39.4.4 serial_manager_status_t SerialManager_CloseWriteHandle (


serial_write_handle_t writeHandle )

This function Closes a writing handle for the serial manager module.

MCUXpresso SDK API Reference Manual


886 NXP Semiconductors
Function Documentation

Parameters

writeHandle The serial manager module writing handle pointer.

Return values

kStatus_SerialManager_- The writing handle is closed.


Success

39.4.5 serial_manager_status_t SerialManager_OpenReadHandle ( serial_handle_t


serialHandle, serial_read_handle_t readHandle )

This function Opens a reading handle for the serial manager module. The reading handle can not be
opened multiple at the same time. The error code kStatus_SerialManager_Busy would be returned when
the previous reading handle is not closed. And There can only be one buffer for receiving for the reading
handle at the same time.
Parameters

serialHandle The serial manager module handle pointer.


readHandle The serial manager module reading handle pointer.

Return values

kStatus_SerialManager_- An error occurred.


Error
kStatus_SerialManager_- The reading handle is opened.
Success
kStatus_SerialManager_- Previous reading handle is not closed.
Busy
Example below shows how to use this API to read data.
* static uint8_t s_serialReadHandleBuffer[SERIAL_MANAGER_READ_HANDLE_SIZE];
* static serial_read_handle_t s_serialReadHandle = &s_serialReadHandleBuffer[0];
* SerialManager_OpenReadHandle(serialHandle, s_serialReadHandle);
* static uint8_t s_nonBlockingBuffer[64];
* SerialManager_InstallRxCallback(s_serialReadHandle, APP_SerialManagerRxCallback, s_serialReadHandle);
* SerialManager_ReadNonBlocking(s_serialReadHandle, s_nonBlockingBuffer, sizeof(s_nonBlockingBuffer));
*

39.4.6 serial_manager_status_t SerialManager_CloseReadHandle (


serial_read_handle_t readHandle )

This function Closes a reading for the serial manager module.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 887
Function Documentation

Parameters

readHandle The serial manager module reading handle pointer.

Return values

kStatus_SerialManager_- The reading handle is closed.


Success

39.4.7 serial_manager_status_t SerialManager_WriteBlocking ( serial-


_write_handle_t writeHandle, uint8_t ∗ buffer, uint32_t length
)

This is a blocking function, which polls the sending queue, waits for the sending queue to be empty. This
function sends data using an interrupt method. The interrupt of the hardware could not be disabled. And
There can only one buffer for transmission for the writing handle at the same time.

Note
The function SerialManager_WriteBlocking and the function #SerialManager_WriteNonBlocking
cannot be used at the same time. And, the function #SerialManager_CancelWriting cannot be used
to abort the transmission of this function.

Parameters

writeHandle The serial manager module handle pointer.


buffer Start address of the data to write.
length Length of the data to write.

Return values

kStatus_SerialManager_- Successfully sent all data.


Success
kStatus_SerialManager_- Previous transmission still not finished; data not all sent yet.
Busy

MCUXpresso SDK API Reference Manual


888 NXP Semiconductors
Function Documentation

kStatus_SerialManager_- An error occurred.


Error

39.4.8 serial_manager_status_t SerialManager_ReadBlocking ( serial-


_read_handle_t readHandle, uint8_t ∗ buffer, uint32_t length
)

This is a blocking function, which polls the receiving buffer, waits for the receiving buffer to be full. This
function receives data using an interrupt method. The interrupt of the hardware could not be disabled. And
There can only one buffer for receiving for the reading handle at the same time.

Note
The function SerialManager_ReadBlocking and the function #SerialManager_ReadNonBlocking
cannot be used at the same time. And, the function #SerialManager_CancelReading cannot be used
to abort the transmission of this function.

Parameters

readHandle The serial manager module handle pointer.


buffer Start address of the data to store the received data.
length The length of the data to be received.

Return values

kStatus_SerialManager_- Successfully received all data.


Success
kStatus_SerialManager_- Previous transmission still not finished; data not all received yet.
Busy
kStatus_SerialManager_- An error occurred.
Error

39.4.9 serial_manager_status_t SerialManager_EnterLowpower ( serial_handle_t


serialHandle )

This function is used to prepare to enter low power consumption.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 889
Function Documentation

Parameters

serialHandle The serial manager module handle pointer.

Return values

kStatus_SerialManager_- Successful operation.


Success

39.4.10 serial_manager_status_t SerialManager_ExitLowpower ( serial_handle_t


serialHandle )

This function is used to restore from low power consumption.


Parameters

serialHandle The serial manager module handle pointer.

Return values

kStatus_SerialManager_- Successful operation.


Success

MCUXpresso SDK API Reference Manual


890 NXP Semiconductors
Serial Port Uart

39.5 Serial Port Uart


39.5.1 Overview

Data Structures

• struct serial_port_uart_config_t
serial port uart config struct More...

Macros

• #define SERIAL_PORT_UART_HANDLE_SIZE (4U)


serial port uart handle size

Enumerations

• enum serial_port_uart_parity_mode_t {
kSerialManager_UartParityDisabled = 0x0U,
kSerialManager_UartParityEven = 0x1U,
kSerialManager_UartParityOdd = 0x2U }
serial port uart parity mode
• enum serial_port_uart_stop_bit_count_t {
kSerialManager_UartOneStopBit = 0U,
kSerialManager_UartTwoStopBit = 1U }
serial port uart stop bit count

39.5.2 Data Structure Documentation

39.5.2.1 struct serial_port_uart_config_t

Data Fields
• uint32_t clockRate
clock rate
• uint32_t baudRate
baud rate
• serial_port_uart_parity_mode_t parityMode
Parity mode, disabled (default), even, odd.
• serial_port_uart_stop_bit_count_t stopBitCount
Number of stop bits, 1 stop bit (default) or 2 stop bits.
• uint8_t instance
Instance (0 - UART0, 1 - UART1, ...), detail information please refer to the SOC corresponding RM.
• uint8_t enableRx
Enable RX.
• uint8_t enableTx

MCUXpresso SDK API Reference Manual


NXP Semiconductors 891
Serial Port Uart

Enable TX.

39.5.2.1.0.46 Field Documentation

39.5.2.1.0.46.1 uint8_t serial_port_uart_config_t::instance

39.5.3 Enumeration Type Documentation

39.5.3.1 enum serial_port_uart_parity_mode_t

Enumerator
kSerialManager_UartParityDisabled Parity disabled.
kSerialManager_UartParityEven Parity even enabled.
kSerialManager_UartParityOdd Parity odd enabled.

39.5.3.2 enum serial_port_uart_stop_bit_count_t

Enumerator
kSerialManager_UartOneStopBit One stop bit.
kSerialManager_UartTwoStopBit Two stop bits.

MCUXpresso SDK API Reference Manual


892 NXP Semiconductors
Serial Port USB

39.6 Serial Port USB


39.6.1 Overview

Modules

• USB Device Configuration

Data Structures

• struct serial_port_usb_cdc_config_t
serial port usb config struct More...

Macros

• #define SERIAL_PORT_USB_CDC_HANDLE_SIZE (72)


serial port usb handle size
• #define USB_DEVICE_INTERRUPT_PRIORITY (3U)
USB interrupt priority.

Enumerations

• enum serial_port_usb_cdc_controller_index_t {
kSerialManager_UsbControllerKhci0 = 0U,
kSerialManager_UsbControllerKhci1 = 1U,
kSerialManager_UsbControllerEhci0 = 2U,
kSerialManager_UsbControllerEhci1 = 3U,
kSerialManager_UsbControllerLpcIp3511Fs0 = 4U,
kSerialManager_UsbControllerLpcIp3511Fs1 = 5U,
kSerialManager_UsbControllerLpcIp3511Hs0 = 6U,
kSerialManager_UsbControllerLpcIp3511Hs1 = 7U,
kSerialManager_UsbControllerOhci0 = 8U,
kSerialManager_UsbControllerOhci1 = 9U,
kSerialManager_UsbControllerIp3516Hs0 = 10U,
kSerialManager_UsbControllerIp3516Hs1 = 11U }
USB controller ID.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 893
Serial Port USB

39.6.2 Data Structure Documentation

39.6.2.1 struct serial_port_usb_cdc_config_t

Data Fields
• serial_port_usb_cdc_controller_index_t controllerIndex
controller index

39.6.3 Enumeration Type Documentation

39.6.3.1 enum serial_port_usb_cdc_controller_index_t

Enumerator
kSerialManager_UsbControllerKhci0 KHCI 0U.
kSerialManager_UsbControllerKhci1 KHCI 1U, Currently, there are no platforms which have two
KHCI IPs, this is reserved to be used in the future.
kSerialManager_UsbControllerEhci0 EHCI 0U.
kSerialManager_UsbControllerEhci1 EHCI 1U, Currently, there are no platforms which have two
EHCI IPs, this is reserved to be used in the future.
kSerialManager_UsbControllerLpcIp3511Fs0 LPC USB IP3511 FS controller 0.
kSerialManager_UsbControllerLpcIp3511Fs1 LPC USB IP3511 FS controller 1, there are no plat-
forms which have two IP3511 IPs, this is reserved to be used in the future.
kSerialManager_UsbControllerLpcIp3511Hs0 LPC USB IP3511 HS controller 0.
kSerialManager_UsbControllerLpcIp3511Hs1 LPC USB IP3511 HS controller 1, there are no plat-
forms which have two IP3511 IPs, this is reserved to be used in the future.
kSerialManager_UsbControllerOhci0 OHCI 0U.
kSerialManager_UsbControllerOhci1 OHCI 1U, Currently, there are no platforms which have two
OHCI IPs, this is reserved to be used in the future.
kSerialManager_UsbControllerIp3516Hs0 IP3516HS 0U.
kSerialManager_UsbControllerIp3516Hs1 IP3516HS 1U, Currently, there are no platforms which
have two IP3516HS IPs, this is reserved to be used in the future.

MCUXpresso SDK API Reference Manual


894 NXP Semiconductors
Serial Port USB

39.6.4 USB Device Configuration

39.6.4.1 Overview

Macros
• #define USB_DEVICE_CONFIG_SELF_POWER (1U)
Whether device is self power.
• #define USB_DEVICE_CONFIG_ENDPOINTS (4U)
How many endpoints are supported in the stack.
• #define USB_DEVICE_CONFIG_USE_TASK (0U)
Whether the device task is enabled.
• #define USB_DEVICE_CONFIG_MAX_MESSAGES (8U)
How many the notification message are supported when the device task is enabled.
• #define USB_DEVICE_CONFIG_USB20_TEST_MODE (0U)
Whether test mode enabled.
• #define USB_DEVICE_CONFIG_CV_TEST (0U)
Whether device CV test is enabled.
• #define USB_DEVICE_CONFIG_COMPLIANCE_TEST (0U)
Whether device compliance test is enabled.
• #define USB_DEVICE_CONFIG_KEEP_ALIVE_MODE (0U)
Whether the keep alive feature enabled.
• #define USB_DEVICE_CONFIG_BUFFER_PROPERTY_CACHEABLE (0U)
Whether the transfer buffer is cache-enabled or not.
• #define USB_DEVICE_CONFIG_LOW_POWER_MODE (0U)
Whether the low power mode is enabled or not.
• #define USB_DEVICE_CONFIG_REMOTE_WAKEUP (0U)
The device remote wakeup is unsupported.
• #define USB_DEVICE_CONFIG_DETACH_ENABLE (0U)
Whether the device detached feature is enabled or not.
• #define USB_DEVICE_CONFIG_ERROR_HANDLING (0U)
Whether handle the USB bus error.
• #define USB_DEVICE_CHARGER_DETECT_ENABLE (0U)
Whether the device charger detect feature is enabled or not.

class instance define


• #define USB_DEVICE_CONFIG_HID (0U)
HID instance count.
• #define USB_DEVICE_CONFIG_CDC_ACM (1U)
CDC ACM instance count.
• #define USB_DEVICE_CONFIG_MSC (0U)
MSC instance count.
• #define USB_DEVICE_CONFIG_AUDIO (0U)
Audio instance count.
• #define USB_DEVICE_CONFIG_PHDC (0U)
PHDC instance count.
• #define USB_DEVICE_CONFIG_VIDEO (0U)
Video instance count.
• #define USB_DEVICE_CONFIG_CCID (0U)

MCUXpresso SDK API Reference Manual


NXP Semiconductors 895
Serial Port USB

CCID instance count.


• #define USB_DEVICE_CONFIG_PRINTER (0U)
Printer instance count.
• #define USB_DEVICE_CONFIG_DFU (0U)
DFU instance count.

39.6.4.2 Macro Definition Documentation

39.6.4.2.1 #define USB_DEVICE_CONFIG_SELF_POWER (1U)

1U supported, 0U not supported

39.6.4.2.2 #define USB_DEVICE_CONFIG_ENDPOINTS (4U)

39.6.4.2.3 #define USB_DEVICE_CONFIG_USE_TASK (0U)

39.6.4.2.4 #define USB_DEVICE_CONFIG_MAX_MESSAGES (8U)

39.6.4.2.5 #define USB_DEVICE_CONFIG_USB20_TEST_MODE (0U)

39.6.4.2.6 #define USB_DEVICE_CONFIG_CV_TEST (0U)

39.6.4.2.7 #define USB_DEVICE_CONFIG_COMPLIANCE_TEST (0U)

If the macro is enabled, the test mode and CV test macroes will be set.

39.6.4.2.8 #define USB_DEVICE_CONFIG_KEEP_ALIVE_MODE (0U)

39.6.4.2.9 #define USB_DEVICE_CONFIG_BUFFER_PROPERTY_CACHEABLE (0U)

39.6.4.2.10 #define USB_DEVICE_CONFIG_LOW_POWER_MODE (0U)

39.6.4.2.11 #define USB_DEVICE_CONFIG_REMOTE_WAKEUP (0U)

39.6.4.2.12 #define USB_DEVICE_CONFIG_DETACH_ENABLE (0U)

39.6.4.2.13 #define USB_DEVICE_CONFIG_ERROR_HANDLING (0U)

39.6.4.2.14 #define USB_DEVICE_CHARGER_DETECT_ENABLE (0U)

MCUXpresso SDK API Reference Manual


896 NXP Semiconductors
Serial Port SWO

39.7 Serial Port SWO


39.7.1 Overview

Data Structures

• struct serial_port_swo_config_t
serial port swo config struct More...

Macros

• #define SERIAL_PORT_SWO_HANDLE_SIZE (12U)


serial port swo handle size

Enumerations

• enum serial_port_swo_protocol_t {
kSerialManager_SwoProtocolManchester = 1U,
kSerialManager_SwoProtocolNrz = 2U }
serial port swo protocol

39.7.2 Data Structure Documentation

39.7.2.1 struct serial_port_swo_config_t

Data Fields
• uint32_t clockRate
clock rate
• uint32_t baudRate
baud rate
• uint32_t port
Port used to transfer data.
• serial_port_swo_protocol_t protocol
SWO protocol.

39.7.3 Enumeration Type Documentation

39.7.3.1 enum serial_port_swo_protocol_t

Enumerator
kSerialManager_SwoProtocolManchester SWO Manchester protocol.
kSerialManager_SwoProtocolNrz SWO UART/NRZ protocol.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 897
Serial Port Virtual USB

39.8 Serial Port Virtual USB


39.8.1 Overview

This chapter describes how to redirect the serial manager stream to application CDC. The weak func-
tions can be implemented by application to redirect the serial manager stream. The weak functions are
following,
USB_DeviceVcomInit - Initialize the cdc vcom.
USB_DeviceVcomDeinit - De-initialize the cdc vcom.
USB_DeviceVcomWrite - Write data with non-blocking mode. After data is sent, the installed TX call-
back should be called with the result.
USB_DeviceVcomRead - Read data with non-blocking mode. After data is received, the installed RX
callback should be called with the result.
USB_DeviceVcomCancelWrite - Cancel write request.
USB_DeviceVcomInstallTxCallback - Install TX callback.
USB_DeviceVcomInstallRxCallback - Install RX callback.
USB_DeviceVcomIsrFunction - The hardware ISR function.

Data Structures

• struct serial_port_usb_cdc_virtual_config_t
serial port usb config struct More...

Macros

• #define SERIAL_PORT_USB_VIRTUAL_HANDLE_SIZE (40U)


serial port USB handle size

MCUXpresso SDK API Reference Manual


898 NXP Semiconductors
Serial Port Virtual USB

Enumerations

• enum serial_port_usb_cdc_virtual_controller_index_t {
kSerialManager_UsbVirtualControllerKhci0 = 0U,
kSerialManager_UsbVirtualControllerKhci1 = 1U,
kSerialManager_UsbVirtualControllerEhci0 = 2U,
kSerialManager_UsbVirtualControllerEhci1 = 3U,
kSerialManager_UsbVirtualControllerLpcIp3511Fs0 = 4U,
kSerialManager_UsbVirtualControllerLpcIp3511Fs1,
kSerialManager_UsbVirtualControllerLpcIp3511Hs0 = 6U,
kSerialManager_UsbVirtualControllerLpcIp3511Hs1,
kSerialManager_UsbVirtualControllerOhci0 = 8U,
kSerialManager_UsbVirtualControllerOhci1 = 9U,
kSerialManager_UsbVirtualControllerIp3516Hs0 = 10U,
kSerialManager_UsbVirtualControllerIp3516Hs1 = 11U }
USB controller ID.

Variables

• serial_port_usb_cdc_virtual_controller_index_t serial_port_usb_cdc_virtual_config_t::controller-
Index
controller index

39.8.2 Data Structure Documentation

39.8.2.1 struct serial_port_usb_cdc_virtual_config_t

Data Fields
• serial_port_usb_cdc_virtual_controller_index_t controllerIndex
controller index

39.8.3 Enumeration Type Documentation

39.8.3.1 enum serial_port_usb_cdc_virtual_controller_index_t

Enumerator
kSerialManager_UsbVirtualControllerKhci0 KHCI 0U.
kSerialManager_UsbVirtualControllerKhci1 KHCI 1U, Currently, there are no platforms which
have two KHCI IPs, this is reserved to be used in the future.
kSerialManager_UsbVirtualControllerEhci0 EHCI 0U.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 899
Serial Port Virtual USB

kSerialManager_UsbVirtualControllerEhci1 EHCI 1U, Currently, there are no platforms which


have two EHCI IPs, this is reserved to be used in the future.
kSerialManager_UsbVirtualControllerLpcIp3511Fs0 LPC USB IP3511 FS controller 0.
kSerialManager_UsbVirtualControllerLpcIp3511Fs1 LPC USB IP3511 FS controller 1, there are
no platforms which have two IP3511 IPs, this is reserved to be used in the future.
kSerialManager_UsbVirtualControllerLpcIp3511Hs0 LPC USB IP3511 HS controller 0.
kSerialManager_UsbVirtualControllerLpcIp3511Hs1 LPC USB IP3511 HS controller 1, there are
no platforms which have two IP3511 IPs, this is reserved to be used in the future.
kSerialManager_UsbVirtualControllerOhci0 OHCI 0U.
kSerialManager_UsbVirtualControllerOhci1 OHCI 1U, Currently, there are no platforms which
have two OHCI IPs, this is reserved to be used in the future.
kSerialManager_UsbVirtualControllerIp3516Hs0 IP3516HS 0U.
kSerialManager_UsbVirtualControllerIp3516Hs1 IP3516HS 1U, Currently, there are no platforms
which have two IP3516HS IPs, this is reserved to be used in the future.

MCUXpresso SDK API Reference Manual


900 NXP Semiconductors
Chapter 40
Button
40.1 Overview
Data Structures
• struct button_callback_message_t
The callback message struct of button. More...
• struct button_gpio_config_t
The button gpio config structure. More...
• struct button_config_t
The button config structure. More...

Macros
• #define BUTTON_HANDLE_SIZE (16U + 24U)
Definition of button handle size as HAL_GPIO_HANDLE_SIZE + button dedicated size.
• #define BUTTON_TIMER_INTERVAL (25U)
Definition of button timer interval,unit is ms.
• #define BUTTON_SHORT_PRESS_THRESHOLD (200U)
Definition of button short press threshold,unit is ms.
• #define BUTTON_LONG_PRESS_THRESHOLD (500U)
Definition of button long press threshold,unit is ms.
• #define BUTTON_DOUBLE_CLICK_THRESHOLD (200U)
Definition of button double click threshold,unit is ms.
• #define BUTTON_USE_COMMON_TASK (1U)
Definition to determine whether use common task.
• #define BUTTON_TASK_PRIORITY (2U)
Definition of button task priority.
• #define BUTTON_TASK_STACK_SIZE (1000U)
Definition of button task stack size.
• #define BUTTON_EVENT_BUTTON (1U)
Definition of button event.

Typedefs
• typedef void ∗ button_handle_t
The handle of button.
• typedef button_status_t(∗ button_callback_t )(void ∗buttonHandle, button_callback_message_t
∗message, void ∗callbackParam)
The callback function of button.

Enumerations
• enum button_status_t {
kStatus_BUTTON_Success = kStatus_Success,
kStatus_BUTTON_Error = MAKE_STATUS(kStatusGroup_BUTTON, 1),

MCUXpresso SDK API Reference Manual


NXP Semiconductors 901
Data Structure Documentation

kStatus_BUTTON_LackSource = MAKE_STATUS(kStatusGroup_BUTTON, 2) }
The status type of button.
• enum button_event_t {
kBUTTON_EventOneClick = 0x01U,
kBUTTON_EventDoubleClick,
kBUTTON_EventShortPress,
kBUTTON_EventLongPress,
kBUTTON_EventError }
The event type of button.

Functions
• button_status_t BUTTON_Deinit (button_handle_t buttonHandle)
Deinitializes a button instance.
• button_status_t BUTTON_WakeUpSetting (button_handle_t buttonHandle, uint8_t enable)
Enables or disables the button wake-up feature.
• button_status_t BUTTON_EnterLowpower (button_handle_t buttonHandle)
Prepares to enter low power consumption.
• button_status_t BUTTON_ExitLowpower (button_handle_t buttonHandle)
Restores from low power consumption.

Initialization
• button_status_t BUTTON_Init (button_handle_t buttonHandle, button_config_t ∗buttonConfig)
Initializes a button with the button handle and the user configuration structure.

Install callback
• button_status_t BUTTON_InstallCallback (button_handle_t buttonHandle, button_callback_t call-
back, void ∗callbackParam)
Installs a callback and callback parameter.

40.2 Data Structure Documentation


40.2.1 struct button_callback_message_t

40.2.2 struct button_gpio_config_t

Data Fields

• uint8_t port
GPIO Port.
• uint8_t pin
GPIO Pin.
• uint8_t pinStateDefault
GPIO Pin voltage when button is not pressed (0 - low level, 1 - high level)

MCUXpresso SDK API Reference Manual


902 NXP Semiconductors
Enumeration Type Documentation

40.2.3 struct button_config_t

40.3 Macro Definition Documentation


40.3.1 #define BUTTON_HANDLE_SIZE (16U + 24U)

40.3.2 #define BUTTON_TIMER_INTERVAL (25U)

40.3.3 #define BUTTON_SHORT_PRESS_THRESHOLD (200U)

40.3.4 #define BUTTON_LONG_PRESS_THRESHOLD (500U)

40.3.5 #define BUTTON_DOUBLE_CLICK_THRESHOLD (200U)

40.3.6 #define BUTTON_USE_COMMON_TASK (1U)

40.3.7 #define BUTTON_TASK_PRIORITY (2U)

40.3.8 #define BUTTON_TASK_STACK_SIZE (1000U)

40.3.9 #define BUTTON_EVENT_BUTTON (1U)

40.4 Enumeration Type Documentation


40.4.1 enum button_status_t

Enumerator
kStatus_BUTTON_Success Success.
kStatus_BUTTON_Error Failed.
kStatus_BUTTON_LackSource Lack of sources.

40.4.2 enum button_event_t

Enumerator
kBUTTON_EventOneClick One click with short time, the duration of key down and key up is less
than BUTTON_SHORT_PRESS_THRESHOLD.
kBUTTON_EventDoubleClick Double click with short time, the duration of key down and key up
is less than BUTTON_SHORT_PRESS_THRESHOLD. And the duration of the two button ac-
tions does not exceed BUTTON_DOUBLE_CLICK_THRESHOLD.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 903
Function Documentation

kBUTTON_EventShortPress Press with short time, the duration of key down and key up is no less
than BUTTON_SHORT_PRESS_THRESHOLD and less than BUTTON_LONG_PRESS_TH-
RESHOLD.
kBUTTON_EventLongPress Press with long time, the duration of key down and key up is no less
than BUTTON_LONG_PRESS_THRESHOLD.
kBUTTON_EventError Error event if the button actions cannot be identified.

40.5 Function Documentation


40.5.1 button_status_t BUTTON_Init ( button_handle_t buttonHandle,
button_config_t ∗ buttonConfig )

This function configures the button with user-defined settings. The user can configure the configuration
structure. The parameter buttonHandle is a pointer to point to a memory space of size BUTTON_HAND-
LE_SIZE allocated by the caller.
Example below shows how to use this API to configure the button.

* uint8_t s_buttonHandleBuffer[BUTTON_HANDLE_SIZE];
* button_handle_t s_buttonHandle = &s_buttonHandleBuffer[0];
* button_config_t buttonConfig;
* buttonConfig.gpio.port = 0;
* buttonConfig.gpio.pin = 1;
* buttonConfig.gpio.pinStateDefault = 0;
* BUTTON_Init(s_buttonHandle, &buttonConfig);
*

Parameters

buttonHandle Pointer to point to a memory space of size BUTTON_HANDLE_SIZE allocated by


the caller.
buttonConfig Pointer to user-defined configuration structure.

Returns
Indicates whether initialization was successful or not.

Return values

kStatus_BUTTON_Error An error occurred.


kStatus_BUTTON_- Button initialization succeed.
Success

MCUXpresso SDK API Reference Manual


904 NXP Semiconductors
Function Documentation

40.5.2 button_status_t BUTTON_InstallCallback ( button_handle_t buttonHandle,


button_callback_t callback, void ∗ callbackParam )

This function is used to install the callback and callback parameter for button module. Once the button is
pressed, the button driver will identify the behavior and notify the upper layer with the button event by the
installed callback function. Currently, the Button supports the three types of event, click, double click and
long press. Detail information refer to button_event_t.
Parameters

buttonHandle Button handle pointer.


callback The callback function.
callbackParam The parameter of the callback function.

Returns
Indicates whether callback install was successful or not.

Return values

kStatus_BUTTON_- Successfully install the callback.


Success

40.5.3 button_status_t BUTTON_Deinit ( button_handle_t buttonHandle )

This function deinitializes the button instance.


Parameters

buttonHandle button handle pointer.

Return values

kStatus_BUTTON_- button de-initialization succeed.


Success

40.5.4 button_status_t BUTTON_WakeUpSetting ( button_handle_t buttonHandle,


uint8_t enable )

This function enables or disables the button wake-up feature.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 905
Function Documentation

Parameters

buttonHandle button handle pointer.


enable enable or disable (0 - disable, 1 - enable).

Return values

kStatus_BUTTON_Error An error occurred.


kStatus_BUTTON_- Set successfully.
Success

40.5.5 button_status_t BUTTON_EnterLowpower ( button_handle_t buttonHandle )

This function is used to prepare to enter low power consumption.


Parameters

buttonHandle button handle pointer.

Return values

kStatus_BUTTON_- Successful operation.


Success

40.5.6 button_status_t BUTTON_ExitLowpower ( button_handle_t buttonHandle )

This function is used to restore from low power consumption.


Parameters

buttonHandle button handle pointer.

Return values

kStatus_BUTTON_- Successful operation.


Success

MCUXpresso SDK API Reference Manual


906 NXP Semiconductors
Chapter 41
GPIO_Adapter
41.1 Overview
Data Structures
• struct hal_gpio_pin_config_t
The pin config struct of GPIO adapter. More...

Macros
• #define HAL_GPIO_HANDLE_SIZE (16U)
Definition of GPIO adapter handle size.
• #define HAL_GPIO_HANDLE_ISR_PRIORITY (3U)
Definition of GPIO adapter isr priority.

Typedefs
• typedef void ∗ hal_gpio_handle_t
The handle of GPIO adapter.
• typedef void(∗ hal_gpio_callback_t )(void ∗param)
The callback function of GPIO adapter.

Enumerations
• enum hal_gpio_interrupt_trigger_t {
kHAL_GpioInterruptDisable = 0x0U,
kHAL_GpioInterruptLogicZero = 0x1U,
kHAL_GpioInterruptRisingEdge = 0x2U,
kHAL_GpioInterruptFallingEdge = 0x3U,
kHAL_GpioInterruptEitherEdge = 0x4U,
kHAL_GpioInterruptLogicOne = 0x5U }
The interrupt trigger of GPIO adapter.
• enum hal_gpio_status_t {
kStatus_HAL_GpioSuccess = kStatus_Success,
kStatus_HAL_GpioError = MAKE_STATUS(kStatusGroup_HAL_GPIO, 1),
kStatus_HAL_GpioLackSource = MAKE_STATUS(kStatusGroup_HAL_GPIO, 2),
kStatus_HAL_GpioPinConflict = MAKE_STATUS(kStatusGroup_HAL_GPIO, 3) }
The status of GPIO adapter.
• enum hal_gpio_direction_t {
kHAL_GpioDirectionOut = 0x00U,
kHAL_GpioDirectionIn }
The direction of GPIO adapter.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 907
Typedef Documentation

Functions
• hal_gpio_status_t HAL_GpioInit (hal_gpio_handle_t gpioHandle, hal_gpio_pin_config_t ∗pin-
Config)
Initializes an GPIO instance with the GPIO handle and the user configuration structure.
• hal_gpio_status_t HAL_GpioDeinit (hal_gpio_handle_t gpioHandle)
Deinitializes a GPIO instance.
• hal_gpio_status_t HAL_GpioGetInput (hal_gpio_handle_t gpioHandle, uint8_t ∗pinState)
Gets the pin voltage.
• hal_gpio_status_t HAL_GpioSetOutput (hal_gpio_handle_t gpioHandle, uint8_t pinState)
Sets the pin voltage.
• hal_gpio_status_t HAL_GpioGetTriggerMode (hal_gpio_handle_t gpioHandle, hal_gpio_interrupt-
_trigger_t ∗gpioTrigger)
Gets the pin interrupt trigger mode.
• hal_gpio_status_t HAL_GpioSetTriggerMode (hal_gpio_handle_t gpioHandle, hal_gpio_interrupt-
_trigger_t gpioTrigger)
Sets the pin interrupt trigger mode.
• hal_gpio_status_t HAL_GpioInstallCallback (hal_gpio_handle_t gpioHandle, hal_gpio_callback_t
callback, void ∗callbackParam)
Installs a callback and callback parameter.
• hal_gpio_status_t HAL_GpioWakeUpSetting (hal_gpio_handle_t gpioHandle, uint8_t enable)
Enables or disables the GPIO wake-up feature.
• hal_gpio_status_t HAL_GpioEnterLowpower (hal_gpio_handle_t gpioHandle)
Prepares to enter low power consumption.
• hal_gpio_status_t HAL_GpioExitLowpower (hal_gpio_handle_t gpioHandle)
Restores from low power consumption.

41.2 Data Structure Documentation


41.2.1 struct hal_gpio_pin_config_t

41.3 Macro Definition Documentation


41.3.1 #define HAL_GPIO_HANDLE_SIZE (16U)

41.3.2 #define HAL_GPIO_HANDLE_ISR_PRIORITY (3U)

41.4 Typedef Documentation


41.4.1 typedef void∗ hal_gpio_handle_t

41.4.2 typedef void(∗ hal_gpio_callback_t)(void ∗param)

MCUXpresso SDK API Reference Manual


908 NXP Semiconductors
Function Documentation

41.5 Enumeration Type Documentation


41.5.1 enum hal_gpio_interrupt_trigger_t

Enumerator
kHAL_GpioInterruptDisable Interrupt disable.
kHAL_GpioInterruptLogicZero Interrupt when logic zero.
kHAL_GpioInterruptRisingEdge Interrupt on rising edge.
kHAL_GpioInterruptFallingEdge Interrupt on falling edge.
kHAL_GpioInterruptEitherEdge Interrupt on either edge.
kHAL_GpioInterruptLogicOne Interrupt when logic one.

41.5.2 enum hal_gpio_status_t

Enumerator
kStatus_HAL_GpioSuccess Success.
kStatus_HAL_GpioError Failed.
kStatus_HAL_GpioLackSource Lack of sources.
kStatus_HAL_GpioPinConflict PIN conflict.

41.5.3 enum hal_gpio_direction_t

Enumerator
kHAL_GpioDirectionOut Out.
kHAL_GpioDirectionIn In.

41.6 Function Documentation


41.6.1 hal_gpio_status_t HAL_GpioInit ( hal_gpio_handle_t gpioHandle,
hal_gpio_pin_config_t ∗ pinConfig )

This function configures the GPIO module with user-defined settings. The user can configure the con-
figuration structure. The parameter handle is a pointer to point to a memory space of size HAL_GPI-
O_HANDLE_SIZE allocated by the caller. Example below shows how to use this API to configure the
GPIO.

* uint8_t g_GpioHandleBuffer[HAL_GPIO_HANDLE_SIZE];
* hal_gpio_handle_t g_GpioHandle = &g_GpioHandleBuffer[0];
* hal_gpio_pin_config_t config;
* config.direction = kHAL_GpioDirectionOut;
* config.port = 0;
* config.pin = 0;
* HAL_GpioInit(g_GpioHandle, &config);
*

MCUXpresso SDK API Reference Manual


NXP Semiconductors 909
Function Documentation

Parameters

gpioHandle Pointer to point to a memory space of size HAL_GPIO_HANDLE_SIZE allocated


by the caller.
pinConfig Pointer to user-defined configuration structure.

Return values

kStatus_HAL_GpioError An error occurred while initializing the GPIO.


kStatus_HAL_GpioPin- The pair of the pin and port passed by pinConfig is initialized.
Conflict
kStatus_HAL_Gpio- GPIO initialization succeed
Success

41.6.2 hal_gpio_status_t HAL_GpioDeinit ( hal_gpio_handle_t gpioHandle )

This function disables the trigger mode.


Parameters

gpioHandle GPIO handle pointer.

Return values

kStatus_HAL_Gpio- GPIO de-initialization succeed


Success

41.6.3 hal_gpio_status_t HAL_GpioGetInput ( hal_gpio_handle_t gpioHandle,


uint8_t ∗ pinState )

This function gets the pin voltage. 0 - low level voltage, 1 - high level voltage.
Parameters

gpioHandle gpio handle pointer.


pinState A pointer to save the pin state.

MCUXpresso SDK API Reference Manual


910 NXP Semiconductors
Function Documentation

Return values

kStatus_HAL_Gpio- Get successfully.


Success

41.6.4 hal_gpio_status_t HAL_GpioSetOutput ( hal_gpio_handle_t gpioHandle,


uint8_t pinState )

This function sets the pin voltage. 0 - low level voltage, 1 - high level voltage.
Parameters

gpioHandle GPIO handle pointer.


pinState Pin state.

Return values

kStatus_HAL_Gpio- Set successfully.


Success

41.6.5 hal_gpio_status_t HAL_GpioGetTriggerMode ( hal_gpio_handle_t


gpioHandle, hal_gpio_interrupt_trigger_t ∗ gpioTrigger )

This function gets the pin interrupt trigger mode. The trigger mode please refer to hal_gpio_interrupt_-
trigger_t.
Parameters

gpioHandle GPIO handle pointer.


gpioTrigger A pointer to save the pin trigger mode value.

Return values

kStatus_HAL_Gpio- Get successfully.


Success

MCUXpresso SDK API Reference Manual


NXP Semiconductors 911
Function Documentation

kStatus_HAL_GpioError The pin is the ouput setting.

41.6.6 hal_gpio_status_t HAL_GpioSetTriggerMode ( hal_gpio_handle_t


gpioHandle, hal_gpio_interrupt_trigger_t gpioTrigger )

This function sets the pin interrupt trigger mode. The trigger mode please refer to hal_gpio_interrupt_-
trigger_t.
Parameters

gpioHandle GPIO handle pointer.


gpioTrigger The pin trigger mode value.

Return values

kStatus_HAL_Gpio- Set successfully.


Success
kStatus_HAL_GpioError The pin is the ouput setting.

41.6.7 hal_gpio_status_t HAL_GpioInstallCallback ( hal_gpio_handle_t gpioHandle,


hal_gpio_callback_t callback, void ∗ callbackParam )

This function is used to install the callback and callback parameter for GPIO module. When the pin state
interrupt happened, the driver will notify the upper layer by the installed callback function. After the
callback called, the GPIO pin state can be got by calling function HAL_GpioGetInput.
Parameters

gpioHandle GPIO handle pointer.


callback The callback function.
callbackParam The parameter of the callback function.

Return values

kStatus_HAL_Gpio- Successfully install the callback.


Success

MCUXpresso SDK API Reference Manual


912 NXP Semiconductors
Function Documentation

41.6.8 hal_gpio_status_t HAL_GpioWakeUpSetting ( hal_gpio_handle_t


gpioHandle, uint8_t enable )

This function enables or disables the GPIO wake-up feature.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 913
Function Documentation

Parameters

gpioHandle GPIO handle pointer.


enable enable or disable (0 - disable, 1 - enable).

Return values

kStatus_HAL_GpioError An error occurred.


kStatus_HAL_Gpio- Set successfully.
Success

41.6.9 hal_gpio_status_t HAL_GpioEnterLowpower ( hal_gpio_handle_t


gpioHandle )

This function is used to prepare to enter low power consumption.


Parameters

gpioHandle GPIO handle pointer.

Return values

kStatus_HAL_Gpio- Successful operation.


Success

41.6.10 hal_gpio_status_t HAL_GpioExitLowpower ( hal_gpio_handle_t gpioHandle


)

This function is used to restore from low power consumption.


Parameters

gpioHandle GPIO handle pointer.

Return values

MCUXpresso SDK API Reference Manual


914 NXP Semiconductors
Function Documentation

kStatus_HAL_Gpio- Successful operation.


Success

MCUXpresso SDK API Reference Manual


NXP Semiconductors 915
Function Documentation

MCUXpresso SDK API Reference Manual


916 NXP Semiconductors
Chapter 42
LED
42.1 Overview
Data Structures
• struct led_pin_config_t
The pin config struct of LED. More...
• struct led_rgb_config_t
The pin config struct of rgb LED. More...
• struct led_monochrome_config_t
The pin config struct of monochrome LED. More...
• struct led_config_t
The config struct of LED. More...
• struct led_flash_config_t
The flash config struct of LED. More...

Macros
• #define LED_DIMMING_ENABLEMENT (0U)
Definition to determine whether enable dimming.
• #define LED_HANDLE_SIZE ((16U ∗ 3U) + 36U)
Definition of LED handle size.
• #define LED_TIMER_INTERVAL (100U)
Definition of LED timer interval,unit is ms.
• #define LED_DIMMING_UPDATE_INTERVAL (100U)
Definition of LED dimming update interval,unit is ms.
• #define LED_FLASH_CYCLE_FOREVER (0xFFFFFFFFU)
Definition of LED flash cycle forever.
• #define LED_BLIP_INTERVAL (250U)
Definition of LED blip interval,unit is ms.
• #define LED_MAKE_COLOR(r, g, b) ((led_color_t)((((led_color_t)b) << 16) | (((led_color_t)g)
<< 8) | ((led_color_t)r)))
Definition to set LED color.

Typedefs
• typedef void ∗ led_handle_t
The handle of LED.
• typedef uint32_t led_color_t
The color struct of LED.

Enumerations
• enum led_status_t {
kStatus_LED_Success = kStatus_Success,
kStatus_LED_Error = MAKE_STATUS(kStatusGroup_LED, 1),

MCUXpresso SDK API Reference Manual


NXP Semiconductors 917
Overview

kStatus_LED_InvalidParameter = MAKE_STATUS(kStatusGroup_LED, 2) }
The status type of LED.
• enum led_flash_type_t {
kLED_FlashOneColor = 0x00U,
kLED_FlashColorWheel }
The flash type of LED.
• enum _led_color {
kLED_Black = LED_MAKE_COLOR(0, 0, 0),
kLED_Red = LED_MAKE_COLOR(255, 0, 0),
kLED_Green = LED_MAKE_COLOR(0, 255, 0),
kLED_Yellow = LED_MAKE_COLOR(255, 255, 0),
kLED_Blue = LED_MAKE_COLOR(0, 0, 255),
kLED_Pink = LED_MAKE_COLOR(255, 0, 255),
kLED_Aquamarine = LED_MAKE_COLOR(0, 255, 255),
kLED_White = LED_MAKE_COLOR(255, 255, 255) }
The color type of LED.
• enum led_type_t {
kLED_TypeRgb = 0x01U,
kLED_TypeMonochrome = 0x02U }
The type of LED.

Functions
• led_status_t LED_Init (led_handle_t ledHandle, led_config_t ∗ledConfig)
Initializes a LED with the LED handle and the user configuration structure.
• led_status_t LED_Deinit (led_handle_t ledHandle)
Deinitializes a LED instance.
• led_status_t LED_SetColor (led_handle_t ledHandle, led_color_t ledRgbColor)
Sets the LED color.
• led_status_t LED_TurnOnOff (led_handle_t ledHandle, uint8_t turnOnOff)
Turns on or off the LED.
• led_status_t LED_Blip (led_handle_t ledHandle)
Blips the LED.
• led_status_t LED_Flash (led_handle_t ledHandle, led_flash_config_t ∗ledFlash)
Flashes the LED.
• led_status_t LED_Dimming (led_handle_t ledHandle, uint16_t dimmingPeriod, uint8_t increase-
ment)
Adjusts the brightness of the LED.
• led_status_t LED_EnterLowpower (led_handle_t ledHandle)
Prepares to enter low power consumption.
• led_status_t LED_ExitLowpower (led_handle_t ledHandle)
Restores from low power consumption.

MCUXpresso SDK API Reference Manual


918 NXP Semiconductors
Data Structure Documentation

42.2 Data Structure Documentation


42.2.1 struct led_pin_config_t

Data Fields

• uint8_t dimmingEnable
dimming enable, 0 - disable, 1 - enable
• uint8_t port
GPIO Port.
• uint8_t pin
GPIO Pin.
• uint8_t pinStateDefault
GPIO Pin voltage when LED is off (0 - low level, 1 - high level)
• uint32_t sourceClock
The clock source of the PWM module.
• uint8_t instance
PWM instance of the pin.
• uint8_t channel
PWM channel of the pin.

42.2.1.0.0.1 Field Documentation

42.2.1.0.0.1.1 uint8_t led_pin_config_t::pinStateDefault

The Pin voltage when LED is off (0 - low level, 1 - high level)

42.2.2 struct led_rgb_config_t

Data Fields

• led_pin_config_t redPin
Red pin setting.
• led_pin_config_t greenPin
Green pin setting.
• led_pin_config_t bluePin
Blue pin setting.

42.2.3 struct led_monochrome_config_t

Data Fields

• led_pin_config_t monochromePin
Monochrome pin setting.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 919
Macro Definition Documentation

42.2.4 struct led_config_t

42.2.5 struct led_flash_config_t

Data Fields

• uint32_t times
Flash times, LED_FLASH_CYCLE_FOREVER for forever.
• uint16_t period
Flash period, unit is ms.
• led_flash_type_t flashType
Flash type, one color or color wheel.
• uint8_t duty
Duty of the LED on for one period (duration = duty ∗ period / 100).

42.2.5.0.0.2 Field Documentation

42.2.5.0.0.2.1 led_flash_type_t led_flash_config_t::flashType

Refer to led_flash_type_t

42.2.5.0.0.2.2 uint8_t led_flash_config_t::duty

42.3 Macro Definition Documentation


42.3.1 #define LED_DIMMING_ENABLEMENT (0U)

Enable or disable the dimming feature

42.3.2 #define LED_HANDLE_SIZE ((16U ∗ 3U) + 36U)

42.3.3 #define LED_TIMER_INTERVAL (100U)

42.3.4 #define LED_DIMMING_UPDATE_INTERVAL (100U)

42.3.5 #define LED_FLASH_CYCLE_FOREVER (0xFFFFFFFFU)

42.3.6 #define LED_BLIP_INTERVAL (250U)

42.3.7 #define LED_MAKE_COLOR( r, g, b ) ((led_color_t)((((led_color_t)b) <<


16) | (((led_color_t)g) << 8) | ((led_color_t)r)))

MCUXpresso SDK API Reference Manual


920 NXP Semiconductors
Function Documentation

42.4 Enumeration Type Documentation


42.4.1 enum led_status_t

Enumerator
kStatus_LED_Success Success.
kStatus_LED_Error Failed.
kStatus_LED_InvalidParameter Invalid parameter.

42.4.2 enum led_flash_type_t

Enumerator
kLED_FlashOneColor Fast with one color.
kLED_FlashColorWheel Fast with color wheel.

42.4.3 enum _led_color

Enumerator
kLED_Black Black.
kLED_Red Red.
kLED_Green Green.
kLED_Yellow Yellow.
kLED_Blue Blue.
kLED_Pink Pink.
kLED_Aquamarine Aquamarine.
kLED_White White.

42.4.4 enum led_type_t

Enumerator
kLED_TypeRgb RGB LED.
kLED_TypeMonochrome Monochrome LED.

42.5 Function Documentation


42.5.1 led_status_t LED_Init ( led_handle_t ledHandle, led_config_t ∗ ledConfig )

This function configures the LED with user-defined settings. The user can configure the configuration
structure. The parameter ledHandle is a pointer to point to a memory space of size LED_HANDLE_S-
IZE allocated by the caller. The LED supports two types LED, RGB and monochrome. Please refer to

MCUXpresso SDK API Reference Manual


NXP Semiconductors 921
Function Documentation

led_type_t. These two types can be set by using led_config_t. The LED also supports LED dimming
mode.
Example below shows how to use this API to configure the LED. For monochrome LED,

* uint8_t s_ledMonochromeHandleBuffer[LED_HANDLE_SIZE];
* led_handle_t s_ledMonochromeHandle = &s_ledMonochromeHandleBuffer[0];
* led_config_t ledMonochromeConfig;
* ledMonochromeConfig.type = kLED_TypeMonochrome;
* ledMonochromeConfig.ledMonochrome.monochromePin.
dimmingEnable = 0;
* ledMonochromeConfig.ledMonochrome.monochromePin.gpio.port = 0;
* ledMonochromeConfig.ledMonochrome.monochromePin.gpio.pin = 1;
* ledMonochromeConfig.ledMonochrome.monochromePin.gpio.pinStateDefault = 0;
* LED_Init(s_ledMonochromeHandle, &ledMonochromeConfig);
*

For rgb LED,

* uint8_t s_ledRgbHandleBuffer[LED_HANDLE_SIZE];
* led_handle_t s_ledRgbHandle = &s_ledRgbHandleBuffer[0];
* led_config_t ledRgbConfig;
* ledRgbConfig.type = kLED_TypeRgb;
* ledRgbConfig.ledRgb.redPin.dimmingEnable = 0;
* ledRgbConfig.ledRgb.redPin.gpio.port = 0;
* ledRgbConfig.ledRgb.redPin.gpio.pin = 1;
* ledRgbConfig.ledRgb.redPin.gpio.pinStateDefault = 0;
* ledRgbConfig.ledRgb.greenPin.dimmingEnable = 0;
* ledRgbConfig.ledRgb.greenPin.gpio.port = 0;
* ledRgbConfig.ledRgb.greenPin.gpio.pin = 2;
* ledRgbConfig.ledRgb.greenPin.gpio.pinStateDefault = 0;
* ledRgbConfig.ledRgb.bluePin.dimmingEnable = 0;
* ledRgbConfig.ledRgb.bluePin.gpio.port = 0;
* ledRgbConfig.ledRgb.bluePin.gpio.pin = 3;
* ledRgbConfig.ledRgb.bluePin.gpio.pinStateDefault = 0;
* LED_Init(s_ledRgbHandle, &ledRgbConfig);
*

For dimming monochrome LED,

* uint8_t s_ledMonochromeHandleBuffer[LED_HANDLE_SIZE];
* led_handle_t s_ledMonochromeHandle = &s_ledMonochromeHandleBuffer[0];
* led_config_t ledMonochromeConfig;
* ledMonochromeConfig.type = kLED_TypeMonochrome;
* ledMonochromeConfig.ledMonochrome.monochromePin.
dimmingEnable = 1;
* ledMonochromeConfig.ledMonochrome.monochromePin.dimming.sourceClock =
48000000;
* ledMonochromeConfig.ledMonochrome.monochromePin.dimming.instance = 0;
* ledMonochromeConfig.ledMonochrome.monochromePin.dimming.channel = 1;
* ledMonochromeConfig.ledMonochrome.monochromePin.dimming.pinStateDefault = 0;
* LED_Init(s_ledMonochromeHandle, &ledMonochromeConfig);
*

MCUXpresso SDK API Reference Manual


922 NXP Semiconductors
Function Documentation

Parameters

ledHandle Pointer to point to a memory space of size LED_HANDLE_SIZE allocated by the


caller.
ledConfig Pointer to user-defined configuration structure.

Return values

kStatus_LED_Error An error occurred.


kStatus_LED_Success LED initialization succeed.

42.5.2 led_status_t LED_Deinit ( led_handle_t ledHandle )

This function deinitializes the LED instance.


Parameters

ledHandle LED handle pointer.

Return values

kStatus_LED_Success LED de-initialization succeed.

42.5.3 led_status_t LED_SetColor ( led_handle_t ledHandle, led_color_t


ledRgbColor )

This function sets the LED color. The function only supports the RGB LED. The default color is kLED_-
White. Please refer to LED_MAKE_COLOR(r,g,b).
Parameters

ledHandle LED handle pointer.


ledRgbColor LED color.

Return values

MCUXpresso SDK API Reference Manual


NXP Semiconductors 923
Function Documentation

kStatus_LED_Error An error occurred.


kStatus_LED_Success Color setting succeed.

42.5.4 led_status_t LED_TurnOnOff ( led_handle_t ledHandle, uint8_t turnOnOff )

This function turns on or off the led.


Parameters

ledHandle LED handle pointer.


turnOnOff Setting value, 1 - turns on, 0 - turns off.

Return values

kStatus_LED_Error An error occurred.


kStatus_LED_Success Successfully turn on or off the LED.

42.5.5 led_status_t LED_Blip ( led_handle_t ledHandle )

This function blips the led.


Parameters

ledHandle LED handle pointer.

Return values

kStatus_LED_Error An error occurred.


kStatus_LED_Success Successfully blip the LED.

42.5.6 led_status_t LED_Flash ( led_handle_t ledHandle, led_flash_config_t ∗


ledFlash )

This function flashes the led. The flash configuration is passed by using led_flash_config_t.

MCUXpresso SDK API Reference Manual


924 NXP Semiconductors
Function Documentation

Parameters

ledHandle LED handle pointer.


ledFlash LED flash configuration.

Return values

kStatus_LED_Error An error occurred.


kStatus_LED_Success Successfully flash the LED.

42.5.7 led_status_t LED_Dimming ( led_handle_t ledHandle, uint16_t


dimmingPeriod, uint8_t increasement )

This function adjust the brightness of the LED.


Parameters

ledHandle LED handle pointer.


dimmingPeriod The duration of the dimming (unit is ms).
increasement Brighten or dim (1 - brighten, 0 - dim).

Return values

kStatus_LED_Error An error occurred.


kStatus_LED_Success Successfully adjust the brightness of the LED.

42.5.8 led_status_t LED_EnterLowpower ( led_handle_t ledHandle )

This function is used to prepare to enter low power consumption.


Parameters

ledHandle LED handle pointer.

Return values

MCUXpresso SDK API Reference Manual


NXP Semiconductors 925
Function Documentation

kStatus_LED_Success Successful operation.

42.5.9 led_status_t LED_ExitLowpower ( led_handle_t ledHandle )

This function is used to restore from low power consumption.


Parameters

ledHandle LED handle pointer.

Return values

kStatus_LED_Success Successful operation.

MCUXpresso SDK API Reference Manual


926 NXP Semiconductors
Chapter 43
GenericList
43.1 Overview
Data Structures
• struct list_handle_t
The list structure. More...
• struct list_element_handle_t
The list element. More...

Enumerations
• enum list_status_t {
kLIST_Ok = kStatus_Success,
kLIST_DuplicateError = MAKE_STATUS(kStatusGroup_LIST, 1),
kLIST_Full = MAKE_STATUS(kStatusGroup_LIST, 2),
kLIST_Empty = MAKE_STATUS(kStatusGroup_LIST, 3),
kLIST_OrphanElement = MAKE_STATUS(kStatusGroup_LIST, 4) }

Functions
• void LIST_Init (list_handle_t list, uint32_t max)

• list_handle_t LIST_GetList (list_element_handle_t element)


Gets the list that contains the given element.
• list_status_t LIST_AddHead (list_handle_t list, list_element_handle_t element)
Links element to the head of the list.
• list_status_t LIST_AddTail (list_handle_t list, list_element_handle_t element)
Links element to the tail of the list.
• list_element_handle_t LIST_RemoveHead (list_handle_t list)
Unlinks element from the head of the list.
• list_element_handle_t LIST_GetHead (list_handle_t list)
Gets head element handle.
• list_element_handle_t LIST_GetNext (list_element_handle_t element)
Gets next element handle for given element handle.
• list_element_handle_t LIST_GetPrev (list_element_handle_t element)
Gets previous element handle for given element handle.
• list_status_t LIST_RemoveElement (list_element_handle_t element)
Unlinks an element from its list.
• list_status_t LIST_AddPrevElement (list_element_handle_t element, list_element_handle_t new-
Element)
Links an element in the previous position relative to a given member of a list.
• uint32_t LIST_GetSize (list_handle_t list)
Gets the current size of a list.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 927
Enumeration Type Documentation

• uint32_t LIST_GetAvailableSize (list_handle_t list)


Gets the number of free places in the list.

43.2 Data Structure Documentation


43.2.1 struct list_t

Data Fields

• struct list_element_tag ∗ head


list head
• struct list_element_tag ∗ tail
list tail
• uint16_t size
list size
• uint16_t max
list max number of elements

43.2.2 struct list_element_t

Data Fields

• struct list_element_tag ∗ next


next list element
• struct list_element_tag ∗ prev
previous list element
• struct list_tag ∗ list
pointer to the list

43.3 Enumeration Type Documentation


43.3.1 enum list_status_t

Include
Public macro definitions
Public type definitions
The list status

Enumerator
kLIST_Ok Success.
kLIST_DuplicateError Duplicate Error.
kLIST_Full FULL.
kLIST_Empty Empty.
kLIST_OrphanElement Orphan Element.

MCUXpresso SDK API Reference Manual


928 NXP Semiconductors
Function Documentation

43.4 Function Documentation


43.4.1 void LIST_Init ( list_handle_t list, uint32_t max )

Public prototypes
Initialize the list.
This function initialize the list.
Parameters

list - List handle to initialize.


max - Maximum number of elements in list. 0 for unlimited.

43.4.2 list_handle_t LIST_GetList ( list_element_handle_t element )

Parameters

element - Handle of the element.

Return values

NULL if element is orphan, Handle of the list the element is inserted into.

43.4.3 list_status_t LIST_AddHead ( list_handle_t list, list_element_handle_t


element )

Parameters

list - Handle of the list.


element - Handle of the element.

Return values

kLIST_Full if list is full, kLIST_Ok if insertion was successful.

43.4.4 list_status_t LIST_AddTail ( list_handle_t list, list_element_handle_t


element )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 929
Function Documentation

Parameters

list - Handle of the list.


element - Handle of the element.

Return values

kLIST_Full if list is full, kLIST_Ok if insertion was successful.

43.4.5 list_element_handle_t LIST_RemoveHead ( list_handle_t list )

Parameters

list - Handle of the list.

Return values

NULL if list is empty, handle of removed element(pointer) if removal was suc-


cessful.

43.4.6 list_element_handle_t LIST_GetHead ( list_handle_t list )

Parameters

list - Handle of the list.

Return values

NULL if list is empty, handle of removed element(pointer) if removal was suc-


cessful.

43.4.7 list_element_handle_t LIST_GetNext ( list_element_handle_t element )

Parameters

MCUXpresso SDK API Reference Manual


930 NXP Semiconductors
Function Documentation

element - Handle of the element.

Return values

NULL if list is empty, handle of removed element(pointer) if removal was suc-


cessful.

43.4.8 list_element_handle_t LIST_GetPrev ( list_element_handle_t element )

Parameters

element - Handle of the element.

Return values

NULL if list is empty, handle of removed element(pointer) if removal was suc-


cessful.

43.4.9 list_status_t LIST_RemoveElement ( list_element_handle_t element )

Parameters

element - Handle of the element.

Return values

kLIST_OrphanElement if element is not part of any list.


kLIST_Ok if removal was successful.

43.4.10 list_status_t LIST_AddPrevElement ( list_element_handle_t element,


list_element_handle_t newElement )

Parameters

MCUXpresso SDK API Reference Manual


NXP Semiconductors 931
Function Documentation

element - Handle of the element.


newElement - New element to insert before the given member.

Return values

kLIST_OrphanElement if element is not part of any list.


kLIST_Ok if removal was successful.

43.4.11 uint32_t LIST_GetSize ( list_handle_t list )

Parameters

list - Handle of the list.

Return values

Current size of the list.

43.4.12 uint32_t LIST_GetAvailableSize ( list_handle_t list )

Parameters

list - Handle of the list.

Return values

Available size of the list.

MCUXpresso SDK API Reference Manual


932 NXP Semiconductors
Chapter 44
Panic
44.1 Overview
Data Structures
• struct panic_data_t
panic data structure. More...

Macros
• #define PANIC_ENABLE_LOG (1)

Typedefs
• typedef uint32_t panic_id_t

Functions
• void panic (panic_id_t id, uint32_t location, uint32_t extra1, uint32_t extra2)

44.2 Data Structure Documentation


44.2.1 struct panic_data_t

44.3 Macro Definition Documentation


44.3.1 #define PANIC_ENABLE_LOG (1)

Public macros

44.4 Typedef Documentation


44.4.1 typedef uint32_t panic_id_t

Include
Public type definitionspanic id.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 933
Function Documentation

44.5 Function Documentation


44.5.1 void panic ( panic_id_t id, uint32_t location, uint32_t extra1, uint32_t
extra2 )

Public prototypes
Panic function.
Parameters

id Panic ID
location location address where the Panic occurred
extra1 extra1 parameter to be stored in Panic structure.
extra1 extra2 parameter to be stored in Panic structure

Return values

No return vaule.

MCUXpresso SDK API Reference Manual


934 NXP Semiconductors
Chapter 45
Timer_Adapter
45.1 Overview
Data Structures
• struct hal_timer_config_t
HAL timer configuration structure for HAL timer setting. More...

Typedefs
• typedef void(∗ hal_timer_callback_t )(void ∗param)
The timer adapter component.
• typedef void ∗ hal_timer_handle_t
HAL timer handle.

Enumerations
• enum hal_timer_status_t {
kStatus_HAL_TimerSuccess = kStatus_Success,
kStatus_HAL_TimerNotSupport = MAKE_STATUS(kStatusGroup_HAL_TIMER, 1),
kStatus_HAL_TimerIsUsed = MAKE_STATUS(kStatusGroup_HAL_TIMER, 2),
kStatus_HAL_TimerInvalid = MAKE_STATUS(kStatusGroup_HAL_TIMER, 3),
kStatus_HAL_TimerOutOfRanger = MAKE_STATUS(kStatusGroup_HAL_TIMER, 4) }
HAL timer status.

Functions
• hal_timer_status_t HAL_TimerInit (hal_timer_handle_t halTimerHandle, hal_timer_config_t ∗hal-
TimerConfig)
Initializes the timer adapter module for a timer basic operation.
• void HAL_TimerDeinit (hal_timer_handle_t halTimerHandle)
DeInitilizate the timer adapter module.
• void HAL_TimerEnable (hal_timer_handle_t halTimerHandle)
Enable the timer adapter module.
• void HAL_TimerDisable (hal_timer_handle_t halTimerHandle)
Disable the timer adapter module.
• void HAL_TimerInstallCallback (hal_timer_handle_t halTimerHandle, hal_timer_callback_t call-
back, void ∗callbackParam)
Install the timer adapter module callback function.
• uint32_t HAL_TimerGetCurrentTimerCount (hal_timer_handle_t halTimerHandle)
Get the timer count of the timer adapter.
• hal_timer_status_t HAL_TimerUpdateTimeout (hal_timer_handle_t halTimerHandle, uint32_-
t timeout)
Update the timeout of the timer adapter to generate timeout interrupt.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 935
Typedef Documentation

• uint32_t HAL_TimerGetMaxTimeout (hal_timer_handle_t halTimerHandle)


Get maximum Timer timeout.
• void HAL_TimerExitLowpower (hal_timer_handle_t halTimerHandle)
Timer adapter power up function.
• void HAL_TimerEnterLowpower (hal_timer_handle_t halTimerHandle)
Timer adapter power down function.

45.2 Data Structure Documentation


45.2.1 struct hal_timer_config_t

Data Fields

• uint32_t timeout
Timeout of the timer, should use microseconds, for example: if set timeout to 1000, mean 1000 microsec-
onds interval would generate timer timeout interrupt.
• uint32_t srcClock_Hz
Source clock of the timer.
• uint8_t instance
Hardware timer module instance, for example: if you want use FTM0,then the instance is configured to 0,
if you want use FTM2 hardware timer, then configure the instance to 2, detail information please refer to
the SOC corresponding RM.Invalid instance value will cause initialization failure.

45.2.1.0.0.3 Field Documentation

45.2.1.0.0.3.1 uint8_t hal_timer_config_t::instance

45.3 Typedef Documentation


45.3.1 typedef void(∗ hal_timer_callback_t)(void ∗param)

The timer adapter is built based on the timer SDK driver provided by the NXP MCUXpresso SDK. The
timer adapter could provide high accuracy timer for user. Since callback function would be handled in
ISR, and timer clock use high accuracy clock, user can get accuracy millisecond timer.
The timer adapter would be used with different HW timer modules like FTM, PIT, LPTMR. But at the
same time, only one HW timer module could be used. On different platforms, different HW timer module
would be used. For the platforms which have multiple HW timer modules, one HW timer module would
be selected as the default, but it is easy to change the default HW timer module to another. Just two steps
to switch the HW timer module: 1.Remove the default HW timer module source file from the project
2.Add the expected HW timer module source file to the project. For example, in platform FRDM-K64F,
there are two HW timer modules available, FTM and PIT. FTM is used as the default HW timer, so ftm_-
adapter.c and timer.h is included in the project by default. If PIT is expected to be used as the HW timer,
ftm_adapter.c need to be removed from the project and pit_adapter.c should be included in the project
HAL timer callback function.

MCUXpresso SDK API Reference Manual


936 NXP Semiconductors
Function Documentation

45.3.2 typedef void∗ hal_timer_handle_t

45.4 Enumeration Type Documentation


45.4.1 enum hal_timer_status_t

Enumerator
kStatus_HAL_TimerSuccess Success.
kStatus_HAL_TimerNotSupport Not Support.
kStatus_HAL_TimerIsUsed timer is used
kStatus_HAL_TimerInvalid timer is invalid
kStatus_HAL_TimerOutOfRanger timer is Out Of Ranger

45.5 Function Documentation


45.5.1 hal_timer_status_t HAL_TimerInit ( hal_timer_handle_t halTimerHandle,
hal_timer_config_t ∗ halTimerConfig )

Note
This API should be called at the beginning of the application using the timer adapter. For Initializes
timer adapter,
* uint8_t halTimerHandle[HAL_TIMER_HANDLE_SIZE];
* hal_timer_config_t halTimerConfig;
* halTimerConfig.timeout = 1000;
* halTimerConfig.srcClock_Hz = BOARD_GetTimeSrcClock();
* halTimerConfig.instance = 0;
* HAL_TimerInit((hal_timer_handle_t)&halTimerHandle, &halTimerConfig);
*

Parameters

halTimer- HAL timer adapter handle, the handle buffer with size #HAL_TIMER_HANDLE_S-
Handle IZE should be allocated at upper level
halTimerConfig A pointer to the HAL timer configuration structure

Return values

kStatus_HAL_Timer- The timer adapter module initialization succeed.


Success

MCUXpresso SDK API Reference Manual


NXP Semiconductors 937
Function Documentation

kStatus_HAL_TimerOut- The timer adapter instance out of ranger.


OfRanger

45.5.2 void HAL_TimerDeinit ( hal_timer_handle_t halTimerHandle )

Note
This API should be called when not using the timer adapter anymore.

Parameters

halTimer- HAL timer adapter handle


Handle

45.5.3 void HAL_TimerEnable ( hal_timer_handle_t halTimerHandle )

Note
This API should be called when enable the timer adapter.

Parameters

halTimer- HAL timer adapter handle


Handle

45.5.4 void HAL_TimerDisable ( hal_timer_handle_t halTimerHandle )

Note
This API should be called when disable the timer adapter.

Parameters

halTimer- HAL timer adapter handle


Handle

45.5.5 void HAL_TimerInstallCallback ( hal_timer_handle_t halTimerHandle,


hal_timer_callback_t callback, void ∗ callbackParam )

MCUXpresso SDK API Reference Manual


938 NXP Semiconductors
Function Documentation

Note
This API should be called to when to install callback function for the timer.Since callback function
would be handled in ISR, and timer clock use high accuracy clock, user can get accuracy millisecond
timer.

Parameters

halTimer- HAL timer adapter handle


Handle
callback The installed callback function by upper layer
callbackParam The callback function parameter

45.5.6 uint32_t HAL_TimerGetCurrentTimerCount ( hal_timer_handle_t


halTimerHandle )

Note
This API should be return the real-time timer counting value in a range from 0 to a timer period, and
return microseconds.

Parameters

halTimer- HAL timer adapter handle


Handle

Return values

the real-time timer counting value and return microseconds.

45.5.7 hal_timer_status_t HAL_TimerUpdateTimeout ( hal_timer_handle_t


halTimerHandle, uint32_t timeout )

Note
This API should be called when need set the timeout of the timer interrupt..

MCUXpresso SDK API Reference Manual


NXP Semiconductors 939
Function Documentation

Parameters

halTimer- HAL timer adapter handle


Handle
Timeout Timeout time, should be used microseconds.

Return values

kStatus_HAL_Timer- The timer adapter module update timeout succeed.


Success
kStatus_HAL_TimerOut- The timer adapter set the timeout out of ranger.
OfRanger

45.5.8 uint32_t HAL_TimerGetMaxTimeout ( hal_timer_handle_t halTimerHandle )

Note
This API should to get maximum Timer timeout value to avoid overflow

Parameters

halTimer- HAL timer adapter handle


Handle

Return values

get the real-time timer maximum timeout value and return microseconds.

45.5.9 void HAL_TimerExitLowpower ( hal_timer_handle_t halTimerHandle )

Note
This API should be called by low power module when system exit from sleep mode.

Parameters

MCUXpresso SDK API Reference Manual


940 NXP Semiconductors
Function Documentation

halTimer- HAL timer adapter handle


Handle

45.5.10 void HAL_TimerEnterLowpower ( hal_timer_handle_t halTimerHandle )

Note
This API should be called by low power module before system enter into sleep mode.

Parameters

halTimer- HAL timer adapter handle


Handle

MCUXpresso SDK API Reference Manual


NXP Semiconductors 941
Function Documentation

MCUXpresso SDK API Reference Manual


942 NXP Semiconductors
Chapter 46
Manager
46.1 Overview
Data Structures
• struct timer_config_t
Timer config. More...

Macros
• #define TM_COMMON_TASK_ENABLE (1)
The timer manager component.

Enumerations
• enum timer_status_t {
kStatus_TimerSuccess = kStatus_Success,
kStatus_TimerInvalidId = MAKE_STATUS(kStatusGroup_TIMERMANAGER, 1),
kStatus_TimerNotSupport = MAKE_STATUS(kStatusGroup_TIMERMANAGER, 2),
kStatus_TimerOutOfRange = MAKE_STATUS(kStatusGroup_TIMERMANAGER, 3),
kStatus_TimerError = MAKE_STATUS(kStatusGroup_TIMERMANAGER, 4) }
Timer status.
• enum timer_mode_t {
kTimerModeSingleShot = 0x01U,
kTimerModeIntervalTimer = 0x02U,
kTimerModeSetMinuteTimer = 0x04U,
kTimerModeSetSecondTimer = 0x08U,
kTimerModeLowPowerTimer = 0x10U }
Timer modes.

Functions
• timer_status_t TM_Init (timer_config_t ∗timerConfig)
Initializes timer manager module with the user configuration structure.
• void TM_Deinit (void)
Deinitialize timer manager module.
• void TM_ExitLowpower (void)
Power up timer manager module.
• void TM_EnterLowpower (void)
Power down timer manager module.
• timer_status_t TM_Open (timer_handle_t timerHandle)
Open a timer with user handle.
• timer_status_t TM_Close (timer_handle_t timerHandle)
Close a timer with user handle.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 943
Data Structure Documentation

• timer_status_t TM_InstallCallback (timer_handle_t timerHandle, timer_callback_t callback, void


∗callbackParam)
Install a specified timer callback.
• timer_status_t TM_Start (timer_handle_t timerHandle, timer_mode_t timerType, uint32_t timer-
Timeout)
Start a specified timer.
• timer_status_t TM_Stop (timer_handle_t timerHandle)
Stop a specified timer.
• uint8_t TM_IsTimerActive (timer_handle_t timerHandle)
Check if a specified timer is active.
• uint8_t TM_IsTimerReady (timer_handle_t timerHandle)
Check if a specified timer is ready.
• uint32_t TM_GetRemainingTime (timer_handle_t timerHandle)
Returns the remaining time until timeout.
• uint32_t TM_GetFirstExpireTime (uint8_t timerType)
Get the first expire time of timer.
• timer_handle_t TM_GetFirstTimerWithParam (void ∗param)
Returns the handle of the timer of the first allocated timer that has the specified parameter.
• uint8_t TM_AreAllTimersOff (void)
Check if all timers except the LP timers are OFF.
• uint32_t TM_NotCountedTimeBeforeSleep (void)
Returns not counted time before system entering in sleep, This function is called by Low Power module.
• void TM_SyncLpmTimers (uint32_t sleepDurationTmrUs)
Sync low power timer in sleep mode, This function is called by Low Power module;.
• void TM_MakeTimerTaskReady (void)
Make timer task ready after wakeup from lowpower mode, This function is called by Low Power module;.

46.2 Data Structure Documentation


46.2.1 struct timer_config_t

Data Fields

• uint32_t srcClock_Hz
• uint8_t instance
Hardware timer module instance, for example: if you want use FTM0,then the instance is configured to 0,
if you want use FTM2 hardware timer, then configure the instance to 2, detail information please refer to
the SOC corresponding RM.

46.2.1.0.0.4 Field Documentation

46.2.1.0.0.4.1 uint32_t timer_config_t::srcClock_Hz

The timer source clock.

46.2.1.0.0.4.2 uint8_t timer_config_t::instance

Invalid instance value will cause initialization failure.

MCUXpresso SDK API Reference Manual


944 NXP Semiconductors
Function Documentation

46.3 Macro Definition Documentation


46.3.1 #define TM_COMMON_TASK_ENABLE (1)

The timer manager is built based on the timer adapter component provided by the NXP MCUXpresso
SDK. It could provide bellow features: shall support SingleShot,repeater,one minute timer,one second
timer and low power mode shall support timer open ,close, start and stop operation, and support callback
function install And provide 1ms accuracy timers
The timer manager would be used with different HW timer modules like FTM, PIT, LPTMR. But at the
same time, only one HW timer module could be used. On different platforms,different HW timer module
would be used. For the platforms which have multiple HW timer modules, one HW timer module would
be selected as the default, but it is easy to change the default HW timer module to another. Just two steps
to switch the HW timer module: 1.Remove the default HW timer module source file from the project
2.Add the expected HW timer module source file to the project. For example, in platform FRDM-K64F,
there are two HW timer modules available, FTM and PIT. FTM is used as the default HW timer, so ftm_-
adapter.c and timer.h is included in the project by default.If PIT is expected to be used as the HW timer,
ftm_adapter.c need to be removed from the project and pit_adapter.c should be included in the project

46.4 Enumeration Type Documentation


46.4.1 enum timer_status_t

Enumerator
kStatus_TimerSuccess Success.
kStatus_TimerInvalidId Invalid Id.
kStatus_TimerNotSupport Not Support.
kStatus_TimerOutOfRange Out Of Range.
kStatus_TimerError Fail.

46.4.2 enum timer_mode_t

Enumerator
kTimerModeSingleShot The timer will expire only once.
kTimerModeIntervalTimer The timer will restart each time it expires.
kTimerModeSetMinuteTimer The timer will one minute timer.
kTimerModeSetSecondTimer The timer will one second timer.
kTimerModeLowPowerTimer The timer will low power mode timer.

46.5 Function Documentation


46.5.1 timer_status_t TM_Init ( timer_config_t ∗ timerConfig )

For Initializes timer manager,

MCUXpresso SDK API Reference Manual


NXP Semiconductors 945
Function Documentation

* timer_config_t timerConfig;
* timerConfig.instance = 0;
* timerConfig.srcClock_Hz = BOARD_GetTimerSrcClock();
* TM_Init(&timerConfig);
*

Parameters

timerConfig Pointer to user-defined timer configuration structure.

Return values

kStatus_TimerSuccess Timer manager initialization succeed.


kStatus_TimerError An error occurred.

46.5.2 timer_status_t TM_Open ( timer_handle_t timerHandle )

Parameters

timerHandle Pointer to a memory space of size #TIMER_HANDLE_SIZE allocated by the caller.

Return values

kStatus_TimerSuccess Timer open succeed.


kStatus_TimerError An error occurred.

46.5.3 timer_status_t TM_Close ( timer_handle_t timerHandle )

Parameters

timerHandle the handle of the timer

Return values

kStatus_TimerSuccess Timer close succeed.


kStatus_TimerError An error occurred.

46.5.4 timer_status_t TM_InstallCallback ( timer_handle_t timerHandle,


timer_callback_t callback, void ∗ callbackParam )

MCUXpresso SDK API Reference Manual


946 NXP Semiconductors
Function Documentation

Parameters

timerHandle the handle of the timer


callback callback function
callbackParam parameter to callback function

Return values

kStatus_TimerSuccess Timer install callback succeed.

46.5.5 timer_status_t TM_Start ( timer_handle_t timerHandle, timer_mode_t


timerType, uint32_t timerTimeout )

Parameters

timerHandle the handle of the timer


timeMode the mode of the timer, for example: kTimerModeSingleShot for the timer will expire
only once, kTimerModeIntervalTimer, the timer will restart each time it expires.
timerTimeout the timer timeout in milliseconds unit for kTimerModeSingleShot, kTimer-
ModeIntervalTimer and kTimerModeLowPowerTimer,if kTimerModeSetMinute-
Timer timeout for minutes unit, if kTimerModeSetSecondTimer the timeout for sec-
onds unit.

Return values

kStatus_TimerSuccess Timer start succeed.


kStatus_TimerError An error occurred.

46.5.6 timer_status_t TM_Stop ( timer_handle_t timerHandle )

Parameters

timerHandle the handle of the timer

MCUXpresso SDK API Reference Manual


NXP Semiconductors 947
Function Documentation

Return values

kStatus_TimerSuccess Timer stop succeed.


kStatus_TimerError An error occurred.

46.5.7 uint8_t TM_IsTimerActive ( timer_handle_t timerHandle )

Parameters

timerHandle the handle of the timer

Return values

return 1 if timer is active, return 0 if timer is not active.

46.5.8 uint8_t TM_IsTimerReady ( timer_handle_t timerHandle )

Parameters

timerHandle the handle of the timer

Return values

return 1 if timer is ready, return 0 if timer is not ready.

46.5.9 uint32_t TM_GetRemainingTime ( timer_handle_t timerHandle )

Parameters

timerHandle the handle of the timer

Return values

remaining time in microseconds until first timer timeouts.

46.5.10 uint32_t TM_GetFirstExpireTime ( uint8_t timerType )

MCUXpresso SDK API Reference Manual


948 NXP Semiconductors
Function Documentation

Parameters

timerHandle the handle of the timer

Return values

return the first expire time of all timer.

46.5.11 timer_handle_t TM_GetFirstTimerWithParam ( void ∗ param )

Parameters

param specified parameter of timer

Return values

return the handle of the timer if success.

46.5.12 uint8_t TM_AreAllTimersOff ( void )

Return values

return 1 there are no active non-low power timers, 0 otherwise.

46.5.13 uint32_t TM_NotCountedTimeBeforeSleep ( void )

Return values

return microseconds that wasn’t counted before entering in sleep.

46.5.14 void TM_SyncLpmTimers ( uint32_t sleepDurationTmrUs )

MCUXpresso SDK API Reference Manual


NXP Semiconductors 949
Function Documentation

Parameters

sleepDuration- sleep duration in microseconds unit


TmrUs

46.5.15 void TM_MakeTimerTaskReady ( void )

MCUXpresso SDK API Reference Manual


950 NXP Semiconductors
Chapter 47
UART_Adapter
47.1 Overview
Data Structures
• struct hal_uart_config_t
UART configuration structure. More...
• struct hal_uart_transfer_t
UART transfer structure. More...

Macros
• #define UART_ADAPTER_NON_BLOCKING_MODE (0U)
Enable or disable UART adapter non-blocking mode (1 - enable, 0 - disable)
• #define HAL_UART_TRANSFER_MODE (0U)
Whether enable transactional function of the UART.

Typedefs
• typedef void(∗ hal_uart_transfer_callback_t )(hal_uart_handle_t handle, hal_uart_status_t status,
void ∗callbackParam)
UART transfer callback function.

Enumerations
• enum hal_uart_status_t {
kStatus_HAL_UartSuccess = kStatus_Success,
kStatus_HAL_UartTxBusy = MAKE_STATUS(kStatusGroup_HAL_UART, 1),
kStatus_HAL_UartRxBusy = MAKE_STATUS(kStatusGroup_HAL_UART, 2),
kStatus_HAL_UartTxIdle = MAKE_STATUS(kStatusGroup_HAL_UART, 3),
kStatus_HAL_UartRxIdle = MAKE_STATUS(kStatusGroup_HAL_UART, 4),
kStatus_HAL_UartBaudrateNotSupport,
kStatus_HAL_UartProtocolError,
kStatus_HAL_UartError = MAKE_STATUS(kStatusGroup_HAL_UART, 7) }
UART status.
• enum hal_uart_parity_mode_t {
kHAL_UartParityDisabled = 0x0U,
kHAL_UartParityEven = 0x1U,
kHAL_UartParityOdd = 0x2U }
UART parity mode.
• enum hal_uart_stop_bit_count_t {
kHAL_UartOneStopBit = 0U,
kHAL_UartTwoStopBit = 1U }
UART stop bit count.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 951
Data Structure Documentation

Initialization and deinitialization


• hal_uart_status_t HAL_UartInit (hal_uart_handle_t handle, hal_uart_config_t ∗config)
Initializes a UART instance with the UART handle and the user configuration structure.
• hal_uart_status_t HAL_UartDeinit (hal_uart_handle_t handle)
Deinitializes a UART instance.

Blocking bus Operations


• hal_uart_status_t HAL_UartReceiveBlocking (hal_uart_handle_t handle, uint8_t ∗data, size_t
length)
Reads RX data register using a blocking method.
• hal_uart_status_t HAL_UartSendBlocking (hal_uart_handle_t handle, const uint8_t ∗data, size_t
length)
Writes to the TX register using a blocking method.

47.2 Data Structure Documentation


47.2.1 struct hal_uart_config_t

Data Fields

• uint32_t srcClock_Hz
Source clock.
• uint32_t baudRate_Bps
Baud rate.
• hal_uart_parity_mode_t parityMode
Parity mode, disabled (default), even, odd.
• hal_uart_stop_bit_count_t stopBitCount
Number of stop bits, 1 stop bit (default) or 2 stop bits.
• uint8_t enableRx
Enable RX.
• uint8_t enableTx
Enable TX.
• uint8_t instance
Instance (0 - UART0, 1 - UART1, ...), detail information please refer to the SOC corresponding RM.

47.2.1.0.0.5 Field Documentation

47.2.1.0.0.5.1 uint8_t hal_uart_config_t::instance

Invalid instance value will cause initialization failure.

47.2.2 struct hal_uart_transfer_t

Data Fields

• uint8_t ∗ data

MCUXpresso SDK API Reference Manual


952 NXP Semiconductors
Enumeration Type Documentation

The buffer of data to be transfer.


• size_t dataSize
The byte count to be transfer.

47.2.2.0.0.6 Field Documentation

47.2.2.0.0.6.1 uint8_t∗ hal_uart_transfer_t::data

47.2.2.0.0.6.2 size_t hal_uart_transfer_t::dataSize

47.3 Macro Definition Documentation


47.3.1 #define HAL_UART_TRANSFER_MODE (0U)

(0 - disable, 1 - enable)

47.4 Typedef Documentation


47.4.1 typedef void(∗ hal_uart_transfer_callback_t)(hal_uart_handle_t handle,
hal_uart_status_t status, void ∗callbackParam)

47.5 Enumeration Type Documentation


47.5.1 enum hal_uart_status_t

Enumerator
kStatus_HAL_UartSuccess Successfully.
kStatus_HAL_UartTxBusy TX busy.
kStatus_HAL_UartRxBusy RX busy.
kStatus_HAL_UartTxIdle HAL UART transmitter is idle.
kStatus_HAL_UartRxIdle HAL UART receiver is idle.
kStatus_HAL_UartBaudrateNotSupport Baudrate is not support in current clock source.
kStatus_HAL_UartProtocolError Error occurs for Noise, Framing, Parity, etc. For transactional
transfer, The up layer needs to abort the transfer and then starts again
kStatus_HAL_UartError Error occurs on HAL UART.

47.5.2 enum hal_uart_parity_mode_t

Enumerator
kHAL_UartParityDisabled Parity disabled.
kHAL_UartParityEven Parity even enabled.
kHAL_UartParityOdd Parity odd enabled.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 953
Function Documentation

47.5.3 enum hal_uart_stop_bit_count_t

Enumerator
kHAL_UartOneStopBit One stop bit.
kHAL_UartTwoStopBit Two stop bits.

47.6 Function Documentation


47.6.1 hal_uart_status_t HAL_UartInit ( hal_uart_handle_t handle,
hal_uart_config_t ∗ config )

This function configures the UART module with user-defined settings. The user can configure the con-
figuration structure. The parameter handle is a pointer to point to a memory space of size #HAL_UAR-
T_HANDLE_SIZE allocated by the caller. Example below shows how to use this API to configure the
UART.

* uint8_t g_UartHandleBuffer[HAL_UART_HANDLE_SIZE];
* hal_uart_handle_t g_UartHandle = &g_UartHandleBuffer[0];
* hal_uart_config_t config;
* config.srcClock_Hz = 48000000;
* config.baudRate_Bps = 115200U;
* config.parityMode = kHAL_UartParityDisabled;
* config.stopBitCount = kHAL_UartOneStopBit;
* config.enableRx = 1;
* config.enableTx = 1;
* config.instance = 0;
* HAL_UartInit(g_UartHandle, &config);
*

Parameters

handle Pointer to point to a memory space of size #HAL_UART_HANDLE_SIZE allocated


by the caller.
config Pointer to user-defined configuration structure.

Return values

kStatus_HAL_Uart- Baudrate is not support in current clock source.


BaudrateNotSupport
kStatus_HAL_Uart- UART initialization succeed
Success

47.6.2 hal_uart_status_t HAL_UartDeinit ( hal_uart_handle_t handle )

This function waits for TX complete, disables TX and RX, and disables the UART clock.

MCUXpresso SDK API Reference Manual


954 NXP Semiconductors
Function Documentation

Parameters

handle UART handle pointer.

Return values

kStatus_HAL_Uart- UART de-initialization succeed


Success

47.6.3 hal_uart_status_t HAL_UartReceiveBlocking ( hal_uart_handle_t handle,


uint8_t ∗ data, size_t length )

This function polls the RX register, waits for the RX register to be full or for RX FIFO to have data, and
reads data from the RX register.

Note
The function HAL_UartReceiveBlocking and the function #HAL_UartTransferReceiveNon-
Blocking cannot be used at the same time. And, the function #HAL_UartTransferAbortReceive
cannot be used to abort the transmission of this function.

Parameters

handle UART handle pointer.


data Start address of the buffer to store the received data.
length Size of the buffer.

Return values

kStatus_HAL_UartError An error occurred while receiving data.


kStatus_HAL_UartParity- A parity error occurred while receiving data.
Error
kStatus_HAL_Uart- Successfully received all data.
Success

47.6.4 hal_uart_status_t HAL_UartSendBlocking ( hal_uart_handle_t handle,


const uint8_t ∗ data, size_t length )

This function polls the TX register, waits for the TX register to be empty or for the TX FIFO to have room
and writes data to the TX buffer.

MCUXpresso SDK API Reference Manual


NXP Semiconductors 955
Function Documentation

Note
The function HAL_UartSendBlocking and the function #HAL_UartTransferSendNonBlocking can-
not be used at the same time. And, the function #HAL_UartTransferAbortSend cannot be used to
abort the transmission of this function.

Parameters

handle UART handle pointer.


data Start address of the data to write.
length Size of the data to write.

Return values

kStatus_HAL_Uart- Successfully sent all data.


Success

MCUXpresso SDK API Reference Manual


956 NXP Semiconductors
How to Reach Us: Information in this document is provided solely to enable system and
software implementers to use NXP products. There are no express or
Home Page:
implied copyright licenses granted hereunder to design or fabricate any
nxp.com
integrated circuits based on the information in this document.
Web Support:
nxp.com/support NXP makes no warranty, representation, or guarantee regarding the
suitability of its products for any particular purpose, nor does NXP
assume any liability arising out of the application or use of any product
or circuit, and specifically disclaims any and all liability, including without
limitation consequential or incidental damages. “Typical” parameters
that may be provided in NXP data sheets and/or specifications can and
do vary in different applications, and actual performance may vary over
time. All operating parameters, including “typicals,” must be validated for
each customer application by customer’s technical experts. NXP does
not convey any license under its patent rights nor the rights of others.
NXP sells products pursuant to standard terms and conditions of sale,
which can be found at the following address:
nxp.com/SalesTermsandConditions.

While NXP has implemented advanced security features, all products


may be subject to unidentified vulnerabilities. Customers are
responsible for the design and operation of their applications and
products to reduce the effect of these vulnerabilities on customer’s
applications and products, and NXP accepts no liability for any
vulnerability that is discovered. Customers should implement
appropriate design and operating safeguards to minimize the risks
associated with their applications and products.

NXP, the NXP logo, NXP SECURE CONNECTIONS FOR A SMARTER


WORLD, Freescale, the Freescale logo, Kinetis, Processor Expert, and
Tower are trademarks of NXP B.V. All other product or service names
are the property of their respective owners. Arm, Cortex, Keil, Mbed,
Mbed Enabled, and Vision are trademarks or registered trademarks of
Arm Limited (or its subsidiaries) in the US and/or elsewhere. The
related technology may be protected by any or all of patents, copyrights,
designs and trade secrets. All rights reserved. Oracle and Java are
registered trademarks of Oracle and/or its affiliates. The Power
Architecture and Power.org word marks and the Power and Power.org
logos and related marks are trademarks and service marks licensed by
Power.org.

© 2019 NXP B.V.

You might also like