LPC55S36
ANACTRL: Analog Control Driver
-
void ANACTRL_Init(ANACTRL_Type *base)
Initializes the ANACTRL mode, the module’s clock will be enabled by invoking this function.
- Parameters:
base – ANACTRL peripheral base address.
-
void ANACTRL_Deinit(ANACTRL_Type *base)
De-initializes ANACTRL module, the module’s clock will be disabled by invoking this function.
- Parameters:
base – ANACTRL peripheral base address.
-
void ANACTRL_SetFro192M(ANACTRL_Type *base, const anactrl_fro192M_config_t *config)
Configs the on-chip high-speed Free Running Oscillator(FRO192M), such as enabling/disabling 12 MHZ clock output and enable/disable 96MHZ clock output.
- Parameters:
base – ANACTRL peripheral base address.
config – Pointer to FRO192M configuration structure. Refer to anactrl_fro192M_config_t structure.
-
void ANACTRL_GetDefaultFro192MConfig(anactrl_fro192M_config_t *config)
Gets the default configuration of FRO192M. The default values are:
config->enable12MHzClk = true; config->enable96MHzClk = false;
- Parameters:
config – Pointer to FRO192M configuration structure. Refer to anactrl_fro192M_config_t structure.
-
void ANACTRL_SetXo32M(ANACTRL_Type *base, const anactrl_xo32M_config_t *config)
Configs the 32 MHz Crystal oscillator(High-speed crystal oscillator), such as enable/disable output to CPU system, and so on.
- Parameters:
base – ANACTRL peripheral base address.
config – Pointer to XO32M configuration structure. Refer to anactrl_xo32M_config_t structure.
-
void ANACTRL_GetDefaultXo32MConfig(anactrl_xo32M_config_t *config)
Gets the default configuration of XO32M. The default values are:
config->enableSysCLkOutput = false; config->enableACBufferBypass = false;
- Parameters:
config – Pointer to XO32M configuration structure. Refer to anactrl_xo32M_config_t structure.
-
static inline void ANACTRL_EnableInterrupts(ANACTRL_Type *base, uint32_t mask)
Enables the ANACTRL interrupts.
- Parameters:
base – ANACTRL peripheral base address.
mask – The interrupt mask. Refer to “_anactrl_interrupt” enumeration.
-
static inline void ANACTRL_DisableInterrupts(ANACTRL_Type *base, uint32_t mask)
Disables the ANACTRL interrupts.
- Parameters:
base – ANACTRL peripheral base address.
mask – The interrupt mask. Refer to “_anactrl_interrupt” enumeration.
-
static inline void ANACTRL_ClearInterrupts(ANACTRL_Type *base, uint32_t mask)
Clears the ANACTRL interrupts.
- Parameters:
base – ANACTRL peripheral base address.
mask – The interrupt mask. Refer to “_anactrl_interrupt” enumeration.
-
static inline uint32_t ANACTRL_GetStatusFlags(ANACTRL_Type *base)
Gets ANACTRL status flags.
This function gets Analog control status flags. The flags are returned as the logical OR value of the enumerators _anactrl_flags. To check for a specific status, compare the return value with enumerators in the _anactrl_flags. For example, to check whether the flash is in power down mode:
if (kANACTRL_FlashPowerDownFlag & ANACTRL_ANACTRL_GetStatusFlags(ANACTRL)) { ... }
- Parameters:
base – ANACTRL peripheral base address.
- Returns:
ANACTRL status flags which are given in the enumerators in the _anactrl_flags.
-
static inline uint32_t ANACTRL_GetOscStatusFlags(ANACTRL_Type *base)
Gets ANACTRL oscillators status flags.
This function gets Anactrl oscillators status flags. The flags are returned as the logical OR value of the enumerators _anactrl_osc_flags. To check for a specific status, compare the return value with enumerators in the _anactrl_osc_flags. For example, to check whether the FRO192M clock output is valid:
if (kANACTRL_OutputClkValidFlag & ANACTRL_ANACTRL_GetOscStatusFlags(ANACTRL)) { ... }
- Parameters:
base – ANACTRL peripheral base address.
- Returns:
ANACTRL oscillators status flags which are given in the enumerators in the _anactrl_osc_flags.
-
static inline uint32_t ANACTRL_GetInterruptStatusFlags(ANACTRL_Type *base)
Gets ANACTRL interrupt status flags.
This function gets Anactrl interrupt status flags. The flags are returned as the logical OR value of the enumerators _anactrl_interrupt_flags. To check for a specific status, compare the return value with enumerators in the _anactrl_interrupt_flags. For example, to check whether the VBAT voltage level is above the threshold:
if (kANACTRL_BodVbatPowerFlag & ANACTRL_ANACTRL_GetInterruptStatusFlags(ANACTRL)) { ... }
- Parameters:
base – ANACTRL peripheral base address.
- Returns:
ANACTRL oscillators status flags which are given in the enumerators in the _anactrl_osc_flags.
-
static inline void ANACTRL_EnableVref1V(ANACTRL_Type *base, bool enable)
Aux_Bias Control Interfaces.
Enables/disabless 1V reference voltage buffer.
- Parameters:
base – ANACTRL peripheral base address.
enable – Used to enable or disable 1V reference voltage buffer.
-
enum _anactrl_interrupt_flags
ANACTRL interrupt flags.
Values:
-
enumerator kANACTRL_BodVbatFlag
BOD VBAT Interrupt status before Interrupt Enable.
-
enumerator kANACTRL_BodVbatInterruptFlag
BOD VBAT Interrupt status after Interrupt Enable.
-
enumerator kANACTRL_BodVbatPowerFlag
Current value of BOD VBAT power status output.
-
enumerator kANACTRL_BodCoreFlag
BOD CORE Interrupt status before Interrupt Enable.
-
enumerator kANACTRL_BodCoreInterruptFlag
BOD CORE Interrupt status after Interrupt Enable.
-
enumerator kANACTRL_BodCorePowerFlag
Current value of BOD CORE power status output.
-
enumerator kANACTRL_DcdcFlag
DCDC Interrupt status before Interrupt Enable.
-
enumerator kANACTRL_DcdcInterruptFlag
DCDC Interrupt status after Interrupt Enable.
-
enumerator kANACTRL_DcdcPowerFlag
Current value of DCDC power status output.
-
enumerator kANACTRL_BodVbatFlag
-
enum _anactrl_interrupt
ANACTRL interrupt control.
Values:
-
enumerator kANACTRL_BodVbatInterruptEnable
BOD VBAT interrupt control.
-
enumerator kANACTRL_BodCoreInterruptEnable
BOD CORE interrupt control.
-
enumerator kANACTRL_DcdcInterruptEnable
DCDC interrupt control.
-
enumerator kANACTRL_BodVbatInterruptEnable
-
enum _anactrl_flags
ANACTRL status flags.
Values:
-
enumerator kANACTRL_FlashPowerDownFlag
Flash power-down status.
-
enumerator kANACTRL_FlashInitErrorFlag
Flash initialization error status.
-
enumerator kANACTRL_FlashPowerDownFlag
-
enum _anactrl_osc_flags
ANACTRL FRO192M and XO32M status flags.
Values:
-
enumerator kANACTRL_OutputClkValidFlag
Output clock valid signal.
-
enumerator kANACTRL_CCOThresholdVoltageFlag
CCO threshold voltage detector output (signal vcco_ok).
-
enumerator kANACTRL_XO32MOutputReadyFlag
Indicates XO out frequency statibilty.
-
enumerator kANACTRL_OutputClkValidFlag
-
typedef struct _anactrl_fro192M_config anactrl_fro192M_config_t
Configuration for FRO192M.
This structure holds the configuration settings for the on-chip high-speed Free Running Oscillator. To initialize this structure to reasonable defaults, call the ANACTRL_GetDefaultFro192MConfig() function and pass a pointer to your config structure instance.
-
typedef struct _anactrl_xo32M_config anactrl_xo32M_config_t
Configuration for XO32M.
This structure holds the configuration settings for the 32 MHz crystal oscillator. To initialize this structure to reasonable defaults, call the ANACTRL_GetDefaultXo32MConfig() function and pass a pointer to your config structure instance.
-
FSL_ANACTRL_DRIVER_VERSION
ANACTRL driver version.
-
struct _anactrl_fro192M_config
- #include <fsl_anactrl.h>
Configuration for FRO192M.
This structure holds the configuration settings for the on-chip high-speed Free Running Oscillator. To initialize this structure to reasonable defaults, call the ANACTRL_GetDefaultFro192MConfig() function and pass a pointer to your config structure instance.
Public Members
-
bool enable12MHzClk
Enable 12MHz clock.
-
bool enable96MHzClk
Enable 96MHz clock.
-
bool enable12MHzClk
-
struct _anactrl_xo32M_config
- #include <fsl_anactrl.h>
Configuration for XO32M.
This structure holds the configuration settings for the 32 MHz crystal oscillator. To initialize this structure to reasonable defaults, call the ANACTRL_GetDefaultXo32MConfig() function and pass a pointer to your config structure instance.
Public Members
-
bool enableACBufferBypass
Enable XO AC buffer bypass in pll and top level.
-
bool enableSysCLkOutput
Enable XO 32 MHz output to CPU system, SCT, and CLKOUT
-
bool enableADCOutput
Enable High speed crystal oscillator output to ADC.
-
bool enableACBufferBypass
AOI: Crossbar AND/OR/INVERT Driver
-
void AOI_Init(AOI_Type *base)
Initializes an AOI instance for operation.
This function un-gates the AOI clock.
- Parameters:
base – AOI peripheral address.
-
void AOI_Deinit(AOI_Type *base)
Deinitializes an AOI instance for operation.
This function shutdowns AOI module.
- Parameters:
base – AOI peripheral address.
-
void AOI_GetEventLogicConfig(AOI_Type *base, aoi_event_t event, aoi_event_config_t *config)
Gets the Boolean evaluation associated.
This function returns the Boolean evaluation associated.
Example:
aoi_event_config_t demoEventLogicStruct; AOI_GetEventLogicConfig(AOI, kAOI_Event0, &demoEventLogicStruct);
- Parameters:
base – AOI peripheral address.
event – Index of the event which will be set of type aoi_event_t.
config – Selected input configuration .
-
void AOI_SetEventLogicConfig(AOI_Type *base, aoi_event_t event, const aoi_event_config_t *eventConfig)
Configures an AOI event.
This function configures an AOI event according to the aoiEventConfig structure. This function configures all inputs (A, B, C, and D) of all product terms (0, 1, 2, and 3) of a desired event.
Example:
aoi_event_config_t demoEventLogicStruct; demoEventLogicStruct.PT0AC = kAOI_InvInputSignal; demoEventLogicStruct.PT0BC = kAOI_InputSignal; demoEventLogicStruct.PT0CC = kAOI_LogicOne; demoEventLogicStruct.PT0DC = kAOI_LogicOne; demoEventLogicStruct.PT1AC = kAOI_LogicZero; demoEventLogicStruct.PT1BC = kAOI_LogicOne; demoEventLogicStruct.PT1CC = kAOI_LogicOne; demoEventLogicStruct.PT1DC = kAOI_LogicOne; demoEventLogicStruct.PT2AC = kAOI_LogicZero; demoEventLogicStruct.PT2BC = kAOI_LogicOne; demoEventLogicStruct.PT2CC = kAOI_LogicOne; demoEventLogicStruct.PT2DC = kAOI_LogicOne; demoEventLogicStruct.PT3AC = kAOI_LogicZero; demoEventLogicStruct.PT3BC = kAOI_LogicOne; demoEventLogicStruct.PT3CC = kAOI_LogicOne; demoEventLogicStruct.PT3DC = kAOI_LogicOne; AOI_SetEventLogicConfig(AOI, kAOI_Event0, demoEventLogicStruct);
- Parameters:
base – AOI peripheral address.
event – Event which will be configured of type aoi_event_t.
eventConfig – Pointer to type aoi_event_config_t structure. The user is responsible for filling out the members of this structure and passing the pointer to this function.
-
FSL_AOI_DRIVER_VERSION
Version 2.0.2.
-
enum _aoi_input_config
AOI input configurations.
The selection item represents the Boolean evaluations.
Values:
-
enumerator kAOI_LogicZero
Forces the input to logical zero.
-
enumerator kAOI_InputSignal
Passes the input signal.
-
enumerator kAOI_InvInputSignal
Inverts the input signal.
-
enumerator kAOI_LogicOne
Forces the input to logical one.
-
enumerator kAOI_LogicZero
-
enum _aoi_event
AOI event indexes, where an event is the collection of the four product terms (0, 1, 2, and 3) and the four signal inputs (A, B, C, and D).
Values:
-
enumerator kAOI_Event0
Event 0 index
-
enumerator kAOI_Event1
Event 1 index
-
enumerator kAOI_Event2
Event 2 index
-
enumerator kAOI_Event3
Event 3 index
-
enumerator kAOI_Event0
-
typedef enum _aoi_input_config aoi_input_config_t
AOI input configurations.
The selection item represents the Boolean evaluations.
-
typedef enum _aoi_event aoi_event_t
AOI event indexes, where an event is the collection of the four product terms (0, 1, 2, and 3) and the four signal inputs (A, B, C, and D).
-
typedef struct _aoi_event_config aoi_event_config_t
AOI event configuration structure.
Defines structure _aoi_event_config and use the AOI_SetEventLogicConfig() function to make whole event configuration.
-
AOI
AOI peripheral address
-
struct _aoi_event_config
- #include <fsl_aoi.h>
AOI event configuration structure.
Defines structure _aoi_event_config and use the AOI_SetEventLogicConfig() function to make whole event configuration.
Public Members
-
aoi_input_config_t PT0AC
Product term 0 input A
-
aoi_input_config_t PT0BC
Product term 0 input B
-
aoi_input_config_t PT0CC
Product term 0 input C
-
aoi_input_config_t PT0DC
Product term 0 input D
-
aoi_input_config_t PT1AC
Product term 1 input A
-
aoi_input_config_t PT1BC
Product term 1 input B
-
aoi_input_config_t PT1CC
Product term 1 input C
-
aoi_input_config_t PT1DC
Product term 1 input D
-
aoi_input_config_t PT2AC
Product term 2 input A
-
aoi_input_config_t PT2BC
Product term 2 input B
-
aoi_input_config_t PT2CC
Product term 2 input C
-
aoi_input_config_t PT2DC
Product term 2 input D
-
aoi_input_config_t PT3AC
Product term 3 input A
-
aoi_input_config_t PT3BC
Product term 3 input B
-
aoi_input_config_t PT3CC
Product term 3 input C
-
aoi_input_config_t PT3DC
Product term 3 input D
-
aoi_input_config_t PT0AC
CACHE: CACHE Memory Controller
-
uint32_t CACHE64_GetInstance(CACHE64_POLSEL_Type *base)
Returns an instance number given peripheral base address.
- Parameters:
base – The peripheral base address.
- Returns:
CACHE64_POLSEL instance number starting from 0.
-
uint32_t CACHE64_GetInstanceByAddr(uint32_t address)
brief Returns an instance number given physical memory address.
param address The physical memory address.
- Returns:
CACHE64_CTRL instance number starting from 0.
-
status_t CACHE64_Init(CACHE64_POLSEL_Type *base, const cache64_config_t *config)
Initializes an CACHE64 instance with the user configuration structure.
This function configures the CACHE64 module with user-defined settings. Call the CACHE64_GetDefaultConfig() function to configure the configuration structure and get the default configuration.
- Parameters:
base – CACHE64_POLSEL peripheral base address.
config – Pointer to a user-defined configuration structure.
- Return values:
kStatus_Success – CACHE64 initialize succeed
-
void CACHE64_GetDefaultConfig(cache64_config_t *config)
Gets the default configuration structure.
This function initializes the CACHE64 configuration structure to a default value. The default values are first region covers whole cacheable area, and policy set to write back.
- Parameters:
config – Pointer to a configuration structure.
-
void CACHE64_EnableCache(CACHE64_CTRL_Type *base)
Enables the cache.
- Parameters:
base – CACHE64_CTRL peripheral base address.
-
void CACHE64_DisableCache(CACHE64_CTRL_Type *base)
Disables the cache.
- Parameters:
base – CACHE64_CTRL peripheral base address.
-
void CACHE64_InvalidateCache(CACHE64_CTRL_Type *base)
Invalidates the cache.
- Parameters:
base – CACHE64_CTRL peripheral base address.
-
void CACHE64_InvalidateCacheByRange(uint32_t address, uint32_t size_byte)
Invalidates cache by range.
Note
Address and size should be aligned to “CACHE64_LINESIZE_BYTE”. The startAddr here will be forced to align to CACHE64_LINESIZE_BYTE if startAddr is not aligned. For the size_byte, application should make sure the alignment or make sure the right operation order if the size_byte is not aligned.
- Parameters:
address – The physical address of cache.
size_byte – size of the memory to be invalidated, should be larger than 0.
-
void CACHE64_CleanCache(CACHE64_CTRL_Type *base)
Cleans the cache.
- Parameters:
base – CACHE64_CTRL peripheral base address.
-
void CACHE64_CleanCacheByRange(uint32_t address, uint32_t size_byte)
Cleans cache by range.
Note
Address and size should be aligned to “CACHE64_LINESIZE_BYTE”. The startAddr here will be forced to align to CACHE64_LINESIZE_BYTE if startAddr is not aligned. For the size_byte, application should make sure the alignment or make sure the right operation order if the size_byte is not aligned.
- Parameters:
address – The physical address of cache.
size_byte – size of the memory to be cleaned, should be larger than 0.
-
void CACHE64_CleanInvalidateCache(CACHE64_CTRL_Type *base)
Cleans and invalidates the cache.
- Parameters:
base – CACHE64_CTRL peripheral base address.
-
void CACHE64_CleanInvalidateCacheByRange(uint32_t address, uint32_t size_byte)
Cleans and invalidate cache by range.
Note
Address and size should be aligned to “CACHE64_LINESIZE_BYTE”. The startAddr here will be forced to align to CACHE64_LINESIZE_BYTE if startAddr is not aligned. For the size_byte, application should make sure the alignment or make sure the right operation order if the size_byte is not aligned.
- Parameters:
address – The physical address of cache.
size_byte – size of the memory to be Cleaned and Invalidated, should be larger than 0.
-
void CACHE64_EnableWriteBuffer(CACHE64_CTRL_Type *base, bool enable)
Enables/disables the write buffer.
- Parameters:
base – CACHE64_CTRL peripheral base address.
enable – The enable or disable flag. true - enable the write buffer. false - disable the write buffer.
-
static inline void ICACHE_InvalidateByRange(uint32_t address, uint32_t size_byte)
Invalidates instruction cache by range.
Note
Address and size should be aligned to CACHE64_LINESIZE_BYTE due to the cache operation unit FSL_FEATURE_CACHE64_CTRL_LINESIZE_BYTE. The startAddr here will be forced to align to the cache line size if startAddr is not aligned. For the size_byte, application should make sure the alignment or make sure the right operation order if the size_byte is not aligned.
- Parameters:
address – The physical address.
size_byte – size of the memory to be invalidated, should be larger than 0.
-
static inline void DCACHE_InvalidateByRange(uint32_t address, uint32_t size_byte)
Invalidates data cache by range.
Note
Address and size should be aligned to CACHE64_LINESIZE_BYTE due to the cache operation unit FSL_FEATURE_CACHE64_CTRL_LINESIZE_BYTE. The startAddr here will be forced to align to the cache line size if startAddr is not aligned. For the size_byte, application should make sure the alignment or make sure the right operation order if the size_byte is not aligned.
- Parameters:
address – The physical address.
size_byte – size of the memory to be invalidated, should be larger than 0.
-
static inline void DCACHE_CleanByRange(uint32_t address, uint32_t size_byte)
Clean data cache by range.
Note
Address and size should be aligned to CACHE64_LINESIZE_BYTE due to the cache operation unit FSL_FEATURE_CACHE64_CTRL_LINESIZE_BYTE. The startAddr here will be forced to align to the cache line size if startAddr is not aligned. For the size_byte, application should make sure the alignment or make sure the right operation order if the size_byte is not aligned.
- Parameters:
address – The physical address.
size_byte – size of the memory to be cleaned, should be larger than 0.
-
static inline void DCACHE_CleanInvalidateByRange(uint32_t address, uint32_t size_byte)
Cleans and Invalidates data cache by range.
Note
Address and size should be aligned to CACHE64_LINESIZE_BYTE due to the cache operation unit FSL_FEATURE_CACHE64_CTRL_LINESIZE_BYTE. The startAddr here will be forced to align to the cache line size if startAddr is not aligned. For the size_byte, application should make sure the alignment or make sure the right operation order if the size_byte is not aligned.
- Parameters:
address – The physical address.
size_byte – size of the memory to be Cleaned and Invalidated, should be larger than 0.
-
FSL_CACHE_DRIVER_VERSION
cache driver version.
-
enum _cache64_policy
Level 2 cache controller way size.
Values:
-
enumerator kCACHE64_PolicyNonCacheable
Non-cacheable
-
enumerator kCACHE64_PolicyWriteThrough
Write through
-
enumerator kCACHE64_PolicyWriteBack
Write back
-
enumerator kCACHE64_PolicyNonCacheable
-
typedef enum _cache64_policy cache64_policy_t
Level 2 cache controller way size.
-
typedef struct _cache64_config cache64_config_t
CACHE64 configuration structure.
-
CACHE64_LINESIZE_BYTE
cache line size.
-
CACHE64_REGION_NUM
cache region number.
-
CACHE64_REGION_ALIGNMENT
cache region alignment.
-
struct _cache64_config
- #include <fsl_cache.h>
CACHE64 configuration structure.
Public Members
-
uint32_t boundaryAddr[(3U) - 1]
< The cache controller can divide whole memory into 3 regions. Boundary address is the FlexSPI internal address (start from 0) instead of system address (start from FlexSPI AMBA base) to split adjacent regions and must be 1KB aligned. The boundary address itself locates in upper region. Cacheable policy for each region.
-
uint32_t boundaryAddr[(3U) - 1]
CACHE: LPCAC CACHE Memory Controller
-
static inline void L1CACHE_EnableCodeCache(void)
Enables the processor code bus cache.
-
static inline void L1CACHE_DisableCodeCache(void)
Disables the processor code bus cache.
-
static inline void L1CACHE_InvalidateCodeCache(void)
Clears cache.
-
static inline void L1CACHE_EnableAllocation(void)
Enables allocation.
-
static inline void L1CACHE_DisableAllocation(void)
Disables allocation.
-
static inline void L1CACHE_EnableParity(void)
Enables parity.
-
static inline void L1CACHE_DisableParity(void)
Disable parity.
-
FSL_CACHE_LPCAC_DRIVER_VERSION
cache driver version
CASPER: The Cryptographic Accelerator and Signal Processing Engine with RAM sharing
casper_driver
-
FSL_CASPER_DRIVER_VERSION
CASPER driver version. Version 2.2.4.
Current version: 2.2.4
Change log:
Version 2.0.0
Initial version
Version 2.0.1
Bug fix KPSDK-24531 double_scalar_multiplication() result may be all zeroes for some specific input
Version 2.0.2
Bug fix KPSDK-25015 CASPER_MEMCPY hard-fault on LPC55xx when both source and destination buffers are outside of CASPER_RAM
Version 2.0.3
Bug fix KPSDK-28107 RSUB, FILL and ZERO operations not implemented in enum _casper_operation.
Version 2.0.4
For GCC compiler, enforce O1 optimize level, specifically to remove strict-aliasing option. This driver is very specific and requires -fno-strict-aliasing.
Version 2.0.5
Fix sign-compare warning.
Version 2.0.6
Fix IAR Pa082 warning.
Version 2.0.7
Fix MISRA-C 2012 issue.
Version 2.0.8
Add feature macro for CASPER_RAM_OFFSET.
Version 2.0.9
Remove unused function Jac_oncurve().
Fix ECC384 build.
Version 2.0.10
Fix MISRA-C 2012 issue.
Version 2.1.0
Add ECC NIST P-521 elliptic curve.
Version 2.2.0
Rework driver to support multiple curves at once.
Version 2.2.1
Fix MISRA-C 2012 issue.
Version 2.2.2
Enable hardware interleaving to RAMX0 and RAMX1 for CASPER by feature macro FSL_FEATURE_CASPER_RAM_HW_INTERLEAVE
Version 2.2.3
Added macro into CASPER_Init and CASPER_Deinit to support devices without clock and reset control.
Version 2.2.4
Fix MISRA-C 2012 issue.
-
enum _casper_operation
CASPER operation.
Values:
-
enumerator kCASPER_OpMul6464NoSum
-
enumerator kCASPER_OpMul6464Sum
Walking 1 or more of J loop, doing r=a*b using 64x64=128
-
enumerator kCASPER_OpMul6464FullSum
Walking 1 or more of J loop, doing c,r=r+a*b using 64x64=128, but assume inner j loop
-
enumerator kCASPER_OpMul6464Reduce
Walking 1 or more of J loop, doing c,r=r+a*b using 64x64=128, but sum all of w.
-
enumerator kCASPER_OpAdd64
Walking 1 or more of J loop, doing c,r[-1]=r+a*b using 64x64=128, but skip 1st write
-
enumerator kCASPER_OpSub64
Walking add with off_AB, and in/out off_RES doing c,r=r+a+c using 64+64=65
-
enumerator kCASPER_OpDouble64
Walking subtract with off_AB, and in/out off_RES doing r=r-a using 64-64=64, with last borrow implicit if any
-
enumerator kCASPER_OpXor64
Walking add to self with off_RES doing c,r=r+r+c using 64+64=65
-
enumerator kCASPER_OpRSub64
Walking XOR with off_AB, and in/out off_RES doing r=r^a using 64^64=64
-
enumerator kCASPER_OpShiftLeft32
Walking subtract with off_AB, and in/out off_RES using r=a-r
-
enumerator kCASPER_OpShiftRight32
Walking shift left doing r1,r=(b*D)|r1, where D is 2^amt and is loaded by app (off_CD not used)
-
enumerator kCASPER_OpCopy
Walking shift right doing r,r1=(b*D)|r1, where D is 2^(32-amt) and is loaded by app (off_CD not used) and off_RES starts at MSW
-
enumerator kCASPER_OpRemask
Copy from ABoff to resoff, 64b at a time
-
enumerator kCASPER_OpFill
Copy and mask from ABoff to resoff, 64b at a time
-
enumerator kCASPER_OpZero
Fill RESOFF using 64 bits at a time with value in A and B
-
enumerator kCASPER_OpCompare
Fill RESOFF using 64 bits at a time of 0s
-
enumerator kCASPER_OpCompareFast
Compare two arrays, running all the way to the end
-
enumerator kCASPER_OpMul6464NoSum
-
enum _casper_algo_t
Algorithm used for CASPER operation.
Values:
-
enumerator kCASPER_ECC_P256
ECC_P256
-
enumerator kCASPER_ECC_P384
ECC_P384
-
enumerator kCASPER_ECC_P521
ECC_P521
-
enumerator kCASPER_ECC_P256
Values:
-
enumerator kCASPER_RamOffset_Result
-
enumerator kCASPER_RamOffset_Base
-
enumerator kCASPER_RamOffset_TempBase
-
enumerator kCASPER_RamOffset_Modulus
-
enumerator kCASPER_RamOffset_M64
-
enumerator kCASPER_RamOffset_Result
-
typedef enum _casper_operation casper_operation_t
CASPER operation.
-
typedef enum _casper_algo_t casper_algo_t
Algorithm used for CASPER operation.
-
void CASPER_Init(CASPER_Type *base)
Enables clock and disables reset for CASPER peripheral.
Enable clock and disable reset for CASPER.
- Parameters:
base – CASPER base address
-
void CASPER_Deinit(CASPER_Type *base)
Disables clock for CASPER peripheral.
Disable clock and enable reset.
- Parameters:
base – CASPER base address
-
CASPER_CP
-
CASPER_CP_CTRL0
-
CASPER_CP_CTRL1
-
CASPER_CP_LOADER
-
CASPER_CP_STATUS
-
CASPER_CP_INTENSET
-
CASPER_CP_INTENCLR
-
CASPER_CP_INTSTAT
-
CASPER_CP_AREG
-
CASPER_CP_BREG
-
CASPER_CP_CREG
-
CASPER_CP_DREG
-
CASPER_CP_RES0
-
CASPER_CP_RES1
-
CASPER_CP_RES2
-
CASPER_CP_RES3
-
CASPER_CP_MASK
-
CASPER_CP_REMASK
-
CASPER_CP_LOCK
-
CASPER_CP_ID
-
CASPER_Wr32b(value, off)
-
CASPER_Wr64b(value, off)
-
CASPER_Rd32b(off)
-
N_wordlen_max
casper_driver_pkha
-
void CASPER_ModExp(CASPER_Type *base, const uint8_t *signature, const uint8_t *pubN, size_t wordLen, uint32_t pubE, uint8_t *plaintext)
Performs modular exponentiation - (A^E) mod N.
This function performs modular exponentiation.
- Parameters:
base – CASPER base address
signature – first addend (in little endian format)
pubN – modulus (in little endian format)
wordLen – Size of pubN in bytes
pubE – exponent
plaintext – [out] Output array to store result of operation (in little endian format)
-
void CASPER_ecc_init(casper_algo_t curve)
Initialize prime modulus mod in Casper memory .
Set the prime modulus mod in Casper memory and set N_wordlen according to selected algorithm.
- Parameters:
curve – elliptic curve algoritm
-
void CASPER_ECC_SECP256R1_Mul(CASPER_Type *base, uint32_t resX[8], uint32_t resY[8], uint32_t X[8], uint32_t Y[8], uint32_t scalar[8])
Performs ECC secp256r1 point single scalar multiplication.
This function performs ECC secp256r1 point single scalar multiplication [resX; resY] = scalar * [X; Y] Coordinates are affine in normal form, little endian. Scalars are little endian. All arrays are little endian byte arrays, uint32_t type is used only to enforce the 32-bit alignment (0-mod-4 address).
- Parameters:
base – CASPER base address
resX – [out] Output X affine coordinate in normal form, little endian.
resY – [out] Output Y affine coordinate in normal form, little endian.
X – Input X affine coordinate in normal form, little endian.
Y – Input Y affine coordinate in normal form, little endian.
scalar – Input scalar integer, in normal form, little endian.
-
void CASPER_ECC_SECP256R1_MulAdd(CASPER_Type *base, uint32_t resX[8], uint32_t resY[8], uint32_t X1[8], uint32_t Y1[8], uint32_t scalar1[8], uint32_t X2[8], uint32_t Y2[8], uint32_t scalar2[8])
Performs ECC secp256r1 point double scalar multiplication.
This function performs ECC secp256r1 point double scalar multiplication [resX; resY] = scalar1 * [X1; Y1] + scalar2 * [X2; Y2] Coordinates are affine in normal form, little endian. Scalars are little endian. All arrays are little endian byte arrays, uint32_t type is used only to enforce the 32-bit alignment (0-mod-4 address).
- Parameters:
base – CASPER base address
resX – [out] Output X affine coordinate.
resY – [out] Output Y affine coordinate.
X1 – Input X1 affine coordinate.
Y1 – Input Y1 affine coordinate.
scalar1 – Input scalar1 integer.
X2 – Input X2 affine coordinate.
Y2 – Input Y2 affine coordinate.
scalar2 – Input scalar2 integer.
-
void CASPER_ECC_SECP384R1_Mul(CASPER_Type *base, uint32_t resX[12], uint32_t resY[12], uint32_t X[12], uint32_t Y[12], uint32_t scalar[12])
Performs ECC secp384r1 point single scalar multiplication.
This function performs ECC secp384r1 point single scalar multiplication [resX; resY] = scalar * [X; Y] Coordinates are affine in normal form, little endian. Scalars are little endian. All arrays are little endian byte arrays, uint32_t type is used only to enforce the 32-bit alignment (0-mod-4 address).
- Parameters:
base – CASPER base address
resX – [out] Output X affine coordinate in normal form, little endian.
resY – [out] Output Y affine coordinate in normal form, little endian.
X – Input X affine coordinate in normal form, little endian.
Y – Input Y affine coordinate in normal form, little endian.
scalar – Input scalar integer, in normal form, little endian.
-
void CASPER_ECC_SECP384R1_MulAdd(CASPER_Type *base, uint32_t resX[12], uint32_t resY[12], uint32_t X1[12], uint32_t Y1[12], uint32_t scalar1[12], uint32_t X2[12], uint32_t Y2[12], uint32_t scalar2[12])
Performs ECC secp384r1 point double scalar multiplication.
This function performs ECC secp384r1 point double scalar multiplication [resX; resY] = scalar1 * [X1; Y1] + scalar2 * [X2; Y2] Coordinates are affine in normal form, little endian. Scalars are little endian. All arrays are little endian byte arrays, uint32_t type is used only to enforce the 32-bit alignment (0-mod-4 address).
- Parameters:
base – CASPER base address
resX – [out] Output X affine coordinate.
resY – [out] Output Y affine coordinate.
X1 – Input X1 affine coordinate.
Y1 – Input Y1 affine coordinate.
scalar1 – Input scalar1 integer.
X2 – Input X2 affine coordinate.
Y2 – Input Y2 affine coordinate.
scalar2 – Input scalar2 integer.
-
void CASPER_ECC_SECP521R1_Mul(CASPER_Type *base, uint32_t resX[18], uint32_t resY[18], uint32_t X[18], uint32_t Y[18], uint32_t scalar[18])
Performs ECC secp521r1 point single scalar multiplication.
This function performs ECC secp521r1 point single scalar multiplication [resX; resY] = scalar * [X; Y] Coordinates are affine in normal form, little endian. Scalars are little endian. All arrays are little endian byte arrays, uint32_t type is used only to enforce the 32-bit alignment (0-mod-4 address).
- Parameters:
base – CASPER base address
resX – [out] Output X affine coordinate in normal form, little endian.
resY – [out] Output Y affine coordinate in normal form, little endian.
X – Input X affine coordinate in normal form, little endian.
Y – Input Y affine coordinate in normal form, little endian.
scalar – Input scalar integer, in normal form, little endian.
-
void CASPER_ECC_SECP521R1_MulAdd(CASPER_Type *base, uint32_t resX[18], uint32_t resY[18], uint32_t X1[18], uint32_t Y1[18], uint32_t scalar1[18], uint32_t X2[18], uint32_t Y2[18], uint32_t scalar2[18])
Performs ECC secp521r1 point double scalar multiplication.
This function performs ECC secp521r1 point double scalar multiplication [resX; resY] = scalar1 * [X1; Y1] + scalar2 * [X2; Y2] Coordinates are affine in normal form, little endian. Scalars are little endian. All arrays are little endian byte arrays, uint32_t type is used only to enforce the 32-bit alignment (0-mod-4 address).
- Parameters:
base – CASPER base address
resX – [out] Output X affine coordinate.
resY – [out] Output Y affine coordinate.
X1 – Input X1 affine coordinate.
Y1 – Input Y1 affine coordinate.
scalar1 – Input scalar1 integer.
X2 – Input X2 affine coordinate.
Y2 – Input Y2 affine coordinate.
scalar2 – Input scalar2 integer.
-
void CASPER_ECC_equal(int *res, uint32_t *op1, uint32_t *op2)
-
void CASPER_ECC_equal_to_zero(int *res, uint32_t *op1)
CDOG
-
status_t CDOG_Init(CDOG_Type *base, cdog_config_t *conf)
Initialize CDOG.
This function initializes CDOG block and setting.
- Parameters:
base – CDOG peripheral base address
conf – CDOG configuration structure
- Returns:
Status of the init operation
-
void CDOG_Deinit(CDOG_Type *base)
Deinitialize CDOG.
This function deinitializes CDOG secure counter.
- Parameters:
base – CDOG peripheral base address
-
void CDOG_GetDefaultConfig(cdog_config_t *conf)
Sets the default configuration of CDOG.
This function initialize CDOG config structure to default values.
- Parameters:
conf – CDOG configuration structure
-
void CDOG_Stop(CDOG_Type *base, uint32_t stop)
Stops secure counter and instruction timer.
This function stops instruction timer and secure counter. This also change state od CDOG to IDLE.
- Parameters:
base – CDOG peripheral base address
stop – expected value which will be compared with value of secure counter
-
void CDOG_Start(CDOG_Type *base, uint32_t reload, uint32_t start)
Sets secure counter and instruction timer values.
This function sets value in RELOAD and START registers for instruction timer and secure counter
- Parameters:
base – CDOG peripheral base address
reload – reload value
start – start value
-
void CDOG_Check(CDOG_Type *base, uint32_t check)
Checks secure counter.
This function compares stop value in handler with secure counter value by writting to RELOAD refister.
- Parameters:
base – CDOG peripheral base address
check – expected (stop) value
-
void CDOG_Set(CDOG_Type *base, uint32_t stop, uint32_t reload, uint32_t start)
Sets secure counter and instruction timer values.
This function sets value in STOP, RELOAD and START registers for instruction timer and secure counter.
- Parameters:
base – CDOG peripheral base address
stop – expected value which will be compared with value of secure counter
reload – reload value for instruction timer
start – start value for secure timer
-
void CDOG_Add(CDOG_Type *base, uint32_t add)
Add value to secure counter.
This function add specified value to secure counter.
- Parameters:
base – CDOG peripheral base address.
add – Value to be added.
-
void CDOG_Add1(CDOG_Type *base)
Add 1 to secure counter.
This function add 1 to secure counter.
- Parameters:
base – CDOG peripheral base address.
-
void CDOG_Add16(CDOG_Type *base)
Add 16 to secure counter.
This function add 16 to secure counter.
- Parameters:
base – CDOG peripheral base address.
-
void CDOG_Add256(CDOG_Type *base)
Add 256 to secure counter.
This function add 256 to secure counter.
- Parameters:
base – CDOG peripheral base address.
-
void CDOG_Sub(CDOG_Type *base, uint32_t sub)
brief Substract value to secure counter
This function substract specified value to secure counter.
param base CDOG peripheral base address. param sub Value to be substracted.
-
void CDOG_Sub1(CDOG_Type *base)
Substract 1 from secure counter.
This function substract specified 1 from secure counter.
- Parameters:
base – CDOG peripheral base address.
-
void CDOG_Sub16(CDOG_Type *base)
Substract 16 from secure counter.
This function substract specified 16 from secure counter.
- Parameters:
base – CDOG peripheral base address.
-
void CDOG_Sub256(CDOG_Type *base)
Substract 256 from secure counter.
This function substract specified 256 from secure counter.
- Parameters:
base – CDOG peripheral base address.
-
void CDOG_WritePersistent(CDOG_Type *base, uint32_t value)
Set the CDOG persistent word.
- Parameters:
base – CDOG peripheral base address.
value – The value to be written.
-
uint32_t CDOG_ReadPersistent(CDOG_Type *base)
Get the CDOG persistent word.
- Parameters:
base – CDOG peripheral base address.
- Returns:
The persistent word.
-
FSL_CDOG_DRIVER_VERSION
Defines CDOG driver version 2.1.3.
Change log:
Version 2.1.3
Re-design multiple instance IRQs and Clocks
Add fix for RESTART command errata
Version 2.1.2
Support multiple IRQs
Fix default CONTROL values
Version 2.1.1
Remove bit CONTROL[CONTROL_CTRL]
Version 2.1.0
Rename CWT to CDOG
Version 2.0.2
Fix MISRA-2012 issues
Version 2.0.1
Fix doxygen issues
Version 2.0.0
initial version
-
enum __cdog_debug_Action_ctrl_enum
Values:
-
enumerator kCDOG_DebugHaltCtrl_Run
-
enumerator kCDOG_DebugHaltCtrl_Pause
-
enumerator kCDOG_DebugHaltCtrl_Run
-
enum __cdog_irq_pause_ctrl_enum
Values:
-
enumerator kCDOG_IrqPauseCtrl_Run
-
enumerator kCDOG_IrqPauseCtrl_Pause
-
enumerator kCDOG_IrqPauseCtrl_Run
-
enum __cdog_fault_ctrl_enum
Values:
-
enumerator kCDOG_FaultCtrl_EnableReset
-
enumerator kCDOG_FaultCtrl_EnableInterrupt
-
enumerator kCDOG_FaultCtrl_NoAction
-
enumerator kCDOG_FaultCtrl_EnableReset
-
enum __code_lock_ctrl_enum
Values:
-
enumerator kCDOG_LockCtrl_Lock
-
enumerator kCDOG_LockCtrl_Unlock
-
enumerator kCDOG_LockCtrl_Lock
-
typedef uint32_t secure_counter_t
-
SC_ADD(add)
-
SC_ADD1
-
SC_ADD16
-
SC_ADD256
-
SC_SUB(sub)
-
SC_SUB1
-
SC_SUB16
-
SC_SUB256
-
SC_CHECK(val)
-
struct cdog_config_t
- #include <fsl_cdog.h>
Clock Driver
-
enum _clock_ip_name
Clock gate name used for CLOCK_EnableClock/CLOCK_DisableClock.
Values:
-
enumerator kCLOCK_IpInvalid
Invalid IP name.
-
enumerator kCLOCK_Rom
Clock gate name: Rom.
-
enumerator kCLOCK_Sram1
Clock gate name: Sram1.
-
enumerator kCLOCK_Sram2
Clock gate name: Sram2.
-
enumerator kCLOCK_Sram3
Clock gate name: Sram3.
-
enumerator kCLOCK_Sram4
Clock gate name: Sram4.
-
enumerator kCLOCK_Flash
Clock gate name: Flash.
-
enumerator kCLOCK_Fmc
Clock gate name: Fmc.
-
enumerator kCLOCK_Flexspi
Clock gate name: Flexspi.
-
enumerator kCLOCK_InputMux
Clock gate name: InputMux.
-
enumerator kCLOCK_Iocon
Clock gate name: Iocon.
-
enumerator kCLOCK_Gpio0
Clock gate name: Gpio0.
-
enumerator kCLOCK_Gpio1
Clock gate name: Gpio1.
-
enumerator kCLOCK_Gpio2
Clock gate name: Gpio2.
-
enumerator kCLOCK_Gpio3
Clock gate name: Gpio3.
-
enumerator kCLOCK_Pint
Clock gate name: Pint.
-
enumerator kCLOCK_Gint
Clock gate name: Gint.
-
enumerator kCLOCK_Dma0
Clock gate name: Dma0.
-
enumerator kCLOCK_Crc0
Clock gate name: Crc.
-
enumerator kCLOCK_Wwdt
Clock gate name: Wwdt.
-
enumerator kCLOCK_Rtc0
Clock gate name: Rtc0.
-
enumerator kCLOCK_Mailbox
Clock gate name: Mailbox.
-
enumerator kCLOCK_Adc0
Clock gate name: Adc0.
-
enumerator kCLOCK_Adc1
Clock gate name: Adc1.
-
enumerator kCLOCK_Dac0
Clock gate name: Dac0.
-
enumerator kCLOCK_Mrt
Clock gate name: Mrt.
-
enumerator kCLOCK_Ostimer
Clock gate name: Ostimer.
-
enumerator kCLOCK_Sct
Clock gate name: Sct.
-
enumerator kCLOCK_Mcan
Clock gate name: Mcan.
-
enumerator kCLOCK_Utick
Clock gate name: Utick.
-
enumerator kCLOCK_FlexComm0
Clock gate name: FlexComm0.
-
enumerator kCLOCK_FlexComm1
Clock gate name: FlexComm1.
-
enumerator kCLOCK_FlexComm2
Clock gate name: FlexComm2.
-
enumerator kCLOCK_FlexComm3
Clock gate name: FlexComm3.
-
enumerator kCLOCK_FlexComm4
Clock gate name: FlexComm4.
-
enumerator kCLOCK_FlexComm5
Clock gate name: FlexComm5.
-
enumerator kCLOCK_FlexComm6
Clock gate name: FlexComm6.
-
enumerator kCLOCK_FlexComm7
Clock gate name: FlexComm7.
-
enumerator kCLOCK_MinUart0
Clock gate name: MinUart0.
-
enumerator kCLOCK_MinUart1
Clock gate name: MinUart1.
-
enumerator kCLOCK_MinUart2
Clock gate name: MinUart2.
-
enumerator kCLOCK_MinUart3
Clock gate name: MinUart3.
-
enumerator kCLOCK_MinUart4
Clock gate name: MinUart4.
-
enumerator kCLOCK_MinUart5
Clock gate name: MinUart5.
-
enumerator kCLOCK_MinUart6
Clock gate name: MinUart6.
-
enumerator kCLOCK_MinUart7
Clock gate name: MinUart7.
-
enumerator kCLOCK_LSpi0
Clock gate name: LSpi0.
-
enumerator kCLOCK_LSpi1
Clock gate name: LSpi1.
-
enumerator kCLOCK_LSpi2
Clock gate name: LSpi2.
-
enumerator kCLOCK_LSpi3
Clock gate name: LSpi3.
-
enumerator kCLOCK_LSpi4
Clock gate name: LSpi4.
-
enumerator kCLOCK_LSpi5
Clock gate name: LSpi5.
-
enumerator kCLOCK_LSpi6
Clock gate name: LSpi6.
-
enumerator kCLOCK_LSpi7
Clock gate name: LSpi7.
-
enumerator kCLOCK_BI2c0
Clock gate name: BI2c0.
-
enumerator kCLOCK_BI2c1
Clock gate name: BI2c1.
-
enumerator kCLOCK_BI2c2
Clock gate name: BI2c2.
-
enumerator kCLOCK_BI2c3
Clock gate name: BI2c3.
-
enumerator kCLOCK_BI2c4
Clock gate name: BI2c4.
-
enumerator kCLOCK_BI2c5
Clock gate name: BI2c5.
-
enumerator kCLOCK_BI2c6
Clock gate name: BI2c6.
-
enumerator kCLOCK_BI2c7
Clock gate name: BI2c7.
-
enumerator kCLOCK_FlexI2s0
Clock gate name: FlexI2s0.
-
enumerator kCLOCK_FlexI2s1
Clock gate name: FlexI2s1.
-
enumerator kCLOCK_FlexI2s2
Clock gate name: FlexI2s2.
-
enumerator kCLOCK_FlexI2s3
Clock gate name: FlexI2s3.
-
enumerator kCLOCK_FlexI2s4
Clock gate name: FlexI2s4.
-
enumerator kCLOCK_FlexI2s5
Clock gate name: FlexI2s5.
-
enumerator kCLOCK_FlexI2s6
Clock gate name: FlexI2s6.
-
enumerator kCLOCK_FlexI2s7
Clock gate name: FlexI2s7.
-
enumerator kCLOCK_Dmic
Clock gate name: Dmic.
-
enumerator kCLOCK_Timer2
Clock gate name: Timer2.
-
enumerator kCLOCK_Usbd0
Clock gate name: Usbd0.
-
enumerator kCLOCK_Timer0
Clock gate name: Timer0.
-
enumerator kCLOCK_Timer1
Clock gate name: Timer1.
-
enumerator kCLOCK_Ezhb
Clock gate name: Ezhb.
-
enumerator kCLOCK_Dma1
Clock gate name: Dma1.
-
enumerator kCLOCK_Comp
Clock gate name: Comp.
-
enumerator kCLOCK_Freqme
Clock gate name: Freqme.
-
enumerator kCLOCK_Cdog
Clock gate name: Cdog.
-
enumerator kCLOCK_Rng
Clock gate name: Rng.
-
enumerator kCLOCK_Pmux1
Clock gate name: Pmux1.
-
enumerator kCLOCK_Sysctl
Clock gate name: Sysctl.
-
enumerator kCLOCK_Usbhmr0
Clock gate name: Usbhmr0.
-
enumerator kCLOCK_Usbhsl0
Clock gate name: Usbhsl0.
-
enumerator kCLOCK_Css
Clock gate name: Css.
-
enumerator kCLOCK_PowerQuad
Clock gate name: PowerQuad.
-
enumerator kCLOCK_Timer3
Clock gate name: Timer3.
-
enumerator kCLOCK_Timer4
Clock gate name: Timer4.
-
enumerator kCLOCK_Puf
Clock gate name: Puf.
-
enumerator kCLOCK_Pkc
Clock gate name: Pkc.
-
enumerator kCLOCK_AnalogCtrl
Clock gate name: AnalogCtrl.
-
enumerator kCLOCK_Hs_Lspi
Clock gate name: Lspi.
-
enumerator kCLOCK_Gpio_Sec
Clock gate name: Sec.
-
enumerator kCLOCK_Gpio_Sec_Int
Clock gate name: Int.
-
enumerator kCLOCK_I3c0
Clock gate name: I3c0.
-
enumerator kCLOCK_Enc0
Clock gate name: Enc0.
-
enumerator kCLOCK_Enc1
Clock gate name: Enc1.
-
enumerator kCLOCK_Pwm0
Clock gate name: Pwm0.
-
enumerator kCLOCK_Pwm1
Clock gate name: Pwm1.
-
enumerator kCLOCK_Aoi0
Clock gate name: Aoi0.
-
enumerator kCLOCK_Aoi1
Clock gate name: Aoi1.
-
enumerator kCLOCK_Ftm0
Clock gate name: Ftm0.
-
enumerator kCLOCK_Dac1
Clock gate name: Dac1.
-
enumerator kCLOCK_Dac2
Clock gate name: Dac2.
-
enumerator kCLOCK_Opamp0
Clock gate name: Opamp0.
-
enumerator kCLOCK_Opamp1
Clock gate name: Opamp1.
-
enumerator kCLOCK_Opamp2
Clock gate name: Opamp2.
-
enumerator kCLOCK_Hscmp0
Clock gate name: Hscmp0.
-
enumerator kCLOCK_Hscmp1
Clock gate name: Hscmp1.
-
enumerator kCLOCK_Hscmp2
Clock gate name: Hscmp2.
-
enumerator kCLOCK_Vref
Clock gate name: Vref.
-
enumerator kCLOCK_Pwm0_Sm0
Clock gate name: PWM0 SM0.
-
enumerator kCLOCK_Pwm0_Sm1
Clock gate name: PWM0 SM1.
-
enumerator kCLOCK_Pwm0_Sm2
Clock gate name: PWM0 SM2.
-
enumerator kCLOCK_Pwm0_Sm3
Clock gate name: PWM0 SM3.
-
enumerator kCLOCK_Pwm1_Sm0
Clock gate name: PWM1 SM0.
-
enumerator kCLOCK_Pwm1_Sm1
Clock gate name: PWM1 SM1.
-
enumerator kCLOCK_Pwm1_Sm2
Clock gate name: PWM1 SM2.
-
enumerator kCLOCK_Pwm1_Sm3
Clock gate name: PWM1 SM3.
-
enumerator kCLOCK_IpInvalid
-
enum _clock_name
Clock name used to get clock frequency.
Values:
-
enumerator kCLOCK_CoreSysClk
Core/system clock (aka MAIN_CLK)
-
enumerator kCLOCK_BusClk
Bus clock (AHB clock)
-
enumerator kCLOCK_ClockOut
CLOCKOUT
-
enumerator kCLOCK_FroHf
FRO48/96
-
enumerator kCLOCK_Pll1Out
PLL1 Output
-
enumerator kCLOCK_Mclk
MCLK
-
enumerator kCLOCK_Fro12M
FRO12M
-
enumerator kCLOCK_Fro1M
FRO1M
-
enumerator kCLOCK_ExtClk
External Clock
-
enumerator kCLOCK_Pll0Out
PLL0 Output
-
enumerator kCLOCK_PllClkDiv
PLLCLKDIV clock
-
enumerator kCLOCK_FlexI2S
FlexI2S clock
-
enumerator kCLOCK_CoreSysClk
-
enum _clock_attach_id
The enumerator of clock attach Id.
Values:
-
enumerator kFRO12M_to_MAIN_CLK
Attach FRO12M to MAIN_CLK.
-
enumerator kEXT_CLK_to_MAIN_CLK
Attach EXT_CLK to MAIN_CLK.
-
enumerator kFRO1M_to_MAIN_CLK
Attach FRO1M to MAIN_CLK.
-
enumerator kFRO_HF_to_MAIN_CLK
Attach FRO_HF to MAIN_CLK.
-
enumerator kPLL0_to_MAIN_CLK
Attach PLL0 to MAIN_CLK.
-
enumerator kPLL1_to_MAIN_CLK
Attach PLL1 to MAIN_CLK.
-
enumerator kOSC32K_to_MAIN_CLK
Attach OSC32K to MAIN_CLK.
-
enumerator kSYSTICK_DIV_to_SYSTICK0
Attach SYSTICK_DIV to SYSTICK0.
-
enumerator kFRO1M_to_SYSTICK0
Attach FRO1M to SYSTICK0.
-
enumerator kOSC32K_to_SYSTICK0
Attach OSC32K to SYSTICK0.
-
enumerator kNONE_to_SYSTICK0
Attach NONE to SYSTICK0.
-
enumerator kTRACE_DIV_to_TRACE
Attach TRACE_DIV to TRACE.
-
enumerator kFRO1M_to_TRACE
Attach FRO1M to TRACE.
-
enumerator kOSC32K_to_TRACE
Attach OSC32K to TRACE.
-
enumerator kNONE_to_TRACE
Attach NONE to TRACE.
-
enumerator kMAIN_CLK_to_CTIMER0
Attach MAIN_CLK to CTIMER0.
-
enumerator kPLL0_to_CTIMER0
Attach PLL0 to CTIMER0.
-
enumerator kPLL1_to_CTIMER0
Attach PLL1 to CTIMER0.
-
enumerator kFRO_HF_to_CTIMER0
Attach FRO_HF to CTIMER0.
-
enumerator kFRO1M_to_CTIMER0
Attach FRO1M to CTIMER0.
-
enumerator kMCLK_IN_to_CTIMER0
-
enumerator kOSC32K_to_CTIMER0
Attach OSC32K to CTIMER0.
-
enumerator kNONE_to_CTIMER0
Attach NONE to CTIMER0.
-
enumerator kMAIN_CLK_to_CTIMER1
Attach MAIN_CLK to CTIMER1.
-
enumerator kPLL0_to_CTIMER1
Attach PLL0 to CTIMER1.
-
enumerator kPLL1_to_CTIMER1
Attach PLL1 to CTIMER1.
-
enumerator kFRO_HF_to_CTIMER1
Attach FRO_HF to CTIMER1.
-
enumerator kFRO1M_to_CTIMER1
Attach FRO1M to CTIMER1.
-
enumerator kMCLK_IN_to_CTIMER1
Attach MCLK_IN to CTIMER1.
-
enumerator kOSC32K_to_CTIMER1
Attach OSC32K to CTIMER1.
-
enumerator kNONE_to_CTIMER1
Attach NONE to CTIMER1.
-
enumerator kMAIN_CLK_to_CTIMER2
Attach MAIN_CLK to CTIMER2.
-
enumerator kPLL0_to_CTIMER2
Attach PLL0 to CTIMER2.
-
enumerator kPLL1_to_CTIMER2
Attach PLL1 to CTIMER2.
-
enumerator kFRO_HF_to_CTIMER2
Attach FRO_HF to CTIMER2.
-
enumerator kFRO1M_to_CTIMER2
Attach FRO1M to CTIMER2.
-
enumerator kMCLK_IN_to_CTIMER2
Attach MCLK_IN to CTIMER2.
-
enumerator kOSC32K_to_CTIMER2
Attach OSC32K to CTIMER2.
-
enumerator kNONE_to_CTIMER2
Attach NONE to CTIMER2.
-
enumerator kMAIN_CLK_to_CTIMER3
Attach MAIN_CLK to CTIMER3.
-
enumerator kPLL0_to_CTIMER3
Attach PLL0 to CTIMER3.
-
enumerator kPLL1_to_CTIMER3
Attach PLL1 to CTIMER3.
-
enumerator kFRO_HF_to_CTIMER3
Attach FRO_HF to CTIMER3.
-
enumerator kFRO1M_to_CTIMER3
Attach FRO1M to CTIMER3.
-
enumerator kMCLK_IN_to_CTIMER3
Attach MCLK_IN to CTIMER3.
-
enumerator kOSC32K_to_CTIMER3
Attach OSC32K to CTIMER3.
-
enumerator kNONE_to_CTIMER3
Attach NONE to CTIMER3.
-
enumerator kMAIN_CLK_to_CTIMER4
Attach MAIN_CLK to CTIMER4.
-
enumerator kPLL0_to_CTIMER4
Attach PLL0 to CTIMER4.
-
enumerator kPLL1_to_CTIMER4
Attach PLL1 to CTIMER4.
-
enumerator kFRO_HF_to_CTIMER4
Attach FRO_HF to CTIMER4.
-
enumerator kFRO1M_to_CTIMER4
Attach FRO1M to CTIMER4.
-
enumerator kMCLK_IN_to_CTIMER4
Attach MCLK_IN to CTIMER4.
-
enumerator kOSC32K_to_CTIMER4
Attach OSC32K to CTIMER4.
-
enumerator kNONE_to_CTIMER4
Attach NONE to CTIMER4.
-
enumerator kMAIN_CLK_to_CLKOUT
Attach MAIN_CLK to CLKOUT.
-
enumerator kPLL0_to_CLKOUT
Attach PLL0 to CLKOUT.
-
enumerator kEXT_CLK_to_CLKOUT
Attach EXT_CLK to CLKOUT.
-
enumerator kFRO_HF_to_CLKOUT
Attach FRO_HF to CLKOUT.
-
enumerator kFRO1M_to_CLKOUT
Attach FRO1M to CLKOUT.
-
enumerator kPLL1_to_CLKOUT
Attach PLL1 to CLKOUT.
-
enumerator kOSC32K_to_CLKOUT
Attach OSC32K to CLKOUT.
-
enumerator kNONE_to_CLKOUT
Attach NONE to CLKOUT.
-
enumerator kFRO12M_to_PLL0
Attach FRO12M to PLL0.
-
enumerator kEXT_CLK_to_PLL0
Attach EXT_CLK to PLL0.
-
enumerator kFRO1M_to_PLL0
Attach FRO1M to PLL0.
-
enumerator kOSC32K_to_PLL0
Attach OSC32K to PLL0.
-
enumerator kNONE_to_PLL0
Attach NONE to PLL0.
-
enumerator kFRO12M_to_PLL1
Attach FRO12M to PLL1.
-
enumerator kEXT_CLK_to_PLL1
Attach EXT_CLK to PLL1.
-
enumerator kFRO1M_to_PLL1
Attach FRO1M to PLL1.
-
enumerator kOSC32K_to_PLL1
Attach OSC32K to PLL1.
-
enumerator kNONE_to_PLL1
Attach NONE to PLL1.
-
enumerator kMCAN_DIV_to_MCAN
Attach MCAN_DIV to MCAN.
-
enumerator kFRO1M_to_MCAN
Attach FRO1M to MCAN.
-
enumerator kOSC32K_to_MCAN
Attach OSC32K to MCAN.
-
enumerator kNONE_to_MCAN
Attach NONE to MCAN.
-
enumerator kMAIN_CLK_to_ADC0
Attach MAIN_CLK to ADC0.
-
enumerator kPLL0_to_ADC0
Attach PLL0 to ADC0.
-
enumerator kFRO_HF_to_ADC0
Attach FRO_HF to ADC0.
-
enumerator kEXT_CLK_to_ADC0
Attach XO to ADC0.
-
enumerator kNONE_to_ADC0
Attach NONE to ADC0.
-
enumerator kMAIN_CLK_to_ADC1
Attach MAIN_CLK to ADC1.
-
enumerator kPLL0_to_ADC1
Attach PLL0 to ADC1.
-
enumerator kFRO_HF_to_ADC1
Attach FRO_HF to ADC1.
-
enumerator kEXT_CLK_to_ADC1
Attach XO to ADC1.
-
enumerator kNONE_to_ADC1
Attach NONE to ADC1.
-
enumerator kMAIN_CLK_to_USB0
Attach MAIN_CLK to USB0.
-
enumerator kPLL0_to_USB0
Attach PLL0 to USB0.
-
enumerator kFRO_HF_to_USB0
Attach FRO_HF to USB0.
-
enumerator kPLL1_to_USB0
Attach PLL1 to USB0.
-
enumerator kNONE_to_USB0
Attach NONE to USB0.
-
enumerator kMAIN_CLK_to_FLEXCOMM0
Attach MAIN_CLK to FLEXCOMM0.
-
enumerator kMAIN_CLK_FRG0_to_FLEXCOMM0
Attach Main clock to FlexComm0.
-
enumerator kPLL_CLK_DIV_FRG0_to_FLEXCOMM0
Attach PLL clock DIV Frg to FlexComm0.
-
enumerator kFRO_HF_DIV_FRG0_to_FLEXCOMM0
Attach FRO HF DIV FRG to FlexComm0.
-
enumerator kFRO12M_to_FLEXCOMM0
Attach FRO12M to FLEXCOMM0.
-
enumerator kFRO_HF_DIV_to_FLEXCOMM0
Attach FRO_HF_DIV to FLEXCOMM0.
-
enumerator kFRO1M_to_FLEXCOMM0
Attach FRO1M to FLEXCOMM0.
-
enumerator kMCLK_IN_to_FLEXCOMM0
Attach MCLK_IN to FLEXCOMM0.
-
enumerator kOSC32K_to_FLEXCOMM0
Attach OSC32K to FLEXCOMM0.
-
enumerator kNONE_to_FLEXCOMM0
Attach NONE to FLEXCOMM0.
-
enumerator kMAIN_CLK_to_FLEXCOMM1
Attach MAIN_CLK to FLEXCOMM1.
-
enumerator kMAIN_CLK_FRG1_to_FLEXCOMM1
Attach Main clock to FlexComm1.
-
enumerator kPLL_CLK_DIV_FRG1_to_FLEXCOMM1
Attach PLL clock DIV Frg to FlexComm1.
-
enumerator kFRO_HF_DIV_FRG1_to_FLEXCOMM1
Attach FRO HF DIV FRG to FlexComm1.
-
enumerator kFRO12M_to_FLEXCOMM1
Attach FRO12M to FLEXCOMM1.
-
enumerator kFRO_HF_DIV_to_FLEXCOMM1
Attach FRO_HF_DIV to FLEXCOMM1.
-
enumerator kFRO1M_to_FLEXCOMM1
Attach FRO1M to FLEXCOMM1.
-
enumerator kMCLK_IN_to_FLEXCOMM1
Attach MCLK_IN to FLEXCOMM1.
-
enumerator kOSC32K_to_FLEXCOMM1
Attach OSC32K to FLEXCOMM1.
-
enumerator kNONE_to_FLEXCOMM1
Attach NONE to FLEXCOMM1.
-
enumerator kMAIN_CLK_to_FLEXCOMM2
Attach MAIN_CLK to FLEXCOMM2.
-
enumerator kMAIN_CLK_FRG2_to_FLEXCOMM2
Attach Main clock to FlexComm2.
-
enumerator kPLL_CLK_DIV_FRG2_to_FLEXCOMM2
Attach PLL clock DIV Frg to FlexComm2.
-
enumerator kFRO_HF_DIV_FRG2_to_FLEXCOMM2
Attach FRO HF DIV FRG to FlexComm2.
-
enumerator kFRO12M_to_FLEXCOMM2
Attach FRO12M to FLEXCOMM2.
-
enumerator kFRO_HF_DIV_to_FLEXCOMM2
Attach FRO_HF_DIV to FLEXCOMM2.
-
enumerator kFRO1M_to_FLEXCOMM2
Attach FRO1M to FLEXCOMM2.
-
enumerator kMCLK_IN_to_FLEXCOMM2
Attach MCLK_IN to FLEXCOMM2.
-
enumerator kOSC32K_to_FLEXCOMM2
Attach OSC32K to FLEXCOMM2.
-
enumerator kNONE_to_FLEXCOMM2
Attach NONE to FLEXCOMM2.
-
enumerator kMAIN_CLK_to_FLEXCOMM3
Attach MAIN_CLK to FLEXCOMM3.
-
enumerator kMAIN_CLK_FRG3_to_FLEXCOMM3
Attach Main clock to FlexComm3.
-
enumerator kPLL_CLK_DIV_FRG3_to_FLEXCOMM3
Attach PLL clock DIV Frg to FlexComm3.
-
enumerator kFRO_HF_DIV_FRG3_to_FLEXCOMM3
Attach FRO HF DIV FRG to FlexComm3.
-
enumerator kFRO12M_to_FLEXCOMM3
Attach FRO12M to FLEXCOMM3.
-
enumerator kFRO_HF_DIV_to_FLEXCOMM3
Attach FRO_HF_DIV to FLEXCOMM3.
-
enumerator kFRO1M_to_FLEXCOMM3
Attach FRO1M to FLEXCOMM3.
-
enumerator kMCLK_IN_to_FLEXCOMM3
Attach MCLK_IN to FLEXCOMM3.
-
enumerator kOSC32K_to_FLEXCOMM3
Attach OSC32K to FLEXCOMM3.
-
enumerator kNONE_to_FLEXCOMM3
Attach NONE to FLEXCOMM3.
-
enumerator kMAIN_CLK_to_FLEXCOMM4
Attach MAIN_CLK to FLEXCOMM4.
-
enumerator kMAIN_CLK_FRG4_to_FLEXCOMM4
Attach Main clock to FlexComm4.
-
enumerator kPLL_CLK_DIV_FRG4_to_FLEXCOMM4
Attach PLL clock DIV Frg to FlexComm4.
-
enumerator kFRO_HF_DIV_FRG4_to_FLEXCOMM4
Attach FRO HF DIV FRG to FlexComm4.
-
enumerator kFRO12M_to_FLEXCOMM4
Attach FRO12M to FLEXCOMM4.
-
enumerator kFRO_HF_DIV_to_FLEXCOMM4
Attach FRO_HF_DIV to FLEXCOMM4.
-
enumerator kFRO1M_to_FLEXCOMM4
Attach FRO1M to FLEXCOMM4.
-
enumerator kMCLK_IN_to_FLEXCOMM4
Attach MCLK_IN to FLEXCOMM4.
-
enumerator kOSC32K_to_FLEXCOMM4
Attach OSC32K to FLEXCOMM4.
-
enumerator kNONE_to_FLEXCOMM4
Attach NONE to FLEXCOMM4.
-
enumerator kMAIN_CLK_to_FLEXCOMM5
Attach MAIN_CLK to FLEXCOMM5.
-
enumerator kMAIN_CLK_FRG5_to_FLEXCOMM5
Attach Main clock to FlexComm5.
-
enumerator kPLL_CLK_DIV_FRG5_to_FLEXCOMM5
Attach PLL clock DIV Frg to FlexComm5.
-
enumerator kFRO_HF_DIV_FRG5_to_FLEXCOMM5
Attach FRO HF DIV FRG to FlexComm5.
-
enumerator kFRO12M_to_FLEXCOMM5
Attach FRO12M to FLEXCOMM5.
-
enumerator kFRO_HF_DIV_to_FLEXCOMM5
Attach FRO_HF_DIV to FLEXCOMM5.
-
enumerator kFRO1M_to_FLEXCOMM5
Attach FRO1M to FLEXCOMM5.
-
enumerator kMCLK_IN_to_FLEXCOMM5
Attach MCLK_IN to FLEXCOMM5.
-
enumerator kOSC32K_to_FLEXCOMM5
Attach OSC32K to FLEXCOMM5.
-
enumerator kNONE_to_FLEXCOMM5
Attach NONE to FLEXCOMM5.
-
enumerator kMAIN_CLK_to_FLEXCOMM6
Attach MAIN_CLK to FLEXCOMM6.
-
enumerator kMAIN_CLK_FRG6_to_FLEXCOMM6
Attach Main clock to FlexComm6.
-
enumerator kPLL_CLK_DIV_FRG6_to_FLEXCOMM6
Attach PLL clock DIV Frg to FlexComm6.
-
enumerator kFRO_HF_DIV_FRG6_to_FLEXCOMM6
Attach FRO HF DIV FRG to FlexComm6.
-
enumerator kFRO12M_to_FLEXCOMM6
Attach FRO12M to FLEXCOMM6.
-
enumerator kFRO_HF_DIV_to_FLEXCOMM6
Attach FRO_HF_DIV to FLEXCOMM6.
-
enumerator kFRO1M_to_FLEXCOMM6
Attach FRO1M to FLEXCOMM6.
-
enumerator kMCLK_IN_to_FLEXCOMM6
Attach MCLK_IN to FLEXCOMM6.
-
enumerator kOSC32K_to_FLEXCOMM6
Attach OSC32K to FLEXCOMM6.
-
enumerator kNONE_to_FLEXCOMM6
Attach NONE to FLEXCOMM6.
-
enumerator kMAIN_CLK_to_FLEXCOMM7
Attach MAIN_CLK to FLEXCOMM7.
-
enumerator kMAIN_CLK_FRG7_to_FLEXCOMM7
Attach Main clock to FlexComm7.
-
enumerator kPLL_CLK_DIV_FRG7_to_FLEXCOMM7
Attach PLL clock DIV Frg to FlexComm7.
-
enumerator kFRO_HF_DIV_FRG7_to_FLEXCOMM7
Attach PLL clock DIV Frg to FlexComm7.
-
enumerator kFRO12M_to_FLEXCOMM7
Attach FRO12M to FLEXCOMM7.
-
enumerator kFRO_HF_DIV_to_FLEXCOMM7
Attach FRO_HF_DIV to FLEXCOMM7.
-
enumerator kFRO1M_to_FLEXCOMM7
Attach FRO1M to FLEXCOMM7.
-
enumerator kMCLK_IN_to_FLEXCOMM7
Attach MCLK_IN to FLEXCOMM7.
-
enumerator kOSC32K_to_FLEXCOMM7
Attach OSC32K to FLEXCOMM7.
-
enumerator kNONE_to_FLEXCOMM7
Attach NONE to FLEXCOMM7.
-
enumerator kMAIN_CLK_to_HSLSPI
Attach MAIN_CLK to HSLSPI.
-
enumerator kPLL_CLK_DIV_to_HSLSPI
Attach PLL_CLK_DIV to HSLSPI.
-
enumerator kFRO12M_to_HSLSPI
Attach FRO12M to HSLSPI.
-
enumerator kFRO_HF_DIV_to_HSLSPI
Attach FRO_HF_DIV to HSLSPI.
-
enumerator kFRO1M_to_HSLSPI
Attach FRO1M to HSLSPI.
-
enumerator kOSC32K_to_HSLSPI
Attach OSC32K to HSLSPI.
-
enumerator kNONE_to_HSLSPI
Attach NONE to HSLSPI.
-
enumerator kFRO_HF_to_MCLK
Attach FRO_HF to MCLK.
-
enumerator kPLL0_to_MCLK
Attach PLL0 to MCLK.
-
enumerator kNONE_to_MCLK
Attach NONE to MCLK.
-
enumerator kMAIN_CLK_to_SCT
Attach MAIN_CLK to SCT.
-
enumerator kPLL0_to_SCT
Attach PLL0 to SCT.
-
enumerator kEXT_CLK_to_SCT
Attach EXT_CLK to SCT.
-
enumerator kFRO_HF_to_SCT
Attach FRO_HF to SCT.
-
enumerator kPLL1_to_SCT
Attach PLL1 to SCT.
-
enumerator kMCLK_IN_to_SCT
Attach MCLK_IN to SCT.
-
enumerator kNONE_to_SCT
Attach NONE to SCT.
-
enumerator kMAIN_CLK_to_DAC0
Attach MAIN_CLK to DAC0.
-
enumerator kPLL0_to_DAC0
Attach PLL0 to DAC0.
-
enumerator kFRO_HF_to_DAC0
Attach FRO_HF to DAC0.
-
enumerator kFRO12M_to_DAC0
Attach FRO12M to DAC0.
-
enumerator kPLL1_to_DAC0
Attach PLL1 to DAC0.
-
enumerator kFRO1M_to_DAC0
Attach FRO1M to DAC0.
-
enumerator kNONE_to_DAC0
Attach NONE to DAC0.
-
enumerator kMAIN_CLK_to_DAC1
Attach MAIN_CLK to DAC1.
-
enumerator kPLL0_to_DAC1
Attach PLL0 to DAC1.
-
enumerator kFRO_HF_to_DAC1
Attach FRO_HF to DAC1.
-
enumerator kFRO12M_to_DAC1
Attach FRO12M to DAC1.
-
enumerator kPLL1_to_DAC1
Attach PLL1 to DAC1.
-
enumerator kFRO1M_to_DAC1
Attach FRO1M to DAC1.
-
enumerator kNONE_to_DAC1
Attach NONE to DAC1.
-
enumerator kMAIN_CLK_to_DAC2
Attach MAIN_CLK to DAC2.
-
enumerator kPLL0_to_DAC2
Attach PLL0 to DAC2.
-
enumerator kFRO_HF_to_DAC2
Attach FRO_HF to DAC2.
-
enumerator kFRO12M_to_DAC2
Attach FRO12M to DAC2.
-
enumerator kPLL1_to_DAC2
Attach PLL1 to DAC2.
-
enumerator kFRO1M_to_DAC2
Attach FRO1M to DAC2.
-
enumerator kNONE_to_DAC2
Attach NONE to DAC2.
-
enumerator kMAIN_CLK_to_FLEXSPI
Attach MAIN_CLK to FLEXSPI.
-
enumerator kPLL0_to_FLEXSPI
Attach PLL0 to FLEXSPI.
-
enumerator kFRO_HF_to_FLEXSPI
Attach FRO_HF to FLEXSPI.
-
enumerator kPLL1_to_FLEXSPI
Attach PLL1 to FLEXSPI.
-
enumerator kNONE_to_FLEXSPI
Attach NONE to FLEXSPI.
-
enumerator kPLL0_to_PLLCLKDIV
Attach PLL0 to PLLCLKDIV.
-
enumerator kPLL1_to_PLLCLKDIV
Attach PLL1 to PLLCLKDIV.
-
enumerator kNONE_to_PLLCLKDIV
Attach NONE to PLLCLKDIV.
-
enumerator kMAIN_CLK_to_I3CFCLK
Attach MAIN_CLK to I3CFCLK.
-
enumerator kFRO_HF_DIV_to_I3CFCLK
Attach FRO_HF_DIV to I3CFCLK.
-
enumerator kNONE_to_I3CFCLK
Attach NONE to I3CFCLK.
-
enumerator kI3CFCLKSEL_to_I3CFCLKSTC
Attach I3CFCLKSEL to I3CFCLKSTC.
-
enumerator kFRO1M_to_I3CFCLKSTC
Attach FRO1M to I3CFCLKSTC.
-
enumerator kNONE_to_I3CFCLKSTC
Attach NONE to I3CFCLKSTC.
-
enumerator kMAIN_CLK_to_DMIC
Attach MAIN_CLK to DMIC.
-
enumerator kPLL0_to_DMIC
Attach PLL0 to DMIC.
-
enumerator kEXT_CLK_to_DMIC
Attach EXT_CLK to DMIC.
-
enumerator kFRO_HF_to_DMIC
Attach FRO_HF to DMIC.
-
enumerator kPLL1_to_DMIC
Attach PLL1 to DMIC.
-
enumerator kMCLK_IN_to_DMIC
Attach MCLK_IN to DMIC.
-
enumerator kNONE_to_DMIC
Attach NONE to DMIC.
-
enumerator kFRO32K_to_FCOSC32K
Attach FRO32K to FCOSC32K.
-
enumerator kXTAL32K_to_FCOSC32K
Attach XTAL32K to FCOSC32K.
-
enumerator kFRO32K_to_OSC32K
Attach FRO32K to OSC32K.
-
enumerator kXTAL32K_to_OSC32K
Attach XTAL32K to OSC32K.
-
enumerator kFRO32K_to_FC32K
Attach FRO32K to FC32K.
-
enumerator kXTAL32K_to_FC32K
Attach XTAL32K to FC32K.
-
enumerator kFRO32K_to_OSTIMER
Attach FRO32K to OSTIMER.
-
enumerator kOSC32K_to_OSTIMER
Attach OSC32K to OSTIMER.
-
enumerator kFRO1M_to_OSTIMER
Attach FRO1M to OSTIMER.
-
enumerator kAHB_CLK_to_OSTIMER
Attach AHB_CLK to OSTIMER.
-
enumerator kNONE_to_NONE
Attach NONE to NONE.
-
enumerator kFRO12M_to_MAIN_CLK
-
enum _clock_div_name
Clock dividers.
Values:
-
enumerator kCLOCK_DivSystickClk
Systick Clock Divider.
-
enumerator kCLOCK_DivArmTrClkDiv
Trace Clock Divider.
-
enumerator kCLOCK_DivCanClk
Can Clock Divider.
-
enumerator kCLOCK_DivFlexFrg0
FRGCTRL0 register.
-
enumerator kCLOCK_DivFlexFrg1
FRGCTRL1 register.
-
enumerator kCLOCK_DivFlexFrg2
FRGCTRL2 register.
-
enumerator kCLOCK_DivFlexFrg3
FRGCTRL3 register.
-
enumerator kCLOCK_DivFlexFrg4
FRGCTRL4 register.
-
enumerator kCLOCK_DivFlexFrg5
FRGCTRL5 register.
-
enumerator kCLOCK_DivFlexFrg6
FRGCTRL6 register.
-
enumerator kCLOCK_DivFlexFrg7
FRGCTRL7 register.
-
enumerator kCLOCK_DivAhbClk
Ahb Clock Divider.
-
enumerator kCLOCK_DivClkOut
Clk Out Divider.
-
enumerator kCLOCK_DivFrohfClk
Frohf Divider.
-
enumerator kCLOCK_DivWdtClk
Wdt Clock Divider.
-
enumerator kCLOCK_DivAdc0Clk
Adc0 Clock Divider.
-
enumerator kCLOCK_DivUsb0Clk
Usb0 Clock Divider.
-
enumerator kCLOCK_DivMclk
Mclk Divider.
-
enumerator kCLOCK_DivSctClk
Sct Clock Divider.
-
enumerator kCLOCK_DivPllClk
Pll0 Clock Divider.
-
enumerator kCLOCK_DivCtimer0Clk
Ctimer0 Clock Divider.
-
enumerator kCLOCK_DivCtimer1Clk
Ctimer1 Clock Divider.
-
enumerator kCLOCK_DivCtimer2Clk
Ctimer2 Clock Divider.
-
enumerator kCLOCK_DivCtimer3Clk
Ctimer3 Clock Divider.
-
enumerator kCLOCK_DivCtimer4Clk
Ctimer4 Clock Divider.
-
enumerator kCLOCK_DivAdc1Clk
Adc1 Clock Divider.
-
enumerator kCLOCK_DivDac0Clk
Dac0 Clock Divider.
-
enumerator kCLOCK_DivDac1Clk
Dac1 Clock Divider.
-
enumerator kCLOCK_DivDac2Clk
Dac2 Clock Divider.
-
enumerator kCLOCK_DivFlexSpiClk
Flex Spi Clock Divider.
-
enumerator kCLOCK_DivI3cFclkStc
I3c Fclk Stc Divider.
-
enumerator kCLOCK_DivI3cFclkS
I3c Fclk S Divider.
-
enumerator kCLOCK_DivI3cFclk
I3c Fclk Divider.
-
enumerator kCLOCK_DivDmicClk
Dmic Clock Divider.
-
enumerator kCLOCK_DivFlexcom0Clk
Flexcom0 Clock Divider.
-
enumerator kCLOCK_DivFlexcom1Clk
Flexcom1 Clock Divider.
-
enumerator kCLOCK_DivFlexcom2Clk
Flexcom2 Clock Divider.
-
enumerator kCLOCK_DivFlexcom3Clk
Flexcom3 Clock Divider.
-
enumerator kCLOCK_DivFlexcom4Clk
Flexcom4 Clock Divider.
-
enumerator kCLOCK_DivFlexcom5Clk
Flexcom5 Clock Divider.
-
enumerator kCLOCK_DivFlexcom6Clk
Flexcom6 Clock Divider.
-
enumerator kCLOCK_DivFlexcom7Clk
Flexcom7 Clock Divider.
-
enumerator kCLOCK_DivSystickClk
-
enum _ss_progmodfm
PLL Spread Spectrum (SS) Programmable modulation frequency See (MF) field in the PLL0SSCG1 register in the UM.
Values:
-
enumerator kSS_MF_512
Nss = 512 (fm ? 3.9 - 7.8 kHz)
-
enumerator kSS_MF_384
Nss ?= 384 (fm ? 5.2 - 10.4 kHz)
-
enumerator kSS_MF_256
Nss = 256 (fm ? 7.8 - 15.6 kHz)
-
enumerator kSS_MF_128
Nss = 128 (fm ? 15.6 - 31.3 kHz)
-
enumerator kSS_MF_64
Nss = 64 (fm ? 32.3 - 64.5 kHz)
-
enumerator kSS_MF_32
Nss = 32 (fm ? 62.5- 125 kHz)
-
enumerator kSS_MF_24
Nss ?= 24 (fm ? 83.3- 166.6 kHz)
-
enumerator kSS_MF_16
Nss = 16 (fm ? 125- 250 kHz)
-
enumerator kSS_MF_512
-
enum _ss_progmoddp
PLL Spread Spectrum (SS) Programmable frequency modulation depth See (MR) field in the PLL0SSCG1 register in the UM.
Values:
-
enumerator kSS_MR_K0
k = 0 (no spread spectrum)
-
enumerator kSS_MR_K1
k = 1
-
enumerator kSS_MR_K1_5
k = 1.5
-
enumerator kSS_MR_K2
k = 2
-
enumerator kSS_MR_K3
k = 3
-
enumerator kSS_MR_K4
k = 4
-
enumerator kSS_MR_K6
k = 6
-
enumerator kSS_MR_K8
k = 8
-
enumerator kSS_MR_K0
-
enum _ss_modwvctrl
PLL Spread Spectrum (SS) Modulation waveform control See (MC) field in the PLL0SSCG1 register in the UM.
Compensation for low pass filtering of the PLL to get a triangular modulation at the output of the PLL, giving a flat frequency spectrum.
Values:
-
enumerator kSS_MC_NOC
no compensation
-
enumerator kSS_MC_RECC
recommended setting
-
enumerator kSS_MC_MAXC
max. compensation
-
enumerator kSS_MC_NOC
-
enum _pll_error
PLL status definitions.
Values:
-
enumerator kStatus_PLL_Success
PLL operation was successful
-
enumerator kStatus_PLL_OutputTooLow
PLL output rate request was too low
-
enumerator kStatus_PLL_OutputTooHigh
PLL output rate request was too high
-
enumerator kStatus_PLL_InputTooLow
PLL input rate is too low
-
enumerator kStatus_PLL_InputTooHigh
PLL input rate is too high
-
enumerator kStatus_PLL_OutsideIntLimit
Requested output rate isn’t possible
-
enumerator kStatus_PLL_CCOTooLow
Requested CCO rate isn’t possible
-
enumerator kStatus_PLL_CCOTooHigh
Requested CCO rate isn’t possible
-
enumerator kStatus_PLL_Success
-
enum _clock_usbfs_src
USB FS clock source definition.
Values:
-
enumerator kCLOCK_UsbfsSrcFro
Use FRO 96 MHz.
-
enumerator kCLOCK_UsbfsSrcPll0
Use PLL0 output.
-
enumerator kCLOCK_UsbfsSrcMainClock
Use Main clock.
-
enumerator kCLOCK_UsbfsSrcPll1
Use PLL1 clock.
-
enumerator kCLOCK_UsbfsSrcNone
this may be selected in order to reduce power when no output is needed.
-
enumerator kCLOCK_UsbfsSrcFro
-
enum _clock_usb_phy_src
Source of the USB HS PHY.
Values:
-
enumerator kCLOCK_UsbPhySrcExt
Use external crystal.
-
enumerator kCLOCK_UsbPhySrcExt
-
typedef enum _clock_ip_name clock_ip_name_t
Clock gate name used for CLOCK_EnableClock/CLOCK_DisableClock.
-
typedef enum _clock_name clock_name_t
Clock name used to get clock frequency.
-
typedef enum _clock_attach_id clock_attach_id_t
The enumerator of clock attach Id.
-
typedef enum _clock_div_name clock_div_name_t
Clock dividers.
-
typedef enum _ss_progmodfm ss_progmodfm_t
PLL Spread Spectrum (SS) Programmable modulation frequency See (MF) field in the PLL0SSCG1 register in the UM.
-
typedef enum _ss_progmoddp ss_progmoddp_t
PLL Spread Spectrum (SS) Programmable frequency modulation depth See (MR) field in the PLL0SSCG1 register in the UM.
-
typedef enum _ss_modwvctrl ss_modwvctrl_t
PLL Spread Spectrum (SS) Modulation waveform control See (MC) field in the PLL0SSCG1 register in the UM.
Compensation for low pass filtering of the PLL to get a triangular modulation at the output of the PLL, giving a flat frequency spectrum.
-
typedef struct _pll_config pll_config_t
PLL configuration structure.
This structure can be used to configure the settings for a PLL setup structure. Fill in the desired configuration for the PLL and call the PLL setup function to fill in a PLL setup structure.
-
typedef struct _pll_setup pll_setup_t
PLL0 setup structure This structure can be used to pre-build a PLL setup configuration at run-time and quickly set the PLL to the configuration. It can be populated with the PLL setup function. If powering up or waiting for PLL lock, the PLL input clock source should be configured prior to PLL setup.
-
typedef enum _pll_error pll_error_t
PLL status definitions.
-
typedef enum _clock_usbfs_src clock_usbfs_src_t
USB FS clock source definition.
-
typedef enum _clock_usb_phy_src clock_usb_phy_src_t
Source of the USB HS PHY.
-
static inline void CLOCK_EnableClock(clock_ip_name_t clk)
Enable the clock for specific IP.
- Parameters:
clk – : Clock to be enabled.
- Returns:
Nothing
-
static inline void CLOCK_DisableClock(clock_ip_name_t clk)
Disable the clock for specific IP.
- Parameters:
clk – : Clock to be Disabled.
- Returns:
Nothing
-
status_t CLOCK_SetupFROClocking(uint32_t iFreq)
Initialize the Core clock to given frequency (12, 48 or 96 MHz). Turns on FRO and uses default CCO, if freq is 12000000, then high speed output is off, else high speed output is enabled.
- Parameters:
iFreq – : Desired frequency (must be one of CLK_FRO_12MHZ or CLK_FRO_48MHZ or CLK_FRO_96MHZ)
- Returns:
returns success or fail status.
-
void CLOCK_SetFLASHAccessCyclesForFreq(uint32_t system_freq_hz)
Set the flash wait states for the input freuqency.
- Parameters:
system_freq_hz – Input frequency
- Returns:
Nothing
-
status_t CLOCK_SetupExtClocking(uint32_t iFreq)
Initialize the external osc clock to given frequency.
- Parameters:
iFreq – : Desired frequency (must be equal to exact rate in Hz)
- Returns:
returns success or fail status.
-
status_t CLOCK_SetupI2SMClkClocking(uint32_t iFreq)
Initialize the I2S MCLK clock to given frequency.
- Parameters:
iFreq – : Desired frequency (must be equal to exact rate in Hz)
- Returns:
returns success or fail status.
-
void CLOCK_AttachClk(clock_attach_id_t connection)
Configure the clock selection muxes.
- Parameters:
connection – : Clock to be configured.
- Returns:
Nothing
-
clock_attach_id_t CLOCK_GetClockAttachId(clock_attach_id_t attachId)
Get the actual clock attach id. This fuction uses the offset in input attach id, then it reads the actual source value in the register and combine the offset to obtain an actual attach id.
- Parameters:
attachId – : Clock attach id to get.
- Returns:
Clock source value.
-
void CLOCK_SetClkDiv(clock_div_name_t div_name, uint32_t divided_by_value, bool reset)
Setup peripheral clock dividers.
- Parameters:
div_name – : Clock divider name
divided_by_value – Value to be divided
reset – : Whether to reset the divider counter.
- Returns:
Nothing
-
uint32_t CLOCK_GetFreq(clock_name_t clockName)
Return Frequency of selected clock.
- Returns:
Frequency of selected clock
-
uint32_t CLOCK_GetFro12MFreq(void)
Return Frequency of FRO 12MHz.
- Returns:
Frequency of FRO 12MHz
-
uint32_t CLOCK_GetFro1MFreq(void)
Return Frequency of FRO 1MHz.
- Returns:
Frequency of FRO 1MHz
-
uint32_t CLOCK_GetClockOutClkFreq(void)
Return Frequency of ClockOut.
- Returns:
Frequency of ClockOut
-
uint32_t CLOCK_GetMCanClkFreq(void)
Return Frequency of Can Clock.
- Returns:
Frequency of Can.
-
uint32_t CLOCK_GetAdcClkFreq(uint32_t id)
Return Frequency of Adc Clock.
- Returns:
Frequency of Adc.
-
uint32_t CLOCK_GetUsb0ClkFreq(void)
Return Frequency of Usb0 Clock.
- Returns:
Frequency of Usb0 Clock.
-
uint32_t CLOCK_GetMclkClkFreq(void)
Return Frequency of MClk Clock.
- Returns:
Frequency of MClk Clock.
-
uint32_t CLOCK_GetSctClkFreq(void)
Return Frequency of SCTimer Clock.
- Returns:
Frequency of SCTimer Clock.
-
uint32_t CLOCK_GetExtClkFreq(void)
Return Frequency of External Clock.
- Returns:
Frequency of External Clock. If no external clock is used returns 0.
-
uint32_t CLOCK_GetWdtClkFreq(void)
Return Frequency of Watchdog.
- Returns:
Frequency of Watchdog
-
uint32_t CLOCK_GetFroHfFreq(void)
Return Frequency of High-Freq output of FRO.
- Returns:
Frequency of High-Freq output of FRO
-
uint32_t CLOCK_GetPll0OutFreq(void)
Return Frequency of PLL.
- Returns:
Frequency of PLL
-
uint32_t CLOCK_GetPll1OutFreq(void)
Return Frequency of USB PLL.
- Returns:
Frequency of PLL
-
uint32_t CLOCK_GetPllClkDivFreq(void)
Return Frequency of PLL_CLK_DIV.
- Returns:
Frequency of PLL_CLK_DIV
-
uint32_t CLOCK_GetOsc32KFreq(void)
Return Frequency of 32kHz osc.
- Returns:
Frequency of 32kHz osc
-
uint32_t CLOCK_GetFC32KFreq(void)
Return Frequency of Flexcomm 32kHz osc.
- Returns:
Frequency of Flexcomm 32kHz osc
-
uint32_t CLOCK_GetCoreSysClkFreq(void)
Return Frequency of Core System.
- Returns:
Frequency of Core System
-
uint32_t CLOCK_GetI2SMClkFreq(void)
Return Frequency of I2S MCLK Clock.
- Returns:
Frequency of I2S MCLK Clock
-
uint32_t CLOCK_GetFrgFreq(uint32_t id)
Return Frequency of FRG Clock.
- Returns:
Frequency of FRG Clock
-
uint32_t CLOCK_GetFlexCommClkFreq(uint32_t id)
Return Frequency of FlexComm Clock.
- Returns:
Frequency of FlexComm Clock
-
uint32_t CLOCK_GetHsLspiClkFreq(void)
Return Frequency of High speed SPI Clock.
- Returns:
Frequency of High speed SPI Clock
-
uint32_t CLOCK_GetCTimerClkFreq(uint32_t id)
Return Frequency of CTimer functional Clock.
- Returns:
Frequency of CTimer functional Clock
-
uint32_t CLOCK_GetSystickClkFreq(void)
Return Frequency of SystickClock.
- Returns:
Frequency of Systick Clock
-
uint32_t CLOCK_GetFlexSpiClkFreq(void)
Return Frequency of FlexSPI.
- Returns:
Frequency of FlexSPI Clock
-
uint32_t CLOCK_GetDmicClkFreq(void)
Return Frequency of DMIC.
- Returns:
Frequency of DMIC Clock
-
uint32_t CLOCK_GetDacClkFreq(uint32_t id)
Return Frequency of DAC Clock.
- Returns:
Frequency of DAC Clock
-
uint32_t CLOCK_GetI3cSTCClkFreq(void)
Return Frequency of I3C function slow TC Clock.
- Returns:
Frequency of I3C function slow TC Clock
-
uint32_t CLOCK_GetI3cSClkFreq(void)
Return Frequency of I3C function slow Clock.
- Returns:
Frequency of I3C function slow Clock
-
uint32_t CLOCK_GetI3cClkFreq(void)
Return Frequency of I3C function Clock.
- Returns:
Frequency of I3C function Clock
-
uint32_t CLOCK_GetPLL0InClockRate(void)
Return PLL0 input clock rate.
- Returns:
PLL0 input clock rate
-
uint32_t CLOCK_GetPLL1InClockRate(void)
Return PLL1 input clock rate.
- Returns:
PLL1 input clock rate
-
uint32_t CLOCK_GetPLL0OutClockRate(bool recompute)
Return PLL0 output clock rate.
Note
The PLL rate is cached in the driver in a variable as the rate computation function can take some time to perform. It is recommended to use ‘false’ with the ‘recompute’ parameter.
- Parameters:
recompute – : Forces a PLL rate recomputation if true
- Returns:
PLL0 output clock rate
-
uint32_t CLOCK_GetPLL1OutClockRate(bool recompute)
Return PLL1 output clock rate.
Note
The PLL rate is cached in the driver in a variable as the rate computation function can take some time to perform. It is recommended to use ‘false’ with the ‘recompute’ parameter.
- Parameters:
recompute – : Forces a PLL rate recomputation if true
- Returns:
PLL1 output clock rate
- __STATIC_INLINE void CLOCK_SetBypassPLL0 (bool bypass)
Enables and disables PLL0 bypass mode.
bypass : true to bypass PLL0 (PLL0 output = PLL0 input, false to disable bypass
- Returns:
PLL0 output clock rate
- __STATIC_INLINE void CLOCK_SetBypassPLL1 (bool bypass)
Enables and disables PLL1 bypass mode.
bypass : true to bypass PLL1 (PLL1 output = PLL1 input, false to disable bypass
- Returns:
PLL1 output clock rate
- __STATIC_INLINE bool CLOCK_IsPLL0Locked (void)
Check if PLL is locked or not.
- Returns:
true if the PLL is locked, false if not locked
- __STATIC_INLINE bool CLOCK_IsPLL1Locked (void)
Check if PLL1 is locked or not.
- Returns:
true if the PLL1 is locked, false if not locked
-
void CLOCK_SetStoredPLL0ClockRate(uint32_t rate)
Store the current PLL0 rate.
- Parameters:
rate – Current rate of the PLL0
- Returns:
Nothing
-
uint32_t CLOCK_GetPLL0OutFromSetup(pll_setup_t *pSetup)
Return PLL0 output clock rate from setup structure.
- Parameters:
pSetup – : Pointer to a PLL setup structure
- Returns:
System PLL output clock rate the setup structure will generate
-
uint32_t CLOCK_GetPLL1OutFromSetup(pll_setup_t *pSetup)
Return PLL1 output clock rate from setup structure.
- Parameters:
pSetup – : Pointer to a PLL setup structure
- Returns:
PLL0 output clock rate the setup structure will generate
-
pll_error_t CLOCK_SetupPLL0Data(pll_config_t *pControl, pll_setup_t *pSetup)
Set PLL0 output based on the passed PLL setup data.
Note
Actual frequency for setup may vary from the desired frequency based on the accuracy of input clocks, rounding, non-fractional PLL mode, etc.
- Parameters:
pControl – : Pointer to populated PLL control structure to generate setup with
pSetup – : Pointer to PLL setup structure to be filled
- Returns:
PLL_ERROR_SUCCESS on success, or PLL setup error code
-
pll_error_t CLOCK_SetupPLL0Prec(pll_setup_t *pSetup, uint32_t flagcfg)
Set PLL output from PLL setup structure (precise frequency)
Note
This function will power off the PLL, setup the PLL with the new setup data, and then optionally powerup the PLL, wait for PLL lock, and adjust system voltages to the new PLL rate. The function will not alter any source clocks (ie, main systen clock) that may use the PLL, so these should be setup prior to and after exiting the function.
- Parameters:
pSetup – : Pointer to populated PLL setup structure
flagcfg – : Flag configuration for PLL config structure
- Returns:
PLL_ERROR_SUCCESS on success, or PLL setup error code
-
pll_error_t CLOCK_SetPLL0Freq(const pll_setup_t *pSetup)
Set PLL output from PLL setup structure (precise frequency)
Note
This function will power off the PLL, setup the PLL with the new setup data, and then optionally powerup the PLL, wait for PLL lock, and adjust system voltages to the new PLL rate. The function will not alter any source clocks (ie, main systen clock) that may use the PLL, so these should be setup prior to and after exiting the function.
- Parameters:
pSetup – : Pointer to populated PLL setup structure
- Returns:
kStatus_PLL_Success on success, or PLL setup error code
-
pll_error_t CLOCK_SetPLL1Freq(const pll_setup_t *pSetup)
Set PLL output from PLL setup structure (precise frequency)
Note
This function will power off the PLL, setup the PLL with the new setup data, and then optionally powerup the PLL, wait for PLL lock, and adjust system voltages to the new PLL rate. The function will not alter any source clocks (ie, main systen clock) that may use the PLL, so these should be setup prior to and after exiting the function.
- Parameters:
pSetup – : Pointer to populated PLL setup structure
- Returns:
kStatus_PLL_Success on success, or PLL setup error code
-
void CLOCK_SetupPLL0Mult(uint32_t multiply_by, uint32_t input_freq)
Set PLL0 output based on the multiplier and input frequency.
Note
Unlike the Chip_Clock_SetupSystemPLLPrec() function, this function does not disable or enable PLL power, wait for PLL lock, or adjust system voltages. These must be done in the application. The function will not alter any source clocks (ie, main systen clock) that may use the PLL, so these should be setup prior to and after exiting the function.
- Parameters:
multiply_by – : multiplier
input_freq – : Clock input frequency of the PLL
- Returns:
Nothing
-
static inline void CLOCK_DisableUsbDevicefs0Clock(clock_ip_name_t clk)
Disable USB clock.
Disable USB clock.
-
bool CLOCK_EnableUsbfs0DeviceClock(clock_usbfs_src_t src, uint32_t freq)
Enable USB Device FS clock.
- Parameters:
src – : clock source
freq – clock frequency Enable USB Device Full Speed clock.
-
bool CLOCK_EnableUsbfs0HostClock(clock_usbfs_src_t src, uint32_t freq)
Enable USB HOST FS clock.
- Parameters:
src – : clock source
freq – clock frequency Enable USB HOST Full Speed clock.
-
void CLOCK_EnableOstimer32kClock(void)
Enable the OSTIMER 32k clock.
- Returns:
Nothing
-
void CLOCK_XtalHfCapabankTrim(int32_t pi32_hfXtalIecLoadpF_x100, int32_t pi32_hfXtalPPcbParCappF_x100, int32_t pi32_hfXtalNPcbParCappF_x100)
Sets board-specific trim values for High Frequency crystal oscillator.
Note
Following default Values can be used: pi32_32MfXtalIecLoadpF_x100 Load capacitance, pF x 100 : 600 pi32_32MfXtalPPcbParCappF_x100 PCB +ve parasitic capacitance, pF x 100 : 20 pi32_32MfXtalNPcbParCappF_x100 PCB -ve parasitic capacitance, pF x 100 : 40
- Parameters:
pi32_hfXtalIecLoadpF_x100 – Load capacitance, pF x 100. For example, 6pF becomes 600, 1.2pF becomes 120
pi32_hfXtalPPcbParCappF_x100 – PCB +ve parasitic capacitance, pF x 100. For example, 6pF becomes 600, 1.2pF becomes 120
pi32_hfXtalNPcbParCappF_x100 – PCB -ve parasitic capacitance, pF x 100. For example, 6pF becomes 600, 1.2pF becomes 120
- Returns:
none
-
void CLOCK_Xtal32khzCapabankTrim(int32_t pi32_32kfXtalIecLoadpF_x100, int32_t pi32_32kfXtalPPcbParCappF_x100, int32_t pi32_32kfXtalNPcbParCappF_x100)
Sets board-specific trim values for 32kHz XTAL.
Note
Following default Values can be used: pi32_32kfXtalIecLoadpF_x100 Load capacitance, pF x 100 : 600 pi32_32kfXtalPPcbParCappF_x100 PCB +ve parasitic capacitance, pF x 100 : 40 pi32_32kfXtalNPcbParCappF_x100 PCB -ve parasitic capacitance, pF x 100 : 40
- Parameters:
pi32_32kfXtalIecLoadpF_x100 – Load capacitance, pF x 100. For example, 6pF becomes 600, 1.2pF becomes 120
pi32_32kfXtalPPcbParCappF_x100 – PCB +ve parasitic capacitance, pF x 100. For example, 6pF becomes 600, 1.2pF becomes 120
pi32_32kfXtalNPcbParCappF_x100 – PCB -ve parasitic capacitance, pF x 100. For example, 6pF becomes 600, 1.2pF becomes 120
- Returns:
none
-
void CLOCK_FroHfTrim(void)
Initialize the trim value for FRO HF.
- Returns:
none
-
FSL_CLOCK_DRIVER_VERSION
CLOCK driver version 2.3.3.
-
FSL_SDK_DISABLE_DRIVER_CLOCK_CONTROL
Configure whether driver controls clock.
When set to 0, peripheral drivers will enable clock in initialize function and disable clock in de-initialize function. When set to 1, peripheral driver will not control the clock, application could control the clock out of the driver.
Note
All drivers share this feature switcher. If it is set to 1, application should handle clock enable and disable for all drivers.
-
CLOCK_USR_CFG_PLL_CONFIG_CACHE_COUNT
User-defined the size of cache for CLOCK_PllGetConfig() function.
Once define this MACRO to be non-zero value, CLOCK_PllGetConfig() function would cache the recent calulation and accelerate the execution to get the right settings.
-
SDK_DEVICE_MAXIMUM_CPU_CLOCK_FREQUENCY
-
ROM_CLOCKS
Clock ip name array for ROM.
-
SRAM_CLOCKS
Clock ip name array for SRAM.
-
FLASH_CLOCKS
Clock ip name array for FLASH.
-
FMC_CLOCKS
Clock ip name array for FMC.
-
INPUTMUX_CLOCKS
Clock ip name array for INPUTMUX.
-
IOCON_CLOCKS
Clock ip name array for IOCON.
-
GPIO_CLOCKS
Clock ip name array for GPIO.
-
PINT_CLOCKS
Clock ip name array for PINT.
-
GINT_CLOCKS
Clock ip name array for GINT.
-
DMA_CLOCKS
Clock ip name array for DMA.
-
CRC_CLOCKS
Clock ip name array for CRC.
-
WWDT_CLOCKS
Clock ip name array for WWDT.
-
RTC_CLOCKS
Clock ip name array for RTC.
-
MAILBOX_CLOCKS
Clock ip name array for Mailbox.
-
LPADC_CLOCKS
Clock ip name array for LPADC.
-
LPDAC_CLOCKS
Clock ip name array for DAC.
-
MRT_CLOCKS
Clock ip name array for MRT.
-
OSTIMER_CLOCKS
Clock ip name array for OSTIMER.
-
SCT_CLOCKS
Clock ip name array for SCT0.
-
MCAN_CLOCKS
Clock ip name array for MCAN.
-
UTICK_CLOCKS
Clock ip name array for UTICK.
-
FLEXCOMM_CLOCKS
Clock ip name array for FLEXCOMM.
-
LPUART_CLOCKS
Clock ip name array for LPUART.
-
BI2C_CLOCKS
Clock ip name array for BI2C.
-
LPSPI_CLOCKS
Clock ip name array for LSPI.
-
FLEXI2S_CLOCKS
Clock ip name array for FLEXI2S.
-
CTIMER_CLOCKS
Clock ip name array for CTIMER.
-
COMP_CLOCKS
Clock ip name array for COMP.
-
FREQME_CLOCKS
Clock ip name array for FREQME.
-
CDOG_CLOCKS
Clock ip name array for CDOG.
-
RNG_CLOCKS
Clock ip name array for RNG.
-
USBHMR0_CLOCKS
Clock ip name array for USBHMR0.
-
USBHSL0_CLOCKS
Clock ip name array for USBHSL0.
-
ANALOGCTRL_CLOCKS
Clock ip name array for ANALOGCTRL.
-
HS_LSPI_CLOCKS
Clock ip name array for HS_LSPI.
-
GPIO_SEC_CLOCKS
Clock ip name array for GPIO_SEC.
-
GPIO_SEC_INT_CLOCKS
Clock ip name array for GPIO_SEC_INT.
-
USBD_CLOCKS
Clock ip name array for USBD.
-
SYSCTL_CLOCKS
Clock ip name array for SYSCTL.
-
DMIC_CLOCKS
Clock ip name array for DMIC.
-
PWM_CLOCKS
Clock ip name array for PWM.
-
ENC_CLOCKS
Clock ip name array for ENC.
-
OPAMP_CLOCKS
Clock ip name array for OPAMP.
-
VREF_CLOCKS
Clock ip name array for VREF.
-
FLEXSPI_CLOCKS
Clock ip name array for FLEXSPI.
-
CACHE64_CLOCKS
Clock ip name array for Cache64.
-
I3C_CLOCKS
Clock ip name array for I3C.
-
HSCMP_CLOCKS
Clock ip name array for HSCMP.
-
POWERQUAD_CLOCKS
Clock ip name array for PowerQuad.
-
AOI_CLOCKS
Clock ip name array for AOI.
-
CLK_GATE_REG_OFFSET_SHIFT
Clock gate name used for CLOCK_EnableClock/CLOCK_DisableClock.
-
CLK_GATE_REG_OFFSET_MASK
-
CLK_GATE_BIT_SHIFT_SHIFT
-
CLK_GATE_BIT_SHIFT_MASK
-
CLK_GATE_DEFINE(reg_offset, bit_shift)
-
CLK_GATE_ABSTRACT_REG_OFFSET(x)
-
CLK_GATE_ABSTRACT_BITS_SHIFT(x)
-
AHB_CLK_CTRL0
-
AHB_CLK_CTRL1
-
AHB_CLK_CTRL2
-
AHB_CLK_CTRL3
-
REG_PWM0SUBCTL
-
REG_PWM1SUBCTL
-
BUS_CLK
Peripherals clock source definition.
-
I2C0_CLK_SRC
-
CLK_ATTACH_ID(mux, sel, pos)
Clock Mux Switches The encoding is as follows each connection identified is 32bits wide while 24bits are valuable starting from LSB upwards.
[4 bits for choice, 0 means invalid choice] [8 bits mux ID]*
-
MUX_A(mux, sel)
-
MUX_B(mux, sel, selector)
-
GET_ID_ITEM(connection)
-
GET_ID_NEXT_ITEM(connection)
-
GET_ID_ITEM_MUX(connection)
-
GET_ID_ITEM_SEL(connection)
-
GET_ID_SELECTOR(connection)
-
CM_SYSTICKCLKSEL0
-
CM_TRACECLKSEL
-
CM_CTIMERCLKSEL0
-
CM_CTIMERCLKSEL1
-
CM_CTIMERCLKSEL2
-
CM_CTIMERCLKSEL3
-
CM_CTIMERCLKSEL4
-
CM_MAINCLKSELA
-
CM_MAINCLKSELB
-
CM_CLKOUTCLKSEL
-
CM_PLL0CLKSEL
-
CM_PLL1CLKSEL
-
CM_MCANCLKSEL
-
CM_ADC0CLKSEL
-
CM_USB0CLKSEL
-
CM_FXCOMCLKSEL0
-
CM_FXCOMCLKSEL1
-
CM_FXCOMCLKSEL2
-
CM_FXCOMCLKSEL3
-
CM_FXCOMCLKSEL4
-
CM_FXCOMCLKSEL5
-
CM_FXCOMCLKSEL6
-
CM_FXCOMCLKSEL7
-
CM_HSLSPICLKSEL
-
CM_MCLKCLKSEL
-
CM_SCTCLKSEL
-
CM_ADC1CLKSEL
-
CM_DAC0CLKSEL
-
CM_DAC1CLKSEL
-
CM_DAC2CLKSEL
-
CM_FLEXSPICLKSEL
-
CM_PLLCLKDIVSEL
-
CM_I3CFCLKSEL
-
CM_I3CFCLKSTCSEL
-
CM_I3CFCLKSSEL
-
CM_DMICFCLKSEL
-
CM_FC32KCLKSEL
-
CM_FRGCLKSEL0
-
CM_FRGCLKSEL1
-
CM_FRGCLKSEL2
-
CM_FRGCLKSEL3
-
CM_FRGCLKSEL4
-
CM_FRGCLKSEL5
-
CM_FRGCLKSEL6
-
CM_FRGCLKSEL7
-
CM_OSTIMERCLKSEL
-
CM_RTCOSC32KCLKSEL
-
PLL_CONFIGFLAG_USEINRATE
PLL configuration structure flags for ‘flags’ field These flags control how the PLL configuration function sets up the PLL setup structure.
When the PLL_CONFIGFLAG_USEINRATE flag is selected, the ‘InputRate’ field in the configuration structure must be assigned with the expected PLL frequency. If the PLL_CONFIGFLAG_USEINRATE is not used, ‘InputRate’ is ignored in the configuration function and the driver will determine the PLL rate from the currently selected PLL source. This flag might be used to configure the PLL input clock more accurately when using the WDT oscillator or a more dyanmic CLKIN source.
When the PLL_CONFIGFLAG_FORCENOFRACT flag is selected, the PLL hardware for the automatic bandwidth selection, Spread Spectrum (SS) support, and fractional M-divider are not used.
Flag to use InputRate in PLL configuration structure for setup
-
PLL_CONFIGFLAG_FORCENOFRACT
Force non-fractional output mode, PLL output will not use the fractional, automatic bandwidth, or SS hardware
-
PLL_SETUPFLAG_POWERUP
PLL setup structure flags for ‘flags’ field These flags control how the PLL setup function sets up the PLL.
Setup will power on the PLL after setup
-
PLL_SETUPFLAG_WAITLOCK
Setup will wait for PLL lock, implies the PLL will be pwoered on
-
PLL_SETUPFLAG_ADGVOLT
Optimize system voltage for the new PLL rate
-
PLL_SETUPFLAG_USEFEEDBACKDIV2
Use feedback divider by 2 in divider path
-
uint32_t desiredRate
Desired PLL rate in Hz
-
uint32_t inputRate
PLL input clock in Hz, only used if PLL_CONFIGFLAG_USEINRATE flag is set
-
uint32_t flags
PLL configuration flags, Or’ed value of PLL_CONFIGFLAG_* definitions
-
ss_progmodfm_t ss_mf
SS Programmable modulation frequency, only applicable when not using PLL_CONFIGFLAG_FORCENOFRACT flag
-
ss_progmoddp_t ss_mr
SS Programmable frequency modulation depth, only applicable when not using PLL_CONFIGFLAG_FORCENOFRACT flag
-
ss_modwvctrl_t ss_mc
SS Modulation waveform control, only applicable when not using PLL_CONFIGFLAG_FORCENOFRACT flag
-
bool mfDither
false for fixed modulation frequency or true for dithering, only applicable when not using PLL_CONFIGFLAG_FORCENOFRACT flag
-
uint32_t pllctrl
PLL control register PLL0CTRL
-
uint32_t pllndec
PLL NDEC register PLL0NDEC
-
uint32_t pllpdec
PLL PDEC register PLL0PDEC
-
uint32_t pllmdec
PLL MDEC registers PLL0PDEC
-
uint32_t pllsscg[2]
PLL SSCTL registers PLL0SSCG
-
uint32_t pllRate
Acutal PLL rate
-
uint32_t flags
PLL setup flags, Or’ed value of PLL_SETUPFLAG_* definitions
-
struct _pll_config
- #include <fsl_clock.h>
PLL configuration structure.
This structure can be used to configure the settings for a PLL setup structure. Fill in the desired configuration for the PLL and call the PLL setup function to fill in a PLL setup structure.
-
struct _pll_setup
- #include <fsl_clock.h>
PLL0 setup structure This structure can be used to pre-build a PLL setup configuration at run-time and quickly set the PLL to the configuration. It can be populated with the PLL setup function. If powering up or waiting for PLL lock, the PLL input clock source should be configured prior to PLL setup.
CMP: Analog Comparator Driver
-
void CMP_Init(const cmp_config_t *config)
CMP initialization.
This function enables the CMP module and do necessary settings.
- Parameters:
config – Pointer to the configuration structure.
-
void CMP_Deinit(void)
CMP deinitialization.
This function gates the clock for CMP module.
-
void CMP_GetDefaultConfig(cmp_config_t *config)
Initializes the CMP user configuration structure.
This function initializes the user configuration structure to these default values.
config->enableHysteresis = true; config->enableLowPower = true; config->filterClockDivider = kCMP_FilterClockDivide1; config->filterSampleMode = kCMP_FilterSampleMode0;
- Parameters:
config – Pointer to the configuration structure.
-
static inline void CMP_SetInputChannels(uint8_t positiveChannel, uint8_t negativeChannel)
-
void CMP_SetVREF(const cmp_vref_config_t *config)
Configures the VREFINPUT.
- Parameters:
config – Pointer to the configuration structure.
-
static inline bool CMP_GetOutput(void)
Get CMP compare output.
- Returns:
The output result. true: voltage on positive side is greater than negative side. false: voltage on positive side is lower than negative side.
-
static inline void CMP_EnableInterrupt(uint32_t type)
CMP enable interrupt.
- Parameters:
type – CMP interrupt type. See “_cmp_interrupt_type”.
-
static inline void CMP_DisableInterrupt(void)
CMP disable interrupt.
-
static inline void CMP_ClearInterrupt(void)
CMP clear interrupt.
-
static inline void CMP_EnableFilteredInterruptSource(bool enable)
Select which Analog comparator output (filtered or un-filtered) is used for interrupt detection.
Note
: When CMP is configured as the wakeup source in power down mode, this function must use the raw output as the interupt source, that is, call this function and set parameter enable to false.
- Parameters:
enable – false: Select Analog Comparator raw output (unfiltered) as input for interrupt detection. true: Select Analog Comparator filtered output as input for interrupt detection.
-
static inline bool CMP_GetPreviousInterruptStatus(void)
Get CMP interrupt status before interupt enable.
- Returns:
Interrupt status. true: interrupt pending, false: no interrupt pending.
-
static inline bool CMP_GetInterruptStatus(void)
Get CMP interrupt status after interupt enable.
- Returns:
Interrupt status. true: interrupt pending, false: no interrupt pending.
-
static inline void CMP_FilterSampleConfig(cmp_filtercgf_samplemode_t filterSampleMode, cmp_filtercgf_clkdiv_t filterClockDivider)
CMP Filter Sample Config.
This function allows the users to configure the sampling mode and clock divider of the CMP Filter.
- Parameters:
filterSampleMode – CMP Select filter sample mode
filterClockDivider – CMP Set fileter clock divider
-
FSL_CMP_DRIVER_VERSION
Driver version 2.2.1.
-
enum _cmp_input_mux
CMP input mux for positive and negative sides.
Values:
-
enumerator kCMP_InputVREF
Cmp input from VREF.
-
enumerator kCMP_Input1
Cmp input source 1.
-
enumerator kCMP_Input2
Cmp input source 2.
-
enumerator kCMP_Input3
Cmp input source 3.
-
enumerator kCMP_Input4
Cmp input source 4.
-
enumerator kCMP_Input5
Cmp input source 5.
-
enumerator kCMP_InputVREF
-
enum _cmp_interrupt_type
CMP interrupt type.
Values:
-
enumerator kCMP_EdgeDisable
Disable edge interupt.
-
enumerator kCMP_EdgeRising
Interrupt on falling edge.
-
enumerator kCMP_EdgeFalling
Interrupt on rising edge.
-
enumerator kCMP_EdgeRisingFalling
Interrupt on both rising and falling edges.
-
enumerator kCMP_LevelDisable
Disable level interupt.
-
enumerator kCMP_LevelHigh
Interrupt on high level.
-
enumerator kCMP_LevelLow
Interrupt on low level.
-
enumerator kCMP_EdgeDisable
-
enum _cmp_vref_source
CMP Voltage Reference source.
Values:
-
enumerator KCMP_VREFSourceVDDA
Select VDDA as VREF.
-
enumerator KCMP_VREFSourceInternalVREF
Select internal VREF as VREF.
-
enumerator KCMP_VREFSourceVDDA
-
enum _cmp_filtercgf_samplemode
CMP Filter sample mode.
Values:
-
enumerator kCMP_FilterSampleMode0
Bypass mode. Filtering is disabled.
-
enumerator kCMP_FilterSampleMode1
Filter 1 clock period.
-
enumerator kCMP_FilterSampleMode2
Filter 2 clock period.
-
enumerator kCMP_FilterSampleMode3
Filter 3 clock period.
-
enumerator kCMP_FilterSampleMode0
-
enum _cmp_filtercgf_clkdiv
CMP Filter clock divider.
Values:
-
enumerator kCMP_FilterClockDivide1
Filter clock period duration equals 1 analog comparator clock period.
-
enumerator kCMP_FilterClockDivide2
Filter clock period duration equals 2 analog comparator clock period.
-
enumerator kCMP_FilterClockDivide4
Filter clock period duration equals 4 analog comparator clock period.
-
enumerator kCMP_FilterClockDivide8
Filter clock period duration equals 8 analog comparator clock period.
-
enumerator kCMP_FilterClockDivide16
Filter clock period duration equals 16 analog comparator clock period.
-
enumerator kCMP_FilterClockDivide32
Filter clock period duration equals 32 analog comparator clock period.
-
enumerator kCMP_FilterClockDivide64
Filter clock period duration equals 64 analog comparator clock period.
-
enumerator kCMP_FilterClockDivide1
-
typedef enum _cmp_vref_source cmp_vref_source_t
CMP Voltage Reference source.
-
typedef struct _cmp_vref_config cmp_vref_config_t
-
typedef enum _cmp_filtercgf_samplemode cmp_filtercgf_samplemode_t
CMP Filter sample mode.
-
typedef enum _cmp_filtercgf_clkdiv cmp_filtercgf_clkdiv_t
CMP Filter clock divider.
-
typedef struct _cmp_config cmp_config_t
CMP configuration structure.
-
struct _cmp_vref_config
- #include <fsl_cmp.h>
Public Members
-
cmp_vref_source_t vrefSource
Reference voltage source.
-
uint8_t vrefValue
Reference voltage step. Available range is 0-31. Per step equals to VREFINPUT/31.
-
cmp_vref_source_t vrefSource
-
struct _cmp_config
- #include <fsl_cmp.h>
CMP configuration structure.
Public Members
-
bool enableHysteresis
Enable hysteresis.
-
bool enableLowPower
Enable low power mode.
-
bool enableHysteresis
CRC: Cyclic Redundancy Check Driver
-
FSL_CRC_DRIVER_VERSION
CRC driver version. Version 2.0.4.
Current version: 2.0.4
Change log:
Version 2.0.4
Release peripheral from reset if necessary in init function.
Version 2.0.3
Fix MISRA issues
Version 2.0.2
Fix MISRA issues
Version 2.0.1
move DATA and DATALL macro definition from header file to source file
-
enum _crc_bits
CRC bit width.
Values:
-
enumerator kCrcBits16
Generate 16-bit CRC code
-
enumerator kCrcBits32
Generate 32-bit CRC code
-
enumerator kCrcBits16
-
enum _crc_result
CRC result type.
Values:
-
enumerator kCrcFinalChecksum
CRC data register read value is the final checksum. Reflect out and final xor protocol features are applied.
-
enumerator kCrcIntermediateChecksum
CRC data register read value is intermediate checksum (raw value). Reflect out and final xor protocol feature are not applied. Intermediate checksum can be used as a seed for CRC_Init() to continue adding data to this checksum.
-
enumerator kCrcFinalChecksum
-
typedef enum _crc_bits crc_bits_t
CRC bit width.
-
typedef enum _crc_result crc_result_t
CRC result type.
-
typedef struct _crc_config crc_config_t
CRC protocol configuration.
This structure holds the configuration for the CRC protocol.
-
void CRC_Init(CRC_Type *base, const crc_config_t *config)
Enables and configures the CRC peripheral module.
This function enables the clock gate in the SIM module for the CRC peripheral. It also configures the CRC module and starts a checksum computation by writing the seed.
- Parameters:
base – CRC peripheral address.
config – CRC module configuration structure.
-
static inline void CRC_Deinit(CRC_Type *base)
Disables the CRC peripheral module.
This function disables the clock gate in the SIM module for the CRC peripheral.
- Parameters:
base – CRC peripheral address.
-
void CRC_GetDefaultConfig(crc_config_t *config)
Loads default values to the CRC protocol configuration structure.
Loads default values to the CRC protocol configuration structure. The default values are as follows.
config->polynomial = 0x1021; config->seed = 0xFFFF; config->reflectIn = false; config->reflectOut = false; config->complementChecksum = false; config->crcBits = kCrcBits16; config->crcResult = kCrcFinalChecksum;
- Parameters:
config – CRC protocol configuration structure.
-
void CRC_WriteData(CRC_Type *base, const uint8_t *data, size_t dataSize)
Writes data to the CRC module.
Writes input data buffer bytes to the CRC data register. The configured type of transpose is applied.
- Parameters:
base – CRC peripheral address.
data – Input data stream, MSByte in data[0].
dataSize – Size in bytes of the input data buffer.
-
uint32_t CRC_Get32bitResult(CRC_Type *base)
Reads the 32-bit checksum from the CRC module.
Reads the CRC data register (either an intermediate or the final checksum). The configured type of transpose and complement is applied.
- Parameters:
base – CRC peripheral address.
- Returns:
An intermediate or the final 32-bit checksum, after configured transpose and complement operations.
-
uint16_t CRC_Get16bitResult(CRC_Type *base)
Reads a 16-bit checksum from the CRC module.
Reads the CRC data register (either an intermediate or the final checksum). The configured type of transpose and complement is applied.
- Parameters:
base – CRC peripheral address.
- Returns:
An intermediate or the final 16-bit checksum, after configured transpose and complement operations.
-
CRC_DRIVER_USE_CRC16_CCIT_FALSE_AS_DEFAULT
Default configuration structure filled by CRC_GetDefaultConfig(). Use CRC16-CCIT-FALSE as defeault.
-
struct _crc_config
- #include <fsl_crc.h>
CRC protocol configuration.
This structure holds the configuration for the CRC protocol.
Public Members
-
uint32_t polynomial
CRC Polynomial, MSBit first. Example polynomial: 0x1021 = 1_0000_0010_0001 = x^12+x^5+1
-
uint32_t seed
Starting checksum value
-
bool reflectIn
Reflect bits on input.
-
bool reflectOut
Reflect bits on output.
-
bool complementChecksum
True if the result shall be complement of the actual checksum.
-
crc_bits_t crcBits
Selects 16- or 32- bit CRC protocol.
-
crc_result_t crcResult
Selects final or intermediate checksum return from CRC_Get16bitResult() or CRC_Get32bitResult()
-
uint32_t polynomial
CTIMER: Standard counter/timers
-
void CTIMER_Init(CTIMER_Type *base, const ctimer_config_t *config)
Ungates the clock and configures the peripheral for basic operation.
Note
This API should be called at the beginning of the application before using the driver.
- Parameters:
base – Ctimer peripheral base address
config – Pointer to the user configuration structure.
-
void CTIMER_Deinit(CTIMER_Type *base)
Gates the timer clock.
- Parameters:
base – Ctimer peripheral base address
-
void CTIMER_GetDefaultConfig(ctimer_config_t *config)
Fills in the timers configuration structure with the default settings.
The default values are:
config->mode = kCTIMER_TimerMode; config->input = kCTIMER_Capture_0; config->prescale = 0;
- Parameters:
config – Pointer to the user configuration structure.
-
status_t CTIMER_SetupPwmPeriod(CTIMER_Type *base, const ctimer_match_t pwmPeriodChannel, ctimer_match_t matchChannel, uint32_t pwmPeriod, uint32_t pulsePeriod, bool enableInt)
Configures the PWM signal parameters.
Enables PWM mode on the match channel passed in and will then setup the match value and other match parameters to generate a PWM signal. This function can manually assign the specified channel to set the PWM cycle.
Note
When setting PWM output from multiple output pins, all should use the same PWM period
- Parameters:
base – Ctimer peripheral base address
pwmPeriodChannel – Specify the channel to control the PWM period
matchChannel – Match pin to be used to output the PWM signal
pwmPeriod – PWM period match value
pulsePeriod – Pulse width match value
enableInt – Enable interrupt when the timer value reaches the match value of the PWM pulse, if it is 0 then no interrupt will be generated.
- Returns:
kStatus_Success on success kStatus_Fail If matchChannel is equal to pwmPeriodChannel; this channel is reserved to set the PWM cycle If PWM pulse width register value is larger than 0xFFFFFFFF.
-
status_t CTIMER_SetupPwm(CTIMER_Type *base, const ctimer_match_t pwmPeriodChannel, ctimer_match_t matchChannel, uint8_t dutyCyclePercent, uint32_t pwmFreq_Hz, uint32_t srcClock_Hz, bool enableInt)
Configures the PWM signal parameters.
Enables PWM mode on the match channel passed in and will then setup the match value and other match parameters to generate a PWM signal. This function can manually assign the specified channel to set the PWM cycle.
Note
When setting PWM output from multiple output pins, all should use the same PWM frequency. Please use CTIMER_SetupPwmPeriod to set up the PWM with high resolution.
- Parameters:
base – Ctimer peripheral base address
pwmPeriodChannel – Specify the channel to control the PWM period
matchChannel – Match pin to be used to output the PWM signal
dutyCyclePercent – PWM pulse width; the value should be between 0 to 100
pwmFreq_Hz – PWM signal frequency in Hz
srcClock_Hz – Timer counter clock in Hz
enableInt – Enable interrupt when the timer value reaches the match value of the PWM pulse, if it is 0 then no interrupt will be generated.
-
static inline void CTIMER_UpdatePwmPulsePeriod(CTIMER_Type *base, ctimer_match_t matchChannel, uint32_t pulsePeriod)
Updates the pulse period of an active PWM signal.
- Parameters:
base – Ctimer peripheral base address
matchChannel – Match pin to be used to output the PWM signal
pulsePeriod – New PWM pulse width match value
-
status_t CTIMER_UpdatePwmDutycycle(CTIMER_Type *base, const ctimer_match_t pwmPeriodChannel, ctimer_match_t matchChannel, uint8_t dutyCyclePercent)
Updates the duty cycle of an active PWM signal.
Note
Please use CTIMER_SetupPwmPeriod to update the PWM with high resolution. This function can manually assign the specified channel to set the PWM cycle.
- Parameters:
base – Ctimer peripheral base address
pwmPeriodChannel – Specify the channel to control the PWM period
matchChannel – Match pin to be used to output the PWM signal
dutyCyclePercent – New PWM pulse width; the value should be between 0 to 100
- Returns:
kStatus_Success on success kStatus_Fail If PWM pulse width register value is larger than 0xFFFFFFFF.
-
static inline void CTIMER_EnableInterrupts(CTIMER_Type *base, uint32_t mask)
Enables the selected Timer interrupts.
- Parameters:
base – Ctimer peripheral base address
mask – The interrupts to enable. This is a logical OR of members of the enumeration ctimer_interrupt_enable_t
-
static inline void CTIMER_DisableInterrupts(CTIMER_Type *base, uint32_t mask)
Disables the selected Timer interrupts.
- Parameters:
base – Ctimer peripheral base address
mask – The interrupts to enable. This is a logical OR of members of the enumeration ctimer_interrupt_enable_t
-
static inline uint32_t CTIMER_GetEnabledInterrupts(CTIMER_Type *base)
Gets the enabled Timer interrupts.
- Parameters:
base – Ctimer peripheral base address
- Returns:
The enabled interrupts. This is the logical OR of members of the enumeration ctimer_interrupt_enable_t
-
static inline uint32_t CTIMER_GetStatusFlags(CTIMER_Type *base)
Gets the Timer status flags.
- Parameters:
base – Ctimer peripheral base address
- Returns:
The status flags. This is the logical OR of members of the enumeration ctimer_status_flags_t
-
static inline void CTIMER_ClearStatusFlags(CTIMER_Type *base, uint32_t mask)
Clears the Timer status flags.
- Parameters:
base – Ctimer peripheral base address
mask – The status flags to clear. This is a logical OR of members of the enumeration ctimer_status_flags_t
-
static inline void CTIMER_StartTimer(CTIMER_Type *base)
Starts the Timer counter.
- Parameters:
base – Ctimer peripheral base address
-
static inline void CTIMER_StopTimer(CTIMER_Type *base)
Stops the Timer counter.
- Parameters:
base – Ctimer peripheral base address
-
FSL_CTIMER_DRIVER_VERSION
Version 2.3.3
-
enum _ctimer_capture_channel
List of Timer capture channels.
Values:
-
enumerator kCTIMER_Capture_0
Timer capture channel 0
-
enumerator kCTIMER_Capture_1
Timer capture channel 1
-
enumerator kCTIMER_Capture_3
Timer capture channel 3
-
enumerator kCTIMER_Capture_0
-
enum _ctimer_capture_edge
List of capture edge options.
Values:
-
enumerator kCTIMER_Capture_RiseEdge
Capture on rising edge
-
enumerator kCTIMER_Capture_FallEdge
Capture on falling edge
-
enumerator kCTIMER_Capture_BothEdge
Capture on rising and falling edge
-
enumerator kCTIMER_Capture_RiseEdge
-
enum _ctimer_match
List of Timer match registers.
Values:
-
enumerator kCTIMER_Match_0
Timer match register 0
-
enumerator kCTIMER_Match_1
Timer match register 1
-
enumerator kCTIMER_Match_2
Timer match register 2
-
enumerator kCTIMER_Match_3
Timer match register 3
-
enumerator kCTIMER_Match_0
-
enum _ctimer_external_match
List of external match.
Values:
-
enumerator kCTIMER_External_Match_0
External match 0
-
enumerator kCTIMER_External_Match_1
External match 1
-
enumerator kCTIMER_External_Match_2
External match 2
-
enumerator kCTIMER_External_Match_3
External match 3
-
enumerator kCTIMER_External_Match_0
-
enum _ctimer_match_output_control
List of output control options.
Values:
-
enumerator kCTIMER_Output_NoAction
No action is taken
-
enumerator kCTIMER_Output_Clear
Clear the EM bit/output to 0
-
enumerator kCTIMER_Output_Set
Set the EM bit/output to 1
-
enumerator kCTIMER_Output_Toggle
Toggle the EM bit/output
-
enumerator kCTIMER_Output_NoAction
-
enum _ctimer_timer_mode
List of Timer modes.
Values:
-
enumerator kCTIMER_TimerMode
-
enumerator kCTIMER_IncreaseOnRiseEdge
-
enumerator kCTIMER_IncreaseOnFallEdge
-
enumerator kCTIMER_IncreaseOnBothEdge
-
enumerator kCTIMER_TimerMode
-
enum _ctimer_interrupt_enable
List of Timer interrupts.
Values:
-
enumerator kCTIMER_Match0InterruptEnable
Match 0 interrupt
-
enumerator kCTIMER_Match1InterruptEnable
Match 1 interrupt
-
enumerator kCTIMER_Match2InterruptEnable
Match 2 interrupt
-
enumerator kCTIMER_Match3InterruptEnable
Match 3 interrupt
-
enumerator kCTIMER_Match0InterruptEnable
-
enum _ctimer_status_flags
List of Timer flags.
Values:
-
enumerator kCTIMER_Match0Flag
Match 0 interrupt flag
-
enumerator kCTIMER_Match1Flag
Match 1 interrupt flag
-
enumerator kCTIMER_Match2Flag
Match 2 interrupt flag
-
enumerator kCTIMER_Match3Flag
Match 3 interrupt flag
-
enumerator kCTIMER_Match0Flag
-
enum ctimer_callback_type_t
Callback type when registering for a callback. When registering a callback an array of function pointers is passed the size could be 1 or 8, the callback type will tell that.
Values:
-
enumerator kCTIMER_SingleCallback
Single Callback type where there is only one callback for the timer. based on the status flags different channels needs to be handled differently
-
enumerator kCTIMER_MultipleCallback
Multiple Callback type where there can be 8 valid callbacks, one per channel. for both match/capture
-
enumerator kCTIMER_SingleCallback
-
typedef enum _ctimer_capture_channel ctimer_capture_channel_t
List of Timer capture channels.
-
typedef enum _ctimer_capture_edge ctimer_capture_edge_t
List of capture edge options.
-
typedef enum _ctimer_match ctimer_match_t
List of Timer match registers.
-
typedef enum _ctimer_external_match ctimer_external_match_t
List of external match.
-
typedef enum _ctimer_match_output_control ctimer_match_output_control_t
List of output control options.
-
typedef enum _ctimer_timer_mode ctimer_timer_mode_t
List of Timer modes.
-
typedef enum _ctimer_interrupt_enable ctimer_interrupt_enable_t
List of Timer interrupts.
-
typedef enum _ctimer_status_flags ctimer_status_flags_t
List of Timer flags.
-
typedef void (*ctimer_callback_t)(uint32_t flags)
-
typedef struct _ctimer_match_config ctimer_match_config_t
Match configuration.
This structure holds the configuration settings for each match register.
-
typedef struct _ctimer_config ctimer_config_t
Timer configuration structure.
This structure holds the configuration settings for the Timer peripheral. To initialize this structure to reasonable defaults, call the CTIMER_GetDefaultConfig() function and pass a pointer to the configuration structure instance.
The configuration structure can be made constant so as to reside in flash.
-
void CTIMER_SetupMatch(CTIMER_Type *base, ctimer_match_t matchChannel, const ctimer_match_config_t *config)
Setup the match register.
User configuration is used to setup the match value and action to be taken when a match occurs.
- Parameters:
base – Ctimer peripheral base address
matchChannel – Match register to configure
config – Pointer to the match configuration structure
-
uint32_t CTIMER_GetOutputMatchStatus(CTIMER_Type *base, uint32_t matchChannel)
Get the status of output match.
This function gets the status of output MAT, whether or not this output is connected to a pin. This status is driven to the MAT pins if the match function is selected via IOCON. 0 = LOW. 1 = HIGH.
- Parameters:
base – Ctimer peripheral base address
matchChannel – External match channel, user can obtain the status of multiple match channels at the same time by using the logic of “|” enumeration ctimer_external_match_t
- Returns:
The mask of external match channel status flags. Users need to use the _ctimer_external_match type to decode the return variables.
-
void CTIMER_SetupCapture(CTIMER_Type *base, ctimer_capture_channel_t capture, ctimer_capture_edge_t edge, bool enableInt)
Setup the capture.
- Parameters:
base – Ctimer peripheral base address
capture – Capture channel to configure
edge – Edge on the channel that will trigger a capture
enableInt – Flag to enable channel interrupts, if enabled then the registered call back is called upon capture
-
static inline uint32_t CTIMER_GetTimerCountValue(CTIMER_Type *base)
Get the timer count value from TC register.
- Parameters:
base – Ctimer peripheral base address.
- Returns:
return the timer count value.
-
void CTIMER_RegisterCallBack(CTIMER_Type *base, ctimer_callback_t *cb_func, ctimer_callback_type_t cb_type)
Register callback.
- Parameters:
base – Ctimer peripheral base address
cb_func – callback function
cb_type – callback function type, singular or multiple
-
static inline void CTIMER_Reset(CTIMER_Type *base)
Reset the counter.
The timer counter and prescale counter are reset on the next positive edge of the APB clock.
- Parameters:
base – Ctimer peripheral base address
-
static inline void CTIMER_SetPrescale(CTIMER_Type *base, uint32_t prescale)
Setup the timer prescale value.
Specifies the maximum value for the Prescale Counter.
- Parameters:
base – Ctimer peripheral base address
prescale – Prescale value
-
static inline uint32_t CTIMER_GetCaptureValue(CTIMER_Type *base, ctimer_capture_channel_t capture)
Get capture channel value.
Get the counter/timer value on the corresponding capture channel.
- Parameters:
base – Ctimer peripheral base address
capture – Select capture channel
- Returns:
The timer count capture value.
-
static inline void CTIMER_EnableResetMatchChannel(CTIMER_Type *base, ctimer_match_t match, bool enable)
Enable reset match channel.
Set the specified match channel reset operation.
- Parameters:
base – Ctimer peripheral base address
match – match channel used
enable – Enable match channel reset operation.
-
static inline void CTIMER_EnableStopMatchChannel(CTIMER_Type *base, ctimer_match_t match, bool enable)
Enable stop match channel.
Set the specified match channel stop operation.
- Parameters:
base – Ctimer peripheral base address.
match – match channel used.
enable – Enable match channel stop operation.
-
static inline void CTIMER_EnableMatchChannelReload(CTIMER_Type *base, ctimer_match_t match, bool enable)
Enable reload channel falling edge.
Enable the specified match channel reload match shadow value.
- Parameters:
base – Ctimer peripheral base address.
match – match channel used.
enable – Enable .
-
static inline void CTIMER_EnableRisingEdgeCapture(CTIMER_Type *base, ctimer_capture_channel_t capture, bool enable)
Enable capture channel rising edge.
Sets the specified capture channel for rising edge capture.
- Parameters:
base – Ctimer peripheral base address.
capture – capture channel used.
enable – Enable rising edge capture.
-
static inline void CTIMER_EnableFallingEdgeCapture(CTIMER_Type *base, ctimer_capture_channel_t capture, bool enable)
Enable capture channel falling edge.
Sets the specified capture channel for falling edge capture.
- Parameters:
base – Ctimer peripheral base address.
capture – capture channel used.
enable – Enable falling edge capture.
-
static inline void CTIMER_SetShadowValue(CTIMER_Type *base, ctimer_match_t match, uint32_t matchvalue)
Set the specified match shadow channel.
- Parameters:
base – Ctimer peripheral base address.
match – match channel used.
matchvalue – Reload the value of the corresponding match register.
-
struct _ctimer_match_config
- #include <fsl_ctimer.h>
Match configuration.
This structure holds the configuration settings for each match register.
Public Members
-
uint32_t matchValue
This is stored in the match register
-
bool enableCounterReset
true: Match will reset the counter false: Match will not reser the counter
-
bool enableCounterStop
true: Match will stop the counter false: Match will not stop the counter
-
ctimer_match_output_control_t outControl
Action to be taken on a match on the EM bit/output
-
bool outPinInitState
Initial value of the EM bit/output
-
bool enableInterrupt
true: Generate interrupt upon match false: Do not generate interrupt on match
-
uint32_t matchValue
-
struct _ctimer_config
- #include <fsl_ctimer.h>
Timer configuration structure.
This structure holds the configuration settings for the Timer peripheral. To initialize this structure to reasonable defaults, call the CTIMER_GetDefaultConfig() function and pass a pointer to the configuration structure instance.
The configuration structure can be made constant so as to reside in flash.
Public Members
-
ctimer_timer_mode_t mode
Timer mode
-
ctimer_capture_channel_t input
Input channel to increment the timer, used only in timer modes that rely on this input signal to increment TC
-
uint32_t prescale
Prescale value
-
ctimer_timer_mode_t mode
DAC: Digital-to-Analog Converter Driver
-
void DAC_Init(LPDAC_Type *base, const dac_config_t *config)
Initialize the DAC module with common configuartion.
The clock will be enabled in this function.
- Parameters:
base – DAC peripheral base address.
config – Pointer to configuration structure.
-
void DAC_GetDefaultConfig(dac_config_t *config)
Get the default settings for initialization’s configuration.
This function initializes the user configuration structure to a default value. The default values are:
config->fifoWatermarkLevel = 0U; config->fifoTriggerMode = kDAC_FIFOTriggerByHardwareMode; config->fifoWorkMode = kDAC_FIFODisabled; config->enableLowPowerMode = false; config->referenceVoltageSource = kDAC_ReferenceVoltageSourceAlt1;
- Parameters:
config – Pointer to configuration structure.
-
void DAC_Deinit(LPDAC_Type *base)
De-initialize the DAC module.
The clock will be disabled in this function.
- Parameters:
base – DAC peripheral base address.
-
static inline void DAC_SetReset(LPDAC_Type *base, uint32_t mask)
Assert the reset control to part hardware.
This function is to assert the reset control to part hardware. Responding part hardware would remain reset untill cleared by software.
- Parameters:
base – DAC peripheral base address.
mask – The reset control mask, see to _dac_reset_control_t.
-
static inline void DAC_ClearReset(LPDAC_Type *base, uint32_t mask)
Clear the reset control to part hardware.
This function is to clear the reset control to part hardware. Responding part hardware would work after the reset control is cleared by software.
- Parameters:
base – DAC peripheral base address.
mask – The reset control mask, see to _dac_reset_control_t.
-
static inline void DAC_Enable(LPDAC_Type *base, bool enable)
Enable the DAC hardware system or not.
This function is to start the Programmable Reference Generator operation or not.
- Parameters:
base – DAC peripheral base address.
enable – Assertion of indicated event.
-
static inline void DAC_EnableInterrupts(LPDAC_Type *base, uint32_t mask)
Enable the interrupts.
- Parameters:
base – DAC peripheral base address.
mask – Mask value of indicated interrupt events. See to _dac_interrupt_enable.
-
static inline void DAC_DisableInterrupts(LPDAC_Type *base, uint32_t mask)
Disable the interrupts.
- Parameters:
base – DAC peripheral base address.
mask – Mask value of indicated interrupt events. See to _dac_interrupt_enable.
-
static inline void DAC_EnableDMA(LPDAC_Type *base, uint32_t mask, bool enable)
Enable the DMA switchers or not.
- Parameters:
base – DAC peripheral base address.
mask – Mask value of indicated DMA requeset. See to _dac_dma_enable.
enable – Enable the DMA or not.
-
static inline uint32_t DAC_GetStatusFlags(LPDAC_Type *base)
Get status flags of DAC module.
- Parameters:
base – DAC peripheral base address.
- Returns:
Mask value of status flags. See to _dac_status_flags.
-
static inline void DAC_ClearStatusFlags(LPDAC_Type *base, uint32_t flags)
Clear status flags of DAC module.
- Parameters:
base – DAC peripheral base address.
flags – Mask value of status flags to be cleared. See to _dac_status_flags.
-
static inline void DAC_SetData(LPDAC_Type *base, uint32_t value)
Set data into the entry of FIFO buffer.
- Parameters:
base – DAC peripheral base address.
value – Setting value into FIFO buffer.
-
static inline uint32_t DAC_GetFIFOWritePointer(LPDAC_Type *base)
Get the value of the FIFO write pointer.
- Parameters:
base – DAC peripheral base address.
- Returns:
Current value of the FIFO write pointer.
-
static inline uint32_t DAC_GetFIFOReadPointer(LPDAC_Type *base)
Get the value of the FIFO read pointer.
- Parameters:
base – DAC peripheral base address.
- Returns:
Current value of the FIFO read pointer.
-
static inline void DAC_DoSoftwareTriggerFIFO(LPDAC_Type *base)
Do software trigger to FIFO when in software mode.
- Parameters:
base – DAC peripheral base address.
-
FSL_DAC_DRIVER_VERSION
DAC driver version 2.1.2.
DAC reset control.
Values:
-
enumerator kDAC_ResetFIFO
Resets the FIFO pointers and flags.
-
enumerator kDAC_ResetLogic
Resets all DAC registers and internal logic.
-
enumerator kDAC_ResetFIFO
DAC interrupts.
Values:
-
enumerator kDAC_FIFOFullInterruptEnable
FIFO full interrupt enable.
-
enumerator kDAC_FIFOEmptyInterruptEnable
FIFO empty interrupt enable.
-
enumerator kDAC_FIFOWatermarkInterruptEnable
FIFO watermark interrupt enable.
-
enumerator kDAC_SwingBackInterruptEnable
Swing back one cycle complete interrupt enable.
-
enumerator kDAC_FIFOOverflowInterruptEnable
FIFO overflow interrupt enable.
-
enumerator kDAC_FIFOUnderflowInterruptEnable
FIFO underflow interrupt enable.
-
enumerator kDAC_PeriodTriggerCompleteInterruptEnable
Period trigger mode conversion complete interrupt enable
-
enumerator kDAC_FIFOFullInterruptEnable
DAC DMA switchers.
Values:
-
enumerator kDAC_FIFOEmptyDMAEnable
FIFO empty DMA enable.
-
enumerator kDAC_FIFOWatermarkDMAEnable
FIFO watermark DMA enable.
-
enumerator kDAC_FIFOEmptyDMAEnable
DAC status flags.
Values:
-
enumerator kDAC_FIFOUnderflowFlag
This flag means that there is a new trigger after the buffer is empty. The FIFO read pointer will not increase in this case and the data sent to DAC analog conversion will not changed. This flag is cleared by writing a 1 to it.
-
enumerator kDAC_FIFOOverflowFlag
This flag indicates that data is intended to write into FIFO after the buffer is full. The writer pointer will not increase in this case. The extra data will not be written into the FIFO. This flag is cleared by writing a 1 to it.
-
enumerator kDAC_FIFOSwingBackFlag
This flag indicates that the DAC has completed one period of conversion in swing back mode. It means that the read pointer has increased to the top (write pointer) once and then decreased to zero once. For example, after three data is written to FIFO, the writer pointer is now 3. Then, if continually triggered, the read pointer will swing like: 0-1-2-1-0-1-2-, and so on. After the fourth trigger, the flag is set. This flag is cleared by writing a 1 to it.
-
enumerator kDAC_FIFOWatermarkFlag
This field is set if the remaining data in FIFO is less than or equal to the setting value of wartermark. By writing data into FIFO by DMA or CPU, this flag is cleared automatically when the data in FIFO is more than the setting value of watermark.
-
enumerator kDAC_FIFOEmptyFlag
FIFO empty flag.
-
enumerator kDAC_FIFOFullFlag
FIFO full flag.
-
enumerator kDAC_PeriodTriggerCompleteFlag
Period trigger mode conversion complete flag.
-
enumerator kDAC_FIFOUnderflowFlag
-
enum _dac_fifo_trigger_mode
DAC FIFO trigger mode.
Values:
-
enumerator kDAC_FIFOTriggerByHardwareMode
Buffer would be triggered by hardware.
-
enumerator kDAC_FIFOTriggerBySoftwareMode
Buffer would be triggered by software.
-
enumerator kDAC_FIFOTriggerByHardwareMode
-
enum _dac_fifo_work_mode
DAC FIFO work mode.
Values:
-
enumerator kDAC_FIFODisabled
FIFO mode is disabled and buffer mode is enabled. Any data written to DATA[DATA] goes to buffer then goes to conversion.
-
enumerator kDAC_FIFOWorkAsNormalMode
FIFO mode is enabled. Data will be first read from FIFO to buffer then goes to conversion.
-
enumerator kDAC_FIFOWorkAsSwingMode
In swing mode, the read pointer swings between the writer pointer and zero. That is, the trigger increases the read pointer till reach the writer pointer and decreases the read pointer till zero, and so on. The FIFO empty/full/watermark flag will not update during swing back mode.
-
enumerator kDAC_FIFOWorkAsPeriodTriggerMode
In periodic trigger mode, user only needs to send the first trigger. Then after every [PTG_PERIOD+1] RCLK cycles, DAC will be automatically triggered by internal trigger. There will be [PTG_NUM] internal triggers, thus in total [PTG_NUM+1] conversions including the first trigger sent by user. User can terminate the current conversion queue by clearing the GCR[PTGEN] bit. Then, after the current conversion is completed, the conversion is terminated and the PTGCOCO flag is set. If PCR[PTG_NUM] is set to zero, there will be infinite triggers following the first hardware/software trigger, until the GCR[PTGEN] is cleared by software. In any case, the conversion can be terminated by FIFORST/SWRST.
-
enumerator kDAC_FIFOWorkAsPeriodTriggerAndSwingMode
Periodically trigger DAC and swing back.
-
enumerator kDAC_FIFODisabled
-
enum _dac_reference_voltage_source
DAC reference voltage source.
Values:
-
enumerator kDAC_ReferenceVoltageSourceAlt1
The DAC selects VREFH_INT as the reference voltage.
-
enumerator kDAC_ReferenceVoltageSourceAlt2
The DAC selects VREFH_EXT as the reference voltage.
-
enumerator kDAC_ReferenceVoltageSourceAlt1
-
enum _dac_reference_current_source
Values:
-
enumerator kDAC_ReferenceCurrentSourcePtat
-
enumerator kDAC_ReferenceCurrentSourceZtc
-
enumerator kDAC_ReferenceCurrentSourcePtat
-
typedef enum _dac_fifo_trigger_mode dac_fifo_trigger_mode_t
DAC FIFO trigger mode.
-
typedef enum _dac_fifo_work_mode dac_fifo_work_mode_t
DAC FIFO work mode.
-
typedef enum _dac_reference_voltage_source dac_reference_voltage_source_t
DAC reference voltage source.
-
typedef enum _dac_reference_current_source dac_reference_current_source_t
-
typedef struct _dac_config dac_config_t
DAC configuration structure.
-
struct _dac_config
- #include <fsl_dac.h>
DAC configuration structure.
Public Members
-
uint32_t fifoWatermarkLevel
FIFO’s watermark, the max value can be the hardware FIFO size.
-
dac_fifo_trigger_mode_t fifoTriggerMode
Select the trigger mode for FIFO.
-
dac_fifo_work_mode_t fifoWorkMode
Select the work mode for FIFO.
-
bool enableOpampBuffer
Opamp is used as buffer.
-
bool enableLowerLowPowerMode
Enable the lower low power mode.
-
uint32_t periodicTriggerNumber
There will be ‘periodicTriggerNumber’ internal triggers following the first hardware/software trigger. So there will be ‘periodicTriggerNumber + 1’ conversions in total. If set to zero, there will be infinite triggers following the first hw/sw trigger, until the GCR[PTGEN] is cleared.
-
uint32_t periodicTriggerWidth
Control the periodic trigger frequency. There will be ‘periodicTriggerWidth + 1’ RCLK cycles between each periodic trigger. The periodic trigger frequency should be configured to not larger than the analog conversion speed.
-
uint32_t syncTime
RCLK cycles before data latch. accessible range is 0-15. It is used to configure the DAC sync cycles which is helpful to reduce glitch on the output. The sync time is (LATCH_CYC+1) RCLK cycles. User should configure this register according to the RCLK frequency. The recommended sync time is at least 40ns.
-
dac_reference_current_source_t referenceCurrentSource
Select the internal reference current source.
-
dac_reference_voltage_source_t referenceVoltageSource
Select the reference voltage source.
-
uint32_t fifoWatermarkLevel
DMA: Direct Memory Access Controller Driver
-
void DMA_Init(DMA_Type *base)
Initializes DMA peripheral.
This function enable the DMA clock, set descriptor table and enable DMA peripheral.
- Parameters:
base – DMA peripheral base address.
-
void DMA_Deinit(DMA_Type *base)
Deinitializes DMA peripheral.
This function gates the DMA clock.
- Parameters:
base – DMA peripheral base address.
-
void DMA_InstallDescriptorMemory(DMA_Type *base, void *addr)
Install DMA descriptor memory.
This function used to register DMA descriptor memory for linked transfer, a typical case is ping pong transfer which will request more than one DMA descriptor memory space, althrough current DMA driver has a default DMA descriptor buffer, but it support one DMA descriptor for one channel only.
- Parameters:
base – DMA base address.
addr – DMA descriptor address
-
static inline bool DMA_ChannelIsActive(DMA_Type *base, uint32_t channel)
Return whether DMA channel is processing transfer.
- Parameters:
base – DMA peripheral base address.
channel – DMA channel number.
- Returns:
True for active state, false otherwise.
-
static inline bool DMA_ChannelIsBusy(DMA_Type *base, uint32_t channel)
Return whether DMA channel is busy.
- Parameters:
base – DMA peripheral base address.
channel – DMA channel number.
- Returns:
True for busy state, false otherwise.
-
static inline void DMA_EnableChannelInterrupts(DMA_Type *base, uint32_t channel)
Enables the interrupt source for the DMA transfer.
- Parameters:
base – DMA peripheral base address.
channel – DMA channel number.
-
static inline void DMA_DisableChannelInterrupts(DMA_Type *base, uint32_t channel)
Disables the interrupt source for the DMA transfer.
- Parameters:
base – DMA peripheral base address.
channel – DMA channel number.
-
static inline void DMA_EnableChannel(DMA_Type *base, uint32_t channel)
Enable DMA channel.
- Parameters:
base – DMA peripheral base address.
channel – DMA channel number.
-
static inline void DMA_DisableChannel(DMA_Type *base, uint32_t channel)
Disable DMA channel.
- Parameters:
base – DMA peripheral base address.
channel – DMA channel number.
-
static inline void DMA_EnableChannelPeriphRq(DMA_Type *base, uint32_t channel)
Set PERIPHREQEN of channel configuration register.
- Parameters:
base – DMA peripheral base address.
channel – DMA channel number.
-
static inline void DMA_DisableChannelPeriphRq(DMA_Type *base, uint32_t channel)
Get PERIPHREQEN value of channel configuration register.
- Parameters:
base – DMA peripheral base address.
channel – DMA channel number.
- Returns:
True for enabled PeriphRq, false for disabled.
-
void DMA_ConfigureChannelTrigger(DMA_Type *base, uint32_t channel, dma_channel_trigger_t *trigger)
Set trigger settings of DMA channel.
- Deprecated:
Do not use this function. It has been superceded by DMA_SetChannelConfig.
- Parameters:
base – DMA peripheral base address.
channel – DMA channel number.
trigger – trigger configuration.
-
void DMA_SetChannelConfig(DMA_Type *base, uint32_t channel, dma_channel_trigger_t *trigger, bool isPeriph)
set channel config.
This function provide a interface to configure channel configuration reisters.
- Parameters:
base – DMA base address.
channel – DMA channel number.
trigger – channel configurations structure.
isPeriph – true is periph request, false is not.
-
static inline uint32_t DMA_SetChannelXferConfig(bool reload, bool clrTrig, bool intA, bool intB, uint8_t width, uint8_t srcInc, uint8_t dstInc, uint32_t bytes)
DMA channel xfer transfer configurations.
- Parameters:
reload – true is reload link descriptor after current exhaust, false is not
clrTrig – true is clear trigger status, wait software trigger, false is not
intA – enable interruptA
intB – enable interruptB
width – transfer width
srcInc – source address interleave size
dstInc – destination address interleave size
bytes – transfer bytes
- Returns:
The vaule of xfer config
-
uint32_t DMA_GetRemainingBytes(DMA_Type *base, uint32_t channel)
Gets the remaining bytes of the current DMA descriptor transfer.
- Parameters:
base – DMA peripheral base address.
channel – DMA channel number.
- Returns:
The number of bytes which have not been transferred yet.
-
static inline void DMA_SetChannelPriority(DMA_Type *base, uint32_t channel, dma_priority_t priority)
Set priority of channel configuration register.
- Parameters:
base – DMA peripheral base address.
channel – DMA channel number.
priority – Channel priority value.
-
static inline dma_priority_t DMA_GetChannelPriority(DMA_Type *base, uint32_t channel)
Get priority of channel configuration register.
- Parameters:
base – DMA peripheral base address.
channel – DMA channel number.
- Returns:
Channel priority value.
-
static inline void DMA_SetChannelConfigValid(DMA_Type *base, uint32_t channel)
Set channel configuration valid.
- Parameters:
base – DMA peripheral base address.
channel – DMA channel number.
-
static inline void DMA_DoChannelSoftwareTrigger(DMA_Type *base, uint32_t channel)
Do software trigger for the channel.
- Parameters:
base – DMA peripheral base address.
channel – DMA channel number.
-
static inline void DMA_LoadChannelTransferConfig(DMA_Type *base, uint32_t channel, uint32_t xfer)
Load channel transfer configurations.
- Parameters:
base – DMA peripheral base address.
channel – DMA channel number.
xfer – transfer configurations.
-
void DMA_CreateDescriptor(dma_descriptor_t *desc, dma_xfercfg_t *xfercfg, void *srcAddr, void *dstAddr, void *nextDesc)
Create application specific DMA descriptor to be used in a chain in transfer.
- Deprecated:
Do not use this function. It has been superceded by DMA_SetupDescriptor.
- Parameters:
desc – DMA descriptor address.
xfercfg – Transfer configuration for DMA descriptor.
srcAddr – Address of last item to transmit
dstAddr – Address of last item to receive.
nextDesc – Address of next descriptor in chain.
-
void DMA_SetupDescriptor(dma_descriptor_t *desc, uint32_t xfercfg, void *srcStartAddr, void *dstStartAddr, void *nextDesc)
setup dma descriptor
Note: This function do not support configure wrap descriptor.
- Parameters:
desc – DMA descriptor address.
xfercfg – Transfer configuration for DMA descriptor.
srcStartAddr – Start address of source address.
dstStartAddr – Start address of destination address.
nextDesc – Address of next descriptor in chain.
-
void DMA_SetupChannelDescriptor(dma_descriptor_t *desc, uint32_t xfercfg, void *srcStartAddr, void *dstStartAddr, void *nextDesc, dma_burst_wrap_t wrapType, uint32_t burstSize)
setup dma channel descriptor
Note: This function support configure wrap descriptor.
- Parameters:
desc – DMA descriptor address.
xfercfg – Transfer configuration for DMA descriptor.
srcStartAddr – Start address of source address.
dstStartAddr – Start address of destination address.
nextDesc – Address of next descriptor in chain.
wrapType – burst wrap type.
burstSize – burst size, reference _dma_burst_size.
-
void DMA_LoadChannelDescriptor(DMA_Type *base, uint32_t channel, dma_descriptor_t *descriptor)
load channel transfer decriptor.
This function can be used to load desscriptor to driver internal channel descriptor that is used to start DMA transfer, the head descriptor table is defined in DMA driver, it is useful for the case:
for the polling transfer, application can allocate a local descriptor memory table to prepare a descriptor firstly and then call this api to load the configured descriptor to driver descriptor table.
DMA_Init(DMA0); DMA_EnableChannel(DMA0, DEMO_DMA_CHANNEL); DMA_SetupDescriptor(desc, xferCfg, s_srcBuffer, &s_destBuffer[0], NULL); DMA_LoadChannelDescriptor(DMA0, DEMO_DMA_CHANNEL, (dma_descriptor_t *)desc); DMA_DoChannelSoftwareTrigger(DMA0, DEMO_DMA_CHANNEL); while(DMA_ChannelIsBusy(DMA0, DEMO_DMA_CHANNEL)) {}
- Parameters:
base – DMA base address.
channel – DMA channel.
descriptor – configured DMA descriptor.
-
void DMA_AbortTransfer(dma_handle_t *handle)
Abort running transfer by handle.
This function aborts DMA transfer specified by handle.
- Parameters:
handle – DMA handle pointer.
-
void DMA_CreateHandle(dma_handle_t *handle, DMA_Type *base, uint32_t channel)
Creates the DMA handle.
This function is called if using transaction API for DMA. This function initializes the internal state of DMA handle.
- Parameters:
handle – DMA handle pointer. The DMA handle stores callback function and parameters.
base – DMA peripheral base address.
channel – DMA channel number.
-
void DMA_SetCallback(dma_handle_t *handle, dma_callback callback, void *userData)
Installs a callback function for the DMA transfer.
This callback is called in DMA IRQ handler. Use the callback to do something after the current major loop transfer completes.
- Parameters:
handle – DMA handle pointer.
callback – DMA callback function pointer.
userData – Parameter for callback function.
-
void DMA_PrepareTransfer(dma_transfer_config_t *config, void *srcAddr, void *dstAddr, uint32_t byteWidth, uint32_t transferBytes, dma_transfer_type_t type, void *nextDesc)
Prepares the DMA transfer structure.
- Deprecated:
Do not use this function. It has been superceded by DMA_PrepareChannelTransfer. This function prepares the transfer configuration structure according to the user input.
Note
The data address and the data width must be consistent. For example, if the SRC is 4 bytes, so the source address must be 4 bytes aligned, or it shall result in source address error(SAE).
- Parameters:
config – The user configuration structure of type dma_transfer_t.
srcAddr – DMA transfer source address.
dstAddr – DMA transfer destination address.
byteWidth – DMA transfer destination address width(bytes).
transferBytes – DMA transfer bytes to be transferred.
type – DMA transfer type.
nextDesc – Chain custom descriptor to transfer.
-
void DMA_PrepareChannelTransfer(dma_channel_config_t *config, void *srcStartAddr, void *dstStartAddr, uint32_t xferCfg, dma_transfer_type_t type, dma_channel_trigger_t *trigger, void *nextDesc)
Prepare channel transfer configurations.
This function used to prepare channel transfer configurations.
- Parameters:
config – Pointer to DMA channel transfer configuration structure.
srcStartAddr – source start address.
dstStartAddr – destination start address.
xferCfg – xfer configuration, user can reference DMA_CHANNEL_XFER about to how to get xferCfg value.
type – transfer type.
trigger – DMA channel trigger configurations.
nextDesc – address of next descriptor.
-
status_t DMA_SubmitTransfer(dma_handle_t *handle, dma_transfer_config_t *config)
Submits the DMA transfer request.
- Deprecated:
Do not use this function. It has been superceded by DMA_SubmitChannelTransfer.
This function submits the DMA transfer request according to the transfer configuration structure. If the user submits the transfer request repeatedly, this function packs an unprocessed request as a TCD and enables scatter/gather feature to process it in the next time.
- Parameters:
handle – DMA handle pointer.
config – Pointer to DMA transfer configuration structure.
- Return values:
kStatus_DMA_Success – It means submit transfer request succeed.
kStatus_DMA_QueueFull – It means TCD queue is full. Submit transfer request is not allowed.
kStatus_DMA_Busy – It means the given channel is busy, need to submit request later.
-
void DMA_SubmitChannelTransferParameter(dma_handle_t *handle, uint32_t xferCfg, void *srcStartAddr, void *dstStartAddr, void *nextDesc)
Submit channel transfer paramter directly.
This function used to configue channel head descriptor that is used to start DMA transfer, the head descriptor table is defined in DMA driver, it is useful for the case:
for the single transfer, application doesn’t need to allocate descriptor table, the head descriptor can be used for it.
DMA_SetChannelConfig(base, channel, trigger, isPeriph); DMA_CreateHandle(handle, base, channel) DMA_SubmitChannelTransferParameter(handle, DMA_CHANNEL_XFER(reload, clrTrig, intA, intB, width, srcInc, dstInc, bytes), srcStartAddr, dstStartAddr, NULL); DMA_StartTransfer(handle)
for the linked transfer, application should responsible for link descriptor, for example, if 4 transfer is required, then application should prepare three descriptor table with macro , the head descriptor in driver can be used for the first transfer descriptor.
define link descriptor table in application with macro DMA_ALLOCATE_LINK_DESCRIPTOR(nextDesc[3]); DMA_SetupDescriptor(nextDesc0, DMA_CHANNEL_XFER(reload, clrTrig, intA, intB, width, srcInc, dstInc, bytes), srcStartAddr, dstStartAddr, nextDesc1); DMA_SetupDescriptor(nextDesc1, DMA_CHANNEL_XFER(reload, clrTrig, intA, intB, width, srcInc, dstInc, bytes), srcStartAddr, dstStartAddr, nextDesc2); DMA_SetupDescriptor(nextDesc2, DMA_CHANNEL_XFER(reload, clrTrig, intA, intB, width, srcInc, dstInc, bytes), srcStartAddr, dstStartAddr, NULL); DMA_SetChannelConfig(base, channel, trigger, isPeriph); DMA_CreateHandle(handle, base, channel) DMA_SubmitChannelTransferParameter(handle, DMA_CHANNEL_XFER(reload, clrTrig, intA, intB, width, srcInc, dstInc, bytes), srcStartAddr, dstStartAddr, nextDesc0); DMA_StartTransfer(handle);
- Parameters:
handle – Pointer to DMA handle.
xferCfg – xfer configuration, user can reference DMA_CHANNEL_XFER about to how to get xferCfg value.
srcStartAddr – source start address.
dstStartAddr – destination start address.
nextDesc – address of next descriptor.
-
void DMA_SubmitChannelDescriptor(dma_handle_t *handle, dma_descriptor_t *descriptor)
Submit channel descriptor.
This function used to configue channel head descriptor that is used to start DMA transfer, the head descriptor table is defined in DMA driver, this functiono is typical for the ping pong case:
for the ping pong case, application should responsible for the descriptor, for example, application should prepare two descriptor table with macro.
define link descriptor table in application with macro DMA_ALLOCATE_LINK_DESCRIPTOR(nextDesc[2]); DMA_SetupDescriptor(nextDesc0, DMA_CHANNEL_XFER(reload, clrTrig, intA, intB, width, srcInc, dstInc, bytes), srcStartAddr, dstStartAddr, nextDesc1); DMA_SetupDescriptor(nextDesc1, DMA_CHANNEL_XFER(reload, clrTrig, intA, intB, width, srcInc, dstInc, bytes), srcStartAddr, dstStartAddr, nextDesc0); DMA_SetChannelConfig(base, channel, trigger, isPeriph); DMA_CreateHandle(handle, base, channel) DMA_SubmitChannelDescriptor(handle, nextDesc0); DMA_StartTransfer(handle);
- Parameters:
handle – Pointer to DMA handle.
descriptor – descriptor to submit.
-
status_t DMA_SubmitChannelTransfer(dma_handle_t *handle, dma_channel_config_t *config)
Submits the DMA channel transfer request.
This function submits the DMA transfer request according to the transfer configuration structure. If the user submits the transfer request repeatedly, this function packs an unprocessed request as a TCD and enables scatter/gather feature to process it in the next time. It is used for the case:
for the single transfer, application doesn’t need to allocate descriptor table, the head descriptor can be used for it.
DMA_CreateHandle(handle, base, channel) DMA_PrepareChannelTransfer(config,srcStartAddr,dstStartAddr,xferCfg,type,trigger,NULL); DMA_SubmitChannelTransfer(handle, config) DMA_StartTransfer(handle)
for the linked transfer, application should responsible for link descriptor, for example, if 4 transfer is required, then application should prepare three descriptor table with macro , the head descriptor in driver can be used for the first transfer descriptor.
define link descriptor table in application with macro DMA_ALLOCATE_LINK_DESCRIPTOR(nextDesc); DMA_SetupDescriptor(nextDesc0, DMA_CHANNEL_XFER(reload, clrTrig, intA, intB, width, srcInc, dstInc, bytes), srcStartAddr, dstStartAddr, nextDesc1); DMA_SetupDescriptor(nextDesc1, DMA_CHANNEL_XFER(reload, clrTrig, intA, intB, width, srcInc, dstInc, bytes), srcStartAddr, dstStartAddr, nextDesc2); DMA_SetupDescriptor(nextDesc2, DMA_CHANNEL_XFER(reload, clrTrig, intA, intB, width, srcInc, dstInc, bytes), srcStartAddr, dstStartAddr, NULL); DMA_CreateHandle(handle, base, channel) DMA_PrepareChannelTransfer(config,srcStartAddr,dstStartAddr,xferCfg,type,trigger,nextDesc0); DMA_SubmitChannelTransfer(handle, config) DMA_StartTransfer(handle)
for the ping pong case, application should responsible for link descriptor, for example, application should prepare two descriptor table with macro , the head descriptor in driver can be used for the first transfer descriptor.
define link descriptor table in application with macro DMA_ALLOCATE_LINK_DESCRIPTOR(nextDesc); DMA_SetupDescriptor(nextDesc0, DMA_CHANNEL_XFER(reload, clrTrig, intA, intB, width, srcInc, dstInc, bytes), srcStartAddr, dstStartAddr, nextDesc1); DMA_SetupDescriptor(nextDesc1, DMA_CHANNEL_XFER(reload, clrTrig, intA, intB, width, srcInc, dstInc, bytes), srcStartAddr, dstStartAddr, nextDesc0); DMA_CreateHandle(handle, base, channel) DMA_PrepareChannelTransfer(config,srcStartAddr,dstStartAddr,xferCfg,type,trigger,nextDesc0); DMA_SubmitChannelTransfer(handle, config) DMA_StartTransfer(handle)
- Parameters:
handle – DMA handle pointer.
config – Pointer to DMA transfer configuration structure.
- Return values:
kStatus_DMA_Success – It means submit transfer request succeed.
kStatus_DMA_QueueFull – It means TCD queue is full. Submit transfer request is not allowed.
kStatus_DMA_Busy – It means the given channel is busy, need to submit request later.
-
void DMA_StartTransfer(dma_handle_t *handle)
DMA start transfer.
This function enables the channel request. User can call this function after submitting the transfer request It will trigger transfer start with software trigger only when hardware trigger is not used.
- Parameters:
handle – DMA handle pointer.
-
void DMA_IRQHandle(DMA_Type *base)
DMA IRQ handler for descriptor transfer complete.
This function clears the channel major interrupt flag and call the callback function if it is not NULL.
- Parameters:
base – DMA base address.
-
FSL_DMA_DRIVER_VERSION
DMA driver version.
Version 2.5.3.
_dma_transfer_status DMA transfer status
Values:
-
enumerator kStatus_DMA_Busy
Channel is busy and can’t handle the transfer request.
-
enumerator kStatus_DMA_Busy
_dma_addr_interleave_size dma address interleave size
Values:
-
enumerator kDMA_AddressInterleave0xWidth
dma source/destination address no interleave
-
enumerator kDMA_AddressInterleave1xWidth
dma source/destination address interleave 1xwidth
-
enumerator kDMA_AddressInterleave2xWidth
dma source/destination address interleave 2xwidth
-
enumerator kDMA_AddressInterleave4xWidth
dma source/destination address interleave 3xwidth
-
enumerator kDMA_AddressInterleave0xWidth
_dma_transfer_width dma transfer width
Values:
-
enumerator kDMA_Transfer8BitWidth
dma channel transfer bit width is 8 bit
-
enumerator kDMA_Transfer16BitWidth
dma channel transfer bit width is 16 bit
-
enumerator kDMA_Transfer32BitWidth
dma channel transfer bit width is 32 bit
-
enumerator kDMA_Transfer8BitWidth
-
enum _dma_priority
DMA channel priority.
Values:
-
enumerator kDMA_ChannelPriority0
Highest channel priority - priority 0
-
enumerator kDMA_ChannelPriority1
Channel priority 1
-
enumerator kDMA_ChannelPriority2
Channel priority 2
-
enumerator kDMA_ChannelPriority3
Channel priority 3
-
enumerator kDMA_ChannelPriority4
Channel priority 4
-
enumerator kDMA_ChannelPriority5
Channel priority 5
-
enumerator kDMA_ChannelPriority6
Channel priority 6
-
enumerator kDMA_ChannelPriority7
Lowest channel priority - priority 7
-
enumerator kDMA_ChannelPriority0
-
enum _dma_int
DMA interrupt flags.
Values:
-
enumerator kDMA_IntA
DMA interrupt flag A
-
enumerator kDMA_IntB
DMA interrupt flag B
-
enumerator kDMA_IntError
DMA interrupt flag error
-
enumerator kDMA_IntA
-
enum _dma_trigger_type
DMA trigger type.
Values:
-
enumerator kDMA_NoTrigger
Trigger is disabled
-
enumerator kDMA_LowLevelTrigger
Low level active trigger
-
enumerator kDMA_HighLevelTrigger
High level active trigger
-
enumerator kDMA_FallingEdgeTrigger
Falling edge active trigger
-
enumerator kDMA_RisingEdgeTrigger
Rising edge active trigger
-
enumerator kDMA_NoTrigger
_dma_burst_size DMA burst size
Values:
-
enumerator kDMA_BurstSize1
burst size 1 transfer
-
enumerator kDMA_BurstSize2
burst size 2 transfer
-
enumerator kDMA_BurstSize4
burst size 4 transfer
-
enumerator kDMA_BurstSize8
burst size 8 transfer
-
enumerator kDMA_BurstSize16
burst size 16 transfer
-
enumerator kDMA_BurstSize32
burst size 32 transfer
-
enumerator kDMA_BurstSize64
burst size 64 transfer
-
enumerator kDMA_BurstSize128
burst size 128 transfer
-
enumerator kDMA_BurstSize256
burst size 256 transfer
-
enumerator kDMA_BurstSize512
burst size 512 transfer
-
enumerator kDMA_BurstSize1024
burst size 1024 transfer
-
enumerator kDMA_BurstSize1
-
enum _dma_trigger_burst
DMA trigger burst.
Values:
-
enumerator kDMA_SingleTransfer
Single transfer
-
enumerator kDMA_LevelBurstTransfer
Burst transfer driven by level trigger
-
enumerator kDMA_EdgeBurstTransfer1
Perform 1 transfer by edge trigger
-
enumerator kDMA_EdgeBurstTransfer2
Perform 2 transfers by edge trigger
-
enumerator kDMA_EdgeBurstTransfer4
Perform 4 transfers by edge trigger
-
enumerator kDMA_EdgeBurstTransfer8
Perform 8 transfers by edge trigger
-
enumerator kDMA_EdgeBurstTransfer16
Perform 16 transfers by edge trigger
-
enumerator kDMA_EdgeBurstTransfer32
Perform 32 transfers by edge trigger
-
enumerator kDMA_EdgeBurstTransfer64
Perform 64 transfers by edge trigger
-
enumerator kDMA_EdgeBurstTransfer128
Perform 128 transfers by edge trigger
-
enumerator kDMA_EdgeBurstTransfer256
Perform 256 transfers by edge trigger
-
enumerator kDMA_EdgeBurstTransfer512
Perform 512 transfers by edge trigger
-
enumerator kDMA_EdgeBurstTransfer1024
Perform 1024 transfers by edge trigger
-
enumerator kDMA_SingleTransfer
-
enum _dma_burst_wrap
DMA burst wrapping.
Values:
-
enumerator kDMA_NoWrap
Wrapping is disabled
-
enumerator kDMA_SrcWrap
Wrapping is enabled for source
-
enumerator kDMA_DstWrap
Wrapping is enabled for destination
-
enumerator kDMA_SrcAndDstWrap
Wrapping is enabled for source and destination
-
enumerator kDMA_NoWrap
-
enum _dma_transfer_type
DMA transfer type.
Values:
-
enumerator kDMA_MemoryToMemory
Transfer from memory to memory (increment source and destination)
-
enumerator kDMA_PeripheralToMemory
Transfer from peripheral to memory (increment only destination)
-
enumerator kDMA_MemoryToPeripheral
Transfer from memory to peripheral (increment only source)
-
enumerator kDMA_StaticToStatic
Peripheral to static memory (do not increment source or destination)
-
enumerator kDMA_MemoryToMemory
-
typedef struct _dma_descriptor dma_descriptor_t
DMA descriptor structure.
-
typedef struct _dma_xfercfg dma_xfercfg_t
DMA transfer configuration.
-
typedef enum _dma_priority dma_priority_t
DMA channel priority.
-
typedef enum _dma_int dma_irq_t
DMA interrupt flags.
-
typedef enum _dma_trigger_type dma_trigger_type_t
DMA trigger type.
-
typedef enum _dma_trigger_burst dma_trigger_burst_t
DMA trigger burst.
-
typedef enum _dma_burst_wrap dma_burst_wrap_t
DMA burst wrapping.
-
typedef enum _dma_transfer_type dma_transfer_type_t
DMA transfer type.
-
typedef struct _dma_channel_trigger dma_channel_trigger_t
DMA channel trigger.
-
typedef struct _dma_channel_config dma_channel_config_t
DMA channel trigger.
-
typedef struct _dma_transfer_config dma_transfer_config_t
DMA transfer configuration.
-
typedef void (*dma_callback)(struct _dma_handle *handle, void *userData, bool transferDone, uint32_t intmode)
Define Callback function for DMA.
-
typedef struct _dma_handle dma_handle_t
DMA transfer handle structure.
-
DMA_MAX_TRANSFER_COUNT
DMA max transfer size.
-
FSL_FEATURE_DMA_LINK_DESCRIPTOR_ALIGN_SIZE
DMA channel numbers.
DMA head link descriptor table align size
-
DMA_ALLOCATE_HEAD_DESCRIPTORS(name, number)
DMA head descriptor table allocate macro To simplify user interface, this macro will help allocate descriptor memory, user just need to provide the name and the number for the allocate descriptor.
- Parameters:
name – Allocate decriptor name.
number – Number of descriptor to be allocated.
-
DMA_ALLOCATE_HEAD_DESCRIPTORS_AT_NONCACHEABLE(name, number)
DMA head descriptor table allocate macro at noncacheable section To simplify user interface, this macro will help allocate descriptor memory at noncacheable section, user just need to provide the name and the number for the allocate descriptor.
- Parameters:
name – Allocate decriptor name.
number – Number of descriptor to be allocated.
-
DMA_ALLOCATE_LINK_DESCRIPTORS(name, number)
DMA link descriptor table allocate macro To simplify user interface, this macro will help allocate descriptor memory, user just need to provide the name and the number for the allocate descriptor.
- Parameters:
name – Allocate decriptor name.
number – Number of descriptor to be allocated.
-
DMA_ALLOCATE_LINK_DESCRIPTORS_AT_NONCACHEABLE(name, number)
DMA link descriptor table allocate macro at noncacheable section To simplify user interface, this macro will help allocate descriptor memory at noncacheable section, user just need to provide the name and the number for the allocate descriptor.
- Parameters:
name – Allocate decriptor name.
number – Number of descriptor to be allocated.
-
DMA_ALLOCATE_DATA_TRANSFER_BUFFER(name, width)
DMA transfer buffer address need to align with the transfer width.
-
DMA_CHANNEL_GROUP(channel)
-
DMA_CHANNEL_INDEX(base, channel)
-
DMA_COMMON_REG_GET(base, channel, reg)
DMA linked descriptor address algin size.
-
DMA_COMMON_CONST_REG_GET(base, channel, reg)
-
DMA_COMMON_REG_SET(base, channel, reg, value)
-
DMA_DESCRIPTOR_END_ADDRESS(start, inc, bytes, width)
DMA descriptor end address calculate.
- Parameters:
start – start address
inc – address interleave size
bytes – transfer bytes
width – transfer width
-
DMA_CHANNEL_XFER(reload, clrTrig, intA, intB, width, srcInc, dstInc, bytes)
-
struct _dma_descriptor
- #include <fsl_dma.h>
DMA descriptor structure.
Public Members
-
volatile uint32_t xfercfg
Transfer configuration
-
void *srcEndAddr
Last source address of DMA transfer
-
void *dstEndAddr
Last destination address of DMA transfer
-
void *linkToNextDesc
Address of next DMA descriptor in chain
-
volatile uint32_t xfercfg
-
struct _dma_xfercfg
- #include <fsl_dma.h>
DMA transfer configuration.
Public Members
-
bool valid
Descriptor is ready to transfer
-
bool reload
Reload channel configuration register after current descriptor is exhausted
-
bool swtrig
Perform software trigger. Transfer if fired when ‘valid’ is set
-
bool clrtrig
Clear trigger
-
bool intA
Raises IRQ when transfer is done and set IRQA status register flag
-
bool intB
Raises IRQ when transfer is done and set IRQB status register flag
-
uint8_t byteWidth
Byte width of data to transfer
-
uint8_t srcInc
Increment source address by ‘srcInc’ x ‘byteWidth’
-
uint8_t dstInc
Increment destination address by ‘dstInc’ x ‘byteWidth’
-
uint16_t transferCount
Number of transfers
-
bool valid
-
struct _dma_channel_trigger
- #include <fsl_dma.h>
DMA channel trigger.
Public Members
-
dma_trigger_type_t type
Select hardware trigger as edge triggered or level triggered.
-
dma_trigger_burst_t burst
Select whether hardware triggers cause a single or burst transfer.
-
dma_burst_wrap_t wrap
Select wrap type, source wrap or dest wrap, or both.
-
dma_trigger_type_t type
-
struct _dma_channel_config
- #include <fsl_dma.h>
DMA channel trigger.
Public Members
-
void *srcStartAddr
Source data address
-
void *dstStartAddr
Destination data address
-
void *nextDesc
Chain custom descriptor
-
uint32_t xferCfg
channel transfer configurations
-
dma_channel_trigger_t *trigger
DMA trigger type
-
bool isPeriph
select the request type
-
void *srcStartAddr
-
struct _dma_transfer_config
- #include <fsl_dma.h>
DMA transfer configuration.
Public Members
-
uint8_t *srcAddr
Source data address
-
uint8_t *dstAddr
Destination data address
-
uint8_t *nextDesc
Chain custom descriptor
-
dma_xfercfg_t xfercfg
Transfer options
-
bool isPeriph
DMA transfer is driven by peripheral
-
uint8_t *srcAddr
-
struct _dma_handle
- #include <fsl_dma.h>
DMA transfer handle structure.
Public Members
-
dma_callback callback
Callback function. Invoked when transfer of descriptor with interrupt flag finishes
-
void *userData
Callback function parameter
-
DMA_Type *base
DMA peripheral base address
-
uint8_t channel
DMA channel number
-
dma_callback callback
DMIC: Digital Microphone
DMIC DMA Driver
-
status_t DMIC_TransferCreateHandleDMA(DMIC_Type *base, dmic_dma_handle_t *handle, dmic_dma_transfer_callback_t callback, void *userData, dma_handle_t *rxDmaHandle)
Initializes the DMIC handle which is used in transactional functions.
- Parameters:
base – DMIC peripheral base address.
handle – Pointer to dmic_dma_handle_t structure.
callback – Callback function.
userData – User data.
rxDmaHandle – User-requested DMA handle for RX DMA transfer.
-
status_t DMIC_TransferReceiveDMA(DMIC_Type *base, dmic_dma_handle_t *handle, dmic_transfer_t *xfer, uint32_t channel)
Receives data using DMA.
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:
base – USART peripheral base address.
handle – Pointer to usart_dma_handle_t structure.
xfer – DMIC DMA transfer structure. See dmic_transfer_t.
channel – DMIC start channel number.
- Return values:
kStatus_Success –
-
void DMIC_TransferAbortReceiveDMA(DMIC_Type *base, dmic_dma_handle_t *handle)
Aborts the received data using DMA.
This function aborts the received data using DMA.
- Parameters:
base – DMIC peripheral base address
handle – Pointer to dmic_dma_handle_t structure
-
status_t DMIC_TransferGetReceiveCountDMA(DMIC_Type *base, dmic_dma_handle_t *handle, uint32_t *count)
Get the number of bytes that have been received.
This function gets the number of bytes that have been received.
- Parameters:
base – DMIC peripheral base address.
handle – DMIC handle pointer.
count – Receive bytes count.
- Return values:
kStatus_NoTransferInProgress – No receive in progress.
kStatus_InvalidArgument – Parameter is invalid.
kStatus_Success – Get successfully through the parameter count;
-
void DMIC_InstallDMADescriptorMemory(dmic_dma_handle_t *handle, void *linkAddr, size_t linkNum)
Install DMA descriptor memory.
This function used to register DMA descriptor memory for linked transfer, a typical case is ping pong transfer which will request more than one DMA descriptor memory space, it should be called after DMIC_TransferCreateHandleDMA. User should be take care about the address of DMA descriptor pool which required align with 16BYTE at least.
- Parameters:
handle – Pointer to DMA channel transfer handle.
linkAddr – DMA link descriptor address.
linkNum – DMA link descriptor number.
-
FSL_DMIC_DMA_DRIVER_VERSION
DMIC DMA driver version 2.4.0.
-
typedef struct _dmic_transfer dmic_transfer_t
DMIC transfer structure.
-
typedef struct _dmic_dma_handle dmic_dma_handle_t
-
typedef void (*dmic_dma_transfer_callback_t)(DMIC_Type *base, dmic_dma_handle_t *handle, status_t status, void *userData)
DMIC transfer callback function.
-
struct _dmic_transfer
- #include <fsl_dmic_dma.h>
DMIC transfer structure.
Public Members
-
void *data
The buffer of data to be transfer.
-
uint8_t dataWidth
DMIC support 16bit/32bit
-
size_t dataSize
The byte count to be transfer.
-
uint8_t dataAddrInterleaveSize
destination address interleave size
-
struct _dmic_transfer *linkTransfer
use to support link transfer
-
void *data
-
struct _dmic_dma_handle
- #include <fsl_dmic_dma.h>
DMIC DMA handle.
Public Members
-
DMIC_Type *base
DMIC peripheral base address.
-
dma_handle_t *rxDmaHandle
The DMA RX channel used.
-
dmic_dma_transfer_callback_t callback
Callback function.
-
void *userData
DMIC callback function parameter.
-
size_t transferSize
Size of the data to receive.
-
volatile uint8_t state
Internal state of DMIC DMA transfer
-
uint32_t channel
DMIC channel used.
-
bool isChannelValid
DMIC channel initialization flag
-
dma_descriptor_t *desLink
descriptor pool pointer
-
size_t linkNum
number of descriptor in descriptors pool
-
DMIC_Type *base
DMIC Driver
-
uint32_t DMIC_GetInstance(DMIC_Type *base)
Get the DMIC instance from peripheral base address.
- Parameters:
base – DMIC peripheral base address.
- Returns:
DMIC instance.
-
void DMIC_Init(DMIC_Type *base)
Turns DMIC Clock on.
- Parameters:
base – : DMIC base
- Returns:
Nothing
-
void DMIC_DeInit(DMIC_Type *base)
Turns DMIC Clock off.
- Parameters:
base – : DMIC base
- Returns:
Nothing
-
void DMIC_SetOperationMode(DMIC_Type *base, operation_mode_t mode)
Set DMIC operating mode.
- Deprecated:
Do not use this function. It has been superceded by DMIC_EnableChannelInterrupt, DMIC_EnableChannelDma.
- Parameters:
base – : The base address of DMIC interface
mode – : DMIC mode
- Returns:
Nothing
-
void DMIC_Use2fs(DMIC_Type *base, bool use2fs)
Configure Clock scaling.
- Parameters:
base – : The base address of DMIC interface
use2fs – : clock scaling
- Returns:
Nothing
-
void DMIC_CfgChannelDc(DMIC_Type *base, dmic_channel_t channel, dc_removal_t dc_cut_level, uint32_t post_dc_gain_reduce, bool saturate16bit)
Configure DMIC channel.
- Parameters:
base – : The base address of DMIC interface
channel – : DMIC channel
dc_cut_level – : dc_removal_t, Cut off Frequency
post_dc_gain_reduce – : Fine gain adjustment in the form of a number of bits to downshift.
saturate16bit – : If selects 16-bit saturation.
-
static inline void DMIC_EnableChannelSignExtend(DMIC_Type *base, dmic_channel_t channel, bool enable)
Enbale channel sign extend which allows processing of 24bit audio data on 32bit machines.
- Parameters:
base – : The base address of DMIC interface
channel – : DMIC channel
enable – : true is enable sign extend, false is disable sign extend
-
void DMIC_ConfigChannel(DMIC_Type *base, dmic_channel_t channel, stereo_side_t side, dmic_channel_config_t *channel_config)
Configure DMIC channel.
- Parameters:
base – : The base address of DMIC interface
channel – : DMIC channel
side – : stereo_side_t, choice of left or right
channel_config – : Channel configuration
- Returns:
Nothing
-
void DMIC_EnableChannnel(DMIC_Type *base, uint32_t channelmask)
Enable a particualr channel.
- Parameters:
base – : The base address of DMIC interface
channelmask – reference _dmic_channel_mask
- Returns:
Nothing
-
void DMIC_FifoChannel(DMIC_Type *base, uint32_t channel, uint32_t trig_level, uint32_t enable, uint32_t resetn)
Configure fifo settings for DMIC channel.
- Parameters:
base – : The base address of DMIC interface
channel – : DMIC channel
trig_level – : FIFO trigger level
enable – : FIFO level
resetn – : FIFO reset
- Returns:
Nothing
-
static inline void DMIC_EnableChannelInterrupt(DMIC_Type *base, dmic_channel_t channel, bool enable)
Enable a particualr channel interrupt request.
- Parameters:
base – : The base address of DMIC interface
channel – : Channel selection
enable – : true is enable, false is disable
-
static inline void DMIC_EnableChannelDma(DMIC_Type *base, dmic_channel_t channel, bool enable)
Enable a particualr channel dma request.
- Parameters:
base – : The base address of DMIC interface
channel – : Channel selection
enable – : true is enable, false is disable
-
static inline void DMIC_EnableChannelFifo(DMIC_Type *base, dmic_channel_t channel, bool enable)
Enable a particualr channel fifo.
- Parameters:
base – : The base address of DMIC interface
channel – : Channel selection
enable – : true is enable, false is disable
-
static inline void DMIC_DoFifoReset(DMIC_Type *base, dmic_channel_t channel)
Channel fifo reset.
- Parameters:
base – : The base address of DMIC interface
channel – : Channel selection
-
static inline uint32_t DMIC_FifoGetStatus(DMIC_Type *base, uint32_t channel)
Get FIFO status.
- Parameters:
base – : The base address of DMIC interface
channel – : DMIC channel
- Returns:
FIFO status
-
static inline void DMIC_FifoClearStatus(DMIC_Type *base, uint32_t channel, uint32_t mask)
Clear FIFO status.
- Parameters:
base – : The base address of DMIC interface
channel – : DMIC channel
mask – : Bits to be cleared
- Returns:
FIFO status
-
static inline uint32_t DMIC_FifoGetData(DMIC_Type *base, uint32_t channel)
Get FIFO data.
- Parameters:
base – : The base address of DMIC interface
channel – : DMIC channel
- Returns:
FIFO data
-
static inline uint32_t DMIC_FifoGetAddress(DMIC_Type *base, uint32_t channel)
Get FIFO address.
- Parameters:
base – : The base address of DMIC interface
channel – : DMIC channel
- Returns:
FIFO data
-
void DMIC_ResetChannelDecimator(DMIC_Type *base, uint32_t channelMask, bool reset)
DMIC channel Decimator reset.
- Parameters:
base – : The base address of DMIC interface
channelMask – : DMIC channel mask, reference _dmic_channel_mask
reset – : true is reset decimator, false is release decimator.
-
static inline void DMIC_EnableChannelGlobalSync(DMIC_Type *base, uint32_t channelMask, uint32_t syncCounter)
Enable DMIC channel global sync function.
- Parameters:
base – : The base address of DMIC interface
channelMask – : DMIC channel mask, reference _dmic_channel_mask
syncCounter – :sync counter will trigger a pulse whenever count reaches CCOUNTVAL. If CCOUNTVAL is set to 0, there will be a pulse on every cycle
-
static inline void DMIC_DisableChannelGlobalSync(DMIC_Type *base, uint32_t channelMask)
Disbale DMIC channel global sync function.
- Parameters:
base – : The base address of DMIC interface
channelMask – : DMIC channel mask, reference _dmic_channel_mask
-
void DMIC_EnableIntCallback(DMIC_Type *base, dmic_callback_t cb)
Enable callback.
This function enables the interrupt for the selected DMIC peripheral. The callback function is not enabled until this function is called.
- Parameters:
base – Base address of the DMIC peripheral.
cb – callback Pointer to store callback function.
- Return values:
None. –
-
void DMIC_DisableIntCallback(DMIC_Type *base, dmic_callback_t cb)
Disable callback.
This function disables the interrupt for the selected DMIC peripheral.
- Parameters:
base – Base address of the DMIC peripheral.
cb – callback Pointer to store callback function..
- Return values:
None. –
-
static inline void DMIC_SetGainNoiseEstHwvad(DMIC_Type *base, uint32_t value)
Sets the gain value for the noise estimator.
- Parameters:
base – DMIC base pointer
value – gain value for the noise estimator.
- Return values:
None. –
-
static inline void DMIC_SetGainSignalEstHwvad(DMIC_Type *base, uint32_t value)
Sets the gain value for the signal estimator.
- Parameters:
base – DMIC base pointer
value – gain value for the signal estimator.
- Return values:
None. –
-
static inline void DMIC_SetFilterCtrlHwvad(DMIC_Type *base, uint32_t value)
Sets the hwvad filter cutoff frequency parameter.
- Parameters:
base – DMIC base pointer
value – cut off frequency value.
- Return values:
None. –
-
static inline void DMIC_SetInputGainHwvad(DMIC_Type *base, uint32_t value)
Sets the input gain of hwvad.
- Parameters:
base – DMIC base pointer
value – input gain value for hwvad.
- Return values:
None. –
-
static inline void DMIC_CtrlClrIntrHwvad(DMIC_Type *base, bool st10)
Clears hwvad internal interrupt flag.
- Parameters:
base – DMIC base pointer
st10 – bit value.
- Return values:
None. –
-
static inline void DMIC_FilterResetHwvad(DMIC_Type *base, bool rstt)
Resets hwvad filters.
- Parameters:
base – DMIC base pointer
rstt – Reset bit value.
- Return values:
None. –
-
static inline uint16_t DMIC_GetNoiseEnvlpEst(DMIC_Type *base)
Gets the value from output of the filter z7.
- Parameters:
base – DMIC base pointer
- Return values:
output – of filter z7.
-
void DMIC_HwvadEnableIntCallback(DMIC_Type *base, dmic_hwvad_callback_t vadcb)
Enable hwvad callback.
This function enables the hwvad interrupt for the selected DMIC peripheral. The callback function is not enabled until this function is called.
- Parameters:
base – Base address of the DMIC peripheral.
vadcb – callback Pointer to store callback function.
- Return values:
None. –
-
void DMIC_HwvadDisableIntCallback(DMIC_Type *base, dmic_hwvad_callback_t vadcb)
Disable callback.
This function disables the hwvad interrupt for the selected DMIC peripheral.
- Parameters:
base – Base address of the DMIC peripheral.
vadcb – callback Pointer to store callback function..
- Return values:
None. –
-
FSL_DMIC_DRIVER_VERSION
DMIC driver version 2.3.2.
_dmic_status DMIC transfer status.
Values:
-
enumerator kStatus_DMIC_Busy
DMIC is busy
-
enumerator kStatus_DMIC_Idle
DMIC is idle
-
enumerator kStatus_DMIC_OverRunError
DMIC over run Error
-
enumerator kStatus_DMIC_UnderRunError
DMIC under run Error
-
enumerator kStatus_DMIC_Busy
-
enum _operation_mode
DMIC different operation modes.
Values:
-
enumerator kDMIC_OperationModeInterrupt
Interrupt mode
-
enumerator kDMIC_OperationModeDma
DMA mode
-
enumerator kDMIC_OperationModeInterrupt
-
enum _stereo_side
DMIC left/right values.
Values:
-
enumerator kDMIC_Left
Left Stereo channel
-
enumerator kDMIC_Right
Right Stereo channel
-
enumerator kDMIC_Left
-
enum pdm_div_t
DMIC Clock pre-divider values.
Values:
-
enumerator kDMIC_PdmDiv1
DMIC pre-divider set in divide by 1
-
enumerator kDMIC_PdmDiv2
DMIC pre-divider set in divide by 2
-
enumerator kDMIC_PdmDiv3
DMIC pre-divider set in divide by 3
-
enumerator kDMIC_PdmDiv4
DMIC pre-divider set in divide by 4
-
enumerator kDMIC_PdmDiv6
DMIC pre-divider set in divide by 6
-
enumerator kDMIC_PdmDiv8
DMIC pre-divider set in divide by 8
-
enumerator kDMIC_PdmDiv12
DMIC pre-divider set in divide by 12
-
enumerator kDMIC_PdmDiv16
DMIC pre-divider set in divide by 16
-
enumerator kDMIC_PdmDiv24
DMIC pre-divider set in divide by 24
-
enumerator kDMIC_PdmDiv32
DMIC pre-divider set in divide by 32
-
enumerator kDMIC_PdmDiv48
DMIC pre-divider set in divide by 48
-
enumerator kDMIC_PdmDiv64
DMIC pre-divider set in divide by 64
-
enumerator kDMIC_PdmDiv96
DMIC pre-divider set in divide by 96
-
enumerator kDMIC_PdmDiv128
DMIC pre-divider set in divide by 128
-
enumerator kDMIC_PdmDiv1
-
enum _compensation
Pre-emphasis Filter coefficient value for 2FS and 4FS modes.
Values:
-
enumerator kDMIC_CompValueZero
Compensation 0
-
enumerator kDMIC_CompValueNegativePoint16
Compensation -0.16
-
enumerator kDMIC_CompValueNegativePoint15
Compensation -0.15
-
enumerator kDMIC_CompValueNegativePoint13
Compensation -0.13
-
enumerator kDMIC_CompValueZero
-
enum _dc_removal
DMIC DC filter control values.
Values:
-
enumerator kDMIC_DcNoRemove
Flat response no filter
-
enumerator kDMIC_DcCut155
Cut off Frequency is 155 Hz
-
enumerator kDMIC_DcCut78
Cut off Frequency is 78 Hz
-
enumerator kDMIC_DcCut39
Cut off Frequency is 39 Hz
-
enumerator kDMIC_DcNoRemove
-
enum _dmic_channel
DMIC Channel number.
Values:
-
enumerator kDMIC_Channel0
DMIC channel 0
-
enumerator kDMIC_Channel1
DMIC channel 1
-
enumerator kDMIC_Channel0
_dmic_channel_mask DMIC Channel mask.
Values:
-
enumerator kDMIC_EnableChannel0
DMIC channel 0 mask
-
enumerator kDMIC_EnableChannel1
DMIC channel 1 mask
-
enumerator kDMIC_EnableChannel0
-
enum _dmic_phy_sample_rate
DMIC and decimator sample rates.
Values:
-
enumerator kDMIC_PhyFullSpeed
Decimator gets one sample per each chosen clock edge of PDM interface
-
enumerator kDMIC_PhyHalfSpeed
PDM clock to Microphone is halved, decimator receives each sample twice
-
enumerator kDMIC_PhyFullSpeed
-
typedef enum _operation_mode operation_mode_t
DMIC different operation modes.
-
typedef enum _stereo_side stereo_side_t
DMIC left/right values.
-
typedef enum _compensation compensation_t
Pre-emphasis Filter coefficient value for 2FS and 4FS modes.
-
typedef enum _dc_removal dc_removal_t
DMIC DC filter control values.
-
typedef enum _dmic_channel dmic_channel_t
DMIC Channel number.
-
typedef enum _dmic_phy_sample_rate dmic_phy_sample_rate_t
DMIC and decimator sample rates.
-
typedef struct _dmic_channel_config dmic_channel_config_t
DMIC Channel configuration structure.
-
typedef void (*dmic_callback_t)(void)
DMIC Callback function.
-
typedef void (*dmic_hwvad_callback_t)(void)
HWVAD Callback function.
-
struct _dmic_channel_config
- #include <fsl_dmic.h>
DMIC Channel configuration structure.
Public Members
-
pdm_div_t divhfclk
DMIC Clock pre-divider values
-
uint32_t osr
oversampling rate(CIC decimation rate) for PCM
-
int32_t gainshft
4FS PCM data gain control
-
compensation_t preac2coef
Pre-emphasis Filter coefficient value for 2FS
-
compensation_t preac4coef
Pre-emphasis Filter coefficient value for 4FS
-
dc_removal_t dc_cut_level
DMIC DC filter control values.
-
uint32_t post_dc_gain_reduce
Fine gain adjustment in the form of a number of bits to downshift
-
dmic_phy_sample_rate_t sample_rate
DMIC and decimator sample rates
-
bool saturate16bit
Selects 16-bit saturation. 0 means results roll over if out range and do not saturate. 1 means if the result overflows, it saturates at 0xFFFF for positive overflow and 0x8000 for negative overflow.
-
bool enableSignExtend
sign extend feature which allows processing of 24bit audio data on 32bit machine
-
pdm_div_t divhfclk
Efuse_driver
-
status_t EFUSE_Init(void)
Initialize EFUSE controller.
This function enables EFUSE Controller clock.
- Return values:
kStatus_Success – 0 Operation succeeded without error.
kStatus_Fail – 1 The operation failed with a generic error.
kStatus_ReadOnly – 2 Requested value cannot be changed because it is read-only.
kStatus_OutOfRange – 3 Requested value is out of range.
kStatus_InvalidArgument – 4 The requested command’s argument is undefined.
kStatus_Timeout – An invalid 5 A timeout occurred
kStatus_NoTransferInProgress – 6 No send in progress.
-
status_t EFUSE_Deinit(void)
De-Initialize EFUSE controller.
This functin disables EFUSE Controller Clock.
- Return values:
kStatus_Success – 0 Operation succeeded without error.
kStatus_Fail – 1 The operation failed with a generic error.
kStatus_ReadOnly – 2 Requested value cannot be changed because it is read-only.
kStatus_OutOfRange – 3 Requested value is out of range.
kStatus_InvalidArgument – 4 The requested command’s argument is undefined.
kStatus_Timeout – An invalid 5 A timeout occurred
kStatus_NoTransferInProgress – 6 No send in progress.
-
status_t EFUSE_Read(uint32_t addr, uint32_t *data)
Read Fuse value from eFuse word.
This function read fuse data from eFuse word to specified data buffer.
- Parameters:
addr – Fuse address
data – Buffer to hold the data read from eFuse word
- Return values:
kStatus_Success – 0 Operation succeeded without error.
kStatus_Fail – 1 The operation failed with a generic error.
kStatus_ReadOnly – 2 Requested value cannot be changed because it is read-only.
kStatus_OutOfRange – 3 Requested value is out of range.
kStatus_InvalidArgument – 4 The requested command’s argument is undefined.
kStatus_Timeout – An invalid 5 A timeout occurred
kStatus_NoTransferInProgress – 6 No send in progress.
-
status_t EFUSE_Program(uint32_t addr, uint32_t data)
Program value to eFuse block.
This function program data to specified eFuse address.
- Parameters:
addr – Fuse address
data – data to be programmed into eFuse Fuse block
- Return values:
kStatus_Success – 0 Operation succeeded without error.
kStatus_Fail – 1 The operation failed with a generic error.
kStatus_ReadOnly – 2 Requested value cannot be changed because it is read-only.
kStatus_OutOfRange – 3 Requested value is out of range.
kStatus_InvalidArgument – 4 The requested command’s argument is undefined.
kStatus_Timeout – An invalid 5 A timeout occurred
kStatus_NoTransferInProgress – 6 No send in progress.
ENC: Quadrature Encoder/Decoder
-
void ENC_Init(ENC_Type *base, const enc_config_t *config)
Initialization for the ENC module.
This function is to make the initialization for the ENC module. It should be called firstly before any operation to the ENC with the operations like:
Enable the clock for ENC module.
Configure the ENC’s working attributes.
- Parameters:
base – ENC peripheral base address.
config – Pointer to configuration structure. See to “enc_config_t”.
-
void ENC_Deinit(ENC_Type *base)
De-initialization for the ENC module.
This function is to make the de-initialization for the ENC module. It could be called when ENC is no longer used with the operations like:
Disable the clock for ENC module.
- Parameters:
base – ENC peripheral base address.
-
void ENC_GetDefaultConfig(enc_config_t *config)
Get an available pre-defined settings for ENC’s configuration.
This function initializes the ENC configuration structure with an available settings, the default value are:
config->enableReverseDirection = false; config->decoderWorkMode = kENC_DecoderWorkAsNormalMode; config->HOMETriggerMode = kENC_HOMETriggerDisabled; config->INDEXTriggerMode = kENC_INDEXTriggerDisabled; config->enableTRIGGERClearPositionCounter = false; config->enableTRIGGERClearHoldPositionCounter = false; config->enableWatchdog = false; config->watchdogTimeoutValue = 0U; config->filterCount = 0U; config->filterSamplePeriod = 0U; config->positionMatchMode = kENC_POSMATCHOnPositionCounterEqualToComapreValue; config->positionCompareValue = 0xFFFFFFFFU; config->revolutionCountCondition = kENC_RevolutionCountOnINDEXPulse; config->enableModuloCountMode = false; config->positionModulusValue = 0U; config->positionInitialValue = 0U; config->prescalerValue = kENC_ClockDiv1; config->enablePeriodMeasurementFunction = true;
- Parameters:
config – Pointer to a variable of configuration structure. See to “enc_config_t”.
-
void ENC_DoSoftwareLoadInitialPositionValue(ENC_Type *base)
Load the initial position value to position counter.
This function is to transfer the initial position value (UINIT and LINIT) contents to position counter (UPOS and LPOS), so that to provide the consistent operation the position counter registers.
- Parameters:
base – ENC peripheral base address.
-
void ENC_SetSelfTestConfig(ENC_Type *base, const enc_self_test_config_t *config)
Enable and configure the self test function.
This function is to enable and configuration the self test function. It controls and sets the frequency of a quadrature signal generator. It provides a quadrature test signal to the inputs of the quadrature decoder module. It is a factory test feature; however, it may be useful to customers’ software development and testing.
- Parameters:
base – ENC peripheral base address.
config – Pointer to configuration structure. See to “enc_self_test_config_t”. Pass “NULL” to disable.
-
void ENC_EnableWatchdog(ENC_Type *base, bool enable)
Enable watchdog for ENC module.
- Parameters:
base – ENC peripheral base address
enable – Enables or disables the watchdog
-
void ENC_SetInitialPositionValue(ENC_Type *base, uint32_t value)
Set initial position value for ENC module.
- Parameters:
base – ENC peripheral base address
value – Positive initial value
-
uint32_t ENC_GetStatusFlags(ENC_Type *base)
Get the status flags.
- Parameters:
base – ENC peripheral base address.
- Returns:
Mask value of status flags. For available mask, see to “_enc_status_flags”.
-
void ENC_ClearStatusFlags(ENC_Type *base, uint32_t mask)
Clear the status flags.
- Parameters:
base – ENC peripheral base address.
mask – Mask value of status flags to be cleared. For available mask, see to “_enc_status_flags”.
-
static inline uint16_t ENC_GetSignalStatusFlags(ENC_Type *base)
Get the signals’ real-time status.
- Parameters:
base – ENC peripheral base address.
- Returns:
Mask value of signals’ real-time status. For available mask, see to “_enc_signal_status_flags”
-
void ENC_EnableInterrupts(ENC_Type *base, uint32_t mask)
Enable the interrupts.
- Parameters:
base – ENC peripheral base address.
mask – Mask value of interrupts to be enabled. For available mask, see to “_enc_interrupt_enable”.
-
void ENC_DisableInterrupts(ENC_Type *base, uint32_t mask)
Disable the interrupts.
- Parameters:
base – ENC peripheral base address.
mask – Mask value of interrupts to be disabled. For available mask, see to “_enc_interrupt_enable”.
-
uint32_t ENC_GetEnabledInterrupts(ENC_Type *base)
Get the enabled interrupts’ flags.
- Parameters:
base – ENC peripheral base address.
- Returns:
Mask value of enabled interrupts.
-
uint32_t ENC_GetPositionValue(ENC_Type *base)
Get the current position counter’s value.
- Parameters:
base – ENC peripheral base address.
- Returns:
Current position counter’s value.
-
uint32_t ENC_GetHoldPositionValue(ENC_Type *base)
Get the hold position counter’s value.
When any of the counter registers is read, the contents of each counter register is written to the corresponding hold register. Taking a snapshot of the counters’ values provides a consistent view of a system position and a velocity to be attained.
- Parameters:
base – ENC peripheral base address.
- Returns:
Hold position counter’s value.
-
static inline uint16_t ENC_GetPositionDifferenceValue(ENC_Type *base)
Get the position difference counter’s value.
- Parameters:
base – ENC peripheral base address.
- Returns:
The position difference counter’s value.
-
static inline uint16_t ENC_GetHoldPositionDifferenceValue(ENC_Type *base)
Get the hold position difference counter’s value.
When any of the counter registers is read, the contents of each counter register is written to the corresponding hold register. Taking a snapshot of the counters’ values provides a consistent view of a system position and a velocity to be attained.
- Parameters:
base – ENC peripheral base address.
- Returns:
Hold position difference counter’s value.
-
static inline uint16_t ENC_GetRevolutionValue(ENC_Type *base)
Get the position revolution counter’s value.
- Parameters:
base – ENC peripheral base address.
- Returns:
The position revolution counter’s value.
-
static inline uint16_t ENC_GetHoldRevolutionValue(ENC_Type *base)
Get the hold position revolution counter’s value.
When any of the counter registers is read, the contents of each counter register is written to the corresponding hold register. Taking a snapshot of the counters’ values provides a consistent view of a system position and a velocity to be attained.
- Parameters:
base – ENC peripheral base address.
- Returns:
Hold position revolution counter’s value.
-
static inline uint16_t ENC_GetLastEdgeTimeValue(ENC_Type *base)
Get the last edge time value.
- Parameters:
base – ENC peripheral base address.
- Returns:
The last edge time hold value.
-
static inline uint16_t ENC_GetHoldLastEdgeTimeValue(ENC_Type *base)
Get the last edge time hold value.
- Parameters:
base – ENC peripheral base address.
- Returns:
The last edge time hold value.
-
static inline uint16_t ENC_GetPositionDifferencePeriodValue(ENC_Type *base)
Get the position difference period value.
- Parameters:
base – ENC peripheral base address.
- Returns:
The position difference period hold value.
-
static inline uint16_t ENC_GetPositionDifferencePeriodBufferValue(ENC_Type *base)
Get the position difference period buffer value.
- Parameters:
base – ENC peripheral base address.
- Returns:
The position difference period hold value.
-
static inline uint16_t ENC_GetHoldPositionDifferencePeriodValue(ENC_Type *base)
Get the position difference period hold value.
- Parameters:
base – ENC peripheral base address.
- Returns:
The position difference period hold value.
-
enum _enc_interrupt_enable
Interrupt enable/disable mask.
Values:
-
enumerator kENC_HOMETransitionInterruptEnable
HOME interrupt enable.
-
enumerator kENC_INDEXPulseInterruptEnable
INDEX pulse interrupt enable.
-
enumerator kENC_WatchdogTimeoutInterruptEnable
Watchdog timeout interrupt enable.
-
enumerator kENC_PositionCompareInerruptEnable
Position compare interrupt enable.
-
enumerator kENC_PositionRollOverInterruptEnable
Roll-over interrupt enable.
-
enumerator kENC_PositionRollUnderInterruptEnable
Roll-under interrupt enable.
-
enumerator kENC_HOMETransitionInterruptEnable
-
enum _enc_status_flags
Status flag mask.
These flags indicate the counter’s events.
Values:
-
enumerator kENC_HOMETransitionFlag
HOME signal transition interrupt request.
-
enumerator kENC_INDEXPulseFlag
INDEX Pulse Interrupt Request.
-
enumerator kENC_WatchdogTimeoutFlag
Watchdog timeout interrupt request.
-
enumerator kENC_PositionCompareFlag
Position compare interrupt request.
-
enumerator kENC_PositionRollOverFlag
Roll-over interrupt request.
-
enumerator kENC_PositionRollUnderFlag
Roll-under interrupt request.
-
enumerator kENC_LastCountDirectionFlag
Last count was in the up direction, or the down direction.
-
enumerator kENC_HOMETransitionFlag
-
enum _enc_signal_status_flags
Signal status flag mask.
These flags indicate the counter’s signal.
Values:
-
enumerator kENC_RawHOMEStatusFlag
Raw HOME input.
-
enumerator kENC_RawINDEXStatusFlag
Raw INDEX input.
-
enumerator kENC_RawPHBStatusFlag
Raw PHASEB input.
-
enumerator kENC_RawPHAEXStatusFlag
Raw PHASEA input.
-
enumerator kENC_FilteredHOMEStatusFlag
The filtered version of HOME input.
-
enumerator kENC_FilteredINDEXStatusFlag
The filtered version of INDEX input.
-
enumerator kENC_FilteredPHBStatusFlag
The filtered version of PHASEB input.
-
enumerator kENC_FilteredPHAStatusFlag
The filtered version of PHASEA input.
-
enumerator kENC_RawHOMEStatusFlag
-
enum _enc_home_trigger_mode
Define HOME signal’s trigger mode.
The ENC would count the trigger from HOME signal line.
Values:
-
enumerator kENC_HOMETriggerDisabled
HOME signal’s trigger is disabled.
-
enumerator kENC_HOMETriggerOnRisingEdge
Use positive going edge-to-trigger initialization of position counters.
-
enumerator kENC_HOMETriggerOnFallingEdge
Use negative going edge-to-trigger initialization of position counters.
-
enumerator kENC_HOMETriggerDisabled
-
enum _enc_index_trigger_mode
Define INDEX signal’s trigger mode.
The ENC would count the trigger from INDEX signal line.
Values:
-
enumerator kENC_INDEXTriggerDisabled
INDEX signal’s trigger is disabled.
-
enumerator kENC_INDEXTriggerOnRisingEdge
Use positive going edge-to-trigger initialization of position counters.
-
enumerator kENC_INDEXTriggerOnFallingEdge
Use negative going edge-to-trigger initialization of position counters.
-
enumerator kENC_INDEXTriggerDisabled
-
enum _enc_decoder_work_mode
Define type for decoder work mode.
The normal work mode uses the standard quadrature decoder with PHASEA and PHASEB. When in signal phase count mode, a positive transition of the PHASEA input generates a count signal while the PHASEB input and the reverse direction control the counter direction. If the reverse direction is not enabled, PHASEB = 0 means counting up and PHASEB = 1 means counting down. Otherwise, the direction is reversed.
Values:
-
enumerator kENC_DecoderWorkAsNormalMode
Use standard quadrature decoder with PHASEA and PHASEB.
-
enumerator kENC_DecoderWorkAsSignalPhaseCountMode
PHASEA input generates a count signal while PHASEB input control the direction.
-
enumerator kENC_DecoderWorkAsNormalMode
-
enum _enc_position_match_mode
Define type for the condition of POSMATCH pulses.
Values:
-
enumerator kENC_POSMATCHOnPositionCounterEqualToComapreValue
POSMATCH pulses when a match occurs between the position counters (POS) and the compare value (COMP).
-
enumerator kENC_POSMATCHOnReadingAnyPositionCounter
POSMATCH pulses when any position counter register is read.
-
enumerator kENC_POSMATCHOnPositionCounterEqualToComapreValue
-
enum _enc_revolution_count_condition
Define type for determining how the revolution counter (REV) is incremented/decremented.
Values:
-
enumerator kENC_RevolutionCountOnINDEXPulse
Use INDEX pulse to increment/decrement revolution counter.
-
enumerator kENC_RevolutionCountOnRollOverModulus
Use modulus counting roll-over/under to increment/decrement revolution counter.
-
enumerator kENC_RevolutionCountOnINDEXPulse
-
enum _enc_self_test_direction
Define type for direction of self test generated signal.
Values:
-
enumerator kENC_SelfTestDirectionPositive
Self test generates the signal in positive direction.
-
enumerator kENC_SelfTestDirectionNegative
Self test generates the signal in negative direction.
-
enumerator kENC_SelfTestDirectionPositive
-
enum _enc_prescaler
Define prescaler value for clock in CTRL3.
The clock is prescaled by a value of 2^PRSC which means that the prescaler logic can divide the clock by a minimum of 1 and a maximum of 32,768.
Values:
-
enumerator kENC_ClockDiv1
-
enumerator kENC_ClockDiv2
-
enumerator kENC_ClockDiv4
-
enumerator kENC_ClockDiv8
-
enumerator kENC_ClockDiv16
-
enumerator kENC_ClockDiv32
-
enumerator kENC_ClockDiv64
-
enumerator kENC_ClockDiv128
-
enumerator kENC_ClockDiv256
-
enumerator kENC_ClockDiv512
-
enumerator kENC_ClockDiv1024
-
enumerator kENC_ClockDiv2048
-
enumerator kENC_ClockDiv4096
-
enumerator kENC_ClockDiv8192
-
enumerator kENC_ClockDiv16384
-
enumerator kENC_ClockDiv32768
-
enumerator kENC_ClockDiv1
-
enum _enc_filter_prescaler
Define input filter prescaler value.
The input filter prescaler value is to prescale the IPBus clock. (Frequency of FILT clock) = (Frequency of IPBus clock) / 2^FILT_PRSC.
Values:
-
enumerator kENC_FilterPrescalerDiv1
Input filter prescaler is 1.
-
enumerator kENC_FilterPrescalerDiv2
Input filter prescaler is 2.
-
enumerator kENC_FilterPrescalerDiv4
Input filter prescaler is 4.
-
enumerator kENC_FilterPrescalerDiv8
Input filter prescaler is 8.
-
enumerator kENC_FilterPrescalerDiv16
Input filter prescaler is 16.
-
enumerator kENC_FilterPrescalerDiv32
Input filter prescaler is 32.
-
enumerator kENC_FilterPrescalerDiv64
Input filter prescaler is 64.
-
enumerator kENC_FilterPrescalerDiv128
Input filter prescaler is 128.
-
enumerator kENC_FilterPrescalerDiv1
-
typedef enum _enc_home_trigger_mode enc_home_trigger_mode_t
Define HOME signal’s trigger mode.
The ENC would count the trigger from HOME signal line.
-
typedef enum _enc_index_trigger_mode enc_index_trigger_mode_t
Define INDEX signal’s trigger mode.
The ENC would count the trigger from INDEX signal line.
-
typedef enum _enc_decoder_work_mode enc_decoder_work_mode_t
Define type for decoder work mode.
The normal work mode uses the standard quadrature decoder with PHASEA and PHASEB. When in signal phase count mode, a positive transition of the PHASEA input generates a count signal while the PHASEB input and the reverse direction control the counter direction. If the reverse direction is not enabled, PHASEB = 0 means counting up and PHASEB = 1 means counting down. Otherwise, the direction is reversed.
-
typedef enum _enc_position_match_mode enc_position_match_mode_t
Define type for the condition of POSMATCH pulses.
-
typedef enum _enc_revolution_count_condition enc_revolution_count_condition_t
Define type for determining how the revolution counter (REV) is incremented/decremented.
-
typedef enum _enc_self_test_direction enc_self_test_direction_t
Define type for direction of self test generated signal.
-
typedef enum _enc_prescaler enc_prescaler_t
Define prescaler value for clock in CTRL3.
The clock is prescaled by a value of 2^PRSC which means that the prescaler logic can divide the clock by a minimum of 1 and a maximum of 32,768.
-
typedef enum _enc_filter_prescaler enc_filter_prescaler_t
Define input filter prescaler value.
The input filter prescaler value is to prescale the IPBus clock. (Frequency of FILT clock) = (Frequency of IPBus clock) / 2^FILT_PRSC.
-
typedef struct _enc_config enc_config_t
Define user configuration structure for ENC module.
-
typedef struct _enc_self_test_config enc_self_test_config_t
Define configuration structure for self test module.
The self test module provides a quadrature test signal to the inputs of the quadrature decoder module. This is a factory test feature. It is also useful to customers’ software development and testing.
-
FSL_ENC_DRIVER_VERSION
-
struct _enc_config
- #include <fsl_enc.h>
Define user configuration structure for ENC module.
Public Members
-
bool enableReverseDirection
Enable reverse direction counting.
-
enc_decoder_work_mode_t decoderWorkMode
Enable signal phase count mode.
-
enc_home_trigger_mode_t HOMETriggerMode
Enable HOME to initialize position counters.
-
enc_index_trigger_mode_t INDEXTriggerMode
Enable INDEX to initialize position counters.
-
bool enableTRIGGERClearPositionCounter
Clear POSD, REV, UPOS and LPOS on rising edge of TRIGGER, or not.
-
bool enableTRIGGERClearHoldPositionCounter
Enable update of hold registers on rising edge of TRIGGER, or not.
-
bool enableWatchdog
Enable the watchdog to detect if the target is moving or not.
-
uint16_t watchdogTimeoutValue
Watchdog timeout count value. It stores the timeout count for the quadrature decoder module watchdog timer. This field is only available when “enableWatchdog” = true. The available value is a 16-bit unsigned number.
-
enc_filter_prescaler_t filterPrescaler
Input filter prescaler.
-
uint16_t filterCount
Input Filter Sample Count. This value should be chosen to reduce the probability of noisy samples causing an incorrect transition to be recognized. The value represent the number of consecutive samples that must agree prior to the input filter accepting an input transition. A value of 0x0 represents 3 samples. A value of 0x7 represents 10 samples. The Available range is 0 - 7.
-
uint16_t filterSamplePeriod
Input Filter Sample Period. This value should be set such that the sampling period is larger than the period of the expected noise. This value represents the sampling period (in IPBus clock cycles) of the decoder input signals. The available range is 0 - 255.
-
enc_position_match_mode_t positionMatchMode
The condition of POSMATCH pulses.
-
uint32_t positionCompareValue
Position compare value. The available value is a 32-bit number.
-
enc_revolution_count_condition_t revolutionCountCondition
Revolution Counter Modulus Enable.
-
bool enableModuloCountMode
Enable Modulo Counting.
-
uint32_t positionModulusValue
Position modulus value. This value would be available only when “enableModuloCountMode” = true. The available value is a 32-bit number.
-
uint32_t positionInitialValue
Position initial value. The available value is a 32-bit number.
-
bool enablePeriodMeasurementFunction
Enable period measurement function.
-
enc_prescaler_t prescalerValue
The value of prescaler.
-
bool enableReverseDirection
-
struct _enc_self_test_config
- #include <fsl_enc.h>
Define configuration structure for self test module.
The self test module provides a quadrature test signal to the inputs of the quadrature decoder module. This is a factory test feature. It is also useful to customers’ software development and testing.
Public Members
-
enc_self_test_direction_t signalDirection
Direction of self test generated signal.
-
uint16_t signalCount
Hold the number of quadrature advances to generate. The available range is 0 - 255.
-
uint16_t signalPeriod
Hold the period of quadrature phase in IPBus clock cycles. The available range is 0 - 31.
-
enc_self_test_direction_t signalDirection
Flash_driver
-
enum _flash_driver_version_constants
Flash driver version for ROM.
Values:
-
enumerator kFLASH_DriverVersionName
Flash driver version name.
-
enumerator kFLASH_DriverVersionMajor
Major flash driver version.
-
enumerator kFLASH_DriverVersionMinor
Minor flash driver version.
-
enumerator kFLASH_DriverVersionBugfix
Bugfix for flash driver version.
-
enumerator kFLASH_DriverVersionName
-
FSL_ROMAPI_FLASH_DRIVER_VERSION
ROMAPI_FLASH driver version 2.0.0.
Flash driver status codes.
Values:
-
enumerator kStatus_FLASH_Success
API is executed successfully
-
enumerator kStatus_FLASH_InvalidArgument
Invalid argument
-
enumerator kStatus_FLASH_SizeError
Error size
-
enumerator kStatus_FLASH_AlignmentError
Parameter is not aligned with the specified baseline
-
enumerator kStatus_FLASH_AddressError
Address is out of range
-
enumerator kStatus_FLASH_AccessError
Invalid instruction codes and out-of bound addresses
-
enumerator kStatus_FLASH_ProtectionViolation
The program/erase operation is requested to execute on protected areas
-
enumerator kStatus_FLASH_CommandFailure
Run-time error during command execution.
-
enumerator kStatus_FLASH_UnknownProperty
Unknown property.
-
enumerator kStatus_FLASH_EraseKeyError
API erase key is invalid.
-
enumerator kStatus_FLASH_RegionExecuteOnly
The current region is execute-only.
-
enumerator kStatus_FLASH_ExecuteInRamFunctionNotReady
Execute-in-RAM function is not available.
-
enumerator kStatus_FLASH_CommandNotSupported
Flash API is not supported.
-
enumerator kStatus_FLASH_ReadOnlyProperty
The flash property is read-only.
-
enumerator kStatus_FLASH_InvalidPropertyValue
The flash property value is out of range.
-
enumerator kStatus_FLASH_InvalidSpeculationOption
The option of flash prefetch speculation is invalid.
-
enumerator kStatus_FLASH_EccError
A correctable or uncorrectable error during command execution.
-
enumerator kStatus_FLASH_CompareError
Destination and source memory contents do not match.
-
enumerator kStatus_FLASH_RegulationLoss
A loss of regulation during read.
-
enumerator kStatus_FLASH_InvalidWaitStateCycles
The wait state cycle set to r/w mode is invalid.
-
enumerator kStatus_FLASH_OutOfDateCfpaPage
CFPA page version is out of date.
-
enumerator kStatus_FLASH_BlankIfrPageData
Blank page cannnot be read.
-
enumerator kStatus_FLASH_EncryptedRegionsEraseNotDoneAtOnce
Encrypted flash subregions are not erased at once.
-
enumerator kStatus_FLASH_ProgramVerificationNotAllowed
Program verification is not allowed when the encryption is enabled.
-
enumerator kStatus_FLASH_HashCheckError
Hash check of page data is failed.
-
enumerator kStatus_FLASH_SealedFfrRegion
The FFR region is sealed.
-
enumerator kStatus_FLASH_FfrRegionWriteBroken
The FFR Spec region is not allowed to be written discontinuously.
-
enumerator kStatus_FLASH_NmpaAccessNotAllowed
The NMPA region is not allowed to be read/written/erased.
-
enumerator kStatus_FLASH_CmpaCfgDirectEraseNotAllowed
The CMPA Cfg region is not allowed to be erased directly.
-
enumerator kStatus_FLASH_FfrBankIsLocked
The FFR bank region is locked.
-
enumerator kStatus_FLASH_CfpaScratchPageInvalid
CFPA Scratch Page is invalid
-
enumerator kStatus_FLASH_CfpaVersionRollbackDisallowed
CFPA version rollback is not allowed
-
enumerator kStatus_FLASH_ReadHidingAreaDisallowed
Flash hiding read is not allowed
-
enumerator kStatus_FLASH_ModifyProtectedAreaDisallowed
Flash firewall page locked erase and program are not allowed
-
enumerator kStatus_FLASH_CommandOperationInProgress
The flash state is busy, indicate that a flash command in progress.
-
enumerator kStatus_FLASH_Success
-
status_t FLASH_IsFlashAreaReadable(flash_config_t *config, uint32_t startAddress, uint32_t lengthInBytes)
Validates the given address range is loaded in the flash hiding region.
- Parameters:
config – A pointer to the storage for the driver runtime state.
startAddress – The start address of the desired flash memory to be verified.
lengthInBytes – The length, given in bytes (not words or long-words), to be verified.
- Return values:
kStatus_FLASH_Success – API was executed successfully.
kStatus_FLASH_InvalidArgument – An invalid argument is provided.
kStatus_FLASH_ReadHidingAreaDisallowed – Flash hiding read is not allowed.
-
status_t FLASH_IsFlashAreaModifiable(flash_config_t *config, uint32_t startAddress, uint32_t lengthInBytes)
Validates the given address range is loaded in the Flash firewall page locked region.
- Parameters:
config – A pointer to the storage for the driver runtime state.
startAddress – The start address of the desired flash memory to be verified.
lengthInBytes – The length, given in bytes (not words or long-words), to be verified.
- Return values:
kStatus_FLASH_Success – API was executed successfully.
kStatus_FLASH_InvalidArgument – An invalid argument is provided.
kStatus_FLASH_ModifyProtectedAreaDisallowed – Flash hiding read is not allowed.
-
kStatusGroupGeneric
Flash driver status group.
-
kStatusGroupFlashDriver
-
MAKE_STATUS(group, code)
Constructs a status code value from a group and a code number.
-
enum _flash_driver_api_keys
Enumeration for Flash 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.
Values:
-
enumerator kFLASH_ApiEraseKey
Key value used to validate all flash erase APIs.
-
enumerator kFLASH_ApiEraseKey
-
enum _flash_property_tag
Enumeration for various flash properties.
Values:
-
enumerator kFLASH_PropertyPflashSectorSize
Pflash sector size property.
-
enumerator kFLASH_PropertyPflashTotalSize
Pflash total size property.
-
enumerator kFLASH_PropertyPflashBlockSize
Pflash block size property.
-
enumerator kFLASH_PropertyPflashBlockCount
Pflash block count property.
-
enumerator kFLASH_PropertyPflashBlockBaseAddr
Pflash block base address property.
-
enumerator kFLASH_PropertyPflashPageSize
Pflash page size property.
-
enumerator kFLASH_PropertyPflashSystemFreq
System Frequency System Frequency.
-
enumerator kFLASH_PropertyFfrSectorSize
FFR sector size property.
-
enumerator kFLASH_PropertyFfrTotalSize
FFR total size property.
-
enumerator kFLASH_PropertyFfrBlockBaseAddr
FFR block base address property.
-
enumerator kFLASH_PropertyFfrPageSize
FFR page size property.
-
enumerator kFLASH_PropertyPflashSectorSize
-
enum _flash_max_erase_page_value
Enumeration for flash max pages to erase.
Values:
-
enumerator kFLASH_MaxPagesToErase
The max value in pages to erase.
-
enumerator kFLASH_MaxPagesToErase
-
enum _flash_alignment_property
Enumeration for flash alignment property.
Values:
-
enumerator kFLASH_AlignementUnitVerifyErase
The alignment unit in bytes used for verify erase operation.
-
enumerator kFLASH_AlignementUnitProgram
The alignment unit in bytes used for program operation.
-
enumerator kFLASH_AlignementUnitSingleWordRead
The alignment unit in bytes used for verify program operation. The alignment unit in bytes used for SingleWordRead command.
-
enumerator kFLASH_AlignementUnitVerifyErase
-
enum _flash_read_ecc_option
Enumeration for flash read ecc option.
Values:
-
enumerator kFLASH_ReadWithEccOn
-
enumerator kFLASH_ReadWithEccOff
ECC is on
-
enumerator kFLASH_ReadWithEccOn
-
enum _flash_read_margin_option
Enumeration for flash read margin option.
Values:
-
enumerator kFLASH_ReadMarginNormal
Normal read
-
enumerator kFLASH_ReadMarginVsProgram
Margin vs. program
-
enumerator kFLASH_ReadMarginVsErase
Margin vs. erase
-
enumerator kFLASH_ReadMarginIllegalBitCombination
Illegal bit combination
-
enumerator kFLASH_ReadMarginNormal
-
enum _flash_read_dmacc_option
Enumeration for flash read dmacc option.
Values:
-
enumerator kFLASH_ReadDmaccDisabled
Memory word
-
enumerator kFLASH_ReadDmaccEnabled
DMACC word
-
enumerator kFLASH_ReadDmaccDisabled
-
enum _flash_ramp_control_option
Enumeration for flash ramp control option.
Values:
-
enumerator kFLASH_RampControlDivisionFactorReserved
Reserved
-
enumerator kFLASH_RampControlDivisionFactor256
clk48mhz / 256 = 187.5KHz
-
enumerator kFLASH_RampControlDivisionFactor128
clk48mhz / 128 = 375KHz
-
enumerator kFLASH_RampControlDivisionFactor64
clk48mhz / 64 = 750KHz
-
enumerator kFLASH_RampControlDivisionFactorReserved
-
typedef enum _flash_property_tag flash_property_tag_t
Enumeration for various flash properties.
-
typedef struct _flash_ecc_log flash_ecc_log_t
Flash ECC log info.
-
typedef struct _flash_mode_config flash_mode_config_t
Flash controller paramter config.
-
typedef struct _flash_ffr_config flash_ffr_config_t
Flash controller paramter config.
-
FOUR_CHAR_CODE(a, b, c, d)
Constructs the four character code for the Flash driver API key.
-
status_t FLASH_Init(flash_config_t *config)
Initializes the global flash properties structure members.
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_FLASH_Success – API was executed successfully.
kStatus_FLASH_InvalidArgument – An invalid argument is provided.
kStatus_FLASH_CommandFailure – Run-time error during the command execution.
kStatus_FLASH_CommandNotSupported – Flash API is not supported.
kStatus_FLASH_EccError – A correctable or uncorrectable error during command execution.
kStatus_FLASH_RegulationLoss – A loss of regulation during read.
-
status_t FLASH_Erase(flash_config_t *config, uint32_t start, uint32_t lengthInBytes, uint32_t key)
Erases the flash sectors encompassed by parameters passed into function.
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. NOTE: The start address need to be 4 Bytes-aligned.
lengthInBytes – The length, given in bytes need be 4 Bytes-aligned.
key – The value used to validate all flash erase APIs.
- Return values:
kStatus_FLASH_Success – API was executed successfully.
kStatus_FLASH_InvalidArgument – An invalid argument is provided.
kStatus_FLASH_AlignmentError – The parameter is not aligned with the specified baseline.
kStatus_FLASH_AddressError – The address is out of range.
kStatus_FLASH_EraseKeyError – The API erase key is invalid.
kStatus_FLASH_ModifyProtectedAreaDisallowed – Flash firewall page locked erase and program are not allowed
kStatus_FLASH_CommandFailure – Run-time error during the command execution.
kStatus_FLASH_CommandNotSupported – Flash API is not supported.
kStatus_FLASH_EccError – A correctable or uncorrectable error during command execution.
kStatus_FLASH_RegulationLoss – A loss of regulation during read.
-
status_t FLASH_EraseNonBlocking(flash_config_t *config, uint32_t start, uint32_t lengthInBytes, uint32_t key)
Non-blocking Erases the flash sectors encompassed by parameters passed into function.
This is a non-blocking function, which returns right away. This function erases the appropriate number of flash sectors based on the desired start address and length, and get the command execute status from the “FLASH_GetCommandState”.
- Parameters:
config – The pointer to the storage for the driver runtime state.
start – The start address of the desired flash memory to be erased. NOTE: The start address need be 4 Bytes-aligned.
lengthInBytes – The length, given in bytes need be 4 Bytes-aligned.
key – The value used to validate all flash erase APIs.
- Return values:
kStatus_FLASH_Success – API was executed successfully.
kStatus_FLASH_InvalidArgument – An invalid argument is provided.
kStatus_FLASH_AlignmentError – The parameter is not aligned with the specified baseline.
kStatus_FLASH_AddressError – The address is out of range.
kStatus_FLASH_EraseKeyError – The API erase key is invalid.
kStatus_FLASH_ModifyProtectedAreaDisallowed – Flash firewall page locked erase and program are not allowed
-
status_t FLASH_Program(flash_config_t *config, uint32_t start, uint8_t *src, uint32_t lengthInBytes)
Programs flash with data at locations passed in through parameters.
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:
kStatus_FLASH_Success – API was executed successfully.
kStatus_FLASH_InvalidArgument – An invalid argument is provided.
kStatus_FLASH_AlignmentError – Parameter is not aligned with the specified baseline.
kStatus_FLASH_AddressError – Address is out of range.
kStatus_FLASH_AccessError – Invalid instruction codes and out-of bounds addresses.
kStatus_FLASH_ModifyProtectedAreaDisallowed – Flash firewall page locked erase and program are not allowed
kStatus_FLASH_CommandFailure – Run-time error during the command execution.
kStatus_FLASH_CommandNotSupported – Flash API is not supported.
kStatus_FLASH_RegulationLoss – A loss of regulation during read.
kStatus_FLASH_EccError – A correctable or uncorrectable error during command execution.
-
status_t FLASH_Read(flash_config_t *config, uint32_t start, uint8_t *dest, uint32_t lengthInBytes)
Reads flash at locations passed in through parameters.
This function read the flash memory from 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 read.
dest – A pointer to the dest buffer of data that is to be read from the flash.
lengthInBytes – The length, given in bytes (not words or long-words), to be read.
- Return values:
kStatus_FLASH_Success – API was executed successfully.
kStatus_FLASH_InvalidArgument – An invalid argument is provided.
kStatus_FLASH_AlignmentError – Parameter is not aligned with the specified baseline.
kStatus_FLASH_AddressError – Address is out of range.
kStatus_FLASH_ReadHidingAreaDisallowed – Flash hiding read is not allowed
kStatus_FLASH_CommandFailure – Run-time error during the command execution.
kStatus_FLASH_CommandNotSupported – Flash API is not supported.
kStatus_FLASH_RegulationLoss – A loss of regulation during read.
kStatus_FLASH_EccError – A correctable or uncorrectable error during command execution.
-
status_t FLASH_VerifyErase(flash_config_t *config, uint32_t start, uint32_t lengthInBytes)
Verifies an erasure of the desired flash area at a specified margin level.
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.
- Return values:
kStatus_FLASH_Success – API was executed successfully.
kStatus_FLASH_InvalidArgument – An invalid argument is provided.
kStatus_FLASH_AlignmentError – Parameter is not aligned with specified baseline.
kStatus_FLASH_AddressError – Address is out of range.
kStatus_FLASH_CommandFailure – Run-time error during the command execution.
kStatus_FLASH_CommandNotSupported – Flash API is not supported.
kStatus_FLASH_RegulationLoss – A loss of regulation during read.
kStatus_FLASH_EccError – A correctable or uncorrectable error during command execution.
-
status_t FLASH_VerifyProgram(flash_config_t *config, uint32_t start, uint32_t lengthInBytes, const uint8_t *expectedData, uint32_t *failedAddress, uint32_t *failedData)
Verifies programming of the desired flash area at a specified margin level.
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.
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_FLASH_Success – API was executed successfully.
kStatus_FLASH_InvalidArgument – An invalid argument is provided.
kStatus_FLASH_AlignmentError – Parameter is not aligned with specified baseline.
kStatus_FLASH_AddressError – Address is out of range.
kStatus_FLASH_AccessError – Invalid instruction codes and out-of bounds addresses.
kStatus_FLASH_ReadHidingAreaDisallowed – Flash hiding read is not allowed
kStatus_FLASH_CommandFailure – Run-time error during the command execution.
kStatus_FLASH_CommandNotSupported – Flash API is not supported.
kStatus_FLASH_RegulationLoss – A loss of regulation during read.
kStatus_FLASH_EccError – A correctable or uncorrectable error during command execution.
-
status_t FLASH_GetProperty(flash_config_t *config, flash_property_tag_t whichProperty, uint32_t *value)
Returns the desired flash property.
- 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_FLASH_Success – API was executed successfully.
kStatus_FLASH_InvalidArgument – An invalid argument is provided.
kStatus_FLASH_UnknownProperty – An unknown property tag.
-
status_t FLASH_GetCommandState(flash_config_t *config)
Get flash command execute status.
This function is used to obtain the status after the command “FLASH_EraseNonBlocking” is executed.
- Parameters:
config – A pointer to the storage for the driver runtime state.
- Return values:
kStatus_FLASH_CommandOperationInProgress – Indicate that a flash command in progress.
kStatus_FLASH_CommandFailure – Run-time error during the command execution.
kStatus_FLASH_CommandNotSupported – Flash API is not supported.
kStatus_FLASH_EccError – A correctable or uncorrectable error during command execution.
kStatus_FLASH_RegulationLoss – A loss of regulation during read.
kStatus_FLASH_Success – API was executed successfully.
-
MAKE_VERSION(major, minor, bugfix)
Constructs the version number for drivers.
-
FSL_SUPPORT_ERASE_SECTOR_NON_BLOCKING
IAP driver support non-block erase function.
-
FSL_FEATURE_SYSCON_HAS_FLASH_HIDING
IAP driver support flash hiding.
-
FSL_FEATURE_SYSCON_HAS_CDPA
IAP driver support CDPA.
-
uint32_t firstEccEventAddress
-
uint32_t eccErrorCount
-
uint32_t eccCorrectionCount
-
uint32_t reserved
-
uint32_t sysFreqInMHz
-
uint8_t readWithEccOff
-
uint8_t readMarginLevel
-
uint8_t readDmaccWord
-
uint8_t reserved0
-
uint8_t reserved1[3]
-
struct _flash_mode_config readSingleWord
-
uint8_t programRampControl
-
uint8_t eraseRampControl
-
uint8_t reserved[2]
-
struct _flash_mode_config setWriteMode
-
uint16_t readInterfaceTimingTrim
-
uint16_t readControllerTimingTrim
-
uint8_t readWaitStates
-
uint8_t reserved[3]
-
struct _flash_mode_config setReadMode
-
uint32_t ffrBlockBase
-
uint32_t ffrTotalSize
-
uint32_t ffrPageSize
-
uint32_t cfpaPageVersion
-
uint32_t cfpaPageOffset
-
uint32_t PFlashBlockBase
A base address of the first PFlash block
-
uint32_t PFlashTotalSize
The size of the combined PFlash block.
-
uint32_t PFlashBlockCount
A number of PFlash blocks.
-
uint32_t PFlashPageSize
The size in bytes of a page of PFlash.
-
uint32_t PFlashSectorSize
The size in bytes of a sector of PFlash.
-
flash_ffr_config_t ffrConfig
-
flash_mode_config_t modeConfig
-
uint32_t *nbootCtx
-
bool useAhbRead
-
struct _flash_ecc_log
- #include <fsl_flash.h>
Flash ECC log info.
-
struct _flash_mode_config
- #include <fsl_flash.h>
Flash controller paramter config.
-
struct _flash_ffr_config
- #include <fsl_flash.h>
Flash controller paramter config.
-
struct flash_config_t
- #include <fsl_flash.h>
Flash driver state information.
An instance of this structure is allocated by the user of the flash driver and passed into each of the driver APIs.
-
struct readSingleWord
-
struct setWriteMode
-
struct setReadMode
Flash_ffr_driver
-
status_t FFR_Init(flash_config_t *config)
Initializes the global FFR properties structure members.
- Parameters:
config – A pointer to the storage for the driver runtime state.
- Return values:
kStatus_FLASH_Success – API was executed successfully.
-
status_t FFR_Lock(flash_config_t *config)
Enable firewall for all flash banks.
CFPA, CMPA, and NMPA flash areas region will be locked, After this function executed; Unless the board is reset again.
- Parameters:
config – A pointer to the storage for the driver runtime state.
- Return values:
kStatus_FLASH_Success – An invalid argument is provided.
-
status_t FFR_SecLibInit(flash_config_t *config, uint32_t *context)
Initialize the Security Library for FFR driver.
- Parameters:
config – A pointer to the storage for the driver runtime state.
context – A pointer to the storage for the nboot data.
- Return values:
kStatus_FLASH_Success – An invalid argument is provided.
kStatus_FLASH_InvalidArgument – An invalid argument is provided.
-
status_t FFR_InfieldPageWrite(flash_config_t *config, uint8_t *page_data, uint32_t valid_len)
APIs to access CFPA pages.
This routine will erase CFPA and program the CFPA page with passed data.
- Parameters:
config – A pointer to the storage for the driver runtime state.
page_data – A pointer to the source buffer of data that is to be programmed into the CFPA.
valid_len – The length, given in bytes, to be programmed.
- Return values:
kStatus_FLASH_Success – The desire page-data were programed successfully into CFPA.
kStatus_FLASH_SizeError – Error size
kStatus_FLASH_ReadHidingAreaDisallowed – Flash hiding read is not allowed
kStatus_FLASH_AlignmentError – Parameter is not aligned with the specified baseline
kStatus_FLASH_ModifyProtectedAreaDisallowed – Flash firewall page locked erase and program are not allowed
kStatus_FLASH_InvalidArgument – An invalid argument is provided.
kStatus_FLASH_AddressError – Address is out of range.
kStatus_FLASH_FfrBankIsLocked – The CFPA was locked.
kStatus_FLASH_OutOfDateCfpaPage – It is not newest CFPA page.
kStatus_FLASH_CommandFailure – access error.
kStatus_FLASH_CommandNotSupported – Flash API is not supported
kStatus_FLASH_EccError – A correctable or uncorrectable error during command execution.
kStatus_FLASH_RegulationLoss – A loss of regulation during read.
-
status_t FFR_GetCustomerInfieldData(flash_config_t *config, uint8_t *pData, uint32_t offset, uint32_t len)
APIs to access CFPA pages.
Generic read function, used by customer to read data stored in ‘Customer In-field Page’.
- Parameters:
config – A pointer to the storage for the driver runtime state.
pData – A pointer to the dest buffer of data that is to be read from ‘Customer In-field Page’.
offset – An offset from the ‘Customer In-field Page’ start address.
len – The length, given in bytes, to be read.
- Return values:
kStatus_FLASH_Success – Get data from ‘Customer In-field Page’.
kStatus_FLASH_InvalidArgument – An invalid argument is provided.
kStatus_FLASH_AddressError – Address is out of range.
kStatus_FLASH_AlignmentError – Parameter is not aligned with the specified baseline.
kStatus_FLASH_ReadHidingAreaDisallowed – Flash hiding read is not allowed
kStatus_FLASH_CommandFailure – access error.
kStatus_FLASH_CommandNotSupported – Flash API is not supported
kStatus_FLASH_EccError – A correctable or uncorrectable error during command execution.
kStatus_FLASH_RegulationLoss – A loss of regulation during read.
-
status_t FFR_CustFactoryPageWrite(flash_config_t *config, uint8_t *page_data, bool seal_part)
APIs to access CMPA pages.
This routine will erase “customer factory page” and program the page with passed data. If ‘seal_part’ parameter is TRUE then the routine will compute SHA256 hash of the page contents and then programs the pages. 1.During development customer code uses this API with ‘seal_part’ set to FALSE. 2.During manufacturing this parameter should be set to TRUE to seal the part from further modifications 3.This routine checks if the page is sealed or not. A page is said to be sealed if the SHA256 value in the page has non-zero value. On boot ROM locks the firewall for the region if hash is programmed anyways. So, write/erase commands will fail eventually.
- Parameters:
config – A pointer to the storage for the driver runtime state.
page_data – A pointer to the source buffer of data that is to be programmed into the “customer factory page”.
seal_part – Set fasle for During development customer code.
- Return values:
kStatus_FLASH_Success – The desire page-data were programed successfully into CMPA.
kStatus_FLASH_InvalidArgument – Parameter is not aligned with the specified baseline.
kStatus_FLASH_AddressError – Address is out of range.
kStatus_FLASH_AlignmentError – Parameter is not aligned with the specified baseline.
kStatus_FLASH_EraseKeyError – API erase key is invalid.
kStatus_FLASH_ModifyProtectedAreaDisallowed – Flash firewall page locked erase and program are not allowed
kStatus_Fail – Generic status for Fail.
kStatus_FLASH_CommandFailure – access error.
kStatus_FLASH_CommandNotSupported – Flash API is not supported
kStatus_FLASH_EccError – A correctable or uncorrectable error during command execution.
kStatus_FLASH_RegulationLoss – A loss of regulation during read.
-
status_t FFR_GetCustomerData(flash_config_t *config, uint8_t *pData, uint32_t offset, uint32_t len)
APIs to access CMPA page.
Read data stored in ‘Customer Factory CFG Page’.
- Parameters:
config – A pointer to the storage for the driver runtime state.
pData – A pointer to the dest buffer of data that is to be read from the Customer Factory CFG Page.
offset – Address offset relative to the CMPA area.
len – The length, given in bytes to be read.
- Return values:
kStatus_FLASH_Success – Get data from ‘Customer Factory CFG Page’.
kStatus_FLASH_InvalidArgument – Parameter is not aligned with the specified baseline.
kStatus_FLASH_AlignmentError – Parameter is not aligned with the specified baseline.
kStatus_FLASH_AddressError – Address is out of range.
kStatus_FLASH_CommandFailure – access error.
kStatus_FLASH_CommandNotSupported – Flash API is not supported
kStatus_FLASH_EccError – A correctable or uncorrectable error during command execution.
kStatus_FLASH_RegulationLoss – A loss of regulation during read.
kStatus_FLASH_ReadHidingAreaDisallowed – Flash hiding read is not allowed
-
status_t FFR_GetCustKeystoreData(flash_config_t *config, uint8_t *pData, uint32_t offset, uint32_t len)
The API is used for getting the customer key store data from the customer key store region(0x3e400 - 0x3e600), and the API should be called after the FLASH_Init and FFR_Init.
- Parameters:
config – A pointer to the storage for the driver runtime state.
pData – A pointer to the dest buffer of data that is to be read from the Customer Factory CFG Page.
offset – Address offset relative to the CMPA area.
len – The length, given in bytes to be read.
- Return values:
kStatus_FLASH_Success – Get data from ‘Customer Factory CFG Page’.
kStatus_FLASH_InvalidArgument – Parameter is not aligned with the specified baseline.
kStatus_FLASH_AddressError – Address is out of range.
kStatus_FLASH_AlignmentError – Parameter is not aligned with the specified baseline.
kStatus_FLASH_ReadHidingAreaDisallowed – Flash hiding read is not allowed
kStatus_FLASH_CommandFailure – access error.
kStatus_FLASH_CommandNotSupported – Flash API is not supported
kStatus_FLASH_EccError – A correctable or uncorrectable error during command execution.
kStatus_FLASH_RegulationLoss – A loss of regulation during read.
-
status_t FFR_CustKeystoreWrite(flash_config_t *config, ffr_key_store_t *pKeyStore)
This routine writes the 3 pages allocated for Key store data.
- Parameters:
config – A pointer to the storage for the driver runtime state.
pKeyStore – A pointer to the source buffer of data that is to be programmed into the “Key store”.
- Return values:
kStatus_FLASH_Success – Get data from ‘Customer Factory CFG Page’.
kStatus_FLASH_InvalidArgument – Parameter is not aligned with the specified baseline.
kStatus_FLASH_CommandFailure – access error.
kStatus_FLASH_CommandNotSupported – Flash API is not supported
kStatus_FLASH_EccError – A correctable or uncorrectable error during command execution.
kStatus_FLASH_RegulationLoss – A loss of regulation during read.
kStatus_FLASH_SealedFfrRegion – The FFR region is sealed.
kStatus_FLASH_FfrBankIsLocked – The FFR bank region is locked.
kStatus_FLASH_AddressError – Address is out of range
kStatus_FLASH_AlignmentError – Parameter is not aligned with the specified baseline.
kStatus_FLASH_ModifyProtectedAreaDisallowed – Flash firewall page locked erase and program are not allowed
-
status_t FFR_GetUUID(flash_config_t *config, uint8_t *uuid)
APIs to access CMPA page.
1.SW should use this API routine to get the UUID of the chip. 2.Calling routine should pass a pointer to buffer which can hold 128-bit value.
- Return values:
kStatus_FLASH_Success – Get data from ‘Customer Factory CFG Page’.
kStatus_FLASH_InvalidArgument – Parameter is not aligned with the specified baseline.
kStatus_FLASH_ReadHidingAreaDisallowed – Flash hiding read is not allowed
kStatus_FLASH_CommandFailure – Run-time error during command execution.
kStatus_FLASH_CommandNotSupported – Flash API is not supported
kStatus_FLASH_RegulationLoss – A loss of regulation during read.
-
enum flash_ffr_page_offset
flash FFR page offset.
Values:
-
enumerator kFfrPageOffset_CFPA
Customer In-Field programmed area
-
enumerator kFfrPageOffset_CFPA_Scratch
CFPA Scratch page
-
enumerator kFfrPageOffset_CFPA_CfgPing
CFPA Configuration area (Ping page)
-
enumerator kFfrPageOffset_CFPA_CfgPong
Same as CFPA page (Pong page)
-
enumerator kFfrPageOffset_CMPA
Customer Manufacturing programmed area
-
enumerator kFfrPageOffset_CMPA_Cfg
CMPA Configuration area (Part of CMPA)
-
enumerator kFfrPageOffset_CMPA_Key
Key Store area (Part of CMPA)
-
enumerator kFfrPageOffset_NMPA
NXP Manufacturing programmed area
-
enumerator kFfrPageOffset_NMPA_Romcp
ROM patch area (Part of NMPA)
-
enumerator kFfrPageOffset_NMPA_Repair
Repair area (Part of NMPA)
-
enumerator kFfrPageOffset_NMPA_Cfg
NMPA configuration area (Part of NMPA)
-
enumerator kFfrPageOffset_NMPA_End
Reserved (Part of NMPA)
-
enumerator kFfrPageOffset_CFPA
-
enum flash_ffr_page_num
flash FFR page number.
Values:
-
enumerator kFfrPageNum_CFPA
Customer In-Field programmed area
-
enumerator kFfrPageNum_CMPA
Customer Manufacturing programmed area
-
enumerator kFfrPageNum_NMPA
NXP Manufacturing programmed area
-
enumerator kFfrPageNum_CMPA_Cfg
-
enumerator kFfrPageNum_NMPA_Romcp
-
enumerator kFfrPageNum_SpecArea
-
enumerator kFfrPageNum_Total
-
enumerator kFfrPageNum_CFPA
-
enum flash_ffr_block_size
flash FFR block size.
Values:
-
enumerator kFfrBlockSize_Key
-
enumerator kFfrBlockSize_ActivationCode
-
enumerator kFfrBlockSize_Key
-
enum cfpa_cfg_cmpa_prog_status
flash cmpa status.
Values:
-
enumerator kFfrCmpaProgStatus_Idle
-
enumerator kFfrCmpaProgStatus_InProgress
-
enumerator kFfrCmpaProgStatus_Idle
-
enum cmpa_prog_process_t
flash cmpa program status.
Values:
-
enumerator kFfrCmpaProgProcess_Pre
-
enumerator kFfrCmpaProgProcess_Post
-
enumerator kFfrCmpaProgProcess_Pre
-
enum ffr_key_type_t
Values:
-
enumerator kFFR_KeyTypeSbkek
-
enumerator kFFR_KeyTypeUser
-
enumerator kFFR_KeyTypeUds
-
enumerator kFFR_KeyTypePrinceRegion0
-
enumerator kFFR_KeyTypePrinceRegion1
-
enumerator kFFR_KeyTypePrinceRegion2
-
enumerator kFFR_KeyTypeSbkek
-
enum ffr_bank_type_t
Values:
-
enumerator kFFR_BankTypeBank0_NMPA
-
enumerator kFFR_BankTypeBank1_CMPA
-
enumerator kFFR_BankTypeBank2_CFPA
-
enumerator kFFR_BankTypeBank0_NMPA
-
uint32_t header
[0x000-0x003]
-
uint32_t version
[0x004-0x007]
-
uint32_t secureFwVersion
[0x008-0x00b]
-
uint32_t nsFwVersion
[0x00c-0x00f]
-
uint32_t imageKeyRevoke
[0x010-0x013]
-
uint32_t ivPrince[3]
[0x014-0x01f]
-
uint32_t ivIped[4]
[0x020-0x02f]
-
uint32_t custCtr[8]
[0x030-0x03f]
-
uint32_t rotkhRevoke
[0x018-0x01b]
-
uint32_t vendorUsage
[0x050-0x053]
-
uint32_t dcfgNsPin
[0x058-0x05b]
-
uint32_t dcfgNsDflt
[0x05c-0x05f]
-
uint32_t enableFaMode
[0x060-0x063]
-
uint32_t cmpaProgInProgress
[0x064-0x067]
-
uint32_t imageCmacUpdateEn
[0x068-0x06b]
-
uint32_t cfpaVersion
[0x06c-0x06f]
-
uint32_t img0Cmac[4]
[0x070-0x07f]
-
uint32_t img1Cmac[4]
[0x080-0x08f]
-
uint8_t reserved2[348]
[0x090-0x1eb]
-
uint32_t cfpaCrc
[0x1eb-0x1ef]
-
uint32_t cfpaCmac[4]
[0x1f0-0x1ff]
-
uint32_t bootCfg
[0x000-0x003]
-
uint32_t spiFlashCanCfg
[0x004-0x007]
-
uint16_t vid
-
uint16_t pid
-
struct cmpa_cfg_info_t usbId
[0x008-0x00b]
-
uint32_t sdioCfg
[0x00c-0x00f]
-
uint32_t dcfgPin
[0x010-0x013]
-
uint32_t dcfgDflt
[0x014-0x017]
-
uint32_t dapVendorUsage
[0x018-0x01b]
-
uint32_t secureBootCfg
[0x01c-0x01f]
-
uint32_t princeBaseAddr
[0x020-0x023]
-
uint32_t princeSr[3]
[0x024-0x02f]
-
uint32_t xtal32kCapBankTrim
[0x030-0x033]
-
uint32_t xtal16mCapBankTrim
[0x034-0x037]
-
uint32_t flashRemapSize
[0x038-0x03b]
-
uint32_t flashRemapOffset
[0x03c-0x03f]
-
uint32_t princeXom[3]
[0x040-0x04b]
-
uint32_t rokthUsage
[0x04c-0x04f]
-
uint32_t rotkh[12]
[0x050-0x07f]
-
uint32_t flexspiCfg0
[0x080-0x083]
-
uint32_t flexspiCfg1
[0x084-0x087]
-
uint8_t reserved1[8]
[0x088-0x08f]
-
uint32_t ipedStartAddr
[0x090-0x093]
-
uint32_t ipedEndAddr
[0x094-0x097]
-
struct cmpa_cfg_info_t ipedRegions[4]
-
uint8_t reserved2[320]
[0x0b0-0x1ef]
-
uint32_t cmpaCmac[4]
[0x1f0-0x1ff]
-
uint32_t header
-
uint8_t reserved[4]
-
uint32_t fro32kCfg
[0x000-0x003]
-
uint32_t puf_cfg
[0x004-0x007]
-
uint32_t bod
[0x008-0x00b]
-
uint32_t trim
[0x00c-0x00f]
-
uint32_t deviceID
[0x010-0x03f]
-
uint32_t peripheralCfg
[0x014-0x017]
-
uint32_t dcdPowerProFileLOW[2]
[0x018-0x01f]
-
uint32_t deviceType
[0x020-0x023]
-
uint32_t ldo_ao
[0x024-0x027]
-
uint32_t gdetDelayCfg
[0x028-0x02b]
-
uint32_t gdetMargin
[0x02c-0x02f]
-
uint32_t gdetTrim1
[0x030-0x033]
-
uint32_t gdetEanble1
[0x034-0x037]
-
uint32_t gdetCtrl1
[0x038-0x03b]
-
uint32_t gdetUpdateTimer
[0x03c-0x03f]
-
uint32_t GpoDataChecksum[4]
[0x040-0x04f]
-
uint32_t finalTestBatchId[4]
[0x050-0x05f]
-
uint32_t ecidBackup[4]
[0x060-0x06f]
-
uint32_t uuid[4]
[0x070-0x07f]
-
uint32_t reserved1[7]
[0x080-0x09b]
-
uint8_t xo32mReadyTimeoutInMs
-
uint8_t usbSpeed
-
uint8_t reserved[2]
-
struct nmpa_cfg_info_t usbCfg
[0x09c-0x09f]
-
uint32_t reserved2[80]
[0x0a0-0x1df]
-
uint8_t cmac[16]
[0x1e0-0x1ef]
-
uint32_t pageChecksum[4]
[0x1f0-0x1ff]
-
uint8_t reserved[1][(512U)]
-
ALIGN_DOWN(x, a)
Alignment(down) utility.
-
ALIGN_UP(x, a)
Alignment(up) utility.
-
FLASH_FFR_MAX_PAGE_SIZE
-
FLASH_FFR_HASH_DIGEST_SIZE
-
FLASH_FFR_IV_CODE_SIZE
-
FFR_BOOTCFG_USBSPEED_SHIFT
-
FFR_BOOTCFG_USBSPEED_MASK
-
FFR_BOOTCFG_USBSPEED_NMPASEL0
-
FFR_BOOTCFG_USBSPEED_FS
-
FFR_BOOTCFG_USBSPEED_HS
-
FFR_BOOTCFG_USBSPEED_NMPASEL3
-
FFR_BOOTCFG_BOOTSPEED_MASK
-
FFR_BOOTCFG_BOOTSPEED_SHIFT
-
FFR_BOOTCFG_BOOTSPEED_NMPASEL
-
FFR_BOOTCFG_BOOTSPEED_48MHZ
-
FFR_BOOTCFG_BOOTSPEED_96MHZ
-
FFR_USBID_VENDORID_MASK
-
FFR_USBID_VENDORID_SHIFT
-
FFR_USBID_PRODUCTID_MASK
-
FFR_USBID_PRODUCTID_SHIFT
-
FFR_IMAGE0_CMAC_UPDATE_MASK
-
FFR_IMAGE1_CMAC_UPDATE_MASK
-
FFR_SYSTEM_SPEED_CODE_MASK
-
FFR_SYSTEM_SPEED_CODE_SHIFT
-
FFR_SYSTEM_SPEED_CODE_FRO12MHZ_12MHZ
-
FFR_SYSTEM_SPEED_CODE_FROHF96MHZ_24MHZ
-
FFR_SYSTEM_SPEED_CODE_FROHF96MHZ_48MHZ
-
FFR_SYSTEM_SPEED_CODE_FROHF96MHZ_96MHZ
-
FFR_USBCFG_USBSPEED_HS
-
FFR_USBCFG_USBSPEED_FS
-
FFR_USBCFG_USBSPEED_NO
-
FFR_MCAN_BAUDRATE_MASK
-
FFR_MCAN_BAUDRATE_SHIFT
-
FFR_PERIPHERALCFG_PERI_MASK
-
FFR_PERIPHERALCFG_PERI_SHIFT
-
FFR_PERIPHERALCFG_COREEN_MASK
-
FFR_PERIPHERALCFG_COREEN_SHIFT
-
FFR_PUF_SRAM_CONFIG_MASK
-
FFR_PUF_SRAM_CONFIG_MASK_SHIFT
-
FFR_PUF_SRAM_VALID_MASK
-
FFR_PUF_SRAM_VALID_SHIFT
-
FFR_PUF_SRAM_MODE_MASK
-
FFR_PUF_SRAM_MODE_SHIFT
-
FFR_PUF_SRAM_CKGATING_MASK
-
FFR_PUF_SRAM_CKGATING_SHIFT
-
FFR_PUF_SRAM_SMB_MASK
-
FFR_PUF_SRAM_SMB_SHIFT
-
FFR_PUF_SRAM_RM_MASK
-
FFR_PUF_SRAM_RM_SHIFT
-
FFR_PUF_SRAM_WM_MASK
-
FFR_PUF_SRAM_WM_SHIFT
-
FFR_PUF_SRAM_WRME_MASK
-
FFR_PUF_SRAM_WRME_SHIFT
-
FFR_PUF_SRAM_RAEN_MASK
-
FFR_PUF_SRAM_RAEN_SHIFT
-
FFR_PUF_SRAM_RAM_MASK
-
FFR_PUF_SRAM_RAM_SHIFT
-
FFR_PUF_SRAM_WAEN_MASK
-
FFR_PUF_SRAM_WAEN_SHIFT
-
FFR_PUF_SRAM_WAM_MASK
-
FFR_PUF_SRAM_WAM_SHIFT
-
FFR_PUF_SRAM_STBP_MASK
-
FFR_PUF_SRAM_STBP_SHIFT
-
struct cfpa_cfg_info_t
- #include <fsl_flash_ffr.h>
flash cfpa configure struct.
-
struct cmpa_cfg_info_t
- #include <fsl_flash_ffr.h>
-
struct cmpa_key_store_header_t
- #include <fsl_flash_ffr.h>
-
struct nmpa_cfg_info_t
- #include <fsl_flash_ffr.h>
-
struct ffr_key_store_t
- #include <fsl_flash_ffr.h>
-
struct usbId
-
struct ipedRegions
Public Members
-
uint32_t ipedStartAddr
[0x090-0x093]
-
uint32_t ipedEndAddr
[0x094-0x097]
-
uint32_t ipedStartAddr
-
struct usbCfg
FLEXCOMM: FLEXCOMM Driver
FLEXCOMM Driver
-
FSL_FLEXCOMM_DRIVER_VERSION
FlexCOMM driver version 2.0.2.
-
enum FLEXCOMM_PERIPH_T
FLEXCOMM peripheral modes.
Values:
-
enumerator FLEXCOMM_PERIPH_NONE
No peripheral
-
enumerator FLEXCOMM_PERIPH_USART
USART peripheral
-
enumerator FLEXCOMM_PERIPH_SPI
SPI Peripheral
-
enumerator FLEXCOMM_PERIPH_I2C
I2C Peripheral
-
enumerator FLEXCOMM_PERIPH_I2S_TX
I2S TX Peripheral
-
enumerator FLEXCOMM_PERIPH_I2S_RX
I2S RX Peripheral
-
enumerator FLEXCOMM_PERIPH_NONE
-
typedef void (*flexcomm_irq_handler_t)(void *base, void *handle)
Typedef for interrupt handler.
-
IRQn_Type const kFlexcommIrqs[]
Array with IRQ number for each FLEXCOMM module.
-
uint32_t FLEXCOMM_GetInstance(void *base)
Returns instance number for FLEXCOMM module with given base address.
-
status_t FLEXCOMM_Init(void *base, FLEXCOMM_PERIPH_T periph)
Initializes FLEXCOMM and selects peripheral mode according to the second parameter.
-
void FLEXCOMM_SetIRQHandler(void *base, flexcomm_irq_handler_t handler, void *flexcommHandle)
Sets IRQ handler for given FLEXCOMM module. It is used by drivers register IRQ handler according to FLEXCOMM mode.
FLEXSPI: Flexible Serial Peripheral Interface Driver
-
uint32_t FLEXSPI_GetInstance(FLEXSPI_Type *base)
Get the instance number for FLEXSPI.
- Parameters:
base – FLEXSPI base pointer.
-
status_t FLEXSPI_CheckAndClearError(FLEXSPI_Type *base, uint32_t status)
Check and clear IP command execution errors.
- Parameters:
base – FLEXSPI base pointer.
status – interrupt status.
-
void FLEXSPI_Init(FLEXSPI_Type *base, const flexspi_config_t *config)
Initializes the FLEXSPI module and internal state.
This function enables the clock for FLEXSPI and also configures the FLEXSPI with the input configure parameters. Users should call this function before any FLEXSPI operations.
- Parameters:
base – FLEXSPI peripheral base address.
config – FLEXSPI configure structure.
-
void FLEXSPI_GetDefaultConfig(flexspi_config_t *config)
Gets default settings for FLEXSPI.
- Parameters:
config – FLEXSPI configuration structure.
-
void FLEXSPI_Deinit(FLEXSPI_Type *base)
Deinitializes the FLEXSPI module.
Clears the FLEXSPI state and FLEXSPI module registers.
- Parameters:
base – FLEXSPI peripheral base address.
-
void FLEXSPI_UpdateDllValue(FLEXSPI_Type *base, flexspi_device_config_t *config, flexspi_port_t port)
Update FLEXSPI DLL value depending on currently flexspi root clock.
- Parameters:
base – FLEXSPI peripheral base address.
config – Flash configuration parameters.
port – FLEXSPI Operation port.
-
void FLEXSPI_SetFlashConfig(FLEXSPI_Type *base, flexspi_device_config_t *config, flexspi_port_t port)
Configures the connected device parameter.
This function configures the connected device relevant parameters, such as the size, command, and so on. The flash configuration value cannot have a default value. The user needs to configure it according to the connected device.
- Parameters:
base – FLEXSPI peripheral base address.
config – Flash configuration parameters.
port – FLEXSPI Operation port.
-
void FLEXSPI_SoftwareReset(FLEXSPI_Type *base)
Software reset for the FLEXSPI logic.
This function sets the software reset flags for both AHB and buffer domain and resets both AHB buffer and also IP FIFOs.
- Parameters:
base – FLEXSPI peripheral base address.
-
static inline void FLEXSPI_Enable(FLEXSPI_Type *base, bool enable)
Enables or disables the FLEXSPI module.
- Parameters:
base – FLEXSPI peripheral base address.
enable – True means enable FLEXSPI, false means disable.
-
static inline void FLEXSPI_EnableInterrupts(FLEXSPI_Type *base, uint32_t mask)
Enables the FLEXSPI interrupts.
- Parameters:
base – FLEXSPI peripheral base address.
mask – FLEXSPI interrupt source.
-
static inline void FLEXSPI_DisableInterrupts(FLEXSPI_Type *base, uint32_t mask)
Disable the FLEXSPI interrupts.
- Parameters:
base – FLEXSPI peripheral base address.
mask – FLEXSPI interrupt source.
-
static inline void FLEXSPI_EnableTxDMA(FLEXSPI_Type *base, bool enable)
Enables or disables FLEXSPI IP Tx FIFO DMA requests.
- Parameters:
base – FLEXSPI peripheral base address.
enable – Enable flag for transmit DMA request. Pass true for enable, false for disable.
-
static inline void FLEXSPI_EnableRxDMA(FLEXSPI_Type *base, bool enable)
Enables or disables FLEXSPI IP Rx FIFO DMA requests.
- Parameters:
base – FLEXSPI peripheral base address.
enable – Enable flag for receive DMA request. Pass true for enable, false for disable.
-
static inline uint32_t FLEXSPI_GetTxFifoAddress(FLEXSPI_Type *base)
Gets FLEXSPI IP tx fifo address for DMA transfer.
- Parameters:
base – FLEXSPI peripheral base address.
- Return values:
The – tx fifo address.
-
static inline uint32_t FLEXSPI_GetRxFifoAddress(FLEXSPI_Type *base)
Gets FLEXSPI IP rx fifo address for DMA transfer.
- Parameters:
base – FLEXSPI peripheral base address.
- Return values:
The – rx fifo address.
-
static inline void FLEXSPI_ResetFifos(FLEXSPI_Type *base, bool txFifo, bool rxFifo)
Clears the FLEXSPI IP FIFO logic.
- Parameters:
base – FLEXSPI peripheral base address.
txFifo – Pass true to reset TX FIFO.
rxFifo – Pass true to reset RX FIFO.
-
static inline void FLEXSPI_GetFifoCounts(FLEXSPI_Type *base, size_t *txCount, size_t *rxCount)
Gets the valid data entries in the FLEXSPI FIFOs.
- Parameters:
base – FLEXSPI peripheral base address.
txCount – [out] Pointer through which the current number of bytes in the transmit FIFO is returned. Pass NULL if this value is not required.
rxCount – [out] Pointer through which the current number of bytes in the receive FIFO is returned. Pass NULL if this value is not required.
-
static inline uint32_t FLEXSPI_GetInterruptStatusFlags(FLEXSPI_Type *base)
Get the FLEXSPI interrupt status flags.
- Parameters:
base – FLEXSPI peripheral base address.
- Return values:
interrupt – status flag, use status flag to AND flexspi_flags_t could get the related status.
-
static inline void FLEXSPI_ClearInterruptStatusFlags(FLEXSPI_Type *base, uint32_t mask)
Get the FLEXSPI interrupt status flags.
- Parameters:
base – FLEXSPI peripheral base address.
mask – FLEXSPI interrupt source.
-
static inline void FLEXSPI_GetDataLearningPhase(FLEXSPI_Type *base, uint8_t *portAPhase, uint8_t *portBPhase)
Gets the sampling clock phase selection after Data Learning.
- Parameters:
base – FLEXSPI peripheral base address.
portAPhase – Pointer to a uint8_t type variable to receive the selected clock phase on PORTA.
portBPhase – Pointer to a uint8_t type variable to receive the selected clock phase on PORTB.
-
static inline flexspi_arb_command_source_t FLEXSPI_GetArbitratorCommandSource(FLEXSPI_Type *base)
Gets the trigger source of current command sequence granted by arbitrator.
- Parameters:
base – FLEXSPI peripheral base address.
- Return values:
trigger – source of current command sequence.
-
static inline flexspi_ip_error_code_t FLEXSPI_GetIPCommandErrorCode(FLEXSPI_Type *base, uint8_t *index)
Gets the error code when IP command error detected.
- Parameters:
base – FLEXSPI peripheral base address.
index – Pointer to a uint8_t type variable to receive the sequence index when error detected.
- Return values:
error – code when IP command error detected.
-
static inline flexspi_ahb_error_code_t FLEXSPI_GetAHBCommandErrorCode(FLEXSPI_Type *base, uint8_t *index)
Gets the error code when AHB command error detected.
- Parameters:
base – FLEXSPI peripheral base address.
index – Pointer to a uint8_t type variable to receive the sequence index when error detected.
- Return values:
error – code when AHB command error detected.
-
static inline bool FLEXSPI_GetBusIdleStatus(FLEXSPI_Type *base)
Returns whether the bus is idle.
- Parameters:
base – FLEXSPI peripheral base address.
- Return values:
true – Bus is idle.
false – Bus is busy.
-
void FLEXSPI_UpdateRxSampleClock(FLEXSPI_Type *base, flexspi_read_sample_clock_t clockSource)
Update read sample clock source.
- Parameters:
base – FLEXSPI peripheral base address.
clockSource – clockSource of type flexspi_read_sample_clock_t
-
void FLEXSPI_UpdateLUT(FLEXSPI_Type *base, uint32_t index, const uint32_t *cmd, uint32_t count)
Updates the LUT table.
- Parameters:
base – FLEXSPI peripheral base address.
index – From which index start to update. It could be any index of the LUT table, which also allows user to update command content inside a command. Each command consists of up to 8 instructions and occupy 4*32-bit memory.
cmd – Command sequence array.
count – Number of sequences.
-
static inline void FLEXSPI_WriteData(FLEXSPI_Type *base, uint32_t data, uint8_t fifoIndex)
Writes data into FIFO.
- Parameters:
base – FLEXSPI peripheral base address
data – The data bytes to send
fifoIndex – Destination fifo index.
-
static inline uint32_t FLEXSPI_ReadData(FLEXSPI_Type *base, uint8_t fifoIndex)
Receives data from data FIFO.
- Parameters:
base – FLEXSPI peripheral base address
fifoIndex – Source fifo index.
- Returns:
The data in the FIFO.
-
status_t FLEXSPI_WriteBlocking(FLEXSPI_Type *base, uint8_t *buffer, size_t size)
Sends a buffer of data bytes using blocking method.
Note
This function blocks via polling until all bytes have been sent.
- Parameters:
base – FLEXSPI peripheral base address
buffer – The data bytes to send
size – The number of data bytes to send
- Return values:
kStatus_Success – write success without error
kStatus_FLEXSPI_SequenceExecutionTimeout – sequence execution timeout
kStatus_FLEXSPI_IpCommandSequenceError – IP command sequence error detected
kStatus_FLEXSPI_IpCommandGrantTimeout – IP command grant timeout detected
-
status_t FLEXSPI_ReadBlocking(FLEXSPI_Type *base, uint8_t *buffer, size_t size)
Receives a buffer of data bytes using a blocking method.
Note
This function blocks via polling until all bytes have been sent.
- Parameters:
base – FLEXSPI peripheral base address
buffer – The data bytes to send
size – The number of data bytes to receive
- Return values:
kStatus_Success – read success without error
kStatus_FLEXSPI_SequenceExecutionTimeout – sequence execution timeout
kStatus_FLEXSPI_IpCommandSequenceError – IP command sequencen error detected
kStatus_FLEXSPI_IpCommandGrantTimeout – IP command grant timeout detected
-
status_t FLEXSPI_TransferBlocking(FLEXSPI_Type *base, flexspi_transfer_t *xfer)
Execute command to transfer a buffer data bytes using a blocking method.
- Parameters:
base – FLEXSPI peripheral base address
xfer – pointer to the transfer structure.
- Return values:
kStatus_Success – command transfer success without error
kStatus_FLEXSPI_SequenceExecutionTimeout – sequence execution timeout
kStatus_FLEXSPI_IpCommandSequenceError – IP command sequence error detected
kStatus_FLEXSPI_IpCommandGrantTimeout – IP command grant timeout detected
-
void FLEXSPI_TransferCreateHandle(FLEXSPI_Type *base, flexspi_handle_t *handle, flexspi_transfer_callback_t callback, void *userData)
Initializes the FLEXSPI handle which is used in transactional functions.
- Parameters:
base – FLEXSPI peripheral base address.
handle – pointer to flexspi_handle_t structure to store the transfer state.
callback – pointer to user callback function.
userData – user parameter passed to the callback function.
-
status_t FLEXSPI_TransferNonBlocking(FLEXSPI_Type *base, flexspi_handle_t *handle, flexspi_transfer_t *xfer)
Performs a interrupt non-blocking transfer on the FLEXSPI bus.
Note
Calling the API returns immediately after transfer initiates. The user needs to call FLEXSPI_GetTransferCount to poll the transfer status to check whether the transfer is finished. If the return status is not kStatus_FLEXSPI_Busy, the transfer is finished. For FLEXSPI_Read, the dataSize should be multiple of rx watermark level, or FLEXSPI could not read data properly.
- Parameters:
base – FLEXSPI peripheral base address.
handle – pointer to flexspi_handle_t structure which stores the transfer state.
xfer – pointer to flexspi_transfer_t structure.
- Return values:
kStatus_Success – Successfully start the data transmission.
kStatus_FLEXSPI_Busy – Previous transmission still not finished.
-
status_t FLEXSPI_TransferGetCount(FLEXSPI_Type *base, flexspi_handle_t *handle, size_t *count)
Gets the master transfer status during a interrupt non-blocking transfer.
- Parameters:
base – FLEXSPI peripheral base address.
handle – pointer to flexspi_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.
-
void FLEXSPI_TransferAbort(FLEXSPI_Type *base, flexspi_handle_t *handle)
Aborts an interrupt non-blocking transfer early.
Note
This API can be called at any time when an interrupt non-blocking transfer initiates to abort the transfer early.
- Parameters:
base – FLEXSPI peripheral base address.
handle – pointer to flexspi_handle_t structure which stores the transfer state
-
void FLEXSPI_TransferHandleIRQ(FLEXSPI_Type *base, flexspi_handle_t *handle)
Master interrupt handler.
- Parameters:
base – FLEXSPI peripheral base address.
handle – pointer to flexspi_handle_t structure.
-
FSL_FLEXSPI_DRIVER_VERSION
FLEXSPI driver version.
Status structure of FLEXSPI.
Values:
-
enumerator kStatus_FLEXSPI_Busy
FLEXSPI is busy
-
enumerator kStatus_FLEXSPI_SequenceExecutionTimeout
Sequence execution timeout error occurred during FLEXSPI transfer.
-
enumerator kStatus_FLEXSPI_IpCommandSequenceError
IP command Sequence execution timeout error occurred during FLEXSPI transfer.
-
enumerator kStatus_FLEXSPI_IpCommandGrantTimeout
IP command grant timeout error occurred during FLEXSPI transfer.
-
enumerator kStatus_FLEXSPI_Busy
CMD definition of FLEXSPI, use to form LUT instruction, _flexspi_command.
Values:
-
enumerator kFLEXSPI_Command_STOP
Stop execution, deassert CS.
-
enumerator kFLEXSPI_Command_SDR
Transmit Command code to Flash, using SDR mode.
-
enumerator kFLEXSPI_Command_RADDR_SDR
Transmit Row Address to Flash, using SDR mode.
-
enumerator kFLEXSPI_Command_CADDR_SDR
Transmit Column Address to Flash, using SDR mode.
-
enumerator kFLEXSPI_Command_MODE1_SDR
Transmit 1-bit Mode bits to Flash, using SDR mode.
-
enumerator kFLEXSPI_Command_MODE2_SDR
Transmit 2-bit Mode bits to Flash, using SDR mode.
-
enumerator kFLEXSPI_Command_MODE4_SDR
Transmit 4-bit Mode bits to Flash, using SDR mode.
-
enumerator kFLEXSPI_Command_MODE8_SDR
Transmit 8-bit Mode bits to Flash, using SDR mode.
-
enumerator kFLEXSPI_Command_WRITE_SDR
Transmit Programming Data to Flash, using SDR mode.
-
enumerator kFLEXSPI_Command_READ_SDR
Receive Read Data from Flash, using SDR mode.
-
enumerator kFLEXSPI_Command_LEARN_SDR
Receive Read Data or Preamble bit from Flash, SDR mode.
-
enumerator kFLEXSPI_Command_DATSZ_SDR
Transmit Read/Program Data size (byte) to Flash, SDR mode.
-
enumerator kFLEXSPI_Command_DUMMY_SDR
Leave data lines undriven by FlexSPI controller.
-
enumerator kFLEXSPI_Command_DUMMY_RWDS_SDR
Leave data lines undriven by FlexSPI controller, dummy cycles decided by RWDS.
-
enumerator kFLEXSPI_Command_DDR
Transmit Command code to Flash, using DDR mode.
-
enumerator kFLEXSPI_Command_RADDR_DDR
Transmit Row Address to Flash, using DDR mode.
-
enumerator kFLEXSPI_Command_CADDR_DDR
Transmit Column Address to Flash, using DDR mode.
-
enumerator kFLEXSPI_Command_MODE1_DDR
Transmit 1-bit Mode bits to Flash, using DDR mode.
-
enumerator kFLEXSPI_Command_MODE2_DDR
Transmit 2-bit Mode bits to Flash, using DDR mode.
-
enumerator kFLEXSPI_Command_MODE4_DDR
Transmit 4-bit Mode bits to Flash, using DDR mode.
-
enumerator kFLEXSPI_Command_MODE8_DDR
Transmit 8-bit Mode bits to Flash, using DDR mode.
-
enumerator kFLEXSPI_Command_WRITE_DDR
Transmit Programming Data to Flash, using DDR mode.
-
enumerator kFLEXSPI_Command_READ_DDR
Receive Read Data from Flash, using DDR mode.
-
enumerator kFLEXSPI_Command_LEARN_DDR
Receive Read Data or Preamble bit from Flash, DDR mode.
-
enumerator kFLEXSPI_Command_DATSZ_DDR
Transmit Read/Program Data size (byte) to Flash, DDR mode.
-
enumerator kFLEXSPI_Command_DUMMY_DDR
Leave data lines undriven by FlexSPI controller.
-
enumerator kFLEXSPI_Command_DUMMY_RWDS_DDR
Leave data lines undriven by FlexSPI controller, dummy cycles decided by RWDS.
-
enumerator kFLEXSPI_Command_JUMP_ON_CS
Stop execution, deassert CS and save operand[7:0] as the instruction start pointer for next sequence
-
enumerator kFLEXSPI_Command_STOP
-
enum _flexspi_pad
pad definition of FLEXSPI, use to form LUT instruction.
Values:
-
enumerator kFLEXSPI_1PAD
Transmit command/address and transmit/receive data only through DATA0/DATA1.
-
enumerator kFLEXSPI_2PAD
Transmit command/address and transmit/receive data only through DATA[1:0].
-
enumerator kFLEXSPI_4PAD
Transmit command/address and transmit/receive data only through DATA[3:0].
-
enumerator kFLEXSPI_8PAD
Transmit command/address and transmit/receive data only through DATA[7:0].
-
enumerator kFLEXSPI_1PAD
-
enum _flexspi_flags
FLEXSPI interrupt status flags.
Values:
-
enumerator kFLEXSPI_SequenceExecutionTimeoutFlag
Sequence execution timeout.
-
enumerator kFLEXSPI_AhbBusErrorFlag
AHB Bus error flag.
-
enumerator kFLEXSPI_SckStoppedBecauseTxEmptyFlag
SCK is stopped during command sequence because Async TX FIFO empty.
-
enumerator kFLEXSPI_SckStoppedBecauseRxFullFlag
SCK is stopped during command sequence because Async RX FIFO full.
-
enumerator kFLEXSPI_DataLearningFailedFlag
Data learning failed.
-
enumerator kFLEXSPI_IpTxFifoWatermarkEmptyFlag
IP TX FIFO WaterMark empty.
-
enumerator kFLEXSPI_IpRxFifoWatermarkAvailableFlag
IP RX FIFO WaterMark available.
-
enumerator kFLEXSPI_AhbCommandSequenceErrorFlag
AHB triggered Command Sequences Error.
-
enumerator kFLEXSPI_IpCommandSequenceErrorFlag
IP triggered Command Sequences Error.
-
enumerator kFLEXSPI_AhbCommandGrantTimeoutFlag
AHB triggered Command Sequences Grant Timeout.
-
enumerator kFLEXSPI_IpCommandGrantTimeoutFlag
IP triggered Command Sequences Grant Timeout.
-
enumerator kFLEXSPI_IpCommandExecutionDoneFlag
IP triggered Command Sequences Execution finished.
-
enumerator kFLEXSPI_AllInterruptFlags
All flags.
-
enumerator kFLEXSPI_SequenceExecutionTimeoutFlag
-
enum _flexspi_read_sample_clock
FLEXSPI sample clock source selection for Flash Reading.
Values:
-
enumerator kFLEXSPI_ReadSampleClkLoopbackInternally
Dummy Read strobe generated by FlexSPI Controller and loopback internally.
-
enumerator kFLEXSPI_ReadSampleClkLoopbackFromDqsPad
Dummy Read strobe generated by FlexSPI Controller and loopback from DQS pad.
-
enumerator kFLEXSPI_ReadSampleClkLoopbackFromSckPad
SCK output clock and loopback from SCK pad.
-
enumerator kFLEXSPI_ReadSampleClkExternalInputFromDqsPad
Flash provided Read strobe and input from DQS pad.
-
enumerator kFLEXSPI_ReadSampleClkLoopbackInternally
-
enum _flexspi_cs_interval_cycle_unit
FLEXSPI interval unit for flash device select.
Values:
-
enumerator kFLEXSPI_CsIntervalUnit1SckCycle
Chip selection interval: CSINTERVAL * 1 serial clock cycle.
-
enumerator kFLEXSPI_CsIntervalUnit256SckCycle
Chip selection interval: CSINTERVAL * 256 serial clock cycle.
-
enumerator kFLEXSPI_CsIntervalUnit1SckCycle
-
enum _flexspi_ahb_write_wait_unit
FLEXSPI AHB wait interval unit for writing.
Values:
-
enumerator kFLEXSPI_AhbWriteWaitUnit2AhbCycle
AWRWAIT unit is 2 ahb clock cycle.
-
enumerator kFLEXSPI_AhbWriteWaitUnit8AhbCycle
AWRWAIT unit is 8 ahb clock cycle.
-
enumerator kFLEXSPI_AhbWriteWaitUnit32AhbCycle
AWRWAIT unit is 32 ahb clock cycle.
-
enumerator kFLEXSPI_AhbWriteWaitUnit128AhbCycle
AWRWAIT unit is 128 ahb clock cycle.
-
enumerator kFLEXSPI_AhbWriteWaitUnit512AhbCycle
AWRWAIT unit is 512 ahb clock cycle.
-
enumerator kFLEXSPI_AhbWriteWaitUnit2048AhbCycle
AWRWAIT unit is 2048 ahb clock cycle.
-
enumerator kFLEXSPI_AhbWriteWaitUnit8192AhbCycle
AWRWAIT unit is 8192 ahb clock cycle.
-
enumerator kFLEXSPI_AhbWriteWaitUnit32768AhbCycle
AWRWAIT unit is 32768 ahb clock cycle.
-
enumerator kFLEXSPI_AhbWriteWaitUnit2AhbCycle
-
enum _flexspi_ip_error_code
Error Code when IP command Error detected.
Values:
-
enumerator kFLEXSPI_IpCmdErrorNoError
No error.
-
enumerator kFLEXSPI_IpCmdErrorJumpOnCsInIpCmd
IP command with JMP_ON_CS instruction used.
-
enumerator kFLEXSPI_IpCmdErrorUnknownOpCode
Unknown instruction opcode in the sequence.
-
enumerator kFLEXSPI_IpCmdErrorSdrDummyInDdrSequence
Instruction DUMMY_SDR/DUMMY_RWDS_SDR used in DDR sequence.
-
enumerator kFLEXSPI_IpCmdErrorDdrDummyInSdrSequence
Instruction DUMMY_DDR/DUMMY_RWDS_DDR used in SDR sequence.
-
enumerator kFLEXSPI_IpCmdErrorInvalidAddress
Flash access start address exceed the whole flash address range (A1/A2/B1/B2).
-
enumerator kFLEXSPI_IpCmdErrorSequenceExecutionTimeout
Sequence execution timeout.
-
enumerator kFLEXSPI_IpCmdErrorFlashBoundaryAcrosss
Flash boundary crossed.
-
enumerator kFLEXSPI_IpCmdErrorNoError
-
enum _flexspi_ahb_error_code
Error Code when AHB command Error detected.
Values:
-
enumerator kFLEXSPI_AhbCmdErrorNoError
No error.
-
enumerator kFLEXSPI_AhbCmdErrorJumpOnCsInWriteCmd
AHB Write command with JMP_ON_CS instruction used in the sequence.
-
enumerator kFLEXSPI_AhbCmdErrorUnknownOpCode
Unknown instruction opcode in the sequence.
-
enumerator kFLEXSPI_AhbCmdErrorSdrDummyInDdrSequence
Instruction DUMMY_SDR/DUMMY_RWDS_SDR used in DDR sequence.
-
enumerator kFLEXSPI_AhbCmdErrorDdrDummyInSdrSequence
Instruction DUMMY_DDR/DUMMY_RWDS_DDR used in SDR sequence.
-
enumerator kFLEXSPI_AhbCmdSequenceExecutionTimeout
Sequence execution timeout.
-
enumerator kFLEXSPI_AhbCmdErrorNoError
-
enum _flexspi_port
FLEXSPI operation port select.
Values:
-
enumerator kFLEXSPI_PortA1
Access flash on A1 port.
-
enumerator kFLEXSPI_PortA2
Access flash on A2 port.
-
enumerator kFLEXSPI_PortCount
-
enumerator kFLEXSPI_PortA1
-
enum _flexspi_arb_command_source
Trigger source of current command sequence granted by arbitrator.
Values:
-
enumerator kFLEXSPI_AhbReadCommand
-
enumerator kFLEXSPI_AhbWriteCommand
-
enumerator kFLEXSPI_IpCommand
-
enumerator kFLEXSPI_SuspendedCommand
-
enumerator kFLEXSPI_AhbReadCommand
-
enum _flexspi_command_type
Command type.
Values:
-
enumerator kFLEXSPI_Command
FlexSPI operation: Only command, both TX and Rx buffer are ignored.
-
enumerator kFLEXSPI_Config
FlexSPI operation: Configure device mode, the TX fifo size is fixed in LUT.
-
enumerator kFLEXSPI_Read
-
enumerator kFLEXSPI_Write
-
enumerator kFLEXSPI_Command
-
typedef enum _flexspi_pad flexspi_pad_t
pad definition of FLEXSPI, use to form LUT instruction.
-
typedef enum _flexspi_flags flexspi_flags_t
FLEXSPI interrupt status flags.
-
typedef enum _flexspi_read_sample_clock flexspi_read_sample_clock_t
FLEXSPI sample clock source selection for Flash Reading.
-
typedef enum _flexspi_cs_interval_cycle_unit flexspi_cs_interval_cycle_unit_t
FLEXSPI interval unit for flash device select.
-
typedef enum _flexspi_ahb_write_wait_unit flexspi_ahb_write_wait_unit_t
FLEXSPI AHB wait interval unit for writing.
-
typedef enum _flexspi_ip_error_code flexspi_ip_error_code_t
Error Code when IP command Error detected.
-
typedef enum _flexspi_ahb_error_code flexspi_ahb_error_code_t
Error Code when AHB command Error detected.
-
typedef enum _flexspi_port flexspi_port_t
FLEXSPI operation port select.
-
typedef enum _flexspi_arb_command_source flexspi_arb_command_source_t
Trigger source of current command sequence granted by arbitrator.
-
typedef enum _flexspi_command_type flexspi_command_type_t
Command type.
-
typedef struct _flexspi_ahbBuffer_config flexspi_ahbBuffer_config_t
-
typedef struct _flexspi_config flexspi_config_t
FLEXSPI configuration structure.
-
typedef struct _flexspi_device_config flexspi_device_config_t
External device configuration items.
-
typedef struct _flexspi_transfer flexspi_transfer_t
Transfer structure for FLEXSPI.
-
typedef struct _flexspi_handle flexspi_handle_t
-
typedef void (*flexspi_transfer_callback_t)(FLEXSPI_Type *base, flexspi_handle_t *handle, status_t status, void *userData)
FLEXSPI transfer callback function.
-
FSL_FEATURE_FLEXSPI_AHB_BUFFER_COUNT
-
FLEXSPI_LUT_SEQ(cmd0, pad0, op0, cmd1, pad1, op1)
Formula to form FLEXSPI instructions in LUT table.
-
struct _flexspi_ahbBuffer_config
- #include <fsl_flexspi.h>
Public Members
-
uint8_t priority
This priority for AHB Master Read which this AHB RX Buffer is assigned.
-
uint8_t masterIndex
AHB Master ID the AHB RX Buffer is assigned.
-
uint16_t bufferSize
AHB buffer size in byte.
-
bool enablePrefetch
AHB Read Prefetch Enable for current AHB RX Buffer corresponding Master, allows prefetch disable/enable separately for each master.
-
uint8_t priority
-
struct _flexspi_config
- #include <fsl_flexspi.h>
FLEXSPI configuration structure.
Public Members
-
flexspi_read_sample_clock_t rxSampleClock
Sample Clock source selection for Flash Reading.
-
bool enableSckFreeRunning
Enable/disable SCK output free-running.
-
bool enableDoze
Enable/disable doze mode support.
-
bool enableHalfSpeedAccess
Enable/disable divide by 2 of the clock for half speed commands.
-
bool enableSameConfigForAll
Enable/disable same configuration for all connected devices when enabled, same configuration in FLASHA1CRx is applied to all.
-
uint16_t seqTimeoutCycle
Timeout wait cycle for command sequence execution, timeout after ahbGrantTimeoutCyle*1024 serial root clock cycles.
-
uint8_t ipGrantTimeoutCycle
Timeout wait cycle for IP command grant, timeout after ipGrantTimeoutCycle*1024 AHB clock cycles.
-
uint8_t txWatermark
FLEXSPI IP transmit watermark value.
-
uint8_t rxWatermark
FLEXSPI receive watermark value.
-
flexspi_read_sample_clock_t rxSampleClock
-
struct _flexspi_device_config
- #include <fsl_flexspi.h>
External device configuration items.
Public Members
-
uint32_t flexspiRootClk
FLEXSPI serial root clock.
-
bool isSck2Enabled
FLEXSPI use SCK2.
-
uint32_t flashSize
Flash size in KByte.
-
bool addressShift
Address shift.
-
flexspi_cs_interval_cycle_unit_t CSIntervalUnit
CS interval unit, 1 or 256 cycle.
-
uint16_t CSInterval
CS line assert interval, multiply CS interval unit to get the CS line assert interval cycles.
-
uint8_t CSHoldTime
CS line hold time.
-
uint8_t CSSetupTime
CS line setup time.
-
uint8_t dataValidTime
Data valid time for external device.
-
uint8_t columnspace
Column space size.
-
bool enableWordAddress
If enable word address.
-
uint8_t AWRSeqIndex
Sequence ID for AHB write command.
-
uint8_t AWRSeqNumber
Sequence number for AHB write command.
-
uint8_t ARDSeqIndex
Sequence ID for AHB read command.
-
uint8_t ARDSeqNumber
Sequence number for AHB read command.
-
flexspi_ahb_write_wait_unit_t AHBWriteWaitUnit
AHB write wait unit.
-
uint16_t AHBWriteWaitInterval
AHB write wait interval, multiply AHB write interval unit to get the AHB write wait cycles.
-
bool enableWriteMask
Enable/Disable FLEXSPI drive DQS pin as write mask when writing to external device.
-
uint32_t flexspiRootClk
-
struct _flexspi_transfer
- #include <fsl_flexspi.h>
Transfer structure for FLEXSPI.
Public Members
-
uint32_t deviceAddress
Operation device address.
-
flexspi_port_t port
Operation port.
-
flexspi_command_type_t cmdType
Execution command type.
-
uint8_t seqIndex
Sequence ID for command.
-
uint8_t SeqNumber
Sequence number for command.
-
uint32_t *data
Data buffer.
-
size_t dataSize
Data size in bytes.
-
uint32_t deviceAddress
-
struct _flexspi_handle
- #include <fsl_flexspi.h>
Transfer handle structure for FLEXSPI.
Public Members
-
uint32_t state
Internal state for FLEXSPI transfer
-
uint8_t *data
Data buffer.
-
size_t dataSize
Remaining Data size in bytes.
-
size_t transferTotalSize
Total Data size in bytes.
-
flexspi_transfer_callback_t completionCallback
Callback for users while transfer finish or error occurred
-
void *userData
FLEXSPI callback function parameter.
-
uint32_t state
-
struct ahbConfig
Public Members
-
uint8_t ahbGrantTimeoutCycle
Timeout wait cycle for AHB command grant, timeout after ahbGrantTimeoutCyle*1024 AHB clock cycles.
-
uint16_t ahbBusTimeoutCycle
Timeout wait cycle for AHB read/write access, timeout after ahbBusTimeoutCycle*1024 AHB clock cycles.
-
uint8_t resumeWaitCycle
Wait cycle for idle state before suspended command sequence resume, timeout after ahbBusTimeoutCycle AHB clock cycles.
-
flexspi_ahbBuffer_config_t buffer[FSL_FEATURE_FLEXSPI_AHB_BUFFER_COUNTn(0)]
AHB buffer size.
-
bool enableClearAHBBufferOpt
Enable/disable automatically clean AHB RX Buffer and TX Buffer when FLEXSPI returns STOP mode ACK.
-
bool enableReadAddressOpt
Enable/disable remove AHB read burst start address alignment limitation. when enable, there is no AHB read burst start address alignment limitation.
-
bool enableAHBPrefetch
Enable/disable AHB read prefetch feature, when enabled, FLEXSPI will fetch more data than current AHB burst.
-
bool enableAHBBufferable
Enable/disable AHB bufferable write access support, when enabled, FLEXSPI return before waiting for command execution finished.
-
bool enableAHBCachable
Enable AHB bus cachable read access support.
-
uint8_t ahbGrantTimeoutCycle
FLEXSPI DMA Driver
-
void FLEXSPI_TransferCreateHandleDMA(FLEXSPI_Type *base, flexspi_dma_handle_t *handle, flexspi_dma_callback_t callback, void *userData, dma_handle_t *txDmaHandle, dma_handle_t *rxDmaHandle)
Initializes the FLEXSPI handle for transfer which is used in transactional functions and set the callback.
- Parameters:
base – FLEXSPI peripheral base address
handle – Pointer to flexspi_dma_handle_t structure
callback – FLEXSPI 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.
-
void FLEXSPI_TransferUpdateSizeDMA(FLEXSPI_Type *base, flexspi_dma_handle_t *handle, flexspi_dma_transfer_nsize_t nsize)
Update FLEXSPI DMA transfer source data transfer size(SSIZE) and destination data transfer size(DSIZE).
See also
flexspi_dma_transfer_nsize_t .
- Parameters:
base – FLEXSPI peripheral base address
handle – Pointer to flexspi_dma_handle_t structure
nsize – FLEXSPI DMA transfer data transfer size(SSIZE/DSIZE), by default the size is kFLEXPSI_DMAnSize1Bytes(one byte).
-
status_t FLEXSPI_TransferDMA(FLEXSPI_Type *base, flexspi_dma_handle_t *handle, flexspi_transfer_t *xfer)
Transfers FLEXSPI data using an dma non-blocking method.
This function writes/receives data to/from the FLEXSPI transmit/receive FIFO. This function is non-blocking.
- Parameters:
base – FLEXSPI peripheral base address.
handle – Pointer to flexspi_dma_handle_t structure
xfer – FLEXSPI transfer structure.
- Return values:
kStatus_FLEXSPI_Busy – FLEXSPI is busy transfer.
kStatus_InvalidArgument – The watermark configuration is invalid, the watermark should be power of 2 to do successfully DMA transfer.
kStatus_Success – FLEXSPI successfully start dma transfer.
-
void FLEXSPI_TransferAbortDMA(FLEXSPI_Type *base, flexspi_dma_handle_t *handle)
Aborts the transfer data using dma.
This function aborts the transfer data using dma.
- Parameters:
base – FLEXSPI peripheral base address.
handle – Pointer to flexspi_dma_handle_t structure
-
status_t FLEXSPI_TransferGetTransferCountDMA(FLEXSPI_Type *base, flexspi_dma_handle_t *handle, size_t *count)
Gets the transferred counts of transfer.
- Parameters:
base – FLEXSPI peripheral base address.
handle – Pointer to flexspi_dma_handle_t structure.
count – Bytes transfer.
- Return values:
kStatus_Success – Succeed get the transfer count.
kStatus_NoTransferInProgress – There is not a non-blocking transaction currently in progress.
-
FSL_FLEXSPI_DMA_DRIVER_VERSION
FLEXSPI DMA driver version 2.2.1.
-
enum _flexspi_dma_ntransfer_size
dma transfer configuration
Values:
-
enumerator kFLEXPSI_DMAnSize1Bytes
Source/Destination data transfer size is 1 byte every time
-
enumerator kFLEXPSI_DMAnSize2Bytes
Source/Destination data transfer size is 2 bytes every time
-
enumerator kFLEXPSI_DMAnSize4Bytes
Source/Destination data transfer size is 4 bytes every time
-
enumerator kFLEXPSI_DMAnSize1Bytes
-
typedef struct _flexspi_dma_handle flexspi_dma_handle_t
-
typedef void (*flexspi_dma_callback_t)(FLEXSPI_Type *base, flexspi_dma_handle_t *handle, status_t status, void *userData)
FLEXSPI dma transfer callback function for finish and error.
-
typedef enum _flexspi_dma_ntransfer_size flexspi_dma_transfer_nsize_t
dma transfer configuration
-
struct _flexspi_dma_handle
- #include <fsl_flexspi_dma.h>
FLEXSPI DMA transfer handle, users should not touch the content of the handle.
Public Members
-
dma_handle_t *txDmaHandle
dma handler for FLEXSPI Tx.
-
dma_handle_t *rxDmaHandle
dma handler for FLEXSPI Rx.
-
size_t transferSize
Bytes need to transfer.
-
flexspi_dma_transfer_nsize_t nsize
dma SSIZE/DSIZE in each transfer.
-
uint8_t nbytes
dma minor byte transfer count initially configured.
-
uint8_t count
The transfer data count in a DMA request.
-
uint32_t state
Internal state for FLEXSPI dma transfer.
-
flexspi_dma_callback_t completionCallback
A callback function called after the dma transfer is finished.
-
void *userData
User callback parameter
-
dma_handle_t *txDmaHandle
Flexspi_nor_flash_driver
Flash Pad Definitions.
Values:
-
enumerator kSerialFlash_1Pad
-
enumerator kSerialFlash_2Pads
-
enumerator kSerialFlash_4Pads
-
enumerator kSerialFlash_8Pads
-
enumerator kSerialFlash_1Pad
FLEXSPI clock configuration type.
Values:
-
enumerator kFLEXSPIClk_SDR
Clock configure for SDR mode
-
enumerator kFLEXSPIClk_DDR
Clock configurat for DDR mode
-
enumerator kFLEXSPIClk_SDR
-
enum _flexspi_read_sample_clk
FLEXSPI Read Sample Clock Source definition.
Values:
-
enumerator kFLEXSPIReadSampleClk_LoopbackInternally
-
enumerator kFLEXSPIReadSampleClk_LoopbackFromDqsPad
-
enumerator kFLEXSPIReadSampleClk_LoopbackFromSckPad
-
enumerator kFLEXSPIReadSampleClk_ExternalInputFromDqsPad
-
enumerator kFLEXSPIReadSampleClk_LoopbackInternally
Flash Type Definition.
Values:
-
enumerator kFLEXSPIDeviceType_SerialNOR
Flash device is Serial NOR
-
enumerator kFLEXSPIDeviceType_SerialNOR
Flash Configuration Command Type.
Values:
-
enumerator kDeviceConfigCmdType_Generic
Generic command, for example: configure dummy cycles, drive strength, etc
-
enumerator kDeviceConfigCmdType_QuadEnable
Quad Enable command
-
enumerator kDeviceConfigCmdType_Spi2Xpi
Switch from SPI to DPI/QPI/OPI mode
-
enumerator kDeviceConfigCmdType_Xpi2Spi
Switch from DPI/QPI/OPI to SPI mode
-
enumerator kDeviceConfigCmdType_Spi2NoCmd
Switch to 0-4-4/0-8-8 mode
-
enumerator kDeviceConfigCmdType_Reset
Reset device command
-
enumerator kDeviceConfigCmdType_Generic
-
enum _flexspi_serial_clk_freq
Defintions for FLEXSPI Serial Clock Frequency.
Values:
-
enumerator kFLEXSPISerialClk_NoChange
-
enumerator kFLEXSPISerialClk_30MHz
-
enumerator kFLEXSPISerialClk_50MHz
-
enumerator kFLEXSPISerialClk_60MHz
-
enumerator kFLEXSPISerialClk_75MHz
-
enumerator kFLEXSPISerialClk_80MHz
-
enumerator kFLEXSPISerialClk_100MHz
-
enumerator kFLEXSPISerialClk_133MHz
-
enumerator kFLEXSPISerialClk_166MHz
-
enumerator kFLEXSPISerialClk_NoChange
Misc feature bit definitions.
Values:
-
enumerator kFLEXSPIMiscOffset_DiffClkEnable
Bit for Differential clock enable
-
enumerator kFLEXSPIMiscOffset_Ck2Enable
Bit for CK2 enable
-
enumerator kFLEXSPIMiscOffset_ParallelEnable
Bit for Parallel mode enable
-
enumerator kFLEXSPIMiscOffset_WordAddressableEnable
Bit for Word Addressable enable
-
enumerator kFLEXSPIMiscOffset_SafeConfigFreqEnable
Bit for Safe Configuration Frequency enable
-
enumerator kFLEXSPIMiscOffset_PadSettingOverrideEnable
Bit for Pad setting override enable
-
enumerator kFLEXSPIMiscOffset_DdrModeEnable
Bit for DDR clock confiuration indication.
-
enumerator kFLEXSPIMiscOffset_UseValidTimeForAllFreq
Bit for DLLCR settings under all modes
-
enumerator kFLEXSPIMiscOffset_DiffClkEnable
-
enum _flexspi_status_groups
FLEXSPI status group numbers.
Values:
-
enumerator kStatusROMGroup_FLEXSPI
Group number for ROM FLEXSPI status codes.
-
enumerator kStatusROMGroup_FLEXSPINOR
ROM FLEXSPI NOR status group number.
-
enumerator kStatusROMGroup_FLEXSPI
-
enum _flexspi_nor_status
FLEXSPI NOR status.
Values:
-
enumerator kStatus_FLEXSPINOR_ProgramFail
Status for Page programming failure
-
enumerator kStatus_FLEXSPINOR_EraseSectorFail
Status for Sector Erase failure
-
enumerator kStatus_FLEXSPINOR_EraseAllFail
Status for Chip Erase failure
-
enumerator kStatus_FLEXSPINOR_WaitTimeout
Status for timeout
-
enumerator kStatus_FlexSPINOR_NotSupported
-
enumerator kStatus_FlexSPINOR_WriteAlignmentError
Status for Alignement error
-
enumerator kStatus_FlexSPINOR_CommandFailure
Status for Erase/Program Verify Error
-
enumerator kStatus_FlexSPINOR_SFDP_NotFound
Status for SFDP read failure
-
enumerator kStatus_FLEXSPINOR_Unsupported_SFDP_Version
Status for Unrecognized SFDP version
-
enumerator kStatus_FLEXSPINOR_Flash_NotFound
Status for Flash detection failure
-
enumerator kStatus_FLEXSPINOR_DTRRead_DummyProbeFailed
Status for DDR Read dummy probe failure
-
enumerator kStatus_FLEXSPI_SequenceExecutionTimeout
Status for Sequence Execution timeout
-
enumerator kStatus_FLEXSPI_InvalidSequence
Status for Invalid Sequence
-
enumerator kStatus_FLEXSPI_DeviceTimeout
Status for Device timeout
-
enumerator kStatus_FLEXSPINOR_ProgramFail
Configure the device_type of “serial_nor_config_option_t” structure.
Values:
-
enumerator kSerialNorCfgOption_Tag
-
enumerator kSerialNorCfgOption_DeviceType_ReadSFDP_SDR
-
enumerator kSerialNorCfgOption_DeviceType_ReadSFDP_DDR
-
enumerator kSerialNorCfgOption_DeviceType_HyperFLASH1V8
-
enumerator kSerialNorCfgOption_DeviceType_HyperFLASH3V0
-
enumerator kSerialNorCfgOption_DeviceType_MacronixOctalDDR
-
enumerator kSerialNorCfgOption_DeviceType_MacronixOctalSDR
-
enumerator kSerialNorCfgOption_DeviceType_MicronOctalDDR
-
enumerator kSerialNorCfgOption_DeviceType_MicronOctalSDR
-
enumerator kSerialNorCfgOption_DeviceType_AdestoOctalDDR
-
enumerator kSerialNorCfgOption_DeviceType_AdestoOctalSDR
-
enumerator kSerialNorCfgOption_Tag
Configure the quad_mode_setting of “serial_nor_config_option_t” structure.
Values:
-
enumerator kSerialNorQuadMode_NotConfig
-
enumerator kSerialNorQuadMode_StatusReg1_Bit6
-
enumerator kSerialNorQuadMode_StatusReg2_Bit1
-
enumerator kSerialNorQuadMode_StatusReg2_Bit7
-
enumerator kSerialNorQuadMode_StatusReg2_Bit1_0x31
-
enumerator kSerialNorQuadMode_NotConfig
FLEXSPI NOR Octal mode.
Values:
-
enumerator kSerialNorOctaldMode_NoOctalEnableBit
-
enumerator kSerialNorOctaldMode_HasOctalEnableBit
-
enumerator kSerialNorOctaldMode_NoOctalEnableBit
miscellaneous mode
Values:
-
enumerator kSerialNorEnhanceMode_Disabled
-
enumerator kSerialNorEnhanceMode_0_4_4_Mode
-
enumerator kSerialNorEnhanceMode_0_8_8_Mode
-
enumerator kSerialNorEnhanceMode_DataOrderSwapped
-
enumerator kSerialNorEnhanceMode_2ndPinMux
-
enumerator kSerialNorEnhanceMode_InternalLoopback
-
enumerator kSerialNorEnhanceMode_SpiMode
-
enumerator kSerialNorEnhanceMode_ExtDqs
-
enumerator kSerialNorEnhanceMode_Disabled
FLEXSPI NOR reset logic options.
Values:
-
enumerator kFlashResetLogic_Disabled
-
enumerator kFlashResetLogic_ResetPin
-
enumerator kFlashResetLogic_JedecHwReset
-
enumerator kFlashResetLogic_Disabled
Configure the flash_connection of “serial_nor_config_option_t” structure.
Values:
-
enumerator kSerialNorConnection_SinglePortA
-
enumerator kSerialNorConnection_Parallel
-
enumerator kSerialNorConnection_SinglePortB
-
enumerator kSerialNorConnection_BothPorts
-
enumerator kSerialNorConnection_SinglePortA
FLEXSPI ROOT clock soruce related definitions.
Values:
-
enumerator kFLEXSPIClkSrc_MainClk
-
enumerator kFLEXSPIClkSrc_Pll0
-
enumerator kFLEXSPIClkSrc_FroHf
-
enumerator kFLEXSPIClkSrc_Pll1
-
enumerator kFLEXSPIClkSrc_MainClk
Restore sequence options Configure the restore_sequence of “flash_run_context_t” structure.
Values:
-
enumerator kRestoreSequence_None
-
enumerator kRestoreSequence_HW_Reset
-
enumerator kRestoreSequence_QPI_4_0xFFs
-
enumerator kRestoreSequence_QPI_Mode_0x00
-
enumerator kRestoreSequence_8QPI_FF
-
enumerator kRestoreSequence_Send_F0
-
enumerator kRestoreSequence_Send_66_99
-
enumerator kRestoreSequence_Send_6699_9966
-
enumerator kRestoreSequence_Send_06_FF
Adesto EcoXIP
-
enumerator kRestoreSequence_QPI_5_0xFFs
-
enumerator kRestoreSequence_Send_QPI_8_0xFFs
-
enumerator kRestoreSequence_Wakeup_0xAB
-
enumerator kRestoreSequence_Wakeup_0xAB_54
-
enumerator kRestoreSequence_None
Port mode options.
Values:
-
enumerator kFlashInstMode_ExtendedSpi
-
enumerator kFlashInstMode_0_4_4_SDR
-
enumerator kFlashInstMode_0_4_4_DDR
-
enumerator kFlashInstMode_DPI_SDR
-
enumerator kFlashInstMode_DPI_DDR
-
enumerator kFlashInstMode_QPI_SDR
-
enumerator kFlashInstMode_QPI_DDR
-
enumerator kFlashInstMode_OPI_SDR
-
enumerator kFlashInstMode_OPI_DDR
-
enumerator kFlashInstMode_ExtendedSpi
Manufacturer ID.
Values:
-
enumerator kSerialFlash_ISSI_ManufacturerID
Manufacturer ID of the ISSI serial flash
-
enumerator kSerialFlash_Adesto_ManufacturerID
Manufacturer ID of the Adesto Technologies serial flash
-
enumerator kSerialFlash_Winbond_ManufacturerID
Manufacturer ID of the Winbond serial flash
-
enumerator kSerialFlash_Cypress_ManufacturerID
Manufacturer ID for Cypress
-
enumerator kSerialFlash_ISSI_ManufacturerID
-
enum _flexspi_operation
flexspi operation.
Values:
-
enumerator kFLEXSPIOperation_Command
Only command, both TX and RX buffer are ignored.
-
enumerator kFLEXSPIOperation_Config
Configure device mode, the TX FIFO size is fixed in LUT.
-
enumerator kFLEXSPIOperation_Write
Write, only TX buffer is effective
-
enumerator kFLEXSPIOperation_Read
Read, only Rx Buffer is effective.
-
enumerator kFLEXSPIOperation_End
-
enumerator kFLEXSPIOperation_Command
-
enum flexspi_clock_type_t
FLEXSPI Clock Type.
Values:
-
enumerator kFlexSpiClock_CoreClock
ARM Core Clock
-
enumerator kFlexSpiClock_AhbClock
AHB clock
-
enumerator kFlexSpiClock_SerialRootClock
Serial Root Clock
-
enumerator kFlexSpiClock_IpgClock
IPG clock
-
enumerator kFlexSpiClock_CoreClock
-
typedef struct _serial_nor_config_option serial_nor_config_option_t
Serial NOR configuration option.
-
typedef struct _lut_sequence flexspi_lut_seq_t
FLEXSPI LUT Sequence structure.
-
typedef struct _FlexSPIConfig flexspi_mem_config_t
FLEXSPI Memory Configuration Block.
-
typedef struct _flexspi_nor_config flexspi_nor_config_t
Serial NOR configuration block.
-
typedef enum _flexspi_operation flexspi_operation_t
flexspi operation.
-
typedef struct _flexspi_xfer flexspi_xfer_t
FLEXSPI Transfer Context.
-
status_t FLEXSPI_NorFlash_Init(uint32_t instance, flexspi_nor_config_t *config)
Initialize Serial NOR devices via FLEXSPI.
This function checks and initializes the FLEXSPI module for the other FLEXSPI APIs.
- Parameters:
instance – storage the instance of FLEXSPI.
config – A pointer to the storage for the driver runtime state.
- Return values:
kStatus_Success – Api was executed succesfuly.
kStatus_InvalidArgument – A invalid argument is provided.
kStatus_FLEXSPI_InvalidSequence – A invalid Sequence is provided.
kStatus_FLEXSPI_SequenceExecutionTimeout – Sequence Execution timeout.
kStatus_FLEXSPI_DeviceTimeout – the device timeout
-
status_t FLEXSPI_NorFlash_ProgramPage(uint32_t instance, flexspi_nor_config_t *config, uint32_t dstAddr, const uint32_t *src)
Program data to Serial NOR via FLEXSPI.
This function programs the NOR flash memory with the dest address for a given flash area as determined by the dst address and the length.
- Parameters:
instance – storage the instance of FLEXSPI.
config – A pointer to the storage for the driver runtime state.
dstAddr – A pointer to the desired flash memory to be programmed. NOTE: It is recommended that use page aligned access; If the dst_addr is not aligned to page,the driver automatically aligns address down with the page address.
src – A pointer to the source buffer of data that is to be programmed into the NOR flash.
- Return values:
kStatus_Success – Api was executed succesfuly.
kStatus_InvalidArgument – A invalid argument is provided.
kStatus_FLEXSPI_InvalidSequence – A invalid Sequence is provided.
kStatus_FLEXSPI_SequenceExecutionTimeout – Sequence Execution timeout.
kStatus_FLEXSPI_DeviceTimeout – the device timeout
-
status_t FLEXSPI_NorFlash_EraseAll(uint32_t instance, flexspi_nor_config_t *config)
Erase all the Serial NOR devices connected on FLEXSPI.
- Parameters:
instance – storage the instance of FLEXSPI.
config – A pointer to the storage for the driver runtime state.
- Return values:
kStatus_Success – Api was executed succesfuly.
kStatus_InvalidArgument – A invalid argument is provided.
kStatus_FLEXSPI_InvalidSequence – A invalid Sequence is provided.
kStatus_FLEXSPI_SequenceExecutionTimeout – Sequence Execution timeout.
kStatus_FLEXSPI_DeviceTimeout – the device timeout
-
status_t FLEXSPI_NorFlash_EraseSector(uint32_t instance, flexspi_nor_config_t *config, uint32_t address)
Erase one sector specified by address.
This function erases one of NOR flash sectors based on the desired address.
- Parameters:
instance – storage the index of FLEXSPI.
config – A pointer to the storage for the driver runtime state.
address – The start address of the desired NOR flash memory to be erased. NOTE: It is recommended that use sector-aligned access nor device; If dstAddr is not aligned with the sector,The driver automatically aligns address down with the sector address.
- Return values:
kStatus_Success – Api was executed succesfuly.
kStatus_InvalidArgument – A invalid argument is provided.
kStatus_FLEXSPI_InvalidSequence – A invalid Sequence is provided.
kStatus_FLEXSPI_SequenceExecutionTimeout – Sequence Execution timeout.
kStatus_FLEXSPI_DeviceTimeout – the device timeout
-
status_t FLEXSPI_NorFlash_EraseBlock(uint32_t instance, flexspi_nor_config_t *config, uint32_t address)
Erase one block specified by address.
This function erases one block of NOR flash based on the desired address.
- Parameters:
instance – storage the index of FLEXSPI.
config – A pointer to the storage for the driver runtime state.
address – The start address of the desired NOR flash memory to be erased. NOTE: It is recommended that use block-aligned access nor device; If dstAddr is not aligned with the block,The driver automatically aligns address down with the block address.
- Return values:
kStatus_Success – Api was executed succesfuly.
kStatus_InvalidArgument – A invalid argument is provided.
kStatus_FLEXSPI_InvalidSequence – A invalid Sequence is provided.
kStatus_FLEXSPI_SequenceExecutionTimeout – Sequence Execution timeout.
kStatus_FLEXSPI_DeviceTimeout – the device timeout
-
status_t FLEXSPI_NorFlash_GetConfig(uint32_t instance, flexspi_nor_config_t *config, serial_nor_config_option_t *option)
Get FLEXSPI NOR Configuration Block based on specified option.
- Parameters:
instance – storage the instance of FLEXSPI.
config – A pointer to the storage for the driver runtime state.
option – A pointer to the storage Serial NOR Configuration Option Context.
- Return values:
kStatus_Success – Api was executed succesfuly.
kStatus_InvalidArgument – A invalid argument is provided.
kStatus_FLEXSPI_InvalidSequence – A invalid Sequence is provided.
kStatus_FLEXSPI_SequenceExecutionTimeout – Sequence Execution timeout.
kStatus_FLEXSPI_DeviceTimeout – the device timeout
-
status_t FLEXSPI_NorFlash_Erase(uint32_t instance, flexspi_nor_config_t *config, uint32_t start, uint32_t length)
Erase Flash Region specified by address and length.
This function erases the appropriate number of flash sectors based on the desired start address and length.
- Parameters:
instance – storage the index of FLEXSPI.
config – A pointer to the storage for the driver runtime state.
start – The start address of the desired NOR flash memory to be erased. NOTE: It is recommended that use sector-aligned access nor device; If dstAddr is not aligned with the sector,the driver automatically aligns address down with the sector address.
length – The length, given in bytes to be erased. NOTE: It is recommended that use sector-aligned access nor device; If length is not aligned with the sector,the driver automatically aligns up with the sector.
- Return values:
kStatus_Success – Api was executed succesfuly.
kStatus_InvalidArgument – A invalid argument is provided.
kStatus_FLEXSPI_InvalidSequence – A invalid Sequence is provided.
kStatus_FLEXSPI_SequenceExecutionTimeout – Sequence Execution timeout.
kStatus_FLEXSPI_DeviceTimeout – the device timeout
-
status_t FLEXSPI_NorFlash_Read(uint32_t instance, flexspi_nor_config_t *config, uint32_t *dst, uint32_t start, uint32_t bytes)
Read data from Serial NOR via FLEXSPI.
This function read the NOR flash memory with the start address for a given flash area as determined by the dst address and the length.
- Parameters:
instance – storage the instance of FLEXSPI.
config – A pointer to the storage for the driver runtime state.
dst – A pointer to the dest buffer of data that is to be read from the NOR flash. NOTE: It is recommended that use page aligned access; If the dstAddr is not aligned to page,the driver automatically aligns address down with the page address.
start – The start address of the desired NOR flash memory to be read.
bytes – The length, given in bytes to be read.
- Return values:
kStatus_Success – Api was executed succesfuly.
kStatus_InvalidArgument – A invalid argument is provided.
kStatus_FLEXSPI_InvalidSequence – A invalid Sequence is provided.
kStatus_FLEXSPI_SequenceExecutionTimeout – Sequence Execution timeout.
kStatus_FLEXSPI_DeviceTimeout – the device timeout
-
status_t FLEXSPI_NorFlash_CommandXfer(uint32_t instance, flexspi_xfer_t *xfer)
FLEXSPI command.
This function is used to perform the command write sequence to the NOR device.
- Parameters:
instance – storage the index of FLEXSPI.
xfer – A pointer to the storage FLEXSPI Transfer Context.
- Return values:
kStatus_Success – Api was executed succesfuly.
kStatus_InvalidArgument – A invalid argument is provided.
kStatus_ROM_FLEXSPI_InvalidSequence – A invalid Sequence is provided.
kStatus_ROM_FLEXSPI_SequenceExecutionTimeout – Sequence Execution timeout.
-
status_t FLEXSPI_NorFlash_UpdateLut(uint32_t instance, uint32_t seqIndex, const uint32_t *lutBase, uint32_t numberOfSeq)
Configure FLEXSPI Lookup table.
- Parameters:
instance – storage the index of FLEXSPI.
seqIndex – storage the sequence Id.
lutBase – A pointer to the look-up-table for command sequences.
numberOfSeq – storage sequence number.
- Return values:
kStatus_Success – Api was executed succesfuly.
kStatus_InvalidArgument – A invalid argument is provided.
kStatus_ROM_FLEXSPI_InvalidSequence – A invalid Sequence is provided.
kStatus_ROM_FLEXSPI_SequenceExecutionTimeout – Sequence Execution timeout.
-
status_t FLEXSPI_NorFlash_SetClockSource(uint32_t clockSource)
Set the clock source for FLEXSPI NOR.
- Parameters:
clockSource – Clock source for FLEXSPI NOR. See to “_flexspi_nor_clock_source”.
- Return values:
kStatus_Success – Api was executed succesfuly.
kStatus_InvalidArgument – A invalid argument is provided.
-
void FLEXSPI_NorFlash_ConfigClock(uint32_t instance, uint32_t freqOption, uint32_t sampleClkMode)
config flexspi clock
- Parameters:
instance – storage the index of FLEXSPI.
freqOption – pointer to FlexSPIFlexSPI flash serial clock frequency.
sampleClkMode – pointer to configure the FlexSPI clock configuration type.
-
FLEXSPI_FEATURE_HAS_PARALLEL_MODE
FLEXSPI Feature related definitions
-
FSL_ROM_FLEXSPI_LUT_SEQ(cmd0, pad0, op0, cmd1, pad1, op1)
-
CMD_SDR
-
CMD_DDR
-
RADDR_SDR
-
RADDR_DDR
-
CADDR_SDR
-
CADDR_DDR
-
MODE1_SDR
-
MODE1_DDR
-
MODE2_SDR
-
MODE2_DDR
-
MODE4_SDR
-
MODE4_DDR
-
MODE8_SDR
-
MODE8_DDR
-
WRITE_SDR
-
WRITE_DDR
-
READ_SDR
-
READ_DDR
-
LEARN_SDR
-
LEARN_DDR
-
DATSZ_SDR
-
DATSZ_DDR
-
DUMMY_SDR
-
DUMMY_DDR
-
DUMMY_RWDS_SDR
-
DUMMY_RWDS_DDR
-
JMP_ON_CS
-
FLEXSPI_STOP
-
FLEXSPI_1PAD
-
FLEXSPI_2PAD
-
FLEXSPI_4PAD
-
FLEXSPI_8PAD
-
NOR_CMD_LUT_SEQ_IDX_READ
NOR LUT sequence index used for default LUT assignment NOTE: The will take effect if the lut sequences are not customized.
READ LUT sequence id in lookupTable stored in config block
-
NOR_CMD_LUT_SEQ_IDX_READSTATUS
Read Status LUT sequence id in lookupTable stored in config block
-
NOR_CMD_LUT_SEQ_IDX_READSTATUS_XPI
Read status DPI/QPI/OPI sequence id in lookupTable stored in config block
-
NOR_CMD_LUT_SEQ_IDX_WRITEENABLE
Write Enable sequence id in lookupTable stored in config block
-
NOR_CMD_LUT_SEQ_IDX_WRITEENABLE_XPI
Write Enable DPI/QPI/OPI sequence id in lookupTable stored in config block
-
NOR_CMD_LUT_SEQ_IDX_ERASESECTOR
Erase Sector sequence id in lookupTable stored in config block
-
NOR_CMD_LUT_SEQ_IDX_READID
-
NOR_CMD_LUT_SEQ_IDX_ERASEBLOCK
Erase Block sequence id in lookupTable stored in config block
-
NOR_CMD_LUT_SEQ_IDX_PAGEPROGRAM
Program sequence id in lookupTable stored in config block
-
NOR_CMD_LUT_SEQ_IDX_CHIPERASE
Chip Erase sequence in lookupTable id stored in config block
-
NOR_CMD_LUT_SEQ_IDX_READ_SFDP
Read SFDP sequence in lookupTable id stored in config block
-
NOR_CMD_LUT_SEQ_IDX_RESTORE_NOCMD
Restore 0-4-4/0-8-8 mode sequence id in lookupTable stored in config block
-
NOR_CMD_LUT_SEQ_IDX_EXIT_NOCMD
Exit 0-4-4/0-8-8 mode sequence id in lookupTable stored in config blobk
-
struct _serial_nor_config_option
- #include <fsl_flexspi_nor_flash.h>
Serial NOR configuration option.
-
union flash_run_context_t
- #include <fsl_flexspi_nor_flash.h>
-
struct _lut_sequence
- #include <fsl_flexspi_nor_flash.h>
FLEXSPI LUT Sequence structure.
Public Members
-
uint8_t seqNum
Sequence Number, valid number: 1-16
-
uint8_t seqId
Sequence Index, valid number: 0-15
-
uint8_t seqNum
-
struct flexspi_dll_time_t
- #include <fsl_flexspi_nor_flash.h>
Public Members
-
uint8_t time_100ps
Data valid time, in terms of 100ps
-
uint8_t delay_cells
Data valid time, in terms of delay cells
-
uint8_t time_100ps
-
struct _FlexSPIConfig
- #include <fsl_flexspi_nor_flash.h>
FLEXSPI Memory Configuration Block.
Public Members
-
uint32_t tag
[0x000-0x003] Tag, fixed value 0x42464346UL
-
uint32_t version
[0x004-0x007] Version,[31:24] -‘V’, [23:16] - Major, [15:8] - Minor, [7:0] - bugfix
-
uint32_t reserved0
[0x008-0x00b] Reserved for future use
-
uint8_t readSampleClkSrc
[0x00c-0x00c] Read Sample Clock Source, valid value: 0/1/3
-
uint8_t csHoldTime
[0x00d-0x00d] CS hold time, default value: 3
-
uint8_t csSetupTime
[0x00e-0x00e] CS setup time, default value: 3
-
uint8_t columnAddressWidth
[0x00f-0x00f] Column Address with, for HyperBus protocol, it is fixed to 3, For Serial NAND, need to refer to datasheet
-
uint8_t deviceModeCfgEnable
[0x010-0x010] Device Mode Configure enable flag, 1 - Enable, 0 - Disable
-
uint8_t deviceModeType
[0x011-0x011] Specify the configuration command type:Quad Enable, DPI/QPI/OPI switch, Generic configuration, etc.
-
uint16_t waitTimeCfgCommands
[0x012-0x013] Wait time for all configuration commands, unit: 100us, Used for DPI/QPI/OPI switch or reset command
-
flexspi_lut_seq_t deviceModeSeq
[0x014-0x017] Device mode sequence info, [7:0] - LUT sequence id, [15:8] - LUt sequence number, [31:16] Reserved
-
uint32_t deviceModeArg
[0x018-0x01b] Argument/Parameter for device configuration
-
uint8_t configCmdEnable
[0x01c-0x01c] Configure command Enable Flag, 1 - Enable, 0 - Disable
-
uint8_t configModeType[3]
[0x01d-0x01f] Configure Mode Type, similar as deviceModeTpe
-
flexspi_lut_seq_t configCmdSeqs[3]
[0x020-0x02b] Sequence info for Device Configuration command, similar as deviceModeSeq
-
uint32_t reserved1
[0x02c-0x02f] Reserved for future use
-
uint32_t configCmdArgs[3]
[0x030-0x03b] Arguments/Parameters for device Configuration commands
-
uint32_t reserved2
[0x03c-0x03f] Reserved for future use
-
uint32_t controllerMiscOption
[0x040-0x043] Controller Misc Options, see Misc feature bit definitions for more details
-
uint8_t deviceType
[0x044-0x044] Device Type: See Flash Type Definition for more details
-
uint8_t sflashPadType
[0x045-0x045] Serial Flash Pad Type: 1 - Single, 2 - Dual, 4 - Quad, 8 - Octal
-
uint8_t serialClkFreq
[0x046-0x046] Serial Flash Frequencey, device specific definitions, See System Boot Chapter for more details
-
uint8_t lutCustomSeqEnable
[0x047-0x047] LUT customization Enable, it is required if the program/erase cannot be done using 1 LUT sequence, currently, only applicable to HyperFLASH
-
uint32_t reserved3[2]
[0x048-0x04f] Reserved for future use
-
uint32_t sflashA1Size
[0x050-0x053] Size of Flash connected to A1
-
uint32_t sflashA2Size
[0x054-0x057] Size of Flash connected to A2
-
uint32_t sflashB1Size
[0x058-0x05b] Size of Flash connected to B1
-
uint32_t sflashB2Size
[0x05c-0x05f] Size of Flash connected to B2
-
uint32_t csPadSettingOverride
[0x060-0x063] CS pad setting override value
-
uint32_t sclkPadSettingOverride
[0x064-0x067] SCK pad setting override value
-
uint32_t dataPadSettingOverride
[0x068-0x06b] data pad setting override value
-
uint32_t dqsPadSettingOverride
[0x06c-0x06f] DQS pad setting override value
-
uint32_t timeoutInMs
[0x070-0x073] Timeout threshold for read status command
-
uint32_t commandInterval
[0x074-0x077] CS deselect interval between two commands
-
flexspi_dll_time_t dataValidTime[2]
[0x078-0x07b] CLK edge to data valid time for PORT A and PORT B
-
uint16_t busyOffset
[0x07c-0x07d] Busy offset, valid value: 0-31
-
uint16_t busyBitPolarity
[0x07e-0x07f] Busy flag polarity, 0 - busy flag is 1 when flash device is busy, 1 - busy flag is 0 when flash device is busy
-
uint32_t lookupTable[64]
[0x080-0x17f] Lookup table holds Flash command sequences
-
flexspi_lut_seq_t lutCustomSeq[12]
[0x180-0x1af] Customizable LUT Sequences
-
uint32_t dll1CrVal
[0x1b0-0x1b3] Customizable DLL0CR setting */
-
uint32_t reserved4[2]
[0x1b4-0x1b7] Customizable DLL1CR setting */
[0x1b8-0x1bf] Reserved for future use
-
uint32_t tag
-
struct _flexspi_nor_config
- #include <fsl_flexspi_nor_flash.h>
Serial NOR configuration block.
Public Members
-
flexspi_mem_config_t memConfig
Common memory configuration info via FLEXSPI
-
uint32_t pageSize
Page size of Serial NOR
-
uint32_t sectorSize
Sector size of Serial NOR
-
uint8_t ipcmdSerialClkFreq
Clock frequency for IP command
-
uint8_t isUniformBlockSize
Sector/Block size is the same
-
uint8_t isDataOrderSwapped
Data order (D0, D1, D2, D3) is swapped (D1,D0, D3, D2)
-
uint8_t reserved0[1]
Reserved for future use
-
uint8_t serialNorType
Serial NOR Flash type: 0/1/2/3
-
uint8_t needExitNoCmdMode
Need to exit NoCmd mode before other IP command
-
uint8_t halfClkForNonReadCmd
Half the Serial Clock for non-read command: true/false
-
uint8_t needRestoreNoCmdMode
Need to Restore NoCmd mode after IP commmand execution
-
uint32_t blockSize
Block size
-
uint32_t flashStateCtx
Flash State Context
-
uint32_t reserve2[10]
Reserved for future use
-
flexspi_mem_config_t memConfig
-
struct _flexspi_xfer
- #include <fsl_flexspi_nor_flash.h>
FLEXSPI Transfer Context.
Public Members
-
flexspi_operation_t operation
FLEXSPI operation
-
uint32_t baseAddress
FLEXSPI operation base address
-
uint32_t seqId
Sequence Id
-
uint32_t seqNum
Sequence Number
-
bool isParallelModeEnable
Is a parallel transfer
-
uint32_t *txBuffer
Tx buffer
-
uint32_t txSize
Tx size in bytes
-
uint32_t *rxBuffer
Rx buffer
-
uint32_t rxSize
Rx size in bytes
-
flexspi_operation_t operation
-
union option0
-
struct B
Public Members
-
uint32_t max_freq
Maximum supported Frequency
-
uint32_t misc_mode
miscellaneous mode
-
uint32_t quad_mode_setting
Quad mode setting
-
uint32_t cmd_pads
Command pads
-
uint32_t query_pads
SFDP read pads
-
uint32_t device_type
Device type
-
uint32_t option_size
Option size, in terms of uint32_t, size = (option_size + 1) * 4
-
uint32_t tag
Tag, must be 0x0E
-
uint32_t max_freq
-
union option1
-
struct B
Public Members
-
uint32_t dummy_cycles
Dummy cycles before read
-
uint32_t status_override
Override status register value during device mode configuration
-
uint32_t pinmux_group
The pinmux group selection
-
uint32_t dqs_pinmux_group
The DQS Pinmux Group Selection
-
uint32_t drive_strength
The Drive Strength of FLEXSPI Pads
-
uint32_t flash_connection
Flash connection option: 0 - Single Flash connected to port A, 1 - Parallel mode, 2 - Single Flash connected to Port B
-
uint32_t dummy_cycles
-
struct B
FREQME: Frequency Measurement
GINT: Group GPIO Input Interrupt Driver
-
FSL_GINT_DRIVER_VERSION
Driver version.
-
enum _gint_comb
GINT combine inputs type.
Values:
-
enumerator kGINT_CombineOr
A grouped interrupt is generated when any one of the enabled inputs is active
-
enumerator kGINT_CombineAnd
A grouped interrupt is generated when all enabled inputs are active
-
enumerator kGINT_CombineOr
-
enum _gint_trig
GINT trigger type.
Values:
-
enumerator kGINT_TrigEdge
Edge triggered based on polarity
-
enumerator kGINT_TrigLevel
Level triggered based on polarity
-
enumerator kGINT_TrigEdge
-
enum _gint_port
Values:
-
enumerator kGINT_Port0
-
enumerator kGINT_Port0
-
typedef enum _gint_comb gint_comb_t
GINT combine inputs type.
-
typedef enum _gint_trig gint_trig_t
GINT trigger type.
-
typedef enum _gint_port gint_port_t
-
typedef void (*gint_cb_t)(void)
GINT Callback function.
-
void GINT_Init(GINT_Type *base)
Initialize GINT peripheral.
This function initializes the GINT peripheral and enables the clock.
- Parameters:
base – Base address of the GINT peripheral.
- Return values:
None. –
-
void GINT_SetCtrl(GINT_Type *base, gint_comb_t comb, gint_trig_t trig, gint_cb_t callback)
Setup GINT peripheral control parameters.
This function sets the control parameters of GINT peripheral.
- Parameters:
base – Base address of the GINT peripheral.
comb – Controls if the enabled inputs are logically ORed or ANDed for interrupt generation.
trig – Controls if the enabled inputs are level or edge sensitive based on polarity.
callback – This function is called when configured group interrupt is generated.
- Return values:
None. –
-
void GINT_GetCtrl(GINT_Type *base, gint_comb_t *comb, gint_trig_t *trig, gint_cb_t *callback)
Get GINT peripheral control parameters.
This function returns the control parameters of GINT peripheral.
- Parameters:
base – Base address of the GINT peripheral.
comb – Pointer to store combine input value.
trig – Pointer to store trigger value.
callback – Pointer to store callback function.
- Return values:
None. –
-
void GINT_ConfigPins(GINT_Type *base, gint_port_t port, uint32_t polarityMask, uint32_t enableMask)
Configure GINT peripheral pins.
This function enables and controls the polarity of enabled pin(s) of a given port.
- Parameters:
base – Base address of the GINT peripheral.
port – Port number.
polarityMask – Each bit position selects the polarity of the corresponding enabled pin. 0 = The pin is active LOW. 1 = The pin is active HIGH.
enableMask – Each bit position selects if the corresponding pin is enabled or not. 0 = The pin is disabled. 1 = The pin is enabled.
- Return values:
None. –
-
void GINT_GetConfigPins(GINT_Type *base, gint_port_t port, uint32_t *polarityMask, uint32_t *enableMask)
Get GINT peripheral pin configuration.
This function returns the pin configuration of a given port.
- Parameters:
base – Base address of the GINT peripheral.
port – Port number.
polarityMask – Pointer to store the polarity mask Each bit position indicates the polarity of the corresponding enabled pin. 0 = The pin is active LOW. 1 = The pin is active HIGH.
enableMask – Pointer to store the enable mask. Each bit position indicates if the corresponding pin is enabled or not. 0 = The pin is disabled. 1 = The pin is enabled.
- Return values:
None. –
-
void GINT_EnableCallback(GINT_Type *base)
Enable callback.
This function enables the interrupt for the selected GINT peripheral. Although the pin(s) are monitored as soon as they are enabled, the callback function is not enabled until this function is called.
- Parameters:
base – Base address of the GINT peripheral.
- Return values:
None. –
-
void GINT_DisableCallback(GINT_Type *base)
Disable callback.
This function disables the interrupt for the selected GINT peripheral. Although the pins are still being monitored but the callback function is not called.
- Parameters:
base – Base address of the peripheral.
- Return values:
None. –
-
static inline void GINT_ClrStatus(GINT_Type *base)
Clear GINT status.
This function clears the GINT status bit.
- Parameters:
base – Base address of the GINT peripheral.
- Return values:
None. –
-
static inline uint32_t GINT_GetStatus(GINT_Type *base)
Get GINT status.
This function returns the GINT status.
- Parameters:
base – Base address of the GINT peripheral.
- Return values:
status – = 0 No group interrupt request. = 1 Group interrupt request active.
-
void GINT_Deinit(GINT_Type *base)
Deinitialize GINT peripheral.
This function disables the GINT clock.
- Parameters:
base – Base address of the GINT peripheral.
- Return values:
None. –
Hashcrypt: The Cryptographic Accelerator
Hashcrypt Background HASH
-
void HASHCRYPT_SHA_SetCallback(HASHCRYPT_Type *base, hashcrypt_hash_ctx_t *ctx, hashcrypt_callback_t callback, void *userData)
Initializes the HASHCRYPT handle for background hashing.
This function initializes the hash context for background hashing (Non-blocking) APIs. This is less typical interface to hash function, but can be used for parallel processing, when main CPU has something else to do. Example is digital signature RSASSA-PKCS1-V1_5-VERIFY((n,e),M,S) algorithm, where background hashing of M can be started, then CPU can compute S^e mod n (in parallel with background hashing) and once the digest becomes available, CPU can proceed to comparison of EM with EM’.
- Parameters:
base – HASHCRYPT peripheral base address.
ctx – [out] Hash context.
callback – Callback function.
userData – User data (to be passed as an argument to callback function, once callback is invoked from isr).
-
status_t HASHCRYPT_SHA_UpdateNonBlocking(HASHCRYPT_Type *base, hashcrypt_hash_ctx_t *ctx, const uint8_t *input, size_t inputSize)
Create running hash on given data.
Configures the HASHCRYPT to compute new running hash as AHB master and returns immediately. HASHCRYPT AHB Master mode supports only aligned
input
address and can be called only once per continuous block of data. Every call to this function must be preceded with HASHCRYPT_SHA_Init() and finished with HASHCRYPT_SHA_Finish(). Once callback function is invoked by HASHCRYPT isr, it should set a flag for the main application to finalize the hashing (padding) and to read out the final digest by calling HASHCRYPT_SHA_Finish().- Parameters:
base – HASHCRYPT peripheral base address
ctx – Specifies callback. Last incomplete 512-bit block of the input is copied into clear buffer for padding.
input – 32-bit word aligned pointer to Input data.
inputSize – Size of input data in bytes (must be word aligned)
- Returns:
Status of the hash update operation.
Hashcrypt common functions
-
FSL_HASHCRYPT_DRIVER_VERSION
HASHCRYPT driver version. Version 2.2.16.
Current version: 2.2.16
Change log:
Version 2.0.0
Initial version
Version 2.0.1
Support loading AES key from unaligned address
Version 2.0.2
Support loading AES key from unaligned address for different compiler and core variants
Version 2.0.3
Remove SHA512 and AES ICB algorithm definitions
Version 2.0.4
Add SHA context switch support
Version 2.1.0
Update the register name and macro to align with new header.
Version 2.1.1
Fix MISRA C-2012.
Version 2.1.2
Support loading AES input data from unaligned address.
Version 2.1.3
Fix MISRA C-2012.
Version 2.1.4
Fix context switch cannot work when switching from AES.
Version 2.1.5
Add data synchronization barrier inside hashcrypt_sha_ldm_stm_16_words() to prevent possible optimization issue.
Version 2.2.0
Add AES-OFB and AES-CFB mixed IP/SW modes.
Version 2.2.1
Add data synchronization barrier inside hashcrypt_sha_ldm_stm_16_words() prevent compiler from reordering memory write when -O2 or higher is used.
Version 2.2.2
Add data synchronization barrier inside hashcrypt_sha_ldm_stm_16_words() to fix optimization issue
Version 2.2.3
Added check for size in hashcrypt_aes_one_block to prevent overflowing COUNT field in MEMCTRL register, if its bigger than COUNT field do a multiple runs.
Version 2.2.4
In all HASHCRYPT_AES_xx functions have been added setting CTRL_MODE bitfield to 0 after processing data, which decreases power consumption.
Version 2.2.5
Add data synchronization barrier and instruction synchronization barrier inside hashcrypt_sha_process_message_data() to fix optimization issue
Version 2.2.6
Add data synchronization barrier inside HASHCRYPT_SHA_Update() and hashcrypt_get_data() function to fix optimization issue on MDK and ARMGCC release targets
Version 2.2.7
Add data synchronization barrier inside HASHCRYPT_SHA_Update() to fix optimization issue on MCUX IDE release target
Version 2.2.8
Unify hashcrypt hashing behavior between aligned and unaligned input data
Version 2.2.9
Add handling of set ERROR bit in the STATUS register
Version 2.2.10
Fix missing error statement in hashcrypt_save_running_hash()
Version 2.2.11
Fix incorrect SHA-256 calculation for long messages with reload
Version 2.2.12
Fix hardfault issue on the Keil compiler due to unaligned memcpy() input on some optimization levels
Version 2.2.13
Added function hashcrypt_seed_prng() which loading random number into PRNG_SEED register before AES operation for SCA protection
Version 2.2.14
Modify function hashcrypt_get_data() to prevent issue with unaligned access
Version 2.2.15
Add wait on DIGEST BIT inside hashcrypt_sha_one_block() to fix issues with some optimization flags
Version 2.2.16
Add DSB instruction inside hashcrypt_sha_ldm_stm_16_words() to fix issues with some optimization flags
-
enum _hashcrypt_algo_t
Algorithm used for Hashcrypt operation.
Values:
-
enumerator kHASHCRYPT_Sha1
SHA_1
-
enumerator kHASHCRYPT_Sha256
SHA_256
-
enumerator kHASHCRYPT_Aes
AES
-
enumerator kHASHCRYPT_Sha1
-
typedef enum _hashcrypt_algo_t hashcrypt_algo_t
Algorithm used for Hashcrypt operation.
-
void HASHCRYPT_Init(HASHCRYPT_Type *base)
Enables clock and disables reset for HASHCRYPT peripheral.
Enable clock and disable reset for HASHCRYPT.
- Parameters:
base – HASHCRYPT base address
-
void HASHCRYPT_Deinit(HASHCRYPT_Type *base)
Disables clock for HASHCRYPT peripheral.
Disable clock and enable reset.
- Parameters:
base – HASHCRYPT base address
-
HASHCRYPT_MODE_SHA1
Algorithm definitions correspond with the values for Mode field in Control register !
-
HASHCRYPT_MODE_SHA256
-
HASHCRYPT_MODE_AES
Hashcrypt AES
-
enum _hashcrypt_aes_mode_t
AES mode.
Values:
-
enumerator kHASHCRYPT_AesEcb
AES ECB mode
-
enumerator kHASHCRYPT_AesCbc
AES CBC mode
-
enumerator kHASHCRYPT_AesCtr
AES CTR mode
-
enumerator kHASHCRYPT_AesEcb
-
enum _hashcrypt_aes_keysize_t
Size of AES key.
Values:
-
enumerator kHASHCRYPT_Aes128
AES 128 bit key
-
enumerator kHASHCRYPT_Aes192
AES 192 bit key
-
enumerator kHASHCRYPT_Aes256
AES 256 bit key
-
enumerator kHASHCRYPT_InvalidKey
AES invalid key
-
enumerator kHASHCRYPT_Aes128
-
enum _hashcrypt_key
HASHCRYPT key source selection.
Values:
-
enumerator kHASHCRYPT_UserKey
HASHCRYPT user key
-
enumerator kHASHCRYPT_SecretKey
HASHCRYPT secret key (dedicated hw bus from PUF)
-
enumerator kHASHCRYPT_UserKey
-
typedef enum _hashcrypt_aes_mode_t hashcrypt_aes_mode_t
AES mode.
-
typedef enum _hashcrypt_aes_keysize_t hashcrypt_aes_keysize_t
Size of AES key.
-
typedef enum _hashcrypt_key hashcrypt_key_t
HASHCRYPT key source selection.
-
typedef struct _hashcrypt_handle hashcrypt_handle_t
- struct _hashcrypt_handle __attribute__ ((aligned))
-
status_t HASHCRYPT_AES_SetKey(HASHCRYPT_Type *base, hashcrypt_handle_t *handle, const uint8_t *key, size_t keySize)
Set AES key to hashcrypt_handle_t struct and optionally to HASHCRYPT.
Sets the AES key for encryption/decryption with the hashcrypt_handle_t structure. The hashcrypt_handle_t input argument specifies key source.
- Parameters:
base – HASHCRYPT peripheral base address.
handle – Handle used for the request.
key – 0-mod-4 aligned pointer to AES key.
keySize – AES key size in bytes. Shall equal 16, 24 or 32.
- Returns:
status from set key operation
-
status_t HASHCRYPT_AES_EncryptEcb(HASHCRYPT_Type *base, hashcrypt_handle_t *handle, const uint8_t *plaintext, uint8_t *ciphertext, size_t size)
Encrypts AES on one or multiple 128-bit block(s).
Encrypts AES. The source plaintext and destination ciphertext can overlap in system memory.
- Parameters:
base – HASHCRYPT peripheral base address
handle – Handle used for this request.
plaintext – Input plain text to encrypt
ciphertext – [out] Output cipher text
size – Size of input and output data in bytes. Must be multiple of 16 bytes.
- Returns:
Status from encrypt operation
-
status_t HASHCRYPT_AES_DecryptEcb(HASHCRYPT_Type *base, hashcrypt_handle_t *handle, const uint8_t *ciphertext, uint8_t *plaintext, size_t size)
Decrypts AES on one or multiple 128-bit block(s).
Decrypts AES. The source ciphertext and destination plaintext can overlap in system memory.
- Parameters:
base – HASHCRYPT peripheral base address
handle – Handle used for this request.
ciphertext – Input plain text to encrypt
plaintext – [out] Output cipher text
size – Size of input and output data in bytes. Must be multiple of 16 bytes.
- Returns:
Status from decrypt operation
-
status_t HASHCRYPT_AES_EncryptCbc(HASHCRYPT_Type *base, hashcrypt_handle_t *handle, const uint8_t *plaintext, uint8_t *ciphertext, size_t size, const uint8_t iv[16])
Encrypts AES using CBC block mode.
- Parameters:
base – HASHCRYPT peripheral base address
handle – Handle used for this request.
plaintext – Input plain text to encrypt
ciphertext – [out] Output cipher text
size – Size of input and output data in bytes. Must be multiple of 16 bytes.
iv – Input initial vector to combine with the first input block.
- Returns:
Status from encrypt operation
-
status_t HASHCRYPT_AES_DecryptCbc(HASHCRYPT_Type *base, hashcrypt_handle_t *handle, const uint8_t *ciphertext, uint8_t *plaintext, size_t size, const uint8_t iv[16])
Decrypts AES using CBC block mode.
- Parameters:
base – HASHCRYPT peripheral base address
handle – Handle used for this request.
ciphertext – Input cipher text to decrypt
plaintext – [out] Output plain text
size – Size of input and output data in bytes. Must be multiple of 16 bytes.
iv – Input initial vector to combine with the first input block.
- Returns:
Status from decrypt operation
-
status_t HASHCRYPT_AES_CryptCtr(HASHCRYPT_Type *base, hashcrypt_handle_t *handle, const uint8_t *input, uint8_t *output, size_t size, uint8_t counter[16U], uint8_t counterlast[16U], size_t *szLeft)
Encrypts or decrypts AES using CTR block mode.
Encrypts or decrypts AES using CTR block mode. AES CTR mode uses only forward AES cipher and same algorithm for encryption and decryption. The only difference between encryption and decryption is that, for encryption, the input argument is plain text and the output argument is cipher text. For decryption, the input argument is cipher text and the output argument is plain text.
- Parameters:
base – HASHCRYPT peripheral base address
handle – Handle used for this request.
input – Input data for CTR block mode
output – [out] Output data for CTR block mode
size – Size of input and output data in bytes
counter – [inout] Input counter (updates on return)
counterlast – [out] Output cipher of last counter, for chained CTR calls (statefull encryption). NULL can be passed if chained calls are not used.
szLeft – [out] Output number of bytes in left unused in counterlast block. NULL can be passed if chained calls are not used.
- Returns:
Status from encrypt operation
-
status_t HASHCRYPT_AES_CryptOfb(HASHCRYPT_Type *base, hashcrypt_handle_t *handle, const uint8_t *input, uint8_t *output, size_t size, const uint8_t iv[16U])
Encrypts or decrypts AES using OFB block mode.
Encrypts or decrypts AES using OFB block mode. AES OFB mode uses only forward AES cipher and same algorithm for encryption and decryption. The only difference between encryption and decryption is that, for encryption, the input argument is plain text and the output argument is cipher text. For decryption, the input argument is cipher text and the output argument is plain text.
- Parameters:
base – HASHCRYPT peripheral base address
handle – Handle used for this request.
input – Input data for OFB block mode
output – [out] Output data for OFB block mode
size – Size of input and output data in bytes
iv – Input initial vector to combine with the first input block.
- Returns:
Status from encrypt operation
-
status_t HASHCRYPT_AES_EncryptCfb(HASHCRYPT_Type *base, hashcrypt_handle_t *handle, const uint8_t *plaintext, uint8_t *ciphertext, size_t size, const uint8_t iv[16])
Encrypts AES using CFB block mode.
- Parameters:
base – HASHCRYPT peripheral base address
handle – Handle used for this request.
plaintext – Input plain text to encrypt
ciphertext – [out] Output cipher text
size – Size of input and output data in bytes. Must be multiple of 16 bytes.
iv – Input initial vector to combine with the first input block.
- Returns:
Status from encrypt operation
-
status_t HASHCRYPT_AES_DecryptCfb(HASHCRYPT_Type *base, hashcrypt_handle_t *handle, const uint8_t *ciphertext, uint8_t *plaintext, size_t size, const uint8_t iv[16])
Decrypts AES using CFB block mode.
- Parameters:
base – HASHCRYPT peripheral base address
handle – Handle used for this request.
ciphertext – Input cipher text to decrypt
plaintext – [out] Output plaintext text
size – Size of input and output data in bytes. Must be multiple of 16 bytes.
iv – Input initial vector to combine with the first input block.
- Returns:
Status from encrypt operation
-
HASHCRYPT_AES_BLOCK_SIZE
AES block size in bytes
-
AES_ENCRYPT
-
AES_DECRYPT
-
struct _hashcrypt_handle
- #include <fsl_hashcrypt.h>
Specify HASHCRYPT’s key resource.
Public Members
-
uint32_t keyWord[8]
Copy of user key (set by HASHCRYPT_AES_SetKey().
-
hashcrypt_key_t keyType
For operations with key (such as AES encryption/decryption), specify key type.
-
uint32_t keyWord[8]
Hashcrypt HASH
-
typedef struct _hashcrypt_hash_ctx_t hashcrypt_hash_ctx_t
Storage type used to save hash context.
-
typedef void (*hashcrypt_callback_t)(HASHCRYPT_Type *base, hashcrypt_hash_ctx_t *ctx, status_t status, void *userData)
HASHCRYPT background hash callback function.
-
status_t HASHCRYPT_SHA(HASHCRYPT_Type *base, hashcrypt_algo_t algo, const uint8_t *input, size_t inputSize, uint8_t *output, size_t *outputSize)
Create HASH on given data.
Perform the full SHA in one function call. The function is blocking.
- Parameters:
base – HASHCRYPT peripheral base address
algo – Underlaying algorithm to use for hash computation.
input – Input data
inputSize – Size of input data in bytes
output – [out] Output hash data
outputSize – [out] Output parameter storing the size of the output hash in bytes
- Returns:
Status of the one call hash operation.
-
status_t HASHCRYPT_SHA_Init(HASHCRYPT_Type *base, hashcrypt_hash_ctx_t *ctx, hashcrypt_algo_t algo)
Initialize HASH context.
This function initializes the HASH.
- Parameters:
base – HASHCRYPT peripheral base address
ctx – [out] Output hash context
algo – Underlaying algorithm to use for hash computation.
- Returns:
Status of initialization
-
status_t HASHCRYPT_SHA_Update(HASHCRYPT_Type *base, hashcrypt_hash_ctx_t *ctx, const uint8_t *input, size_t inputSize)
Add data to current HASH.
Add data to current HASH. This can be called repeatedly with an arbitrary amount of data to be hashed. The functions blocks. If it returns kStatus_Success, the running hash has been updated (HASHCRYPT has processed the input data), so the memory at
input
pointer can be released back to system. The HASHCRYPT context buffer is updated with the running hash and with all necessary information to support possible context switch.- Parameters:
base – HASHCRYPT peripheral base address
ctx – [inout] HASH context
input – Input data
inputSize – Size of input data in bytes
- Returns:
Status of the hash update operation
-
status_t HASHCRYPT_SHA_Finish(HASHCRYPT_Type *base, hashcrypt_hash_ctx_t *ctx, uint8_t *output, size_t *outputSize)
Finalize hashing.
Outputs the final hash (computed by HASHCRYPT_HASH_Update()) and erases the context.
- Parameters:
base – HASHCRYPT peripheral base address
ctx – [inout] Input hash context
output – [out] Output hash data
outputSize – [inout] Optional parameter (can be passed as NULL). On function entry, it specifies the size of output[] buffer. On function return, it stores the number of updated output bytes.
- Returns:
Status of the hash finish operation
-
HASHCRYPT_HASH_CTX_SIZE
HASHCRYPT HASH Context size.
-
struct _hashcrypt_hash_ctx_t
- #include <fsl_hashcrypt.h>
Storage type used to save hash context.
Public Members
-
uint32_t x[22]
storage
-
uint32_t x[22]
HSCMP: High Speed Analog Comparator Driver
-
void HSCMP_Init(HSCMP_Type *base, const hscmp_config_t *config)
Initialize the HSCMP.
This function initializes the HSCMP module. The operations included are:
Enabling the clock for HSCMP module.
Configuring the comparator.
Enabling the HSCMP module. Note: For some devices, multiple HSCMP instance share the same clock gate. In this case, to enable the clock for any instance enables all the HSCMPs. Check the chip reference manual for the clock assignment of the HSCMP.
- Parameters:
base – HSCMP peripheral base address.
config – Pointer to “hscmp_config_t” structure.
-
void HSCMP_Deinit(HSCMP_Type *base)
De-initializes the HSCMP module.
This function de-initializes the HSCMP module. The operations included are:
Disabling the HSCMP module.
Disabling the clock for HSCMP module.
This function disables the clock for the HSCMP. Note: For some devices, multiple HSCMP instance shares the same clock gate. In this case, before disabling the clock for the HSCMP, ensure that all the HSCMP instances are not used.
- Parameters:
base – HSCMP peripheral base address.
-
void HSCMP_GetDefaultConfig(hscmp_config_t *config)
Gets an available pre-defined settings for the comparator’s configuration.
This function initializes the comparator configuration structure to these default values:
config->enableStopMode = false; config->enableOutputPin = false; config->useUnfilteredOutput = false; config->enableInvertOutput = false; config->hysteresisMode = kHSCMP_HysteresisLevel0; config->powerMode = kHSCMP_LowSpeedPowerMode;
- Parameters:
config – Pointer to “hscmp_config_t” structure.
-
static inline void HSCMP_Enable(HSCMP_Type *base, bool enable)
Enable/Disable HSCMP module.
- Parameters:
base – HSCMP peripheral base address.
enable – “true” means enable the module, and “false” means disable the module.
-
void HSCMP_SetInputChannels(HSCMP_Type *base, uint32_t positiveChannel, uint32_t negativeChannel)
Select the input channels for HSCMP. This function determines which input is selected for the negative and positive mux.
- Parameters:
base – HSCMP peripheral base address.
positiveChannel – Positive side input channel number. Available range is 0-7.
negativeChannel – Negative side input channel number. Available range is 0-7.
-
static inline void HSCMP_EnableDMA(HSCMP_Type *base, bool enable)
Enables/disables the DMA request for rising/falling events. Normally, the HSCMP generates a CPU interrupt if there is a rising/falling event. When DMA support is enabled and the rising/falling interrupt is enabled , the rising/falling event forces a DMA transfer request rather than a CPU interrupt instead.
- Parameters:
base – HSCMP peripheral base address.
enable – “true” means enable DMA support, and “false” means disable DMA support.
-
static inline void HSCMP_EnableWindowMode(HSCMP_Type *base, bool enable)
Enable/Disable window mode.When any windowed mode is active, COUTA is clocked by the bus clock whenever WINDOW = 1. The last latched value is held when WINDOW = 0. The optionally inverted comparator output COUT_RAW is sampled on every bus clock when WINDOW=1 to generate COUTA.
- Parameters:
base – HSCMP peripheral base address.
enable – “true” means enable window mode, and “false” means disable window mode.
-
void HSCMP_SetFilterConfig(HSCMP_Type *base, const hscmp_filter_config_t *config)
Configures the filter.
- Parameters:
base – HSCMP peripheral base address.
config – Pointer to “hscmp_filter_config_t” structure.
-
void HSCMP_SetDACConfig(HSCMP_Type *base, const hscmp_dac_config_t *config)
Configure the internal DAC module.
- Parameters:
base – HSCMP peripheral base address.
config – Pointer to “hscmp_dac_config_t” structure. If config is “NULL”, disable internal DAC.
-
static inline void HSCMP_EnableInterrupts(HSCMP_Type *base, uint32_t mask)
Enable the interrupts.
- Parameters:
base – HSCMP peripheral base address.
mask – Mask value for interrupts. See “_hscmp_interrupt_enable”.
-
static inline void HSCMP_DisableInterrupts(HSCMP_Type *base, uint32_t mask)
Disable the interrupts.
- Parameters:
base – HSCMP peripheral base address.
mask – Mask value for interrupts. See “_hscmp_interrupt_enable”.
-
static inline uint32_t HSCMP_GetStatusFlags(HSCMP_Type *base)
Get the HSCMP status flags.
- Parameters:
base – HSCMP peripheral base address.
- Returns:
Mask value for the asserted flags. See “_hscmp_status_flags”.
-
static inline void HSCMP_ClearStatusFlags(HSCMP_Type *base, uint32_t mask)
Clear the HSCMP status flags.
- Parameters:
base – HSCMP peripheral base address.
mask – Mask value for the flags. See “_hscmp_status_flags”.
-
FSL_HSCMP_DRIVER_VERSION
HSCMP driver version 2.0.4.
-
enum _hscmp_status_flags
HSCMP status falgs mask.
Values:
-
enumerator kHSCMP_OutputRisingEventFlag
Rising-edge on the comparison output has occurred.
-
enumerator kHSCMP_OutputFallingEventFlag
Falling-edge on the comparison output has occurred.
-
enumerator kHSCMP_OutputAssertEventFlag
Return the current value of the analog comparator output. The flag does not support W1C.
-
enumerator kHSCMP_OutputRisingEventFlag
-
enum _hscmp_interrupt_enable
HSCMP interrupt enable/disable mask.
Values:
-
enumerator kHSCMP_OutputRisingInterruptEnable
Comparator interrupt enable rising.
-
enumerator kHSCMP_OutputFallingInterruptEnable
Comparator interrupt enable falling.
-
enumerator kHSCMP_OutputRisingInterruptEnable
-
enum _hscmp_hysteresis_mode
HSCMP hysteresis mode. See chip data sheet to get the actual hystersis value with each level.
Values:
-
enumerator kHSCMP_HysteresisLevel0
The hard block output has level 0 hysteresis internally.
-
enumerator kHSCMP_HysteresisLevel1
The hard block output has level 1 hysteresis internally.
-
enumerator kHSCMP_HysteresisLevel2
The hard block output has level 2 hysteresis internally.
-
enumerator kHSCMP_HysteresisLevel3
The hard block output has level 3 hysteresis internally.
-
enumerator kHSCMP_HysteresisLevel0
-
enum _hscmp_power_mode
HSCMP nano mode.
Values:
-
enumerator kHSCMP_LowSpeedPowerMode
Low speed comparison mode is selected.
-
enumerator kHSCMP_HighSpeedPowerMode
High speed comparison mode is selected.
-
enumerator kHSCMP_NanoPowerMode
Nano power comparator is enabled.
-
enumerator kHSCMP_LowSpeedPowerMode
-
enum _hscmp_dac_reference_voltage_source
Internal DAC reference voltage source.
Values:
-
enumerator kHSCMP_VrefSourceVin1
vrefh_int is selected as resistor ladder network supply reference Vin.
-
enumerator kHSCMP_VrefSourceVin2
vrefh_ext is selected as resistor ladder network supply reference Vin.
-
enumerator kHSCMP_VrefSourceVin1
-
typedef enum _hscmp_hysteresis_mode hscmp_hysteresis_mode_t
HSCMP hysteresis mode. See chip data sheet to get the actual hystersis value with each level.
-
typedef enum _hscmp_power_mode hscmp_power_mode_t
HSCMP nano mode.
-
typedef enum _hscmp_dac_reference_voltage_source hscmp_dac_reference_voltage_source_t
Internal DAC reference voltage source.
-
typedef struct _hscmp_filter_config hscmp_filter_config_t
Configure the filter.
-
typedef struct _hscmp_dac_config hscmp_dac_config_t
configure the internal DAC.
-
typedef struct _hscmp_config hscmp_config_t
Configures the comparator.
-
struct _hscmp_filter_config
- #include <fsl_hscmp.h>
Configure the filter.
Public Members
-
bool enableSample
Decide whether to use the external SAMPLE as a sampling clock input.
-
uint8_t filterSampleCount
Filter Sample Count. Available range is 1-7; 0 disables the filter.
-
uint8_t filterSamplePeriod
Filter Sample Period. The divider to the bus clock. Available range is 0-255. The sampling clock must be at least 4 times slower than the system clock to the comparator. So if enableSample is “false”, filterSamplePeriod should be set greater than 4.
-
bool enableSample
-
struct _hscmp_dac_config
- #include <fsl_hscmp.h>
configure the internal DAC.
Public Members
-
bool enableLowPowerMode
Decide whether to enable DAC low power mode.
-
hscmp_dac_reference_voltage_source_t referenceVoltageSource
Internal DAC supply voltage reference source.
-
uint8_t DACValue
Value for the DAC Output Voltage. Available range is 0-63.
-
bool enableLowPowerMode
-
struct _hscmp_config
- #include <fsl_hscmp.h>
Configures the comparator.
Public Members
-
bool enableStopMode
Decide whether to enable the comparator when in STOP modes.
-
bool enableOutputPin
Decide whether to enable the comparator is available in selected pin.
-
bool useUnfilteredOutput
Decide whether to use unfiltered output.
-
bool enableInvertOutput
Decide whether to inverts the comparator output.
-
hscmp_hysteresis_mode_t hysteresisMode
HSCMP hysteresis mode.
-
hscmp_power_mode_t powerMode
HSCMP power mode.
-
bool enableStopMode
I2C: Inter-Integrated Circuit Driver
I2C DMA Driver
-
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)
Init the I2C handle which is used in transactional functions.
- Parameters:
base – I2C peripheral base address
handle – pointer to i2c_master_dma_handle_t structure
callback – pointer to user callback function
userData – user param passed to the callback function
dmaHandle – DMA handle pointer
-
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.
- Parameters:
base – I2C peripheral base address
handle – pointer to i2c_master_dma_handle_t structure
xfer – pointer to transfer structure of i2c_master_transfer_t
- Return values:
kStatus_Success – Sucessully complete the data transmission.
kStatus_I2C_Busy – Previous transmission still not finished.
kStatus_I2C_Timeout – Transfer error, wait signal timeout.
kStatus_I2C_ArbitrationLost – Transfer error, arbitration lost.
kStataus_I2C_Nak – Transfer error, receive Nak during transfer.
-
status_t I2C_MasterTransferGetCountDMA(I2C_Type *base, i2c_master_dma_handle_t *handle, size_t *count)
Get master transfer status during a dma non-blocking transfer.
- Parameters:
base – I2C peripheral base address
handle – pointer to i2c_master_dma_handle_t structure
count – Number of bytes transferred so far by the non-blocking transaction.
-
void I2C_MasterTransferAbortDMA(I2C_Type *base, i2c_master_dma_handle_t *handle)
Abort a master dma non-blocking transfer in a early time.
- Parameters:
base – I2C peripheral base address
handle – pointer to i2c_master_dma_handle_t structure
-
FSL_I2C_DMA_DRIVER_VERSION
I2C DMA driver version.
-
typedef struct _i2c_master_dma_handle i2c_master_dma_handle_t
I2C master dma handle typedef.
-
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.
-
typedef void (*flexcomm_i2c_dma_master_irq_handler_t)(I2C_Type *base, i2c_master_dma_handle_t *handle)
Typedef for master dma handler.
-
I2C_MAX_DMA_TRANSFER_COUNT
Maximum lenght of single DMA transfer (determined by capability of the DMA engine)
-
struct _i2c_master_dma_handle
- #include <fsl_i2c_dma.h>
I2C master dma transfer structure.
Public Members
-
uint8_t state
Transfer state machine current state.
-
uint32_t transferCount
Indicates progress of the transfer
-
uint32_t remainingBytesDMA
Remaining byte count to be transferred using DMA.
-
uint8_t *buf
Buffer pointer for current state.
-
bool checkAddrNack
Whether to check the nack signal is detected during addressing.
-
dma_handle_t *dmaHandle
The DMA handler used.
-
i2c_master_transfer_t transfer
Copy of the current transfer info.
-
i2c_master_dma_transfer_callback_t completionCallback
Callback function called after dma transfer finished.
-
void *userData
Callback parameter passed to callback function.
-
uint8_t state
I2C Driver
-
FSL_I2C_DRIVER_VERSION
I2C driver version.
I2C status return codes.
Values:
-
enumerator kStatus_I2C_Busy
The master is already performing a transfer.
-
enumerator kStatus_I2C_Idle
The slave driver is idle.
-
enumerator kStatus_I2C_Nak
The slave device sent a NAK in response to a byte.
-
enumerator kStatus_I2C_InvalidParameter
Unable to proceed due to invalid parameter.
-
enumerator kStatus_I2C_BitError
Transferred bit was not seen on the bus.
-
enumerator kStatus_I2C_ArbitrationLost
Arbitration lost error.
-
enumerator kStatus_I2C_NoTransferInProgress
Attempt to abort a transfer when one is not in progress.
-
enumerator kStatus_I2C_DmaRequestFail
DMA request failed.
-
enumerator kStatus_I2C_StartStopError
Start and stop error.
-
enumerator kStatus_I2C_UnexpectedState
Unexpected state.
-
enumerator kStatus_I2C_Timeout
Timeout when waiting for I2C master/slave pending status to set to continue transfer.
-
enumerator kStatus_I2C_Addr_Nak
NAK received for Address
-
enumerator kStatus_I2C_EventTimeout
Timeout waiting for bus event.
-
enumerator kStatus_I2C_SclLowTimeout
Timeout SCL signal remains low.
-
enumerator kStatus_I2C_Busy
-
enum _i2c_status_flags
I2C status flags.
Note
These enums are meant to be OR’d together to form a bit mask.
Values:
-
enumerator kI2C_MasterPendingFlag
The I2C module is waiting for software interaction. bit 0
-
enumerator kI2C_MasterArbitrationLostFlag
The arbitration of the bus was lost. There was collision on the bus. bit 4
-
enumerator kI2C_MasterStartStopErrorFlag
There was an error during start or stop phase of the transaction. bit 6
-
enumerator kI2C_MasterIdleFlag
The I2C master idle status. bit 5
-
enumerator kI2C_MasterRxReadyFlag
The I2C master rx ready status. bit 1
-
enumerator kI2C_MasterTxReadyFlag
The I2C master tx ready status. bit 2
-
enumerator kI2C_MasterAddrNackFlag
The I2C master address nack status. bit 7
-
enumerator kI2C_MasterDataNackFlag
The I2C master data nack status. bit 3
-
enumerator kI2C_SlavePendingFlag
The I2C module is waiting for software interaction. bit 8
-
enumerator kI2C_SlaveNotStretching
Indicates whether the slave is currently stretching clock (0 = yes, 1 = no). bit 11
-
enumerator kI2C_SlaveSelected
Indicates whether the slave is selected by an address match. bit 14
-
enumerator kI2C_SaveDeselected
Indicates that slave was previously deselected (deselect event took place, w1c). bit 15
-
enumerator kI2C_SlaveAddressedFlag
One of the I2C slave’s 4 addresses is matched. bit 22
-
enumerator kI2C_SlaveReceiveFlag
Slave receive data available. bit 9
-
enumerator kI2C_SlaveTransmitFlag
Slave data can be transmitted. bit 10
-
enumerator kI2C_SlaveAddress0MatchFlag
Slave address0 match. bit 20
-
enumerator kI2C_SlaveAddress1MatchFlag
Slave address1 match. bit 12
-
enumerator kI2C_SlaveAddress2MatchFlag
Slave address2 match. bit 13
-
enumerator kI2C_SlaveAddress3MatchFlag
Slave address3 match. bit 21
-
enumerator kI2C_MonitorReadyFlag
The I2C monitor ready interrupt. bit 16
-
enumerator kI2C_MonitorOverflowFlag
The monitor data overrun interrupt. bit 17
-
enumerator kI2C_MonitorActiveFlag
The monitor is active. bit 18
-
enumerator kI2C_MonitorIdleFlag
The monitor idle interrupt. bit 19
-
enumerator kI2C_EventTimeoutFlag
The bus event timeout interrupt. bit 24
-
enumerator kI2C_SclTimeoutFlag
The SCL timeout interrupt. bit 25
-
enumerator kI2C_MasterAllClearFlags
-
enumerator kI2C_SlaveAllClearFlags
-
enumerator kI2C_CommonAllClearFlags
-
enumerator kI2C_MasterPendingFlag
-
enum _i2c_interrupt_enable
I2C interrupt enable.
Note
These enums are meant to be OR’d together to form a bit mask.
Values:
-
enumerator kI2C_MasterPendingInterruptEnable
The I2C master communication pending interrupt.
-
enumerator kI2C_MasterArbitrationLostInterruptEnable
The I2C master arbitration lost interrupt.
-
enumerator kI2C_MasterStartStopErrorInterruptEnable
The I2C master start/stop timing error interrupt.
-
enumerator kI2C_SlavePendingInterruptEnable
The I2C slave communication pending interrupt.
-
enumerator kI2C_SlaveNotStretchingInterruptEnable
The I2C slave not streching interrupt, deep-sleep mode can be entered only when this interrupt occurs.
-
enumerator kI2C_SlaveDeselectedInterruptEnable
The I2C slave deselection interrupt.
-
enumerator kI2C_MonitorReadyInterruptEnable
The I2C monitor ready interrupt.
-
enumerator kI2C_MonitorOverflowInterruptEnable
The monitor data overrun interrupt.
-
enumerator kI2C_MonitorIdleInterruptEnable
The monitor idle interrupt.
-
enumerator kI2C_EventTimeoutInterruptEnable
The bus event timeout interrupt.
-
enumerator kI2C_SclTimeoutInterruptEnable
The SCL timeout interrupt.
-
enumerator kI2C_MasterAllInterruptEnable
-
enumerator kI2C_SlaveAllInterruptEnable
-
enumerator kI2C_CommonAllInterruptEnable
-
enumerator kI2C_MasterPendingInterruptEnable
-
I2C_RETRY_TIMES
Retry times for waiting flag.
-
I2C_MASTER_TRANSMIT_IGNORE_LAST_NACK
Whether to ignore the nack signal of the last byte during master transmit.
-
I2C_STAT_MSTCODE_IDLE
Master Idle State Code
-
I2C_STAT_MSTCODE_RXREADY
Master Receive Ready State Code
-
I2C_STAT_MSTCODE_TXREADY
Master Transmit Ready State Code
-
I2C_STAT_MSTCODE_NACKADR
Master NACK by slave on address State Code
-
I2C_STAT_MSTCODE_NACKDAT
Master NACK by slave on data State Code
-
I2C_STAT_SLVST_ADDR
-
I2C_STAT_SLVST_RX
-
I2C_STAT_SLVST_TX
I2C Master Driver
-
void I2C_MasterGetDefaultConfig(i2c_master_config_t *masterConfig)
Provides a default configuration for the I2C master peripheral.
This function provides the following default configuration for the I2C master peripheral:
masterConfig->enableMaster = true; masterConfig->baudRate_Bps = 100000U; masterConfig->enableTimeout = false;
After calling this function, you can override any settings in order to customize the configuration, prior to initializing the master driver with I2C_MasterInit().
- Parameters:
masterConfig – [out] User provided configuration structure for default values. Refer to i2c_master_config_t.
-
void I2C_MasterInit(I2C_Type *base, const i2c_master_config_t *masterConfig, uint32_t srcClock_Hz)
Initializes the I2C master peripheral.
This function enables the peripheral clock and initializes the I2C master peripheral as described by the user provided configuration. A software reset is performed prior to configuration.
- Parameters:
base – The I2C peripheral base address.
masterConfig – User provided peripheral configuration. Use I2C_MasterGetDefaultConfig() to get a set of defaults that you can override.
srcClock_Hz – Frequency in Hertz of the I2C functional clock. Used to calculate the baud rate divisors, filter widths, and timeout periods.
-
void I2C_MasterDeinit(I2C_Type *base)
Deinitializes the I2C master peripheral.
This function disables the I2C master peripheral and gates the clock. It also performs a software reset to restore the peripheral to reset conditions.
- Parameters:
base – The I2C peripheral base address.
-
uint32_t I2C_GetInstance(I2C_Type *base)
Returns an instance number given a base address.
If an invalid base address is passed, debug builds will assert. Release builds will just return instance number 0.
- Parameters:
base – The I2C peripheral base address.
- Returns:
I2C instance number starting from 0.
-
static inline void I2C_MasterReset(I2C_Type *base)
Performs a software reset.
Restores the I2C master peripheral to reset conditions.
- Parameters:
base – The I2C peripheral base address.
-
static inline void I2C_MasterEnable(I2C_Type *base, bool enable)
Enables or disables the I2C module as master.
- Parameters:
base – The I2C peripheral base address.
enable – Pass true to enable or false to disable the specified I2C as master.
-
uint32_t I2C_GetStatusFlags(I2C_Type *base)
Gets the I2C status flags.
A bit mask with the state of all I2C status flags is returned. For each flag, the corresponding bit in the return value is set if the flag is asserted.
See also
_i2c_status_flags.
- Parameters:
base – The I2C peripheral base address.
- Returns:
State of the status flags:
1: related status flag is set.
0: related status flag is not set.
-
static inline void I2C_ClearStatusFlags(I2C_Type *base, uint32_t statusMask)
Clears the I2C status flag state.
Refer to kI2C_CommonAllClearStatusFlags, kI2C_MasterAllClearStatusFlags and kI2C_SlaveAllClearStatusFlags to see the clearable flags. Attempts to clear other flags has no effect.
See also
_i2c_status_flags, _i2c_master_status_flags and _i2c_slave_status_flags.
- Parameters:
base – The I2C peripheral base address.
statusMask – A bitmask of status flags that are to be cleared. The mask is composed of the members in kI2C_CommonAllClearStatusFlags, kI2C_MasterAllClearStatusFlags and kI2C_SlaveAllClearStatusFlags. You may pass the result of a previous call to I2C_GetStatusFlags().
-
static inline void I2C_MasterClearStatusFlags(I2C_Type *base, uint32_t statusMask)
Clears the I2C master status flag state.
- Deprecated:
Do not use this function. It has been superceded by I2C_ClearStatusFlags The following status register flags can be cleared:
kI2C_MasterArbitrationLostFlag
kI2C_MasterStartStopErrorFlag
Attempts to clear other flags has no effect.
See also
_i2c_status_flags.
- Parameters:
base – The I2C peripheral base address.
statusMask – A bitmask of status flags that are to be cleared. The mask is composed of _i2c_status_flags enumerators OR’d together. You may pass the result of a previous call to I2C_GetStatusFlags().
-
static inline void I2C_EnableInterrupts(I2C_Type *base, uint32_t interruptMask)
Enables the I2C interrupt requests.
- Parameters:
base – The I2C peripheral base address.
interruptMask – Bit mask of interrupts to enable. See _i2c_interrupt_enable for the set of constants that should be OR’d together to form the bit mask.
-
static inline void I2C_DisableInterrupts(I2C_Type *base, uint32_t interruptMask)
Disables the I2C interrupt requests.
- Parameters:
base – The I2C peripheral base address.
interruptMask – Bit mask of interrupts to disable. See _i2c_interrupt_enable for the set of constants that should be OR’d together to form the bit mask.
-
static inline uint32_t I2C_GetEnabledInterrupts(I2C_Type *base)
Returns the set of currently enabled I2C interrupt requests.
- Parameters:
base – The I2C peripheral base address.
- Returns:
A bitmask composed of _i2c_interrupt_enable enumerators OR’d together to indicate the set of enabled interrupts.
-
void I2C_MasterSetBaudRate(I2C_Type *base, uint32_t baudRate_Bps, uint32_t srcClock_Hz)
Sets the I2C bus frequency for master transactions.
The I2C master is automatically disabled and re-enabled as necessary to configure the baud rate. Do not call this function during a transfer, or the transfer is aborted.
- Parameters:
base – The I2C peripheral base address.
srcClock_Hz – I2C functional clock frequency in Hertz.
baudRate_Bps – Requested bus frequency in bits per second.
-
void I2C_MasterSetTimeoutValue(I2C_Type *base, uint8_t timeout_Ms, uint32_t srcClock_Hz)
Sets the I2C bus timeout value.
If the SCL signal remains low or bus does not have event longer than the timeout value, kI2C_SclTimeoutFlag or kI2C_EventTimeoutFlag is set. This can indicete the bus is held by slave or any fault occurs to the I2C module.
- Parameters:
base – The I2C peripheral base address.
timeout_Ms – Timeout value in millisecond.
srcClock_Hz – I2C functional clock frequency in Hertz.
-
static inline bool I2C_MasterGetBusIdleState(I2C_Type *base)
Returns whether the bus is idle.
Requires the master mode to be enabled.
- Parameters:
base – The I2C peripheral base address.
- Return values:
true – Bus is busy.
false – Bus is idle.
-
status_t I2C_MasterStart(I2C_Type *base, uint8_t address, i2c_direction_t direction)
Sends a START on the I2C bus.
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.
-
status_t I2C_MasterStop(I2C_Type *base)
Sends a STOP signal on the I2C bus.
- Return values:
kStatus_Success – Successfully send the stop signal.
kStatus_I2C_Timeout – Send stop signal failed, timeout.
-
static inline status_t I2C_MasterRepeatedStart(I2C_Type *base, uint8_t address, i2c_direction_t direction)
Sends a REPEATED START on the I2C bus.
- 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.
-
status_t I2C_MasterWriteBlocking(I2C_Type *base, const void *txBuff, size_t txSize, uint32_t flags)
Performs a polling send transfer on the I2C bus.
Sends up to txSize number of bytes to the previously addressed slave device. The slave may reply with a NAK to any byte in order to terminate the transfer early. If this happens, this function returns kStatus_I2C_Nak.
- Parameters:
base – The I2C peripheral base address.
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 control special behavior like suppressing start or stop, for normal transfers use kI2C_TransferDefaultFlag
- Return values:
kStatus_Success – Data was sent successfully.
kStatus_I2C_Busy – Another master is currently utilizing the bus.
kStatus_I2C_Nak – The slave device sent a NAK in response to a byte.
kStatus_I2C_ArbitrationLost – Arbitration lost error.
-
status_t I2C_MasterReadBlocking(I2C_Type *base, void *rxBuff, size_t rxSize, uint32_t flags)
Performs a polling receive transfer on the I2C bus.
- Parameters:
base – The I2C peripheral base address.
rxBuff – The pointer to the data to be transferred.
rxSize – The length in bytes of the data to be transferred.
flags – Transfer control flag to control special behavior like suppressing start or stop, for normal transfers use kI2C_TransferDefaultFlag
- Return values:
kStatus_Success – Data was received successfully.
kStatus_I2C_Busy – Another master is currently utilizing the bus.
kStatus_I2C_Nak – The slave device sent a NAK in response to a byte.
kStatus_I2C_ArbitrationLost – Arbitration lost error.
-
status_t I2C_MasterTransferBlocking(I2C_Type *base, i2c_master_transfer_t *xfer)
Performs a master polling transfer on the I2C bus.
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.
kStatus_I2C_Busy – Previous transmission still not finished.
kStatus_I2C_Timeout – Transfer error, wait signal timeout.
kStatus_I2C_ArbitrationLost – Transfer error, arbitration lost.
kStataus_I2C_Nak – Transfer error, receive NAK during transfer.
kStataus_I2C_Addr_Nak – Transfer error, receive NAK during addressing.
-
void I2C_MasterTransferCreateHandle(I2C_Type *base, i2c_master_handle_t *handle, i2c_master_transfer_callback_t callback, void *userData)
Creates a new handle for the I2C master non-blocking APIs.
The creation of a handle is for use with the non-blocking APIs. Once a handle is created, there is not a corresponding destroy handle. If the user wants to terminate a transfer, the I2C_MasterTransferAbort() API shall be called.
- Parameters:
base – The I2C peripheral base address.
handle – [out] Pointer to the I2C master driver handle.
callback – User provided pointer to the asynchronous callback function.
userData – User provided pointer to the application callback data.
-
status_t I2C_MasterTransferNonBlocking(I2C_Type *base, i2c_master_handle_t *handle, i2c_master_transfer_t *xfer)
Performs a non-blocking transaction on the I2C bus.
- Parameters:
base – The I2C peripheral base address.
handle – Pointer to the I2C master driver handle.
xfer – The pointer to the transfer descriptor.
- Return values:
kStatus_Success – The transaction was started successfully.
kStatus_I2C_Busy – Either another master is currently utilizing the bus, or a non-blocking transaction is already in progress.
-
status_t I2C_MasterTransferGetCount(I2C_Type *base, i2c_master_handle_t *handle, size_t *count)
Returns number of bytes transferred so far.
- Parameters:
base – The I2C peripheral base address.
handle – Pointer to the I2C master driver handle.
count – [out] Number of bytes transferred so far by the non-blocking transaction.
- Return values:
kStatus_Success –
kStatus_I2C_Busy –
-
status_t I2C_MasterTransferAbort(I2C_Type *base, i2c_master_handle_t *handle)
Terminates a non-blocking I2C master transmission early.
Note
It is not safe to call this function from an IRQ handler that has a higher priority than the I2C peripheral’s IRQ priority.
- Parameters:
base – The I2C peripheral base address.
handle – Pointer to the I2C master driver handle.
- Return values:
kStatus_Success – A transaction was successfully aborted.
kStatus_I2C_Timeout – Timeout during polling for flags.
-
void I2C_MasterTransferHandleIRQ(I2C_Type *base, i2c_master_handle_t *handle)
Reusable routine to handle master interrupts.
Note
This function does not need to be called unless you are reimplementing the nonblocking API’s interrupt handler routines to add special functionality.
- Parameters:
base – The I2C peripheral base address.
handle – Pointer to the I2C master driver handle.
-
enum _i2c_direction
Direction of master and slave transfers.
Values:
-
enumerator kI2C_Write
Master transmit.
-
enumerator kI2C_Read
Master receive.
-
enumerator kI2C_Write
-
enum _i2c_master_transfer_flags
Transfer option flags.
Note
These enumerations are intended to be OR’d together to form a bit mask of options for the _i2c_master_transfer::flags field.
Values:
-
enumerator kI2C_TransferDefaultFlag
Transfer starts with a start signal, stops with a stop signal.
-
enumerator kI2C_TransferNoStartFlag
Don’t send a start condition, address, and sub address
-
enumerator kI2C_TransferRepeatedStartFlag
Send a repeated start condition
-
enumerator kI2C_TransferNoStopFlag
Don’t send a stop condition.
-
enumerator kI2C_TransferDefaultFlag
-
enum _i2c_transfer_states
States for the state machine used by transactional APIs.
Values:
-
enumerator kIdleState
-
enumerator kTransmitSubaddrState
-
enumerator kTransmitDataState
-
enumerator kReceiveDataBeginState
-
enumerator kReceiveDataState
-
enumerator kReceiveLastDataState
-
enumerator kStartState
-
enumerator kStopState
-
enumerator kWaitForCompletionState
-
enumerator kIdleState
-
typedef enum _i2c_direction i2c_direction_t
Direction of master and slave transfers.
-
typedef struct _i2c_master_config i2c_master_config_t
Structure with settings to initialize the I2C master module.
This structure holds configuration settings for the I2C peripheral. To initialize this structure to reasonable defaults, call the I2C_MasterGetDefaultConfig() function and pass a pointer to your configuration structure instance.
The configuration structure can be made constant so it resides in flash.
-
typedef struct _i2c_master_transfer i2c_master_transfer_t
I2C master transfer typedef.
-
typedef struct _i2c_master_handle i2c_master_handle_t
I2C master handle typedef.
-
typedef void (*i2c_master_transfer_callback_t)(I2C_Type *base, i2c_master_handle_t *handle, status_t completionStatus, void *userData)
Master completion callback function pointer type.
This callback is used only for the non-blocking master transfer API. Specify the callback you wish to use in the call to I2C_MasterTransferCreateHandle().
- Param base:
The I2C peripheral base address.
- Param completionStatus:
Either kStatus_Success or an error code describing how the transfer completed.
- Param userData:
Arbitrary pointer-sized value passed from the application.
-
struct _i2c_master_config
- #include <fsl_i2c.h>
Structure with settings to initialize the I2C master module.
This structure holds configuration settings for the I2C peripheral. To initialize this structure to reasonable defaults, call the I2C_MasterGetDefaultConfig() function and pass a pointer to your configuration structure instance.
The configuration structure can be made constant so it resides in flash.
Public Members
-
bool enableMaster
Whether to enable master mode.
-
uint32_t baudRate_Bps
Desired baud rate in bits per second.
-
bool enableTimeout
Enable internal timeout function.
-
uint8_t timeout_Ms
Event timeout and SCL low timeout value.
-
bool enableMaster
-
struct _i2c_master_transfer
- #include <fsl_i2c.h>
Non-blocking transfer descriptor structure.
This structure is used to pass transaction parameters to the I2C_MasterTransferNonBlocking() API.
Public Members
-
uint32_t flags
Bit mask of options for the transfer. See enumeration _i2c_master_transfer_flags for available options. Set to 0 or kI2C_TransferDefaultFlag for normal transfers.
-
uint8_t slaveAddress
The 7-bit slave address.
-
i2c_direction_t direction
Either kI2C_Read or kI2C_Write.
-
uint32_t subaddress
Sub address. Transferred MSB first.
-
size_t subaddressSize
Length of sub address to send in bytes. Maximum size is 4 bytes.
-
void *data
Pointer to data to transfer.
-
size_t dataSize
Number of bytes to transfer.
-
uint32_t flags
-
struct _i2c_master_handle
- #include <fsl_i2c.h>
Driver handle for master non-blocking APIs.
Note
The contents of this structure are private and subject to change.
Public Members
-
uint8_t state
Transfer state machine current state.
-
uint32_t transferCount
Indicates progress of the transfer
-
uint32_t remainingBytes
Remaining byte count in current state.
-
uint8_t *buf
Buffer pointer for current state.
-
bool checkAddrNack
Whether to check the nack signal is detected during addressing.
-
i2c_master_transfer_t transfer
Copy of the current transfer info.
-
i2c_master_transfer_callback_t completionCallback
Callback function pointer.
-
void *userData
Application data passed to callback.
-
uint8_t state
I2C Slave Driver
-
void I2C_SlaveGetDefaultConfig(i2c_slave_config_t *slaveConfig)
Provides a default configuration for the I2C slave peripheral.
This function provides the following default configuration for the I2C slave peripheral:
slaveConfig->enableSlave = true; slaveConfig->address0.disable = false; slaveConfig->address0.address = 0u; slaveConfig->address1.disable = true; slaveConfig->address2.disable = true; slaveConfig->address3.disable = true; slaveConfig->busSpeed = kI2C_SlaveStandardMode;
After calling this function, override any settings to customize the configuration, prior to initializing the master driver with I2C_SlaveInit(). Be sure to override at least the address0.address member of the configuration structure with the desired slave address.
- Parameters:
slaveConfig – [out] User provided configuration structure that is set to default values. Refer to i2c_slave_config_t.
-
status_t I2C_SlaveInit(I2C_Type *base, const i2c_slave_config_t *slaveConfig, uint32_t srcClock_Hz)
Initializes the I2C slave peripheral.
This function enables the peripheral clock and initializes the I2C slave peripheral as described by the user provided configuration.
- Parameters:
base – The I2C peripheral base address.
slaveConfig – User provided peripheral configuration. Use I2C_SlaveGetDefaultConfig() to get a set of defaults that you can override.
srcClock_Hz – Frequency in Hertz of the I2C functional clock. Used to calculate CLKDIV value to provide enough data setup time for master when slave stretches the clock.
-
void I2C_SlaveSetAddress(I2C_Type *base, i2c_slave_address_register_t addressRegister, uint8_t address, bool addressDisable)
Configures Slave Address n register.
This function writes new value to Slave Address register.
- Parameters:
base – The I2C peripheral base address.
addressRegister – The module supports multiple address registers. The parameter determines which one shall be changed.
address – The slave address to be stored to the address register for matching.
addressDisable – Disable matching of the specified address register.
-
void I2C_SlaveDeinit(I2C_Type *base)
Deinitializes the I2C slave peripheral.
This function disables the I2C slave peripheral and gates the clock. It also performs a software reset to restore the peripheral to reset conditions.
- Parameters:
base – The I2C peripheral base address.
-
static inline void I2C_SlaveEnable(I2C_Type *base, bool enable)
Enables or disables the I2C module as slave.
- Parameters:
base – The I2C peripheral base address.
enable – True to enable or flase to disable.
-
static inline void I2C_SlaveClearStatusFlags(I2C_Type *base, uint32_t statusMask)
Clears the I2C status flag state.
The following status register flags can be cleared:
slave deselected flag
Attempts to clear other flags has no effect.
See also
_i2c_slave_flags.
- Parameters:
base – The I2C peripheral base address.
statusMask – A bitmask of status flags that are to be cleared. The mask is composed of _i2c_slave_flags enumerators OR’d together. You may pass the result of a previous call to I2C_SlaveGetStatusFlags().
-
status_t I2C_SlaveWriteBlocking(I2C_Type *base, const uint8_t *txBuff, size_t txSize)
Performs a polling send transfer on the I2C bus.
The function executes blocking address phase and blocking data phase.
- Parameters:
base – The I2C peripheral base address.
txBuff – The pointer to the data to be transferred.
txSize – The length in bytes of the data to be transferred.
- Returns:
kStatus_Success Data has been sent.
- Returns:
kStatus_Fail Unexpected slave state (master data write while master read from slave is expected).
-
status_t I2C_SlaveReadBlocking(I2C_Type *base, uint8_t *rxBuff, size_t rxSize)
Performs a polling receive transfer on the I2C bus.
The function executes blocking address phase and blocking data phase.
- Parameters:
base – The I2C peripheral base address.
rxBuff – The pointer to the data to be transferred.
rxSize – The length in bytes of the data to be transferred.
- Returns:
kStatus_Success Data has been received.
- Returns:
kStatus_Fail Unexpected slave state (master data read while master write to slave is expected).
-
void I2C_SlaveTransferCreateHandle(I2C_Type *base, i2c_slave_handle_t *handle, i2c_slave_transfer_callback_t callback, void *userData)
Creates a new handle for the I2C slave non-blocking APIs.
The creation of a handle is for use with the non-blocking APIs. Once a handle is created, there is not a corresponding destroy handle. If the user wants to terminate a transfer, the I2C_SlaveTransferAbort() API shall be called.
- Parameters:
base – The I2C peripheral base address.
handle – [out] Pointer to the I2C slave driver handle.
callback – User provided pointer to the asynchronous callback function.
userData – User provided pointer to the application callback data.
-
status_t I2C_SlaveTransferNonBlocking(I2C_Type *base, i2c_slave_handle_t *handle, uint32_t eventMask)
Starts accepting slave transfers.
Call this API after calling I2C_SlaveInit() and I2C_SlaveTransferCreateHandle() to start processing transactions driven by an I2C master. The slave monitors the I2C bus and pass events to the callback that was passed into the call to I2C_SlaveTransferCreateHandle(). The callback is always invoked from the interrupt context.
If no slave Tx transfer is busy, a master read from slave request invokes kI2C_SlaveTransmitEvent callback. If no slave Rx transfer is busy, a master write to slave request invokes kI2C_SlaveReceiveEvent callback.
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 kI2C_SlaveTransmitEvent and kI2C_SlaveReceiveEvent events are always enabled and do not need to be included in the mask. Alternatively, you can 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 specify 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.
- Return values:
kStatus_Success – Slave transfers were successfully started.
kStatus_I2C_Busy – Slave transfers have already been started on this handle.
-
status_t I2C_SlaveSetSendBuffer(I2C_Type *base, volatile i2c_slave_transfer_t *transfer, const void *txData, size_t txSize, uint32_t eventMask)
Starts accepting master read from slave requests.
The function can be called in response to kI2C_SlaveTransmitEvent callback to start a new slave Tx transfer from within the transfer callback.
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 kI2C_SlaveTransmitEvent and kI2C_SlaveReceiveEvent events are always enabled and do not need to be included in the mask. Alternatively, you can 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.
transfer – Pointer to i2c_slave_transfer_t structure.
txData – Pointer to data to send to master.
txSize – Size of txData in bytes.
eventMask – Bit mask formed by OR’ing together i2c_slave_transfer_event_t enumerators to specify 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.
- Return values:
kStatus_Success – Slave transfers were successfully started.
kStatus_I2C_Busy – Slave transfers have already been started on this handle.
-
status_t I2C_SlaveSetReceiveBuffer(I2C_Type *base, volatile i2c_slave_transfer_t *transfer, void *rxData, size_t rxSize, uint32_t eventMask)
Starts accepting master write to slave requests.
The function can be called in response to kI2C_SlaveReceiveEvent callback to start a new slave Rx transfer from within the transfer callback.
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 kI2C_SlaveTransmitEvent and kI2C_SlaveReceiveEvent events are always enabled and do not need to be included in the mask. Alternatively, you can 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.
transfer – Pointer to i2c_slave_transfer_t structure.
rxData – Pointer to data to store data from master.
rxSize – Size of rxData in bytes.
eventMask – Bit mask formed by OR’ing together i2c_slave_transfer_event_t enumerators to specify 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.
- Return values:
kStatus_Success – Slave transfers were successfully started.
kStatus_I2C_Busy – Slave transfers have already been started on this handle.
-
static inline uint32_t I2C_SlaveGetReceivedAddress(I2C_Type *base, volatile i2c_slave_transfer_t *transfer)
Returns the slave address sent by the I2C master.
This function should only be called from the address match event callback kI2C_SlaveAddressMatchEvent.
- Parameters:
base – The I2C peripheral base address.
transfer – The I2C slave transfer.
- Returns:
The 8-bit address matched by the I2C slave. Bit 0 contains the R/w direction bit, and the 7-bit slave address is in the upper 7 bits.
-
void I2C_SlaveTransferAbort(I2C_Type *base, i2c_slave_handle_t *handle)
Aborts the slave non-blocking transfers.
Note
This API could be called at any time to stop slave for handling the bus events.
- Parameters:
base – The I2C peripheral base address.
handle – Pointer to i2c_slave_handle_t structure which stores the transfer state.
- Return values:
kStatus_Success –
kStatus_I2C_Idle –
-
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.
- 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.
-
void I2C_SlaveTransferHandleIRQ(I2C_Type *base, i2c_slave_handle_t *handle)
Reusable routine to handle slave interrupts.
Note
This function does not need to be called unless you are reimplementing the non blocking API’s interrupt handler routines to add special functionality.
- Parameters:
base – The I2C peripheral base address.
handle – Pointer to i2c_slave_handle_t structure which stores the transfer state.
-
enum _i2c_slave_address_register
I2C slave address register.
Values:
-
enumerator kI2C_SlaveAddressRegister0
Slave Address 0 register.
-
enumerator kI2C_SlaveAddressRegister1
Slave Address 1 register.
-
enumerator kI2C_SlaveAddressRegister2
Slave Address 2 register.
-
enumerator kI2C_SlaveAddressRegister3
Slave Address 3 register.
-
enumerator kI2C_SlaveAddressRegister0
-
enum _i2c_slave_address_qual_mode
I2C slave address match options.
Values:
-
enumerator kI2C_QualModeMask
The SLVQUAL0 field (qualAddress) is used as a logical mask for matching address0.
-
enumerator kI2C_QualModeExtend
The SLVQUAL0 (qualAddress) field is used to extend address 0 matching in a range of addresses.
-
enumerator kI2C_QualModeMask
-
enum _i2c_slave_bus_speed
I2C slave bus speed options.
Values:
-
enumerator kI2C_SlaveStandardMode
-
enumerator kI2C_SlaveFastMode
-
enumerator kI2C_SlaveFastModePlus
-
enumerator kI2C_SlaveHsMode
-
enumerator kI2C_SlaveStandardMode
-
enum _i2c_slave_transfer_event
Set of events sent to the callback for non blocking slave transfers.
These event enumerations are used for two related purposes. First, a bit mask created by OR’ing together events is passed to I2C_SlaveTransferNonBlocking() in order 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.
Values:
-
enumerator kI2C_SlaveAddressMatchEvent
Received the slave address after a start or repeated start.
-
enumerator kI2C_SlaveTransmitEvent
Callback is requested to provide data to transmit (slave-transmitter role).
-
enumerator kI2C_SlaveReceiveEvent
Callback is requested to provide a buffer in which to place received data (slave-receiver role).
-
enumerator kI2C_SlaveCompletionEvent
All data in the active transfer have been consumed.
-
enumerator kI2C_SlaveDeselectedEvent
The slave function has become deselected (SLVSEL flag changing from 1 to 0.
-
enumerator kI2C_SlaveAllEvents
Bit mask of all available events.
-
enumerator kI2C_SlaveAddressMatchEvent
-
enum _i2c_slave_fsm
I2C slave software finite state machine states.
Values:
-
enumerator kI2C_SlaveFsmAddressMatch
-
enumerator kI2C_SlaveFsmReceive
-
enumerator kI2C_SlaveFsmTransmit
-
enumerator kI2C_SlaveFsmAddressMatch
-
typedef enum _i2c_slave_address_register i2c_slave_address_register_t
I2C slave address register.
-
typedef struct _i2c_slave_address i2c_slave_address_t
Data structure with 7-bit Slave address and Slave address disable.
-
typedef enum _i2c_slave_address_qual_mode i2c_slave_address_qual_mode_t
I2C slave address match options.
-
typedef enum _i2c_slave_bus_speed i2c_slave_bus_speed_t
I2C slave bus speed options.
-
typedef struct _i2c_slave_config i2c_slave_config_t
Structure with settings to initialize the I2C slave module.
This structure holds configuration settings for the I2C slave peripheral. To initialize this structure to reasonable defaults, call the I2C_SlaveGetDefaultConfig() function and pass a pointer to your configuration structure instance.
The configuration structure can be made constant so it resides in flash.
-
typedef enum _i2c_slave_transfer_event i2c_slave_transfer_event_t
Set of events sent to the callback for non blocking slave transfers.
These event enumerations are used for two related purposes. First, a bit mask created by OR’ing together events is passed to I2C_SlaveTransferNonBlocking() in order 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.
-
typedef struct _i2c_slave_handle i2c_slave_handle_t
I2C slave handle typedef.
-
typedef struct _i2c_slave_transfer i2c_slave_transfer_t
I2C slave transfer structure.
-
typedef void (*i2c_slave_transfer_callback_t)(I2C_Type *base, volatile i2c_slave_transfer_t *transfer, void *userData)
Slave event callback function pointer type.
This callback is used only for the slave non-blocking transfer API. To install a callback, use the I2C_SlaveSetCallback() function after you have created a handle.
- Param base:
Base address for the I2C instance on which the event occurred.
- Param transfer:
Pointer to transfer descriptor containing values passed to and/or from the callback.
- Param userData:
Arbitrary pointer-sized value passed from the application.
-
typedef enum _i2c_slave_fsm i2c_slave_fsm_t
I2C slave software finite state machine states.
-
typedef void (*flexcomm_i2c_master_irq_handler_t)(I2C_Type *base, i2c_master_handle_t *handle)
Typedef for master interrupt handler.
-
typedef void (*flexcomm_i2c_slave_irq_handler_t)(I2C_Type *base, i2c_slave_handle_t *handle)
Typedef for slave interrupt handler.
-
struct _i2c_slave_address
- #include <fsl_i2c.h>
Data structure with 7-bit Slave address and Slave address disable.
Public Members
-
uint8_t address
7-bit Slave address SLVADR.
-
bool addressDisable
Slave address disable SADISABLE.
-
uint8_t address
-
struct _i2c_slave_config
- #include <fsl_i2c.h>
Structure with settings to initialize the I2C slave module.
This structure holds configuration settings for the I2C slave peripheral. To initialize this structure to reasonable defaults, call the I2C_SlaveGetDefaultConfig() function and pass a pointer to your configuration structure instance.
The configuration structure can be made constant so it resides in flash.
Public Members
-
i2c_slave_address_t address0
Slave’s 7-bit address and disable.
-
i2c_slave_address_t address1
Alternate slave 7-bit address and disable.
-
i2c_slave_address_t address2
Alternate slave 7-bit address and disable.
-
i2c_slave_address_t address3
Alternate slave 7-bit address and disable.
-
i2c_slave_address_qual_mode_t qualMode
Qualify mode for slave address 0.
-
uint8_t qualAddress
Slave address qualifier for address 0.
-
i2c_slave_bus_speed_t busSpeed
Slave bus speed mode. If the slave function stretches SCL to allow for software response, it must provide sufficient data setup time to the master before releasing the stretched clock. This is accomplished by inserting one clock time of CLKDIV at that point. The busSpeed value is used to configure CLKDIV such that one clock time is greater than the tSU;DAT value noted in the I2C bus specification for the I2C mode that is being used. If the busSpeed mode is unknown at compile time, use the longest data setup time kI2C_SlaveStandardMode (250 ns)
-
bool enableSlave
Enable slave mode.
-
i2c_slave_address_t address0
-
struct _i2c_slave_transfer
- #include <fsl_i2c.h>
I2C slave transfer structure.
Public Members
-
i2c_slave_handle_t *handle
Pointer to handle that contains this transfer.
-
i2c_slave_transfer_event_t event
Reason the callback is being invoked.
-
uint8_t receivedAddress
Matching address send by master. 7-bits plus R/nW bit0
-
uint32_t eventMask
Mask of enabled events.
-
uint8_t *rxData
Transfer buffer for receive data
-
const uint8_t *txData
Transfer buffer for transmit data
-
size_t txSize
Transfer size
-
size_t rxSize
Transfer size
-
size_t transferredCount
Number of bytes transferred during this transfer.
-
status_t completionStatus
Success or error code describing how the transfer completed. Only applies for kI2C_SlaveCompletionEvent.
-
i2c_slave_handle_t *handle
-
struct _i2c_slave_handle
- #include <fsl_i2c.h>
I2C slave handle structure.
Note
The contents of this structure are private and subject to change.
Public Members
-
volatile i2c_slave_transfer_t transfer
I2C slave transfer.
-
volatile bool isBusy
Whether transfer is busy.
-
volatile i2c_slave_fsm_t slaveFsm
slave transfer state machine.
-
i2c_slave_transfer_callback_t callback
Callback function called at transfer event.
-
void *userData
Callback parameter passed to callback.
-
volatile i2c_slave_transfer_t transfer
I2S: I2S Driver
I2S DMA Driver
-
void I2S_TxTransferCreateHandleDMA(I2S_Type *base, i2s_dma_handle_t *handle, dma_handle_t *dmaHandle, i2s_dma_transfer_callback_t callback, void *userData)
Initializes handle for transfer of audio data.
- Parameters:
base – I2S base pointer.
handle – pointer to handle structure.
dmaHandle – pointer to dma handle structure.
callback – function to be called back when transfer is done or fails.
userData – pointer to data passed to callback.
-
status_t I2S_TxTransferSendDMA(I2S_Type *base, i2s_dma_handle_t *handle, i2s_transfer_t transfer)
Begins or queue sending of the given data.
- Parameters:
base – I2S base pointer.
handle – pointer to handle structure.
transfer – data buffer.
- Return values:
kStatus_Success –
kStatus_I2S_Busy – if all queue slots are occupied with unsent buffers.
-
void I2S_TransferAbortDMA(I2S_Type *base, i2s_dma_handle_t *handle)
Aborts transfer of data.
- Parameters:
base – I2S base pointer.
handle – pointer to handle structure.
-
void I2S_RxTransferCreateHandleDMA(I2S_Type *base, i2s_dma_handle_t *handle, dma_handle_t *dmaHandle, i2s_dma_transfer_callback_t callback, void *userData)
Initializes handle for reception of audio data.
- Parameters:
base – I2S base pointer.
handle – pointer to handle structure.
dmaHandle – pointer to dma handle structure.
callback – function to be called back when transfer is done or fails.
userData – pointer to data passed to callback.
-
status_t I2S_RxTransferReceiveDMA(I2S_Type *base, i2s_dma_handle_t *handle, i2s_transfer_t transfer)
Begins or queue reception of data into given buffer.
- Parameters:
base – I2S base pointer.
handle – pointer to handle structure.
transfer – data buffer.
- Return values:
kStatus_Success –
kStatus_I2S_Busy – if all queue slots are occupied with buffers which are not full.
-
void I2S_DMACallback(dma_handle_t *handle, void *userData, bool transferDone, uint32_t tcds)
Invoked from DMA interrupt handler.
- Parameters:
handle – pointer to DMA handle structure.
userData – argument for user callback.
transferDone – if transfer was done.
tcds –
-
void I2S_TransferInstallLoopDMADescriptorMemory(i2s_dma_handle_t *handle, void *dmaDescriptorAddr, size_t dmaDescriptorNum)
Install DMA descriptor memory for loop transfer only.
This function used to register DMA descriptor memory for the i2s loop dma transfer.
It must be callbed before I2S_TransferSendLoopDMA/I2S_TransferReceiveLoopDMA and after I2S_RxTransferCreateHandleDMA/I2S_TxTransferCreateHandleDMA.
User should be take care about the address of DMA descriptor pool which required align with 16BYTE at least.
- Parameters:
handle – Pointer to i2s DMA transfer handle.
dmaDescriptorAddr – DMA descriptor start address.
dmaDescriptorNum – DMA descriptor number.
-
status_t I2S_TransferSendLoopDMA(I2S_Type *base, i2s_dma_handle_t *handle, i2s_transfer_t *xfer, uint32_t loopTransferCount)
Send link transfer data using DMA.
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.
This function support loop transfer, such as A->B->…->A, the loop transfer chain will be converted into a chain of descriptor and submit to dma. Application must be aware of that the more counts of the loop transfer, then more DMA descriptor memory required, user can use function I2S_InstallDMADescriptorMemory to register the dma descriptor memory.
As the DMA support maximum 1024 transfer count, so application must be aware of that this transfer function support maximum 1024 samples in each transfer, otherwise assert error or error status will be returned. Once the loop transfer start, application can use function I2S_TransferAbortDMA to stop the loop transfer.
- Parameters:
base – I2S peripheral base address.
handle – Pointer to usart_dma_handle_t structure.
xfer – I2S DMA transfer structure. See i2s_transfer_t.
loopTransferCount – loop count
- Return values:
kStatus_Success –
-
status_t I2S_TransferReceiveLoopDMA(I2S_Type *base, i2s_dma_handle_t *handle, i2s_transfer_t *xfer, uint32_t loopTransferCount)
Receive link transfer data using DMA.
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.
This function support loop transfer, such as A->B->…->A, the loop transfer chain will be converted into a chain of descriptor and submit to dma. Application must be aware of that the more counts of the loop transfer, then more DMA descriptor memory required, user can use function I2S_InstallDMADescriptorMemory to register the dma descriptor memory.
As the DMA support maximum 1024 transfer count, so application must be aware of that this transfer function support maximum 1024 samples in each transfer, otherwise assert error or error status will be returned. Once the loop transfer start, application can use function I2S_TransferAbortDMA to stop the loop transfer.
- Parameters:
base – I2S peripheral base address.
handle – Pointer to usart_dma_handle_t structure.
xfer – I2S DMA transfer structure. See i2s_transfer_t.
loopTransferCount – loop count
- Return values:
kStatus_Success –
-
FSL_I2S_DMA_DRIVER_VERSION
I2S DMA driver version 2.3.3.
-
typedef struct _i2s_dma_handle i2s_dma_handle_t
Members not to be accessed / modified outside of the driver.
-
typedef void (*i2s_dma_transfer_callback_t)(I2S_Type *base, i2s_dma_handle_t *handle, status_t completionStatus, void *userData)
Callback function invoked from DMA API on completion.
- Param base:
I2S base pointer.
- Param handle:
pointer to I2S transaction.
- Param completionStatus:
status of the transaction.
- Param userData:
optional pointer to user arguments data.
-
struct _i2s_dma_handle
- #include <fsl_i2s_dma.h>
i2s dma handle
Public Members
-
uint32_t state
Internal state of I2S DMA transfer
-
uint8_t bytesPerFrame
bytes per frame
-
i2s_dma_transfer_callback_t completionCallback
Callback function pointer
-
void *userData
Application data passed to callback
-
dma_handle_t *dmaHandle
DMA handle
-
volatile i2s_transfer_t i2sQueue[(4U)]
Transfer queue storing transfer buffers
-
volatile uint8_t queueUser
Queue index where user’s next transfer will be stored
-
volatile uint8_t queueDriver
Queue index of buffer actually used by the driver
-
dma_descriptor_t *i2sLoopDMADescriptor
descriptor pool pointer
-
size_t i2sLoopDMADescriptorNum
number of descriptor in descriptors pool
-
uint32_t state
I2S Driver
-
void I2S_TxInit(I2S_Type *base, const i2s_config_t *config)
Initializes the FLEXCOMM peripheral for I2S transmit functionality.
Ungates the FLEXCOMM clock and configures the module for I2S transmission using a configuration structure. The configuration structure can be custom filled or set with default values by I2S_TxGetDefaultConfig().
Note
This API should be called at the beginning of the application to use the I2S driver.
- Parameters:
base – I2S base pointer.
config – pointer to I2S configuration structure.
-
void I2S_RxInit(I2S_Type *base, const i2s_config_t *config)
Initializes the FLEXCOMM peripheral for I2S receive functionality.
Ungates the FLEXCOMM clock and configures the module for I2S receive using a configuration structure. The configuration structure can be custom filled or set with default values by I2S_RxGetDefaultConfig().
Note
This API should be called at the beginning of the application to use the I2S driver.
- Parameters:
base – I2S base pointer.
config – pointer to I2S configuration structure.
-
void I2S_TxGetDefaultConfig(i2s_config_t *config)
Sets the I2S Tx configuration structure to default values.
This API initializes the configuration structure for use in I2S_TxInit(). The initialized structure can remain unchanged in I2S_TxInit(), or it can be modified before calling I2S_TxInit(). Example:
i2s_config_t config; I2S_TxGetDefaultConfig(&config);
Default values:
config->masterSlave = kI2S_MasterSlaveNormalMaster; config->mode = kI2S_ModeI2sClassic; config->rightLow = false; config->leftJust = false; config->pdmData = false; config->sckPol = false; config->wsPol = false; config->divider = 1; config->oneChannel = false; config->dataLength = 16; config->frameLength = 32; config->position = 0; config->watermark = 4; config->txEmptyZero = true; config->pack48 = false;
- Parameters:
config – pointer to I2S configuration structure.
-
void I2S_RxGetDefaultConfig(i2s_config_t *config)
Sets the I2S Rx configuration structure to default values.
This API initializes the configuration structure for use in I2S_RxInit(). The initialized structure can remain unchanged in I2S_RxInit(), or it can be modified before calling I2S_RxInit(). Example:
i2s_config_t config; I2S_RxGetDefaultConfig(&config);
Default values:
config->masterSlave = kI2S_MasterSlaveNormalSlave; config->mode = kI2S_ModeI2sClassic; config->rightLow = false; config->leftJust = false; config->pdmData = false; config->sckPol = false; config->wsPol = false; config->divider = 1; config->oneChannel = false; config->dataLength = 16; config->frameLength = 32; config->position = 0; config->watermark = 4; config->txEmptyZero = false; config->pack48 = false;
- Parameters:
config – pointer to I2S configuration structure.
-
void I2S_Deinit(I2S_Type *base)
De-initializes the I2S peripheral.
This API gates the FLEXCOMM clock. The I2S module can’t operate unless I2S_TxInit or I2S_RxInit is called to enable the clock.
- Parameters:
base – I2S base pointer.
-
void I2S_SetBitClockRate(I2S_Type *base, uint32_t sourceClockHz, uint32_t sampleRate, uint32_t bitWidth, uint32_t channelNumbers)
Transmitter/Receiver bit clock rate configurations.
- Parameters:
base – SAI base pointer.
sourceClockHz – bit clock source frequency.
sampleRate – audio data sample rate.
bitWidth – audio data bitWidth.
channelNumbers – audio channel numbers.
-
void I2S_TxTransferCreateHandle(I2S_Type *base, i2s_handle_t *handle, i2s_transfer_callback_t callback, void *userData)
Initializes handle for transfer of audio data.
- Parameters:
base – I2S base pointer.
handle – pointer to handle structure.
callback – function to be called back when transfer is done or fails.
userData – pointer to data passed to callback.
-
status_t I2S_TxTransferNonBlocking(I2S_Type *base, i2s_handle_t *handle, i2s_transfer_t transfer)
Begins or queue sending of the given data.
- Parameters:
base – I2S base pointer.
handle – pointer to handle structure.
transfer – data buffer.
- Return values:
kStatus_Success –
kStatus_I2S_Busy – if all queue slots are occupied with unsent buffers.
-
void I2S_TxTransferAbort(I2S_Type *base, i2s_handle_t *handle)
Aborts sending of data.
- Parameters:
base – I2S base pointer.
handle – pointer to handle structure.
-
void I2S_RxTransferCreateHandle(I2S_Type *base, i2s_handle_t *handle, i2s_transfer_callback_t callback, void *userData)
Initializes handle for reception of audio data.
- Parameters:
base – I2S base pointer.
handle – pointer to handle structure.
callback – function to be called back when transfer is done or fails.
userData – pointer to data passed to callback.
-
status_t I2S_RxTransferNonBlocking(I2S_Type *base, i2s_handle_t *handle, i2s_transfer_t transfer)
Begins or queue reception of data into given buffer.
- Parameters:
base – I2S base pointer.
handle – pointer to handle structure.
transfer – data buffer.
- Return values:
kStatus_Success –
kStatus_I2S_Busy – if all queue slots are occupied with buffers which are not full.
-
void I2S_RxTransferAbort(I2S_Type *base, i2s_handle_t *handle)
Aborts receiving of data.
- Parameters:
base – I2S base pointer.
handle – pointer to handle structure.
-
status_t I2S_TransferGetCount(I2S_Type *base, i2s_handle_t *handle, size_t *count)
Returns number of bytes transferred so far.
- Parameters:
base – I2S base pointer.
handle – pointer to handle structure.
count – [out] number of bytes transferred so far by the non-blocking transaction.
- Return values:
kStatus_Success –
kStatus_NoTransferInProgress – there is no non-blocking transaction currently in progress.
-
status_t I2S_TransferGetErrorCount(I2S_Type *base, i2s_handle_t *handle, size_t *count)
Returns number of buffer underruns or overruns.
- Parameters:
base – I2S base pointer.
handle – pointer to handle structure.
count – [out] number of transmit errors encountered so far by the non-blocking transaction.
- Return values:
kStatus_Success –
kStatus_NoTransferInProgress – there is no non-blocking transaction currently in progress.
-
static inline void I2S_Enable(I2S_Type *base)
Enables I2S operation.
- Parameters:
base – I2S base pointer.
-
void I2S_EnableSecondaryChannel(I2S_Type *base, uint32_t channel, bool oneChannel, uint32_t position)
Enables I2S secondary channel.
- Parameters:
base – I2S base pointer.
channel – seondary channel channel number, reference _i2s_secondary_channel.
oneChannel – true is treated as single channel, functionality left channel for this pair.
position – define the location within the frame of the data, should not bigger than 0x1FFU.
-
static inline void I2S_DisableSecondaryChannel(I2S_Type *base, uint32_t channel)
Disables I2S secondary channel.
- Parameters:
base – I2S base pointer.
channel – seondary channel channel number, reference _i2s_secondary_channel.
-
static inline void I2S_Disable(I2S_Type *base)
Disables I2S operation.
- Parameters:
base – I2S base pointer.
-
static inline void I2S_EnableInterrupts(I2S_Type *base, uint32_t interruptMask)
Enables I2S FIFO interrupts.
- Parameters:
base – I2S base pointer.
interruptMask – bit mask of interrupts to enable. See i2s_flags_t for the set of constants that should be OR’d together to form the bit mask.
-
static inline void I2S_DisableInterrupts(I2S_Type *base, uint32_t interruptMask)
Disables I2S FIFO interrupts.
- Parameters:
base – I2S base pointer.
interruptMask – bit mask of interrupts to enable. See i2s_flags_t for the set of constants that should be OR’d together to form the bit mask.
-
static inline uint32_t I2S_GetEnabledInterrupts(I2S_Type *base)
Returns the set of currently enabled I2S FIFO interrupts.
- Parameters:
base – I2S base pointer.
- Returns:
A bitmask composed of i2s_flags_t enumerators OR’d together to indicate the set of enabled interrupts.
-
status_t I2S_EmptyTxFifo(I2S_Type *base)
Flush the valid data in TX fifo.
- Parameters:
base – I2S base pointer.
- Returns:
kStatus_Fail empty TX fifo failed, kStatus_Success empty tx fifo success.
-
void I2S_TxHandleIRQ(I2S_Type *base, i2s_handle_t *handle)
Invoked from interrupt handler when transmit FIFO level decreases.
- Parameters:
base – I2S base pointer.
handle – pointer to handle structure.
-
void I2S_RxHandleIRQ(I2S_Type *base, i2s_handle_t *handle)
Invoked from interrupt handler when receive FIFO level decreases.
- Parameters:
base – I2S base pointer.
handle – pointer to handle structure.
-
FSL_I2S_DRIVER_VERSION
I2S driver version 2.3.2.
_i2s_status I2S status codes.
Values:
-
enumerator kStatus_I2S_BufferComplete
Transfer from/into a single buffer has completed
-
enumerator kStatus_I2S_Done
All buffers transfers have completed
-
enumerator kStatus_I2S_Busy
Already performing a transfer and cannot queue another buffer
-
enumerator kStatus_I2S_BufferComplete
-
enum _i2s_flags
I2S flags.
Note
These enums are meant to be OR’d together to form a bit mask.
Values:
-
enumerator kI2S_TxErrorFlag
TX error interrupt
-
enumerator kI2S_TxLevelFlag
TX level interrupt
-
enumerator kI2S_RxErrorFlag
RX error interrupt
-
enumerator kI2S_RxLevelFlag
RX level interrupt
-
enumerator kI2S_TxErrorFlag
-
enum _i2s_master_slave
Master / slave mode.
Values:
-
enumerator kI2S_MasterSlaveNormalSlave
Normal slave
-
enumerator kI2S_MasterSlaveWsSyncMaster
WS synchronized master
-
enumerator kI2S_MasterSlaveExtSckMaster
Master using existing SCK
-
enumerator kI2S_MasterSlaveNormalMaster
Normal master
-
enumerator kI2S_MasterSlaveNormalSlave
-
enum _i2s_mode
I2S mode.
Values:
-
enumerator kI2S_ModeI2sClassic
I2S classic mode
-
enumerator kI2S_ModeDspWs50
DSP mode, WS having 50% duty cycle
-
enumerator kI2S_ModeDspWsShort
DSP mode, WS having one clock long pulse
-
enumerator kI2S_ModeDspWsLong
DSP mode, WS having one data slot long pulse
-
enumerator kI2S_ModeI2sClassic
_i2s_secondary_channel I2S secondary channel.
Values:
-
enumerator kI2S_SecondaryChannel1
secondary channel 1
-
enumerator kI2S_SecondaryChannel2
secondary channel 2
-
enumerator kI2S_SecondaryChannel3
secondary channel 3
-
enumerator kI2S_SecondaryChannel1
-
typedef enum _i2s_flags i2s_flags_t
I2S flags.
Note
These enums are meant to be OR’d together to form a bit mask.
-
typedef enum _i2s_master_slave i2s_master_slave_t
Master / slave mode.
-
typedef enum _i2s_mode i2s_mode_t
I2S mode.
-
typedef struct _i2s_config i2s_config_t
I2S configuration structure.
-
typedef struct _i2s_transfer i2s_transfer_t
Buffer to transfer from or receive audio data into.
-
typedef struct _i2s_handle i2s_handle_t
Transactional state of the intialized transfer or receive I2S operation.
-
typedef void (*i2s_transfer_callback_t)(I2S_Type *base, i2s_handle_t *handle, status_t completionStatus, void *userData)
Callback function invoked from transactional API on completion of a single buffer transfer.
- Param base:
I2S base pointer.
- Param handle:
pointer to I2S transaction.
- Param completionStatus:
status of the transaction.
- Param userData:
optional pointer to user arguments data.
-
I2S_NUM_BUFFERS
Number of buffers .
-
struct _i2s_config
- #include <fsl_i2s.h>
I2S configuration structure.
Public Members
-
i2s_master_slave_t masterSlave
Master / slave configuration
-
i2s_mode_t mode
I2S mode
-
bool rightLow
Right channel data in low portion of FIFO
-
bool leftJust
Left justify data in FIFO
-
bool pdmData
Data source is the D-Mic subsystem
-
bool sckPol
SCK polarity
-
bool wsPol
WS polarity
-
uint16_t divider
Flexcomm function clock divider (1 - 4096)
-
bool oneChannel
true mono, false stereo
-
uint8_t dataLength
Data length (4 - 32)
-
uint16_t frameLength
Frame width (4 - 512)
-
uint16_t position
Data position in the frame
-
uint8_t watermark
FIFO trigger level
-
bool txEmptyZero
Transmit zero when buffer becomes empty or last item
-
bool pack48
Packing format for 48-bit data (false - 24 bit values, true - alternating 32-bit and 16-bit values)
-
i2s_master_slave_t masterSlave
-
struct _i2s_transfer
- #include <fsl_i2s.h>
Buffer to transfer from or receive audio data into.
Public Members
-
uint8_t *data
Pointer to data buffer.
-
size_t dataSize
Buffer size in bytes.
-
uint8_t *data
-
struct _i2s_handle
- #include <fsl_i2s.h>
Members not to be accessed / modified outside of the driver.
Public Members
-
volatile uint32_t state
State of transfer
-
i2s_transfer_callback_t completionCallback
Callback function pointer
-
void *userData
Application data passed to callback
-
bool oneChannel
true mono, false stereo
-
uint8_t dataLength
Data length (4 - 32)
-
bool pack48
Packing format for 48-bit data (false - 24 bit values, true - alternating 32-bit and 16-bit values)
-
uint8_t watermark
FIFO trigger level
-
bool useFifo48H
When dataLength 17-24: true use FIFOWR48H, false use FIFOWR
-
volatile i2s_transfer_t i2sQueue[(4U)]
Transfer queue storing transfer buffers
-
volatile uint8_t queueUser
Queue index where user’s next transfer will be stored
-
volatile uint8_t queueDriver
Queue index of buffer actually used by the driver
-
volatile uint32_t errorCount
Number of buffer underruns/overruns
-
volatile uint32_t transferCount
Number of bytes transferred
-
volatile uint32_t state
I3C: I3C Driver
-
FSL_I3C_DRIVER_VERSION
I3C driver version.
I3C status return codes.
Values:
-
enumerator kStatus_I3C_Busy
The master is already performing a transfer.
-
enumerator kStatus_I3C_Idle
The slave driver is idle.
-
enumerator kStatus_I3C_Nak
The slave device sent a NAK in response to an address.
-
enumerator kStatus_I3C_WriteAbort
The slave device sent a NAK in response to a write.
-
enumerator kStatus_I3C_Term
The master terminates slave read.
-
enumerator kStatus_I3C_HdrParityError
Parity error from DDR read.
-
enumerator kStatus_I3C_CrcError
CRC error from DDR read.
-
enumerator kStatus_I3C_ReadFifoError
Read from M/SRDATAB register when FIFO empty.
-
enumerator kStatus_I3C_WriteFifoError
Write to M/SWDATAB register when FIFO full.
-
enumerator kStatus_I3C_MsgError
Message SDR/DDR mismatch or read/write message in wrong state
-
enumerator kStatus_I3C_InvalidReq
Invalid use of request.
-
enumerator kStatus_I3C_Timeout
The module has stalled too long in a frame.
-
enumerator kStatus_I3C_SlaveCountExceed
The I3C slave count has exceed the definition in I3C_MAX_DEVCNT.
-
enumerator kStatus_I3C_IBIWon
The I3C slave event IBI or MR or HJ won the arbitration on a header address.
-
enumerator kStatus_I3C_OverrunError
Slave internal from-bus buffer/FIFO overrun.
-
enumerator kStatus_I3C_UnderrunError
Slave internal to-bus buffer/FIFO underrun
-
enumerator kStatus_I3C_UnderrunNak
Slave internal from-bus buffer/FIFO underrun and NACK error
-
enumerator kStatus_I3C_InvalidStart
Slave invalid start flag
-
enumerator kStatus_I3C_SdrParityError
SDR parity error
-
enumerator kStatus_I3C_S0S1Error
S0 or S1 error
-
enumerator kStatus_I3C_Busy
-
enum _i3c_hdr_mode
I3C HDR modes.
Values:
-
enumerator kI3C_HDRModeNone
-
enumerator kI3C_HDRModeDDR
-
enumerator kI3C_HDRModeTSP
-
enumerator kI3C_HDRModeTSL
-
enumerator kI3C_HDRModeNone
-
typedef enum _i3c_hdr_mode i3c_hdr_mode_t
I3C HDR modes.
-
typedef struct _i3c_device_info i3c_device_info_t
I3C device information.
-
I3C_RETRY_TIMES
Timeout times for waiting flag.
-
I3C_MAX_DEVCNT
-
I3C_IBI_BUFF_SIZE
-
struct _i3c_device_info
- #include <fsl_i3c.h>
I3C device information.
Public Members
-
uint8_t dynamicAddr
Device dynamic address.
-
uint8_t staticAddr
Static address.
-
uint8_t dcr
Device characteristics register information.
-
uint8_t bcr
Bus characteristics register information.
-
uint16_t vendorID
Device vendor ID(manufacture ID).
-
uint32_t partNumber
Device part number info
-
uint16_t maxReadLength
Maximum read length.
-
uint16_t maxWriteLength
Maximum write length.
-
uint8_t hdrMode
Support hdr mode, could be OR logic in i3c_hdr_mode.
-
uint8_t dynamicAddr
I3C Common Driver
-
typedef struct _i3c_config i3c_config_t
Structure with settings to initialize the I3C module, could both initialize master and slave functionality.
This structure holds configuration settings for the I3C peripheral. To initialize this structure to reasonable defaults, call the I3C_GetDefaultConfig() function and pass a pointer to your configuration structure instance.
The configuration structure can be made constant so it resides in flash.
-
uint32_t I3C_GetInstance(I3C_Type *base)
Get which instance current I3C is used.
- Parameters:
base – The I3C peripheral base address.
-
void I3C_GetDefaultConfig(i3c_config_t *config)
Provides a default configuration for the I3C peripheral, the configuration covers both master functionality and slave functionality.
This function provides the following default configuration for I3C:
config->enableMaster = kI3C_MasterCapable; config->disableTimeout = false; config->hKeep = kI3C_MasterHighKeeperNone; config->enableOpenDrainStop = true; config->enableOpenDrainHigh = true; config->baudRate_Hz.i2cBaud = 400000U; config->baudRate_Hz.i3cPushPullBaud = 12500000U; config->baudRate_Hz.i3cOpenDrainBaud = 2500000U; config->masterDynamicAddress = 0x0AU; config->slowClock_Hz = 1000000U; config->enableSlave = true; config->vendorID = 0x11BU; config->enableRandomPart = false; config->partNumber = 0; config->dcr = 0; config->bcr = 0; config->hdrMode = (uint8_t)kI3C_HDRModeDDR; config->nakAllRequest = false; config->ignoreS0S1Error = false; config->offline = false; config->matchSlaveStartStop = false;
After calling this function, you can override any settings in order to customize the configuration, prior to initializing the common I3C driver with I3C_Init().
- Parameters:
config – [out] User provided configuration structure for default values. Refer to i3c_config_t.
-
void I3C_Init(I3C_Type *base, const i3c_config_t *config, uint32_t sourceClock_Hz)
Initializes the I3C peripheral. This function enables the peripheral clock and initializes the I3C peripheral as described by the user provided configuration. This will initialize both the master peripheral and slave peripheral so that I3C module could work as pure master, pure slave or secondary master, etc. A software reset is performed prior to configuration.
- Parameters:
base – The I3C peripheral base address.
config – User provided peripheral configuration. Use I3C_GetDefaultConfig() to get a set of defaults that you can override.
sourceClock_Hz – Frequency in Hertz of the I3C functional clock. Used to calculate the baud rate divisors, filter widths, and timeout periods.
-
struct _i3c_config
- #include <fsl_i3c.h>
Structure with settings to initialize the I3C module, could both initialize master and slave functionality.
This structure holds configuration settings for the I3C peripheral. To initialize this structure to reasonable defaults, call the I3C_GetDefaultConfig() function and pass a pointer to your configuration structure instance.
The configuration structure can be made constant so it resides in flash.
Public Members
-
i3c_master_enable_t enableMaster
Enable master mode.
-
bool disableTimeout
Whether to disable timeout to prevent the ERRWARN.
-
i3c_master_hkeep_t hKeep
High keeper mode setting.
-
bool enableOpenDrainStop
Whether to emit open-drain speed STOP.
-
bool enableOpenDrainHigh
Enable Open-Drain High to be 1 PPBAUD count for i3c messages, or 1 ODBAUD.
-
i3c_baudrate_hz_t baudRate_Hz
Desired baud rate settings.
-
uint8_t masterDynamicAddress
Main master dynamic address configuration.
-
uint32_t maxWriteLength
Maximum write length.
-
uint32_t maxReadLength
Maximum read length.
-
bool enableSlave
Whether to enable slave.
-
uint8_t staticAddr
Static address.
-
uint16_t vendorID
Device vendor ID(manufacture ID).
-
uint32_t partNumber
Device part number info
-
uint8_t dcr
Device characteristics register information.
-
uint8_t bcr
Bus characteristics register information.
-
uint8_t hdrMode
Support hdr mode, could be OR logic in enumeration:i3c_hdr_mode_t.
-
bool nakAllRequest
Whether to reply NAK to all requests except broadcast CCC.
-
bool ignoreS0S1Error
Whether to ignore S0/S1 error in SDR mode.
-
bool offline
Whether to wait 60 us of bus quiet or HDR request to ensure slave track SDR mode safely.
-
bool matchSlaveStartStop
Whether to assert start/stop status only the time slave is addressed.
-
i3c_master_enable_t enableMaster
I3C Master DMA Driver
-
typedef struct _i3c_master_dma_handle i3c_master_dma_handle_t
-
typedef struct _i3c_master_dma_callback i3c_master_dma_callback_t
i3c master callback functions.
-
void I3C_MasterTransferCreateHandleDMA(I3C_Type *base, i3c_master_dma_handle_t *handle, const i3c_master_dma_callback_t *callback, void *userData, dma_handle_t *rxDmaHandle, dma_handle_t *txDmaHandle)
Create a new handle for the I3C master DMA APIs.
The creation of a handle is for use with the DMA APIs. Once a handle is created, there is not a corresponding destroy handle. If the user wants to terminate a transfer, the I3C_MasterTransferAbortDMA() API shall be called.
For devices where the I3C send and receive DMA requests are OR’d together, the txDmaHandle parameter is ignored and may be set to NULL.
- Parameters:
base – The I3C peripheral base address.
handle – Pointer to the I3C master driver handle.
callback – User provided pointer to the asynchronous callback function.
userData – User provided pointer to the application callback data.
rxDmaHandle – Handle for the DMA receive channel. Created by the user prior to calling this function.
txDmaHandle – Handle for the DMA transmit channel. Created by the user prior to calling this function.
-
status_t I3C_MasterTransferDMA(I3C_Type *base, i3c_master_dma_handle_t *handle, i3c_master_transfer_t *transfer)
Performs a non-blocking DMA-based transaction on the I3C bus.
The callback specified when the handle was created is invoked when the transaction has completed.
- Parameters:
base – The I3C peripheral base address.
handle – Pointer to the I3C master driver handle.
transfer – The pointer to the transfer descriptor.
- Return values:
kStatus_Success – The transaction was started successfully.
kStatus_I3C_Busy – Either another master is currently utilizing the bus, or another DMA transaction is already in progress.
-
status_t I3C_MasterTransferGetCountDMA(I3C_Type *base, i3c_master_dma_handle_t *handle, size_t *count)
Returns number of bytes transferred so far.
- Parameters:
base – The I3C peripheral base address.
handle – Pointer to the I3C master driver handle.
count – [out] Number of bytes transferred so far by the non-blocking transaction.
- Return values:
kStatus_Success –
kStatus_NoTransferInProgress – There is not a DMA transaction currently in progress.
-
void I3C_MasterTransferAbortDMA(I3C_Type *base, i3c_master_dma_handle_t *handle)
Terminates a non-blocking I3C master transmission early.
Note
It is not safe to call this function from an IRQ handler that has a higher priority than the DMA peripheral’s IRQ priority.
- Parameters:
base – The I3C peripheral base address.
handle – Pointer to the I3C master driver handle.
-
void I3C_MasterTransferDMAHandleIRQ(I3C_Type *base, void *i3cHandle)
Reusable routine to handle master interrupts.
Note
This function does not need to be called unless you are reimplementing the nonblocking API’s interrupt handler routines to add special functionality.
- Parameters:
base – The I3C peripheral base address.
handle – Pointer to the I3C master DMA driver handle.
-
void (*slave2Master)(I3C_Type *base, void *userData)
Transfer complete callback
-
void (*ibiCallback)(I3C_Type *base, i3c_master_dma_handle_t *handle, i3c_ibi_type_t ibiType, i3c_ibi_state_t ibiState)
IBI event callback
-
void (*transferComplete)(I3C_Type *base, i3c_master_dma_handle_t *handle, status_t status, void *userData)
Transfer complete callback
-
I3C_Type *base
I3C base pointer.
-
uint8_t state
Transfer state machine current state.
-
uint32_t transferCount
Indicates progress of the transfer
-
uint8_t subaddressBuffer[4]
Saving subaddress command.
-
uint8_t subaddressCount
Saving command count.
-
i3c_master_transfer_t transfer
Copy of the current transfer info.
-
i3c_master_dma_callback_t callback
Callback function pointer.
-
void *userData
Application data passed to callback.
-
dma_handle_t *rxDmaHandle
Handle for receive DMA channel.
-
dma_handle_t *txDmaHandle
Handle for transmit DMA channel.
-
uint8_t ibiAddress
Slave address which request IBI.
-
uint8_t *ibiBuff
Pointer to IBI buffer to keep ibi bytes.
-
size_t ibiPayloadSize
IBI payload size.
-
i3c_ibi_type_t ibiType
IBI type.
-
uint32_t event
Reason the callback is being invoked.
-
uint8_t *txData
Transfer buffer
-
size_t txDataSize
Transfer size
-
uint8_t *rxData
Transfer buffer
-
size_t rxDataSize
Transfer size
-
status_t completionStatus
Success or error code describing how the transfer completed. Only applies for kI3C_SlaveCompletionEvent.
-
I3C_Type *base
I3C base pointer.
-
i3c_slave_dma_transfer_t transfer
I3C slave transfer copy.
-
bool isBusy
Whether transfer is busy.
-
bool wasTransmit
Whether the last transfer was a transmit.
-
uint32_t eventMask
Mask of enabled events.
-
i3c_slave_dma_callback_t callback
Callback function called at transfer event.
-
dma_handle_t *rxDmaHandle
Handle for receive DMA channel.
-
dma_handle_t *txDmaHandle
Handle for transmit DMA channel.
-
void *userData
Callback parameter passed to callback.
-
struct _i3c_master_dma_callback
- #include <fsl_i3c_dma.h>
i3c master callback functions.
-
struct _i3c_master_dma_handle
- #include <fsl_i3c_dma.h>
Driver handle for master DMA APIs.
Note
The contents of this structure are private and subject to change.
I3C Master Driver
-
void I3C_MasterGetDefaultConfig(i3c_master_config_t *masterConfig)
Provides a default configuration for the I3C master peripheral.
This function provides the following default configuration for the I3C master peripheral:
masterConfig->enableMaster = kI3C_MasterOn; masterConfig->disableTimeout = false; masterConfig->hKeep = kI3C_MasterHighKeeperNone; masterConfig->enableOpenDrainStop = true; masterConfig->enableOpenDrainHigh = true; masterConfig->baudRate_Hz = 100000U; masterConfig->busType = kI3C_TypeI2C;
After calling this function, you can override any settings in order to customize the configuration, prior to initializing the master driver with I3C_MasterInit().
- Parameters:
masterConfig – [out] User provided configuration structure for default values. Refer to i3c_master_config_t.
-
void I3C_MasterInit(I3C_Type *base, const i3c_master_config_t *masterConfig, uint32_t sourceClock_Hz)
Initializes the I3C master peripheral.
This function enables the peripheral clock and initializes the I3C master peripheral as described by the user provided configuration. A software reset is performed prior to configuration.
- Parameters:
base – The I3C peripheral base address.
masterConfig – User provided peripheral configuration. Use I3C_MasterGetDefaultConfig() to get a set of defaults that you can override.
sourceClock_Hz – Frequency in Hertz of the I3C functional clock. Used to calculate the baud rate divisors, filter widths, and timeout periods.
-
void I3C_MasterDeinit(I3C_Type *base)
Deinitializes the I3C master peripheral.
This function disables the I3C master peripheral and gates the clock. It also performs a software reset to restore the peripheral to reset conditions.
- Parameters:
base – The I3C peripheral base address.
-
status_t I3C_MasterCheckAndClearError(I3C_Type *base, uint32_t status)
-
status_t I3C_MasterWaitForCtrlDone(I3C_Type *base, bool waitIdle)
-
status_t I3C_CheckForBusyBus(I3C_Type *base)
-
static inline void I3C_MasterEnable(I3C_Type *base, i3c_master_enable_t enable)
Set I3C module master mode.
- Parameters:
base – The I3C peripheral base address.
enable – Enable master mode.
-
void I3C_SlaveGetDefaultConfig(i3c_slave_config_t *slaveConfig)
Provides a default configuration for the I3C slave peripheral.
This function provides the following default configuration for the I3C slave peripheral:
slaveConfig->enableslave = true;
After calling this function, you can override any settings in order to customize the configuration, prior to initializing the slave driver with I3C_SlaveInit().
- Parameters:
slaveConfig – [out] User provided configuration structure for default values. Refer to i3c_slave_config_t.
-
void I3C_SlaveInit(I3C_Type *base, const i3c_slave_config_t *slaveConfig, uint32_t slowClock_Hz)
Initializes the I3C slave peripheral.
This function enables the peripheral clock and initializes the I3C slave peripheral as described by the user provided configuration.
- Parameters:
base – The I3C peripheral base address.
slaveConfig – User provided peripheral configuration. Use I3C_SlaveGetDefaultConfig() to get a set of defaults that you can override.
slowClock_Hz – Frequency in Hertz of the I3C slow clock. Used to calculate the bus match condition values. If FSL_FEATURE_I3C_HAS_NO_SCONFIG_BAMATCH defines as 1, this parameter is useless.
-
void I3C_SlaveDeinit(I3C_Type *base)
Deinitializes the I3C slave peripheral.
This function disables the I3C slave peripheral and gates the clock.
- Parameters:
base – The I3C peripheral base address.
-
static inline void I3C_SlaveEnable(I3C_Type *base, bool isEnable)
Enable/Disable Slave.
- Parameters:
base – The I3C peripheral base address.
isEnable – Enable or disable.
-
static inline uint32_t I3C_MasterGetStatusFlags(I3C_Type *base)
Gets the I3C master status flags.
A bit mask with the state of all I3C master status flags is returned. For each flag, the corresponding bit in the return value is set if the flag is asserted.
See also
_i3c_master_flags
- Parameters:
base – The I3C peripheral base address.
- Returns:
State of the status flags:
1: related status flag is set.
0: related status flag is not set.
-
static inline void I3C_MasterClearStatusFlags(I3C_Type *base, uint32_t statusMask)
Clears the I3C master status flag state.
The following status register flags can be cleared:
kI3C_MasterSlaveStartFlag
kI3C_MasterControlDoneFlag
kI3C_MasterCompleteFlag
kI3C_MasterArbitrationWonFlag
kI3C_MasterSlave2MasterFlag
Attempts to clear other flags has no effect.
See also
_i3c_master_flags.
- Parameters:
base – The I3C peripheral base address.
statusMask – A bitmask of status flags that are to be cleared. The mask is composed of _i3c_master_flags enumerators OR’d together. You may pass the result of a previous call to I3C_MasterGetStatusFlags().
-
static inline uint32_t I3C_MasterGetErrorStatusFlags(I3C_Type *base)
Gets the I3C master error status flags.
A bit mask with the state of all I3C master error status flags is returned. For each flag, the corresponding bit in the return value is set if the flag is asserted.
See also
_i3c_master_error_flags
- Parameters:
base – The I3C peripheral base address.
- Returns:
State of the error status flags:
1: related status flag is set.
0: related status flag is not set.
-
static inline void I3C_MasterClearErrorStatusFlags(I3C_Type *base, uint32_t statusMask)
Clears the I3C master error status flag state.
See also
_i3c_master_error_flags.
- Parameters:
base – The I3C peripheral base address.
statusMask – A bitmask of error status flags that are to be cleared. The mask is composed of _i3c_master_error_flags enumerators OR’d together. You may pass the result of a previous call to I3C_MasterGetStatusFlags().
-
i3c_master_state_t I3C_MasterGetState(I3C_Type *base)
Gets the I3C master state.
- Parameters:
base – The I3C peripheral base address.
- Returns:
I3C master state.
-
static inline uint32_t I3C_SlaveGetStatusFlags(I3C_Type *base)
Gets the I3C slave status flags.
A bit mask with the state of all I3C slave status flags is returned. For each flag, the corresponding bit in the return value is set if the flag is asserted.
See also
_i3c_slave_flags
- Parameters:
base – The I3C peripheral base address.
- Returns:
State of the status flags:
1: related status flag is set.
0: related status flag is not set.
-
static inline void I3C_SlaveClearStatusFlags(I3C_Type *base, uint32_t statusMask)
Clears the I3C slave status flag state.
The following status register flags can be cleared:
kI3C_SlaveBusStartFlag
kI3C_SlaveMatchedFlag
kI3C_SlaveBusStopFlag
Attempts to clear other flags has no effect.
See also
_i3c_slave_flags.
- Parameters:
base – The I3C peripheral base address.
statusMask – A bitmask of status flags that are to be cleared. The mask is composed of _i3c_slave_flags enumerators OR’d together. You may pass the result of a previous call to I3C_SlaveGetStatusFlags().
-
static inline uint32_t I3C_SlaveGetErrorStatusFlags(I3C_Type *base)
Gets the I3C slave error status flags.
A bit mask with the state of all I3C slave error status flags is returned. For each flag, the corresponding bit in the return value is set if the flag is asserted.
See also
_i3c_slave_error_flags
- Parameters:
base – The I3C peripheral base address.
- Returns:
State of the error status flags:
1: related status flag is set.
0: related status flag is not set.
-
static inline void I3C_SlaveClearErrorStatusFlags(I3C_Type *base, uint32_t statusMask)
Clears the I3C slave error status flag state.
See also
_i3c_slave_error_flags.
- Parameters:
base – The I3C peripheral base address.
statusMask – A bitmask of error status flags that are to be cleared. The mask is composed of _i3c_slave_error_flags enumerators OR’d together. You may pass the result of a previous call to I3C_SlaveGetErrorStatusFlags().
-
i3c_slave_activity_state_t I3C_SlaveGetActivityState(I3C_Type *base)
Gets the I3C slave state.
- Parameters:
base – The I3C peripheral base address.
- Returns:
I3C slave activity state, refer i3c_slave_activity_state_t.
-
status_t I3C_SlaveCheckAndClearError(I3C_Type *base, uint32_t status)
-
static inline void I3C_MasterEnableInterrupts(I3C_Type *base, uint32_t interruptMask)
Enables the I3C master interrupt requests.
All flags except kI3C_MasterBetweenFlag and kI3C_MasterNackDetectFlag can be enabled as interrupts.
- Parameters:
base – The I3C peripheral base address.
interruptMask – Bit mask of interrupts to enable. See _i3c_master_flags for the set of constants that should be OR’d together to form the bit mask.
-
static inline void I3C_MasterDisableInterrupts(I3C_Type *base, uint32_t interruptMask)
Disables the I3C master interrupt requests.
All flags except kI3C_MasterBetweenFlag and kI3C_MasterNackDetectFlag can be enabled as interrupts.
- Parameters:
base – The I3C peripheral base address.
interruptMask – Bit mask of interrupts to disable. See _i3c_master_flags for the set of constants that should be OR’d together to form the bit mask.
-
static inline uint32_t I3C_MasterGetEnabledInterrupts(I3C_Type *base)
Returns the set of currently enabled I3C master interrupt requests.
- Parameters:
base – The I3C peripheral base address.
- Returns:
A bitmask composed of _i3c_master_flags enumerators OR’d together to indicate the set of enabled interrupts.
-
static inline uint32_t I3C_MasterGetPendingInterrupts(I3C_Type *base)
Returns the set of pending I3C master interrupt requests.
- Parameters:
base – The I3C peripheral base address.
- Returns:
A bitmask composed of _i3c_master_flags enumerators OR’d together to indicate the set of pending interrupts.
-
static inline void I3C_SlaveEnableInterrupts(I3C_Type *base, uint32_t interruptMask)
Enables the I3C slave interrupt requests.
Only below flags can be enabled as interrupts.
kI3C_SlaveBusStartFlag
kI3C_SlaveMatchedFlag
kI3C_SlaveBusStopFlag
kI3C_SlaveRxReadyFlag
kI3C_SlaveTxReadyFlag
kI3C_SlaveDynamicAddrChangedFlag
kI3C_SlaveReceivedCCCFlag
kI3C_SlaveErrorFlag
kI3C_SlaveHDRCommandMatchFlag
kI3C_SlaveCCCHandledFlag
kI3C_SlaveEventSentFlag
- Parameters:
base – The I3C peripheral base address.
interruptMask – Bit mask of interrupts to enable. See _i3c_slave_flags for the set of constants that should be OR’d together to form the bit mask.
-
static inline void I3C_SlaveDisableInterrupts(I3C_Type *base, uint32_t interruptMask)
Disables the I3C slave interrupt requests.
Only below flags can be disabled as interrupts.
kI3C_SlaveBusStartFlag
kI3C_SlaveMatchedFlag
kI3C_SlaveBusStopFlag
kI3C_SlaveRxReadyFlag
kI3C_SlaveTxReadyFlag
kI3C_SlaveDynamicAddrChangedFlag
kI3C_SlaveReceivedCCCFlag
kI3C_SlaveErrorFlag
kI3C_SlaveHDRCommandMatchFlag
kI3C_SlaveCCCHandledFlag
kI3C_SlaveEventSentFlag
- Parameters:
base – The I3C peripheral base address.
interruptMask – Bit mask of interrupts to disable. See _i3c_slave_flags for the set of constants that should be OR’d together to form the bit mask.
-
static inline uint32_t I3C_SlaveGetEnabledInterrupts(I3C_Type *base)
Returns the set of currently enabled I3C slave interrupt requests.
- Parameters:
base – The I3C peripheral base address.
- Returns:
A bitmask composed of _i3c_slave_flags enumerators OR’d together to indicate the set of enabled interrupts.
-
static inline uint32_t I3C_SlaveGetPendingInterrupts(I3C_Type *base)
Returns the set of pending I3C slave interrupt requests.
- Parameters:
base – The I3C peripheral base address.
- Returns:
A bitmask composed of _i3c_slave_flags enumerators OR’d together to indicate the set of pending interrupts.
-
static inline void I3C_MasterEnableDMA(I3C_Type *base, bool enableTx, bool enableRx, uint32_t width)
Enables or disables I3C master DMA requests.
- Parameters:
base – The I3C peripheral base address.
enableTx – Enable flag for transmit DMA request. Pass true for enable, false for disable.
enableRx – Enable flag for receive DMA request. Pass true for enable, false for disable.
width – DMA read/write unit in bytes.
-
static inline uint32_t I3C_MasterGetTxFifoAddress(I3C_Type *base, uint32_t width)
Gets I3C master transmit data register address for DMA transfer.
- Parameters:
base – The I3C peripheral base address.
width – DMA read/write unit in bytes.
- Returns:
The I3C Master Transmit Data Register address.
-
static inline uint32_t I3C_MasterGetRxFifoAddress(I3C_Type *base, uint32_t width)
Gets I3C master receive data register address for DMA transfer.
- Parameters:
base – The I3C peripheral base address.
width – DMA read/write unit in bytes.
- Returns:
The I3C Master Receive Data Register address.
-
static inline void I3C_SlaveEnableDMA(I3C_Type *base, bool enableTx, bool enableRx, uint32_t width)
Enables or disables I3C slave DMA requests.
- Parameters:
base – The I3C peripheral base address.
enableTx – Enable flag for transmit DMA request. Pass true for enable, false for disable.
enableRx – Enable flag for receive DMA request. Pass true for enable, false for disable.
width – DMA read/write unit in bytes.
-
static inline uint32_t I3C_SlaveGetTxFifoAddress(I3C_Type *base, uint32_t width)
Gets I3C slave transmit data register address for DMA transfer.
- Parameters:
base – The I3C peripheral base address.
width – DMA read/write unit in bytes.
- Returns:
The I3C Slave Transmit Data Register address.
-
static inline uint32_t I3C_SlaveGetRxFifoAddress(I3C_Type *base, uint32_t width)
Gets I3C slave receive data register address for DMA transfer.
- Parameters:
base – The I3C peripheral base address.
width – DMA read/write unit in bytes.
- Returns:
The I3C Slave Receive Data Register address.
-
static inline void I3C_MasterSetWatermarks(I3C_Type *base, i3c_tx_trigger_level_t txLvl, i3c_rx_trigger_level_t rxLvl, bool flushTx, bool flushRx)
Sets the watermarks for I3C master FIFOs.
- Parameters:
base – The I3C peripheral base address.
txLvl – Transmit FIFO watermark level. The kI3C_MasterTxReadyFlag flag is set whenever the number of words in the transmit FIFO reaches txLvl.
rxLvl – Receive FIFO watermark level. The kI3C_MasterRxReadyFlag flag is set whenever the number of words in the receive FIFO reaches rxLvl.
flushTx – true if TX FIFO is to be cleared, otherwise TX FIFO remains unchanged.
flushRx – true if RX FIFO is to be cleared, otherwise RX FIFO remains unchanged.
-
static inline void I3C_MasterGetFifoCounts(I3C_Type *base, size_t *rxCount, size_t *txCount)
Gets the current number of bytes in the I3C master FIFOs.
- Parameters:
base – The I3C peripheral base address.
txCount – [out] Pointer through which the current number of bytes in the transmit FIFO is returned. Pass NULL if this value is not required.
rxCount – [out] Pointer through which the current number of bytes in the receive FIFO is returned. Pass NULL if this value is not required.
-
static inline void I3C_SlaveSetWatermarks(I3C_Type *base, i3c_tx_trigger_level_t txLvl, i3c_rx_trigger_level_t rxLvl, bool flushTx, bool flushRx)
Sets the watermarks for I3C slave FIFOs.
- Parameters:
base – The I3C peripheral base address.
txLvl – Transmit FIFO watermark level. The kI3C_SlaveTxReadyFlag flag is set whenever the number of words in the transmit FIFO reaches txLvl.
rxLvl – Receive FIFO watermark level. The kI3C_SlaveRxReadyFlag flag is set whenever the number of words in the receive FIFO reaches rxLvl.
flushTx – true if TX FIFO is to be cleared, otherwise TX FIFO remains unchanged.
flushRx – true if RX FIFO is to be cleared, otherwise RX FIFO remains unchanged.
-
static inline void I3C_SlaveGetFifoCounts(I3C_Type *base, size_t *rxCount, size_t *txCount)
Gets the current number of bytes in the I3C slave FIFOs.
- Parameters:
base – The I3C peripheral base address.
txCount – [out] Pointer through which the current number of bytes in the transmit FIFO is returned. Pass NULL if this value is not required.
rxCount – [out] Pointer through which the current number of bytes in the receive FIFO is returned. Pass NULL if this value is not required.
-
void I3C_MasterSetBaudRate(I3C_Type *base, const i3c_baudrate_hz_t *baudRate_Hz, uint32_t sourceClock_Hz)
Sets the I3C bus frequency for master transactions.
The I3C master is automatically disabled and re-enabled as necessary to configure the baud rate. Do not call this function during a transfer, or the transfer is aborted.
- Parameters:
base – The I3C peripheral base address.
baudRate_Hz – Pointer to structure of requested bus frequency in Hertz.
sourceClock_Hz – I3C functional clock frequency in Hertz.
-
static inline bool I3C_MasterGetBusIdleState(I3C_Type *base)
Returns whether the bus is idle.
Requires the master mode to be enabled.
- Parameters:
base – The I3C peripheral base address.
- Return values:
true – Bus is busy.
false – Bus is idle.
-
status_t I3C_MasterStartWithRxSize(I3C_Type *base, i3c_bus_type_t type, uint8_t address, i3c_direction_t dir, uint8_t rxSize)
Sends a START signal and slave address on the I2C/I3C bus, receive size is also specified in the call.
This function is used to initiate a new master mode transfer. First, the bus state is checked to ensure that another master is not occupying the bus. Then a START signal is transmitted, followed by the 7-bit address specified in the a address parameter. Note that this function does not actually wait until the START and address are successfully sent on the bus before returning.
- Parameters:
base – The I3C peripheral base address.
type – The bus type to use in this transaction.
address – 7-bit slave device address, in bits [6:0].
dir – Master transfer direction, either kI3C_Read or kI3C_Write. This parameter is used to set the R/w bit (bit 0) in the transmitted slave address.
rxSize – Read terminate size for the followed read transfer, limit to 255 bytes.
- Return values:
kStatus_Success – START signal and address were successfully enqueued in the transmit FIFO.
kStatus_I3C_Busy – Another master is currently utilizing the bus.
-
status_t I3C_MasterStart(I3C_Type *base, i3c_bus_type_t type, uint8_t address, i3c_direction_t dir)
Sends a START signal and slave address on the I2C/I3C bus.
This function is used to initiate a new master mode transfer. First, the bus state is checked to ensure that another master is not occupying the bus. Then a START signal is transmitted, followed by the 7-bit address specified in the address parameter. Note that this function does not actually wait until the START and address are successfully sent on the bus before returning.
- Parameters:
base – The I3C peripheral base address.
type – The bus type to use in this transaction.
address – 7-bit slave device address, in bits [6:0].
dir – Master transfer direction, either kI3C_Read or kI3C_Write. This parameter is used to set the R/w bit (bit 0) in the transmitted slave address.
- Return values:
kStatus_Success – START signal and address were successfully enqueued in the transmit FIFO.
kStatus_I3C_Busy – Another master is currently utilizing the bus.
-
status_t I3C_MasterRepeatedStartWithRxSize(I3C_Type *base, i3c_bus_type_t type, uint8_t address, i3c_direction_t dir, uint8_t rxSize)
Sends a repeated START signal and slave address on the I2C/I3C bus, receive size is also specified in the call.
This function is used to send a Repeated START signal when a transfer is already in progress. Like I3C_MasterStart(), it also sends the specified 7-bit address. Call this API also configures the read terminate size for the following read transfer. For example, set the rxSize = 2, the following read transfer will be terminated after two bytes of data received. Write transfer will not be affected by the rxSize configuration.
Note
This function exists primarily to maintain compatible APIs between I3C and I2C drivers, as well as to better document the intent of code that uses these APIs.
- Parameters:
base – The I3C peripheral base address.
type – The bus type to use in this transaction.
address – 7-bit slave device address, in bits [6:0].
dir – Master transfer direction, either kI3C_Read or kI3C_Write. This parameter is used to set the R/w bit (bit 0) in the transmitted slave address.
rxSize – Read terminate size for the followed read transfer, limit to 255 bytes.
- Return values:
kStatus_Success – Repeated START signal and address were successfully enqueued in the transmit FIFO.
-
static inline status_t I3C_MasterRepeatedStart(I3C_Type *base, i3c_bus_type_t type, uint8_t address, i3c_direction_t dir)
Sends a repeated START signal and slave address on the I2C/I3C bus.
This function is used to send a Repeated START signal when a transfer is already in progress. Like I3C_MasterStart(), it also sends the specified 7-bit address.
Note
This function exists primarily to maintain compatible APIs between I3C and I2C drivers, as well as to better document the intent of code that uses these APIs.
- Parameters:
base – The I3C peripheral base address.
type – The bus type to use in this transaction.
address – 7-bit slave device address, in bits [6:0].
dir – Master transfer direction, either kI3C_Read or kI3C_Write. This parameter is used to set the R/w bit (bit 0) in the transmitted slave address.
- Return values:
kStatus_Success – Repeated START signal and address were successfully enqueued in the transmit FIFO.
-
status_t I3C_MasterSend(I3C_Type *base, const void *txBuff, size_t txSize, uint32_t flags)
Performs a polling send transfer on the I2C/I3C bus.
Sends up to txSize number of bytes to the previously addressed slave device. The slave may reply with a NAK to any byte in order to terminate the transfer early. If this happens, this function returns kStatus_I3C_Nak.
- Parameters:
base – The I3C peripheral base address.
txBuff – The pointer to the data to be transferred.
txSize – The length in bytes of the data to be transferred.
flags – Bit mask of options for the transfer. See enumeration _i3c_master_transfer_flags for available options.
- Return values:
kStatus_Success – Data was sent successfully.
kStatus_I3C_Busy – Another master is currently utilizing the bus.
kStatus_I3C_Timeout – The module has stalled too long in a frame.
kStatus_I3C_Nak – The slave device sent a NAK in response to an address.
kStatus_I3C_WriteAbort – The slave device sent a NAK in response to a write.
kStatus_I3C_MsgError – Message SDR/DDR mismatch or read/write message in wrong state.
kStatus_I3C_WriteFifoError – Write to M/SWDATAB register when FIFO full.
kStatus_I3C_InvalidReq – Invalid use of request.
-
status_t I3C_MasterReceive(I3C_Type *base, void *rxBuff, size_t rxSize, uint32_t flags)
Performs a polling receive transfer on the I2C/I3C bus.
- Parameters:
base – The I3C peripheral base address.
rxBuff – The pointer to the data to be transferred.
rxSize – The length in bytes of the data to be transferred.
flags – Bit mask of options for the transfer. See enumeration _i3c_master_transfer_flags for available options.
- Return values:
kStatus_Success – Data was received successfully.
kStatus_I3C_Busy – Another master is currently utilizing the bus.
kStatus_I3C_Timeout – The module has stalled too long in a frame.
kStatus_I3C_Term – The master terminates slave read.
kStatus_I3C_HdrParityError – Parity error from DDR read.
kStatus_I3C_CrcError – CRC error from DDR read.
kStatus_I3C_MsgError – Message SDR/DDR mismatch or read/write message in wrong state.
kStatus_I3C_ReadFifoError – Read from M/SRDATAB register when FIFO empty.
kStatus_I3C_InvalidReq – Invalid use of request.
-
status_t I3C_MasterStop(I3C_Type *base)
Sends a STOP signal on the I2C/I3C bus.
This function does not return until the STOP signal is seen on the bus, or an error occurs.
- Parameters:
base – The I3C peripheral base address.
- Return values:
kStatus_Success – The STOP signal was successfully sent on the bus and the transaction terminated.
kStatus_I3C_Busy – Another master is currently utilizing the bus.
kStatus_I3C_Timeout – The module has stalled too long in a frame.
kStatus_I3C_InvalidReq – Invalid use of request.
-
void I3C_MasterEmitRequest(I3C_Type *base, i3c_bus_request_t masterReq)
I3C master emit request.
- Parameters:
base – The I3C peripheral base address.
masterReq – I3C master request of type i3c_bus_request_t
-
static inline void I3C_MasterEmitIBIResponse(I3C_Type *base, i3c_ibi_response_t ibiResponse)
I3C master emit request.
- Parameters:
base – The I3C peripheral base address.
ibiResponse – I3C master emit IBI response of type i3c_ibi_response_t
-
void I3C_MasterRegisterIBI(I3C_Type *base, i3c_register_ibi_addr_t *ibiRule)
I3C master register IBI rule.
- Parameters:
base – The I3C peripheral base address.
ibiRule – Pointer to ibi rule description of type i3c_register_ibi_addr_t
-
void I3C_MasterGetIBIRules(I3C_Type *base, i3c_register_ibi_addr_t *ibiRule)
I3C master get IBI rule.
- Parameters:
base – The I3C peripheral base address.
ibiRule – Pointer to store the read out ibi rule description.
-
i3c_ibi_type_t I3C_GetIBIType(I3C_Type *base)
I3C master get IBI Type.
- Parameters:
base – The I3C peripheral base address.
- Return values:
i3c_ibi_type_t – Type of i3c_ibi_type_t.
-
static inline uint8_t I3C_GetIBIAddress(I3C_Type *base)
I3C master get IBI Address.
- Parameters:
base – The I3C peripheral base address.
- Return values:
The – 8-bit IBI address.
-
status_t I3C_MasterProcessDAASpecifiedBaudrate(I3C_Type *base, uint8_t *addressList, uint32_t count, i3c_master_daa_baudrate_t *daaBaudRate)
Performs a DAA in the i3c bus with specified temporary baud rate.
- Parameters:
base – The I3C peripheral base address.
addressList – The pointer for address list which is used to do DAA.
count – The address count in the address list.
daaBaudRate – The temporary baud rate in DAA process, NULL for using initial setting. The initial setting is set back between the completion of the DAA and the return of this function.
- Return values:
kStatus_Success – The transaction was started successfully.
kStatus_I3C_Busy – Either another master is currently utilizing the bus, or a non-blocking transaction is already in progress.
kStatus_I3C_SlaveCountExceed – The I3C slave count has exceed the definition in I3C_MAX_DEVCNT.
-
static inline status_t I3C_MasterProcessDAA(I3C_Type *base, uint8_t *addressList, uint32_t count)
Performs a DAA in the i3c bus.
- Parameters:
base – The I3C peripheral base address.
addressList – The pointer for address list which is used to do DAA.
count – The address count in the address list. The initial setting is set back between the completion of the DAA and the return of this function.
- Return values:
kStatus_Success – The transaction was started successfully.
kStatus_I3C_Busy – Either another master is currently utilizing the bus, or a non-blocking transaction is already in progress.
kStatus_I3C_SlaveCountExceed – The I3C slave count has exceed the definition in I3C_MAX_DEVCNT.
-
i3c_device_info_t *I3C_MasterGetDeviceListAfterDAA(I3C_Type *base, uint8_t *count)
Get device information list after DAA process is done.
- Parameters:
base – The I3C peripheral base address.
count – [out] The pointer to store the available device count.
- Returns:
Pointer to the i3c_device_info_t array.
-
void I3C_MasterClearDeviceCount(I3C_Type *base)
Clear the global device count which represents current devices number on the bus. When user resets all dynamic addresses on the bus, should call this API.
- Parameters:
base – The I3C peripheral base address.
-
status_t I3C_MasterTransferBlocking(I3C_Type *base, i3c_master_transfer_t *transfer)
Performs a master polling transfer on the I2C/I3C bus.
Note
The API does not return until the transfer succeeds or fails due to error happens during transfer.
- Parameters:
base – The I3C peripheral base address.
transfer – Pointer to the transfer structure.
- Return values:
kStatus_Success – Data was received successfully.
kStatus_I3C_Busy – Another master is currently utilizing the bus.
kStatus_I3C_IBIWon – The I3C slave event IBI or MR or HJ won the arbitration on a header address.
kStatus_I3C_Timeout – The module has stalled too long in a frame.
kStatus_I3C_Nak – The slave device sent a NAK in response to an address.
kStatus_I3C_WriteAbort – The slave device sent a NAK in response to a write.
kStatus_I3C_Term – The master terminates slave read.
kStatus_I3C_HdrParityError – Parity error from DDR read.
kStatus_I3C_CrcError – CRC error from DDR read.
kStatus_I3C_MsgError – Message SDR/DDR mismatch or read/write message in wrong state.
kStatus_I3C_ReadFifoError – Read from M/SRDATAB register when FIFO empty.
kStatus_I3C_WriteFifoError – Write to M/SWDATAB register when FIFO full.
kStatus_I3C_InvalidReq – Invalid use of request.
-
status_t I3C_SlaveSend(I3C_Type *base, const void *txBuff, size_t txSize)
Performs a polling send transfer on the I3C bus.
- Parameters:
base – The I3C peripheral base address.
txBuff – The pointer to the data to be transferred.
txSize – The length in bytes of the data to be transferred.
- Returns:
Error or success status returned by API.
-
status_t I3C_SlaveReceive(I3C_Type *base, void *rxBuff, size_t rxSize)
Performs a polling receive transfer on the I3C bus.
- Parameters:
base – The I3C peripheral base address.
rxBuff – The pointer to the data to be transferred.
rxSize – The length in bytes of the data to be transferred.
- Returns:
Error or success status returned by API.
-
void I3C_MasterTransferCreateHandle(I3C_Type *base, i3c_master_handle_t *handle, const i3c_master_transfer_callback_t *callback, void *userData)
Creates a new handle for the I3C master non-blocking APIs.
The creation of a handle is for use with the non-blocking APIs. Once a handle is created, there is not a corresponding destroy handle. If the user wants to terminate a transfer, the I3C_MasterTransferAbort() API shall be called.
Note
The function also enables the NVIC IRQ for the input I3C. Need to notice that on some SoCs the I3C IRQ is connected to INTMUX, in this case user needs to enable the associated INTMUX IRQ in application.
- Parameters:
base – The I3C peripheral base address.
handle – [out] Pointer to the I3C master driver handle.
callback – User provided pointer to the asynchronous callback function.
userData – User provided pointer to the application callback data.
-
status_t I3C_MasterTransferNonBlocking(I3C_Type *base, i3c_master_handle_t *handle, i3c_master_transfer_t *transfer)
Performs a non-blocking transaction on the I2C/I3C bus.
- Parameters:
base – The I3C peripheral base address.
handle – Pointer to the I3C master driver handle.
transfer – The pointer to the transfer descriptor.
- Return values:
kStatus_Success – The transaction was started successfully.
kStatus_I3C_Busy – Either another master is currently utilizing the bus, or a non-blocking transaction is already in progress.
-
status_t I3C_MasterTransferGetCount(I3C_Type *base, i3c_master_handle_t *handle, size_t *count)
Returns number of bytes transferred so far.
- Parameters:
base – The I3C peripheral base address.
handle – Pointer to the I3C master driver handle.
count – [out] Number of bytes transferred so far by the non-blocking transaction.
- Return values:
kStatus_Success –
kStatus_NoTransferInProgress – There is not a non-blocking transaction currently in progress.
-
void I3C_MasterTransferAbort(I3C_Type *base, i3c_master_handle_t *handle)
Terminates a non-blocking I3C master transmission early.
Note
It is not safe to call this function from an IRQ handler that has a higher priority than the I3C peripheral’s IRQ priority.
- Parameters:
base – The I3C peripheral base address.
handle – Pointer to the I3C master driver handle.
- Return values:
kStatus_Success – A transaction was successfully aborted.
kStatus_I3C_Idle – There is not a non-blocking transaction currently in progress.
-
void I3C_MasterTransferHandleIRQ(I3C_Type *base, void *intHandle)
Reusable routine to handle master interrupts.
Note
This function does not need to be called unless you are reimplementing the nonblocking API’s interrupt handler routines to add special functionality.
- Parameters:
base – The I3C peripheral base address.
intHandle – Pointer to the I3C master driver handle.
-
enum _i3c_master_flags
I3C master peripheral flags.
The following status register flags can be cleared:
kI3C_MasterSlaveStartFlag
kI3C_MasterControlDoneFlag
kI3C_MasterCompleteFlag
kI3C_MasterArbitrationWonFlag
kI3C_MasterSlave2MasterFlag
All flags except kI3C_MasterBetweenFlag and kI3C_MasterNackDetectFlag can be enabled as interrupts.
Note
These enums are meant to be OR’d together to form a bit mask.
Values:
-
enumerator kI3C_MasterBetweenFlag
Between messages/DAAs flag
-
enumerator kI3C_MasterNackDetectFlag
NACK detected flag
-
enumerator kI3C_MasterSlaveStartFlag
Slave request start flag
-
enumerator kI3C_MasterControlDoneFlag
Master request complete flag
-
enumerator kI3C_MasterCompleteFlag
Transfer complete flag
-
enumerator kI3C_MasterRxReadyFlag
Rx data ready in Rx buffer flag
-
enumerator kI3C_MasterTxReadyFlag
Tx buffer ready for Tx data flag
-
enumerator kI3C_MasterArbitrationWonFlag
Header address won arbitration flag
-
enumerator kI3C_MasterErrorFlag
Error occurred flag
-
enumerator kI3C_MasterSlave2MasterFlag
Switch from slave to master flag
-
enumerator kI3C_MasterClearFlags
-
enum _i3c_master_error_flags
I3C master error flags to indicate the causes.
Note
These enums are meant to be OR’d together to form a bit mask.
Values:
-
enumerator kI3C_MasterErrorNackFlag
Slave NACKed the last address
-
enumerator kI3C_MasterErrorWriteAbortFlag
Slave NACKed the write data
-
enumerator kI3C_MasterErrorParityFlag
Parity error from DDR read
-
enumerator kI3C_MasterErrorCrcFlag
CRC error from DDR read
-
enumerator kI3C_MasterErrorReadFlag
Read from MRDATAB register when FIFO empty
-
enumerator kI3C_MasterErrorWriteFlag
Write to MWDATAB register when FIFO full
-
enumerator kI3C_MasterErrorMsgFlag
Message SDR/DDR mismatch or read/write message in wrong state
-
enumerator kI3C_MasterErrorInvalidReqFlag
Invalid use of request
-
enumerator kI3C_MasterErrorTimeoutFlag
The module has stalled too long in a frame
-
enumerator kI3C_MasterAllErrorFlags
All error flags
-
enumerator kI3C_MasterErrorNackFlag
-
enum _i3c_master_state
I3C working master state.
Values:
-
enumerator kI3C_MasterStateIdle
Bus stopped.
-
enumerator kI3C_MasterStateSlvReq
Bus stopped but slave holding SDA low.
-
enumerator kI3C_MasterStateMsgSdr
In SDR Message mode from using MWMSG_SDR.
-
enumerator kI3C_MasterStateNormAct
In normal active SDR mode.
-
enumerator kI3C_MasterStateDdr
In DDR Message mode.
-
enumerator kI3C_MasterStateDaa
In ENTDAA mode.
-
enumerator kI3C_MasterStateIbiAck
Waiting on IBI ACK/NACK decision.
-
enumerator kI3C_MasterStateIbiRcv
Receiving IBI.
-
enumerator kI3C_MasterStateIdle
-
enum _i3c_master_enable
I3C master enable configuration.
Values:
-
enumerator kI3C_MasterOff
Master off.
-
enumerator kI3C_MasterOn
Master on.
-
enumerator kI3C_MasterCapable
Master capable.
-
enumerator kI3C_MasterOff
-
enum _i3c_master_hkeep
I3C high keeper configuration.
Values:
-
enumerator kI3C_MasterHighKeeperNone
Use PUR to hold SCL high.
-
enumerator kI3C_MasterHighKeeperWiredIn
Use pin_HK controls.
-
enumerator kI3C_MasterPassiveSDA
Hi-Z for Bus Free and hold SDA.
-
enumerator kI3C_MasterPassiveSDASCL
Hi-Z both for Bus Free, and can Hi-Z SDA for hold.
-
enumerator kI3C_MasterHighKeeperNone
-
enum _i3c_bus_request
Emits the requested operation when doing in pieces vs. by message.
Values:
-
enumerator kI3C_RequestNone
No request.
-
enumerator kI3C_RequestEmitStartAddr
Request to emit start and address on bus.
-
enumerator kI3C_RequestEmitStop
Request to emit stop on bus.
-
enumerator kI3C_RequestIbiAckNack
Manual IBI ACK or NACK.
-
enumerator kI3C_RequestProcessDAA
Process DAA.
-
enumerator kI3C_RequestForceExit
Request to force exit.
-
enumerator kI3C_RequestAutoIbi
Hold in stopped state, but Auto-emit START,7E.
-
enumerator kI3C_RequestNone
-
enum _i3c_bus_type
Bus type with EmitStartAddr.
Values:
-
enumerator kI3C_TypeI3CSdr
SDR mode of I3C.
-
enumerator kI3C_TypeI2C
Standard i2c protocol.
-
enumerator kI3C_TypeI3CDdr
HDR-DDR mode of I3C.
-
enumerator kI3C_TypeI3CSdr
-
enum _i3c_ibi_response
IBI response.
Values:
-
enumerator kI3C_IbiRespAck
ACK with no mandatory byte.
-
enumerator kI3C_IbiRespNack
NACK.
-
enumerator kI3C_IbiRespAckMandatory
ACK with mandatory byte.
-
enumerator kI3C_IbiRespManual
Reserved.
-
enumerator kI3C_IbiRespAck
-
enum _i3c_ibi_type
IBI type.
Values:
-
enumerator kI3C_IbiNormal
In-band interrupt.
-
enumerator kI3C_IbiHotJoin
slave hot join.
-
enumerator kI3C_IbiMasterRequest
slave master ship request.
-
enumerator kI3C_IbiNormal
-
enum _i3c_ibi_state
IBI state.
Values:
-
enumerator kI3C_IbiReady
In-band interrupt ready state, ready for user to handle.
-
enumerator kI3C_IbiDataBuffNeed
In-band interrupt need data buffer for data receive.
-
enumerator kI3C_IbiAckNackPending
In-band interrupt Ack/Nack pending for decision.
-
enumerator kI3C_IbiReady
-
enum _i3c_direction
Direction of master and slave transfers.
Values:
-
enumerator kI3C_Write
Master transmit.
-
enumerator kI3C_Read
Master receive.
-
enumerator kI3C_Write
-
enum _i3c_tx_trigger_level
Watermark of TX int/dma trigger level.
Values:
-
enumerator kI3C_TxTriggerOnEmpty
Trigger on empty.
-
enumerator kI3C_TxTriggerUntilOneQuarterOrLess
Trigger on 1/4 full or less.
-
enumerator kI3C_TxTriggerUntilOneHalfOrLess
Trigger on 1/2 full or less.
-
enumerator kI3C_TxTriggerUntilOneLessThanFull
Trigger on 1 less than full or less.
-
enumerator kI3C_TxTriggerOnEmpty
-
enum _i3c_rx_trigger_level
Watermark of RX int/dma trigger level.
Values:
-
enumerator kI3C_RxTriggerOnNotEmpty
Trigger on not empty.
-
enumerator kI3C_RxTriggerUntilOneQuarterOrMore
Trigger on 1/4 full or more.
-
enumerator kI3C_RxTriggerUntilOneHalfOrMore
Trigger on 1/2 full or more.
-
enumerator kI3C_RxTriggerUntilThreeQuarterOrMore
Trigger on 3/4 full or more.
-
enumerator kI3C_RxTriggerOnNotEmpty
-
enum _i3c_rx_term_ops
I3C master read termination operations.
Values:
-
enumerator kI3C_RxTermDisable
Master doesn’t terminate read, used for CCC transfer.
-
enumerator kI3C_RxAutoTerm
Master auto terminate read after receiving specified bytes(<=255).
-
enumerator kI3C_RxTermLastByte
Master terminates read at any time after START, no length limitation.
-
enumerator kI3C_RxTermDisable
-
enum _i3c_start_scl_delay
I3C start SCL delay options.
Values:
-
enumerator kI3C_NoDelay
No delay.
-
enumerator kI3C_IncreaseSclHalfPeriod
Increases SCL clock period by 1/2.
-
enumerator kI3C_IncreaseSclOnePeriod
Increases SCL clock period by 1.
-
enumerator kI3C_IncreaseSclOneAndHalfPeriod
Increases SCL clock period by 1 1/2
-
enumerator kI3C_NoDelay
-
enum _i3c_master_transfer_flags
Transfer option flags.
Note
These enumerations are intended to be OR’d together to form a bit mask of options for the _i3c_master_transfer::flags field.
Values:
-
enumerator kI3C_TransferDefaultFlag
Transfer starts with a start signal, stops with a stop signal.
-
enumerator kI3C_TransferNoStartFlag
Don’t send a start condition, address, and sub address
-
enumerator kI3C_TransferRepeatedStartFlag
Send a repeated start condition
-
enumerator kI3C_TransferNoStopFlag
Don’t send a stop condition.
-
enumerator kI3C_TransferWordsFlag
Transfer in words, else transfer in bytes.
-
enumerator kI3C_TransferDisableRxTermFlag
Disable Rx termination. Note: It’s for I3C CCC transfer.
-
enumerator kI3C_TransferRxAutoTermFlag
Set Rx auto-termination. Note: It’s adaptive based on Rx size(<=255 bytes) except in I3C_MasterReceive.
-
enumerator kI3C_TransferStartWithBroadcastAddr
Start transfer with 0x7E, then read/write data with device address.
-
enumerator kI3C_TransferDefaultFlag
-
typedef enum _i3c_master_state i3c_master_state_t
I3C working master state.
-
typedef enum _i3c_master_enable i3c_master_enable_t
I3C master enable configuration.
-
typedef enum _i3c_master_hkeep i3c_master_hkeep_t
I3C high keeper configuration.
-
typedef enum _i3c_bus_request i3c_bus_request_t
Emits the requested operation when doing in pieces vs. by message.
-
typedef enum _i3c_bus_type i3c_bus_type_t
Bus type with EmitStartAddr.
-
typedef enum _i3c_ibi_response i3c_ibi_response_t
IBI response.
-
typedef enum _i3c_ibi_type i3c_ibi_type_t
IBI type.
-
typedef enum _i3c_ibi_state i3c_ibi_state_t
IBI state.
-
typedef enum _i3c_direction i3c_direction_t
Direction of master and slave transfers.
-
typedef enum _i3c_tx_trigger_level i3c_tx_trigger_level_t
Watermark of TX int/dma trigger level.
-
typedef enum _i3c_rx_trigger_level i3c_rx_trigger_level_t
Watermark of RX int/dma trigger level.
-
typedef enum _i3c_rx_term_ops i3c_rx_term_ops_t
I3C master read termination operations.
-
typedef enum _i3c_start_scl_delay i3c_start_scl_delay_t
I3C start SCL delay options.
-
typedef struct _i3c_register_ibi_addr i3c_register_ibi_addr_t
Structure with setting master IBI rules and slave registry.
-
typedef struct _i3c_baudrate i3c_baudrate_hz_t
Structure with I3C baudrate settings.
-
typedef struct _i3c_master_daa_baudrate i3c_master_daa_baudrate_t
I3C DAA baud rate configuration.
-
typedef struct _i3c_master_config i3c_master_config_t
Structure with settings to initialize the I3C master module.
This structure holds configuration settings for the I3C peripheral. To initialize this structure to reasonable defaults, call the I3C_MasterGetDefaultConfig() function and pass a pointer to your configuration structure instance.
The configuration structure can be made constant so it resides in flash.
-
typedef struct _i3c_master_transfer i3c_master_transfer_t
-
typedef struct _i3c_master_handle i3c_master_handle_t
-
typedef struct _i3c_master_transfer_callback i3c_master_transfer_callback_t
i3c master callback functions.
-
typedef void (*i3c_master_isr_t)(I3C_Type *base, void *handle)
Typedef for master interrupt handler.
-
struct _i3c_register_ibi_addr
- #include <fsl_i3c.h>
Structure with setting master IBI rules and slave registry.
Public Members
-
uint8_t address[5]
Address array for registry.
-
bool ibiHasPayload
Whether the address array has mandatory IBI byte.
-
uint8_t address[5]
-
struct _i3c_baudrate
- #include <fsl_i3c.h>
Structure with I3C baudrate settings.
Public Members
-
uint32_t i2cBaud
Desired I2C baud rate in Hertz.
-
uint32_t i3cPushPullBaud
Desired I3C push-pull baud rate in Hertz.
-
uint32_t i3cOpenDrainBaud
Desired I3C open-drain baud rate in Hertz.
-
uint32_t i2cBaud
-
struct _i3c_master_daa_baudrate
- #include <fsl_i3c.h>
I3C DAA baud rate configuration.
Public Members
-
uint32_t sourceClock_Hz
FCLK, function clock in Hertz.
-
uint32_t i3cPushPullBaud
Desired I3C push-pull baud rate in Hertz.
-
uint32_t i3cOpenDrainBaud
Desired I3C open-drain baud rate in Hertz.
-
uint32_t sourceClock_Hz
-
struct _i3c_master_config
- #include <fsl_i3c.h>
Structure with settings to initialize the I3C master module.
This structure holds configuration settings for the I3C peripheral. To initialize this structure to reasonable defaults, call the I3C_MasterGetDefaultConfig() function and pass a pointer to your configuration structure instance.
The configuration structure can be made constant so it resides in flash.
Public Members
-
i3c_master_enable_t enableMaster
Enable master mode.
-
bool disableTimeout
Whether to disable timeout to prevent the ERRWARN.
-
i3c_master_hkeep_t hKeep
High keeper mode setting.
-
bool enableOpenDrainStop
Whether to emit open-drain speed STOP.
-
bool enableOpenDrainHigh
Enable Open-Drain High to be 1 PPBAUD count for i3c messages, or 1 ODBAUD.
-
i3c_baudrate_hz_t baudRate_Hz
Desired baud rate settings.
-
i3c_master_enable_t enableMaster
-
struct _i3c_master_transfer_callback
- #include <fsl_i3c.h>
i3c master callback functions.
Public Members
-
void (*slave2Master)(I3C_Type *base, void *userData)
Transfer complete callback
-
void (*ibiCallback)(I3C_Type *base, i3c_master_handle_t *handle, i3c_ibi_type_t ibiType, i3c_ibi_state_t ibiState)
IBI event callback
-
void (*transferComplete)(I3C_Type *base, i3c_master_handle_t *handle, status_t completionStatus, void *userData)
Transfer complete callback
-
void (*slave2Master)(I3C_Type *base, void *userData)
-
struct _i3c_master_transfer
- #include <fsl_i3c.h>
Non-blocking transfer descriptor structure.
This structure is used to pass transaction parameters to the I3C_MasterTransferNonBlocking() API.
Public Members
-
uint32_t flags
Bit mask of options for the transfer. See enumeration _i3c_master_transfer_flags for available options. Set to 0 or kI3C_TransferDefaultFlag for normal transfers.
-
uint8_t slaveAddress
The 7-bit slave address.
-
i3c_direction_t direction
Either kI3C_Read or kI3C_Write.
-
uint32_t subaddress
Sub address. Transferred MSB first.
-
size_t subaddressSize
Length of sub address to send in bytes. Maximum size is 4 bytes.
-
void *data
Pointer to data to transfer.
-
size_t dataSize
Number of bytes to transfer.
-
i3c_bus_type_t busType
bus type.
-
i3c_ibi_response_t ibiResponse
ibi response during transfer.
-
uint32_t flags
-
struct _i3c_master_handle
- #include <fsl_i3c.h>
Driver handle for master non-blocking APIs.
Note
The contents of this structure are private and subject to change.
Public Members
-
uint8_t state
Transfer state machine current state.
-
uint32_t remainingBytes
Remaining byte count in current state.
-
i3c_rx_term_ops_t rxTermOps
Read termination operation.
-
i3c_master_transfer_t transfer
Copy of the current transfer info.
-
uint8_t ibiAddress
Slave address which request IBI.
-
uint8_t *ibiBuff
Pointer to IBI buffer to keep ibi bytes.
-
size_t ibiPayloadSize
IBI payload size.
-
i3c_ibi_type_t ibiType
IBI type.
-
i3c_master_transfer_callback_t callback
Callback functions pointer.
-
void *userData
Application data passed to callback.
-
uint8_t state
I3C Slave DMA Driver
-
void I3C_SlaveTransferCreateHandleDMA(I3C_Type *base, i3c_slave_dma_handle_t *handle, i3c_slave_dma_callback_t callback, void *userData, dma_handle_t *rxDmaHandle, dma_handle_t *txDmaHandle)
Create a new handle for the I3C slave DMA APIs.
The creation of a handle is for use with the DMA APIs. Once a handle is created, there is not a corresponding destroy handle. If the user wants to terminate a transfer, the I3C_SlaveTransferAbortDMA() API shall be called.
For devices where the I3C send and receive DMA requests are OR’d together, the txDmaHandle parameter is ignored and may be set to NULL.
- Parameters:
base – The I3C peripheral base address.
handle – Pointer to the I3C slave driver handle.
callback – User provided pointer to the asynchronous callback function.
userData – User provided pointer to the application callback data.
rxDmaHandle – Handle for the DMA receive channel. Created by the user prior to calling this function.
txDmaHandle – Handle for the DMA transmit channel. Created by the user prior to calling this function.
-
status_t I3C_SlaveTransferDMA(I3C_Type *base, i3c_slave_dma_handle_t *handle, i3c_slave_dma_transfer_t *transfer, uint32_t eventMask)
Prepares for a non-blocking DMA-based transaction on the I3C bus.
The API will do DMA configuration according to the input transfer descriptor, and the data will be transferred when there’s bus master requesting transfer from/to this slave. So the timing of call to this API need be aligned with master application to ensure the transfer is executed as expected. Callback specified when the handle was created is invoked when the transaction has completed.
- Parameters:
base – The I3C peripheral base address.
handle – Pointer to the I3C slave driver handle.
transfer – The pointer to the transfer descriptor.
eventMask – Bit mask formed by OR’ing together i3c_slave_transfer_event_t enumerators to specify which events to send to the callback. The transmit and receive events is not allowed to be enabled.
- Return values:
kStatus_Success – The transaction was started successfully.
kStatus_I3C_Busy – Either another master is currently utilizing the bus, or another DMA transaction is already in progress.
-
void I3C_SlaveTransferAbortDMA(I3C_Type *base, i3c_slave_dma_handle_t *handle)
Abort a slave dma non-blocking transfer in a early time.
- Parameters:
base – I3C peripheral base address
handle – pointer to i3c_slave_dma_handle_t structure
-
void I3C_SlaveTransferDMAHandleIRQ(I3C_Type *base, void *i3cHandle)
Reusable routine to handle slave interrupts.
Note
This function does not need to be called unless you are reimplementing the nonblocking API’s interrupt handler routines to add special functionality.
- Parameters:
base – The I3C peripheral base address.
handle – Pointer to the I3C slave DMA driver handle.
-
typedef struct _i3c_slave_dma_handle i3c_slave_dma_handle_t
-
typedef struct _i3c_slave_dma_transfer i3c_slave_dma_transfer_t
I3C slave transfer structure.
-
typedef void (*i3c_slave_dma_callback_t)(I3C_Type *base, i3c_slave_dma_transfer_t *transfer, void *userData)
Slave event callback function pointer type.
This callback is used only for the slave DMA transfer API.
- Param base:
Base address for the I3C instance on which the event occurred.
- Param handle:
Pointer to slave DMA transfer handle.
- Param transfer:
Pointer to transfer descriptor containing values passed to and/or from the callback.
- Param userData:
Arbitrary pointer-sized value passed from the application.
-
struct _i3c_slave_dma_transfer
- #include <fsl_i3c_dma.h>
I3C slave transfer structure.
-
struct _i3c_slave_dma_handle
- #include <fsl_i3c_dma.h>
I3C slave dma handle structure.
Note
The contents of this structure are private and subject to change.
I3C Slave Driver
-
void I3C_SlaveGetDefaultConfig(i3c_slave_config_t *slaveConfig)
Provides a default configuration for the I3C slave peripheral.
This function provides the following default configuration for the I3C slave peripheral:
slaveConfig->enableslave = true;
After calling this function, you can override any settings in order to customize the configuration, prior to initializing the slave driver with I3C_SlaveInit().
- Parameters:
slaveConfig – [out] User provided configuration structure for default values. Refer to i3c_slave_config_t.
-
void I3C_SlaveInit(I3C_Type *base, const i3c_slave_config_t *slaveConfig, uint32_t slowClock_Hz)
Initializes the I3C slave peripheral.
This function enables the peripheral clock and initializes the I3C slave peripheral as described by the user provided configuration.
- Parameters:
base – The I3C peripheral base address.
slaveConfig – User provided peripheral configuration. Use I3C_SlaveGetDefaultConfig() to get a set of defaults that you can override.
slowClock_Hz – Frequency in Hertz of the I3C slow clock. Used to calculate the bus match condition values. If FSL_FEATURE_I3C_HAS_NO_SCONFIG_BAMATCH defines as 1, this parameter is useless.
-
void I3C_SlaveDeinit(I3C_Type *base)
Deinitializes the I3C slave peripheral.
This function disables the I3C slave peripheral and gates the clock.
- Parameters:
base – The I3C peripheral base address.
-
static inline void I3C_SlaveEnable(I3C_Type *base, bool isEnable)
Enable/Disable Slave.
- Parameters:
base – The I3C peripheral base address.
isEnable – Enable or disable.
-
static inline uint32_t I3C_SlaveGetStatusFlags(I3C_Type *base)
Gets the I3C slave status flags.
A bit mask with the state of all I3C slave status flags is returned. For each flag, the corresponding bit in the return value is set if the flag is asserted.
See also
_i3c_slave_flags
- Parameters:
base – The I3C peripheral base address.
- Returns:
State of the status flags:
1: related status flag is set.
0: related status flag is not set.
-
static inline void I3C_SlaveClearStatusFlags(I3C_Type *base, uint32_t statusMask)
Clears the I3C slave status flag state.
The following status register flags can be cleared:
kI3C_SlaveBusStartFlag
kI3C_SlaveMatchedFlag
kI3C_SlaveBusStopFlag
Attempts to clear other flags has no effect.
See also
_i3c_slave_flags.
- Parameters:
base – The I3C peripheral base address.
statusMask – A bitmask of status flags that are to be cleared. The mask is composed of _i3c_slave_flags enumerators OR’d together. You may pass the result of a previous call to I3C_SlaveGetStatusFlags().
-
static inline uint32_t I3C_SlaveGetErrorStatusFlags(I3C_Type *base)
Gets the I3C slave error status flags.
A bit mask with the state of all I3C slave error status flags is returned. For each flag, the corresponding bit in the return value is set if the flag is asserted.
See also
_i3c_slave_error_flags
- Parameters:
base – The I3C peripheral base address.
- Returns:
State of the error status flags:
1: related status flag is set.
0: related status flag is not set.
-
static inline void I3C_SlaveClearErrorStatusFlags(I3C_Type *base, uint32_t statusMask)
Clears the I3C slave error status flag state.
See also
_i3c_slave_error_flags.
- Parameters:
base – The I3C peripheral base address.
statusMask – A bitmask of error status flags that are to be cleared. The mask is composed of _i3c_slave_error_flags enumerators OR’d together. You may pass the result of a previous call to I3C_SlaveGetErrorStatusFlags().
-
i3c_slave_activity_state_t I3C_SlaveGetActivityState(I3C_Type *base)
Gets the I3C slave state.
- Parameters:
base – The I3C peripheral base address.
- Returns:
I3C slave activity state, refer i3c_slave_activity_state_t.
-
status_t I3C_SlaveCheckAndClearError(I3C_Type *base, uint32_t status)
-
static inline void I3C_SlaveEnableInterrupts(I3C_Type *base, uint32_t interruptMask)
Enables the I3C slave interrupt requests.
Only below flags can be enabled as interrupts.
kI3C_SlaveBusStartFlag
kI3C_SlaveMatchedFlag
kI3C_SlaveBusStopFlag
kI3C_SlaveRxReadyFlag
kI3C_SlaveTxReadyFlag
kI3C_SlaveDynamicAddrChangedFlag
kI3C_SlaveReceivedCCCFlag
kI3C_SlaveErrorFlag
kI3C_SlaveHDRCommandMatchFlag
kI3C_SlaveCCCHandledFlag
kI3C_SlaveEventSentFlag
- Parameters:
base – The I3C peripheral base address.
interruptMask – Bit mask of interrupts to enable. See _i3c_slave_flags for the set of constants that should be OR’d together to form the bit mask.
-
static inline void I3C_SlaveDisableInterrupts(I3C_Type *base, uint32_t interruptMask)
Disables the I3C slave interrupt requests.
Only below flags can be disabled as interrupts.
kI3C_SlaveBusStartFlag
kI3C_SlaveMatchedFlag
kI3C_SlaveBusStopFlag
kI3C_SlaveRxReadyFlag
kI3C_SlaveTxReadyFlag
kI3C_SlaveDynamicAddrChangedFlag
kI3C_SlaveReceivedCCCFlag
kI3C_SlaveErrorFlag
kI3C_SlaveHDRCommandMatchFlag
kI3C_SlaveCCCHandledFlag
kI3C_SlaveEventSentFlag
- Parameters:
base – The I3C peripheral base address.
interruptMask – Bit mask of interrupts to disable. See _i3c_slave_flags for the set of constants that should be OR’d together to form the bit mask.
-
static inline uint32_t I3C_SlaveGetEnabledInterrupts(I3C_Type *base)
Returns the set of currently enabled I3C slave interrupt requests.
- Parameters:
base – The I3C peripheral base address.
- Returns:
A bitmask composed of _i3c_slave_flags enumerators OR’d together to indicate the set of enabled interrupts.
-
static inline uint32_t I3C_SlaveGetPendingInterrupts(I3C_Type *base)
Returns the set of pending I3C slave interrupt requests.
- Parameters:
base – The I3C peripheral base address.
- Returns:
A bitmask composed of _i3c_slave_flags enumerators OR’d together to indicate the set of pending interrupts.
-
static inline void I3C_SlaveEnableDMA(I3C_Type *base, bool enableTx, bool enableRx, uint32_t width)
Enables or disables I3C slave DMA requests.
- Parameters:
base – The I3C peripheral base address.
enableTx – Enable flag for transmit DMA request. Pass true for enable, false for disable.
enableRx – Enable flag for receive DMA request. Pass true for enable, false for disable.
width – DMA read/write unit in bytes.
-
static inline uint32_t I3C_SlaveGetTxFifoAddress(I3C_Type *base, uint32_t width)
Gets I3C slave transmit data register address for DMA transfer.
- Parameters:
base – The I3C peripheral base address.
width – DMA read/write unit in bytes.
- Returns:
The I3C Slave Transmit Data Register address.
-
static inline uint32_t I3C_SlaveGetRxFifoAddress(I3C_Type *base, uint32_t width)
Gets I3C slave receive data register address for DMA transfer.
- Parameters:
base – The I3C peripheral base address.
width – DMA read/write unit in bytes.
- Returns:
The I3C Slave Receive Data Register address.
-
static inline void I3C_SlaveSetWatermarks(I3C_Type *base, i3c_tx_trigger_level_t txLvl, i3c_rx_trigger_level_t rxLvl, bool flushTx, bool flushRx)
Sets the watermarks for I3C slave FIFOs.
- Parameters:
base – The I3C peripheral base address.
txLvl – Transmit FIFO watermark level. The kI3C_SlaveTxReadyFlag flag is set whenever the number of words in the transmit FIFO reaches txLvl.
rxLvl – Receive FIFO watermark level. The kI3C_SlaveRxReadyFlag flag is set whenever the number of words in the receive FIFO reaches rxLvl.
flushTx – true if TX FIFO is to be cleared, otherwise TX FIFO remains unchanged.
flushRx – true if RX FIFO is to be cleared, otherwise RX FIFO remains unchanged.
-
static inline void I3C_SlaveGetFifoCounts(I3C_Type *base, size_t *rxCount, size_t *txCount)
Gets the current number of bytes in the I3C slave FIFOs.
- Parameters:
base – The I3C peripheral base address.
txCount – [out] Pointer through which the current number of bytes in the transmit FIFO is returned. Pass NULL if this value is not required.
rxCount – [out] Pointer through which the current number of bytes in the receive FIFO is returned. Pass NULL if this value is not required.
-
status_t I3C_SlaveSend(I3C_Type *base, const void *txBuff, size_t txSize)
Performs a polling send transfer on the I3C bus.
- Parameters:
base – The I3C peripheral base address.
txBuff – The pointer to the data to be transferred.
txSize – The length in bytes of the data to be transferred.
- Returns:
Error or success status returned by API.
-
status_t I3C_SlaveReceive(I3C_Type *base, void *rxBuff, size_t rxSize)
Performs a polling receive transfer on the I3C bus.
- Parameters:
base – The I3C peripheral base address.
rxBuff – The pointer to the data to be transferred.
rxSize – The length in bytes of the data to be transferred.
- Returns:
Error or success status returned by API.
-
void I3C_SlaveTransferCreateHandle(I3C_Type *base, i3c_slave_handle_t *handle, i3c_slave_transfer_callback_t callback, void *userData)
Creates a new handle for the I3C slave non-blocking APIs.
The creation of a handle is for use with the non-blocking APIs. Once a handle is created, there is not a corresponding destroy handle. If the user wants to terminate a transfer, the I3C_SlaveTransferAbort() API shall be called.
Note
The function also enables the NVIC IRQ for the input I3C. Need to notice that on some SoCs the I3C IRQ is connected to INTMUX, in this case user needs to enable the associated INTMUX IRQ in application.
- Parameters:
base – The I3C peripheral base address.
handle – [out] Pointer to the I3C slave driver handle.
callback – User provided pointer to the asynchronous callback function.
userData – User provided pointer to the application callback data.
-
status_t I3C_SlaveTransferNonBlocking(I3C_Type *base, i3c_slave_handle_t *handle, uint32_t eventMask)
Starts accepting slave transfers.
Call this API after calling I2C_SlaveInit() and I3C_SlaveTransferCreateHandle() to start processing transactions driven by an I2C master. The slave monitors the I2C bus and pass events to the callback that was passed into the call to I3C_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 i3c_slave_transfer_event_t enumerators for the events you wish to receive. The kI3C_SlaveTransmitEvent and kI3C_SlaveReceiveEvent events are always enabled and do not need to be included in the mask. Alternatively, you can pass 0 to get a default set of only the transmit and receive events that are always enabled. In addition, the kI3C_SlaveAllEvents constant is provided as a convenient way to enable all events.
- Parameters:
base – The I3C peripheral base address.
handle – Pointer to struct: _i3c_slave_handle structure which stores the transfer state.
eventMask – Bit mask formed by OR’ing together i3c_slave_transfer_event_t enumerators to specify 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 kI3C_SlaveAllEvents to enable all events.
- Return values:
kStatus_Success – Slave transfers were successfully started.
kStatus_I3C_Busy – Slave transfers have already been started on this handle.
-
status_t I3C_SlaveTransferGetCount(I3C_Type *base, i3c_slave_handle_t *handle, size_t *count)
Gets the slave transfer status during a non-blocking transfer.
- Parameters:
base – The I3C peripheral base address.
handle – Pointer to i2c_slave_handle_t structure.
count – [out] Pointer to a value to hold the number of bytes transferred. May be NULL if the count is not required.
- Return values:
kStatus_Success –
kStatus_NoTransferInProgress –
-
void I3C_SlaveTransferAbort(I3C_Type *base, i3c_slave_handle_t *handle)
Aborts the slave non-blocking transfers.
Note
This API could be called at any time to stop slave for handling the bus events.
- Parameters:
base – The I3C peripheral base address.
handle – Pointer to struct: _i3c_slave_handle structure which stores the transfer state.
- Return values:
kStatus_Success –
kStatus_I3C_Idle –
-
void I3C_SlaveTransferHandleIRQ(I3C_Type *base, void *intHandle)
Reusable routine to handle slave interrupts.
Note
This function does not need to be called unless you are reimplementing the non blocking API’s interrupt handler routines to add special functionality.
- Parameters:
base – The I3C peripheral base address.
intHandle – Pointer to struct: _i3c_slave_handle structure which stores the transfer state.
-
enum _i3c_slave_flags
I3C slave peripheral flags.
The following status register flags can be cleared:
kI3C_SlaveBusStartFlag
kI3C_SlaveMatchedFlag
kI3C_SlaveBusStopFlag
Only below flags can be enabled as interrupts.
kI3C_SlaveBusStartFlag
kI3C_SlaveMatchedFlag
kI3C_SlaveBusStopFlag
kI3C_SlaveRxReadyFlag
kI3C_SlaveTxReadyFlag
kI3C_SlaveDynamicAddrChangedFlag
kI3C_SlaveReceivedCCCFlag
kI3C_SlaveErrorFlag
kI3C_SlaveHDRCommandMatchFlag
kI3C_SlaveCCCHandledFlag
kI3C_SlaveEventSentFlag
Note
These enums are meant to be OR’d together to form a bit mask.
Values:
-
enumerator kI3C_SlaveNotStopFlag
Slave status not stop flag
-
enumerator kI3C_SlaveMessageFlag
Slave status message, indicating slave is listening to the bus traffic or responding
-
enumerator kI3C_SlaveRequiredReadFlag
Slave status required, either is master doing SDR read from slave, or is IBI pushing out.
-
enumerator kI3C_SlaveRequiredWriteFlag
Slave status request write, master is doing SDR write to slave, except slave in ENTDAA mode
-
enumerator kI3C_SlaveBusDAAFlag
I3C bus is in ENTDAA mode
-
enumerator kI3C_SlaveBusHDRModeFlag
I3C bus is in HDR mode
-
enumerator kI3C_SlaveBusStartFlag
Start/Re-start event is seen since the bus was last cleared
-
enumerator kI3C_SlaveMatchedFlag
Slave address(dynamic/static) matched since last cleared
-
enumerator kI3C_SlaveBusStopFlag
Stop event is seen since the bus was last cleared
-
enumerator kI3C_SlaveRxReadyFlag
Rx data ready in rx buffer flag
-
enumerator kI3C_SlaveTxReadyFlag
Tx buffer ready for Tx data flag
-
enumerator kI3C_SlaveDynamicAddrChangedFlag
Slave dynamic address has been assigned, re-assigned, or lost
-
enumerator kI3C_SlaveReceivedCCCFlag
Slave received Common command code
-
enumerator kI3C_SlaveErrorFlag
Error occurred flag
-
enumerator kI3C_SlaveHDRCommandMatchFlag
High data rate command match
-
enumerator kI3C_SlaveCCCHandledFlag
Slave received Common command code is handled by I3C module
-
enumerator kI3C_SlaveEventSentFlag
Slave IBI/P2P/MR/HJ event has been sent
-
enumerator kI3C_SlaveIbiDisableFlag
Slave in band interrupt is disabled.
-
enumerator kI3C_SlaveMasterRequestDisabledFlag
Slave master request is disabled.
-
enumerator kI3C_SlaveHotJoinDisabledFlag
Slave Hot-Join is disabled.
-
enumerator kI3C_SlaveClearFlags
All flags which are cleared by the driver upon starting a transfer.
-
enumerator kI3C_SlaveAllIrqFlags
-
enum _i3c_slave_error_flags
I3C slave error flags to indicate the causes.
Note
These enums are meant to be OR’d together to form a bit mask.
Values:
-
enumerator kI3C_SlaveErrorOverrunFlag
Slave internal from-bus buffer/FIFO overrun.
-
enumerator kI3C_SlaveErrorUnderrunFlag
Slave internal to-bus buffer/FIFO underrun
-
enumerator kI3C_SlaveErrorUnderrunNakFlag
Slave internal from-bus buffer/FIFO underrun and NACK error
-
enumerator kI3C_SlaveErrorTermFlag
Terminate error from master
-
enumerator kI3C_SlaveErrorInvalidStartFlag
Slave invalid start flag
-
enumerator kI3C_SlaveErrorSdrParityFlag
SDR parity error
-
enumerator kI3C_SlaveErrorHdrParityFlag
HDR parity error
-
enumerator kI3C_SlaveErrorHdrCRCFlag
HDR-DDR CRC error
-
enumerator kI3C_SlaveErrorS0S1Flag
S0 or S1 error
-
enumerator kI3C_SlaveErrorOverreadFlag
Over-read error
-
enumerator kI3C_SlaveErrorOverwriteFlag
Over-write error
-
enumerator kI3C_SlaveErrorOverrunFlag
-
enum _i3c_slave_event
I3C slave.event.
Values:
-
enumerator kI3C_SlaveEventNormal
Normal mode.
-
enumerator kI3C_SlaveEventIBI
In band interrupt event.
-
enumerator kI3C_SlaveEventMasterReq
Master request event.
-
enumerator kI3C_SlaveEventHotJoinReq
Hot-join event.
-
enumerator kI3C_SlaveEventNormal
-
enum _i3c_slave_activity_state
I3C slave.activity state.
Values:
-
enumerator kI3C_SlaveNoLatency
Normal bus operation
-
enumerator kI3C_SlaveLatency1Ms
1ms of latency.
-
enumerator kI3C_SlaveLatency100Ms
100ms of latency.
-
enumerator kI3C_SlaveLatency10S
10s latency.
-
enumerator kI3C_SlaveNoLatency
-
enum _i3c_slave_transfer_event
Set of events sent to the callback for non blocking slave transfers.
These event enumerations are used for two related purposes. First, a bit mask created by OR’ing together events is passed to I3C_SlaveTransferNonBlocking() in order 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.
Values:
-
enumerator kI3C_SlaveAddressMatchEvent
Received the slave address after a start or repeated start.
-
enumerator kI3C_SlaveTransmitEvent
Callback is requested to provide data to transmit (slave-transmitter role).
-
enumerator kI3C_SlaveReceiveEvent
Callback is requested to provide a buffer in which to place received data (slave-receiver role).
-
enumerator kI3C_SlaveRequiredTransmitEvent
Callback is requested to provide a buffer in which to place received data (slave-receiver role).
-
enumerator kI3C_SlaveStartEvent
A start/repeated start was detected.
-
enumerator kI3C_SlaveHDRCommandMatchEvent
Slave Match HDR Command.
-
enumerator kI3C_SlaveCompletionEvent
A stop was detected, completing the transfer.
-
enumerator kI3C_SlaveRequestSentEvent
Slave request event sent.
-
enumerator kI3C_SlaveReceivedCCCEvent
Slave received CCC event, need to handle by application.
-
enumerator kI3C_SlaveAllEvents
Bit mask of all available events.
-
enumerator kI3C_SlaveAddressMatchEvent
-
typedef enum _i3c_slave_event i3c_slave_event_t
I3C slave.event.
-
typedef enum _i3c_slave_activity_state i3c_slave_activity_state_t
I3C slave.activity state.
-
typedef struct _i3c_slave_config i3c_slave_config_t
Structure with settings to initialize the I3C slave module.
This structure holds configuration settings for the I3C peripheral. To initialize this structure to reasonable defaults, call the I3C_SlaveGetDefaultConfig() function and pass a pointer to your configuration structure instance.
The configuration structure can be made constant so it resides in flash.
-
typedef enum _i3c_slave_transfer_event i3c_slave_transfer_event_t
Set of events sent to the callback for non blocking slave transfers.
These event enumerations are used for two related purposes. First, a bit mask created by OR’ing together events is passed to I3C_SlaveTransferNonBlocking() in order 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.
-
typedef struct _i3c_slave_transfer i3c_slave_transfer_t
I3C slave transfer structure.
-
typedef struct _i3c_slave_handle i3c_slave_handle_t
-
typedef void (*i3c_slave_transfer_callback_t)(I3C_Type *base, i3c_slave_transfer_t *transfer, void *userData)
Slave event callback function pointer type.
This callback is used only for the slave non-blocking transfer API. To install a callback, use the I3C_SlaveSetCallback() function after you have created a handle.
- Param base:
Base address for the I3C instance on which the event occurred.
- Param transfer:
Pointer to transfer descriptor containing values passed to and/or from the callback.
- Param userData:
Arbitrary pointer-sized value passed from the application.
-
typedef void (*i3c_slave_isr_t)(I3C_Type *base, void *handle)
Typedef for slave interrupt handler.
-
struct _i3c_slave_config
- #include <fsl_i3c.h>
Structure with settings to initialize the I3C slave module.
This structure holds configuration settings for the I3C peripheral. To initialize this structure to reasonable defaults, call the I3C_SlaveGetDefaultConfig() function and pass a pointer to your configuration structure instance.
The configuration structure can be made constant so it resides in flash.
Public Members
-
bool enableSlave
Whether to enable slave.
-
uint8_t staticAddr
Static address.
-
uint16_t vendorID
Device vendor ID(manufacture ID).
-
uint32_t partNumber
Device part number info
-
uint8_t dcr
Device characteristics register information.
-
uint8_t bcr
Bus characteristics register information.
-
uint8_t hdrMode
Support hdr mode, could be OR logic in enumeration:i3c_hdr_mode_t.
-
bool nakAllRequest
Whether to reply NAK to all requests except broadcast CCC.
-
bool ignoreS0S1Error
Whether to ignore S0/S1 error in SDR mode.
-
bool offline
Whether to wait 60 us of bus quiet or HDR request to ensure slave track SDR mode safely.
-
bool matchSlaveStartStop
Whether to assert start/stop status only the time slave is addressed.
-
uint32_t maxWriteLength
Maximum write length.
-
uint32_t maxReadLength
Maximum read length.
-
bool enableSlave
-
struct _i3c_slave_transfer
- #include <fsl_i3c.h>
I3C slave transfer structure.
Public Members
-
uint32_t event
Reason the callback is being invoked.
-
uint8_t *txData
Transfer buffer
-
size_t txDataSize
Transfer size
-
uint8_t *rxData
Transfer buffer
-
size_t rxDataSize
Transfer size
-
status_t completionStatus
Success or error code describing how the transfer completed. Only applies for kI3C_SlaveCompletionEvent.
-
size_t transferredCount
Number of bytes actually transferred since start or last repeated start.
-
uint32_t event
-
struct _i3c_slave_handle
- #include <fsl_i3c.h>
I3C slave handle structure.
Note
The contents of this structure are private and subject to change.
Public Members
-
i3c_slave_transfer_t transfer
I3C slave transfer copy.
-
bool isBusy
Whether transfer is busy.
-
bool wasTransmit
Whether the last transfer was a transmit.
-
uint32_t eventMask
Mask of enabled events.
-
uint32_t transferredCount
Count of bytes transferred.
-
i3c_slave_transfer_callback_t callback
Callback function called at transfer event.
-
void *userData
Callback parameter passed to callback.
-
uint8_t txFifoSize
Tx Fifo size
-
i3c_slave_transfer_t transfer
INPUTMUX: Input Multiplexing Driver
-
enum _inputmux_connection_t
INPUTMUX connections type.
Values:
-
enumerator kINPUTMUX_SctGpioInAToSct0
SCT0 INMUX.
-
enumerator kINPUTMUX_SctGpioInBToSct0
-
enumerator kINPUTMUX_SctGpioInCToSct0
-
enumerator kINPUTMUX_SctGpioInDToSct0
-
enumerator kINPUTMUX_SctGpioInEToSct0
-
enumerator kINPUTMUX_SctGpioInFToSct0
-
enumerator kINPUTMUX_SctGpioInGToSct0
-
enumerator kINPUTMUX_SctGpioInHToSct0
-
enumerator kINPUTMUX_Ctimer0M0ToSct0
-
enumerator kINPUTMUX_Ctimer1M0ToSct0
-
enumerator kINPUTMUX_Ctimer2M0ToSct0
-
enumerator kINPUTMUX_Ctimer3M0ToSct0
-
enumerator kINPUTMUX_Ctimer4M0ToSct0
-
enumerator kINPUTMUX_Adc0IrqToSct0
-
enumerator kINPUTMUX_GpiointBmatchToSct0
-
enumerator kINPUTMUX_Usb0FrameToggleToSct0
-
enumerator kINPUTMUX_CompOutToSct0
-
enumerator kINPUTMUX_I2sSharedSck0ToSct0
-
enumerator kINPUTMUX_I2sSharedSck1ToSct0
-
enumerator kINPUTMUX_I2sSharedWs0ToSct0
-
enumerator kINPUTMUX_I2sSharedWs1ToSct0
-
enumerator kINPUTMUX_ArmTxevToSct0
-
enumerator kINPUTMUX_DebugHaltedToSct0
-
enumerator kINPUTMUX_Adc1IrqToSct0
-
enumerator kINPUTMUX_Adc0tcomp0ToSct0
-
enumerator kINPUTMUX_Adc0tcomp1ToSct0
-
enumerator kINPUTMUX_Adc0tcomp2ToSct0
-
enumerator kINPUTMUX_Adc0tcomp3ToSct0
-
enumerator kINPUTMUX_Adc1tcomp0ToSct0
-
enumerator kINPUTMUX_Adc1tcomp1ToSct0
-
enumerator kINPUTMUX_Adc1tcomp2ToSct0
-
enumerator kINPUTMUX_Adc1tcomp3ToSct0
-
enumerator kINPUTMUX_Hscmp0OutToSct0
-
enumerator kINPUTMUX_Hscmp1OutToSct0
-
enumerator kINPUTMUX_Hscmp2OutToSct0
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig01ToSct0
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig01ToSct0
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig01ToSct0
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig01ToSct0
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig01ToSct0
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig01ToSct0
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig01ToSct0
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig01ToSct0
-
enumerator kINPUTMUX_Enc0CmpPosMatchToSct0
-
enumerator kINPUTMUX_Enc1CmpPosMatchToSct0
-
enumerator kINPUTMUX_Aoi0Out0ToSct0
-
enumerator kINPUTMUX_Aoi0Out1ToSct0
-
enumerator kINPUTMUX_Aoi0Out2ToSct0
-
enumerator kINPUTMUX_Aoi0Out3ToSct0
-
enumerator kINPUTMUX_Aoi1Out0ToSct0
-
enumerator kINPUTMUX_Aoi1Out1ToSct0
-
enumerator kINPUTMUX_Aoi1Out2ToSct0
-
enumerator kINPUTMUX_Aoi1Out3ToSct0
-
enumerator kINPUTMUX_Fc3SckToSct0
-
enumerator kINPUTMUX_Fc3RxdSdaMosiDataToSct0
-
enumerator kINPUTMUX_Fc3TxdSclMisoWsToSct0
-
enumerator kINPUTMUX_Fc3CtsDsaSsel0ToSct0
-
enumerator kINPUTMUX_TmprOutToSct0
TIMER0 CAPTSEL.
-
enumerator kINPUTMUX_CtimerInp0ToTimer0Captsel
-
enumerator kINPUTMUX_CtimerInp1ToTimer0Captsel
-
enumerator kINPUTMUX_CtimerInp2ToTimer0Captsel
-
enumerator kINPUTMUX_CtimerInp3ToTimer0Captsel
-
enumerator kINPUTMUX_CtimerInp4ToTimer0Captsel
-
enumerator kINPUTMUX_CtimerInp5ToTimer0Captsel
-
enumerator kINPUTMUX_CtimerInp6ToTimer0Captsel
-
enumerator kINPUTMUX_CtimerInp7ToTimer0Captsel
-
enumerator kINPUTMUX_CtimerInp8ToTimer0Captsel
-
enumerator kINPUTMUX_CtimerInp9ToTimer0Captsel
-
enumerator kINPUTMUX_CtimerInp10ToTimer0Captsel
-
enumerator kINPUTMUX_CtimerInp11ToTimer0Captsel
-
enumerator kINPUTMUX_CtimerInp12ToTimer0Captsel
-
enumerator kINPUTMUX_CtimerInp13ToTimer0Captsel
-
enumerator kINPUTMUX_CtimerInp14ToTimer0Captsel
-
enumerator kINPUTMUX_CtimerInp15ToTimer0Captsel
-
enumerator kINPUTMUX_CtimerInp16ToTimer0Captsel
-
enumerator kINPUTMUX_CtimerInp17ToTimer0Captsel
-
enumerator kINPUTMUX_CtimerInp18ToTimer0Captsel
-
enumerator kINPUTMUX_CtimerInp19ToTimer0Captsel
-
enumerator kINPUTMUX_Usb0FrameToggleToTimer0Captsel
-
enumerator kINPUTMUX_CompOutToTimer0Captsel
-
enumerator kINPUTMUX_I2sSharedWs0ToTimer0Captsel
-
enumerator kINPUTMUX_I2sSharedWs1ToTimer0Captsel
-
enumerator kINPUTMUX_Adc0IrqToTimer0Captsel
-
enumerator kINPUTMUX_Adc1IrqToTimer0Captsel
-
enumerator kINPUTMUX_Hscmp0OutToTimer0Captsel
-
enumerator kINPUTMUX_Hscmp1OutToTimer0Captsel
-
enumerator kINPUTMUX_Hscmp2OutToTimer0Captsel
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig01ToTimer0Captsel
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig01ToTimer0Captsel
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig01ToTimer0Captsel
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig01ToTimer0Captsel
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig01ToTimer0Captsel
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig01ToTimer0Captsel
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig01ToTimer0Captsel
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig01ToTimer0Captsel
-
enumerator kINPUTMUX_Enc0CmpPosMatchToTimer0Captsel
-
enumerator kINPUTMUX_Enc1CmpPosMatchToTimer0Captsel
-
enumerator kINPUTMUX_Aoi0Out0ToTimer0Captsel
-
enumerator kINPUTMUX_Aoi0Out1ToTimer0Captsel
-
enumerator kINPUTMUX_Aoi0Out2ToTimer0Captsel
-
enumerator kINPUTMUX_Aoi0Out3ToTimer0Captsel
-
enumerator kINPUTMUX_Aoi1Out0ToTimer0Captsel
-
enumerator kINPUTMUX_Aoi1Out1ToTimer0Captsel
-
enumerator kINPUTMUX_Aoi1Out2ToTimer0Captsel
-
enumerator kINPUTMUX_Aoi1Out3ToTimer0Captsel
-
enumerator kINPUTMUX_TmprOutToTimer0Captsel
TIMER0 Trigger.
-
enumerator kINPUTMUX_CtimerInp0ToTimer0Trigger
-
enumerator kINPUTMUX_CtimerInp1ToTimer0Trigger
-
enumerator kINPUTMUX_CtimerInp2ToTimer0Trigger
-
enumerator kINPUTMUX_CtimerInp3ToTimer0Trigger
-
enumerator kINPUTMUX_CtimerInp4ToTimer0Trigger
-
enumerator kINPUTMUX_CtimerInp5ToTimer0Trigger
-
enumerator kINPUTMUX_CtimerInp6ToTimer0Trigger
-
enumerator kINPUTMUX_CtimerInp7ToTimer0Trigger
-
enumerator kINPUTMUX_CtimerInp8ToTimer0Trigger
-
enumerator kINPUTMUX_CtimerInp9ToTimer0Trigger
-
enumerator kINPUTMUX_CtimerInp10ToTimer0Trigger
-
enumerator kINPUTMUX_CtimerInp11ToTimer0Trigger
-
enumerator kINPUTMUX_CtimerInp12ToTimer0Trigger
-
enumerator kINPUTMUX_CtimerInp13ToTimer0Trigger
-
enumerator kINPUTMUX_CtimerInp14ToTimer0Trigger
-
enumerator kINPUTMUX_CtimerInp15ToTimer0Trigger
-
enumerator kINPUTMUX_CtimerInp16ToTimer0Trigger
-
enumerator kINPUTMUX_CtimerInp17ToTimer0Trigger
-
enumerator kINPUTMUX_CtimerInp18ToTimer0Trigger
-
enumerator kINPUTMUX_CtimerInp19ToTimer0Trigger
-
enumerator kINPUTMUX_Usb0FrameToggleToTimer0Trigger
-
enumerator kINPUTMUX_CompOutToTimer0Trigger
-
enumerator kINPUTMUX_I2sSharedWs0ToTimer0Trigger
-
enumerator kINPUTMUX_I2sSharedWs1ToTimer0Trigger
-
enumerator kINPUTMUX_Adc0IrqToTimer0Trigger
-
enumerator kINPUTMUX_Adc1IrqToTimer0Trigger
-
enumerator kINPUTMUX_Hscmp0OutToTimer0Trigger
-
enumerator kINPUTMUX_Hscmp1OutToTimer0Trigger
-
enumerator kINPUTMUX_Hscmp2OutToTimer0Trigger
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig01ToTimer0Trigger
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig01ToTimer0Trigger
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig01ToTimer0Trigger
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig01ToTimer0Trigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig01ToTimer0Trigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig01ToTimer0Trigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig01ToTimer0Trigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig01ToTimer0Trigger
-
enumerator kINPUTMUX_Enc0CmpPosMatchToTimer0Trigger
-
enumerator kINPUTMUX_Enc1CmpPosMatchToTimer0Trigger
-
enumerator kINPUTMUX_Aoi0Out0ToTimer0Trigger
-
enumerator kINPUTMUX_Aoi0Out1ToTimer0Trigger
-
enumerator kINPUTMUX_Aoi0Out2ToTimer0Trigger
-
enumerator kINPUTMUX_Aoi0Out3ToTimer0Trigger
-
enumerator kINPUTMUX_Aoi1Out0ToTimer0Trigger
-
enumerator kINPUTMUX_Aoi1Out1ToTimer0Trigger
-
enumerator kINPUTMUX_Aoi1Out2ToTimer0Trigger
-
enumerator kINPUTMUX_Aoi1Out3ToTimer0Trigger
-
enumerator kINPUTMUX_TmprOutToTimer0Trigger
TIMER1 CAPTSEL.
-
enumerator kINPUTMUX_CtimerInp0ToTimer1Captsel
-
enumerator kINPUTMUX_CtimerInp1ToTimer1Captsel
-
enumerator kINPUTMUX_CtimerInp2ToTimer1Captsel
-
enumerator kINPUTMUX_CtimerInp3ToTimer1Captsel
-
enumerator kINPUTMUX_CtimerInp4ToTimer1Captsel
-
enumerator kINPUTMUX_CtimerInp5ToTimer1Captsel
-
enumerator kINPUTMUX_CtimerInp6ToTimer1Captsel
-
enumerator kINPUTMUX_CtimerInp7ToTimer1Captsel
-
enumerator kINPUTMUX_CtimerInp8ToTimer1Captsel
-
enumerator kINPUTMUX_CtimerInp9ToTimer1Captsel
-
enumerator kINPUTMUX_CtimerInp10ToTimer1Captsel
-
enumerator kINPUTMUX_CtimerInp11ToTimer1Captsel
-
enumerator kINPUTMUX_CtimerInp12ToTimer1Captsel
-
enumerator kINPUTMUX_CtimerInp13ToTimer1Captsel
-
enumerator kINPUTMUX_CtimerInp14ToTimer1Captsel
-
enumerator kINPUTMUX_CtimerInp15ToTimer1Captsel
-
enumerator kINPUTMUX_CtimerInp16ToTimer1Captsel
-
enumerator kINPUTMUX_CtimerInp17ToTimer1Captsel
-
enumerator kINPUTMUX_CtimerInp18ToTimer1Captsel
-
enumerator kINPUTMUX_CtimerInp19ToTimer1Captsel
-
enumerator kINPUTMUX_Usb0FrameToggleToTimer1Captsel
-
enumerator kINPUTMUX_CompOutToTimer1Captsel
-
enumerator kINPUTMUX_I2sSharedWs0ToTimer1Captsel
-
enumerator kINPUTMUX_I2sSharedWs1ToTimer1Captsel
-
enumerator kINPUTMUX_Adc0IrqToTimer1Captsel
-
enumerator kINPUTMUX_Adc1IrqToTimer1Captsel
-
enumerator kINPUTMUX_Hscmp0OutToTimer1Captsel
-
enumerator kINPUTMUX_Hscmp1OutToTimer1Captsel
-
enumerator kINPUTMUX_Hscmp2OutToTimer1Captsel
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig01ToTimer1Captsel
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig01ToTimer1Captsel
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig01ToTimer1Captsel
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig01ToTimer1Captsel
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig01ToTimer1Captsel
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig01ToTimer1Captsel
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig01ToTimer1Captsel
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig01ToTimer1Captsel
-
enumerator kINPUTMUX_Enc0CmpPosMatchToTimer1Captsel
-
enumerator kINPUTMUX_Enc1CmpPosMatchToTimer1Captsel
-
enumerator kINPUTMUX_Aoi0Out0ToTimer1Captsel
-
enumerator kINPUTMUX_Aoi0Out1ToTimer1Captsel
-
enumerator kINPUTMUX_Aoi0Out2ToTimer1Captsel
-
enumerator kINPUTMUX_Aoi0Out3ToTimer1Captsel
-
enumerator kINPUTMUX_Aoi1Out0ToTimer1Captsel
-
enumerator kINPUTMUX_Aoi1Out1ToTimer1Captsel
-
enumerator kINPUTMUX_Aoi1Out2ToTimer1Captsel
-
enumerator kINPUTMUX_Aoi1Out3ToTimer1Captsel
-
enumerator kINPUTMUX_TmprOutToTimer1Captsel
TIMER1 Trigger.
-
enumerator kINPUTMUX_CtimerInp0ToTimer1Trigger
-
enumerator kINPUTMUX_CtimerInp1ToTimer1Trigger
-
enumerator kINPUTMUX_CtimerInp2ToTimer1Trigger
-
enumerator kINPUTMUX_CtimerInp3ToTimer1Trigger
-
enumerator kINPUTMUX_CtimerInp4ToTimer1Trigger
-
enumerator kINPUTMUX_CtimerInp5ToTimer1Trigger
-
enumerator kINPUTMUX_CtimerInp6ToTimer1Trigger
-
enumerator kINPUTMUX_CtimerInp7ToTimer1Trigger
-
enumerator kINPUTMUX_CtimerInp8ToTimer1Trigger
-
enumerator kINPUTMUX_CtimerInp9ToTimer1Trigger
-
enumerator kINPUTMUX_CtimerInp10ToTimer1Trigger
-
enumerator kINPUTMUX_CtimerInp11ToTimer1Trigger
-
enumerator kINPUTMUX_CtimerInp12ToTimer1Trigger
-
enumerator kINPUTMUX_CtimerInp13ToTimer1Trigger
-
enumerator kINPUTMUX_CtimerInp14ToTimer1Trigger
-
enumerator kINPUTMUX_CtimerInp15ToTimer1Trigger
-
enumerator kINPUTMUX_CtimerInp16ToTimer1Trigger
-
enumerator kINPUTMUX_CtimerInp17ToTimer1Trigger
-
enumerator kINPUTMUX_CtimerInp18ToTimer1Trigger
-
enumerator kINPUTMUX_CtimerInp19ToTimer1Trigger
-
enumerator kINPUTMUX_Usb0FrameToggleToTimer1Trigger
-
enumerator kINPUTMUX_CompOutToTimer1Trigger
-
enumerator kINPUTMUX_I2sSharedWs0ToTimer1Trigger
-
enumerator kINPUTMUX_I2sSharedWs1ToTimer1Trigger
-
enumerator kINPUTMUX_Adc0IrqToTimer1Trigger
-
enumerator kINPUTMUX_Adc1IrqToTimer1Trigger
-
enumerator kINPUTMUX_Hscmp0OutToTimer1Trigger
-
enumerator kINPUTMUX_Hscmp1OutToTimer1Trigger
-
enumerator kINPUTMUX_Hscmp2OutToTimer1Trigger
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig01ToTimer1Trigger
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig01ToTimer1Trigger
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig01ToTimer1Trigger
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig01ToTimer1Trigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig01ToTimer1Trigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig01ToTimer1Trigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig01ToTimer1Trigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig01ToTimer1Trigger
-
enumerator kINPUTMUX_Enc0CmpPosMatchToTimer1Trigger
-
enumerator kINPUTMUX_Enc1CmpPosMatchToTimer1Trigger
-
enumerator kINPUTMUX_Aoi0Out0ToTimer1Trigger
-
enumerator kINPUTMUX_Aoi0Out1ToTimer1Trigger
-
enumerator kINPUTMUX_Aoi0Out2ToTimer1Trigger
-
enumerator kINPUTMUX_Aoi0Out3ToTimer1Trigger
-
enumerator kINPUTMUX_Aoi1Out0ToTimer1Trigger
-
enumerator kINPUTMUX_Aoi1Out1ToTimer1Trigger
-
enumerator kINPUTMUX_Aoi1Out2ToTimer1Trigger
-
enumerator kINPUTMUX_Aoi1Out3ToTimer1Trigger
-
enumerator kINPUTMUX_TmprOutToTimer1Trigger
TIMER2 CAPTSEL.
-
enumerator kINPUTMUX_CtimerInp0ToTimer2Captsel
-
enumerator kINPUTMUX_CtimerInp1ToTimer2Captsel
-
enumerator kINPUTMUX_CtimerInp2ToTimer2Captsel
-
enumerator kINPUTMUX_CtimerInp3ToTimer2Captsel
-
enumerator kINPUTMUX_CtimerInp4ToTimer2Captsel
-
enumerator kINPUTMUX_CtimerInp5ToTimer2Captsel
-
enumerator kINPUTMUX_CtimerInp6ToTimer2Captsel
-
enumerator kINPUTMUX_CtimerInp7ToTimer2Captsel
-
enumerator kINPUTMUX_CtimerInp8ToTimer2Captsel
-
enumerator kINPUTMUX_CtimerInp9ToTimer2Captsel
-
enumerator kINPUTMUX_CtimerInp10ToTimer2Captsel
-
enumerator kINPUTMUX_CtimerInp11ToTimer2Captsel
-
enumerator kINPUTMUX_CtimerInp12ToTimer2Captsel
-
enumerator kINPUTMUX_CtimerInp13ToTimer2Captsel
-
enumerator kINPUTMUX_CtimerInp14ToTimer2Captsel
-
enumerator kINPUTMUX_CtimerInp15ToTimer2Captsel
-
enumerator kINPUTMUX_CtimerInp16ToTimer2Captsel
-
enumerator kINPUTMUX_CtimerInp17ToTimer2Captsel
-
enumerator kINPUTMUX_CtimerInp18ToTimer2Captsel
-
enumerator kINPUTMUX_CtimerInp19ToTimer2Captsel
-
enumerator kINPUTMUX_Usb0FrameToggleToTimer2Captsel
-
enumerator kINPUTMUX_CompOutToTimer2Captsel
-
enumerator kINPUTMUX_I2sSharedWs0ToTimer2Captsel
-
enumerator kINPUTMUX_I2sSharedWs1ToTimer2Captsel
-
enumerator kINPUTMUX_Adc0IrqToTimer2Captsel
-
enumerator kINPUTMUX_Adc1IrqToTimer2Captsel
-
enumerator kINPUTMUX_Hscmp0OutToTimer2Captsel
-
enumerator kINPUTMUX_Hscmp1OutToTimer2Captsel
-
enumerator kINPUTMUX_Hscmp2OutToTimer2Captsel
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig01ToTimer2Captsel
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig01ToTimer2Captsel
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig01ToTimer2Captsel
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig01ToTimer2Captsel
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig01ToTimer2Captsel
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig01ToTimer2Captsel
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig01ToTimer2Captsel
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig01ToTimer2Captsel
-
enumerator kINPUTMUX_Enc0CmpPosMatchToTimer2Captsel
-
enumerator kINPUTMUX_Enc1CmpPosMatchToTimer2Captsel
-
enumerator kINPUTMUX_Aoi0Out0ToTimer2Captsel
-
enumerator kINPUTMUX_Aoi0Out1ToTimer2Captsel
-
enumerator kINPUTMUX_Aoi0Out2ToTimer2Captsel
-
enumerator kINPUTMUX_Aoi0Out3ToTimer2Captsel
-
enumerator kINPUTMUX_Aoi1Out0ToTimer2Captsel
-
enumerator kINPUTMUX_Aoi1Out1ToTimer2Captsel
-
enumerator kINPUTMUX_Aoi1Out2ToTimer2Captsel
-
enumerator kINPUTMUX_Aoi1Out3ToTimer2Captsel
-
enumerator kINPUTMUX_TmprOutToTimer2Captsel
TIMER2 Trigger.
-
enumerator kINPUTMUX_CtimerInp0ToTimer2Trigger
-
enumerator kINPUTMUX_CtimerInp1ToTimer2Trigger
-
enumerator kINPUTMUX_CtimerInp2ToTimer2Trigger
-
enumerator kINPUTMUX_CtimerInp3ToTimer2Trigger
-
enumerator kINPUTMUX_CtimerInp4ToTimer2Trigger
-
enumerator kINPUTMUX_CtimerInp5ToTimer2Trigger
-
enumerator kINPUTMUX_CtimerInp6ToTimer2Trigger
-
enumerator kINPUTMUX_CtimerInp7ToTimer2Trigger
-
enumerator kINPUTMUX_CtimerInp8ToTimer2Trigger
-
enumerator kINPUTMUX_CtimerInp9ToTimer2Trigger
-
enumerator kINPUTMUX_CtimerInp10ToTimer2Trigger
-
enumerator kINPUTMUX_CtimerInp11ToTimer2Trigger
-
enumerator kINPUTMUX_CtimerInp12ToTimer2Trigger
-
enumerator kINPUTMUX_CtimerInp13ToTimer2Trigger
-
enumerator kINPUTMUX_CtimerInp14ToTimer2Trigger
-
enumerator kINPUTMUX_CtimerInp15ToTimer2Trigger
-
enumerator kINPUTMUX_CtimerInp16ToTimer2Trigger
-
enumerator kINPUTMUX_CtimerInp17ToTimer2Trigger
-
enumerator kINPUTMUX_CtimerInp18ToTimer2Trigger
-
enumerator kINPUTMUX_CtimerInp19ToTimer2Trigger
-
enumerator kINPUTMUX_Usb0FrameToggleToTimer2Trigger
-
enumerator kINPUTMUX_CompOutToTimer2Trigger
-
enumerator kINPUTMUX_I2sSharedWs0ToTimer2Trigger
-
enumerator kINPUTMUX_I2sSharedWs1ToTimer2Trigger
-
enumerator kINPUTMUX_Adc0IrqToTimer2Trigger
-
enumerator kINPUTMUX_Adc1IrqToTimer2Trigger
-
enumerator kINPUTMUX_Hscmp0OutToTimer2Trigger
-
enumerator kINPUTMUX_Hscmp1OutToTimer2Trigger
-
enumerator kINPUTMUX_Hscmp2OutToTimer2Trigger
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig01ToTimer2Trigger
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig01ToTimer2Trigger
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig01ToTimer2Trigger
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig01ToTimer2Trigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig01ToTimer2Trigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig01ToTimer2Trigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig01ToTimer2Trigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig01ToTimer2Trigger
-
enumerator kINPUTMUX_Enc0CmpPosMatchToTimer2Trigger
-
enumerator kINPUTMUX_Enc1CmpPosMatchToTimer2Trigger
-
enumerator kINPUTMUX_Aoi0Out0ToTimer2Trigger
-
enumerator kINPUTMUX_Aoi0Out1ToTimer2Trigger
-
enumerator kINPUTMUX_Aoi0Out2ToTimer2Trigger
-
enumerator kINPUTMUX_Aoi0Out3ToTimer2Trigger
-
enumerator kINPUTMUX_Aoi1Out0ToTimer2Trigger
-
enumerator kINPUTMUX_Aoi1Out1ToTimer2Trigger
-
enumerator kINPUTMUX_Aoi1Out2ToTimer2Trigger
-
enumerator kINPUTMUX_Aoi1Out3ToTimer2Trigger
-
enumerator kINPUTMUX_TmprOutToTimer2Trigger
Pin interrupt select.
-
enumerator kINPUTMUX_GpioPort0Pin0ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin1ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin2ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin3ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin4ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin5ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin6ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin7ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin8ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin9ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin10ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin11ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin12ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin13ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin14ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin15ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin16ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin17ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin18ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin19ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin20ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin21ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin22ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin23ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin24ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin25ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin26ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin27ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin28ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin29ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin30ToPintsel
-
enumerator kINPUTMUX_GpioPort0Pin31ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin0ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin1ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin2ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin3ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin4ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin5ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin6ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin7ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin8ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin9ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin10ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin11ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin12ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin13ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin14ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin15ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin16ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin17ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin18ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin19ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin20ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin21ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin22ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin23ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin24ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin25ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin26ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin27ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin28ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin29ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin30ToPintsel
-
enumerator kINPUTMUX_GpioPort1Pin31ToPintsel
DMA0 Input trigger.
-
enumerator kINPUTMUX_FlexSpiRxToDma0
-
enumerator kINPUTMUX_FlexSpiTxToDma0
-
enumerator kINPUTMUX_PinInt0ToDma0
-
enumerator kINPUTMUX_PinInt1ToDma0
-
enumerator kINPUTMUX_PinInt2ToDma0
-
enumerator kINPUTMUX_PinInt3ToDma0
-
enumerator kINPUTMUX_Ctimer0M0ToDma0
-
enumerator kINPUTMUX_Ctimer0M1ToDma0
-
enumerator kINPUTMUX_Ctimer1M0ToDma0
-
enumerator kINPUTMUX_Ctimer1M1ToDma0
-
enumerator kINPUTMUX_Ctimer2M0ToDma0
-
enumerator kINPUTMUX_Ctimer2M1ToDma0
-
enumerator kINPUTMUX_Ctimer3M0ToDma0
-
enumerator kINPUTMUX_Ctimer3M1ToDma0
-
enumerator kINPUTMUX_Ctimer4M0ToDma0
-
enumerator kINPUTMUX_Ctimer4M1ToDma0
-
enumerator kINPUTMUX_CompOutToDma0
-
enumerator kINPUTMUX_OtrigAToDma0
-
enumerator kINPUTMUX_OtrigBToDma0
-
enumerator kINPUTMUX_OtrigCToDma0
-
enumerator kINPUTMUX_OtrigDToDma0
-
enumerator kINPUTMUX_SctDma0ToDma0
-
enumerator kINPUTMUX_SctDma1ToDma0
-
enumerator kINPUTMUX_Adc0Tcomp0ToDma0
-
enumerator kINPUTMUX_Adc1Tcomp0ToDma0
-
enumerator kINPUTMUX_Hscmp0ToDma0
-
enumerator kINPUTMUX_Hscmp1ToDma0
-
enumerator kINPUTMUX_Hscmp2ToDma0
-
enumerator kINPUTMUX_Aoi0Out0ToDma0
-
enumerator kINPUTMUX_Aoi0Out1ToDma0
-
enumerator kINPUTMUX_Aoi0Out2ToDma0
-
enumerator kINPUTMUX_Aoi0Out3ToDma0
-
enumerator kINPUTMUX_Aoi1Out0ToDma0
-
enumerator kINPUTMUX_Aoi1Out1ToDma0
-
enumerator kINPUTMUX_Aoi1Out2ToDma0
-
enumerator kINPUTMUX_Aoi1Out3ToDma0
-
enumerator kINPUTMUX_FlexPwm0ReqCapt0ToDma0
-
enumerator kINPUTMUX_FlexPwm0ReqCapt1ToDma0
-
enumerator kINPUTMUX_FlexPwm0ReqCapt2ToDma0
-
enumerator kINPUTMUX_FlexPwm0ReqCapt3ToDma0
-
enumerator kINPUTMUX_FlexPwm0ReqVal0ToDma0
-
enumerator kINPUTMUX_FlexPwm0ReqVal1ToDma0
-
enumerator kINPUTMUX_FlexPwm0ReqVal2ToDma0
-
enumerator kINPUTMUX_FlexPwm0ReqVal3ToDma0
-
enumerator kINPUTMUX_FlexPwm1ReqCapt0ToDma0
-
enumerator kINPUTMUX_FlexPwm1ReqCapt1ToDma0
-
enumerator kINPUTMUX_FlexPwm1ReqCapt2ToDma0
-
enumerator kINPUTMUX_FlexPwm1ReqCapt3ToDma0
-
enumerator kINPUTMUX_FlexPwm1ReqVal0ToDma0
-
enumerator kINPUTMUX_FlexPwm1ReqVal1ToDma0
-
enumerator kINPUTMUX_FlexPwm1ReqVal2ToDma0
-
enumerator kINPUTMUX_FlexPwm1ReqVal3ToDma0
-
enumerator kINPUTMUX_TmprOutToDma0
DMA0 output trigger.
-
enumerator kINPUTMUX_Dma0FlexSpiRxTrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0FlexSpiTxTrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0PinInt0TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0PinInt1TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0PinInt2TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0PinInt3TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0Ctimer0M0TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0Ctimer0M1TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0Ctimer1M0TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0Ctimer1M1TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0Ctimer2M0TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0Ctimer2M1TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0Ctimer3M0TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0Ctimer3M1TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0Ctimer4M0TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0Ctimer4M1TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0CompOutTrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0OtrigATrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0OtrigBTrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0OtrigCTrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0OtrigDTrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0SctDma0TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0SctDma1TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0Adc0Tcomp0TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0Adc1Tcomp0TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0Hscmp0TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0Hscmp1TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0Hscmp2TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0Aoi0Out0TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0Aoi0Out1TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0Aoi0Out2TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0Aoi0Out3TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0Aoi1Out0TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0Aoi1Out1TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0Aoi1Out2TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0Aoi1Out3TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0FlexPwm0ReqCapt0TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0FlexPwm0ReqCapt1TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0FlexPwm0ReqCapt2TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0FlexPwm0ReqCapt3TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0FlexPwm0ReqVal0TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0FlexPwm0ReqVal1TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0FlexPwm0ReqVal2TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0FlexPwm0ReqVal3TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0FlexPwm1ReqCapt0TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0FlexPwm1ReqCapt1TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0FlexPwm1ReqCapt2TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0FlexPwm1ReqCapt3TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0FlexPwm1ReqVal0TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0FlexPwm1ReqVal1TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0FlexPwm1ReqVal2TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma0FlexPwm1ReqVal3TrigoutToTriginChannels
-
enumerator kINPUTMUX_TmprOutTrigoutToTriginChannels
Selection for frequency measurement reference clock.
-
enumerator kINPUTMUX_Xtal32MhzToFreqmeasRef
-
enumerator kINPUTMUX_FroOsc12MhzToFreqmeasRef
-
enumerator kINPUTMUX_FroOsc96MhzToFreqmeasRef
-
enumerator kINPUTMUX_WdoscToFreqmeasRef
-
enumerator kINPUTMUX_32KhzOscToFreqmeasRef
-
enumerator kINPUTMUX_MainSysClockToFreqmeasRef
-
enumerator kINPUTMUX_FreqmeGpioClkAToFreqmeasRef
-
enumerator kINPUTMUX_FreqmeGpioClkBToFreqmeasRef
-
enumerator kINPUTMUX_Aoi0Out2ToFreqmeasRef
-
enumerator kINPUTMUX_Aoi1Out2ToFreqmeasRef
Selection for frequency measurement target clock.
-
enumerator kINPUTMUX_Xtal32MhzToFreqmeasTarget
-
enumerator kINPUTMUX_FroOsc12MhzToFreqmeasTarget
-
enumerator kINPUTMUX_FroOsc96MhzToFreqmeasTarget
-
enumerator kINPUTMUX_WdoscToFreqmeasTarget
-
enumerator kINPUTMUX_32KhzOscToFreqmeasTarget
-
enumerator kINPUTMUX_MainSysClockToFreqmeasTarget
-
enumerator kINPUTMUX_FreqmeGpioClkAToFreqmeasTarget
-
enumerator kINPUTMUX_FreqmeGpioClkBToFreqmeasTarget
-
enumerator kINPUTMUX_Aoi0Out2ToFreqmeasTarget
-
enumerator kINPUTMUX_Aoi1Out2ToFreqmeasTarget
TIMER3 CAPTSEL.
-
enumerator kINPUTMUX_CtimerInp0ToTimer3Captsel
-
enumerator kINPUTMUX_CtimerInp1ToTimer3Captsel
-
enumerator kINPUTMUX_CtimerInp2ToTimer3Captsel
-
enumerator kINPUTMUX_CtimerInp3ToTimer3Captsel
-
enumerator kINPUTMUX_CtimerInp4ToTimer3Captsel
-
enumerator kINPUTMUX_CtimerInp5ToTimer3Captsel
-
enumerator kINPUTMUX_CtimerInp6ToTimer3Captsel
-
enumerator kINPUTMUX_CtimerInp7ToTimer3Captsel
-
enumerator kINPUTMUX_CtimerInp8ToTimer3Captsel
-
enumerator kINPUTMUX_CtimerInp9ToTimer3Captsel
-
enumerator kINPUTMUX_CtimerInp10ToTimer3Captsel
-
enumerator kINPUTMUX_CtimerInp11ToTimer3Captsel
-
enumerator kINPUTMUX_CtimerInp12ToTimer3Captsel
-
enumerator kINPUTMUX_CtimerInp13ToTimer3Captsel
-
enumerator kINPUTMUX_CtimerInp14ToTimer3Captsel
-
enumerator kINPUTMUX_CtimerInp15ToTimer3Captsel
-
enumerator kINPUTMUX_CtimerInp16ToTimer3Captsel
-
enumerator kINPUTMUX_CtimerInp17ToTimer3Captsel
-
enumerator kINPUTMUX_CtimerInp18ToTimer3Captsel
-
enumerator kINPUTMUX_CtimerInp19ToTimer3Captsel
-
enumerator kINPUTMUX_Usb0FrameToggleToTimer3Captsel
-
enumerator kINPUTMUX_CompOutToTimer3Captsel
-
enumerator kINPUTMUX_I2sSharedWs0ToTimer3Captsel
-
enumerator kINPUTMUX_I2sSharedWs1ToTimer3Captsel
-
enumerator kINPUTMUX_Adc0IrqToTimer3Captsel
-
enumerator kINPUTMUX_Adc1IrqToTimer3Captsel
-
enumerator kINPUTMUX_Hscmp0OutToTimer3Captsel
-
enumerator kINPUTMUX_Hscmp1OutToTimer3Captsel
-
enumerator kINPUTMUX_Hscmp2OutToTimer3Captsel
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig01ToTimer3Captsel
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig01ToTimer3Captsel
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig01ToTimer3Captsel
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig01ToTimer3Captsel
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig01ToTimer3Captsel
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig01ToTimer3Captsel
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig01ToTimer3Captsel
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig01ToTimer3Captsel
-
enumerator kINPUTMUX_Enc0CmpPosMatchToTimer3Captsel
-
enumerator kINPUTMUX_Enc1CmpPosMatchToTimer3Captsel
-
enumerator kINPUTMUX_Aoi0Out0ToTimer3Captsel
-
enumerator kINPUTMUX_Aoi0Out1ToTimer3Captsel
-
enumerator kINPUTMUX_Aoi0Out2ToTimer3Captsel
-
enumerator kINPUTMUX_Aoi0Out3ToTimer3Captsel
-
enumerator kINPUTMUX_Aoi1Out0ToTimer3Captsel
-
enumerator kINPUTMUX_Aoi1Out1ToTimer3Captsel
-
enumerator kINPUTMUX_Aoi1Out2ToTimer3Captsel
-
enumerator kINPUTMUX_Aoi1Out3ToTimer3Captsel
-
enumerator kINPUTMUX_TmprOutToTimer3Captsel
TIMER3 Trigger.
-
enumerator kINPUTMUX_CtimerInp0ToTimer3Trigger
-
enumerator kINPUTMUX_CtimerInp1ToTimer3Trigger
-
enumerator kINPUTMUX_CtimerInp2ToTimer3Trigger
-
enumerator kINPUTMUX_CtimerInp3ToTimer3Trigger
-
enumerator kINPUTMUX_CtimerInp4ToTimer3Trigger
-
enumerator kINPUTMUX_CtimerInp5ToTimer3Trigger
-
enumerator kINPUTMUX_CtimerInp6ToTimer3Trigger
-
enumerator kINPUTMUX_CtimerInp7ToTimer3Trigger
-
enumerator kINPUTMUX_CtimerInp8ToTimer3Trigger
-
enumerator kINPUTMUX_CtimerInp9ToTimer3Trigger
-
enumerator kINPUTMUX_CtimerInp10ToTimer3Trigger
-
enumerator kINPUTMUX_CtimerInp11ToTimer3Trigger
-
enumerator kINPUTMUX_CtimerInp12ToTimer3Trigger
-
enumerator kINPUTMUX_CtimerInp13ToTimer3Trigger
-
enumerator kINPUTMUX_CtimerInp14ToTimer3Trigger
-
enumerator kINPUTMUX_CtimerInp15ToTimer3Trigger
-
enumerator kINPUTMUX_CtimerInp16ToTimer3Trigger
-
enumerator kINPUTMUX_CtimerInp17ToTimer3Trigger
-
enumerator kINPUTMUX_CtimerInp18ToTimer3Trigger
-
enumerator kINPUTMUX_CtimerInp19ToTimer3Trigger
-
enumerator kINPUTMUX_Usb0FrameToggleToTimer3Trigger
-
enumerator kINPUTMUX_CompOutToTimer3Trigger
-
enumerator kINPUTMUX_I2sSharedWs0ToTimer3Trigger
-
enumerator kINPUTMUX_I2sSharedWs1ToTimer3Trigger
-
enumerator kINPUTMUX_Adc0IrqToTimer3Trigger
-
enumerator kINPUTMUX_Adc1IrqToTimer3Trigger
-
enumerator kINPUTMUX_Hscmp0OutToTimer3Trigger
-
enumerator kINPUTMUX_Hscmp1OutToTimer3Trigger
-
enumerator kINPUTMUX_Hscmp2OutToTimer3Trigger
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig01ToTimer3Trigger
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig01ToTimer3Trigger
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig01ToTimer3Trigger
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig01ToTimer3Trigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig01ToTimer3Trigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig01ToTimer3Trigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig01ToTimer3Trigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig01ToTimer3Trigger
-
enumerator kINPUTMUX_Enc0CmpPosMatchToTimer3Trigger
-
enumerator kINPUTMUX_Enc1CmpPosMatchToTimer3Trigger
-
enumerator kINPUTMUX_Aoi0Out0ToTimer3Trigger
-
enumerator kINPUTMUX_Aoi0Out1ToTimer3Trigger
-
enumerator kINPUTMUX_Aoi0Out2ToTimer3Trigger
-
enumerator kINPUTMUX_Aoi0Out3ToTimer3Trigger
-
enumerator kINPUTMUX_Aoi1Out0ToTimer3Trigger
-
enumerator kINPUTMUX_Aoi1Out1ToTimer3Trigger
-
enumerator kINPUTMUX_Aoi1Out2ToTimer3Trigger
-
enumerator kINPUTMUX_Aoi1Out3ToTimer3Trigger
-
enumerator kINPUTMUX_TmprOutToTimer3Trigger
Timer4 CAPTSEL.
-
enumerator kINPUTMUX_CtimerInp0ToTimer4Captsel
-
enumerator kINPUTMUX_CtimerInp1ToTimer4Captsel
-
enumerator kINPUTMUX_CtimerInp2ToTimer4Captsel
-
enumerator kINPUTMUX_CtimerInp3ToTimer4Captsel
-
enumerator kINPUTMUX_CtimerInp4ToTimer4Captsel
-
enumerator kINPUTMUX_CtimerInp5ToTimer4Captsel
-
enumerator kINPUTMUX_CtimerInp6ToTimer4Captsel
-
enumerator kINPUTMUX_CtimerInp7ToTimer4Captsel
-
enumerator kINPUTMUX_CtimerInp8ToTimer4Captsel
-
enumerator kINPUTMUX_CtimerInp9ToTimer4Captsel
-
enumerator kINPUTMUX_CtimerInp10ToTimer4Captsel
-
enumerator kINPUTMUX_CtimerInp11ToTimer4Captsel
-
enumerator kINPUTMUX_CtimerInp12ToTimer4Captsel
-
enumerator kINPUTMUX_CtimerInp13ToTimer4Captsel
-
enumerator kINPUTMUX_CtimerInp14ToTimer4Captsel
-
enumerator kINPUTMUX_CtimerInp15ToTimer4Captsel
-
enumerator kINPUTMUX_CtimerInp16ToTimer4Captsel
-
enumerator kINPUTMUX_CtimerInp17ToTimer4Captsel
-
enumerator kINPUTMUX_CtimerInp18ToTimer4Captsel
-
enumerator kINPUTMUX_CtimerInp19ToTimer4Captsel
-
enumerator kINPUTMUX_Usb0FrameToggleToTimer4Captsel
-
enumerator kINPUTMUX_CompOutToTimer4Captsel
-
enumerator kINPUTMUX_I2sSharedWs0ToTimer4Captsel
-
enumerator kINPUTMUX_I2sSharedWs1ToTimer4Captsel
-
enumerator kINPUTMUX_Adc0IrqToTimer4Captsel
-
enumerator kINPUTMUX_Adc1IrqToTimer4Captsel
-
enumerator kINPUTMUX_Hscmp0OutToTimer4Captsel
-
enumerator kINPUTMUX_Hscmp1OutToTimer4Captsel
-
enumerator kINPUTMUX_Hscmp2OutToTimer4Captsel
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig01ToTimer4Captsel
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig01ToTimer4Captsel
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig01ToTimer4Captsel
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig01ToTimer4Captsel
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig01ToTimer4Captsel
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig01ToTimer4Captsel
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig01ToTimer4Captsel
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig01ToTimer4Captsel
-
enumerator kINPUTMUX_Enc0CmpPosMatchToTimer4Captsel
-
enumerator kINPUTMUX_Enc1CmpPosMatchToTimer4Captsel
-
enumerator kINPUTMUX_Aoi0Out0ToTimer4Captsel
-
enumerator kINPUTMUX_Aoi0Out1ToTimer4Captsel
-
enumerator kINPUTMUX_Aoi0Out2ToTimer4Captsel
-
enumerator kINPUTMUX_Aoi0Out3ToTimer4Captsel
-
enumerator kINPUTMUX_Aoi1Out0ToTimer4Captsel
-
enumerator kINPUTMUX_Aoi1Out1ToTimer4Captsel
-
enumerator kINPUTMUX_Aoi1Out2ToTimer4Captsel
-
enumerator kINPUTMUX_Aoi1Out3ToTimer4Captsel
-
enumerator kINPUTMUX_TmprOutToTimer4Captsel
TIMER4 Trigger.
-
enumerator kINPUTMUX_CtimerInp0ToTimer4Trigger
-
enumerator kINPUTMUX_CtimerInp1ToTimer4Trigger
-
enumerator kINPUTMUX_CtimerInp2ToTimer4Trigger
-
enumerator kINPUTMUX_CtimerInp3ToTimer4Trigger
-
enumerator kINPUTMUX_CtimerInp4ToTimer4Trigger
-
enumerator kINPUTMUX_CtimerInp5ToTimer4Trigger
-
enumerator kINPUTMUX_CtimerInp6ToTimer4Trigger
-
enumerator kINPUTMUX_CtimerInp7ToTimer4Trigger
-
enumerator kINPUTMUX_CtimerInp8ToTimer4Trigger
-
enumerator kINPUTMUX_CtimerInp9ToTimer4Trigger
-
enumerator kINPUTMUX_CtimerInp10ToTimer4Trigger
-
enumerator kINPUTMUX_CtimerInp11ToTimer4Trigger
-
enumerator kINPUTMUX_CtimerInp12ToTimer4Trigger
-
enumerator kINPUTMUX_CtimerInp13ToTimer4Trigger
-
enumerator kINPUTMUX_CtimerInp14ToTimer4Trigger
-
enumerator kINPUTMUX_CtimerInp15ToTimer4Trigger
-
enumerator kINPUTMUX_CtimerInp16ToTimer4Trigger
-
enumerator kINPUTMUX_CtimerInp17ToTimer4Trigger
-
enumerator kINPUTMUX_CtimerInp18ToTimer4Trigger
-
enumerator kINPUTMUX_CtimerInp19ToTimer4Trigger
-
enumerator kINPUTMUX_Usb0FrameToggleToTimer4Trigger
-
enumerator kINPUTMUX_CompOutToTimer4Trigger
-
enumerator kINPUTMUX_I2sSharedWs0ToTimer4Trigger
-
enumerator kINPUTMUX_I2sSharedWs1ToTimer4Trigger
-
enumerator kINPUTMUX_Adc0IrqToTimer4Trigger
-
enumerator kINPUTMUX_Adc1IrqToTimer4Trigger
-
enumerator kINPUTMUX_Hscmp0OutToTimer4Trigger
-
enumerator kINPUTMUX_Hscmp1OutToTimer4Trigger
-
enumerator kINPUTMUX_Hscmp2OutToTimer4Trigger
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig01ToTimer4Trigger
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig01ToTimer4Trigger
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig01ToTimer4Trigger
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig01ToTimer4Trigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig01ToTimer4Trigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig01ToTimer4Trigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig01ToTimer4Trigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig01ToTimer4Trigger
-
enumerator kINPUTMUX_Enc0CmpPosMatchToTimer4Trigger
-
enumerator kINPUTMUX_Enc1CmpPosMatchToTimer4Trigger
-
enumerator kINPUTMUX_Aoi0Out0ToTimer4Trigger
-
enumerator kINPUTMUX_Aoi0Out1ToTimer4Trigger
-
enumerator kINPUTMUX_Aoi0Out2ToTimer4Trigger
-
enumerator kINPUTMUX_Aoi0Out3ToTimer4Trigger
-
enumerator kINPUTMUX_Aoi1Out0ToTimer4Trigger
-
enumerator kINPUTMUX_Aoi1Out1ToTimer4Trigger
-
enumerator kINPUTMUX_Aoi1Out2ToTimer4Trigger
-
enumerator kINPUTMUX_Aoi1Out3ToTimer4Trigger
-
enumerator kINPUTMUX_TmprOutToTimer4Trigger
-
enumerator kINPUTMUX_GpioPort0Pin0ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin1ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin2ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin3ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin4ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin5ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin6ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin7ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin8ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin9ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin10ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin11ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin12ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin13ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin14ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin15ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin16ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin17ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin18ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin19ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin20ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin21ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin22ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin23ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin24ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin25ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin26ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin27ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin28ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin29ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin30ToPintSecsel
-
enumerator kINPUTMUX_GpioPort0Pin31ToPintSecsel
DMA1 Input trigger.
-
enumerator kINPUTMUX_PinInt0ToDma1
-
enumerator kINPUTMUX_PinInt1ToDma1
-
enumerator kINPUTMUX_PinInt2ToDma1
-
enumerator kINPUTMUX_PinInt3ToDma1
-
enumerator kINPUTMUX_Ctimer0M0ToDma1
-
enumerator kINPUTMUX_Ctimer0M1ToDma1
-
enumerator kINPUTMUX_Ctimer2M0ToDma1
-
enumerator kINPUTMUX_Ctimer4M0ToDma1
-
enumerator kINPUTMUX_OtrigAToDma1
-
enumerator kINPUTMUX_OtrigBToDma1
-
enumerator kINPUTMUX_OtrigCToDma1
-
enumerator kINPUTMUX_OtrigDToDma1
-
enumerator kINPUTMUX_Sct0DmaReq0ToDma1
-
enumerator kINPUTMUX_Sct0DmaReq1ToDma1
-
enumerator kINPUTMUX_FlexSpiRxToDma1
-
enumerator kINPUTMUX_FlexSpiTxToDma1
-
enumerator kINPUTMUX_Aoi0Out0ToDma1
-
enumerator kINPUTMUX_Aoi0Out1ToDma1
-
enumerator kINPUTMUX_Aoi0Out2ToDma1
-
enumerator kINPUTMUX_Aoi0Out3ToDma1
-
enumerator kINPUTMUX_Aoi1Out0ToDma1
-
enumerator kINPUTMUX_Aoi1Out1ToDma1
-
enumerator kINPUTMUX_Aoi1Out2ToDma1
-
enumerator kINPUTMUX_Aoi1Out3ToDma1
-
enumerator kINPUTMUX_TmprOutToDma1
DMA1 output trigger.
-
enumerator kINPUTMUX_Dma1HsLspiRxTrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma1HsLspiTxTrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma1Flexcom0RxTrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma1Flexcom0TxTrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma1Flexcom1RxTrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma1Flexcom1TxTrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma1Flexcom3RxTrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma1Flexcom3TxTrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma1Dmic0Ch0TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma1Dmic0Ch1TrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma1I3c0RxTrigoutToTriginChannels
-
enumerator kINPUTMUX_Dma1I3c0TxTrigoutToTriginChannels
HSCMP0 trigger.
-
enumerator kINPUTMUX_PinInt0ToHscmp0Trigger
-
enumerator kINPUTMUX_PinInt6ToHscmp0Trigger
-
enumerator kINPUTMUX_SctOut4ToHscmp0Trigger
-
enumerator kINPUTMUX_SctOut5ToHscmp0Trigger
-
enumerator kINPUTMUX_SctOut6ToHscmp0Trigger
-
enumerator kINPUTMUX_Ctimer0M3ToHscmp0Trigger
-
enumerator kINPUTMUX_Ctimer1M3ToHscmp0Trigger
-
enumerator kINPUTMUX_Ctimer2M3ToHscmp0Trigger
-
enumerator kINPUTMUX_Ctimer0M0ToHscmp0Trigger
-
enumerator kINPUTMUX_Ctimer4M0ToHscmp0Trigger
-
enumerator kINPUTMUX_ArmTxevToHscmp0Trigger
-
enumerator kINPUTMUX_GpiointBmatchToHscmp0Trigger
-
enumerator kINPUTMUX_Adc0Tcomp0ToHscmp0Trigger
-
enumerator kINPUTMUX_Adc1Tcomp0ToHscmp0Trigger
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig01ToHscmp0Trigger
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig01ToHscmp0Trigger
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig01ToHscmp0Trigger
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig01ToHscmp0Trigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig01ToHscmp0Trigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig01ToHscmp0Trigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig01ToHscmp0Trigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig01ToHscmp0Trigger
-
enumerator kINPUTMUX_Enc0CmpPosMatchToHscmp0Trigger
-
enumerator kINPUTMUX_Enc1CmpPosMatchToHscmp0Trigger
-
enumerator kINPUTMUX_Aoi0Out0ToHscmp0Trigger
-
enumerator kINPUTMUX_Aoi0Out1ToHscmp0Trigger
-
enumerator kINPUTMUX_Aoi0Out2ToHscmp0Trigger
-
enumerator kINPUTMUX_Aoi0Out3ToHscmp0Trigger
-
enumerator kINPUTMUX_Aoi1Out0ToHscmp0Trigger
-
enumerator kINPUTMUX_Aoi1Out1ToHscmp0Trigger
-
enumerator kINPUTMUX_Aoi1Out2ToHscmp0Trigger
-
enumerator kINPUTMUX_Aoi1Out3ToHscmp0Trigger
-
enumerator kINPUTMUX_Dma0Trigout0ToHscmp0Trigger
-
enumerator kINPUTMUX_Dma0Trigout1ToHscmp0Trigger
-
enumerator kINPUTMUX_Dma0Trigout2ToHscmp0Trigger
ADC0 trigger.
-
enumerator kINPUTMUX_PinInt0ToAdc0Trigger
-
enumerator kINPUTMUX_PinInt1ToAdc0Trigger
-
enumerator kINPUTMUX_SctOut4ToAdc0Trigger
-
enumerator kINPUTMUX_SctOut5ToAdc0Trigger
-
enumerator kINPUTMUX_SctOut9ToAdc0Trigger
-
enumerator kINPUTMUX_Ctimer0M3ToAdc0Trigger
-
enumerator kINPUTMUX_Ctimer1M3ToAdc0Trigger
-
enumerator kINPUTMUX_Ctimer2M3ToAdc0Trigger
-
enumerator kINPUTMUX_Ctimer3M3ToAdc0Trigger
-
enumerator kINPUTMUX_Ctimer4M3ToAdc0Trigger
-
enumerator kINPUTMUX_CompOutToAdc0Trigger
-
enumerator kINPUTMUX_ArmTxevToAdc0Trigger
-
enumerator kINPUTMUX_GpiointBmatchToAdc0Trigger
-
enumerator kINPUTMUX_Adc0Tcomp0ToAdc0Trigger
-
enumerator kINPUTMUX_Adc0Tcomp1ToAdc0Trigger
-
enumerator kINPUTMUX_Adc0Tcomp2ToAdc0Trigger
-
enumerator kINPUTMUX_Adc0Tcomp3ToAdc0Trigger
-
enumerator kINPUTMUX_Adc1Tcomp0ToAdc0Trigger
-
enumerator kINPUTMUX_Adc1Tcomp1ToAdc0Trigger
-
enumerator kINPUTMUX_Adc1Tcomp2ToAdc0Trigger
-
enumerator kINPUTMUX_Adc1Tcomp3ToAdc0Trigger
-
enumerator kINPUTMUX_Hscmp0OutToAdc0Trigger
-
enumerator kINPUTMUX_Hscmp1OutToAdc0Trigger
-
enumerator kINPUTMUX_Hscmp2OutToAdc0Trigger
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig0ToAdc0Trigger
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig1ToAdc0Trigger
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig0ToAdc0Trigger
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig1ToAdc0Trigger
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig0ToAdc0Trigger
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig1ToAdc0Trigger
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig0ToAdc0Trigger
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig1ToAdc0Trigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig0ToAdc0Trigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig1ToAdc0Trigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig0ToAdc0Trigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig1ToAdc0Trigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig0ToAdc0Trigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig1ToAdc0Trigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig0ToAdc0Trigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig1ToAdc0Trigger
-
enumerator kINPUTMUX_Enc0CmpPosMatchToAdc0Trigger
-
enumerator kINPUTMUX_Enc1CmpPosMatchToAdc0Trigger
-
enumerator kINPUTMUX_Aoi0Out0ToAdc0Trigger
-
enumerator kINPUTMUX_Aoi0Out1ToAdc0Trigger
-
enumerator kINPUTMUX_Aoi0Out2ToAdc0Trigger
-
enumerator kINPUTMUX_Aoi0Out3ToAdc0Trigger
-
enumerator kINPUTMUX_Aoi1Out0ToAdc0Trigger
-
enumerator kINPUTMUX_Aoi1Out1ToAdc0Trigger
-
enumerator kINPUTMUX_Aoi1Out2ToAdc0Trigger
-
enumerator kINPUTMUX_Aoi1Out3ToAdc0Trigger
-
enumerator kINPUTMUX_Dma0Trigout0ToAdc0Trigger
-
enumerator kINPUTMUX_Dma0Trigout1ToAdc0Trigger
-
enumerator kINPUTMUX_Dma0Trigout2ToAdc0Trigger
ADC1 trigger.
-
enumerator kINPUTMUX_PinInt0ToAdc1Trigger
-
enumerator kINPUTMUX_PinInt2ToAdc1Trigger
-
enumerator kINPUTMUX_SctOut4ToAdc1Trigger
-
enumerator kINPUTMUX_SctOut5ToAdc1Trigger
-
enumerator kINPUTMUX_SctOut3ToAdc1Trigger
-
enumerator kINPUTMUX_Ctimer0M3ToAdc1Trigger
-
enumerator kINPUTMUX_Ctimer1M3ToAdc1Trigger
-
enumerator kINPUTMUX_Ctimer2M3ToAdc1Trigger
-
enumerator kINPUTMUX_Ctimer3M2ToAdc1Trigger
-
enumerator kINPUTMUX_Ctimer4M1ToAdc1Trigger
-
enumerator kINPUTMUX_CompOutToAdc1Trigger
-
enumerator kINPUTMUX_ArmTxevToAdc1Trigger
-
enumerator kINPUTMUX_GpiointBmatchToAdc1Trigger
-
enumerator kINPUTMUX_Adc0Tcomp0ToAdc1Trigger
-
enumerator kINPUTMUX_Adc0Tcomp1ToAdc1Trigger
-
enumerator kINPUTMUX_Adc0Tcomp2ToAdc1Trigger
-
enumerator kINPUTMUX_Adc0Tcomp3ToAdc1Trigger
-
enumerator kINPUTMUX_Adc1Tcomp0ToAdc1Trigger
-
enumerator kINPUTMUX_Adc1Tcomp1ToAdc1Trigger
-
enumerator kINPUTMUX_Adc1Tcomp2ToAdc1Trigger
-
enumerator kINPUTMUX_Adc1Tcomp3ToAdc1Trigger
-
enumerator kINPUTMUX_Hscmp0OutToAdc1Trigger
-
enumerator kINPUTMUX_Hscmp1OutToAdc1Trigger
-
enumerator kINPUTMUX_Hscmp2OutToAdc1Trigger
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig0ToAdc1Trigger
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig1ToAdc1Trigger
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig0ToAdc1Trigger
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig1ToAdc1Trigger
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig0ToAdc1Trigger
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig1ToAdc1Trigger
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig0ToAdc1Trigger
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig1ToAdc1Trigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig0ToAdc1Trigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig1ToAdc1Trigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig0ToAdc1Trigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig1ToAdc1Trigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig0ToAdc1Trigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig1ToAdc1Trigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig0ToAdc1Trigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig1ToAdc1Trigger
-
enumerator kINPUTMUX_Enc0CmpPosMatchToAdc1Trigger
-
enumerator kINPUTMUX_Enc1CmpPosMatchToAdc1Trigger
-
enumerator kINPUTMUX_Aoi0Out0ToAdc1Trigger
-
enumerator kINPUTMUX_Aoi0Out1ToAdc1Trigger
-
enumerator kINPUTMUX_Aoi0Out2ToAdc1Trigger
-
enumerator kINPUTMUX_Aoi0Out3ToAdc1Trigger
-
enumerator kINPUTMUX_Aoi1Out0ToAdc1Trigger
-
enumerator kINPUTMUX_Aoi1Out1ToAdc1Trigger
-
enumerator kINPUTMUX_Aoi1Out2ToAdc1Trigger
-
enumerator kINPUTMUX_Aoi1Out3ToAdc1Trigger
-
enumerator kINPUTMUX_Dma0Trigout0ToAdc1Trigger
-
enumerator kINPUTMUX_Dma0Trigout1ToAdc1Trigger
-
enumerator kINPUTMUX_Dma0Trigout2ToAdc1Trigger
DAC0 trigger.
-
enumerator kINPUTMUX_PinInt0ToDac0Trigger
-
enumerator kINPUTMUX_PinInt3ToDac0Trigger
-
enumerator kINPUTMUX_SctOut4ToDac0Trigger
-
enumerator kINPUTMUX_SctOut5ToDac0Trigger
-
enumerator kINPUTMUX_SctOut0ToDac0Trigger
-
enumerator kINPUTMUX_Ctimer0M3ToDac0Trigger
-
enumerator kINPUTMUX_Ctimer1M3ToDac0Trigger
-
enumerator kINPUTMUX_Ctimer2M3ToDac0Trigger
-
enumerator kINPUTMUX_Ctimer2M0ToDac0Trigger
-
enumerator kINPUTMUX_Ctimer3M0ToDac0Trigger
-
enumerator kINPUTMUX_CompOutToDac0Trigger
-
enumerator kINPUTMUX_ArmTxevToDac0Trigger
-
enumerator kINPUTMUX_GpiointBmatchToDac0Trigger
-
enumerator kINPUTMUX_Adc0Tcomp0ToDac0Trigger
-
enumerator kINPUTMUX_Adc1Tcomp0ToDac0Trigger
-
enumerator kINPUTMUX_Hscmp0OutToDac0Trigger
-
enumerator kINPUTMUX_Hscmp1OutToDac0Trigger
-
enumerator kINPUTMUX_Hscmp2OutToDac0Trigger
-
enumerator kINPUTMUX_Aoi0Out0ToDac0Trigger
-
enumerator kINPUTMUX_Aoi0Out1ToDac0Trigger
-
enumerator kINPUTMUX_Aoi0Out2ToDac0Trigger
-
enumerator kINPUTMUX_Aoi0Out3ToDac0Trigger
-
enumerator kINPUTMUX_Aoi1Out0ToDac0Trigger
-
enumerator kINPUTMUX_Aoi1Out1ToDac0Trigger
-
enumerator kINPUTMUX_Aoi1Out2ToDac0Trigger
-
enumerator kINPUTMUX_Aoi1Out3ToDac0Trigger
-
enumerator kINPUTMUX_Dma0Trigout0ToDac0Trigger
-
enumerator kINPUTMUX_Dma0Trigout1ToDac0Trigger
-
enumerator kINPUTMUX_Dma0Trigout2ToDac0Trigger
DAC1 trigger.
-
enumerator kINPUTMUX_PinInt0ToDac1Trigger
-
enumerator kINPUTMUX_PinInt4ToDac1Trigger
-
enumerator kINPUTMUX_SctOut4ToDac1Trigger
-
enumerator kINPUTMUX_SctOut5ToDac1Trigger
-
enumerator kINPUTMUX_SctOut1ToDac1Trigger
-
enumerator kINPUTMUX_Ctimer0M3ToDac1Trigger
-
enumerator kINPUTMUX_Ctimer1M3ToDac1Trigger
-
enumerator kINPUTMUX_Ctimer2M3ToDac1Trigger
-
enumerator kINPUTMUX_Ctimer2M1ToDac1Trigger
-
enumerator kINPUTMUX_Ctimer3M1ToDac1Trigger
-
enumerator kINPUTMUX_CompOutToDac1Trigger
-
enumerator kINPUTMUX_ArmTxevToDac1Trigger
-
enumerator kINPUTMUX_GpiointBmatchToDac1Trigger
-
enumerator kINPUTMUX_Adc0Tcomp1ToDac1Trigger
-
enumerator kINPUTMUX_Adc1Tcomp1ToDac1Trigger
-
enumerator kINPUTMUX_Hscmp0OutToDac1Trigger
-
enumerator kINPUTMUX_Hscmp1OutToDac1Trigger
-
enumerator kINPUTMUX_Hscmp2OutToDac1Trigger
-
enumerator kINPUTMUX_Aoi0Out0ToDac1Trigger
-
enumerator kINPUTMUX_Aoi0Out1ToDac1Trigger
-
enumerator kINPUTMUX_Aoi0Out2ToDac1Trigger
-
enumerator kINPUTMUX_Aoi0Out3ToDac1Trigger
-
enumerator kINPUTMUX_Aoi1Out0ToDac1Trigger
-
enumerator kINPUTMUX_Aoi1Out1ToDac1Trigger
-
enumerator kINPUTMUX_Aoi1Out2ToDac1Trigger
-
enumerator kINPUTMUX_Aoi1Out3ToDac1Trigger
-
enumerator kINPUTMUX_Dma0Trigout0ToDac1Trigger
-
enumerator kINPUTMUX_Dma0Trigout1ToDac1Trigger
-
enumerator kINPUTMUX_Dma0Trigout2ToDac1Trigger
DAC2 trigger.
-
enumerator kINPUTMUX_PinInt0ToDac2Trigger
-
enumerator kINPUTMUX_PinInt5ToDac2Trigger
-
enumerator kINPUTMUX_SctOut4ToDac2Trigger
-
enumerator kINPUTMUX_SctOut5ToDac2Trigger
-
enumerator kINPUTMUX_SctOut2ToDac2Trigger
-
enumerator kINPUTMUX_Ctimer0M3ToDac2Trigger
-
enumerator kINPUTMUX_Ctimer1M3ToDac2Trigger
-
enumerator kINPUTMUX_Ctimer2M3ToDac2Trigger
-
enumerator kINPUTMUX_Ctimer2M2ToDac2Trigger
-
enumerator kINPUTMUX_Ctimer3M2ToDac2Trigger
-
enumerator kINPUTMUX_CompOutToDac2Trigger
-
enumerator kINPUTMUX_ArmTxevToDac2Trigger
-
enumerator kINPUTMUX_GpiointBmatchToDac2Trigger
-
enumerator kINPUTMUX_Adc0Tcomp2ToDac2Trigger
-
enumerator kINPUTMUX_Adc1Tcomp2ToDac2Trigger
-
enumerator kINPUTMUX_Hscmp0OutToDac2Trigger
-
enumerator kINPUTMUX_Hscmp1OutToDac2Trigger
-
enumerator kINPUTMUX_Hscmp2OutToDac2Trigger
-
enumerator kINPUTMUX_Aoi0Out0ToDac2Trigger
-
enumerator kINPUTMUX_Aoi0Out1ToDac2Trigger
-
enumerator kINPUTMUX_Aoi0Out2ToDac2Trigger
-
enumerator kINPUTMUX_Aoi0Out3ToDac2Trigger
-
enumerator kINPUTMUX_Aoi1Out0ToDac2Trigger
-
enumerator kINPUTMUX_Aoi1Out1ToDac2Trigger
-
enumerator kINPUTMUX_Aoi1Out2ToDac2Trigger
-
enumerator kINPUTMUX_Aoi1Out3ToDac2Trigger
-
enumerator kINPUTMUX_Dma0Trigout0ToDac2Trigger
-
enumerator kINPUTMUX_Dma0Trigout1ToDac2Trigger
-
enumerator kINPUTMUX_Dma0Trigout2ToDac2Trigger
ENC0 TRIG.
-
enumerator kINPUTMUX_PinInt0ToEnc0Trigger
-
enumerator kINPUTMUX_PinInt4ToEnc0Trigger
-
enumerator kINPUTMUX_SctOut4ToEnc0Trigger
-
enumerator kINPUTMUX_SctOut5ToEnc0Trigger
-
enumerator kINPUTMUX_SctOut1ToEnc0Trigger
-
enumerator kINPUTMUX_Ctimer0M3ToEnc0Trigger
-
enumerator kINPUTMUX_Ctimer1M3ToEnc0Trigger
-
enumerator kINPUTMUX_Ctimer2M3ToEnc0Trigger
-
enumerator kINPUTMUX_Ctimer1M0ToEnc0Trigger
-
enumerator kINPUTMUX_Ctimer3M0ToEnc0Trigger
-
enumerator kINPUTMUX_CompOutToEnc0Trigger
-
enumerator kINPUTMUX_ArmTxevToEnc0Trigger
-
enumerator kINPUTMUX_GpiointBmatchToEnc0Trigger
-
enumerator kINPUTMUX_Adc0Tcomp0ToEnc0Trigger
-
enumerator kINPUTMUX_Adc0Tcomp1ToEnc0Trigger
-
enumerator kINPUTMUX_Adc0Tcomp2ToEnc0Trigger
-
enumerator kINPUTMUX_Adc0Tcomp3ToEnc0Trigger
-
enumerator kINPUTMUX_Adc1Tcomp0ToEnc0Trigger
-
enumerator kINPUTMUX_Adc1Tcomp1ToEnc0Trigger
-
enumerator kINPUTMUX_Adc1Tcomp2ToEnc0Trigger
-
enumerator kINPUTMUX_Adc1Tcomp3ToEnc0Trigger
-
enumerator kINPUTMUX_Hscmp0OutToEnc0Trigger
-
enumerator kINPUTMUX_Hscmp1OutToEnc0Trigger
-
enumerator kINPUTMUX_Hscmp2OutToEnc0Trigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig0ToEnc0Trigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig1ToEnc0Trigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig0ToEnc0Trigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig1ToEnc0Trigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig0ToEnc0Trigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig1ToEnc0Trigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig0ToEnc0Trigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig1ToEnc0Trigger
-
enumerator kINPUTMUX_Enc0CmpPosMatchToEnc0Trigger
-
enumerator kINPUTMUX_Enc1CmpPosMatchToEnc0Trigger
-
enumerator kINPUTMUX_Aoi0Out0ToEnc0Trigger
-
enumerator kINPUTMUX_Aoi0Out1ToEnc0Trigger
-
enumerator kINPUTMUX_Aoi0Out2ToEnc0Trigger
-
enumerator kINPUTMUX_Aoi0Out3ToEnc0Trigger
-
enumerator kINPUTMUX_Aoi1Out0ToEnc0Trigger
-
enumerator kINPUTMUX_Aoi1Out1ToEnc0Trigger
-
enumerator kINPUTMUX_Aoi1Out2ToEnc0Trigger
-
enumerator kINPUTMUX_Aoi1Out3ToEnc0Trigger
-
enumerator kINPUTMUX_ExtTrigIn0ToEnc0Trigger
-
enumerator kINPUTMUX_ExtTrigIn1ToEnc0Trigger
-
enumerator kINPUTMUX_ExtTrigIn2ToEnc0Trigger
-
enumerator kINPUTMUX_ExtTrigIn3ToEnc0Trigger
-
enumerator kINPUTMUX_ExtTrigIn4ToEnc0Trigger
-
enumerator kINPUTMUX_ExtTrigIn5ToEnc0Trigger
-
enumerator kINPUTMUX_ExtTrigIn6ToEnc0Trigger
-
enumerator kINPUTMUX_ExtTrigIn7ToEnc0Trigger
-
enumerator kINPUTMUX_ExtTrigIn8ToEnc0Trigger
-
enumerator kINPUTMUX_ExtTrigIn9ToEnc0Trigger
-
enumerator kINPUTMUX_Dma0Trigout0ToEnc0Trigger
-
enumerator kINPUTMUX_Dma0Trigout1ToEnc0Trigger
-
enumerator kINPUTMUX_Dma0Trigout2ToEnc0Trigger
ENC0 HOME.
-
enumerator kINPUTMUX_PinInt0ToEnc0Home
-
enumerator kINPUTMUX_PinInt4ToEnc0Home
-
enumerator kINPUTMUX_SctOut4ToEnc0Home
-
enumerator kINPUTMUX_SctOut5ToEnc0Home
-
enumerator kINPUTMUX_SctOut1ToEnc0Home
-
enumerator kINPUTMUX_Ctimer0M3ToEnc0Home
-
enumerator kINPUTMUX_Ctimer1M3ToEnc0Home
-
enumerator kINPUTMUX_Ctimer2M3ToEnc0Home
-
enumerator kINPUTMUX_Ctimer1M0ToEnc0Home
-
enumerator kINPUTMUX_Ctimer3M0ToEnc0Home
-
enumerator kINPUTMUX_CompOutToEnc0Home
-
enumerator kINPUTMUX_ArmTxevToEnc0Home
-
enumerator kINPUTMUX_GpiointBmatchToEnc0Home
-
enumerator kINPUTMUX_Adc0Tcomp0ToEnc0Home
-
enumerator kINPUTMUX_Adc0Tcomp1ToEnc0Home
-
enumerator kINPUTMUX_Adc0Tcomp2ToEnc0Home
-
enumerator kINPUTMUX_Adc0Tcomp3ToEnc0Home
-
enumerator kINPUTMUX_Adc1Tcomp0ToEnc0Home
-
enumerator kINPUTMUX_Adc1Tcomp1ToEnc0Home
-
enumerator kINPUTMUX_Adc1Tcomp2ToEnc0Home
-
enumerator kINPUTMUX_Adc1Tcomp3ToEnc0Home
-
enumerator kINPUTMUX_Hscmp0OutToEnc0Home
-
enumerator kINPUTMUX_Hscmp1OutToEnc0Home
-
enumerator kINPUTMUX_Hscmp2OutToEnc0Home
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig0ToEnc0Home
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig1ToEnc0Home
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig0ToEnc0Home
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig1ToEnc0Home
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig0ToEnc0Home
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig1ToEnc0Home
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig0ToEnc0Home
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig1ToEnc0Home
-
enumerator kINPUTMUX_Enc0CmpPosMatchToEnc0Home
-
enumerator kINPUTMUX_Enc1CmpPosMatchToEnc0Home
-
enumerator kINPUTMUX_Aoi0Out0ToEnc0Home
-
enumerator kINPUTMUX_Aoi0Out1ToEnc0Home
-
enumerator kINPUTMUX_Aoi0Out2ToEnc0Home
-
enumerator kINPUTMUX_Aoi0Out3ToEnc0Home
-
enumerator kINPUTMUX_Aoi1Out0ToEnc0Home
-
enumerator kINPUTMUX_Aoi1Out1ToEnc0Home
-
enumerator kINPUTMUX_Aoi1Out2ToEnc0Home
-
enumerator kINPUTMUX_Aoi1Out3ToEnc0Home
-
enumerator kINPUTMUX_ExtTrigIn0ToEnc0Home
-
enumerator kINPUTMUX_ExtTrigIn1ToEnc0Home
-
enumerator kINPUTMUX_ExtTrigIn2ToEnc0Home
-
enumerator kINPUTMUX_ExtTrigIn3ToEnc0Home
-
enumerator kINPUTMUX_ExtTrigIn4ToEnc0Home
-
enumerator kINPUTMUX_ExtTrigIn5ToEnc0Home
-
enumerator kINPUTMUX_ExtTrigIn6ToEnc0Home
-
enumerator kINPUTMUX_ExtTrigIn7ToEnc0Home
-
enumerator kINPUTMUX_ExtTrigIn8ToEnc0Home
-
enumerator kINPUTMUX_ExtTrigIn9ToEnc0Home
-
enumerator kINPUTMUX_Dma0Trigout0ToEnc0Home
-
enumerator kINPUTMUX_Dma0Trigout1ToEnc0Home
-
enumerator kINPUTMUX_Dma0Trigout2ToEnc0Home
ENC0 INDEX.
-
enumerator kINPUTMUX_PinInt0ToEnc0Index
-
enumerator kINPUTMUX_PinInt4ToEnc0Index
-
enumerator kINPUTMUX_SctOut4ToEnc0Index
-
enumerator kINPUTMUX_SctOut5ToEnc0Index
-
enumerator kINPUTMUX_SctOut1ToEnc0Index
-
enumerator kINPUTMUX_Ctimer0M3ToEnc0Index
-
enumerator kINPUTMUX_Ctimer1M3ToEnc0Index
-
enumerator kINPUTMUX_Ctimer2M3ToEnc0Index
-
enumerator kINPUTMUX_Ctimer1M0ToEnc0Index
-
enumerator kINPUTMUX_Ctimer3M0ToEnc0Index
-
enumerator kINPUTMUX_CompOutToEnc0Index
-
enumerator kINPUTMUX_ArmTxevToEnc0Index
-
enumerator kINPUTMUX_GpiointBmatchToEnc0Index
-
enumerator kINPUTMUX_Adc0Tcomp0ToEnc0Index
-
enumerator kINPUTMUX_Adc0Tcomp1ToEnc0Index
-
enumerator kINPUTMUX_Adc0Tcomp2ToEnc0Index
-
enumerator kINPUTMUX_Adc0Tcomp3ToEnc0Index
-
enumerator kINPUTMUX_Adc1Tcomp0ToEnc0Index
-
enumerator kINPUTMUX_Adc1Tcomp1ToEnc0Index
-
enumerator kINPUTMUX_Adc1Tcomp2ToEnc0Index
-
enumerator kINPUTMUX_Adc1Tcomp3ToEnc0Index
-
enumerator kINPUTMUX_Hscmp0OutToEnc0Index
-
enumerator kINPUTMUX_Hscmp1OutToEnc0Index
-
enumerator kINPUTMUX_Hscmp2OutToEnc0Index
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig0ToEnc0Index
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig1ToEnc0Index
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig0ToEnc0Index
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig1ToEnc0Index
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig0ToEnc0Index
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig1ToEnc0Index
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig0ToEnc0Index
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig1ToEnc0Index
-
enumerator kINPUTMUX_Enc0CmpPosMatchToEnc0Index
-
enumerator kINPUTMUX_Enc1CmpPosMatchToEnc0Index
-
enumerator kINPUTMUX_Aoi0Out0ToEnc0Index
-
enumerator kINPUTMUX_Aoi0Out1ToEnc0Index
-
enumerator kINPUTMUX_Aoi0Out2ToEnc0Index
-
enumerator kINPUTMUX_Aoi0Out3ToEnc0Index
-
enumerator kINPUTMUX_Aoi1Out0ToEnc0Index
-
enumerator kINPUTMUX_Aoi1Out1ToEnc0Index
-
enumerator kINPUTMUX_Aoi1Out2ToEnc0Index
-
enumerator kINPUTMUX_Aoi1Out3ToEnc0Index
-
enumerator kINPUTMUX_ExtTrigIn0ToEnc0Index
-
enumerator kINPUTMUX_ExtTrigIn1ToEnc0Index
-
enumerator kINPUTMUX_ExtTrigIn2ToEnc0Index
-
enumerator kINPUTMUX_ExtTrigIn3ToEnc0Index
-
enumerator kINPUTMUX_ExtTrigIn4ToEnc0Index
-
enumerator kINPUTMUX_ExtTrigIn5ToEnc0Index
-
enumerator kINPUTMUX_ExtTrigIn6ToEnc0Index
-
enumerator kINPUTMUX_ExtTrigIn7ToEnc0Index
-
enumerator kINPUTMUX_ExtTrigIn8ToEnc0Index
-
enumerator kINPUTMUX_ExtTrigIn9ToEnc0Index
-
enumerator kINPUTMUX_Dma0Trigout0ToEnc0Index
-
enumerator kINPUTMUX_Dma0Trigout1ToEnc0Index
-
enumerator kINPUTMUX_Dma0Trigout2ToEnc0Index
ENC0 PHASEB.
-
enumerator kINPUTMUX_PinInt0ToEnc0Phaseb
-
enumerator kINPUTMUX_PinInt4ToEnc0Phaseb
-
enumerator kINPUTMUX_SctOut4ToEnc0Phaseb
-
enumerator kINPUTMUX_SctOut5ToEnc0Phaseb
-
enumerator kINPUTMUX_SctOut1ToEnc0Phaseb
-
enumerator kINPUTMUX_Ctimer0M3ToEnc0Phaseb
-
enumerator kINPUTMUX_Ctimer1M3ToEnc0Phaseb
-
enumerator kINPUTMUX_Ctimer2M3ToEnc0Phaseb
-
enumerator kINPUTMUX_Ctimer1M0ToEnc0Phaseb
-
enumerator kINPUTMUX_Ctimer3M0ToEnc0Phaseb
-
enumerator kINPUTMUX_CompOutToEnc0Phaseb
-
enumerator kINPUTMUX_ArmTxevToEnc0Phaseb
-
enumerator kINPUTMUX_GpiointBmatchToEnc0Phaseb
-
enumerator kINPUTMUX_Adc0Tcomp0ToEnc0Phaseb
-
enumerator kINPUTMUX_Adc0Tcomp1ToEnc0Phaseb
-
enumerator kINPUTMUX_Adc0Tcomp2ToEnc0Phaseb
-
enumerator kINPUTMUX_Adc0Tcomp3ToEnc0Phaseb
-
enumerator kINPUTMUX_Adc1Tcomp0ToEnc0Phaseb
-
enumerator kINPUTMUX_Adc1Tcomp1ToEnc0Phaseb
-
enumerator kINPUTMUX_Adc1Tcomp2ToEnc0Phaseb
-
enumerator kINPUTMUX_Adc1Tcomp3ToEnc0Phaseb
-
enumerator kINPUTMUX_Hscmp0OutToEnc0Phaseb
-
enumerator kINPUTMUX_Hscmp1OutToEnc0Phaseb
-
enumerator kINPUTMUX_Hscmp2OutToEnc0Phaseb
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig0ToEnc0Phaseb
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig1ToEnc0Phaseb
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig0ToEnc0Phaseb
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig1ToEnc0Phaseb
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig0ToEnc0Phaseb
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig1ToEnc0Phaseb
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig0ToEnc0Phaseb
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig1ToEnc0Phaseb
-
enumerator kINPUTMUX_Enc0CmpPosMatchToEnc0Phaseb
-
enumerator kINPUTMUX_Enc1CmpPosMatchToEnc0Phaseb
-
enumerator kINPUTMUX_Aoi0Out0ToEnc0Phaseb
-
enumerator kINPUTMUX_Aoi0Out1ToEnc0Phaseb
-
enumerator kINPUTMUX_Aoi0Out2ToEnc0Phaseb
-
enumerator kINPUTMUX_Aoi0Out3ToEnc0Phaseb
-
enumerator kINPUTMUX_Aoi1Out0ToEnc0Phaseb
-
enumerator kINPUTMUX_Aoi1Out1ToEnc0Phaseb
-
enumerator kINPUTMUX_Aoi1Out2ToEnc0Phaseb
-
enumerator kINPUTMUX_Aoi1Out3ToEnc0Phaseb
-
enumerator kINPUTMUX_ExtTrigIn0ToEnc0Phaseb
-
enumerator kINPUTMUX_ExtTrigIn1ToEnc0Phaseb
-
enumerator kINPUTMUX_ExtTrigIn2ToEnc0Phaseb
-
enumerator kINPUTMUX_ExtTrigIn3ToEnc0Phaseb
-
enumerator kINPUTMUX_ExtTrigIn4ToEnc0Phaseb
-
enumerator kINPUTMUX_ExtTrigIn5ToEnc0Phaseb
-
enumerator kINPUTMUX_ExtTrigIn6ToEnc0Phaseb
-
enumerator kINPUTMUX_ExtTrigIn7ToEnc0Phaseb
-
enumerator kINPUTMUX_ExtTrigIn8ToEnc0Phaseb
-
enumerator kINPUTMUX_ExtTrigIn9ToEnc0Phaseb
-
enumerator kINPUTMUX_Dma0Trigout0ToEnc0Phaseb
-
enumerator kINPUTMUX_Dma0Trigout1ToEnc0Phaseb
-
enumerator kINPUTMUX_Dma0Trigout2ToEnc0Phaseb
ENC0 PHASEA.
-
enumerator kINPUTMUX_PinInt0ToEnc0Phasea
-
enumerator kINPUTMUX_PinInt4ToEnc0Phasea
-
enumerator kINPUTMUX_SctOut4ToEnc0Phasea
-
enumerator kINPUTMUX_SctOut5ToEnc0Phasea
-
enumerator kINPUTMUX_SctOut1ToEnc0Phasea
-
enumerator kINPUTMUX_Ctimer0M3ToEnc0Phasea
-
enumerator kINPUTMUX_Ctimer1M3ToEnc0Phasea
-
enumerator kINPUTMUX_Ctimer2M3ToEnc0Phasea
-
enumerator kINPUTMUX_Ctimer1M0ToEnc0Phasea
-
enumerator kINPUTMUX_Ctimer3M0ToEnc0Phasea
-
enumerator kINPUTMUX_CompOutToEnc0Phasea
-
enumerator kINPUTMUX_ArmTxevToEnc0Phasea
-
enumerator kINPUTMUX_GpiointBmatchToEnc0Phasea
-
enumerator kINPUTMUX_Adc0Tcomp0ToEnc0Phasea
-
enumerator kINPUTMUX_Adc0Tcomp1ToEnc0Phasea
-
enumerator kINPUTMUX_Adc0Tcomp2ToEnc0Phasea
-
enumerator kINPUTMUX_Adc0Tcomp3ToEnc0Phasea
-
enumerator kINPUTMUX_Adc1Tcomp0ToEnc0Phasea
-
enumerator kINPUTMUX_Adc1Tcomp1ToEnc0Phasea
-
enumerator kINPUTMUX_Adc1Tcomp2ToEnc0Phasea
-
enumerator kINPUTMUX_Adc1Tcomp3ToEnc0Phasea
-
enumerator kINPUTMUX_Hscmp0OutToEnc0Phasea
-
enumerator kINPUTMUX_Hscmp1OutToEnc0Phasea
-
enumerator kINPUTMUX_Hscmp2OutToEnc0Phasea
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig0ToEnc0Phasea
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig1ToEnc0Phasea
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig0ToEnc0Phasea
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig1ToEnc0Phasea
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig0ToEnc0Phasea
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig1ToEnc0Phasea
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig0ToEnc0Phasea
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig1ToEnc0Phasea
-
enumerator kINPUTMUX_Enc0CmpPosMatchToEnc0Phasea
-
enumerator kINPUTMUX_Enc1CmpPosMatchToEnc0Phasea
-
enumerator kINPUTMUX_Aoi0Out0ToEnc0Phasea
-
enumerator kINPUTMUX_Aoi0Out1ToEnc0Phasea
-
enumerator kINPUTMUX_Aoi0Out2ToEnc0Phasea
-
enumerator kINPUTMUX_Aoi0Out3ToEnc0Phasea
-
enumerator kINPUTMUX_Aoi1Out0ToEnc0Phasea
-
enumerator kINPUTMUX_Aoi1Out1ToEnc0Phasea
-
enumerator kINPUTMUX_Aoi1Out2ToEnc0Phasea
-
enumerator kINPUTMUX_Aoi1Out3ToEnc0Phasea
-
enumerator kINPUTMUX_ExtTrigIn0ToEnc0Phasea
-
enumerator kINPUTMUX_ExtTrigIn1ToEnc0Phasea
-
enumerator kINPUTMUX_ExtTrigIn2ToEnc0Phasea
-
enumerator kINPUTMUX_ExtTrigIn3ToEnc0Phasea
-
enumerator kINPUTMUX_ExtTrigIn4ToEnc0Phasea
-
enumerator kINPUTMUX_ExtTrigIn5ToEnc0Phasea
-
enumerator kINPUTMUX_ExtTrigIn6ToEnc0Phasea
-
enumerator kINPUTMUX_ExtTrigIn7ToEnc0Phasea
-
enumerator kINPUTMUX_ExtTrigIn8ToEnc0Phasea
-
enumerator kINPUTMUX_ExtTrigIn9ToEnc0Phasea
-
enumerator kINPUTMUX_Dma0Trigout0ToEnc0Phasea
-
enumerator kINPUTMUX_Dma0Trigout1ToEnc0Phasea
-
enumerator kINPUTMUX_Dma0Trigout2ToEnc0Phasea
ENC1 TRIG.
-
enumerator kINPUTMUX_PinInt0ToEnc1Trigger
-
enumerator kINPUTMUX_PinInt5ToEnc1Trigger
-
enumerator kINPUTMUX_SctOut4ToEnc1Trigger
-
enumerator kINPUTMUX_SctOut5ToEnc1Trigger
-
enumerator kINPUTMUX_SctOut7ToEnc1Trigger
-
enumerator kINPUTMUX_Ctimer0M3ToEnc1Trigger
-
enumerator kINPUTMUX_Ctimer1M3ToEnc1Trigger
-
enumerator kINPUTMUX_Ctimer2M3ToEnc1Trigger
-
enumerator kINPUTMUX_Ctimer1M1ToEnc1Trigger
-
enumerator kINPUTMUX_Ctimer3M1ToEnc1Trigger
-
enumerator kINPUTMUX_CompOutToEnc1Trigger
-
enumerator kINPUTMUX_ArmTxevToEnc1Trigger
-
enumerator kINPUTMUX_GpiointBmatchToEnc1Trigger
-
enumerator kINPUTMUX_Adc0Tcomp0ToEnc1Trigger
-
enumerator kINPUTMUX_Adc0Tcomp1ToEnc1Trigger
-
enumerator kINPUTMUX_Adc0Tcomp2ToEnc1Trigger
-
enumerator kINPUTMUX_Adc0Tcomp3ToEnc1Trigger
-
enumerator kINPUTMUX_Adc1Tcomp0ToEnc1Trigger
-
enumerator kINPUTMUX_Adc1Tcomp1ToEnc1Trigger
-
enumerator kINPUTMUX_Adc1Tcomp2ToEnc1Trigger
-
enumerator kINPUTMUX_Adc1Tcomp3ToEnc1Trigger
-
enumerator kINPUTMUX_Hscmp0OutToEnc1Trigger
-
enumerator kINPUTMUX_Hscmp1OutToEnc1Trigger
-
enumerator kINPUTMUX_Hscmp2OutToEnc1Trigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig0ToEnc1Trigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig1ToEnc1Trigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig0ToEnc1Trigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig1ToEnc1Trigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig0ToEnc1Trigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig1ToEnc1Trigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig0ToEnc1Trigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig1ToEnc1Trigger
-
enumerator kINPUTMUX_Enc0CmpPosMatchToEnc1Trigger
-
enumerator kINPUTMUX_Enc1CmpPosMatchToEnc1Trigger
-
enumerator kINPUTMUX_Aoi0Out0ToEnc1Trigger
-
enumerator kINPUTMUX_Aoi0Out1ToEnc1Trigger
-
enumerator kINPUTMUX_Aoi0Out2ToEnc1Trigger
-
enumerator kINPUTMUX_Aoi0Out3ToEnc1Trigger
-
enumerator kINPUTMUX_Aoi1Out0ToEnc1Trigger
-
enumerator kINPUTMUX_Aoi1Out1ToEnc1Trigger
-
enumerator kINPUTMUX_Aoi1Out2ToEnc1Trigger
-
enumerator kINPUTMUX_Aoi1Out3ToEnc1Trigger
-
enumerator kINPUTMUX_ExtTrigIn0ToEnc1Trigger
-
enumerator kINPUTMUX_ExtTrigIn1ToEnc1Trigger
-
enumerator kINPUTMUX_ExtTrigIn2ToEnc1Trigger
-
enumerator kINPUTMUX_ExtTrigIn3ToEnc1Trigger
-
enumerator kINPUTMUX_ExtTrigIn4ToEnc1Trigger
-
enumerator kINPUTMUX_ExtTrigIn5ToEnc1Trigger
-
enumerator kINPUTMUX_ExtTrigIn6ToEnc1Trigger
-
enumerator kINPUTMUX_ExtTrigIn7ToEnc1Trigger
-
enumerator kINPUTMUX_ExtTrigIn8ToEnc1Trigger
-
enumerator kINPUTMUX_ExtTrigIn9ToEnc1Trigger
-
enumerator kINPUTMUX_Dma0Trigout0ToEnc1Trigger
-
enumerator kINPUTMUX_Dma0Trigout1ToEnc1Trigger
-
enumerator kINPUTMUX_Dma0Trigout2ToEnc1Trigger
ENC1 HOME.
-
enumerator kINPUTMUX_PinInt0ToEnc1Home
-
enumerator kINPUTMUX_PinInt5ToEnc1Home
-
enumerator kINPUTMUX_SctOut4ToEnc1Home
-
enumerator kINPUTMUX_SctOut5ToEnc1Home
-
enumerator kINPUTMUX_SctOut7ToEnc1Home
-
enumerator kINPUTMUX_Ctimer0M3ToEnc1Home
-
enumerator kINPUTMUX_Ctimer1M3ToEnc1Home
-
enumerator kINPUTMUX_Ctimer2M3ToEnc1Home
-
enumerator kINPUTMUX_Ctimer1M1ToEnc1Home
-
enumerator kINPUTMUX_Ctimer3M1ToEnc1Home
-
enumerator kINPUTMUX_CompOutToEnc1Home
-
enumerator kINPUTMUX_ArmTxevToEnc1Home
-
enumerator kINPUTMUX_GpiointBmatchToEnc1Home
-
enumerator kINPUTMUX_Adc0Tcomp0ToEnc1Home
-
enumerator kINPUTMUX_Adc0Tcomp1ToEnc1Home
-
enumerator kINPUTMUX_Adc0Tcomp2ToEnc1Home
-
enumerator kINPUTMUX_Adc0Tcomp3ToEnc1Home
-
enumerator kINPUTMUX_Adc1Tcomp0ToEnc1Home
-
enumerator kINPUTMUX_Adc1Tcomp1ToEnc1Home
-
enumerator kINPUTMUX_Adc1Tcomp2ToEnc1Home
-
enumerator kINPUTMUX_Adc1Tcomp3ToEnc1Home
-
enumerator kINPUTMUX_Hscmp0OutToEnc1Home
-
enumerator kINPUTMUX_Hscmp1OutToEnc1Home
-
enumerator kINPUTMUX_Hscmp2OutToEnc1Home
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig0ToEnc1Home
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig1ToEnc1Home
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig0ToEnc1Home
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig1ToEnc1Home
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig0ToEnc1Home
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig1ToEnc1Home
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig0ToEnc1Home
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig1ToEnc1Home
-
enumerator kINPUTMUX_Enc0CmpPosMatchToEnc1Home
-
enumerator kINPUTMUX_Enc1CmpPosMatchToEnc1Home
-
enumerator kINPUTMUX_Aoi0Out0ToEnc1Home
-
enumerator kINPUTMUX_Aoi0Out1ToEnc1Home
-
enumerator kINPUTMUX_Aoi0Out2ToEnc1Home
-
enumerator kINPUTMUX_Aoi0Out3ToEnc1Home
-
enumerator kINPUTMUX_Aoi1Out0ToEnc1Home
-
enumerator kINPUTMUX_Aoi1Out1ToEnc1Home
-
enumerator kINPUTMUX_Aoi1Out2ToEnc1Home
-
enumerator kINPUTMUX_Aoi1Out3ToEnc1Home
-
enumerator kINPUTMUX_ExtTrigIn0ToEnc1Home
-
enumerator kINPUTMUX_ExtTrigIn1ToEnc1Home
-
enumerator kINPUTMUX_ExtTrigIn2ToEnc1Home
-
enumerator kINPUTMUX_ExtTrigIn3ToEnc1Home
-
enumerator kINPUTMUX_ExtTrigIn4ToEnc1Home
-
enumerator kINPUTMUX_ExtTrigIn5ToEnc1Home
-
enumerator kINPUTMUX_ExtTrigIn6ToEnc1Home
-
enumerator kINPUTMUX_ExtTrigIn7ToEnc1Home
-
enumerator kINPUTMUX_ExtTrigIn8ToEnc1Home
-
enumerator kINPUTMUX_ExtTrigIn9ToEnc1Home
-
enumerator kINPUTMUX_Dma0Trigout0ToEnc1Home
-
enumerator kINPUTMUX_Dma0Trigout1ToEnc1Home
-
enumerator kINPUTMUX_Dma0Trigout2ToEnc1Home
ENC1 INDEX.
-
enumerator kINPUTMUX_PinInt0ToEnc1Index
-
enumerator kINPUTMUX_PinInt5ToEnc1Index
-
enumerator kINPUTMUX_SctOut4ToEnc1Index
-
enumerator kINPUTMUX_SctOut5ToEnc1Index
-
enumerator kINPUTMUX_SctOut7ToEnc1Index
-
enumerator kINPUTMUX_Ctimer0M3ToEnc1Index
-
enumerator kINPUTMUX_Ctimer1M3ToEnc1Index
-
enumerator kINPUTMUX_Ctimer2M3ToEnc1Index
-
enumerator kINPUTMUX_Ctimer1M1ToEnc1Index
-
enumerator kINPUTMUX_Ctimer3M1ToEnc1Index
-
enumerator kINPUTMUX_CompOutToEnc1Index
-
enumerator kINPUTMUX_ArmTxevToEnc1Index
-
enumerator kINPUTMUX_GpiointBmatchToEnc1Index
-
enumerator kINPUTMUX_Adc0Tcomp0ToEnc1Index
-
enumerator kINPUTMUX_Adc0Tcomp1ToEnc1Index
-
enumerator kINPUTMUX_Adc0Tcomp2ToEnc1Index
-
enumerator kINPUTMUX_Adc0Tcomp3ToEnc1Index
-
enumerator kINPUTMUX_Adc1Tcomp0ToEnc1Index
-
enumerator kINPUTMUX_Adc1Tcomp1ToEnc1Index
-
enumerator kINPUTMUX_Adc1Tcomp2ToEnc1Index
-
enumerator kINPUTMUX_Adc1Tcomp3ToEnc1Index
-
enumerator kINPUTMUX_Hscmp0OutToEnc1Index
-
enumerator kINPUTMUX_Hscmp1OutToEnc1Index
-
enumerator kINPUTMUX_Hscmp2OutToEnc1Index
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig0ToEnc1Index
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig1ToEnc1Index
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig0ToEnc1Index
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig1ToEnc1Index
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig0ToEnc1Index
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig1ToEnc1Index
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig0ToEnc1Index
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig1ToEnc1Index
-
enumerator kINPUTMUX_Enc0CmpPosMatchToEnc1Index
-
enumerator kINPUTMUX_Enc1CmpPosMatchToEnc1Index
-
enumerator kINPUTMUX_Aoi0Out0ToEnc1Index
-
enumerator kINPUTMUX_Aoi0Out1ToEnc1Index
-
enumerator kINPUTMUX_Aoi0Out2ToEnc1Index
-
enumerator kINPUTMUX_Aoi0Out3ToEnc1Index
-
enumerator kINPUTMUX_Aoi1Out0ToEnc1Index
-
enumerator kINPUTMUX_Aoi1Out1ToEnc1Index
-
enumerator kINPUTMUX_Aoi1Out2ToEnc1Index
-
enumerator kINPUTMUX_Aoi1Out3ToEnc1Index
-
enumerator kINPUTMUX_ExtTrigIn0ToEnc1Index
-
enumerator kINPUTMUX_ExtTrigIn1ToEnc1Index
-
enumerator kINPUTMUX_ExtTrigIn2ToEnc1Index
-
enumerator kINPUTMUX_ExtTrigIn3ToEnc1Index
-
enumerator kINPUTMUX_ExtTrigIn4ToEnc1Index
-
enumerator kINPUTMUX_ExtTrigIn5ToEnc1Index
-
enumerator kINPUTMUX_ExtTrigIn6ToEnc1Index
-
enumerator kINPUTMUX_ExtTrigIn7ToEnc1Index
-
enumerator kINPUTMUX_ExtTrigIn8ToEnc1Index
-
enumerator kINPUTMUX_ExtTrigIn9ToEnc1Index
-
enumerator kINPUTMUX_Dma0Trigout0ToEnc1Index
-
enumerator kINPUTMUX_Dma0Trigout1ToEnc1Index
-
enumerator kINPUTMUX_Dma0Trigout2ToEnc1Index
ENC1 PHASEB.
-
enumerator kINPUTMUX_PinInt0ToEnc1Phaseb
-
enumerator kINPUTMUX_PinInt5ToEnc1Phaseb
-
enumerator kINPUTMUX_SctOut4ToEnc1Phaseb
-
enumerator kINPUTMUX_SctOut5ToEnc1Phaseb
-
enumerator kINPUTMUX_SctOut7ToEnc1Phaseb
-
enumerator kINPUTMUX_Ctimer0M3ToEnc1Phaseb
-
enumerator kINPUTMUX_Ctimer1M3ToEnc1Phaseb
-
enumerator kINPUTMUX_Ctimer2M3ToEnc1Phaseb
-
enumerator kINPUTMUX_Ctimer1M1ToEnc1Phaseb
-
enumerator kINPUTMUX_Ctimer3M1ToEnc1Phaseb
-
enumerator kINPUTMUX_CompOutToEnc1Phaseb
-
enumerator kINPUTMUX_ArmTxevToEnc1Phaseb
-
enumerator kINPUTMUX_GpiointBmatchToEnc1Phaseb
-
enumerator kINPUTMUX_Adc0Tcomp0ToEnc1Phaseb
-
enumerator kINPUTMUX_Adc0Tcomp1ToEnc1Phaseb
-
enumerator kINPUTMUX_Adc0Tcomp2ToEnc1Phaseb
-
enumerator kINPUTMUX_Adc0Tcomp3ToEnc1Phaseb
-
enumerator kINPUTMUX_Adc1Tcomp0ToEnc1Phaseb
-
enumerator kINPUTMUX_Adc1Tcomp1ToEnc1Phaseb
-
enumerator kINPUTMUX_Adc1Tcomp2ToEnc1Phaseb
-
enumerator kINPUTMUX_Adc1Tcomp3ToEnc1Phaseb
-
enumerator kINPUTMUX_Hscmp0OutToEnc1Phaseb
-
enumerator kINPUTMUX_Hscmp1OutToEnc1Phaseb
-
enumerator kINPUTMUX_Hscmp2OutToEnc1Phaseb
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig0ToEnc1Phaseb
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig1ToEnc1Phaseb
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig0ToEnc1Phaseb
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig1ToEnc1Phaseb
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig0ToEnc1Phaseb
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig1ToEnc1Phaseb
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig0ToEnc1Phaseb
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig1ToEnc1Phaseb
-
enumerator kINPUTMUX_Enc0CmpPosMatchToEnc1Phaseb
-
enumerator kINPUTMUX_Enc1CmpPosMatchToEnc1Phaseb
-
enumerator kINPUTMUX_Aoi0Out0ToEnc1Phaseb
-
enumerator kINPUTMUX_Aoi0Out1ToEnc1Phaseb
-
enumerator kINPUTMUX_Aoi0Out2ToEnc1Phaseb
-
enumerator kINPUTMUX_Aoi0Out3ToEnc1Phaseb
-
enumerator kINPUTMUX_Aoi1Out0ToEnc1Phaseb
-
enumerator kINPUTMUX_Aoi1Out1ToEnc1Phaseb
-
enumerator kINPUTMUX_Aoi1Out2ToEnc1Phaseb
-
enumerator kINPUTMUX_Aoi1Out3ToEnc1Phaseb
-
enumerator kINPUTMUX_ExtTrigIn0ToEnc1Phaseb
-
enumerator kINPUTMUX_ExtTrigIn1ToEnc1Phaseb
-
enumerator kINPUTMUX_ExtTrigIn2ToEnc1Phaseb
-
enumerator kINPUTMUX_ExtTrigIn3ToEnc1Phaseb
-
enumerator kINPUTMUX_ExtTrigIn4ToEnc1Phaseb
-
enumerator kINPUTMUX_ExtTrigIn5ToEnc1Phaseb
-
enumerator kINPUTMUX_ExtTrigIn6ToEnc1Phaseb
-
enumerator kINPUTMUX_ExtTrigIn7ToEnc1Phaseb
-
enumerator kINPUTMUX_ExtTrigIn8ToEnc1Phaseb
-
enumerator kINPUTMUX_ExtTrigIn9ToEnc1Phaseb
-
enumerator kINPUTMUX_Dma0Trigout0ToEnc1Phaseb
-
enumerator kINPUTMUX_Dma0Trigout1ToEnc1Phaseb
-
enumerator kINPUTMUX_Dma0Trigout2ToEnc1Phaseb
ENC1 PHASEA.
-
enumerator kINPUTMUX_PinInt0ToEnc1Phasea
-
enumerator kINPUTMUX_PinInt5ToEnc1Phasea
-
enumerator kINPUTMUX_SctOut4ToEnc1Phasea
-
enumerator kINPUTMUX_SctOut5ToEnc1Phasea
-
enumerator kINPUTMUX_SctOut7ToEnc1Phasea
-
enumerator kINPUTMUX_Ctimer0M3ToEnc1Phasea
-
enumerator kINPUTMUX_Ctimer1M3ToEnc1Phasea
-
enumerator kINPUTMUX_Ctimer2M3ToEnc1Phasea
-
enumerator kINPUTMUX_Ctimer1M1ToEnc1Phasea
-
enumerator kINPUTMUX_Ctimer3M1ToEnc1Phasea
-
enumerator kINPUTMUX_CompOutToEnc1Phasea
-
enumerator kINPUTMUX_ArmTxevToEnc1Phasea
-
enumerator kINPUTMUX_GpiointBmatchToEnc1Phasea
-
enumerator kINPUTMUX_Adc0Tcomp0ToEnc1Phasea
-
enumerator kINPUTMUX_Adc0Tcomp1ToEnc1Phasea
-
enumerator kINPUTMUX_Adc0Tcomp2ToEnc1Phasea
-
enumerator kINPUTMUX_Adc0Tcomp3ToEnc1Phasea
-
enumerator kINPUTMUX_Adc1Tcomp0ToEnc1Phasea
-
enumerator kINPUTMUX_Adc1Tcomp1ToEnc1Phasea
-
enumerator kINPUTMUX_Adc1Tcomp2ToEnc1Phasea
-
enumerator kINPUTMUX_Adc1Tcomp3ToEnc1Phasea
-
enumerator kINPUTMUX_Hscmp0OutToEnc1Phasea
-
enumerator kINPUTMUX_Hscmp1OutToEnc1Phasea
-
enumerator kINPUTMUX_Hscmp2OutToEnc1Phasea
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig0ToEnc1Phasea
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig1ToEnc1Phasea
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig0ToEnc1Phasea
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig1ToEnc1Phasea
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig0ToEnc1Phasea
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig1ToEnc1Phasea
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig0ToEnc1Phasea
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig1ToEnc1Phasea
-
enumerator kINPUTMUX_Enc0CmpPosMatchToEnc1Phasea
-
enumerator kINPUTMUX_Enc1CmpPosMatchToEnc1Phasea
-
enumerator kINPUTMUX_Aoi0Out0ToEnc1Phasea
-
enumerator kINPUTMUX_Aoi0Out1ToEnc1Phasea
-
enumerator kINPUTMUX_Aoi0Out2ToEnc1Phasea
-
enumerator kINPUTMUX_Aoi0Out3ToEnc1Phasea
-
enumerator kINPUTMUX_Aoi1Out0ToEnc1Phasea
-
enumerator kINPUTMUX_Aoi1Out1ToEnc1Phasea
-
enumerator kINPUTMUX_Aoi1Out2ToEnc1Phasea
-
enumerator kINPUTMUX_Aoi1Out3ToEnc1Phasea
-
enumerator kINPUTMUX_ExtTrigIn0ToEnc1Phasea
-
enumerator kINPUTMUX_ExtTrigIn1ToEnc1Phasea
-
enumerator kINPUTMUX_ExtTrigIn2ToEnc1Phasea
-
enumerator kINPUTMUX_ExtTrigIn3ToEnc1Phasea
-
enumerator kINPUTMUX_ExtTrigIn4ToEnc1Phasea
-
enumerator kINPUTMUX_ExtTrigIn5ToEnc1Phasea
-
enumerator kINPUTMUX_ExtTrigIn6ToEnc1Phasea
-
enumerator kINPUTMUX_ExtTrigIn7ToEnc1Phasea
-
enumerator kINPUTMUX_ExtTrigIn8ToEnc1Phasea
-
enumerator kINPUTMUX_ExtTrigIn9ToEnc1Phasea
-
enumerator kINPUTMUX_Dma0Trigout0ToEnc1Phasea
-
enumerator kINPUTMUX_Dma0Trigout1ToEnc1Phasea
-
enumerator kINPUTMUX_Dma0Trigout2ToEnc1Phasea
PWM0 external synchronization trigger.
-
enumerator kINPUTMUX_PinInt0ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_PinInt5ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_SctOut4ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_SctOut5ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_SctOut2ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Ctimer0M3ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Ctimer1M3ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Ctimer2M3ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Ctimer2M0ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Ctimer4M0ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_CompOutToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_ArmTxevToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_GpiointBmatchToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Adc0Tcomp0ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Adc0Tcomp1ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Adc0Tcomp2ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Adc0Tcomp3ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Adc1Tcomp0ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Adc1Tcomp1ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Adc1Tcomp2ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Adc1Tcomp3ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Hscmp0OutToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Hscmp1OutToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Hscmp2OutToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig0ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig1ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig0ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig1ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig0ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig1ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig0ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig1ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Enc0CmpPosMatchToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Enc1CmpPosMatchToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Aoi0Out0ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Aoi0Out1ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Aoi0Out2ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Aoi0Out3ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Aoi1Out0ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Aoi1Out1ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Aoi1Out2ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Aoi1Out3ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_ExtTrigIn0ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_ExtTrigIn1ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_ExtTrigIn2ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_ExtTrigIn3ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_ExtTrigIn4ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_ExtTrigIn5ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_ExtTrigIn6ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_ExtTrigIn7ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_ExtTrigIn8ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_ExtTrigIn9ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Dma0Trigout0ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Dma0Trigout1ToPwm0ExtSyncTrigger
-
enumerator kINPUTMUX_Dma0Trigout2ToPwm0ExtSyncTrigger
PWM0 input trigger connections trigger.
-
enumerator kINPUTMUX_PinInt0ToPwm0ExtATrigger
-
enumerator kINPUTMUX_PinInt5ToPwm0ExtATrigger
-
enumerator kINPUTMUX_SctOut4ToPwm0ExtATrigger
-
enumerator kINPUTMUX_SctOut5ToPwm0ExtATrigger
-
enumerator kINPUTMUX_SctOut2ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Ctimer0M3ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Ctimer1M3ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Ctimer2M3ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Ctimer2M0ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Ctimer4M0ToPwm0ExtATrigger
-
enumerator kINPUTMUX_CompOutToPwm0ExtATrigger
-
enumerator kINPUTMUX_ArmTxevToPwm0ExtATrigger
-
enumerator kINPUTMUX_GpiointBmatchToPwm0ExtATrigger
-
enumerator kINPUTMUX_Adc0Tcomp0ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Adc0Tcomp1ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Adc0Tcomp2ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Adc0Tcomp3ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Adc1Tcomp0ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Adc1Tcomp1ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Adc1Tcomp2ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Adc1Tcomp3ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Hscmp0OutToPwm0ExtATrigger
-
enumerator kINPUTMUX_Hscmp1OutToPwm0ExtATrigger
-
enumerator kINPUTMUX_Hscmp2OutToPwm0ExtATrigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig0ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig1ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig0ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig1ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig0ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig1ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig0ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig1ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Enc0CmpPosMatchToPwm0ExtATrigger
-
enumerator kINPUTMUX_Enc1CmpPosMatchToPwm0ExtATrigger
-
enumerator kINPUTMUX_Aoi0Out0ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Aoi0Out1ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Aoi0Out2ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Aoi0Out3ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Aoi1Out0ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Aoi1Out1ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Aoi1Out2ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Aoi1Out3ToPwm0ExtATrigger
-
enumerator kINPUTMUX_ExtTrigIn0ToPwm0ExtATrigger
-
enumerator kINPUTMUX_ExtTrigIn1ToPwm0ExtATrigger
-
enumerator kINPUTMUX_ExtTrigIn2ToPwm0ExtATrigger
-
enumerator kINPUTMUX_ExtTrigIn3ToPwm0ExtATrigger
-
enumerator kINPUTMUX_ExtTrigIn4ToPwm0ExtATrigger
-
enumerator kINPUTMUX_ExtTrigIn5ToPwm0ExtATrigger
-
enumerator kINPUTMUX_ExtTrigIn6ToPwm0ExtATrigger
-
enumerator kINPUTMUX_ExtTrigIn7ToPwm0ExtATrigger
-
enumerator kINPUTMUX_ExtTrigIn8ToPwm0ExtATrigger
-
enumerator kINPUTMUX_ExtTrigIn9ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Dma0Trigout0ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Dma0Trigout1ToPwm0ExtATrigger
-
enumerator kINPUTMUX_Dma0Trigout2ToPwm0ExtATrigger
PWM0 external force trigger connections trigger.
-
enumerator kINPUTMUX_PinInt0ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_PinInt5ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_SctOut4ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_SctOut5ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_SctOut2ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Ctimer0M3ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Ctimer1M3ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Ctimer2M3ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Ctimer2M0ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Ctimer4M0ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_CompOutToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_ArmTxevToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_GpiointBmatchToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Adc0Tcomp0ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Adc0Tcomp1ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Adc0Tcomp2ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Adc0Tcomp3ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Adc1Tcomp0ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Adc1Tcomp1ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Adc1Tcomp2ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Adc1Tcomp3ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Hscmp0OutToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Hscmp1OutToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Hscmp2OutToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig0ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig1ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig0ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig1ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig0ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig1ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig0ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig1ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Enc0CmpPosMatchToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Enc1CmpPosMatchToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Aoi0Out0ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Aoi0Out1ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Aoi0Out2ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Aoi0Out3ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Aoi1Out0ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Aoi1Out1ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Aoi1Out2ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Aoi1Out3ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_ExtTrigIn0ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_ExtTrigIn1ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_ExtTrigIn2ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_ExtTrigIn3ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_ExtTrigIn4ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_ExtTrigIn5ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_ExtTrigIn6ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_ExtTrigIn7ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_ExtTrigIn8ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_ExtTrigIn9ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Dma0Trigout0ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Dma0Trigout1ToPwm0ExtForceTrigger
-
enumerator kINPUTMUX_Dma0Trigout2ToPwm0ExtForceTrigger
PWM0 fault input trigger connections trigger.
-
enumerator kINPUTMUX_PinInt0ToPwm0FaultTrigger
-
enumerator kINPUTMUX_PinInt5ToPwm0FaultTrigger
-
enumerator kINPUTMUX_SctOut4ToPwm0FaultTrigger
-
enumerator kINPUTMUX_SctOut5ToPwm0FaultTrigger
-
enumerator kINPUTMUX_SctOut2ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Ctimer0M3ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Ctimer1M3ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Ctimer2M3ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Ctimer2M0ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Ctimer4M0ToPwm0FaultTrigger
-
enumerator kINPUTMUX_CompOutToPwm0FaultTrigger
-
enumerator kINPUTMUX_ArmTxevToPwm0FaultTrigger
-
enumerator kINPUTMUX_GpiointBmatchToPwm0FaultTrigger
-
enumerator kINPUTMUX_Adc0Tcomp0ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Adc0Tcomp1ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Adc0Tcomp2ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Adc0Tcomp3ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Adc1Tcomp0ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Adc1Tcomp1ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Adc1Tcomp2ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Adc1Tcomp3ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Hscmp0OutToPwm0FaultTrigger
-
enumerator kINPUTMUX_Hscmp1OutToPwm0FaultTrigger
-
enumerator kINPUTMUX_Hscmp2OutToPwm0FaultTrigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig0ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig1ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig0ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig1ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig0ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig1ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig0ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig1ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Enc0CmpPosMatchToPwm0FaultTrigger
-
enumerator kINPUTMUX_Enc1CmpPosMatchToPwm0FaultTrigger
-
enumerator kINPUTMUX_Aoi0Out0ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Aoi0Out1ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Aoi0Out2ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Aoi0Out3ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Aoi1Out0ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Aoi1Out1ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Aoi1Out2ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Aoi1Out3ToPwm0FaultTrigger
-
enumerator kINPUTMUX_ExtTrigIn0ToPwm0FaultTrigger
-
enumerator kINPUTMUX_ExtTrigIn1ToPwm0FaultTrigger
-
enumerator kINPUTMUX_ExtTrigIn2ToPwm0FaultTrigger
-
enumerator kINPUTMUX_ExtTrigIn3ToPwm0FaultTrigger
-
enumerator kINPUTMUX_ExtTrigIn4ToPwm0FaultTrigger
-
enumerator kINPUTMUX_ExtTrigIn5ToPwm0FaultTrigger
-
enumerator kINPUTMUX_ExtTrigIn6ToPwm0FaultTrigger
-
enumerator kINPUTMUX_ExtTrigIn7ToPwm0FaultTrigger
-
enumerator kINPUTMUX_ExtTrigIn8ToPwm0FaultTrigger
-
enumerator kINPUTMUX_ExtTrigIn9ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Dma0Trigout0ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Dma0Trigout1ToPwm0FaultTrigger
-
enumerator kINPUTMUX_Dma0Trigout2ToPwm0FaultTrigger
PWM0 extclk input trigger connections trigger.
-
enumerator kINPUTMUX_PinInt0ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_PinInt5ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_SctOut4ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_SctOut5ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_SctOut2ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Ctimer0M3ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Ctimer1M3ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Ctimer2M3ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Ctimer2M0ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Ctimer4M0ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_CompOutToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_ArmTxevToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_GpiointBmatchToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Adc0Tcomp0ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Adc0Tcomp1ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Adc0Tcomp2ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Adc0Tcomp3ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Adc1Tcomp0ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Adc1Tcomp1ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Adc1Tcomp2ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Adc1Tcomp3ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Hscmp0OutToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Hscmp1OutToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Hscmp2OutToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig0ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig1ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig0ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig1ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig0ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig1ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig0ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig1ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Enc0CmpPosMatchToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Enc1CmpPosMatchToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Aoi0Out0ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Aoi0Out1ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Aoi0Out2ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Aoi0Out3ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Aoi1Out0ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Aoi1Out1ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Aoi1Out2ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Aoi1Out3ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_ExtTrigIn0ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_ExtTrigIn1ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_ExtTrigIn2ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_ExtTrigIn3ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_ExtTrigIn4ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_ExtTrigIn5ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_ExtTrigIn6ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_ExtTrigIn7ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_ExtTrigIn8ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_ExtTrigIn9ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Dma0Trigout0ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Dma0Trigout1ToPwm0ExtClkTrigger
-
enumerator kINPUTMUX_Dma0Trigout2ToPwm0ExtClkTrigger
PWM1 external synchronization trigger.
-
enumerator kINPUTMUX_PinInt0ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_PinInt2ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_SctOut4ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_SctOut5ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_SctOut3ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Ctimer0M3ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Ctimer1M3ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Ctimer2M3ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Ctimer2M1ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Ctimer4M1ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_CompOutToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_ArmTxevToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_GpiointBmatchToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Adc0Tcomp0ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Adc0Tcomp1ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Adc0Tcomp2ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Adc0Tcomp3ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Adc1Tcomp0ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Adc1Tcomp1ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Adc1Tcomp2ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Adc1Tcomp3ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Hscmp0OutToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Hscmp1OutToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Hscmp2OutToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig0ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig1ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig0ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig1ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig0ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig1ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig0ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig1ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Enc0CmpPosMatchToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Enc1CmpPosMatchToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Aoi0Out0ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Aoi0Out1ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Aoi0Out2ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Aoi0Out3ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Aoi1Out0ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Aoi1Out1ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Aoi1Out2ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Aoi1Out3ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_ExtTrigIn0ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_ExtTrigIn1ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_ExtTrigIn2ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_ExtTrigIn3ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_ExtTrigIn4ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_ExtTrigIn5ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_ExtTrigIn6ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_ExtTrigIn7ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_ExtTrigIn8ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_ExtTrigIn9ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Dma0Trigout0ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Dma0Trigout1ToPwm1ExtSyncTrigger
-
enumerator kINPUTMUX_Dma0Trigout2ToPwm1ExtSyncTrigger
PWM1 input trigger connections trigger.
-
enumerator kINPUTMUX_PinInt0ToPwm1ExtATrigger
-
enumerator kINPUTMUX_PinInt2ToPwm1ExtATrigger
-
enumerator kINPUTMUX_SctOut4ToPwm1ExtATrigger
-
enumerator kINPUTMUX_SctOut5ToPwm1ExtATrigger
-
enumerator kINPUTMUX_SctOut3ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Ctimer0M3ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Ctimer1M3ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Ctimer2M3ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Ctimer2M1ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Ctimer4M1ToPwm1ExtATrigger
-
enumerator kINPUTMUX_CompOutToPwm1ExtATrigger
-
enumerator kINPUTMUX_ArmTxevToPwm1ExtATrigger
-
enumerator kINPUTMUX_GpiointBmatchToPwm1ExtATrigger
-
enumerator kINPUTMUX_Adc0Tcomp0ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Adc0Tcomp1ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Adc0Tcomp2ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Adc0Tcomp3ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Adc1Tcomp0ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Adc1Tcomp1ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Adc1Tcomp2ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Adc1Tcomp3ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Hscmp0OutToPwm1ExtATrigger
-
enumerator kINPUTMUX_Hscmp1OutToPwm1ExtATrigger
-
enumerator kINPUTMUX_Hscmp2OutToPwm1ExtATrigger
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig0ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig1ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig0ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig1ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig0ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig1ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig0ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig1ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Enc0CmpPosMatchToPwm1ExtATrigger
-
enumerator kINPUTMUX_Enc1CmpPosMatchToPwm1ExtATrigger
-
enumerator kINPUTMUX_Aoi0Out0ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Aoi0Out1ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Aoi0Out2ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Aoi0Out3ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Aoi1Out0ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Aoi1Out1ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Aoi1Out2ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Aoi1Out3ToPwm1ExtATrigger
-
enumerator kINPUTMUX_ExtTrigIn0ToPwm1ExtATrigger
-
enumerator kINPUTMUX_ExtTrigIn1ToPwm1ExtATrigger
-
enumerator kINPUTMUX_ExtTrigIn2ToPwm1ExtATrigger
-
enumerator kINPUTMUX_ExtTrigIn3ToPwm1ExtATrigger
-
enumerator kINPUTMUX_ExtTrigIn4ToPwm1ExtATrigger
-
enumerator kINPUTMUX_ExtTrigIn5ToPwm1ExtATrigger
-
enumerator kINPUTMUX_ExtTrigIn6ToPwm1ExtATrigger
-
enumerator kINPUTMUX_ExtTrigIn7ToPwm1ExtATrigger
-
enumerator kINPUTMUX_ExtTrigIn8ToPwm1ExtATrigger
-
enumerator kINPUTMUX_ExtTrigIn9ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Dma0Trigout0ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Dma0Trigout1ToPwm1ExtATrigger
-
enumerator kINPUTMUX_Dma0Trigout2ToPwm1ExtATrigger
PWM1 external force trigger connections.
-
enumerator kINPUTMUX_PinInt0ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_PinInt2ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_SctOut4ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_SctOut5ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_SctOut3ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Ctimer0M3ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Ctimer1M3ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Ctimer2M3ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Ctimer2M1ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Ctimer4M1ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_CompOutToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_ArmTxevToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_GpiointBmatchToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Adc0Tcomp0ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Adc0Tcomp1ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Adc0Tcomp2ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Adc0Tcomp3ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Adc1Tcomp0ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Adc1Tcomp1ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Adc1Tcomp2ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Adc1Tcomp3ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Hscmp0OutToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Hscmp1OutToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Hscmp2OutToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig0ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig1ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig0ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig1ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig0ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig1ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig0ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig1ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Enc0CmpPosMatchToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Enc1CmpPosMatchToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Aoi0Out0ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Aoi0Out1ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Aoi0Out2ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Aoi0Out3ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Aoi1Out0ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Aoi1Out1ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Aoi1Out2ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Aoi1Out3ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_ExtTrigIn0ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_ExtTrigIn1ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_ExtTrigIn2ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_ExtTrigIn3ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_ExtTrigIn4ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_ExtTrigIn5ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_ExtTrigIn6ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_ExtTrigIn7ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_ExtTrigIn8ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_ExtTrigIn9ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Dma0Trigout0ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Dma0Trigout1ToPwm1ExtForceTrigger
-
enumerator kINPUTMUX_Dma0Trigout2ToPwm1ExtForceTrigger
PWM1 fault input trigger connections trigger.
-
enumerator kINPUTMUX_PinInt0ToPwm1FaultTrigger
-
enumerator kINPUTMUX_PinInt2ToPwm1FaultTrigger
-
enumerator kINPUTMUX_SctOut4ToPwm1FaultTrigger
-
enumerator kINPUTMUX_SctOut5ToPwm1FaultTrigger
-
enumerator kINPUTMUX_SctOut3ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Ctimer0M3ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Ctimer1M3ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Ctimer2M3ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Ctimer2M1ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Ctimer4M1ToPwm1FaultTrigger
-
enumerator kINPUTMUX_CompOutToPwm1FaultTrigger
-
enumerator kINPUTMUX_ArmTxevToPwm1FaultTrigger
-
enumerator kINPUTMUX_GpiointBmatchToPwm1FaultTrigger
-
enumerator kINPUTMUX_Adc0Tcomp0ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Adc0Tcomp1ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Adc0Tcomp2ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Adc0Tcomp3ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Adc1Tcomp0ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Adc1Tcomp1ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Adc1Tcomp2ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Adc1Tcomp3ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Hscmp0OutToPwm1FaultTrigger
-
enumerator kINPUTMUX_Hscmp1OutToPwm1FaultTrigger
-
enumerator kINPUTMUX_Hscmp2OutToPwm1FaultTrigger
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig0ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig1ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig0ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig1ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig0ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig1ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig0ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig1ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Enc0CmpPosMatchToPwm1FaultTrigger
-
enumerator kINPUTMUX_Enc1CmpPosMatchToPwm1FaultTrigger
-
enumerator kINPUTMUX_Aoi0Out0ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Aoi0Out1ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Aoi0Out2ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Aoi0Out3ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Aoi1Out0ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Aoi1Out1ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Aoi1Out2ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Aoi1Out3ToPwm1FaultTrigger
-
enumerator kINPUTMUX_ExtTrigIn0ToPwm1FaultTrigger
-
enumerator kINPUTMUX_ExtTrigIn1ToPwm1FaultTrigger
-
enumerator kINPUTMUX_ExtTrigIn2ToPwm1FaultTrigger
-
enumerator kINPUTMUX_ExtTrigIn3ToPwm1FaultTrigger
-
enumerator kINPUTMUX_ExtTrigIn4ToPwm1FaultTrigger
-
enumerator kINPUTMUX_ExtTrigIn5ToPwm1FaultTrigger
-
enumerator kINPUTMUX_ExtTrigIn6ToPwm1FaultTrigger
-
enumerator kINPUTMUX_ExtTrigIn7ToPwm1FaultTrigger
-
enumerator kINPUTMUX_ExtTrigIn8ToPwm1FaultTrigger
-
enumerator kINPUTMUX_ExtTrigIn9ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Dma0Trigout0ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Dma0Trigout1ToPwm1FaultTrigger
-
enumerator kINPUTMUX_Dma0Trigout2ToPwm1FaultTrigger
PWM1 extclk input trigger connections trigger.
-
enumerator kINPUTMUX_PinInt0ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_PinInt2ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_SctOut4ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_SctOut5ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_SctOut3ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Ctimer0M3ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Ctimer1M3ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Ctimer2M3ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Ctimer2M1ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Ctimer4M1ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_CompOutToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_ArmTxevToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_GpiointBmatchToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Adc0Tcomp0ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Adc0Tcomp1ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Adc0Tcomp2ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Adc0Tcomp3ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Adc1Tcomp0ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Adc1Tcomp1ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Adc1Tcomp2ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Adc1Tcomp3ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Hscmp0OutToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Hscmp1OutToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Hscmp2OutToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig0ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig1ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig0ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig1ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig0ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig1ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig0ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig1ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Enc0CmpPosMatchToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Enc1CmpPosMatchToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Aoi0Out0ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Aoi0Out1ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Aoi0Out2ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Aoi0Out3ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Aoi1Out0ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Aoi1Out1ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Aoi1Out2ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Aoi1Out3ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_ExtTrigIn0ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_ExtTrigIn1ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_ExtTrigIn2ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_ExtTrigIn3ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_ExtTrigIn4ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_ExtTrigIn5ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_ExtTrigIn6ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_ExtTrigIn7ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_ExtTrigIn8ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_ExtTrigIn9ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Dma0Trigout0ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Dma0Trigout1ToPwm1ExtClkTrigger
-
enumerator kINPUTMUX_Dma0Trigout2ToPwm1ExtClkTrigger
AOI0 trigger.
-
enumerator kINPUTMUX_PinInt0ToAoi0InTrigger
-
enumerator kINPUTMUX_PinInt1ToAoi0InTrigger
-
enumerator kINPUTMUX_SctOut0ToAoi0InTrigger
-
enumerator kINPUTMUX_SctOut1ToAoi0InTrigger
-
enumerator kINPUTMUX_SctOut2ToAoi0InTrigger
-
enumerator kINPUTMUX_SctOut3ToAoi0InTrigger
-
enumerator kINPUTMUX_Ctimer0M3ToAoi0InTrigger
-
enumerator kINPUTMUX_Ctimer1M3ToAoi0InTrigger
-
enumerator kINPUTMUX_Ctimer2M3ToAoi0InTrigger
-
enumerator kINPUTMUX_Ctimer2M2ToAoi0InTrigger
-
enumerator kINPUTMUX_Ctimer3M2ToAoi0InTrigger
-
enumerator kINPUTMUX_Ctimer4M2ToAoi0InTrigger
-
enumerator kINPUTMUX_CompOutToAoi0InTrigger
-
enumerator kINPUTMUX_GpiointBmatchToAoi0InTrigger
-
enumerator kINPUTMUX_Adc0IrqToAoi0InTrigger
-
enumerator kINPUTMUX_Adc1IrqToAoi0InTrigger
-
enumerator kINPUTMUX_Adc0Tcomp0ToAoi0InTrigger
-
enumerator kINPUTMUX_Adc0Tcomp1ToAoi0InTrigger
-
enumerator kINPUTMUX_Adc0Tcomp2ToAoi0InTrigger
-
enumerator kINPUTMUX_Adc0Tcomp3ToAoi0InTrigger
-
enumerator kINPUTMUX_Adc1Tcomp0ToAoi0InTrigger
-
enumerator kINPUTMUX_Adc1Tcomp1ToAoi0InTrigger
-
enumerator kINPUTMUX_Adc1Tcomp2ToAoi0InTrigger
-
enumerator kINPUTMUX_Adc1Tcomp3ToAoi0InTrigger
-
enumerator kINPUTMUX_Hscmp0OutToAoi0InTrigger
-
enumerator kINPUTMUX_Hscmp1OutToAoi0InTrigger
-
enumerator kINPUTMUX_Hscmp2OutToAoi0InTrigger
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig0ToAoi0InTrigger
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig1ToAoi0InTrigger
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig0ToAoi0InTrigger
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig1ToAoi0InTrigger
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig0ToAoi0InTrigger
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig1ToAoi0InTrigger
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig0ToAoi0InTrigger
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig1ToAoi0InTrigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig0ToAoi0InTrigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig1ToAoi0InTrigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig0ToAoi0InTrigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig1ToAoi0InTrigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig0ToAoi0InTrigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig1ToAoi0InTrigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig0ToAoi0InTrigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig1ToAoi0InTrigger
-
enumerator kINPUTMUX_Enc0CmpPosMatchToAoi0InTrigger
-
enumerator kINPUTMUX_Enc1CmpPosMatchToAoi0InTrigger
-
enumerator kINPUTMUX_ExtTrigIn0ToAoi0InTrigger
-
enumerator kINPUTMUX_ExtTrigIn1ToAoi0InTrigger
-
enumerator kINPUTMUX_ExtTrigIn2ToAoi0InTrigger
-
enumerator kINPUTMUX_ExtTrigIn3ToAoi0InTrigger
-
enumerator kINPUTMUX_Dma0Trigout0ToAoi0InTrigger
-
enumerator kINPUTMUX_Dma0Trigout1ToAoi0InTrigger
-
enumerator kINPUTMUX_Dma0Trigout2ToAoi0InTrigger
-
enumerator kINPUTMUX_Dma0Trigout3ToAoi0InTrigger
-
enumerator kINPUTMUX_Dma0Trigout4ToAoi0InTrigger
-
enumerator kINPUTMUX_Dma0Trigout5ToAoi0InTrigger
-
enumerator kINPUTMUX_Dma0Trigout6ToAoi0InTrigger
-
enumerator kINPUTMUX_Dma1Trigout0ToAoi0InTrigger
-
enumerator kINPUTMUX_Dma1Trigout1ToAoi0InTrigger
-
enumerator kINPUTMUX_Dma1Trigout2ToAoi0InTrigger
AOI1 trigger.
-
enumerator kINPUTMUX_PinInt0ToAoi1InTrigger
-
enumerator kINPUTMUX_PinInt1ToAoi1InTrigger
-
enumerator kINPUTMUX_SctOut0ToAoi1InTrigger
-
enumerator kINPUTMUX_SctOut1ToAoi1InTrigger
-
enumerator kINPUTMUX_SctOut2ToAoi1InTrigger
-
enumerator kINPUTMUX_SctOut3ToAoi1InTrigger
-
enumerator kINPUTMUX_Ctimer0M3ToAoi1InTrigger
-
enumerator kINPUTMUX_Ctimer1M3ToAoi1InTrigger
-
enumerator kINPUTMUX_Ctimer2M3ToAoi1InTrigger
-
enumerator kINPUTMUX_Ctimer2M2ToAoi1InTrigger
-
enumerator kINPUTMUX_Ctimer3M2ToAoi1InTrigger
-
enumerator kINPUTMUX_Ctimer4M2ToAoi1InTrigger
-
enumerator kINPUTMUX_CompOutToAoi1InTrigger
-
enumerator kINPUTMUX_GpiointBmatchToAoi1InTrigger
-
enumerator kINPUTMUX_Adc0IrqToAoi1InTrigger
-
enumerator kINPUTMUX_Adc1IrqToAoi1InTrigger
-
enumerator kINPUTMUX_Adc0Tcomp0ToAoi1InTrigger
-
enumerator kINPUTMUX_Adc0Tcomp1ToAoi1InTrigger
-
enumerator kINPUTMUX_Adc0Tcomp2ToAoi1InTrigger
-
enumerator kINPUTMUX_Adc0Tcomp3ToAoi1InTrigger
-
enumerator kINPUTMUX_Adc1Tcomp0ToAoi1InTrigger
-
enumerator kINPUTMUX_Adc1Tcomp1ToAoi1InTrigger
-
enumerator kINPUTMUX_Adc1Tcomp2ToAoi1InTrigger
-
enumerator kINPUTMUX_Adc1Tcomp3ToAoi1InTrigger
-
enumerator kINPUTMUX_Hscmp0OutToAoi1InTrigger
-
enumerator kINPUTMUX_Hscmp1OutToAoi1InTrigger
-
enumerator kINPUTMUX_Hscmp2OutToAoi1InTrigger
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig0ToAoi1InTrigger
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig1ToAoi1InTrigger
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig0ToAoi1InTrigger
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig1ToAoi1InTrigger
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig0ToAoi1InTrigger
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig1ToAoi1InTrigger
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig0ToAoi1InTrigger
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig1ToAoi1InTrigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig0ToAoi1InTrigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig1ToAoi1InTrigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig0ToAoi1InTrigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig1ToAoi1InTrigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig0ToAoi1InTrigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig1ToAoi1InTrigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig0ToAoi1InTrigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig1ToAoi1InTrigger
-
enumerator kINPUTMUX_Enc0CmpPosMatchToAoi1InTrigger
-
enumerator kINPUTMUX_Enc1CmpPosMatchToAoi1InTrigger
-
enumerator kINPUTMUX_ExtTrigIn0ToAoi1InTrigger
-
enumerator kINPUTMUX_ExtTrigIn1ToAoi1InTrigger
-
enumerator kINPUTMUX_ExtTrigIn2ToAoi1InTrigger
-
enumerator kINPUTMUX_ExtTrigIn3ToAoi1InTrigger
-
enumerator kINPUTMUX_Dma0Trigout0ToAoi1InTrigger
-
enumerator kINPUTMUX_Dma0Trigout1ToAoi1InTrigger
-
enumerator kINPUTMUX_Dma0Trigout2ToAoi1InTrigger
-
enumerator kINPUTMUX_Dma0Trigout3ToAoi1InTrigger
-
enumerator kINPUTMUX_Dma0Trigout4ToAoi1InTrigger
-
enumerator kINPUTMUX_Dma0Trigout5ToAoi1InTrigger
-
enumerator kINPUTMUX_Dma0Trigout6ToAoi1InTrigger
-
enumerator kINPUTMUX_Dma1Trigout0ToAoi1InTrigger
-
enumerator kINPUTMUX_Dma1Trigout1ToAoi1InTrigger
-
enumerator kINPUTMUX_Dma1Trigout2ToAoi1InTrigger
AOI External trigger.
-
enumerator kINPUTMUX_PinInt0ToAoiExtTrigger
-
enumerator kINPUTMUX_PinInt1ToAoiExtTrigger
-
enumerator kINPUTMUX_Adc0IrqToAoiExtTrigger
-
enumerator kINPUTMUX_Adc1IrqToAoiExtTrigger
-
enumerator kINPUTMUX_Adc0Tcomp0ToAoiExtTrigger
-
enumerator kINPUTMUX_Adc1Tcomp0ToAoiExtTrigger
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig01ToAoiExtTrigger
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig01ToAoiExtTrigger
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig01ToAoiExtTrigger
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig01ToAoiExtTrigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig01ToAoiExtTrigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig01ToAoiExtTrigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig01ToAoiExtTrigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig01ToAoiExtTrigger
-
enumerator kINPUTMUX_Enc0CmpPosMatchToAoiExtTrigger
-
enumerator kINPUTMUX_Enc1CmpPosMatchToAoiExtTrigger
-
enumerator kINPUTMUX_Aoi0Out0ToAoiExtTrigger
-
enumerator kINPUTMUX_Aoi0Out1ToAoiExtTrigger
-
enumerator kINPUTMUX_Aoi0Out2ToAoiExtTrigger
-
enumerator kINPUTMUX_Aoi0Out3ToAoiExtTrigger
-
enumerator kINPUTMUX_Aoi1Out0ToAoiExtTrigger
-
enumerator kINPUTMUX_Aoi1Out1ToAoiExtTrigger
-
enumerator kINPUTMUX_Aoi1Out2ToAoiExtTrigger
-
enumerator kINPUTMUX_Aoi1Out3ToAoiExtTrigger
-
enumerator kINPUTMUX_TmprOutToAoiExtTrigger
HSCMP1 trigger.
-
enumerator kINPUTMUX_PinInt0ToHscmp1Trigger
-
enumerator kINPUTMUX_PinInt7ToHscmp1Trigger
-
enumerator kINPUTMUX_SctOut4ToHscmp1Trigger
-
enumerator kINPUTMUX_SctOut5ToHscmp1Trigger
-
enumerator kINPUTMUX_SctOut7ToHscmp1Trigger
-
enumerator kINPUTMUX_Ctimer0M3ToHscmp1Trigger
-
enumerator kINPUTMUX_Ctimer1M3ToHscmp1Trigger
-
enumerator kINPUTMUX_Ctimer2M3ToHscmp1Trigger
-
enumerator kINPUTMUX_Ctimer0M1ToHscmp1Trigger
-
enumerator kINPUTMUX_Ctimer4M1ToHscmp1Trigger
-
enumerator kINPUTMUX_ArmTxevToHscmp1Trigger
-
enumerator kINPUTMUX_GpiointBmatchToHscmp1Trigger
-
enumerator kINPUTMUX_Adc0Tcomp1ToHscmp1Trigger
-
enumerator kINPUTMUX_Adc1Tcomp1ToHscmp1Trigger
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig01ToHscmp1Trigger
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig01ToHscmp1Trigger
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig01ToHscmp1Trigger
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig01ToHscmp1Trigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig01ToHscmp1Trigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig01ToHscmp1Trigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig01ToHscmp1Trigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig01ToHscmp1Trigger
-
enumerator kINPUTMUX_Enc0CmpPosMatchToHscmp1Trigger
-
enumerator kINPUTMUX_Enc1CmpPosMatchToHscmp1Trigger
-
enumerator kINPUTMUX_Aoi0Out0ToHscmp1Trigger
-
enumerator kINPUTMUX_Aoi0Out1ToHscmp1Trigger
-
enumerator kINPUTMUX_Aoi0Out2ToHscmp1Trigger
-
enumerator kINPUTMUX_Aoi0Out3ToHscmp1Trigger
-
enumerator kINPUTMUX_Aoi1Out0ToHscmp1Trigger
-
enumerator kINPUTMUX_Aoi1Out1ToHscmp1Trigger
-
enumerator kINPUTMUX_Aoi1Out2ToHscmp1Trigger
-
enumerator kINPUTMUX_Aoi1Out3ToHscmp1Trigger
-
enumerator kINPUTMUX_Dma0Trigout0ToHscmp1Trigger
-
enumerator kINPUTMUX_Dma0Trigout1ToHscmp1Trigger
-
enumerator kINPUTMUX_Dma0Trigout2ToHscmp1Trigger
HSCMP2 trigger.
-
enumerator kINPUTMUX_PinInt0ToHscmp2Trigger
-
enumerator kINPUTMUX_PinInt4ToHscmp2Trigger
-
enumerator kINPUTMUX_SctOut4ToHscmp2Trigger
-
enumerator kINPUTMUX_SctOut5ToHscmp2Trigger
-
enumerator kINPUTMUX_SctOut8ToHscmp2Trigger
-
enumerator kINPUTMUX_Ctimer0M3ToHscmp2Trigger
-
enumerator kINPUTMUX_Ctimer1M3ToHscmp2Trigger
-
enumerator kINPUTMUX_Ctimer2M3ToHscmp2Trigger
-
enumerator kINPUTMUX_Ctimer0M2ToHscmp2Trigger
-
enumerator kINPUTMUX_Ctimer4M2ToHscmp2Trigger
-
enumerator kINPUTMUX_ArmTxevToHscmp2Trigger
-
enumerator kINPUTMUX_GpiointBmatchToHscmp2Trigger
-
enumerator kINPUTMUX_Adc0Tcomp2ToHscmp2Trigger
-
enumerator kINPUTMUX_Adc1Tcomp2ToHscmp2Trigger
-
enumerator kINPUTMUX_Pwm0Sm0MuxTrig01ToHscmp2Trigger
-
enumerator kINPUTMUX_Pwm0Sm1MuxTrig01ToHscmp2Trigger
-
enumerator kINPUTMUX_Pwm0Sm2MuxTrig01ToHscmp2Trigger
-
enumerator kINPUTMUX_Pwm0Sm3MuxTrig01ToHscmp2Trigger
-
enumerator kINPUTMUX_Pwm1Sm0MuxTrig01ToHscmp2Trigger
-
enumerator kINPUTMUX_Pwm1Sm1MuxTrig01ToHscmp2Trigger
-
enumerator kINPUTMUX_Pwm1Sm2MuxTrig01ToHscmp2Trigger
-
enumerator kINPUTMUX_Pwm1Sm3MuxTrig01ToHscmp2Trigger
-
enumerator kINPUTMUX_Enc0CmpPosMatchToHscmp2Trigger
-
enumerator kINPUTMUX_Enc1CmpPosMatchToHscmp2Trigger
-
enumerator kINPUTMUX_Aoi0Out0ToHscmp2Trigger
-
enumerator kINPUTMUX_Aoi0Out1ToHscmp2Trigger
-
enumerator kINPUTMUX_Aoi0Out2ToHscmp2Trigger
-
enumerator kINPUTMUX_Aoi0Out3ToHscmp2Trigger
-
enumerator kINPUTMUX_Aoi1Out0ToHscmp2Trigger
-
enumerator kINPUTMUX_Aoi1Out1ToHscmp2Trigger
-
enumerator kINPUTMUX_Aoi1Out2ToHscmp2Trigger
-
enumerator kINPUTMUX_Aoi1Out3ToHscmp2Trigger
-
enumerator kINPUTMUX_Dma0Trigout0ToHscmp2Trigger
-
enumerator kINPUTMUX_Dma0Trigout1ToHscmp2Trigger
-
enumerator kINPUTMUX_Dma0Trigout2ToHscmp2Trigger
-
enumerator kINPUTMUX_SctGpioInAToSct0
-
enum _inputmux_signal_t
INPUTMUX signal enable/disable type.
Values:
-
enumerator kINPUTMUX_FlexSpiRxToDmac0Ch0RequestEna
DMA0 REQ(DMA0_REQEN0) signal.
-
enumerator kINPUTMUX_FlexSpiTxToDmac0Ch1RequestEna
-
enumerator kINPUTMUX_PinInt0ToDmac0Ch2RequestEna
-
enumerator kINPUTMUX_PinInt1ToDmac0Ch3RequestEna
-
enumerator kINPUTMUX_PinInt2ToDmac0Ch4RequestEna
-
enumerator kINPUTMUX_PinInt3ToDmac0Ch5RequestEna
-
enumerator kINPUTMUX_Ctimer0M0ToDmac0Ch6RequestEna
-
enumerator kINPUTMUX_Ctimer0M1ToDmac0Ch7RequestEna
-
enumerator kINPUTMUX_Ctimer1M0ToDmac0Ch8RequestEna
-
enumerator kINPUTMUX_Ctimer1M1ToDmac0Ch9RequestEna
-
enumerator kINPUTMUX_Ctimer2M0ToDmac0Ch10RequestEna
-
enumerator kINPUTMUX_Ctimer2M1ToDmac0Ch11RequestEna
-
enumerator kINPUTMUX_Ctimer3M0ToDmac0Ch12RequestEna
-
enumerator kINPUTMUX_Ctimer3M1ToDmac0Ch13RequestEna
-
enumerator kINPUTMUX_Ctimer4M0ToDmac0Ch14RequestEna
-
enumerator kINPUTMUX_Ctimer4M1ToDmac0Ch15RequestEna
-
enumerator kINPUTMUX_CompOutToDmac0Ch16RequestEna
-
enumerator kINPUTMUX_OtrigAToDmac0Ch17RequestEna
-
enumerator kINPUTMUX_OtrigBToDmac0Ch18RequestEna
-
enumerator kINPUTMUX_OtrigCToDmac0Ch19RequestEna
-
enumerator kINPUTMUX_OtrigDToDmac0Ch20RequestEna
-
enumerator kINPUTMUX_SctDma0ToDmac0Ch21RequestEna
-
enumerator kINPUTMUX_SctDma1ToDmac0Ch22RequestEna
-
enumerator kINPUTMUX_Adc0Tcomp0ToDmac23Ch0RequestEna
-
enumerator kINPUTMUX_Adc1Tcomp0ToDmac24Ch0RequestEna
-
enumerator kINPUTMUX_Hscmp0ToDmac0Ch25RequestEna
-
enumerator kINPUTMUX_Hscmp1ToDmac0Ch26RequestEna
-
enumerator kINPUTMUX_Hscmp2ToDmac0Ch27RequestEna
-
enumerator kINPUTMUX_Aoi0Out0ToDmac0Ch28RequestEna
-
enumerator kINPUTMUX_Aoi0Out1ToDmac0Ch29RequestEna
-
enumerator kINPUTMUX_Aoi0Out2ToDmac0Ch30RequestEna
-
enumerator kINPUTMUX_Aoi0Out3ToDmac0Ch31RequestEna
DMA0 REQ(DMA0_REQEN0) signal.
-
enumerator kINPUTMUX_Aoi1Out0ToDmac0Ch32RequestEna
-
enumerator kINPUTMUX_Aoi1Out1ToDmac0Ch33RequestEna
-
enumerator kINPUTMUX_Aoi1Out2ToDmac0Ch34RequestEna
-
enumerator kINPUTMUX_Aoi1Out3ToDmac0Ch35RequestEna
-
enumerator kINPUTMUX_FlexPwm0ReqCapt0ToDmac0Ch36RequestEna
-
enumerator kINPUTMUX_FlexPwm0ReqCapt1ToDmac0Ch37RequestEna
-
enumerator kINPUTMUX_FlexPwm0ReqCapt2ToDmac0Ch38RequestEna
-
enumerator kINPUTMUX_FlexPwm0ReqCapt3ToDmac0Ch39RequestEna
-
enumerator kINPUTMUX_FlexPwm0ReqVal0ToDmac0Ch40RequestEna
-
enumerator kINPUTMUX_FlexPwm0ReqVal1ToDmac0Ch41RequestEna
-
enumerator kINPUTMUX_FlexPwm0ReqVal2ToDmac0Ch42RequestEna
-
enumerator kINPUTMUX_FlexPwm0ReqVal3ToDmac0Ch43RequestEna
-
enumerator kINPUTMUX_FlexPwm1ReqCapt0ToDmac0Ch44RequestEna
-
enumerator kINPUTMUX_FlexPwm1ReqCapt1ToDmac0Ch45RequestEna
-
enumerator kINPUTMUX_FlexPwm1ReqCapt2ToDmac0Ch46RequestEna
-
enumerator kINPUTMUX_FlexPwm1ReqCapt3ToDmac0Ch47RequestEna
-
enumerator kINPUTMUX_FlexPwm1ReqVal0ToDmac0Ch48RequestEna
-
enumerator kINPUTMUX_FlexPwm1ReqVal1ToDmac0Ch49RequestEna
-
enumerator kINPUTMUX_FlexPwm1ReqVal2ToDmac0Ch50RequestEna
-
enumerator kINPUTMUX_FlexPwm1ReqVal3ToDmac0Ch51RequestEna
-
enumerator kINPUTMUX_TmprOutToDmac0Ch52RequestEna
DMA1 REQ(DMA1_REQEN) signal.
-
enumerator kINPUTMUX_HsLspiRxToDmac1Ch2RequestEna
-
enumerator kINPUTMUX_HsLspiTxToDmac1Ch3RequestEna
-
enumerator kINPUTMUX_Flexcom0RxToDmac1Ch4RequestEna
-
enumerator kINPUTMUX_Flexcom0TxToDmac1Ch5RequestEna
-
enumerator kINPUTMUX_Flexcom1RxToDmac1Ch6RequestEna
-
enumerator kINPUTMUX_Flexcom1TxToDmac1Ch7RequestEna
-
enumerator kINPUTMUX_Flexcom3RxToDmac1Ch8RequestEna
-
enumerator kINPUTMUX_Flexcom3TxToDmac1Ch9RequestEna
-
enumerator kINPUTMUX_Dmic0Ch0ToDmac1Ch10RequestEna
-
enumerator kINPUTMUX_Dmic0Ch1ToDmac1Ch11RequestEna
-
enumerator kINPUTMUX_I3c0RxToDmac1Ch12RequestEna
-
enumerator kINPUTMUX_I3c0TxToDmac1Ch13RequestEna
DMA0 input trigger(DMA0_ITRIGEN0) source enable.
-
enumerator kINPUTMUX_Dmac0InputTriggerFlexSpiRxEna
-
enumerator kINPUTMUX_Dmac0InputTriggerFlexSpiTxEna
-
enumerator kINPUTMUX_Dmac0InputTriggerPinInt0Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerPinInt1Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerPinInt2Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerPinInt3Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerCtimer0M0Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerCtimer0M1Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerCtimer1M0Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerCtimer1M1Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerCtimer2M0Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerCtimer2M1Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerCtimer3M0Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerCtimer3M1Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerCtimer4M0Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerCtimer4M1Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerCompOutEna
-
enumerator kINPUTMUX_Dmac0InputTriggerOtrigAEna
-
enumerator kINPUTMUX_Dmac0InputTriggerOtrigBEna
-
enumerator kINPUTMUX_Dmac0InputTriggerOtrigCEna
-
enumerator kINPUTMUX_Dmac0InputTriggerOtrigDEna
-
enumerator kINPUTMUX_Dmac0InputTriggerSctDma0Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerSctDma1Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerAdc0Tcomp0Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerAdc1Tcomp0Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerHscmp0Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerHscmp1Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerHscmp2Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerAoi0Out0Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerAoi0Out1Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerAoi0Out2Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerAoi0Out3Ena
DMA0 input trigger(DMA0_ITRIGEN1) source enable.
-
enumerator kINPUTMUX_Dmac0InputTriggerAoi1Out0Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerAoi1Out1Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerAoi1Out2Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerAoi1Out3Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerFlexPwm0ReqCapt0Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerFlexPwm0ReqCapt1Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerFlexPwm0ReqCapt2Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerFlexPwm0ReqCapt3Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerFlexPwm0ReqVal0Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerFlexPwm0ReqVal1Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerFlexPwm0ReqVal2Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerFlexPwm0ReqVal3Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerFlexPwm1ReqCapt0Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerFlexPwm1ReqCapt1Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerFlexPwm1ReqCapt2Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerFlexPwm1ReqCapt3Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerFlexPwm1ReqVal0Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerFlexPwm1ReqVal1Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerFlexPwm1ReqVal2Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerFlexPwm1ReqVal3Ena
-
enumerator kINPUTMUX_Dmac0InputTriggerTmprOutEna
DMA1 input trigger(DMA1_ITRIGEN) source enable.
-
enumerator kINPUTMUX_Dmac1InputTriggerHsLspiRxEna
-
enumerator kINPUTMUX_Dmac1InputTriggerHsLspiTxEna
-
enumerator kINPUTMUX_Dmac1InputTriggerFlexcom0RxEna
-
enumerator kINPUTMUX_Dmac1InputTriggerFlexcom0TxEna
-
enumerator kINPUTMUX_Dmac1InputTriggerFlexcom1RxEna
-
enumerator kINPUTMUX_Dmac1InputTriggerFlexcom1TxEna
-
enumerator kINPUTMUX_Dmac1InputTriggerFlexcom3RxEna
-
enumerator kINPUTMUX_Dmac1InputTriggerFlexcom3TxEna
-
enumerator kINPUTMUX_Dmac1InputTriggerDmic0Ch0Ena
-
enumerator kINPUTMUX_Dmac1InputTriggerDmic0Ch1Ena
-
enumerator kINPUTMUX_Dmac1InputTriggerI3c0RxEna
-
enumerator kINPUTMUX_Dmac1InputTriggerI3c0TxEna
-
enumerator kINPUTMUX_FlexSpiRxToDmac0Ch0RequestEna
-
typedef enum _inputmux_connection_t inputmux_connection_t
INPUTMUX connections type.
-
typedef enum _inputmux_signal_t inputmux_signal_t
INPUTMUX signal enable/disable type.
-
SCT0_INMUX0
Periphinmux IDs.
-
TIMER0CAPTSEL0
-
TIMER0TRIGIN
-
TIMER1CAPTSEL0
-
TIMER1TRIGIN
-
TIMER2CAPTSEL0
-
TIMER2TRIGIN
-
PINTSEL_PMUX_ID
-
PINTSEL0
-
DMA0_ITRIG_INMUX0
-
DMA0_OTRIG_INMUX0
-
FREQMEAS_REF_REG
-
FREQMEAS_TARGET_REG
-
TIMER3CAPTSEL0
-
TIMER3TRIGIN
-
TIMER4CAPTSEL0
-
TIMER4TRIGIN
-
PINTSECSEL0
-
DMA1_ITRIG_INMUX0
-
DMA1_OTRIG_INMUX0
-
HSCMP0_TRIGIN
-
ADC0_TRIG0
-
ADC1_TRIG0
-
DAC0_TRIGIN
-
DAC1_TRIGIN
-
DAC2_TRIGIN
-
ENC0TRIG
-
ENC0HOME
-
ENC0INDEX
-
ENC0PHASEB
-
ENC0PHASEA
-
ENC1TRIG
-
ENC1HOME
-
ENC1INDEX
-
ENC1PHASEB
-
ENC1PHASEA
-
PWM0_EXTSYNC0
-
PWM0_EXTA0
-
PWM0_EXTFORCETRIG
-
PWM0_FAULT0
-
PWM1_EXTSYNC0
-
PWM1_EXTA0
-
PWM1_EXTFORCETRIG
-
PWM1_FAULT0
-
PWM0_EXTCLKTRIG
-
PWM1_EXTCLKTRIG
-
AOI0_IN0
-
AOI1_IN0
-
AOI_EXT_TRIG0
-
HSCMP1_TRIGIN
-
HSCMP2_TRIGIN
-
DMA0_ITRIG_INMUX_32
-
DMA0_REQ_EN0_ID
-
DMA0_REQ_EN1_ID
-
DMA1_REQ_EN_ID
-
DMA0_ITRIG_EN0_ID
-
DMA0_ITRIG_EN1_ID
-
DMA1_ITRIG_EN_ID
-
ENA_SHIFT
-
PMUX_SHIFT
-
FSL_INPUTMUX_DRIVER_VERSION
Group interrupt driver version for SDK.
-
void INPUTMUX_Init(INPUTMUX_Type *base)
Initialize INPUTMUX peripheral.
This function enables the INPUTMUX clock.
- Parameters:
base – Base address of the INPUTMUX peripheral.
- Return values:
None. –
-
void INPUTMUX_AttachSignal(INPUTMUX_Type *base, uint16_t index, inputmux_connection_t connection)
Attaches a signal.
This function attaches multiplexed signals from INPUTMUX to target signals. For example, to attach GPIO PORT0 Pin 5 to PINT peripheral, do the following:
In this example, INTMUX has 8 registers for PINT, PINT_SEL0~PINT_SEL7. With parameterINPUTMUX_AttachSignal(INPUTMUX, 2, kINPUTMUX_GpioPort0Pin5ToPintsel);
index
specified as 2, this function configures register PINT_SEL2.- Parameters:
base – Base address of the INPUTMUX peripheral.
index – The serial number of destination register in the group of INPUTMUX registers with same name.
connection – Applies signal from source signals collection to target signal.
- Return values:
None. –
-
void INPUTMUX_EnableSignal(INPUTMUX_Type *base, inputmux_signal_t signal, bool enable)
Enable/disable a signal.
This function gates the INPUTPMUX clock.
- Parameters:
base – Base address of the INPUTMUX peripheral.
signal – Enable signal register id and bit offset.
enable – Selects enable or disable.
- Return values:
None. –
-
void INPUTMUX_Deinit(INPUTMUX_Type *base)
Deinitialize INPUTMUX peripheral.
This function disables the INPUTMUX clock.
- Parameters:
base – Base address of the INPUTMUX peripheral.
- Return values:
None. –
Inline Prince Encryption Decryption
-
FSL_IPED_DRIVER_VERSION
IPED driver version. Version 2.2.0.
Current version: 2.2.0
Change log:
Version 2.2.0
Renamed CSS to ELS
Version 2.1.1
Fix build error due to renamed symbols
Version 2.1.0
Add IPED_Config() (including CMPA write) and IPED_Reconfig() features.
Version 2.0.0
Initial version
-
enum _iped_status
Values:
-
enumerator kStatus_IPED_RegionIsLocked
-
enumerator kStatus_IPED_RegionIsLocked
-
enum _iped_lock
Values:
-
enumerator kIPED_RegionUnlock
-
enumerator kIPED_RegionLock
-
enumerator kIPED_RegionUnlock
-
enum _iped_cmpa
Values:
-
enumerator kIPED_SkipCMPA
-
enumerator kIPED_WriteCMPA
-
enumerator kIPED_SkipCMPA
-
typedef uint32_t iped_region_t
-
typedef uint32_t iped_prince_rounds_t
-
typedef enum _iped_lock iped_lock_t
-
typedef enum _iped_cmpa iped_cmpa_t
-
typedef struct _flexspi_iped_region_option flexspi_iped_prot_region_option_t
-
typedef struct _flexspi_iped_region_arg flexspi_iped_region_arg_t
-
static inline void IPED_EncryptEnable(FLEXSPI_Type *base)
Enable data encryption.
This function enables IPED on-the-fly data encryption.
- Parameters:
base – IPED peripheral address.
-
static inline void IPED_EncryptDisable(FLEXSPI_Type *base)
Disable data encryption.
This function disables IPED on-the-fly data encryption.
- Parameters:
base – IPED peripheral address.
-
static inline void IPED_SetLock(FLEXSPI_Type *base, iped_region_t region)
Locks access for specified region registers or data mask register.
This function sets lock on specified region.
- Parameters:
base – IPED peripheral address.
region – number to lock
-
status_t IPED_SetRegionAddressRange(FLEXSPI_Type *base, iped_region_t region, uint32_t start_address, uint32_t end_address)
Sets IPED region address range.
This function configures IPED region address range.
- Parameters:
base – IPED peripheral address.
region – Selection of the IPED region to be configured.
start_address – Start address for region.
end_address – End address for region.
-
status_t IPED_GetRegionAddressRange(FLEXSPI_Type *base, iped_region_t region, uint32_t *start_address, uint32_t *end_address)
Gets IPED region base address.
This function reads current start and end address settings for selected region.
- Parameters:
base – IPED peripheral address.
region – Selection of the IPED region to be configured.
start_address – Start address for region.
end_address – End address for region.
-
status_t IPED_SetRegionIV(FLEXSPI_Type *base, iped_region_t region, const uint8_t iv[8])
Sets the IPED region IV.
This function sets specified AES IV for the given region.
- Parameters:
base – IPED peripheral address.
region – Selection of the IPED region to be configured.
iv – 64-bit AES IV in little-endian byte order.
-
static inline void IPED_SetPrinceRounds(FLEXSPI_Type *base, iped_prince_rounds_t rounds)
Sets the IPED region IV.
This function sets specified AES IV for the given region.
- Parameters:
base – IPED peripheral address.
rounds – Number of PRINCE rounds used during encryption/decryption
-
status_t IPED_Configure(api_core_context_t *coreCtx, flexspi_iped_region_arg_t *config, iped_lock_t lock, iped_cmpa_t writeCmpa)
Configures IPED setting.
This function does the initial IPED configuration via ROM IAP API call. IPED_SR_x configuration for each region configuration is stored into FFR (CMPA). IPED IV erase counters (MCTR_INT_IV_CTRx) in CFPA are updated accordingly.
Note: This function is expected to be called once in the device lifetime, typically during the initial device provisioning (especially if programming the CMPA pages in PFR flash is enabled).
- Parameters:
coreCtx – The pointer to the ROM API driver context structure.
config – The pointer to the IPED driver configuration structure.
lock – Locks the IPED configuration, if CMPA write enabled, also sets the IPEDx_START bits[1:0] 01 - Enabled, 10,11 - Enabled & locked
writeCmpa – If selected, IPED configuration will be programmed in PFR flash using ROM API. Note: This can not be reverted!!
- Return values:
kStatus_Success –
kStatus_CommandUnsupported –
kStatus_InvalidArgument –
kStatus_FLASH_ModifyProtectedAreaDisallowed –
kStatusMemoryRangeInvalid –
kStatus_Fail –
kStatus_OutOfRange –
kStatus_SPI_BaudrateNotSupport –
-
status_t IPED_Reconfigure(api_core_context_t *coreCtx, flexspi_iped_region_arg_t *config)
Configures IPED setting.
This function is used to re-configure IPED IP based on configuration stored in FFR. This function also needs to be called after wake up from power-down mode to regenerate IV encryption key in ELS key store whose presence is necessary for correct IPED operation during erase and write operations to encrypted regions of internal flash memory (dependency for correct operation of MEM_Erase() and MEM_Write() after wake up from power-down mode).
- Parameters:
coreCtx – The pointer to the ROM API driver context structure.
config – The pointer to the IPED driver configuration structure. If NULL CMPA cinfiguration is read and used. Note: when providing config structure, you have to call Reconfigure for each IPED region individually starting with Region 0. Region 0 must be enabled as a base region.
- Return values:
kStatus_Success –
kStatus_Fail –
-
kIPED_Region0
IPED region 0
-
kIPED_Region1
IPED region 1
-
kIPED_Region2
IPED region 2
-
kIPED_Region3
IPED region 3
-
kIPED_PrinceRounds12
-
kIPED_PrinceRounds22
-
IPED_TAG
IPED fixed tag in flexspi_iped_region_arg_t structure.
-
IPED_TAG_SHIFT
-
IPED_REGION_COUNT
IPED region count.
-
IPED_RW_ENABLE_VAL
-
IPED_RW_DISABLE_VAL
-
NXP_DIE_EXT_MEM_ENC_SK
Define for ELS key store indexes.
-
NXP_DIE_MEM_IV_ENC_SK
-
CFPA_VER_OFFSET
CFPA version and IV indexes (see Protected Flash Region table)
-
CFPA_IPED_IV_OFFSET
-
CFPA_SCRATCH_VER
CFPA scrach version and IV addresses (see Protected Flash Region table)
-
CFPA_SCRATCH_IV
-
IPED_START_ADDR_LOCK_EN_MASK
CMPA start address, end address, lock and enable bit-field masks (see Protected Flash Region table)
-
IPED_START_ADDR_MASK
-
IPED_END_ADDR_MASK
-
SYSCON_ELS_KDF_MASK
KDF mask and key properties for NXP_DIE_MEM_IV_ENC_SK (see SYSCON documentation)
-
CMPA_IPED_START_OFFSET
CMPA Start address index (see Protected Flash Region table)
-
IPED_ADDRESS_MASK
CMPA Start address mask (see Protected Flash Region table)
-
IPED_ENABLE_MASK
CMPA Start address enable/lock mask bits (see Protected Flash Region table)
-
CMPA_PAGE_SIZE
CMPA page size (see Protected Flash Region table)
-
struct _flexspi_iped_region_option
- #include <fsl_iped.h>
-
struct _flexspi_iped_region_arg
- #include <fsl_iped.h>
-
struct IPED_CMPA_page
- #include <fsl_iped.h>
IPED - CMPA page layout.
Public Members
-
uint8_t RESERVED_0[144]
Reserved 0, offset: 0x00
- __IO uint32_t IPED0_START
IPED0_START, offset: 0x90
- __IO uint32_t IPED0_END
IPED0_END, offset: 0x94
- __IO uint32_t IPED1_START
IPED1_START, offset: 0x98
- __IO uint32_t IPED1_END
IPED1_END, offset: 0x9C
- __IO uint32_t IPED2_START
IPED2_START, offset: 0xA0
- __IO uint32_t IPED2_END
IPED2_END, offset: 0xA4
- __IO uint32_t IPED3_START
IPED3_START, offset: 0xA8
- __IO uint32_t IPED3_END
IPED3_END, offset: 0xAC
-
uint8_t RESERVED_1[336]
Reserved 1, offset: 0xB0
-
uint8_t RESERVED_0[144]
IRTC: IRTC Driver
-
status_t IRTC_Init(RTC_Type *base, const irtc_config_t *config)
Ungates the IRTC clock and configures the peripheral for basic operation.
This function initiates a soft-reset of the IRTC module, this has not effect on DST, calendaring, standby time and tamper detect registers.
Note
This API should be called at the beginning of the application using the IRTC driver.
- Parameters:
base – IRTC peripheral base address
config – Pointer to user’s IRTC config structure.
- Returns:
kStatus_Success If the driver is initialized successfully.
- Returns:
kStatus_Fail if we cannot disable register write protection
- Returns:
kStatus_InvalidArgument If the input parameters are wrong.
-
status_t IRTC_Deinit(RTC_Type *base)
Gate the IRTC clock.
- Parameters:
base – IRTC peripheral base address
- Returns:
kStatus_Success If the driver is initialized successfully.
- Returns:
kStatus_InvalidArgument If the input parameters are wrong.
-
void IRTC_GetDefaultConfig(irtc_config_t *config)
Fill in the IRTC config struct with the default settings.
The default values are:
config->wakeupSelect = true; config->timerStdMask = false; config->alrmMatch = kRTC_MatchSecMinHr;
- Parameters:
config – Pointer to user’s IRTC config structure.
-
status_t IRTC_SetDatetime(RTC_Type *base, const irtc_datetime_t *datetime)
Sets the IRTC date and time according to the given time structure.
The IRTC counter is started after the time is set.
- Parameters:
base – IRTC peripheral base address
datetime – Pointer to structure where the date and time details to set are stored
- Returns:
kStatus_Success: success in setting the time and starting the IRTC kStatus_InvalidArgument: failure. An error occurs because the datetime format is incorrect.
-
void IRTC_GetDatetime(RTC_Type *base, irtc_datetime_t *datetime)
Gets the IRTC time and stores it in the given time structure.
- Parameters:
base – IRTC peripheral base address
datetime – Pointer to structure where the date and time details are stored.
-
status_t IRTC_SetAlarm(RTC_Type *base, const irtc_datetime_t *alarmTime)
Sets the IRTC alarm time.
Note
weekDay field of alarmTime is not used during alarm match and should be set to 0
- Parameters:
base – RTC peripheral base address
alarmTime – Pointer to structure where the alarm time is stored.
- Returns:
kStatus_Success: success in setting the alarm kStatus_InvalidArgument: error in setting the alarm. Error occurs because the alarm datetime format is incorrect.
-
void IRTC_GetAlarm(RTC_Type *base, irtc_datetime_t *datetime)
Returns the IRTC alarm time.
- Parameters:
base – RTC peripheral base address
datetime – Pointer to structure where the alarm date and time details are stored.
-
static inline void IRTC_EnableInterrupts(RTC_Type *base, uint32_t mask)
Enables the selected IRTC interrupts.
- Parameters:
base – IRTC peripheral base address
mask – The interrupts to enable. This is a logical OR of members of the enumeration irtc_interrupt_enable_t
-
static inline void IRTC_DisableInterrupts(RTC_Type *base, uint32_t mask)
Disables the selected IRTC interrupts.
- Parameters:
base – IRTC peripheral base address
mask – The interrupts to enable. This is a logical OR of members of the enumeration irtc_interrupt_enable_t
-
static inline uint32_t IRTC_GetEnabledInterrupts(RTC_Type *base)
Gets the enabled IRTC interrupts.
- Parameters:
base – IRTC peripheral base address
- Returns:
The enabled interrupts. This is the logical OR of members of the enumeration irtc_interrupt_enable_t
-
static inline uint32_t IRTC_GetStatusFlags(RTC_Type *base)
Gets the IRTC status flags.
- Parameters:
base – IRTC peripheral base address
- Returns:
The status flags. This is the logical OR of members of the enumeration irtc_status_flags_t
-
static inline void IRTC_ClearStatusFlags(RTC_Type *base, uint32_t mask)
Clears the IRTC status flags.
- Parameters:
base – IRTC peripheral base address
mask – The status flags to clear. This is a logical OR of members of the enumeration irtc_status_flags_t
-
void IRTC_SetDaylightTime(RTC_Type *base, const irtc_daylight_time_t *datetime)
Sets the IRTC daylight savings start and stop date and time.
It also enables the daylight saving bit in the IRTC control register
- Parameters:
base – IRTC peripheral base address
datetime – Pointer to a structure where the date and time details are stored.
-
void IRTC_GetDaylightTime(RTC_Type *base, irtc_daylight_time_t *datetime)
Gets the IRTC daylight savings time and stores it in the given time structure.
- Parameters:
base – IRTC peripheral base address
datetime – Pointer to a structure where the date and time details are stored.
-
void IRTC_SetCoarseCompensation(RTC_Type *base, uint8_t compensationValue, uint8_t compensationInterval)
Enables the coarse compensation and sets the value in the IRTC compensation register.
- Parameters:
base – IRTC peripheral base address
compensationValue – Compensation value is a 2’s complement value.
compensationInterval – Compensation interval.
-
void IRTC_SetFineCompensation(RTC_Type *base, uint8_t integralValue, uint8_t fractionValue, bool accumulateFractional)
Enables the fine compensation and sets the value in the IRTC compensation register.
- Parameters:
base – The IRTC peripheral base address
integralValue – Compensation integral value; twos complement value of the integer part
fractionValue – Compensation fraction value expressed as number of clock cycles of a fixed 4.194304Mhz clock that have to be added.
accumulateFractional – Flag indicating if we want to add to previous fractional part; true: Add to previously accumulated fractional part, false: Start afresh and overwrite current value
-
static inline void IRTC_EnableSubsecondCounter(RTC_Type *base, bool enable)
Enable the RTC wake-up timer.
1HZ clock out selected via call to API IRTC_ConfigClockOut in order for the subsecond counter to synchronize with the RTC_SECONDS counter.
- Parameters:
base – RTC peripheral base address
enable – Use/Un-use the sub-second counter.
true: Use RTC wake-up timer at the same time.
false: Un-use RTC wake-up timer, RTC only use the normal seconds timer by default.
-
static inline uint32_t IRTC_GetSubsecondCount(RTC_Type *base)
Read the actual RTC sub-second COUNT value.
- Parameters:
base – RTC peripheral base address
- Returns:
The actual RTC sub-second COUNT value.
-
static inline void IRTC_SetWakeupCount(RTC_Type *base, bool enable1kHzClk, uint32_t wakeupValue)
Set countdown value to the RTC wake timer counter register.
- Parameters:
base – RTC peripheral base address
enable1kHzClk – Enable 1kHz clock source for the wake timer, else use the 32kHz clock.
wakeupValue – The value to be loaded into the WAKE register in wake timer counter.
-
static inline uint32_t IRTC_GetWakeupCount(RTC_Type *base)
Read the actual value from the WAKE register value in RTC wake timer.
- Parameters:
base – RTC peripheral base address
- Returns:
The actual value of the WAKE register value in wake timer counter.
-
FSL_IRTC_DRIVER_VERSION
-
enum _irtc_clock_select
IRTC clock select.
Values:
-
enumerator kIRTC_Clk16K
16.384 kHz clock is selected.
-
enumerator kIRTC_Clk32K
32.768 kHz clock is selected.
-
enumerator kIRTC_Clk16K
-
enum _irtc_interrupt_enable
List of IRTC interrupts.
Values:
-
enumerator kIRTC_AlarmInterruptEnable
Alarm Interrupt Enable
-
enumerator kIRTC_DayInterruptEnable
Days Interrupt Enable
-
enumerator kIRTC_HourInterruptEnable
Hours Interrupt Enable
-
enumerator kIRTC_MinInterruptEnable
Minutes Interrupt Enable
-
enumerator kIRTC_1hzInterruptEnable
1 Hz interval Interrupt Enable
-
enumerator kIRTC_2hzInterruptEnable
2 Hz interval Interrupt Enable
-
enumerator kIRTC_4hzInterruptEnable
4 Hz interval Interrupt Enable
-
enumerator kIRTC_8hzInterruptEnable
8 Hz interval Interrupt Enable
-
enumerator kIRTC_16hzInterruptEnable
16 Hz interval Interrupt Enable
-
enumerator kIRTC_32hzInterruptEnable
32 Hz interval Interrupt Enable
-
enumerator kIRTC_64hzInterruptEnable
64 Hz interval Interrupt Enable
-
enumerator kIRTC_128hzInterruptEnable
128 Hz interval Interrupt Enable
-
enumerator kIRTC_256hzInterruptEnable
256 Hz interval Interrupt Enable
-
enumerator kIRTC_512hzInterruptEnable
512 Hz interval Interrupt Enable
-
enumerator kIRTC_WakeTimerInterruptEnable
Wake timer Interrupt Enable
-
enumerator kIRTC_TamperQueueFullInterruptEnable
Tamper queue full Interrupt Enable
-
enumerator kIRTC_AlarmInterruptEnable
-
enum _irtc_status_flags
List of IRTC flags.
Values:
-
enumerator kIRTC_AlarmFlag
Alarm Status flag
-
enumerator kIRTC_DayFlag
Days Status flag
-
enumerator kIRTC_HourFlag
Hour Status flag
-
enumerator kIRTC_MinFlag
Minutes Status flag
-
enumerator kIRTC_1hzFlag
1 Hz interval status flag
-
enumerator kIRTC_2hzFlag
2 Hz interval status flag
-
enumerator kIRTC_4hzFlag
4 Hz interval status flag
-
enumerator kIRTC_8hzFlag
8 Hz interval status flag
-
enumerator kIRTC_16hzFlag
16 Hz interval status flag
-
enumerator kIRTC_32hzFlag
32 Hz interval status flag
-
enumerator kIRTC_64hzFlag
64 Hz interval status flag
-
enumerator kIRTC_128hzFlag
128 Hz interval status flag
-
enumerator kIRTC_256hzFlag
256 Hz interval status flag
-
enumerator kIRTC_512hzFlag
512 Hz interval status flag
-
enumerator kIRTC_InvalidFlag
Indicates if time/date counters are invalid
-
enumerator kIRTC_WriteProtFlag
Write protect enable status flag
-
enumerator kIRTC_CmpIntFlag
Compensation interval status flag
-
enumerator kIRTC_CmpDoneFlag
Compensation done flag
-
enumerator kIRTC_BusErrFlag
Bus error flag
-
enumerator kIRTC_WakeTimerFlag
Wake timer status flag
-
enumerator kIRTC_AlarmFlag
-
enum _irtc_alarm_match
IRTC alarm match options.
Values:
-
enumerator kRTC_MatchSecMinHr
Only match second, minute and hour
-
enumerator kRTC_MatchSecMinHrDay
Only match second, minute, hour and day
-
enumerator kRTC_MatchSecMinHrDayMnth
Only match second, minute, hour, day and month
-
enumerator kRTC_MatchSecMinHrDayMnthYr
Only match second, minute, hour, day, month and year
-
enumerator kRTC_MatchSecMinHr
-
enum _irtc_clockout_sel
IRTC clockout select.
Values:
-
enumerator kIRTC_ClkoutNo
No clock out
-
enumerator kIRTC_ClkoutFine1Hz
clock out fine 1Hz
-
enumerator kIRTC_Clkout32kHz
clock out 32.768kHz
-
enumerator kIRTC_ClkoutCoarse1Hz
clock out coarse 1Hz
-
enumerator kIRTC_ClkoutNo
-
typedef enum _irtc_clock_select irtc_clock_select_t
IRTC clock select.
-
typedef enum _irtc_interrupt_enable irtc_interrupt_enable_t
List of IRTC interrupts.
-
typedef enum _irtc_status_flags irtc_status_flags_t
List of IRTC flags.
-
typedef enum _irtc_alarm_match irtc_alarm_match_t
IRTC alarm match options.
-
typedef enum _irtc_clockout_sel irtc_clockout_sel_t
IRTC clockout select.
-
typedef struct _irtc_datetime irtc_datetime_t
Structure is used to hold the date and time.
-
typedef struct _irtc_daylight_time irtc_daylight_time_t
Structure is used to hold the daylight saving time.
-
typedef struct _irtc_config irtc_config_t
RTC config structure.
This structure holds the configuration settings for the RTC peripheral. To initialize this structure to reasonable defaults, call the IRTC_GetDefaultConfig() function and pass a pointer to your config structure instance.
The config struct can be made const so it resides in flash
-
status_t IRTC_SetWriteProtection(RTC_Type *base, bool lock)
Locks or unlocks IRTC registers for write access.
Note
When the registers are unlocked, they remain in unlocked state for 2 seconds, after which they are locked automatically. After power-on-reset, the registers come out unlocked and they are locked automatically 15 seconds after power on.
- Parameters:
base – IRTC peripheral base address
lock – true: Lock IRTC registers; false: Unlock IRTC registers.
- Returns:
kStatus_Success: if lock or unlock operation is successful kStatus_Fail: if lock or unlock operation fails even after multiple retry attempts
-
static inline void IRTC_Reset(RTC_Type *base)
Performs a software reset on the IRTC module.
Clears contents of alarm, interrupt (status and enable except tamper interrupt enable bit) registers, STATUS[CMP_DONE] and STATUS[BUS_ERR]. This has no effect on DST, calendaring, standby time and tamper detect registers.
- Parameters:
base – IRTC peripheral base address
-
void IRTC_ConfigClockOut(RTC_Type *base, irtc_clockout_sel_t clkOut)
Select which clock to output from RTC.
Select which clock to output from RTC for other modules to use inside SoC, for example, RTC subsystem needs RTC to output 1HZ clock for sub-second counter.
- Parameters:
base – IRTC peripheral base address
clkOut – select clock to use for output,
-
void IRTC_ConfigClockSelect(RTC_Type *base, irtc_clock_select_t clkSelect)
Select which clock is used by RTC.
Select which clock is used by RTC to output to the peripheral and divided to generate a 512 Hz clock and a 1 Hz clock.
- Parameters:
base – IRTC peripheral base address
clkSelect – select clock used by RTC
-
static inline void IRTC_EnableClockOutputToPeripheral(RTC_Type *base, bool enable)
Determines whether the selected clock is output to other peripherals.
Determines whether the selected clock is output to other peripherals.
- Parameters:
base – IRTC peripheral base address
enable – determine whether the selected clock is output to other peripherals
-
IRTC_STATUS_W1C_BITS
-
struct _irtc_datetime
- #include <fsl_irtc.h>
Structure is used to hold the date and time.
Public Members
-
uint16_t year
Range from 1984 to 2239.
-
uint8_t month
Range from 1 to 12.
-
uint8_t day
Range from 1 to 31 (depending on month).
-
uint8_t weekDay
Range from 0(Sunday) to 6(Saturday).
-
uint8_t hour
Range from 0 to 23.
-
uint8_t minute
Range from 0 to 59.
-
uint8_t second
Range from 0 to 59.
-
uint16_t year
-
struct _irtc_daylight_time
- #include <fsl_irtc.h>
Structure is used to hold the daylight saving time.
Public Members
-
uint8_t startMonth
Range from 1 to 12
-
uint8_t endMonth
Range from 1 to 12
-
uint8_t startDay
Range from 1 to 31 (depending on month)
-
uint8_t endDay
Range from 1 to 31 (depending on month)
-
uint8_t startHour
Range from 0 to 23
-
uint8_t endHour
Range from 0 to 23
-
uint8_t startMonth
-
struct _irtc_config
- #include <fsl_irtc.h>
RTC config structure.
This structure holds the configuration settings for the RTC peripheral. To initialize this structure to reasonable defaults, call the IRTC_GetDefaultConfig() function and pass a pointer to your config structure instance.
The config struct can be made const so it resides in flash
Public Members
-
irtc_alarm_match_t alrmMatch
Pick one option from enumeration :: irtc_alarm_match_t
-
irtc_clock_select_t clockSelect
Pick one option from enumeration :: irtc_clock_select_t
-
bool disableClockOutput
true: The selected clock is not output to other peripherals; false: The selected clock is output to other peripherals
-
irtc_alarm_match_t alrmMatch
Intrusion and Tamper Response Controller
ITRC
-
status_t ITRC_SetActionToEvent(ITRC_Type *base, itrc_out_signals_t out, itrc_input_signals_t in, itrc_lock_t lock, itrc_enable_t enable)
Set ITRC Action to Event.
This function sets input Event signal to corresponding output Action response signal.
- Parameters:
base – ITRC peripheral base address
out – ITRC OUT signal action
in – ITRC IN signal event
lock – if set locks INx_SEL configuration. This can be cleared only by PMC Core reset.
enable – if set input Event will be selected for output Action, otherwise disable (if not already locked).
- Returns:
kStatus_Success if success, kStatus_InvalidArgument otherwise
-
void ITRC_SetSWEvent0(ITRC_Type *base)
Trigger ITRC SW Event 0.
This funciton set SW_EVENT0 register with value !=0 which triggers ITRC SW Event 0.
- Parameters:
base – ITRC peripheral base address
-
void ITRC_SetSWEvent1(ITRC_Type *base)
Trigger ITRC SW Event 1.
This funciton set SW_EVENT1 register with value !=0 which triggers ITRC SW Event 1.
- Parameters:
base – ITRC peripheral base address
-
uint32_t ITRC_GetStatus(ITRC_Type *base)
Get ITRC Status.
This function returns ITRC register status.
- Parameters:
base – ITRC peripheral base address
- Returns:
Value of ITRC STATUS register
-
status_t ITRC_ClearStatus(ITRC_Type *base, uint32_t word)
Clear ITRC status.
This function clears corresponding ITRC event or action in STATUS register.
- Parameters:
base – ITRC peripheral base address
word – 32bit word represent corresponding event/action in STATUS register to be cleared (see ITRC_STATUS_INx/OUTx_STATUS)
- Returns:
kStatus_Success if success, kStatus_InvalidArgument otherwise
-
status_t ITRC_ClearAllStatus(ITRC_Type *base)
Clear All ITRC status.
This function clears all event and action status.
- Parameters:
base – ITRC peripheral base address
- Returns:
kStatus_Success if success
-
status_t ITRC_Init(ITRC_Type *base)
Initialize ITRC.
This function initializes ITRC by enabling IRQ.
- Parameters:
base – ITRC peripheral base address
conf – ITRC configuration structure
- Returns:
Status of the init operation
-
void ITRC_Deinit(ITRC_Type *base)
Deinitialize ITRC.
This function deinitializes ITRC by disabling IRQ.
- Parameters:
base – ITRC peripheral base address
-
FSL_ITRC_DRIVER_VERSION
Defines ITRC driver version 2.4.0.
Change log:
Version 2.4.0
Rework the input signal definition for better flexibility
Version 2.3.0
Update names of kITRC_SwEvent1/2 to kITRC_SwEvent0/1 to align with RM
Version 2.2.0
Update driver to new version and input events
Version 2.1.0
Make SYSCON glitch platform dependent
Version 2.0.0
initial version
-
enum _itrc_input_signals
Values:
-
enum _itrc_lock
Values:
-
enumerator kITRC_Unlock
-
enumerator kITRC_Lock
-
enumerator kITRC_Unlock
-
enum _itrc_enable
Values:
-
enumerator kITRC_Enable
-
enumerator kITRC_Disable
-
enumerator kITRC_Enable
-
enum _itrc_out_signals
Values:
-
enumerator kITRC_Irq
-
enumerator kITRC_ElsReset
-
enumerator kITRC_PufZeroize
-
enumerator kITRC_RamZeroize
-
enumerator kITRC_ChipReset
-
enumerator kITRC_TamperOut
-
enumerator kITRC_TamperOut1
-
enumerator kITRC_Irq
-
typedef enum _itrc_input_signals itrc_input_signals_t
-
typedef enum _itrc_lock itrc_lock_t
-
typedef enum _itrc_enable itrc_enable_t
-
typedef enum _itrc_out_signals itrc_out_signals_t
-
void ITRC0_DriverIRQHandler(void)
-
ITRC_STATUS_IN2_STATUS_MASK
-
ITRC_STATUS_IN3_STATUS_MASK
-
ITRC_STATUS_IN9_STATUS_MASK
-
ITRC_STATUS1_IN17_STATUS_MASK
-
ITRC_STATUS1_IN19_STATUS_MASK
-
ITRC_STATUS1_IN24_21_STATUS_MASK
-
ITRC_STATUS1_IN32_25_STATUS_MASK
-
ITRC_STATUS1_IN46_STATUS_MASK
-
IN_0_15_EVENTS_MASK
-
OUT_ACTIONS_MASK
-
ITRC_OUT_COUNT
-
ITRC
Common Driver
-
FSL_COMMON_DRIVER_VERSION
common driver version.
-
DEBUG_CONSOLE_DEVICE_TYPE_NONE
No debug console.
-
DEBUG_CONSOLE_DEVICE_TYPE_UART
Debug console based on UART.
-
DEBUG_CONSOLE_DEVICE_TYPE_LPUART
Debug console based on LPUART.
-
DEBUG_CONSOLE_DEVICE_TYPE_LPSCI
Debug console based on LPSCI.
-
DEBUG_CONSOLE_DEVICE_TYPE_USBCDC
Debug console based on USBCDC.
-
DEBUG_CONSOLE_DEVICE_TYPE_FLEXCOMM
Debug console based on FLEXCOMM.
-
DEBUG_CONSOLE_DEVICE_TYPE_IUART
Debug console based on i.MX UART.
-
DEBUG_CONSOLE_DEVICE_TYPE_VUSART
Debug console based on LPC_VUSART.
-
DEBUG_CONSOLE_DEVICE_TYPE_MINI_USART
Debug console based on LPC_USART.
-
DEBUG_CONSOLE_DEVICE_TYPE_SWO
Debug console based on SWO.
-
DEBUG_CONSOLE_DEVICE_TYPE_QSCI
Debug console based on QSCI.
-
MIN(a, b)
Computes the minimum of a and b.
-
MAX(a, b)
Computes the maximum of a and b.
-
UINT16_MAX
Max value of uint16_t type.
-
UINT32_MAX
Max value of uint32_t type.
-
SDK_ATOMIC_LOCAL_ADD(addr, val)
Add value val from the variable at address address.
-
SDK_ATOMIC_LOCAL_SUB(addr, val)
Subtract value val to the variable at address address.
-
SDK_ATOMIC_LOCAL_SET(addr, bits)
Set the bits specifiled by bits to the variable at address address.
-
SDK_ATOMIC_LOCAL_CLEAR(addr, bits)
Clear the bits specifiled by bits to the variable at address address.
-
SDK_ATOMIC_LOCAL_TOGGLE(addr, bits)
Toggle the bits specifiled by bits to the variable at address address.
-
SDK_ATOMIC_LOCAL_CLEAR_AND_SET(addr, clearBits, setBits)
For the variable at address address, clear the bits specifiled by clearBits and set the bits specifiled by setBits.
-
SDK_ATOMIC_LOCAL_COMPARE_AND_SET(addr, expected, newValue)
For the variable at address address, check whether the value equal to expected. If value same as expected then update newValue to address and return true , else return false .
-
SDK_ATOMIC_LOCAL_TEST_AND_SET(addr, newValue)
For the variable at address address, set as newValue value and return old value.
-
USEC_TO_COUNT(us, clockFreqInHz)
Macro to convert a microsecond period to raw count value
-
COUNT_TO_USEC(count, clockFreqInHz)
Macro to convert a raw count value to microsecond
-
MSEC_TO_COUNT(ms, clockFreqInHz)
Macro to convert a millisecond period to raw count value
-
COUNT_TO_MSEC(count, clockFreqInHz)
Macro to convert a raw count value to millisecond
-
SDK_ISR_EXIT_BARRIER
-
SDK_SIZEALIGN(var, alignbytes)
Macro to define a variable with L1 d-cache line size alignment
Macro to define a variable with L2 cache line size alignment
Macro to change a value to a given size aligned value
-
AT_NONCACHEABLE_SECTION(var)
Define a variable var, and place it in non-cacheable section.
-
AT_NONCACHEABLE_SECTION_ALIGN(var, alignbytes)
Define a variable var, and place it in non-cacheable section, the start address of the variable is aligned to alignbytes.
-
AT_NONCACHEABLE_SECTION_INIT(var)
Define a variable var with initial value, and place it in non-cacheable section.
-
AT_NONCACHEABLE_SECTION_ALIGN_INIT(var, alignbytes)
Define a variable var with initial value, and place it in non-cacheable section, the start address of the variable is aligned to alignbytes.
-
enum _status_groups
Status group numbers.
Values:
-
enumerator kStatusGroup_Generic
Group number for generic status codes.
-
enumerator kStatusGroup_FLASH
Group number for FLASH status codes.
-
enumerator kStatusGroup_LPSPI
Group number for LPSPI status codes.
-
enumerator kStatusGroup_FLEXIO_SPI
Group number for FLEXIO SPI status codes.
-
enumerator kStatusGroup_DSPI
Group number for DSPI status codes.
-
enumerator kStatusGroup_FLEXIO_UART
Group number for FLEXIO UART status codes.
-
enumerator kStatusGroup_FLEXIO_I2C
Group number for FLEXIO I2C status codes.
-
enumerator kStatusGroup_LPI2C
Group number for LPI2C status codes.
-
enumerator kStatusGroup_UART
Group number for UART status codes.
-
enumerator kStatusGroup_I2C
Group number for UART status codes.
-
enumerator kStatusGroup_LPSCI
Group number for LPSCI status codes.
-
enumerator kStatusGroup_LPUART
Group number for LPUART status codes.
-
enumerator kStatusGroup_SPI
Group number for SPI status code.
-
enumerator kStatusGroup_XRDC
Group number for XRDC status code.
-
enumerator kStatusGroup_SEMA42
Group number for SEMA42 status code.
-
enumerator kStatusGroup_SDHC
Group number for SDHC status code
-
enumerator kStatusGroup_SDMMC
Group number for SDMMC status code
-
enumerator kStatusGroup_SAI
Group number for SAI status code
-
enumerator kStatusGroup_MCG
Group number for MCG status codes.
-
enumerator kStatusGroup_SCG
Group number for SCG status codes.
-
enumerator kStatusGroup_SDSPI
Group number for SDSPI status codes.
-
enumerator kStatusGroup_FLEXIO_I2S
Group number for FLEXIO I2S status codes
-
enumerator kStatusGroup_FLEXIO_MCULCD
Group number for FLEXIO LCD status codes
-
enumerator kStatusGroup_FLASHIAP
Group number for FLASHIAP status codes
-
enumerator kStatusGroup_FLEXCOMM_I2C
Group number for FLEXCOMM I2C status codes
-
enumerator kStatusGroup_I2S
Group number for I2S status codes
-
enumerator kStatusGroup_IUART
Group number for IUART status codes
-
enumerator kStatusGroup_CSI
Group number for CSI status codes
-
enumerator kStatusGroup_MIPI_DSI
Group number for MIPI DSI status codes
-
enumerator kStatusGroup_SDRAMC
Group number for SDRAMC status codes.
-
enumerator kStatusGroup_POWER
Group number for POWER status codes.
-
enumerator kStatusGroup_ENET
Group number for ENET status codes.
-
enumerator kStatusGroup_PHY
Group number for PHY status codes.
-
enumerator kStatusGroup_TRGMUX
Group number for TRGMUX status codes.
-
enumerator kStatusGroup_SMARTCARD
Group number for SMARTCARD status codes.
-
enumerator kStatusGroup_LMEM
Group number for LMEM status codes.
-
enumerator kStatusGroup_QSPI
Group number for QSPI status codes.
-
enumerator kStatusGroup_DMA
Group number for DMA status codes.
-
enumerator kStatusGroup_EDMA
Group number for EDMA status codes.
-
enumerator kStatusGroup_DMAMGR
Group number for DMAMGR status codes.
-
enumerator kStatusGroup_FLEXCAN
Group number for FlexCAN status codes.
-
enumerator kStatusGroup_LTC
Group number for LTC status codes.
-
enumerator kStatusGroup_FLEXIO_CAMERA
Group number for FLEXIO CAMERA status codes.
-
enumerator kStatusGroup_LPC_SPI
Group number for LPC_SPI status codes.
-
enumerator kStatusGroup_LPC_USART
Group number for LPC_USART status codes.
-
enumerator kStatusGroup_DMIC
Group number for DMIC status codes.
-
enumerator kStatusGroup_SDIF
Group number for SDIF status codes.
-
enumerator kStatusGroup_SPIFI
Group number for SPIFI status codes.
-
enumerator kStatusGroup_OTP
Group number for OTP status codes.
-
enumerator kStatusGroup_MCAN
Group number for MCAN status codes.
-
enumerator kStatusGroup_CAAM
Group number for CAAM status codes.
-
enumerator kStatusGroup_ECSPI
Group number for ECSPI status codes.
-
enumerator kStatusGroup_USDHC
Group number for USDHC status codes.
-
enumerator kStatusGroup_LPC_I2C
Group number for LPC_I2C status codes.
-
enumerator kStatusGroup_DCP
Group number for DCP status codes.
-
enumerator kStatusGroup_MSCAN
Group number for MSCAN status codes.
-
enumerator kStatusGroup_ESAI
Group number for ESAI status codes.
-
enumerator kStatusGroup_FLEXSPI
Group number for FLEXSPI status codes.
-
enumerator kStatusGroup_MMDC
Group number for MMDC status codes.
-
enumerator kStatusGroup_PDM
Group number for MIC status codes.
-
enumerator kStatusGroup_SDMA
Group number for SDMA status codes.
-
enumerator kStatusGroup_ICS
Group number for ICS status codes.
-
enumerator kStatusGroup_SPDIF
Group number for SPDIF status codes.
-
enumerator kStatusGroup_LPC_MINISPI
Group number for LPC_MINISPI status codes.
-
enumerator kStatusGroup_HASHCRYPT
Group number for Hashcrypt status codes
-
enumerator kStatusGroup_LPC_SPI_SSP
Group number for LPC_SPI_SSP status codes.
-
enumerator kStatusGroup_I3C
Group number for I3C status codes
-
enumerator kStatusGroup_LPC_I2C_1
Group number for LPC_I2C_1 status codes.
-
enumerator kStatusGroup_NOTIFIER
Group number for NOTIFIER status codes.
-
enumerator kStatusGroup_DebugConsole
Group number for debug console status codes.
-
enumerator kStatusGroup_SEMC
Group number for SEMC status codes.
-
enumerator kStatusGroup_ApplicationRangeStart
Starting number for application groups.
-
enumerator kStatusGroup_IAP
Group number for IAP status codes
-
enumerator kStatusGroup_SFA
Group number for SFA status codes
-
enumerator kStatusGroup_SPC
Group number for SPC status codes.
-
enumerator kStatusGroup_PUF
Group number for PUF status codes.
-
enumerator kStatusGroup_TOUCH_PANEL
Group number for touch panel status codes
-
enumerator kStatusGroup_VBAT
Group number for VBAT status codes
-
enumerator kStatusGroup_XSPI
Group number for XSPI status codes
-
enumerator kStatusGroup_PNGDEC
Group number for PNGDEC status codes
-
enumerator kStatusGroup_JPEGDEC
Group number for JPEGDEC status codes
-
enumerator kStatusGroup_HAL_GPIO
Group number for HAL GPIO status codes.
-
enumerator kStatusGroup_HAL_UART
Group number for HAL UART status codes.
-
enumerator kStatusGroup_HAL_TIMER
Group number for HAL TIMER status codes.
-
enumerator kStatusGroup_HAL_SPI
Group number for HAL SPI status codes.
-
enumerator kStatusGroup_HAL_I2C
Group number for HAL I2C status codes.
-
enumerator kStatusGroup_HAL_FLASH
Group number for HAL FLASH status codes.
-
enumerator kStatusGroup_HAL_PWM
Group number for HAL PWM status codes.
-
enumerator kStatusGroup_HAL_RNG
Group number for HAL RNG status codes.
-
enumerator kStatusGroup_HAL_I2S
Group number for HAL I2S status codes.
-
enumerator kStatusGroup_HAL_ADC_SENSOR
Group number for HAL ADC SENSOR status codes.
-
enumerator kStatusGroup_TIMERMANAGER
Group number for TiMER MANAGER status codes.
-
enumerator kStatusGroup_SERIALMANAGER
Group number for SERIAL MANAGER status codes.
-
enumerator kStatusGroup_LED
Group number for LED status codes.
-
enumerator kStatusGroup_BUTTON
Group number for BUTTON status codes.
-
enumerator kStatusGroup_EXTERN_EEPROM
Group number for EXTERN EEPROM status codes.
-
enumerator kStatusGroup_SHELL
Group number for SHELL status codes.
-
enumerator kStatusGroup_MEM_MANAGER
Group number for MEM MANAGER status codes.
-
enumerator kStatusGroup_LIST
Group number for List status codes.
-
enumerator kStatusGroup_OSA
Group number for OSA status codes.
-
enumerator kStatusGroup_COMMON_TASK
Group number for Common task status codes.
-
enumerator kStatusGroup_MSG
Group number for messaging status codes.
-
enumerator kStatusGroup_SDK_OCOTP
Group number for OCOTP status codes.
-
enumerator kStatusGroup_SDK_FLEXSPINOR
Group number for FLEXSPINOR status codes.
-
enumerator kStatusGroup_CODEC
Group number for codec status codes.
-
enumerator kStatusGroup_ASRC
Group number for codec status ASRC.
-
enumerator kStatusGroup_OTFAD
Group number for codec status codes.
-
enumerator kStatusGroup_SDIOSLV
Group number for SDIOSLV status codes.
-
enumerator kStatusGroup_MECC
Group number for MECC status codes.
-
enumerator kStatusGroup_ENET_QOS
Group number for ENET_QOS status codes.
-
enumerator kStatusGroup_LOG
Group number for LOG status codes.
-
enumerator kStatusGroup_I3CBUS
Group number for I3CBUS status codes.
-
enumerator kStatusGroup_QSCI
Group number for QSCI status codes.
-
enumerator kStatusGroup_ELEMU
Group number for ELEMU status codes.
-
enumerator kStatusGroup_QUEUEDSPI
Group number for QSPI status codes.
-
enumerator kStatusGroup_POWER_MANAGER
Group number for POWER_MANAGER status codes.
-
enumerator kStatusGroup_IPED
Group number for IPED status codes.
-
enumerator kStatusGroup_ELS_PKC
Group number for ELS PKC status codes.
-
enumerator kStatusGroup_CSS_PKC
Group number for CSS PKC status codes.
-
enumerator kStatusGroup_HOSTIF
Group number for HOSTIF status codes.
-
enumerator kStatusGroup_CLIF
Group number for CLIF status codes.
-
enumerator kStatusGroup_BMA
Group number for BMA status codes.
-
enumerator kStatusGroup_NETC
Group number for NETC status codes.
-
enumerator kStatusGroup_ELE
Group number for ELE status codes.
-
enumerator kStatusGroup_GLIKEY
Group number for GLIKEY status codes.
-
enumerator kStatusGroup_AON_POWER
Group number for AON_POWER status codes.
-
enumerator kStatusGroup_AON_COMMON
Group number for AON_COMMON status codes.
-
enumerator kStatusGroup_ENDAT3
Group number for ENDAT3 status codes.
-
enumerator kStatusGroup_HIPERFACE
Group number for HIPERFACE status codes.
-
enumerator kStatusGroup_Generic
Generic status return codes.
Values:
-
enumerator kStatus_Success
Generic status for Success.
-
enumerator kStatus_Fail
Generic status for Fail.
-
enumerator kStatus_ReadOnly
Generic status for read only failure.
-
enumerator kStatus_OutOfRange
Generic status for out of range access.
-
enumerator kStatus_InvalidArgument
Generic status for invalid argument check.
-
enumerator kStatus_Timeout
Generic status for timeout.
-
enumerator kStatus_NoTransferInProgress
Generic status for no transfer in progress.
-
enumerator kStatus_Busy
Generic status for module is busy.
-
enumerator kStatus_NoData
Generic status for no data is found for the operation.
-
enumerator kStatus_Success
-
typedef int32_t status_t
Type used for all status and error return values.
-
void *SDK_Malloc(size_t size, size_t alignbytes)
Allocate memory with given alignment and aligned size.
This is provided to support the dynamically allocated memory used in cache-able region.
- Parameters:
size – The length required to malloc.
alignbytes – The alignment size.
- Return values:
The – allocated memory.
-
void SDK_Free(void *ptr)
Free memory.
- Parameters:
ptr – The memory to be release.
-
void SDK_DelayAtLeastUs(uint32_t delayTime_us, uint32_t coreClock_Hz)
Delay at least for some time. Please note that, this API uses while loop for delay, different run-time environments make the time not precise, if precise delay count was needed, please implement a new delay function with hardware timer.
- Parameters:
delayTime_us – Delay time in unit of microsecond.
coreClock_Hz – Core clock frequency with Hz.
-
static inline status_t EnableIRQ(IRQn_Type interrupt)
Enable specific interrupt.
Enable LEVEL1 interrupt. For some devices, there might be multiple interrupt levels. For example, there are NVIC and intmux. Here the interrupts connected to NVIC are the LEVEL1 interrupts, because they are routed to the core directly. The interrupts connected to intmux are the LEVEL2 interrupts, they are routed to NVIC first then routed to core.
This function only enables the LEVEL1 interrupts. The number of LEVEL1 interrupts is indicated by the feature macro FSL_FEATURE_NUMBER_OF_LEVEL1_INT_VECTORS.
- Parameters:
interrupt – The IRQ number.
- Return values:
kStatus_Success – Interrupt enabled successfully
kStatus_Fail – Failed to enable the interrupt
-
static inline status_t DisableIRQ(IRQn_Type interrupt)
Disable specific interrupt.
Disable LEVEL1 interrupt. For some devices, there might be multiple interrupt levels. For example, there are NVIC and intmux. Here the interrupts connected to NVIC are the LEVEL1 interrupts, because they are routed to the core directly. The interrupts connected to intmux are the LEVEL2 interrupts, they are routed to NVIC first then routed to core.
This function only disables the LEVEL1 interrupts. The number of LEVEL1 interrupts is indicated by the feature macro FSL_FEATURE_NUMBER_OF_LEVEL1_INT_VECTORS.
- Parameters:
interrupt – The IRQ number.
- Return values:
kStatus_Success – Interrupt disabled successfully
kStatus_Fail – Failed to disable the interrupt
-
static inline status_t EnableIRQWithPriority(IRQn_Type interrupt, uint8_t priNum)
Enable the IRQ, and also set the interrupt priority.
Only handle LEVEL1 interrupt. For some devices, there might be multiple interrupt levels. For example, there are NVIC and intmux. Here the interrupts connected to NVIC are the LEVEL1 interrupts, because they are routed to the core directly. The interrupts connected to intmux are the LEVEL2 interrupts, they are routed to NVIC first then routed to core.
This function only handles the LEVEL1 interrupts. The number of LEVEL1 interrupts is indicated by the feature macro FSL_FEATURE_NUMBER_OF_LEVEL1_INT_VECTORS.
- Parameters:
interrupt – The IRQ to Enable.
priNum – Priority number set to interrupt controller register.
- Return values:
kStatus_Success – Interrupt priority set successfully
kStatus_Fail – Failed to set the interrupt priority.
-
static inline status_t IRQ_SetPriority(IRQn_Type interrupt, uint8_t priNum)
Set the IRQ priority.
Only handle LEVEL1 interrupt. For some devices, there might be multiple interrupt levels. For example, there are NVIC and intmux. Here the interrupts connected to NVIC are the LEVEL1 interrupts, because they are routed to the core directly. The interrupts connected to intmux are the LEVEL2 interrupts, they are routed to NVIC first then routed to core.
This function only handles the LEVEL1 interrupts. The number of LEVEL1 interrupts is indicated by the feature macro FSL_FEATURE_NUMBER_OF_LEVEL1_INT_VECTORS.
- Parameters:
interrupt – The IRQ to set.
priNum – Priority number set to interrupt controller register.
- Return values:
kStatus_Success – Interrupt priority set successfully
kStatus_Fail – Failed to set the interrupt priority.
-
static inline status_t IRQ_ClearPendingIRQ(IRQn_Type interrupt)
Clear the pending IRQ flag.
Only handle LEVEL1 interrupt. For some devices, there might be multiple interrupt levels. For example, there are NVIC and intmux. Here the interrupts connected to NVIC are the LEVEL1 interrupts, because they are routed to the core directly. The interrupts connected to intmux are the LEVEL2 interrupts, they are routed to NVIC first then routed to core.
This function only handles the LEVEL1 interrupts. The number of LEVEL1 interrupts is indicated by the feature macro FSL_FEATURE_NUMBER_OF_LEVEL1_INT_VECTORS.
- Parameters:
interrupt – The flag which IRQ to clear.
- Return values:
kStatus_Success – Interrupt priority set successfully
kStatus_Fail – Failed to set the interrupt priority.
-
static inline uint32_t DisableGlobalIRQ(void)
Disable the global IRQ.
Disable the global interrupt and return the current primask register. User is required to provided the primask register for the EnableGlobalIRQ().
- Returns:
Current primask value.
-
static inline void EnableGlobalIRQ(uint32_t primask)
Enable the global IRQ.
Set the primask register with the provided primask value but not just enable the primask. The idea is for the convenience of integration of RTOS. some RTOS get its own management mechanism of primask. User is required to use the EnableGlobalIRQ() and DisableGlobalIRQ() in pair.
- Parameters:
primask – value of primask register to be restored. The primask value is supposed to be provided by the DisableGlobalIRQ().
-
void EnableDeepSleepIRQ(IRQn_Type interrupt)
Enable specific interrupt for wake-up from deep-sleep mode.
Enable the interrupt for wake-up from deep sleep mode. Some interrupts are typically used in sleep mode only and will not occur during deep-sleep mode because relevant clocks are stopped. However, it is possible to enable those clocks (significantly increasing power consumption in the reduced power mode), making these wake-ups possible.
Note
This function also enables the interrupt in the NVIC (EnableIRQ() is called internaly).
- Parameters:
interrupt – The IRQ number.
-
void DisableDeepSleepIRQ(IRQn_Type interrupt)
Disable specific interrupt for wake-up from deep-sleep mode.
Disable the interrupt for wake-up from deep sleep mode. Some interrupts are typically used in sleep mode only and will not occur during deep-sleep mode because relevant clocks are stopped. However, it is possible to enable those clocks (significantly increasing power consumption in the reduced power mode), making these wake-ups possible.
Note
This function also disables the interrupt in the NVIC (DisableIRQ() is called internaly).
- Parameters:
interrupt – The IRQ number.
-
static inline bool _SDK_AtomicLocalCompareAndSet(uint32_t *addr, uint32_t expected, uint32_t newValue)
-
static inline uint32_t _SDK_AtomicTestAndSet(uint32_t *addr, uint32_t newValue)
-
FSL_DRIVER_TRANSFER_DOUBLE_WEAK_IRQ
Macro to use the default weak IRQ handler in drivers.
-
MAKE_STATUS(group, code)
Construct a status code value from a group and code number.
-
MAKE_VERSION(major, minor, bugfix)
Construct the version number for drivers.
The driver version is a 32-bit number, for both 32-bit platforms(such as Cortex M) and 16-bit platforms(such as DSC).
| Unused || Major Version || Minor Version || Bug Fix | 31 25 24 17 16 9 8 0
-
ARRAY_SIZE(x)
Computes the number of elements in an array.
-
UINT64_H(X)
Macro to get upper 32 bits of a 64-bit value
-
UINT64_L(X)
Macro to get lower 32 bits of a 64-bit value
-
SUPPRESS_FALL_THROUGH_WARNING()
For switch case code block, if case section ends without “break;” statement, there wil be fallthrough warning with compiler flag -Wextra or -Wimplicit-fallthrough=n when using armgcc. To suppress this warning, “SUPPRESS_FALL_THROUGH_WARNING();” need to be added at the end of each case section which misses “break;”statement.
-
MSDK_REG_SECURE_ADDR(x)
Convert the register address to the one used in secure mode.
-
MSDK_REG_NONSECURE_ADDR(x)
Convert the register address to the one used in non-secure mode.
LPADC: 12-bit SAR Analog-to-Digital Converter Driver
-
void LPADC_Init(ADC_Type *base, const lpadc_config_t *config)
Initializes the LPADC module.
- Parameters:
base – LPADC peripheral base address.
config – Pointer to configuration structure. See “lpadc_config_t”.
-
void LPADC_GetDefaultConfig(lpadc_config_t *config)
Gets an available pre-defined settings for initial configuration.
This function initializes the converter configuration structure with an available settings. The default values are:
config->enableInDozeMode = true; config->enableAnalogPreliminary = false; config->powerUpDelay = 0x80; config->referenceVoltageSource = kLPADC_ReferenceVoltageAlt1; config->powerLevelMode = kLPADC_PowerLevelAlt1; config->triggerPriorityPolicy = kLPADC_TriggerPriorityPreemptImmediately; config->enableConvPause = false; config->convPauseDelay = 0U; config->FIFOWatermark = 0U;
- Parameters:
config – Pointer to configuration structure.
-
void LPADC_Deinit(ADC_Type *base)
De-initializes the LPADC module.
- Parameters:
base – LPADC peripheral base address.
-
static inline void LPADC_Enable(ADC_Type *base, bool enable)
Switch on/off the LPADC module.
- Parameters:
base – LPADC peripheral base address.
enable – switcher to the module.
-
static inline void LPADC_DoResetFIFO(ADC_Type *base)
Do reset the conversion FIFO.
- Parameters:
base – LPADC peripheral base address.
-
static inline void LPADC_DoResetConfig(ADC_Type *base)
Do reset the module’s configuration.
Reset all ADC internal logic and registers, except the Control Register (ADCx_CTRL).
- Parameters:
base – LPADC peripheral base address.
-
static inline uint32_t LPADC_GetStatusFlags(ADC_Type *base)
Get status flags.
- Parameters:
base – LPADC peripheral base address.
- Returns:
status flags’ mask. See to _lpadc_status_flags.
-
static inline void LPADC_ClearStatusFlags(ADC_Type *base, uint32_t mask)
Clear status flags.
Only the flags can be cleared by writing ADCx_STATUS register would be cleared by this API.
- Parameters:
base – LPADC peripheral base address.
mask – Mask value for flags to be cleared. See to _lpadc_status_flags.
-
static inline uint32_t LPADC_GetTriggerStatusFlags(ADC_Type *base)
Get trigger status flags to indicate which trigger sequences have been completed or interrupted by a high priority trigger exception.
- Parameters:
base – LPADC peripheral base address.
- Returns:
The OR’ed value of _lpadc_trigger_status_flags.
-
static inline void LPADC_ClearTriggerStatusFlags(ADC_Type *base, uint32_t mask)
Clear trigger status flags.
- Parameters:
base – LPADC peripheral base address.
mask – The mask of trigger status flags to be cleared, should be the OR’ed value of _lpadc_trigger_status_flags.
-
static inline void LPADC_EnableInterrupts(ADC_Type *base, uint32_t mask)
Enable interrupts.
- Parameters:
base – LPADC peripheral base address.
mask – Mask value for interrupt events. See to _lpadc_interrupt_enable.
-
static inline void LPADC_DisableInterrupts(ADC_Type *base, uint32_t mask)
Disable interrupts.
- Parameters:
base – LPADC peripheral base address.
mask – Mask value for interrupt events. See to _lpadc_interrupt_enable.
-
static inline void LPADC_EnableFIFOWatermarkDMA(ADC_Type *base, bool enable)
Switch on/off the DMA trigger for FIFO watermark event.
- Parameters:
base – LPADC peripheral base address.
enable – Switcher to the event.
-
static inline uint32_t LPADC_GetConvResultCount(ADC_Type *base)
Get the count of result kept in conversion FIFO.
- Parameters:
base – LPADC peripheral base address.
- Returns:
The count of result kept in conversion FIFO.
-
bool LPADC_GetConvResult(ADC_Type *base, lpadc_conv_result_t *result)
Get the result in conversion FIFO.
- Parameters:
base – LPADC peripheral base address.
result – Pointer to structure variable that keeps the conversion result in conversion FIFO.
- Returns:
Status whether FIFO entry is valid.
-
void LPADC_GetConvResultBlocking(ADC_Type *base, lpadc_conv_result_t *result)
Get the result in conversion FIFO using blocking method.
- Parameters:
base – LPADC peripheral base address.
result – Pointer to structure variable that keeps the conversion result in conversion FIFO.
-
void LPADC_SetConvTriggerConfig(ADC_Type *base, uint32_t triggerId, const lpadc_conv_trigger_config_t *config)
Configure the conversion trigger source.
Each programmable trigger can launch the conversion command in command buffer.
- Parameters:
base – LPADC peripheral base address.
triggerId – ID for each trigger. Typically, the available value range is from 0.
config – Pointer to configuration structure. See to lpadc_conv_trigger_config_t.
-
void LPADC_GetDefaultConvTriggerConfig(lpadc_conv_trigger_config_t *config)
Gets an available pre-defined settings for trigger’s configuration.
This function initializes the trigger’s configuration structure with an available settings. The default values are:
config->targetCommandId = 0U; config->delayPower = 0U; config->priority = 0U; config->channelAFIFOSelect = 0U; config->channelBFIFOSelect = 0U; config->enableHardwareTrigger = false;
- Parameters:
config – Pointer to configuration structure.
-
static inline void LPADC_DoSoftwareTrigger(ADC_Type *base, uint32_t triggerIdMask)
Do software trigger to conversion command.
- Parameters:
base – LPADC peripheral base address.
triggerIdMask – Mask value for software trigger indexes, which count from zero.
-
void LPADC_SetConvCommandConfig(ADC_Type *base, uint32_t commandId, const lpadc_conv_command_config_t *config)
Configure conversion command.
Note
The number of compare value register on different chips is different, that is mean in some chips, some command buffers do not have the compare functionality.
- Parameters:
base – LPADC peripheral base address.
commandId – ID for command in command buffer. Typically, the available value range is 1 - 15.
config – Pointer to configuration structure. See to lpadc_conv_command_config_t.
-
void LPADC_GetDefaultConvCommandConfig(lpadc_conv_command_config_t *config)
Gets an available pre-defined settings for conversion command’s configuration.
This function initializes the conversion command’s configuration structure with an available settings. The default values are:
config->sampleScaleMode = kLPADC_SampleFullScale; config->channelBScaleMode = kLPADC_SampleFullScale; config->sampleChannelMode = kLPADC_SampleChannelSingleEndSideA; config->channelNumber = 0U; config->channelBNumber = 0U; config->chainedNextCommandNumber = 0U; config->enableAutoChannelIncrement = false; config->loopCount = 0U; config->hardwareAverageMode = kLPADC_HardwareAverageCount1; config->sampleTimeMode = kLPADC_SampleTimeADCK3; config->hardwareCompareMode = kLPADC_HardwareCompareDisabled; config->hardwareCompareValueHigh = 0U; config->hardwareCompareValueLow = 0U; config->conversionResolutionMode = kLPADC_ConversionResolutionStandard; config->enableWaitTrigger = false; config->enableChannelB = false;
- Parameters:
config – Pointer to configuration structure.
-
void LPADC_EnableCalibration(ADC_Type *base, bool enable)
Enable the calibration function.
When CALOFS is set, the ADC is configured to perform a calibration function anytime the ADC executes a conversion. Any channel selected is ignored and the value returned in the RESFIFO is a signed value between -31 and 31. -32 is not a valid and is never a returned value. Software should copy the lower 6- bits of the conversion result stored in the RESFIFO after a completed calibration conversion to the OFSTRIM field. The OFSTRIM field is used in normal operation for offset correction.
- Parameters:
base – LPADC peripheral base address.
enable – switcher to the calibration function.
-
static inline void LPADC_SetOffsetValue(ADC_Type *base, uint32_t value)
Set proper offset value to trim ADC.
To minimize the offset during normal operation, software should read the conversion result from the RESFIFO calibration operation and write the lower 6 bits to the OFSTRIM register.
- Parameters:
base – LPADC peripheral base address.
value – Setting offset value.
-
void LPADC_DoAutoCalibration(ADC_Type *base)
Do auto calibration.
Calibration function should be executed before using converter in application. It used the software trigger and a dummy conversion, get the offset and write them into the OFSTRIM register. It called some of functional API including: -LPADC_EnableCalibration(…) -LPADC_LPADC_SetOffsetValue(…) -LPADC_SetConvCommandConfig(…) -LPADC_SetConvTriggerConfig(…)
- Parameters:
base – LPADC peripheral base address.
base – LPADC peripheral base address.
-
static inline void LPADC_SetOffsetValue(ADC_Type *base, int16_t value)
Set trim value for offset.
Note
For 16-bit conversions, each increment is 1/2 LSB resulting in a programmable offset range of -256 LSB to 255.5 LSB; For 12-bit conversions, each increment is 1/32 LSB resulting in a programmable offset range of -16 LSB to 15.96875 LSB.
- Parameters:
base – LPADC peripheral base address.
value – Offset trim value, is a 10-bit signed value between -512 and 511.
-
static inline void LPADC_GetOffsetValue(ADC_Type *base, int16_t *pValue)
Get trim value of offset.
- Parameters:
base – LPADC peripheral base address.
pValue – Pointer to the variable in type of int16_t to store offset value.
-
static inline void LPADC_EnableOffsetCalibration(ADC_Type *base, bool enable)
Enable the offset calibration function.
- Parameters:
base – LPADC peripheral base address.
enable – switcher to the calibration function.
-
static inline void LPADC_SetOffsetCalibrationMode(ADC_Type *base, lpadc_offset_calibration_mode_t mode)
Set offset calibration mode.
- Parameters:
base – LPADC peripheral base address.
mode – set offset calibration mode.see to lpadc_offset_calibration_mode_t .
-
void LPADC_DoOffsetCalibration(ADC_Type *base)
Do offset calibration.
- Parameters:
base – LPADC peripheral base address.
-
void LPADC_PrepareAutoCalibration(ADC_Type *base)
Prepare auto calibration, LPADC_FinishAutoCalibration has to be called before using the LPADC. LPADC_DoAutoCalibration has been split in two API to avoid to be stuck too long in the function.
- Parameters:
base – LPADC peripheral base address.
-
void LPADC_FinishAutoCalibration(ADC_Type *base)
Finish auto calibration start with LPADC_PrepareAutoCalibration.
Note
This feature is used for LPADC with CTRL[CALOFSMODE].
- Parameters:
base – LPADC peripheral base address.
-
void LPADC_GetCalibrationValue(ADC_Type *base, lpadc_calibration_value_t *ptrCalibrationValue)
Get calibration value into the memory which is defined by invoker.
Note
Please note the ADC will be disabled temporary.
Note
This function should be used after finish calibration.
- Parameters:
base – LPADC peripheral base address.
ptrCalibrationValue – Pointer to lpadc_calibration_value_t structure, this memory block should be always powered on even in low power modes.
-
void LPADC_SetCalibrationValue(ADC_Type *base, const lpadc_calibration_value_t *ptrCalibrationValue)
Set calibration value into ADC calibration registers.
Note
Please note the ADC will be disabled temporary.
- Parameters:
base – LPADC peripheral base address.
ptrCalibrationValue – Pointer to lpadc_calibration_value_t structure which contains ADC’s calibration value.
-
FSL_LPADC_DRIVER_VERSION
LPADC driver version 2.9.1.
-
enum _lpadc_status_flags
Define hardware flags of the module.
Values:
-
enumerator kLPADC_ResultFIFO0OverflowFlag
Indicates that more data has been written to the Result FIFO 0 than it can hold.
-
enumerator kLPADC_ResultFIFO0ReadyFlag
Indicates when the number of valid datawords in the result FIFO 0 is greater than the setting watermark level.
-
enumerator kLPADC_TriggerExceptionFlag
Indicates that a trigger exception event has occurred.
-
enumerator kLPADC_TriggerCompletionFlag
Indicates that a trigger completion event has occurred.
-
enumerator kLPADC_CalibrationReadyFlag
Indicates that the calibration process is done.
-
enumerator kLPADC_ActiveFlag
Indicates that the ADC is in active state.
-
enumerator kLPADC_ResultFIFOOverflowFlag
To compilitable with old version, do not recommend using this, please use kLPADC_ResultFIFO0OverflowFlag as instead.
-
enumerator kLPADC_ResultFIFOReadyFlag
To compilitable with old version, do not recommend using this, please use kLPADC_ResultFIFO0ReadyFlag as instead.
-
enumerator kLPADC_ResultFIFO0OverflowFlag
-
enum _lpadc_interrupt_enable
Define interrupt switchers of the module.
Note: LPADC of different chips supports different number of trigger sources, please check the Reference Manual for details.
Values:
-
enumerator kLPADC_ResultFIFO0OverflowInterruptEnable
Configures ADC to generate overflow interrupt requests when FOF0 flag is asserted.
-
enumerator kLPADC_FIFO0WatermarkInterruptEnable
Configures ADC to generate watermark interrupt requests when RDY0 flag is asserted.
-
enumerator kLPADC_ResultFIFOOverflowInterruptEnable
To compilitable with old version, do not recommend using this, please use kLPADC_ResultFIFO0OverflowInterruptEnable as instead.
-
enumerator kLPADC_FIFOWatermarkInterruptEnable
To compilitable with old version, do not recommend using this, please use kLPADC_FIFO0WatermarkInterruptEnable as instead.
-
enumerator kLPADC_TriggerExceptionInterruptEnable
Configures ADC to generate trigger exception interrupt.
-
enumerator kLPADC_Trigger0CompletionInterruptEnable
Configures ADC to generate interrupt when trigger 0 completion.
-
enumerator kLPADC_Trigger1CompletionInterruptEnable
Configures ADC to generate interrupt when trigger 1 completion.
-
enumerator kLPADC_Trigger2CompletionInterruptEnable
Configures ADC to generate interrupt when trigger 2 completion.
-
enumerator kLPADC_Trigger3CompletionInterruptEnable
Configures ADC to generate interrupt when trigger 3 completion.
-
enumerator kLPADC_Trigger4CompletionInterruptEnable
Configures ADC to generate interrupt when trigger 4 completion.
-
enumerator kLPADC_Trigger5CompletionInterruptEnable
Configures ADC to generate interrupt when trigger 5 completion.
-
enumerator kLPADC_Trigger6CompletionInterruptEnable
Configures ADC to generate interrupt when trigger 6 completion.
-
enumerator kLPADC_Trigger7CompletionInterruptEnable
Configures ADC to generate interrupt when trigger 7 completion.
-
enumerator kLPADC_Trigger8CompletionInterruptEnable
Configures ADC to generate interrupt when trigger 8 completion.
-
enumerator kLPADC_Trigger9CompletionInterruptEnable
Configures ADC to generate interrupt when trigger 9 completion.
-
enumerator kLPADC_Trigger10CompletionInterruptEnable
Configures ADC to generate interrupt when trigger 10 completion.
-
enumerator kLPADC_Trigger11CompletionInterruptEnable
Configures ADC to generate interrupt when trigger 11 completion.
-
enumerator kLPADC_Trigger12CompletionInterruptEnable
Configures ADC to generate interrupt when trigger 12 completion.
-
enumerator kLPADC_Trigger13CompletionInterruptEnable
Configures ADC to generate interrupt when trigger 13 completion.
-
enumerator kLPADC_Trigger14CompletionInterruptEnable
Configures ADC to generate interrupt when trigger 14 completion.
-
enumerator kLPADC_Trigger15CompletionInterruptEnable
Configures ADC to generate interrupt when trigger 15 completion.
-
enumerator kLPADC_ResultFIFO0OverflowInterruptEnable
-
enum _lpadc_trigger_status_flags
The enumerator of lpadc trigger status flags, including interrupted flags and completed flags.
Note: LPADC of different chips supports different number of trigger sources, please check the Reference Manual for details.
Values:
-
enumerator kLPADC_Trigger0InterruptedFlag
Trigger 0 is interrupted by a high priority exception.
-
enumerator kLPADC_Trigger1InterruptedFlag
Trigger 1 is interrupted by a high priority exception.
-
enumerator kLPADC_Trigger2InterruptedFlag
Trigger 2 is interrupted by a high priority exception.
-
enumerator kLPADC_Trigger3InterruptedFlag
Trigger 3 is interrupted by a high priority exception.
-
enumerator kLPADC_Trigger4InterruptedFlag
Trigger 4 is interrupted by a high priority exception.
-
enumerator kLPADC_Trigger5InterruptedFlag
Trigger 5 is interrupted by a high priority exception.
-
enumerator kLPADC_Trigger6InterruptedFlag
Trigger 6 is interrupted by a high priority exception.
-
enumerator kLPADC_Trigger7InterruptedFlag
Trigger 7 is interrupted by a high priority exception.
-
enumerator kLPADC_Trigger8InterruptedFlag
Trigger 8 is interrupted by a high priority exception.
-
enumerator kLPADC_Trigger9InterruptedFlag
Trigger 9 is interrupted by a high priority exception.
-
enumerator kLPADC_Trigger10InterruptedFlag
Trigger 10 is interrupted by a high priority exception.
-
enumerator kLPADC_Trigger11InterruptedFlag
Trigger 11 is interrupted by a high priority exception.
-
enumerator kLPADC_Trigger12InterruptedFlag
Trigger 12 is interrupted by a high priority exception.
-
enumerator kLPADC_Trigger13InterruptedFlag
Trigger 13 is interrupted by a high priority exception.
-
enumerator kLPADC_Trigger14InterruptedFlag
Trigger 14 is interrupted by a high priority exception.
-
enumerator kLPADC_Trigger15InterruptedFlag
Trigger 15 is interrupted by a high priority exception.
-
enumerator kLPADC_Trigger0CompletedFlag
Trigger 0 is completed and trigger 0 has enabled completion interrupts.
-
enumerator kLPADC_Trigger1CompletedFlag
Trigger 1 is completed and trigger 1 has enabled completion interrupts.
-
enumerator kLPADC_Trigger2CompletedFlag
Trigger 2 is completed and trigger 2 has enabled completion interrupts.
-
enumerator kLPADC_Trigger3CompletedFlag
Trigger 3 is completed and trigger 3 has enabled completion interrupts.
-
enumerator kLPADC_Trigger4CompletedFlag
Trigger 4 is completed and trigger 4 has enabled completion interrupts.
-
enumerator kLPADC_Trigger5CompletedFlag
Trigger 5 is completed and trigger 5 has enabled completion interrupts.
-
enumerator kLPADC_Trigger6CompletedFlag
Trigger 6 is completed and trigger 6 has enabled completion interrupts.
-
enumerator kLPADC_Trigger7CompletedFlag
Trigger 7 is completed and trigger 7 has enabled completion interrupts.
-
enumerator kLPADC_Trigger8CompletedFlag
Trigger 8 is completed and trigger 8 has enabled completion interrupts.
-
enumerator kLPADC_Trigger9CompletedFlag
Trigger 9 is completed and trigger 9 has enabled completion interrupts.
-
enumerator kLPADC_Trigger10CompletedFlag
Trigger 10 is completed and trigger 10 has enabled completion interrupts.
-
enumerator kLPADC_Trigger11CompletedFlag
Trigger 11 is completed and trigger 11 has enabled completion interrupts.
-
enumerator kLPADC_Trigger12CompletedFlag
Trigger 12 is completed and trigger 12 has enabled completion interrupts.
-
enumerator kLPADC_Trigger13CompletedFlag
Trigger 13 is completed and trigger 13 has enabled completion interrupts.
-
enumerator kLPADC_Trigger14CompletedFlag
Trigger 14 is completed and trigger 14 has enabled completion interrupts.
-
enumerator kLPADC_Trigger15CompletedFlag
Trigger 15 is completed and trigger 15 has enabled completion interrupts.
-
enumerator kLPADC_Trigger0InterruptedFlag
-
enum _lpadc_sample_scale_mode
Define enumeration of sample scale mode.
The sample scale mode is used to reduce the selected ADC analog channel input voltage level by a factor. The maximum possible voltage on the ADC channel input should be considered when selecting a scale mode to ensure that the reducing factor always results voltage level at or below the VREFH reference. This reducing capability allows conversion of analog inputs higher than VREFH. A-side and B-side channel inputs are both scaled using the scale mode.
Values:
-
enumerator kLPADC_SamplePartScale
Use divided input voltage signal. (For scale select,please refer to the reference manual).
-
enumerator kLPADC_SampleFullScale
Full scale (Factor of 1).
-
enumerator kLPADC_SamplePartScale
-
enum _lpadc_sample_channel_mode
Define enumeration of channel sample mode.
The channel sample mode configures the channel with single-end/differential/dual-single-end, side A/B.
Values:
-
enumerator kLPADC_SampleChannelSingleEndSideA
Single-end mode, only A-side channel is converted.
-
enumerator kLPADC_SampleChannelSingleEndSideB
Single-end mode, only B-side channel is converted.
-
enumerator kLPADC_SampleChannelDiffBothSideAB
Differential mode, the ADC result is (CHnA-CHnB).
-
enumerator kLPADC_SampleChannelDiffBothSideBA
Differential mode, the ADC result is (CHnB-CHnA).
-
enumerator kLPADC_SampleChannelDiffBothSide
Differential mode, the ADC result is (CHnA-CHnB).
-
enumerator kLPADC_SampleChannelDualSingleEndBothSide
Dual-Single-Ended Mode. Both A side and B side channels are converted independently.
-
enumerator kLPADC_SampleChannelSingleEndSideA
-
enum _lpadc_hardware_average_mode
Define enumeration of hardware average selection.
It Selects how many ADC conversions are averaged to create the ADC result. An internal storage buffer is used to capture temporary results while the averaging iterations are executed.
Note
Some enumerator values are not available on some devices, mainly depends on the size of AVGS field in CMDH register.
Values:
-
enumerator kLPADC_HardwareAverageCount1
Single conversion.
-
enumerator kLPADC_HardwareAverageCount2
2 conversions averaged.
-
enumerator kLPADC_HardwareAverageCount4
4 conversions averaged.
-
enumerator kLPADC_HardwareAverageCount8
8 conversions averaged.
-
enumerator kLPADC_HardwareAverageCount16
16 conversions averaged.
-
enumerator kLPADC_HardwareAverageCount32
32 conversions averaged.
-
enumerator kLPADC_HardwareAverageCount64
64 conversions averaged.
-
enumerator kLPADC_HardwareAverageCount128
128 conversions averaged.
-
enumerator kLPADC_HardwareAverageCount1
-
enum _lpadc_sample_time_mode
Define enumeration of sample time selection.
The shortest sample time maximizes conversion speed for lower impedance inputs. Extending sample time allows higher impedance inputs to be accurately sampled. Longer sample times can also be used to lower overall power consumption when command looping and sequencing is configured and high conversion rates are not required.
Values:
-
enumerator kLPADC_SampleTimeADCK3
3 ADCK cycles total sample time.
-
enumerator kLPADC_SampleTimeADCK5
5 ADCK cycles total sample time.
-
enumerator kLPADC_SampleTimeADCK7
7 ADCK cycles total sample time.
-
enumerator kLPADC_SampleTimeADCK11
11 ADCK cycles total sample time.
-
enumerator kLPADC_SampleTimeADCK19
19 ADCK cycles total sample time.
-
enumerator kLPADC_SampleTimeADCK35
35 ADCK cycles total sample time.
-
enumerator kLPADC_SampleTimeADCK67
69 ADCK cycles total sample time.
-
enumerator kLPADC_SampleTimeADCK131
131 ADCK cycles total sample time.
-
enumerator kLPADC_SampleTimeADCK3
-
enum _lpadc_hardware_compare_mode
Define enumeration of hardware compare mode.
After an ADC channel input is sampled and converted and any averaging iterations are performed, this mode setting guides operation of the automatic compare function to optionally only store when the compare operation is true. When compare is enabled, the conversion result is compared to the compare values.
Values:
-
enumerator kLPADC_HardwareCompareDisabled
Compare disabled.
-
enumerator kLPADC_HardwareCompareStoreOnTrue
Compare enabled. Store on true.
-
enumerator kLPADC_HardwareCompareRepeatUntilTrue
Compare enabled. Repeat channel acquisition until true.
-
enumerator kLPADC_HardwareCompareDisabled
-
enum _lpadc_conversion_resolution_mode
Define enumeration of conversion resolution mode.
Configure the resolution bit in specific conversion type. For detailed resolution accuracy, see to lpadc_sample_channel_mode_t
Values:
-
enumerator kLPADC_ConversionResolutionStandard
Standard resolution. Single-ended 12-bit conversion, Differential 13-bit conversion with 2’s complement output.
-
enumerator kLPADC_ConversionResolutionHigh
High resolution. Single-ended 16-bit conversion; Differential 16-bit conversion with 2’s complement output.
-
enumerator kLPADC_ConversionResolutionStandard
-
enum _lpadc_conversion_average_mode
Define enumeration of conversion averages mode.
Configure the converion average number for auto-calibration.
Note
Some enumerator values are not available on some devices, mainly depends on the size of CAL_AVGS field in CTRL register.
Values:
-
enumerator kLPADC_ConversionAverage1
Single conversion.
-
enumerator kLPADC_ConversionAverage2
2 conversions averaged.
-
enumerator kLPADC_ConversionAverage4
4 conversions averaged.
-
enumerator kLPADC_ConversionAverage8
8 conversions averaged.
-
enumerator kLPADC_ConversionAverage16
16 conversions averaged.
-
enumerator kLPADC_ConversionAverage32
32 conversions averaged.
-
enumerator kLPADC_ConversionAverage64
64 conversions averaged.
-
enumerator kLPADC_ConversionAverage128
128 conversions averaged.
-
enumerator kLPADC_ConversionAverage1
-
enum _lpadc_reference_voltage_mode
Define enumeration of reference voltage source.
For detail information, need to check the SoC’s specification.
Values:
-
enumerator kLPADC_ReferenceVoltageAlt1
Option 1 setting.
-
enumerator kLPADC_ReferenceVoltageAlt2
Option 2 setting.
-
enumerator kLPADC_ReferenceVoltageAlt3
Option 3 setting.
-
enumerator kLPADC_ReferenceVoltageAlt1
-
enum _lpadc_power_level_mode
Define enumeration of power configuration.
Configures the ADC for power and performance. In the highest power setting the highest conversion rates will be possible. Refer to the device data sheet for power and performance capabilities for each setting.
Values:
-
enumerator kLPADC_PowerLevelAlt1
Lowest power setting.
-
enumerator kLPADC_PowerLevelAlt2
Next lowest power setting.
-
enumerator kLPADC_PowerLevelAlt3
…
-
enumerator kLPADC_PowerLevelAlt4
Highest power setting.
-
enumerator kLPADC_PowerLevelAlt1
-
enum _lpadc_offset_calibration_mode
Define enumeration of offset calibration mode.
Values:
-
enumerator kLPADC_OffsetCalibration12bitMode
12 bit offset calibration mode.
-
enumerator kLPADC_OffsetCalibration16bitMode
16 bit offset calibration mode.
-
enumerator kLPADC_OffsetCalibration12bitMode
-
enum _lpadc_trigger_priority_policy
Define enumeration of trigger priority policy.
This selection controls how higher priority triggers are handled.
Note
kLPADC_TriggerPriorityPreemptSubsequently is not available on some devices, mainly depends on the size of TPRICTRL field in CFG register.
Values:
-
enumerator kLPADC_ConvPreemptImmediatelyNotAutoResumed
If a higher priority trigger is detected during command processing, the current conversion is aborted and the new command specified by the trigger is started, when higher priority conversion finishes, the preempted conversion is not automatically resumed or restarted.
-
enumerator kLPADC_ConvPreemptSoftlyNotAutoResumed
If a higher priority trigger is received during command processing, the current conversion is completed (including averaging iterations and compare function if enabled) and stored to the result FIFO before the higher priority trigger/command is initiated, when higher priority conversion finishes, the preempted conversion is not resumed or restarted.
-
enumerator kLPADC_ConvPreemptImmediatelyAutoRestarted
If a higher priority trigger is detected during command processing, the current conversion is aborted and the new command specified by the trigger is started, when higher priority conversion finishes, the preempted conversion will automatically be restarted.
-
enumerator kLPADC_ConvPreemptSoftlyAutoRestarted
If a higher priority trigger is received during command processing, the current conversion is completed (including averaging iterations and compare function if enabled) and stored to the result FIFO before the higher priority trigger/command is initiated, when higher priority conversion finishes, the preempted conversion will automatically be restarted.
-
enumerator kLPADC_ConvPreemptImmediatelyAutoResumed
If a higher priority trigger is detected during command processing, the current conversion is aborted and the new command specified by the trigger is started, when higher priority conversion finishes, the preempted conversion will automatically be resumed.
-
enumerator kLPADC_ConvPreemptSoftlyAutoResumed
If a higher priority trigger is received during command processing, the current conversion is completed (including averaging iterations and compare function if enabled) and stored to the result FIFO before the higher priority trigger/command is initiated, when higher priority conversion finishes, the preempted conversion will be automatically be resumed.
-
enumerator kLPADC_TriggerPriorityPreemptImmediately
Legacy support is not recommended as it only ensures compatibility with older versions.
-
enumerator kLPADC_TriggerPriorityPreemptSoftly
Legacy support is not recommended as it only ensures compatibility with older versions.
-
enumerator kLPADC_TriggerPriorityExceptionDisabled
High priority trigger exception disabled.
-
enumerator kLPADC_ConvPreemptImmediatelyNotAutoResumed
-
typedef enum _lpadc_sample_scale_mode lpadc_sample_scale_mode_t
Define enumeration of sample scale mode.
The sample scale mode is used to reduce the selected ADC analog channel input voltage level by a factor. The maximum possible voltage on the ADC channel input should be considered when selecting a scale mode to ensure that the reducing factor always results voltage level at or below the VREFH reference. This reducing capability allows conversion of analog inputs higher than VREFH. A-side and B-side channel inputs are both scaled using the scale mode.
-
typedef enum _lpadc_sample_channel_mode lpadc_sample_channel_mode_t
Define enumeration of channel sample mode.
The channel sample mode configures the channel with single-end/differential/dual-single-end, side A/B.
-
typedef enum _lpadc_hardware_average_mode lpadc_hardware_average_mode_t
Define enumeration of hardware average selection.
It Selects how many ADC conversions are averaged to create the ADC result. An internal storage buffer is used to capture temporary results while the averaging iterations are executed.
Note
Some enumerator values are not available on some devices, mainly depends on the size of AVGS field in CMDH register.
-
typedef enum _lpadc_sample_time_mode lpadc_sample_time_mode_t
Define enumeration of sample time selection.
The shortest sample time maximizes conversion speed for lower impedance inputs. Extending sample time allows higher impedance inputs to be accurately sampled. Longer sample times can also be used to lower overall power consumption when command looping and sequencing is configured and high conversion rates are not required.
-
typedef enum _lpadc_hardware_compare_mode lpadc_hardware_compare_mode_t
Define enumeration of hardware compare mode.
After an ADC channel input is sampled and converted and any averaging iterations are performed, this mode setting guides operation of the automatic compare function to optionally only store when the compare operation is true. When compare is enabled, the conversion result is compared to the compare values.
-
typedef enum _lpadc_conversion_resolution_mode lpadc_conversion_resolution_mode_t
Define enumeration of conversion resolution mode.
Configure the resolution bit in specific conversion type. For detailed resolution accuracy, see to lpadc_sample_channel_mode_t
-
typedef enum _lpadc_conversion_average_mode lpadc_conversion_average_mode_t
Define enumeration of conversion averages mode.
Configure the converion average number for auto-calibration.
Note
Some enumerator values are not available on some devices, mainly depends on the size of CAL_AVGS field in CTRL register.
-
typedef enum _lpadc_reference_voltage_mode lpadc_reference_voltage_source_t
Define enumeration of reference voltage source.
For detail information, need to check the SoC’s specification.
-
typedef enum _lpadc_power_level_mode lpadc_power_level_mode_t
Define enumeration of power configuration.
Configures the ADC for power and performance. In the highest power setting the highest conversion rates will be possible. Refer to the device data sheet for power and performance capabilities for each setting.
-
typedef enum _lpadc_offset_calibration_mode lpadc_offset_calibration_mode_t
Define enumeration of offset calibration mode.
-
typedef enum _lpadc_trigger_priority_policy lpadc_trigger_priority_policy_t
Define enumeration of trigger priority policy.
This selection controls how higher priority triggers are handled.
Note
kLPADC_TriggerPriorityPreemptSubsequently is not available on some devices, mainly depends on the size of TPRICTRL field in CFG register.
-
typedef struct _lpadc_calibration_value lpadc_calibration_value_t
A structure of calibration value.
-
ADC_OFSTRIM_OFSTRIM_MAX
-
ADC_OFSTRIM_OFSTRIM_SIGN
-
LPADC_GET_ACTIVE_COMMAND_STATUS(statusVal)
Define the MACRO function to get command status from status value.
The statusVal is the return value from LPADC_GetStatusFlags().
-
LPADC_GET_ACTIVE_TRIGGER_STATUE(statusVal)
Define the MACRO function to get trigger status from status value.
The statusVal is the return value from LPADC_GetStatusFlags().
-
struct lpadc_config_t
- #include <fsl_lpadc.h>
LPADC global configuration.
This structure would used to keep the settings for initialization.
Public Members
-
bool enableInternalClock
Enables the internally generated clock source. The clock source is used in clock selection logic at the chip level and is optionally used for the ADC clock source.
-
bool enableVref1LowVoltage
If voltage reference option1 input is below 1.8V, it should be “true”. If voltage reference option1 input is above 1.8V, it should be “false”.
-
bool enableInDozeMode
Control system transition to Stop and Wait power modes while ADC is converting. When enabled in Doze mode, immediate entries to Wait or Stop are allowed. When disabled, the ADC will wait for the current averaging iteration/FIFO storage to complete before acknowledging stop or wait mode entry.
-
lpadc_conversion_average_mode_t conversionAverageMode
Auto-Calibration Averages.
-
bool enableAnalogPreliminary
ADC analog circuits are pre-enabled and ready to execute conversions without startup delays(at the cost of higher DC current consumption).
-
uint32_t powerUpDelay
When the analog circuits are not pre-enabled, the ADC analog circuits are only powered while the ADC is active and there is a counted delay defined by this field after an initial trigger transitions the ADC from its Idle state to allow time for the analog circuits to stabilize. The startup delay count of (powerUpDelay * 4) ADCK cycles must result in a longer delay than the analog startup time.
-
lpadc_reference_voltage_source_t referenceVoltageSource
Selects the voltage reference high used for conversions.
-
lpadc_power_level_mode_t powerLevelMode
Power Configuration Selection.
-
lpadc_trigger_priority_policy_t triggerPriorityPolicy
Control how higher priority triggers are handled, see to lpadc_trigger_priority_policy_t.
-
bool enableConvPause
Enables the ADC pausing function. When enabled, a programmable delay is inserted during command execution sequencing between LOOP iterations, between commands in a sequence, and between conversions when command is executing in “Compare Until True” configuration.
-
uint32_t convPauseDelay
Controls the duration of pausing during command execution sequencing. The pause delay is a count of (convPauseDelay*4) ADCK cycles. Only available when ADC pausing function is enabled. The available value range is in 9-bit.
-
uint32_t FIFOWatermark
FIFOWatermark is a programmable threshold setting. When the number of datawords stored in the ADC Result FIFO is greater than the value in this field, the ready flag would be asserted to indicate stored data has reached the programmable threshold.
-
bool enableInternalClock
-
struct lpadc_conv_command_config_t
- #include <fsl_lpadc.h>
Define structure to keep the configuration for conversion command.
Public Members
-
lpadc_sample_scale_mode_t sampleScaleMode
Sample scale mode.
-
lpadc_sample_scale_mode_t channelBScaleMode
Alternate channe B Scale mode.
-
lpadc_sample_channel_mode_t sampleChannelMode
Channel sample mode.
-
uint32_t channelNumber
Channel number, select the channel or channel pair.
-
uint32_t channelBNumber
Alternate Channel B number, select the channel.
-
uint32_t chainedNextCommandNumber
Selects the next command to be executed after this command completes. 1-15 is available, 0 is to terminate the chain after this command.
-
bool enableAutoChannelIncrement
Loop with increment: when disabled, the “loopCount” field selects the number of times the selected channel is converted consecutively; when enabled, the “loopCount” field defines how many consecutive channels are converted as part of the command execution.
-
uint32_t loopCount
Selects how many times this command executes before finish and transition to the next command or Idle state. Command executes LOOP+1 times. 0-15 is available.
-
lpadc_hardware_average_mode_t hardwareAverageMode
Hardware average selection.
-
lpadc_sample_time_mode_t sampleTimeMode
Sample time selection.
-
lpadc_hardware_compare_mode_t hardwareCompareMode
Hardware compare selection.
-
uint32_t hardwareCompareValueHigh
Compare Value High. The available value range is in 16-bit.
-
uint32_t hardwareCompareValueLow
Compare Value Low. The available value range is in 16-bit.
-
lpadc_conversion_resolution_mode_t conversionResolutionMode
Conversion resolution mode.
-
bool enableWaitTrigger
Wait for trigger assertion before execution: when disabled, this command will be automatically executed; when enabled, the active trigger must be asserted again before executing this command.
-
lpadc_sample_scale_mode_t sampleScaleMode
-
struct lpadc_conv_trigger_config_t
- #include <fsl_lpadc.h>
Define structure to keep the configuration for conversion trigger.
Public Members
-
uint32_t targetCommandId
Select the command from command buffer to execute upon detect of the associated trigger event.
-
uint32_t delayPower
Select the trigger delay duration to wait at the start of servicing a trigger event. When this field is clear, then no delay is incurred. When this field is set to a non-zero value, the duration for the delay is 2^delayPower ADCK cycles. The available value range is 4-bit.
-
uint32_t priority
Sets the priority of the associated trigger source. If two or more triggers have the same priority level setting, the lower order trigger event has the higher priority. The lower value for this field is for the higher priority, the available value range is 1-bit.
-
bool enableHardwareTrigger
Enable hardware trigger source to initiate conversion on the rising edge of the input trigger source or not. THe software trigger is always available.
-
uint32_t targetCommandId
-
struct lpadc_conv_result_t
- #include <fsl_lpadc.h>
Define the structure to keep the conversion result.
Public Members
-
uint32_t commandIdSource
Indicate the command buffer being executed that generated this result.
-
uint32_t loopCountIndex
Indicate the loop count value during command execution that generated this result.
-
uint32_t triggerIdSource
Indicate the trigger source that initiated a conversion and generated this result.
-
uint16_t convValue
Data result.
-
uint32_t commandIdSource
-
struct _lpadc_calibration_value
- #include <fsl_lpadc.h>
A structure of calibration value.
Lpc_freqme
-
void FREQME_Init(FREQME_Type *base, const freq_measure_config_t *config)
Initialize freqme module, set operate mode, operate mode attribute and initialize measurement cycle.
- Parameters:
base – FREQME peripheral base address.
config – The pointer to module basic configuration, please refer to freq_measure_config_t.
-
void FREQME_GetDefaultConfig(freq_measure_config_t *config)
Get default configuration.
config->operateMode = kFREQME_FreqMeasurementMode; config->operateModeAttribute.refClkScaleFactor = 0U; config->enableContinuousMode = false; config->startMeasurement = false;
- Parameters:
config – The pointer to module basic configuration, please refer to freq_measure_config_t.
-
static inline void FREQME_StartMeasurementCycle(FREQME_Type *base)
Start frequency or pulse width measurement process.
- Parameters:
base – FREQME peripheral base address.
-
static inline void FREQME_TerminateMeasurementCycle(FREQME_Type *base)
Force the termination of any measurement cycle currently in progress and resets RESULT or just reset RESULT if the module in idle state.
- Parameters:
base – FREQME peripheral base address.
-
static inline void FREQME_EnableContinuousMode(FREQME_Type *base, bool enable)
Enable/disable Continuous mode.
- Parameters:
base – FREQME peripheral base address.
enable – Used to enable/disable continuous mode,
true Enable Continuous mode.
false Disable Continuous mode.
-
static inline bool FREQME_CheckContinuousMode(FREQME_Type *base)
Check whether continuous mode is enabled.
- Parameters:
base – FREQME peripheral base address.
- Return values:
True – Continuous mode is enabled, the measurement is performed continuously.
False – Continuous mode is disabled.
-
static inline void FREQME_SetOperateMode(FREQME_Type *base, freqme_operate_mode_t operateMode)
Set operate mode of freqme module.
- Parameters:
base – FREQME peripheral base address.
operateMode – The operate mode to be set, please refer to freqme_operate_mode_t.
-
static inline bool FREQME_CheckOperateMode(FREQME_Type *base)
Check module’s operate mode.
- Parameters:
base – FREQME peripheral base address.
- Return values:
True – Pulse width measurement mode.
False – Frequency measurement mode.
-
static inline void FREQME_SetMinExpectedValue(FREQME_Type *base, uint32_t minValue)
Set the minimum expected value for the measurement result.
- Parameters:
base – FREQME peripheral base address.
minValue – The minimum value to set, please note that this value is 31 bits width.
-
static inline void FREQME_SetMaxExpectedValue(FREQME_Type *base, uint32_t maxValue)
Set the maximum expected value for the measurement result.
- Parameters:
base – FREQME peripheral base address.
maxValue – The maximum value to set, please note that this value is 31 bits width.
-
uint32_t FREQME_CalculateTargetClkFreq(FREQME_Type *base, uint32_t refClkFrequency)
Calculate the frequency of selected target clock。
Note
The formula: Ftarget = (RESULT - 2) * Freference / 2 ^ REF_SCALE.
Note
This function only useful when the operate mode is selected as frequency measurement mode.
- Parameters:
base – FREQME peripheral base address.
refClkFrequency – The frequency of reference clock.
- Returns:
The frequency of target clock the unit is Hz, if the output result is 0, please check the module’s operate mode.
-
static inline uint8_t FREQME_GetReferenceClkScaleValue(FREQME_Type *base)
Get reference clock scaling factor.
- Parameters:
base – FREQME peripheral base address.
- Returns:
Reference clock scaling factor, the reference count cycle is 2 ^ ref_scale.
-
static inline void FREQME_SetPulsePolarity(FREQME_Type *base, freqme_pulse_polarity_t pulsePolarity)
Set pulse polarity when operate mode is selected as Pulse Width Measurement mode.
- Parameters:
base – FREQME peripheral base address.
pulsePolarity – The pulse polarity to be set, please refer to freqme_pulse_polarity_t.
-
static inline bool FREQME_CheckPulsePolarity(FREQME_Type *base)
Check pulse polarity when the operate mode is selected as pulse width measurement mode.
- Parameters:
base – FREQME peripheral base address.
- Return values:
True – Low period.
False – High period.
-
static inline uint32_t FREQME_GetMeasurementResult(FREQME_Type *base)
Get measurement result, if operate mode is selected as pulse width measurement mode this function can be used to calculate pulse width.
Note
Pulse width = counter result / Frequency of target clock.
- Parameters:
base – FREQME peripheral base address.
- Returns:
Measurement result.
-
static inline uint32_t FREQME_GetInterruptStatusFlags(FREQME_Type *base)
Get interrupt status flags, such as overflow interrupt status flag, underflow interrupt status flag, and so on.
- Parameters:
base – FREQME peripheral base address.
- Returns:
Current interrupt status flags, should be the OR’ed value of _freqme_interrupt_status_flags.
-
static inline void FREQME_ClearInterruptStatusFlags(FREQME_Type *base, uint32_t statusFlags)
Clear interrupt status flags.
- Parameters:
base – FREQME peripheral base address.
statusFlags – The combination of interrupt status flags to clear, should be the OR’ed value of _freqme_interrupt_status_flags.
-
static inline void FREQME_EnableInterrupts(FREQME_Type *base, uint32_t masks)
Enable interrupts, such as result ready interrupt, overflow interrupt and so on.
- Parameters:
base – FREQME peripheral base address.
masks – The mask of interrupts to enable, should be the OR’ed value of _freqme_interrupt_enable.
-
static inline void FREQME_DisableInterrupts(FREQME_Type *base, uint32_t masks)
Disable interrupts, such as result ready interrupt, overflow interrupt and so on.
- Parameters:
base – FREQME peripheral base address.
masks – The mask of interrupts to disable, should be the OR’ed value of _freqme_interrupt_enable.
-
FSL_FREQME_DRIVER_VERSION
FREQME driver version 2.1.2.
-
enum _freqme_interrupt_status_flags
The enumeration of interrupt status flags. .
Values:
-
enumerator kFREQME_UnderflowInterruptStatusFlag
Indicate the measurement is just done and the result is less than minimun value.
-
enumerator kFREQME_OverflowInterruptStatusFlag
Indicate the measurement is just done and the result is greater than maximum value.
-
enumerator kFREQME_ReadyInterruptStatusFlag
Indicate the measurement is just done and the result is ready to read.
-
enumerator kFREQME_AllInterruptStatusFlags
All interrupt status flags.
-
enumerator kFREQME_UnderflowInterruptStatusFlag
-
enum _freqme_interrupt_enable
The enumeration of interrupts, including underflow interrupt, overflow interrupt, and result ready interrupt. .
Values:
-
enumerator kFREQME_UnderflowInterruptEnable
Enable interrupt when the result is less than minimum value.
-
enumerator kFREQME_OverflowInterruptEnable
Enable interrupt when the result is greater than maximum value.
-
enumerator kFREQME_ReadyInterruptEnable
Enable interrupt when a measurement completes and the result is ready.
-
enumerator kFREQME_UnderflowInterruptEnable
-
enum _freqme_operate_mode
FREQME module operate mode enumeration, including frequency measurement mode and pulse width measurement mode.
Values:
-
enumerator kFREQME_FreqMeasurementMode
The module works in the frequency measurement mode.
-
enumerator kFREOME_PulseWidthMeasurementMode
The module works in the pulse width measurement mode.
-
enumerator kFREQME_FreqMeasurementMode
-
enum _freqme_pulse_polarity
The enumeration of pulse polarity.
Values:
-
enumerator kFREQME_PulseHighPeriod
Select high period of the reference clock.
-
enumerator kFREQME_PulseLowPeriod
Select low period of the reference clock.
-
enumerator kFREQME_PulseHighPeriod
-
typedef enum _freqme_operate_mode freqme_operate_mode_t
FREQME module operate mode enumeration, including frequency measurement mode and pulse width measurement mode.
-
typedef enum _freqme_pulse_polarity freqme_pulse_polarity_t
The enumeration of pulse polarity.
-
typedef union _freqme_mode_attribute freqme_mode_attribute_t
The union of operate mode attribute.
Note
If the operate mode is selected as frequency measurement mode the member refClkScaleFactor should be used, if the operate mode is selected as pulse width measurement mode the member pulsePolarity should be used.
-
typedef struct _freq_measure_config freq_measure_config_t
The structure of freqme module basic configuration, including operate mode, operate mode attribute and so on.
-
union _freqme_mode_attribute
- #include <fsl_freqme.h>
The union of operate mode attribute.
Note
If the operate mode is selected as frequency measurement mode the member refClkScaleFactor should be used, if the operate mode is selected as pulse width measurement mode the member pulsePolarity should be used.
Public Members
-
uint8_t refClkScaleFactor
Only useful in frequency measurement operate mode, used to set the reference clock counter scaling factor.
-
freqme_pulse_polarity_t pulsePolarity
Only Useful in pulse width measurement operate mode, used to set period polarity.
-
uint8_t refClkScaleFactor
-
struct _freq_measure_config
- #include <fsl_freqme.h>
The structure of freqme module basic configuration, including operate mode, operate mode attribute and so on.
Public Members
-
freqme_operate_mode_t operateMode
Select operate mode, please refer to freqme_operate_mode_t.
-
freqme_mode_attribute_t operateModeAttribute
Used to set the attribute of the selected operate mode, if the operate mode is selected as kFREQME_FreqMeasurementMode set freqme_mode_attribute_t::refClkScaleFactor, if operate mode is selected as kFREOME_PulseWidthMeasurementMode, please set freqme_mode_attribute_t::pulsePolarity.
-
bool enableContinuousMode
Enable/disable continuous mode, if continuous mode is enable, the measurement is performed continuously and the result for the last completed measurement is available in the result register.
-
freqme_operate_mode_t operateMode
GPIO: General Purpose I/O
-
void GPIO_PortInit(GPIO_Type *base, uint32_t port)
Initializes the GPIO peripheral.
This function ungates the GPIO clock.
- Parameters:
base – GPIO peripheral base pointer.
port – GPIO port number.
-
void GPIO_PinInit(GPIO_Type *base, uint32_t port, uint32_t pin, const gpio_pin_config_t *config)
Initializes a GPIO pin used by the board.
To initialize the GPIO, define a pin configuration, either input or output, in the user file. Then, call the GPIO_PinInit() function.
This is an example to define an input pin or 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(Typically GPIO)
port – GPIO port number
pin – GPIO pin number
config – GPIO pin configuration pointer
-
static inline void GPIO_PinWrite(GPIO_Type *base, uint32_t port, uint32_t pin, uint8_t output)
Sets the output level of the one GPIO pin to the logic 1 or 0.
- Parameters:
base – GPIO peripheral base pointer(Typically GPIO)
port – GPIO port number
pin – GPIO pin number
output – GPIO pin output logic level.
0: corresponding pin output low-logic level.
1: corresponding pin output high-logic level.
-
static inline uint32_t GPIO_PinRead(GPIO_Type *base, uint32_t port, uint32_t pin)
Reads the current input value of the GPIO PIN.
- Parameters:
base – GPIO peripheral base pointer(Typically GPIO)
port – GPIO port number
pin – GPIO pin number
- Return values:
GPIO – port input value
0: corresponding pin input low-logic level.
1: corresponding pin input high-logic level.
-
FSL_GPIO_DRIVER_VERSION
LPC GPIO driver version.
-
FSL_GPIO_DRIVER_VERSION
LPC GPIO driver version.
-
enum _gpio_pin_direction
LPC GPIO direction definition.
Values:
-
enumerator kGPIO_DigitalInput
Set current pin as digital input
-
enumerator kGPIO_DigitalOutput
Set current pin as digital output
-
enumerator kGPIO_DigitalInput
-
enum _gpio_pin_direction
LPC GPIO direction definition.
Values:
-
enumerator kGPIO_DigitalInput
Set current pin as digital input
-
enumerator kGPIO_DigitalOutput
Set current pin as digital output
-
enumerator kGPIO_DigitalInput
-
enum _gpio_interrupt_mode
GPIO interrupt mode definition.
Values:
-
enumerator kGPIO_IntDisabled
Set current pin general IO functionality.
-
enumerator kGPIO_IntLowLevel
Set current pin interrupt is low-level sensitive.
-
enumerator kGPIO_IntHighLevel
Set current pin interrupt is high-level sensitive.
-
enumerator kGPIO_IntRisingEdge
Set current pin interrupt is rising-edge sensitive.
-
enumerator kGPIO_IntFallingEdge
Set current pin interrupt is falling-edge sensitive.
-
enumerator kGPIO_IntRisingOrFallingEdge
Enable the edge select bit to override the ICR register’s configuration.
-
enumerator kGPIO_IntDisabled
-
typedef enum _gpio_pin_direction gpio_pin_direction_t
LPC GPIO direction definition.
-
typedef struct _gpio_pin_config gpio_pin_config_t
The GPIO pin configuration structure.
Every pin can only be configured as either output pin or input pin at a time. If configured as a input pin, then leave the outputConfig unused.
-
typedef enum _gpio_pin_direction gpio_pin_direction_t
LPC GPIO direction definition.
-
typedef enum _gpio_interrupt_mode gpio_interrupt_mode_t
GPIO interrupt mode definition.
-
typedef struct _gpio_pin_config gpio_pin_config_t
The GPIO pin configuration structure.
Every pin can only be configured as either output pin or input pin at a time. If configured as a input pin, then leave the outputConfig unused.
-
static inline void GPIO_PortSet(GPIO_Type *base, uint32_t port, uint32_t mask)
Sets the output level of the multiple GPIO pins to the logic 1.
- Parameters:
base – GPIO peripheral base pointer(Typically GPIO)
port – GPIO port number
mask – GPIO pin number macro
-
static inline void GPIO_PortClear(GPIO_Type *base, uint32_t port, uint32_t mask)
Sets the output level of the multiple GPIO pins to the logic 0.
- Parameters:
base – GPIO peripheral base pointer(Typically GPIO)
port – GPIO port number
mask – GPIO pin number macro
-
static inline void GPIO_PortToggle(GPIO_Type *base, uint32_t port, uint32_t mask)
Reverses current output logic of the multiple GPIO pins.
- Parameters:
base – GPIO peripheral base pointer(Typically GPIO)
port – GPIO port number
mask – GPIO pin number macro
-
void GPIO_PinInit(GPIO_Type *base, uint32_t pin, const gpio_pin_config_t *Config)
Initializes a GPIO pin used by the board.
To initialize the GPIO, define a pin configuration, either input or output, in the user file. Then, call the GPIO_PinInit() function.
This is an example to define an input pin or 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(Typically GPIO)
pin – GPIO pin number
Config – GPIO pin configuration pointer
-
void GPIO_PinSetInterruptConfig(GPIO_Type *base, uint32_t pin, gpio_interrupt_mode_t pinInterruptMode)
Initializes the GPIO peripheral.
This function ungates the GPIO clock.
- Parameters:
base – GPIO peripheral base pointer.
pin – GPIO pin number
pinInterruptMode – GPIO interrupt mode
-
struct _gpio_pin_config
- #include <fsl_gpio.h>
The GPIO pin configuration structure.
Every pin can only be configured as either output pin or input pin at a time. If configured as a input pin, then leave the outputConfig unused.
Public Members
-
gpio_pin_direction_t pinDirection
GPIO direction, input or output
-
uint8_t outputLogic
Set default output logic, no use in input
Set a default output logic, which has no use in input
-
gpio_pin_direction_t direction
Specifies the pin direction.
-
gpio_pin_direction_t pinDirection
GPIO: General Purpose I/O
IOCON: I/O pin configuration
-
FSL_IOCON_DRIVER_VERSION
IOCON driver version.
-
typedef struct _iocon_group iocon_group_t
Array of IOCON pin definitions passed to IOCON_SetPinMuxing() must be in this format.
- __STATIC_INLINE void IOCON_PinMuxSet (IOCON_Type *base, uint8_t port, uint8_t pin, uint32_t modefunc)
Sets I/O Control pin mux.
- Parameters:
base – : The base of IOCON peripheral on the chip
port – : GPIO port to mux
pin – : GPIO pin to mux
modefunc – : OR’ed values of type IOCON_*
- Returns:
Nothing
- __STATIC_INLINE void IOCON_SetPinMuxing (IOCON_Type *base, const iocon_group_t *pinArray, uint32_t arrayLength)
Set all I/O Control pin muxing.
- Parameters:
base – : The base of IOCON peripheral on the chip
pinArray – : Pointer to array of pin mux selections
arrayLength – : Number of entries in pinArray
- Returns:
Nothing
-
FSL_COMPONENT_ID
-
IOCON_FUNC0
IOCON function and mode selection definitions.
Note
See the User Manual for specific modes and functions supported by the various pins. Selects pin function 0
-
IOCON_FUNC1
Selects pin function 1
-
IOCON_FUNC2
Selects pin function 2
-
IOCON_FUNC3
Selects pin function 3
-
IOCON_FUNC4
Selects pin function 4
-
IOCON_FUNC5
Selects pin function 5
-
IOCON_FUNC6
Selects pin function 6
-
IOCON_FUNC7
Selects pin function 7
-
struct _iocon_group
- #include <fsl_iocon.h>
Array of IOCON pin definitions passed to IOCON_SetPinMuxing() must be in this format.
MCAN: Controller Area Network Driver
-
void MCAN_Init(CAN_Type *base, const mcan_config_t *config, uint32_t sourceClock_Hz)
Initializes an MCAN instance.
This function initializes the MCAN module with user-defined settings. This example shows how to set up the mcan_config_t parameters and how to call the MCAN_Init function by passing in these parameters.
mcan_config_t config; config->baudRateA = 500000U; config->baudRateD = 1000000U; config->enableCanfdNormal = false; config->enableCanfdSwitch = false; config->enableLoopBackInt = false; config->enableLoopBackExt = false; config->enableBusMon = false; MCAN_Init(CANFD0, &config, 8000000UL);
- Parameters:
base – MCAN peripheral base address.
config – Pointer to the user-defined configuration structure.
sourceClock_Hz – MCAN Protocol Engine clock source frequency in Hz.
-
void MCAN_Deinit(CAN_Type *base)
Deinitializes an MCAN instance.
This function deinitializes the MCAN module.
- Parameters:
base – MCAN peripheral base address.
-
void MCAN_GetDefaultConfig(mcan_config_t *config)
Gets the default configuration structure.
This function initializes the MCAN configuration structure to default values. The default values are as follows. config->baudRateA = 500000U; config->baudRateD = 1000000U; config->enableCanfdNormal = false; config->enableCanfdSwitch = false; config->enableLoopBackInt = false; config->enableLoopBackExt = false; config->enableBusMon = false;
- Parameters:
config – Pointer to the MCAN configuration structure.
-
static inline void MCAN_EnterInitialMode(CAN_Type *base)
MCAN enters initialization mode.
After enter initialization mode, users can write access to the protected configuration registers.
- Parameters:
base – MCAN peripheral base address.
-
static inline void MCAN_EnterNormalMode(CAN_Type *base)
MCAN enters normal mode.
After initialization, INIT bit in CCCR register must be cleared to enter normal mode thus synchronizes to the CAN bus and ready for communication.
- Parameters:
base – MCAN peripheral base address.
-
static inline void MCAN_SetMsgRAMBase(CAN_Type *base, uint32_t value)
Sets the MCAN Message RAM base address.
This function sets the Message RAM base address.
- Parameters:
base – MCAN peripheral base address.
value – Desired Message RAM base.
-
static inline uint32_t MCAN_GetMsgRAMBase(CAN_Type *base)
Gets the MCAN Message RAM base address.
This function gets the Message RAM base address.
- Parameters:
base – MCAN peripheral base address.
- Returns:
Message RAM base address.
-
bool MCAN_CalculateImprovedTimingValues(uint32_t baudRate, uint32_t sourceClock_Hz, mcan_timing_config_t *pconfig)
Calculates the improved timing values by specific baudrates for classical CAN.
- Parameters:
baudRate – The classical CAN speed in bps defined by user
sourceClock_Hz – The Source clock data speed in bps. Zero to disable baudrate switching
pconfig – Pointer to the MCAN timing configuration structure.
- Returns:
TRUE if timing configuration found, FALSE if failed to find configuration
-
bool MCAN_CalculateSpecifiedTimingValues(uint32_t sourceClock_Hz, mcan_timing_config_t *pconfig, const mcan_timing_param_t *pParamConfig)
Calculates the specified timing values for classical CAN with user-defined settings.
User can specify baudrates, sample point position, bus length, and transceiver propagation delay. This example shows how to set up the mcan_timing_param_t parameters and how to call the this function by passing in these parameters.
mcan_timing_config_t timing_config; mcan_timing_param_t timing_param; timing_param.busLength = 1U; timing_param.propTxRx = 230U; timing_param.nominalbaudRate = 500000U; timing_param.nominalSP = 800U; MCAN_CalculateSpecifiedTimingValues(MCAN_CLK_FREQ, &timing_config, &timing_param);
Note that due to integer division will sacrifice the precision, actual sample point may not equal to expected. If actual sample point is not in allowed 2% range, this function will return false. So it is better to select higher source clock when baudrate is relatively high. This will ensure more time quanta and higher precision of sample point. Parameter busLength and propTxRx are optional and intended to verify whether propagation delay is too long to corrupt sample point. User can set these parameter zero if you do not want to consider this factor.
- Parameters:
sourceClock_Hz – The Source clock data speed in bps.
pconfig – Pointer to the MCAN timing configuration structure.
config – Pointer to the MCAN timing parameters structure.
- Returns:
TRUE if timing configuration found, FALSE if failed to find configuration
-
void MCAN_SetArbitrationTimingConfig(CAN_Type *base, const mcan_timing_config_t *config)
Sets the MCAN protocol arbitration phase timing characteristic.
This function gives user settings to CAN bus timing characteristic. The function is for an experienced user. For less experienced users, call the MCAN_Init() and fill the baud rate field with a desired value. This provides the default arbitration phase timing characteristics.
Note that calling MCAN_SetArbitrationTimingConfig() overrides the baud rate set in MCAN_Init().
- Parameters:
base – MCAN peripheral base address.
config – Pointer to the timing configuration structure.
-
status_t MCAN_SetBaudRate(CAN_Type *base, uint32_t sourceClock_Hz, uint32_t baudRate_Bps)
Set Baud Rate of MCAN classic mode.
This function set the baud rate of MCAN base on MCAN_CalculateImprovedTimingValues() API calculated timing values.
- Parameters:
base – MCAN peripheral base address.
sourceClock_Hz – Source Clock in Hz.
baudRate_Bps – Baud Rate in Bps.
- Returns:
kStatus_Success - Set CAN baud rate (only has Nominal phase) successfully.
-
bool MCAN_FDCalculateImprovedTimingValues(uint32_t baudRate, uint32_t baudRateFD, uint32_t sourceClock_Hz, mcan_timing_config_t *pconfig)
Calculates the improved timing values by specific baudrates for CANFD.
- Parameters:
baudRate – The CANFD bus control speed in bps defined by user
baudRateFD – The CANFD bus data speed in bps defined by user
sourceClock_Hz – The Source clock data speed in bps.
pconfig – Pointer to the MCAN timing configuration structure.
- Returns:
TRUE if timing configuration found, FALSE if failed to find configuration
-
bool MCAN_FDCalculateSpecifiedTimingValues(uint32_t sourceClock_Hz, mcan_timing_config_t *pconfig, const mcan_timing_param_t *pParamConfig)
Calculates the specified timing values for CANFD with user-defined settings.
User can specify baudrates, sample point position, bus length, and transceiver propagation delay. This example shows how to set up the mcan_timing_param_t parameters and how to call the this function by passing in these parameters.
mcan_timing_config_t timing_config; mcan_timing_param_t timing_param; timing_param.busLength = 1U; timing_param.propTxRx = 230U; timing_param.nominalbaudRate = 500000U; timing_param.nominalSP = 800U; timing_param.databaudRate = 4000000U; timing_param.dataSP = 700U; MCAN_FDCalculateSpecifiedTimingValues(MCAN_CLK_FREQ, &timing_config, &timing_param);
Note that due to integer division will sacrifice the precision, actual sample point may not equal to expected. So it is better to select higher source clock when baudrate is relatively high. Select higher nominal baudrate when source clock is relatively high because large clock predivider will lead to less time quanta in data phase. This function will set predivider in arbitration phase equal to data phase. These methods will ensure more time quanta and higher precision of sample point. Parameter busLength and propTxRx are optional and intended to verify whether propagation delay is too long to corrupt sample point. User can set these parameter zero if you do not want to consider this factor.
- Parameters:
sourceClock_Hz – The Source clock data speed in bps.
pconfig – Pointer to the MCAN timing configuration structure.
config – Pointer to the MCAN timing parameters structure.
- Returns:
TRUE if timing configuration found, FALSE if failed to find configuration
-
status_t MCAN_SetBaudRateFD(CAN_Type *base, uint32_t sourceClock_Hz, uint32_t baudRateN_Bps, uint32_t baudRateD_Bps)
Set Baud Rate of MCAN FD mode.
This function set the baud rate of MCAN FD base on MCAN_FDCalculateImprovedTimingValues API calculated timing values.
- Parameters:
base – MCAN peripheral base address.
sourceClock_Hz – Source Clock in Hz.
baudRateN_Bps – Nominal Baud Rate in Bps.
baudRateD_Bps – Data Baud Rate in Bps.
- Returns:
kStatus_Success - Set CAN FD baud rate (include Nominal and Data phase) successfully.
-
void MCAN_SetDataTimingConfig(CAN_Type *base, const mcan_timing_config_t *config)
Sets the MCAN protocol data phase timing characteristic.
This function gives user settings to CAN bus timing characteristic. The function is for an experienced user. For less experienced users, call the MCAN_Init() and fill the baud rate field with a desired value. This provides the default data phase timing characteristics.
Note that calling MCAN_SetArbitrationTimingConfig() overrides the baud rate set in MCAN_Init().
- Parameters:
base – MCAN peripheral base address.
config – Pointer to the timing configuration structure.
-
void MCAN_SetRxFifo0Config(CAN_Type *base, const mcan_rx_fifo_config_t *config)
Configures an MCAN receive fifo 0 buffer.
This function sets start address, element size, watermark, operation mode and datafield size of the recieve fifo 0.
- Parameters:
base – MCAN peripheral base address.
config – The receive fifo 0 configuration structure.
-
void MCAN_SetRxFifo1Config(CAN_Type *base, const mcan_rx_fifo_config_t *config)
Configures an MCAN receive fifo 1 buffer.
This function sets start address, element size, watermark, operation mode and datafield size of the recieve fifo 1.
- Parameters:
base – MCAN peripheral base address.
config – The receive fifo 1 configuration structure.
-
void MCAN_SetRxBufferConfig(CAN_Type *base, const mcan_rx_buffer_config_t *config)
Configures an MCAN receive buffer.
This function sets start address and datafield size of the recieve buffer.
- Parameters:
base – MCAN peripheral base address.
config – The receive buffer configuration structure.
-
void MCAN_SetTxEventFifoConfig(CAN_Type *base, const mcan_tx_fifo_config_t *config)
Configures an MCAN transmit event fifo.
This function sets start address, element size, watermark of the transmit event fifo.
- Parameters:
base – MCAN peripheral base address.
config – The transmit event fifo configuration structure.
-
void MCAN_SetTxBufferConfig(CAN_Type *base, const mcan_tx_buffer_config_t *config)
Configures an MCAN transmit buffer.
This function sets start address, element size, fifo/queue mode and datafield size of the transmit buffer.
- Parameters:
base – MCAN peripheral base address.
config – The transmit buffer configuration structure.
-
void MCAN_SetFilterConfig(CAN_Type *base, const mcan_frame_filter_config_t *config)
Set filter configuration.
This function sets remote and non masking frames in global filter configuration, also the start address, list size in standard/extended ID filter configuration.
- Parameters:
base – MCAN peripheral base address.
config – The MCAN filter configuration.
-
status_t MCAN_SetMessageRamConfig(CAN_Type *base, const mcan_memory_config_t *config)
Set Message RAM related configuration.
Note
This function include Standard/extended ID filter, Rx FIFO 0/1, Rx buffer, Tx event FIFO and Tx buffer configurations
- Parameters:
base – MCAN peripheral base address.
config – The MCAN filter configuration.
- Return values:
kStatus_Success – - Message RAM related configuration Successfully.
kStatus_Fail – - Message RAM related configure fail due to wrong address parameter.
-
void MCAN_SetSTDFilterElement(CAN_Type *base, const mcan_frame_filter_config_t *config, const mcan_std_filter_element_config_t *filter, uint8_t idx)
Set standard message ID filter element configuration.
- Parameters:
base – MCAN peripheral base address.
config – The MCAN filter configuration.
filter – The MCAN standard message ID filter element configuration.
idx – The standard message ID filter element index.
-
void MCAN_SetEXTFilterElement(CAN_Type *base, const mcan_frame_filter_config_t *config, const mcan_ext_filter_element_config_t *filter, uint8_t idx)
Set extended message ID filter element configuration.
- Parameters:
base – MCAN peripheral base address.
config – The MCAN filter configuration.
filter – The MCAN extended message ID filter element configuration.
idx – The extended message ID filter element index.
-
static inline uint32_t MCAN_GetStatusFlag(CAN_Type *base, uint32_t mask)
Gets the MCAN module interrupt flags.
This function gets all MCAN interrupt status flags.
- Parameters:
base – MCAN peripheral base address.
mask – The ORed MCAN interrupt mask.
- Returns:
MCAN status flags which are ORed.
-
static inline void MCAN_ClearStatusFlag(CAN_Type *base, uint32_t mask)
Clears the MCAN module interrupt flags.
This function clears MCAN interrupt status flags.
- Parameters:
base – MCAN peripheral base address.
mask – The ORed MCAN interrupt mask.
-
static inline bool MCAN_GetRxBufferStatusFlag(CAN_Type *base, uint8_t idx)
Gets the new data flag of specific Rx Buffer.
This function gets new data flag of specific Rx Buffer.
- Parameters:
base – MCAN peripheral base address.
idx – Rx Buffer index.
- Returns:
Rx Buffer new data status flag.
-
static inline void MCAN_ClearRxBufferStatusFlag(CAN_Type *base, uint8_t idx)
Clears the new data flag of specific Rx Buffer.
This function clears new data flag of specific Rx Buffer.
- Parameters:
base – MCAN peripheral base address.
idx – Rx Buffer index.
-
static inline void MCAN_EnableInterrupts(CAN_Type *base, uint32_t line, uint32_t mask)
Enables MCAN interrupts according to the provided interrupt line and mask.
This function enables the MCAN interrupts according to the provided interrupt line and mask. The mask is a logical OR of enumeration members.
- Parameters:
base – MCAN peripheral base address.
line – Interrupt line number, 0 or 1.
mask – The interrupts to enable.
-
static inline void MCAN_EnableTransmitBufferInterrupts(CAN_Type *base, uint8_t idx)
Enables MCAN Tx Buffer interrupts according to the provided index.
This function enables the MCAN Tx Buffer interrupts.
- Parameters:
base – MCAN peripheral base address.
idx – Tx Buffer index.
-
static inline void MCAN_DisableTransmitBufferInterrupts(CAN_Type *base, uint8_t idx)
Disables MCAN Tx Buffer interrupts according to the provided index.
This function disables the MCAN Tx Buffer interrupts.
- Parameters:
base – MCAN peripheral base address.
idx – Tx Buffer index.
-
static inline void MCAN_DisableInterrupts(CAN_Type *base, uint32_t mask)
Disables MCAN interrupts according to the provided mask.
This function disables the MCAN interrupts according to the provided mask. The mask is a logical OR of enumeration members.
- Parameters:
base – MCAN peripheral base address.
mask – The interrupts to disable.
-
uint32_t MCAN_IsTransmitRequestPending(CAN_Type *base, uint8_t idx)
Gets the Tx buffer request pending status.
This function returns Tx Message Buffer transmission request pending status.
- Parameters:
base – MCAN peripheral base address.
idx – The MCAN Tx Buffer index.
-
uint32_t MCAN_IsTransmitOccurred(CAN_Type *base, uint8_t idx)
Gets the Tx buffer transmission occurred status.
This function returns Tx Message Buffer transmission occurred status.
- Parameters:
base – MCAN peripheral base address.
idx – The MCAN Tx Buffer index.
-
status_t MCAN_WriteTxBuffer(CAN_Type *base, uint8_t idx, const mcan_tx_buffer_frame_t *pTxFrame)
Writes an MCAN Message to the Transmit Buffer.
This function writes a CAN Message to the specified Transmit Message Buffer and changes the Message Buffer state to start CAN Message transmit. After that the function returns immediately.
- Parameters:
base – MCAN peripheral base address.
idx – The MCAN Tx Buffer index.
pTxFrame – Pointer to CAN message frame to be sent.
-
status_t MCAN_ReadRxBuffer(CAN_Type *base, uint8_t idx, mcan_rx_buffer_frame_t *pRxFrame)
Reads an MCAN Message from Rx Buffer.
This function reads a CAN message from the Rx Buffer in the Message RAM.
- Parameters:
base – MCAN peripheral base address.
idx – The MCAN Rx Buffer index.
pRxFrame – Pointer to CAN message frame structure for reception.
- Return values:
kStatus_Success – - Read Message from Rx Buffer successfully.
-
status_t MCAN_ReadRxFifo(CAN_Type *base, uint8_t fifoBlock, mcan_rx_buffer_frame_t *pRxFrame)
Reads an MCAN Message from Rx FIFO.
This function reads a CAN message from the Rx FIFO in the Message RAM.
- Parameters:
base – MCAN peripheral base address.
fifoBlock – Rx FIFO block 0 or 1.
pRxFrame – Pointer to CAN message frame structure for reception.
- Return values:
kStatus_Success – - Read Message from Rx FIFO successfully.
-
static inline void MCAN_TransmitAddRequest(CAN_Type *base, uint8_t idx)
Tx Buffer add request to send message out.
This function add sending request to corresponding Tx Buffer.
- Parameters:
base – MCAN peripheral base address.
idx – Tx Buffer index.
-
static inline void MCAN_TransmitCancelRequest(CAN_Type *base, uint8_t idx)
Tx Buffer cancel sending request.
This function clears Tx buffer request pending bit.
- Parameters:
base – MCAN peripheral base address.
idx – Tx Buffer index.
-
status_t MCAN_TransferSendBlocking(CAN_Type *base, uint8_t idx, mcan_tx_buffer_frame_t *pTxFrame)
Performs a polling send transaction on the CAN bus.
Note that a transfer handle does not need to be created before calling this API.
- Parameters:
base – MCAN peripheral base pointer.
idx – The MCAN buffer index.
pTxFrame – Pointer to CAN message frame to be sent.
- Return values:
kStatus_Success – - Write Tx Message Buffer Successfully.
kStatus_Fail – - Tx Message Buffer is currently in use.
-
status_t MCAN_TransferReceiveBlocking(CAN_Type *base, uint8_t idx, mcan_rx_buffer_frame_t *pRxFrame)
Performs a polling receive transaction on the CAN bus.
Note that a transfer handle does not need to be created before calling this API.
- Parameters:
base – MCAN peripheral base pointer.
idx – The MCAN buffer index.
pRxFrame – Pointer to CAN message frame structure for reception.
- Return values:
kStatus_Success – - Read Rx Message Buffer Successfully.
kStatus_Fail – - No new message.
-
status_t MCAN_TransferReceiveFifoBlocking(CAN_Type *base, uint8_t fifoBlock, mcan_rx_buffer_frame_t *pRxFrame)
Performs a polling receive transaction from Rx FIFO on the CAN bus.
Note that a transfer handle does not need to be created before calling this API.
- Parameters:
base – MCAN peripheral base pointer.
fifoBlock – Rx FIFO block, 0 or 1.
pRxFrame – Pointer to CAN message frame structure for reception.
- Return values:
kStatus_Success – - Read Message from Rx FIFO successfully.
kStatus_Fail – - No new message in Rx FIFO.
-
void MCAN_TransferCreateHandle(CAN_Type *base, mcan_handle_t *handle, mcan_transfer_callback_t callback, void *userData)
Initializes the MCAN handle.
This function initializes the MCAN handle, which can be used for other MCAN transactional APIs. Usually, for a specified MCAN instance, call this API once to get the initialized handle.
- Parameters:
base – MCAN peripheral base address.
handle – MCAN handle pointer.
callback – The callback function.
userData – The parameter of the callback function.
-
status_t MCAN_TransferSendNonBlocking(CAN_Type *base, mcan_handle_t *handle, mcan_buffer_transfer_t *xfer)
Sends a message using IRQ.
This function sends a message using IRQ. This is a non-blocking function, which returns right away. When messages have been sent out, the send callback function is called.
- Parameters:
base – MCAN peripheral base address.
handle – MCAN handle pointer.
xfer – MCAN Buffer transfer structure. See the mcan_buffer_transfer_t.
- Return values:
kStatus_Success – Start Tx Buffer sending process successfully.
kStatus_Fail – Write Tx Buffer failed.
kStatus_MCAN_TxBusy – Tx Buffer is in use.
-
status_t MCAN_TransferReceiveFifoNonBlocking(CAN_Type *base, uint8_t fifoBlock, mcan_handle_t *handle, mcan_fifo_transfer_t *xfer)
Receives a message from Rx FIFO using IRQ.
This function receives a message using IRQ. This is a non-blocking function, which returns right away. When all messages have been received, the receive callback function is called.
- Parameters:
base – MCAN peripheral base address.
handle – MCAN handle pointer.
fifoBlock – Rx FIFO block, 0 or 1.
xfer – MCAN Rx FIFO transfer structure. See the mcan_fifo_transfer_t.
- Return values:
kStatus_Success – - Start Rx FIFO receiving process successfully.
kStatus_MCAN_RxFifo0Busy – - Rx FIFO 0 is currently in use.
kStatus_MCAN_RxFifo1Busy – - Rx FIFO 1 is currently in use.
-
void MCAN_TransferAbortSend(CAN_Type *base, mcan_handle_t *handle, uint8_t bufferIdx)
Aborts the interrupt driven message send process.
This function aborts the interrupt driven message send process.
- Parameters:
base – MCAN peripheral base address.
handle – MCAN handle pointer.
bufferIdx – The MCAN Buffer index.
-
void MCAN_TransferAbortReceiveFifo(CAN_Type *base, uint8_t fifoBlock, mcan_handle_t *handle)
Aborts the interrupt driven message receive from Rx FIFO process.
This function aborts the interrupt driven message receive from Rx FIFO process.
- Parameters:
base – MCAN peripheral base address.
fifoBlock – MCAN Fifo block, 0 or 1.
handle – MCAN handle pointer.
-
void MCAN_TransferHandleIRQ(CAN_Type *base, mcan_handle_t *handle)
MCAN IRQ handle function.
This function handles the MCAN Error, the Buffer, and the Rx FIFO IRQ request.
- Parameters:
base – MCAN peripheral base address.
handle – MCAN handle pointer.
-
FSL_MCAN_DRIVER_VERSION
MCAN driver version.
MCAN transfer status.
Values:
-
enumerator kStatus_MCAN_TxBusy
Tx Buffer is Busy.
-
enumerator kStatus_MCAN_TxIdle
Tx Buffer is Idle.
-
enumerator kStatus_MCAN_RxBusy
Rx Buffer is Busy.
-
enumerator kStatus_MCAN_RxIdle
Rx Buffer is Idle.
-
enumerator kStatus_MCAN_RxFifo0New
New message written to Rx FIFO 0.
-
enumerator kStatus_MCAN_RxFifo0Idle
Rx FIFO 0 is Idle.
-
enumerator kStatus_MCAN_RxFifo0Watermark
Rx FIFO 0 fill level reached watermark.
-
enumerator kStatus_MCAN_RxFifo0Full
Rx FIFO 0 full.
-
enumerator kStatus_MCAN_RxFifo0Lost
Rx FIFO 0 message lost.
-
enumerator kStatus_MCAN_RxFifo1New
New message written to Rx FIFO 1.
-
enumerator kStatus_MCAN_RxFifo1Idle
Rx FIFO 1 is Idle.
-
enumerator kStatus_MCAN_RxFifo1Watermark
Rx FIFO 1 fill level reached watermark.
-
enumerator kStatus_MCAN_RxFifo1Full
Rx FIFO 1 full.
-
enumerator kStatus_MCAN_RxFifo1Lost
Rx FIFO 1 message lost.
-
enumerator kStatus_MCAN_RxFifo0Busy
Rx FIFO 0 is busy.
-
enumerator kStatus_MCAN_RxFifo1Busy
Rx FIFO 1 is busy.
-
enumerator kStatus_MCAN_ErrorStatus
MCAN Module Error and Status.
-
enumerator kStatus_MCAN_UnHandled
UnHadled Interrupt asserted.
-
enumerator kStatus_MCAN_TxBusy
-
enum _mcan_flags
MCAN status flags.
This provides constants for the MCAN status flags for use in the MCAN functions. Note: The CPU read action clears MCAN_ErrorFlag, therefore user need to read MCAN_ErrorFlag and distinguish which error is occur using _mcan_error_flags enumerations.
Values:
-
enumerator kMCAN_AccesstoRsvdFlag
CAN Synchronization Status.
-
enumerator kMCAN_ProtocolErrDIntFlag
Tx Warning Interrupt Flag.
-
enumerator kMCAN_ProtocolErrAIntFlag
Rx Warning Interrupt Flag.
-
enumerator kMCAN_BusOffIntFlag
Tx Error Warning Status.
-
enumerator kMCAN_ErrorWarningIntFlag
Rx Error Warning Status.
-
enumerator kMCAN_ErrorPassiveIntFlag
Rx Error Warning Status.
-
enumerator kMCAN_AccesstoRsvdFlag
-
enum _mcan_rx_fifo_flags
MCAN Rx FIFO status flags.
The MCAN Rx FIFO Status enumerations are used to determine the status of the Rx FIFO.
Values:
-
enumerator kMCAN_RxFifo0NewFlag
Rx FIFO 0 new message flag.
-
enumerator kMCAN_RxFifo0WatermarkFlag
Rx FIFO 0 watermark reached flag.
-
enumerator kMCAN_RxFifo0FullFlag
Rx FIFO 0 full flag.
-
enumerator kMCAN_RxFifo0LostFlag
Rx FIFO 0 message lost flag.
-
enumerator kMCAN_RxFifo1NewFlag
Rx FIFO 0 new message flag.
-
enumerator kMCAN_RxFifo1WatermarkFlag
Rx FIFO 0 watermark reached flag.
-
enumerator kMCAN_RxFifo1FullFlag
Rx FIFO 0 full flag.
-
enumerator kMCAN_RxFifo1LostFlag
Rx FIFO 0 message lost flag.
-
enumerator kMCAN_RxFifo0NewFlag
-
enum _mcan_tx_flags
MCAN Tx status flags.
The MCAN Tx Status enumerations are used to determine the status of the Tx Buffer/Event FIFO.
Values:
-
enumerator kMCAN_TxTransmitCompleteFlag
Transmission completed flag.
-
enumerator kMCAN_TxTransmitCancelFinishFlag
Transmission cancellation finished flag.
-
enumerator kMCAN_TxEventFifoLostFlag
Tx Event FIFO element lost.
-
enumerator kMCAN_TxEventFifoFullFlag
Tx Event FIFO full.
-
enumerator kMCAN_TxEventFifoWatermarkFlag
Tx Event FIFO fill level reached watermark.
-
enumerator kMCAN_TxEventFifoNewFlag
Tx Handler wrote Tx Event FIFO element flag.
-
enumerator kMCAN_TxEventFifoEmptyFlag
Tx FIFO empty flag.
-
enumerator kMCAN_TxTransmitCompleteFlag
-
enum _mcan_interrupt_enable
MCAN interrupt configuration structure, default settings all disabled.
This structure contains the settings for all of the MCAN Module interrupt configurations.
Values:
-
enumerator kMCAN_BusOffInterruptEnable
Bus Off interrupt.
-
enumerator kMCAN_ErrorInterruptEnable
Error interrupt.
-
enumerator kMCAN_WarningInterruptEnable
Rx Warning interrupt.
-
enumerator kMCAN_BusOffInterruptEnable
-
enum _mcan_frame_idformat
MCAN frame format.
Values:
-
enumerator kMCAN_FrameIDStandard
Standard frame format attribute.
-
enumerator kMCAN_FrameIDExtend
Extend frame format attribute.
-
enumerator kMCAN_FrameIDStandard
-
enum _mcan_frame_type
MCAN frame type.
Values:
-
enumerator kMCAN_FrameTypeData
Data frame type attribute.
-
enumerator kMCAN_FrameTypeRemote
Remote frame type attribute.
-
enumerator kMCAN_FrameTypeData
-
enum _mcan_bytes_in_datafield
MCAN frame datafield size.
Values:
-
enumerator kMCAN_8ByteDatafield
8 byte data field.
-
enumerator kMCAN_12ByteDatafield
12 byte data field.
-
enumerator kMCAN_16ByteDatafield
16 byte data field.
-
enumerator kMCAN_20ByteDatafield
20 byte data field.
-
enumerator kMCAN_24ByteDatafield
24 byte data field.
-
enumerator kMCAN_32ByteDatafield
32 byte data field.
-
enumerator kMCAN_48ByteDatafield
48 byte data field.
-
enumerator kMCAN_64ByteDatafield
64 byte data field.
-
enumerator kMCAN_8ByteDatafield
-
enum _mcan_fifo_type
MCAN Rx FIFO block number.
Values:
-
enumerator kMCAN_Fifo0
CAN Rx FIFO 0.
-
enumerator kMCAN_Fifo1
CAN Rx FIFO 1.
-
enumerator kMCAN_Fifo0
-
enum _mcan_fifo_opmode_config
MCAN FIFO Operation Mode.
Values:
-
enumerator kMCAN_FifoBlocking
FIFO blocking mode.
-
enumerator kMCAN_FifoOverwrite
FIFO overwrite mode.
-
enumerator kMCAN_FifoBlocking
-
enum _mcan_txmode_config
MCAN Tx FIFO/Queue Mode.
Values:
-
enumerator kMCAN_txFifo
Tx FIFO operation.
-
enumerator kMCAN_txQueue
Tx Queue operation.
-
enumerator kMCAN_txFifo
-
enum _mcan_remote_frame_config
MCAN remote frames treatment.
Values:
-
enumerator kMCAN_filterFrame
Filter remote frames.
-
enumerator kMCAN_rejectFrame
Reject all remote frames.
-
enumerator kMCAN_filterFrame
-
enum _mcan_nonmasking_frame_config
MCAN non-masking frames treatment.
Values:
-
enumerator kMCAN_acceptinFifo0
Accept non-masking frames in Rx FIFO 0.
-
enumerator kMCAN_acceptinFifo1
Accept non-masking frames in Rx FIFO 1.
-
enumerator kMCAN_reject0
Reject non-masking frames.
-
enumerator kMCAN_reject1
Reject non-masking frames.
-
enumerator kMCAN_acceptinFifo0
-
enum _mcan_fec_config
MCAN Filter Element Configuration.
Values:
-
enumerator kMCAN_disable
Disable filter element.
-
enumerator kMCAN_storeinFifo0
Store in Rx FIFO 0 if filter matches.
-
enumerator kMCAN_storeinFifo1
Store in Rx FIFO 1 if filter matches.
-
enumerator kMCAN_reject
Reject ID if filter matches.
-
enumerator kMCAN_setprio
Set priority if filter matches.
-
enumerator kMCAN_setpriofifo0
Set priority and store in FIFO 0 if filter matches.
-
enumerator kMCAN_setpriofifo1
Set priority and store in FIFO 1 if filter matches.
-
enumerator kMCAN_storeinbuffer
Store into Rx Buffer or as debug message.
-
enumerator kMCAN_disable
-
enum _mcan_std_filter_type
MCAN Filter Type.
Values:
-
enumerator kMCAN_range
Range filter from SFID1 to SFID2.
-
enumerator kMCAN_dual
Dual ID filter for SFID1 or SFID2.
-
enumerator kMCAN_classic
Classic filter: SFID1 = filter, SFID2 = mask.
-
enumerator kMCAN_disableORrange2
Filter element disabled for standard filter or Range filter, XIDAM mask not applied for extended filter.
-
enumerator kMCAN_range
-
typedef enum _mcan_frame_idformat mcan_frame_idformat_t
MCAN frame format.
-
typedef enum _mcan_frame_type mcan_frame_type_t
MCAN frame type.
-
typedef enum _mcan_bytes_in_datafield mcan_bytes_in_datafield_t
MCAN frame datafield size.
-
typedef struct _mcan_tx_buffer_frame mcan_tx_buffer_frame_t
MCAN Tx Buffer structure.
-
typedef struct _mcan_rx_buffer_frame mcan_rx_buffer_frame_t
MCAN Rx FIFO/Buffer structure.
-
typedef enum _mcan_fifo_type mcan_fifo_type_t
MCAN Rx FIFO block number.
-
typedef enum _mcan_fifo_opmode_config mcan_fifo_opmode_config_t
MCAN FIFO Operation Mode.
-
typedef enum _mcan_txmode_config mcan_txmode_config_t
MCAN Tx FIFO/Queue Mode.
-
typedef enum _mcan_remote_frame_config mcan_remote_frame_config_t
MCAN remote frames treatment.
-
typedef enum _mcan_nonmasking_frame_config mcan_nonmasking_frame_config_t
MCAN non-masking frames treatment.
-
typedef enum _mcan_fec_config mcan_fec_config_t
MCAN Filter Element Configuration.
-
typedef struct _mcan_rx_fifo_config mcan_rx_fifo_config_t
MCAN Rx FIFO configuration.
-
typedef struct _mcan_rx_buffer_config mcan_rx_buffer_config_t
MCAN Rx Buffer configuration.
-
typedef struct _mcan_tx_fifo_config mcan_tx_fifo_config_t
MCAN Tx Event FIFO configuration.
-
typedef struct _mcan_tx_buffer_config mcan_tx_buffer_config_t
MCAN Tx Buffer configuration.
-
typedef enum _mcan_std_filter_type mcan_filter_type_t
MCAN Filter Type.
-
typedef struct _mcan_std_filter_element_config mcan_std_filter_element_config_t
MCAN Standard Message ID Filter Element.
-
typedef struct _mcan_ext_filter_element_config mcan_ext_filter_element_config_t
MCAN Extended Message ID Filter Element.
-
typedef struct _mcan_frame_filter_config mcan_frame_filter_config_t
MCAN Rx filter configuration.
-
typedef struct _mcan_timing_config mcan_timing_config_t
MCAN protocol timing characteristic configuration structure.
-
typedef struct _mcan_timing_param mcan_timing_param_t
MCAN bit timing parameter configuration structure.
-
typedef struct _mcan_memory_config mcan_memory_config_t
MCAN Message RAM related configuration structure.
-
typedef struct _mcan_config mcan_config_t
MCAN module configuration structure.
-
typedef struct _mcan_buffer_transfer mcan_buffer_transfer_t
MCAN Buffer transfer.
-
typedef struct _mcan_fifo_transfer mcan_fifo_transfer_t
MCAN Rx FIFO transfer.
-
typedef struct _mcan_handle mcan_handle_t
MCAN handle structure definition.
-
typedef void (*mcan_transfer_callback_t)(CAN_Type *base, mcan_handle_t *handle, status_t status, uint32_t result, void *userData)
MCAN transfer callback function.
The MCAN transfer callback returns a value from the underlying layer. If the status equals to kStatus_MCAN_ErrorStatus, the result parameter is the Content of MCAN status register which can be used to get the working status(or error status) of MCAN module. If the status equals to other MCAN Message Buffer transfer status, the result is the index of Message Buffer that generate transfer event. If the status equals to other MCAN Message Buffer transfer status, the result is meaningless and should be Ignored.
-
MCAN_RETRY_TIMES
-
struct _mcan_tx_buffer_frame
- #include <fsl_mcan.h>
MCAN Tx Buffer structure.
Public Members
-
uint8_t size
classical CAN is 8(bytes), FD is 12/64 such.
-
uint8_t size
-
struct _mcan_rx_buffer_frame
- #include <fsl_mcan.h>
MCAN Rx FIFO/Buffer structure.
Public Members
-
uint8_t size
classical CAN is 8(bytes), FD is 12/64 such.
-
uint8_t size
-
struct _mcan_rx_fifo_config
- #include <fsl_mcan.h>
MCAN Rx FIFO configuration.
Public Members
-
uint32_t address
FIFOn start address.
-
uint32_t elementSize
FIFOn element number.
-
uint32_t watermark
FIFOn watermark level.
-
mcan_fifo_opmode_config_t opmode
FIFOn blocking/overwrite mode.
-
mcan_bytes_in_datafield_t datafieldSize
Data field size per frame, size>8 is for CANFD.
-
uint32_t address
-
struct _mcan_rx_buffer_config
- #include <fsl_mcan.h>
MCAN Rx Buffer configuration.
Public Members
-
uint32_t address
Rx Buffer start address.
-
mcan_bytes_in_datafield_t datafieldSize
Data field size per frame, size>8 is for CANFD.
-
uint32_t address
-
struct _mcan_tx_fifo_config
- #include <fsl_mcan.h>
MCAN Tx Event FIFO configuration.
Public Members
-
uint32_t address
Event fifo start address.
-
uint32_t elementSize
FIFOn element number.
-
uint32_t watermark
FIFOn watermark level.
-
uint32_t address
-
struct _mcan_tx_buffer_config
- #include <fsl_mcan.h>
MCAN Tx Buffer configuration.
Public Members
-
uint32_t address
Tx Buffers Start Address.
-
uint32_t dedicatedSize
Number of Dedicated Transmit Buffers.
-
uint32_t fqSize
Transmit FIFO/Queue Size.
-
mcan_txmode_config_t mode
Tx FIFO/Queue Mode.
-
mcan_bytes_in_datafield_t datafieldSize
Data field size per frame, size>8 is for CANFD.
-
uint32_t address
-
struct _mcan_std_filter_element_config
- #include <fsl_mcan.h>
MCAN Standard Message ID Filter Element.
Public Members
-
uint32_t sfid2
Standard Filter ID 2.
-
uint32_t __pad0__
Reserved.
-
uint32_t sfid1
Standard Filter ID 1.
-
uint32_t sfec
Standard Filter Element Configuration.
-
uint32_t sft
Standard Filter Type.
-
uint32_t sfid2
-
struct _mcan_ext_filter_element_config
- #include <fsl_mcan.h>
MCAN Extended Message ID Filter Element.
Public Members
-
uint32_t efid1
Extended Filter ID 1.
-
uint32_t efec
Extended Filter Element Configuration.
-
uint32_t efid2
Extended Filter ID 2.
-
uint32_t __pad0__
Reserved.
-
uint32_t eft
Extended Filter Type.
-
uint32_t efid1
-
struct _mcan_frame_filter_config
- #include <fsl_mcan.h>
MCAN Rx filter configuration.
Public Members
-
uint32_t address
Filter start address.
-
uint32_t listSize
Filter list size.
-
mcan_frame_idformat_t idFormat
Frame format.
-
mcan_remote_frame_config_t remFrame
Remote frame treatment.
-
mcan_nonmasking_frame_config_t nmFrame
Non-masking frame treatment.
-
uint32_t address
-
struct _mcan_timing_config
- #include <fsl_mcan.h>
MCAN protocol timing characteristic configuration structure.
Public Members
-
uint16_t preDivider
Nominal Clock Pre-scaler Division Factor.
-
uint8_t rJumpwidth
Nominal Re-sync Jump Width.
-
uint8_t seg1
Nominal Time Segment 1.
-
uint8_t seg2
Nominal Time Segment 2.
-
uint16_t datapreDivider
Data Clock Pre-scaler Division Factor.
-
uint8_t datarJumpwidth
Data Re-sync Jump Width.
-
uint8_t dataseg1
Data Time Segment 1.
-
uint8_t dataseg2
Data Time Segment 2.
-
uint16_t preDivider
-
struct _mcan_timing_param
- #include <fsl_mcan.h>
MCAN bit timing parameter configuration structure.
Public Members
-
uint32_t busLength
Maximum Bus length in meter.
-
uint32_t propTxRx
Transceiver propagation delay in nanosecond.
-
uint32_t nominalbaudRate
Baud rate of Arbitration phase in bps.
-
uint32_t nominalSP
Sample point of Arbitration phase, range in 10 ~ 990, 800 means 80%.
-
uint32_t databaudRate
Baud rate of Data phase in bps.
-
uint32_t dataSP
Sample point of Data phase, range in 0 ~ 1000, 800 means 80%.
-
uint32_t busLength
-
struct _mcan_memory_config
- #include <fsl_mcan.h>
MCAN Message RAM related configuration structure.
Public Members
-
uint32_t baseAddr
Message RAM base address, should be 4k alignment.
-
uint32_t baseAddr
-
struct _mcan_config
- #include <fsl_mcan.h>
MCAN module configuration structure.
Public Members
-
uint32_t baudRateA
Baud rate of Arbitration phase in bps.
-
uint32_t baudRateD
Baud rate of Data phase in bps.
-
bool enableCanfdNormal
Enable or Disable CANFD normal.
-
bool enableCanfdSwitch
Enable or Disable CANFD with baudrate switch.
-
bool enableLoopBackInt
Enable or Disable Internal Back.
-
bool enableLoopBackExt
Enable or Disable External Loop Back.
-
bool enableBusMon
Enable or Disable Bus Monitoring Mode.
-
mcan_timing_config_t timingConfig
Protocol timing .
-
uint32_t baudRateA
-
struct _mcan_buffer_transfer
- #include <fsl_mcan.h>
MCAN Buffer transfer.
Public Members
-
mcan_tx_buffer_frame_t *frame
The buffer of CAN Message to be transfer.
-
uint8_t bufferIdx
The index of Message buffer used to transfer Message.
-
mcan_tx_buffer_frame_t *frame
-
struct _mcan_fifo_transfer
- #include <fsl_mcan.h>
MCAN Rx FIFO transfer.
Public Members
-
mcan_rx_buffer_frame_t *frame
The buffer of CAN Message to be received from Rx FIFO.
-
mcan_rx_buffer_frame_t *frame
-
struct _mcan_handle
- #include <fsl_mcan.h>
MCAN handle structure.
Public Members
-
mcan_transfer_callback_t callback
Callback function.
-
void *userData
MCAN callback function parameter.
-
mcan_tx_buffer_frame_t *volatile bufferFrameBuf[64]
The buffer for received data from Buffers.
-
mcan_rx_buffer_frame_t *volatile rxFifoFrameBuf
The buffer for received data from Rx FIFO.
-
volatile uint8_t bufferState[64]
Message Buffer transfer state.
-
volatile uint8_t rxFifoState
Rx FIFO transfer state.
-
mcan_transfer_callback_t callback
-
struct __unnamed63__
Public Members
-
uint32_t id
CAN Frame Identifier.
-
uint32_t rtr
CAN Frame Type(DATA or REMOTE).
-
uint32_t xtd
CAN Frame Type(STD or EXT).
-
uint32_t esi
CAN Frame Error State Indicator.
-
uint32_t id
-
struct __unnamed65__
Public Members
-
uint32_t dlc
Data Length Code 9 10 11 12 13 14 15 Number of data bytes 12 16 20 24 32 48 64
-
uint32_t brs
Bit Rate Switch.
-
uint32_t fdf
CAN FD format.
-
uint32_t __pad1__
Reserved.
-
uint32_t efc
Event FIFO control.
-
uint32_t mm
Message Marker.
-
uint32_t dlc
-
struct __unnamed67__
Public Members
-
uint32_t id
CAN Frame Identifier.
-
uint32_t rtr
CAN Frame Type(DATA or REMOTE).
-
uint32_t xtd
CAN Frame Type(STD or EXT).
-
uint32_t esi
CAN Frame Error State Indicator.
-
uint32_t id
-
struct __unnamed69__
Public Members
-
uint32_t rxts
Rx Timestamp.
-
uint32_t dlc
Data Length Code 9 10 11 12 13 14 15 Number of data bytes 12 16 20 24 32 48 64
-
uint32_t brs
Bit Rate Switch.
-
uint32_t fdf
CAN FD format.
-
uint32_t __pad0__
Reserved.
-
uint32_t fidx
Filter Index.
-
uint32_t anmf
Accepted Non-matching Frame.
-
uint32_t rxts
Memory_interface
Memory group definition.
Values:
-
enumerator kMemoryGroup_Internal
Memory belongs internal 4G memory region.
-
enumerator kMemoryGroup_External
Memory belongs external memory region.
-
enumerator kMemoryGroup_Internal
Memory device ID definition.
Values:
-
enumerator kMemoryInternal
Internal memory (include all on chip memory)
-
enumerator kMemoryQuadSpi0
Qsuad SPI memory 0
-
enumerator kMemoryIFR0
Nonvolatile information register 0. Only used by SB loader.
-
enumerator kMemoryFFR
LPCc040hd flash FFR region.
-
enumerator kMemorySemcNor
SEMC Nor memory
-
enumerator kMemoryFlexSpiNor
Flex SPI Nor memory
-
enumerator kMemorySpifiNor
SPIFI Nor memory
-
enumerator kMemoryFlashExecuteOnly
Execute-only region on internal Flash
-
enumerator kMemorySemcNand
SEMC NAND memory
-
enumerator kMemorySpiNand
SPI NAND memory
-
enumerator kMemorySpiNorEeprom
SPI NOR/EEPROM memory
-
enumerator kMemoryI2cNorEeprom
I2C NOR/EEPROM memory
-
enumerator kMemorySDCard
eSD, SD, SDHC, SDXC memory Card
-
enumerator kMemoryMMCCard
MMC, eMMC memory Card
-
enumerator kMemoryInternal
Bootloader status group numbers.
Values:
-
enumerator kStatusGroup_Bootloader
Bootloader status group number (100).
-
enumerator kStatusGroup_MemoryInterface
Memory interface status group number (102).
-
enumerator kStatusGroup_Bootloader
Memory interface status codes.
Values:
-
enumerator kStatusMemoryRangeInvalid
Status: Memory Range Invalid
-
enumerator kStatusMemoryReadFailed
Status: Memory Read Failed
-
enumerator kStatusMemoryWriteFailed
Status: Memory Write Failed
-
enumerator kStatusMemoryCumulativeWrite
Status: Memory Cumulative Write
-
enumerator kStatusMemoryAppOverlapWithExecuteOnlyRegion
Status: Memory AppOverlapWithExecuteOnlyRegion
-
enumerator kStatusMemoryNotConfigured
Status: Memory Not Configured
-
enumerator kStatusMemoryAlignmentError
Status: Memory Alignment Error
-
enumerator kStatusMemoryVerifyFailed
Status: Memory Verify Failed
-
enumerator kStatusMemoryWriteProtected
Status: Memory Write Protected
-
enumerator kStatusMemoryAddressError
Status: Memory Address Error
-
enumerator kStatusMemoryBlankCheckFailed
Status: Memory Blank Check Failed
-
enumerator kStatusMemoryBlankPageReadDisallowed
Status: Memory Blank Page Read Disallowed
-
enumerator kStatusMemoryProtectedPageReadDisallowed
Status: Memory Protected Page Read Disallowed
-
enumerator kStatusMemoryFfrSpecRegionWriteBroken
Status: Memory Ffr Spec Region Write Broken
-
enumerator kStatusMemoryUnsupportedCommand
Status: Memory Unsupported Command
-
enumerator kStatusMemoryRangeInvalid
Bootloader status codes.
Values:
-
enumerator kStatus_UnknownCommand
Status: Unknown Command
-
enumerator kStatus_SecurityViolation
Status: Security Violation
-
enumerator kStatus_AbortDataPhase
Status: Abort Data Phase
-
enumerator kStatus_Ping
Status: Ping
-
enumerator kStatus_NoResponse
Status: No Response
-
enumerator kStatus_NoResponseExpected
Status: No Response Expected
-
enumerator kStatus_CommandUnsupported
Status: Command Unsupported
-
enumerator kStatus_UnknownCommand
-
typedef union StandardVersion standard_version_t
Structure of version property.
-
typedef struct kb_api_parameter_struct kp_api_init_param_t
API initialization data structure.
-
standard_version_t API_Version(void)
-
status_t API_Init(api_core_context_t *coreCtx, const kp_api_init_param_t *param)
Initialize the IAP API runtime environment.
-
status_t API_Deinit(api_core_context_t *coreCtx)
Deinitialize the IAP API runtime environment.
-
status_t MEM_Init(api_core_context_t *coreCtx)
Initialize memory interface.
- Return values:
kStatus_Fail –
kStatus_Success –
-
status_t MEM_Config(api_core_context_t *coreCtx, uint32_t *config, uint32_t memoryId)
Configure memory interface.
- Parameters:
coreCtx – A pointer to the storage for the driver runtime state.
config – memory configure struct.
memoryId – Indicates the index of the memory type. Please refer to “Memory group definition”
- Return values:
kStatus_Success –
kStatus_CommandUnsupported –
kStatus_InvalidArgument –
kStatus_FLASH_ModifyProtectedAreaDisallowed –
kStatusMemoryRangeInvalid –
kStatus_Fail –
kStatus_OutOfRange –
-
status_t MEM_Write(api_core_context_t *coreCtx, uint32_t start, uint32_t lengthInBytes, const uint8_t *buf, uint32_t memoryId)
Write memory.
- Parameters:
coreCtx – A pointer to the storage for the driver runtime state.
start – The start address of the desired flash memory to be programmed. For internal flash the address need to be 512bytes-aligned.
lengthInBytes – Number of bytes to be programmed.
buf – A pointer to the source buffer of data that is to be programmed into the flash.
memoryId – Indicates the index of the memory type. Please refer to “Memory group definition”
- Return values:
kStatus_Success –
kStatus_Fail –
kStatusMemoryRangeInvalid –
kStatus_CommandUnsupported –
kStatus_FLASH_AlignmentError –
kStatusMemoryCumulativeWrite –
kStatus_FLASH_InvalidArgument –
kStatus_FLASH_AddressError –
kStatus_FLASH_ModifyProtectedAreaDisallowed –
kStatus_FLASH_CommandFailure –
kStatus_FLASH_CommandNotSupported –
kStatus_FLASH_EccError –
kStatus_FLASH_RegulationLoss –
kStatus_FLASH_Success –
kStatus_FLASH_ReadHidingAreaDisallowed –
kStatus_FLASH_CompareError –
kStatusMemoryNotConfigured –
kStatusMemoryVerifyFailed –
-
status_t MEM_Fill(api_core_context_t *coreCtx, uint32_t start, uint32_t lengthInBytes, uint32_t pattern, uint32_t memoryId)
Fill memory with a word pattern.
- Parameters:
coreCtx – A pointer to the storage for the driver runtime state.
start – The start address of the desired flash memory to be programmed. For internal flash the address need to be 512bytes-aligned.
lengthInBytes – Number of bytes to be programmed.
pattern – The data to be written into the specified memory area.
memoryId – Indicates the index of the memory type. Please refer to “Memory group definition”
- Return values:
kStatus_CommandUnsupported –
kStatus_Success –
kStatus_FLASH_AlignmentError –
kStatusMemoryCumulativeWrite –
kStatus_Fail –
kStatus_FLASH_InvalidArgument –
kStatus_FLASH_AddressError –
kStatus_FLASH_Success –
kStatus_FLASH_ModifyProtectedAreaDisallowed –
kStatus_FLASH_CommandFailure –
kStatus_FLASH_CommandNotSupported –
kStatus_FLASH_EccError –
kStatus_FLASH_RegulationLoss –
kStatus_FLASH_ReadHidingAreaDisallowed –
-
status_t MEM_Flush(api_core_context_t *coreCtx)
Flush memory.
- Return values:
kStatus_Success –
kStatus_Fail –
kStatusMemoryCumulativeWrite –
kStatus_FLASH_InvalidArgument –
kStatus_FLASH_AlignmentError –
kStatus_FLASH_Success –
kStatus_FLASH_AddressError –
kStatus_FLASH_ModifyProtectedAreaDisallowed –
kStatus_FLASH_CommandFailure –
kStatus_FLASH_CommandNotSupported –
kStatus_FLASH_EccError –
kStatus_FLASH_RegulationLoss –
kStatus_FLASH_ReadHidingAreaDisallowed –
kStatusMemoryVerifyFailed –
-
status_t MEM_Erase(api_core_context_t *coreCtx, uint32_t start, uint32_t lengthInBytes, uint32_t memoryId)
Erase memory.
- Parameters:
coreCtx – A pointer to the storage for the driver runtime state.
start – The start address of the desired flash memory to be erased.
lengthInBytes – Number of bytes to be read.
memoryId – Indicates the index of the memory type. Please refer to “Memory group definition”
- Return values:
kStatus_Success –
kStatusMemoryRangeInvalid –
kStatusMemoryAddressError –
kStatus_FLASH_InvalidArgument –
kStatus_FLASH_AlignmentError –
kStatus_FLASH_Success –
kStatus_FLASH_AddressError –
kStatus_FLASH_EraseKeyError –
kStatus_FLASH_ModifyProtectedAreaDisallowed –
kStatus_Fail –
kStatus_FLASH_CommandFailure –
kStatus_FLASH_CommandNotSupported –
kStatus_FLASH_EccError –
kStatus_FLASH_RegulationLoss –
kStatusMemoryNotConfigured –
kStatusMemoryVerifyFailed –
-
status_t MEM_EraseAll(api_core_context_t *coreCtx, uint32_t memoryId)
Erase entire memory based on memoryId.
- Parameters:
coreCtx – A pointer to the storage for the driver runtime state.
memoryId – Indicates the index of the memory type. Please refer to “Memory group definition”
- Return values:
kStatus_Success –
kStatus_Fail –
kStatus_CommandUnsupported –
kStatus_FLASH_InvalidArgument –
kStatus_FLASH_AlignmentError –
kStatus_FLASH_Success –
kStatus_FLASH_AddressError –
kStatus_FLASH_EraseKeyError –
kStatus_FLASH_CommandFailure –
kStatus_FLASH_CommandNotSupported –
kStatus_FLASH_EccError –
kStatus_FLASH_RegulationLoss –
kStatus_FLASH_ModifyProtectedAreaDisallowed –
kStatusMemoryVerifyFailed –
kStatusMemoryNotConfigured –
kStatus_InvalidArgument –
-
FSL_ROMAPI_MEM_INTERFACE_DRIVER_VERSION
ROMAPI_MEM_INTERFACE driver version 2.0.0.
-
DEVICE_ID_MASK
Bit mask for device ID.
-
DEVICE_ID_SHIFT
Bit position of device ID.
-
GROUP_ID_MASK
Bit mask for group ID.
-
GROUP_ID_SHIFT
Bit position of group ID.
-
MAKE_MEMORYID(group, device)
Construct a memory ID from a given group ID and device ID.
-
GROUPID(memoryId)
Get group ID from a given memory ID.
-
DEVICEID(memoryId)
Get device ID from a given memory ID.
-
status_t (*init)(void)
-
status_t (*read)(uint32_t address, uint32_t length, uint8_t *buffer, uint32_t memoryId)
-
status_t (*write)(uint32_t address, uint32_t length, const uint8_t *buffer, uint32_t memoryId)
-
status_t (*fill)(uint32_t address, uint32_t length, uint32_t pattern)
-
status_t (*flush)(void)
-
status_t (*finalize)(void)
-
status_t (*erase)(uint32_t address, uint32_t length, uint32_t memoryId)
-
status_t (*init)(void)
-
status_t (*read)(uint32_t address, uint32_t length, uint8_t *buffer)
-
status_t (*write)(uint32_t address, uint32_t length, const uint8_t *buffer)
-
status_t (*fill)(uint32_t address, uint32_t length, uint32_t pattern)
-
status_t (*flush)(void)
-
status_t (*erase)(uint32_t address, uint32_t length)
-
status_t (*config)(uint32_t *buffer)
-
status_t (*erase_all)(void)
-
uint32_t startAddress
-
uint32_t endAddress
-
uint32_t memoryProperty
-
uint32_t memoryId
-
const memory_region_interface_t *memoryInterface
-
uint8_t bugfix
bugfix version [7:0]
-
uint8_t minor
minor version [15:8]
-
uint8_t major
major version [23:16]
-
char name
name [31:24]
- struct StandardVersion
-
uint32_t version
combined version numbers
-
uint32_t allocStart
-
uint32_t allocSize
-
struct memory_interface_t
- #include <fsl_mem_interface.h>
Interface to memory operations.
This is the main abstract interface to all memory operations.
-
struct memory_region_interface_t
- #include <fsl_mem_interface.h>
Interface to memory operations for one region of memory.
-
struct memory_map_entry_t
- #include <fsl_mem_interface.h>
Structure of a memory map entry.
-
union StandardVersion
- #include <fsl_mem_interface.h>
Structure of version property.
-
struct kb_api_parameter_struct
- #include <fsl_mem_interface.h>
API initialization data structure.
-
struct __unnamed33__
Public Members
-
uint8_t bugfix
bugfix version [7:0]
-
uint8_t minor
minor version [15:8]
-
uint8_t major
major version [23:16]
-
char name
name [31:24]
-
uint8_t bugfix
MRT: Multi-Rate Timer
-
void MRT_Init(MRT_Type *base, const mrt_config_t *config)
Ungates the MRT clock and configures the peripheral for basic operation.
Note
This API should be called at the beginning of the application using the MRT driver.
- Parameters:
base – Multi-Rate timer peripheral base address
config – Pointer to user’s MRT config structure. If MRT has MULTITASK bit field in MODCFG reigster, param config is useless.
-
void MRT_Deinit(MRT_Type *base)
Gate the MRT clock.
- Parameters:
base – Multi-Rate timer peripheral base address
-
static inline void MRT_GetDefaultConfig(mrt_config_t *config)
Fill in the MRT config struct with the default settings.
The default values are:
config->enableMultiTask = false;
- Parameters:
config – Pointer to user’s MRT config structure.
-
static inline void MRT_SetupChannelMode(MRT_Type *base, mrt_chnl_t channel, const mrt_timer_mode_t mode)
Sets up an MRT channel mode.
- Parameters:
base – Multi-Rate timer peripheral base address
channel – Channel that is being configured.
mode – Timer mode to use for the channel.
-
static inline void MRT_EnableInterrupts(MRT_Type *base, mrt_chnl_t channel, uint32_t mask)
Enables the MRT interrupt.
- Parameters:
base – Multi-Rate timer peripheral base address
channel – Timer channel number
mask – The interrupts to enable. This is a logical OR of members of the enumeration mrt_interrupt_enable_t
-
static inline void MRT_DisableInterrupts(MRT_Type *base, mrt_chnl_t channel, uint32_t mask)
Disables the selected MRT interrupt.
- Parameters:
base – Multi-Rate timer peripheral base address
channel – Timer channel number
mask – The interrupts to disable. This is a logical OR of members of the enumeration mrt_interrupt_enable_t
-
static inline uint32_t MRT_GetEnabledInterrupts(MRT_Type *base, mrt_chnl_t channel)
Gets the enabled MRT interrupts.
- Parameters:
base – Multi-Rate timer peripheral base address
channel – Timer channel number
- Returns:
The enabled interrupts. This is the logical OR of members of the enumeration mrt_interrupt_enable_t
-
static inline uint32_t MRT_GetStatusFlags(MRT_Type *base, mrt_chnl_t channel)
Gets the MRT status flags.
- Parameters:
base – Multi-Rate timer peripheral base address
channel – Timer channel number
- Returns:
The status flags. This is the logical OR of members of the enumeration mrt_status_flags_t
-
static inline void MRT_ClearStatusFlags(MRT_Type *base, mrt_chnl_t channel, uint32_t mask)
Clears the MRT status flags.
- Parameters:
base – Multi-Rate timer peripheral base address
channel – Timer channel number
mask – The status flags to clear. This is a logical OR of members of the enumeration mrt_status_flags_t
-
void MRT_UpdateTimerPeriod(MRT_Type *base, mrt_chnl_t channel, uint32_t count, bool immediateLoad)
Used to update the timer period in units of count.
The new value will be immediately loaded or will be loaded at the end of the current time interval. For one-shot interrupt mode the new value will be immediately loaded.
Note
User can call the utility macros provided in fsl_common.h to convert to ticks
- Parameters:
base – Multi-Rate timer peripheral base address
channel – Timer channel number
count – Timer period in units of ticks
immediateLoad – true: Load the new value immediately into the TIMER register; false: Load the new value at the end of current timer interval
-
static inline uint32_t MRT_GetCurrentTimerCount(MRT_Type *base, mrt_chnl_t channel)
Reads the current timer counting value.
This function returns the real-time timer counting value, in a range from 0 to a timer period.
Note
User can call the utility macros provided in fsl_common.h to convert ticks to usec or msec
- Parameters:
base – Multi-Rate timer peripheral base address
channel – Timer channel number
- Returns:
Current timer counting value in ticks
-
static inline void MRT_StartTimer(MRT_Type *base, mrt_chnl_t channel, uint32_t count)
Starts the timer counting.
After calling this function, timers load period value, counts down to 0 and depending on the timer mode it will either load the respective start value again or stop.
Note
User can call the utility macros provided in fsl_common.h to convert to ticks
- Parameters:
base – Multi-Rate timer peripheral base address
channel – Timer channel number.
count – Timer period in units of ticks. Count can contain the LOAD bit, which control the force load feature.
-
static inline void MRT_StopTimer(MRT_Type *base, mrt_chnl_t channel)
Stops the timer counting.
This function stops the timer from counting.
- Parameters:
base – Multi-Rate timer peripheral base address
channel – Timer channel number.
-
static inline uint32_t MRT_GetIdleChannel(MRT_Type *base)
Find the available channel.
This function returns the lowest available channel number.
- Parameters:
base – Multi-Rate timer peripheral base address
-
static inline void MRT_ReleaseChannel(MRT_Type *base, mrt_chnl_t channel)
Release the channel when the timer is using the multi-task mode.
In multi-task mode, the INUSE flags allow more control over when MRT channels are released for further use. The user can hold on to a channel acquired by calling MRT_GetIdleChannel() for as long as it is needed and release it by calling this function. This removes the need to ask for an available channel for every use.
- Parameters:
base – Multi-Rate timer peripheral base address
channel – Timer channel number.
-
FSL_MRT_DRIVER_VERSION
-
enum _mrt_chnl
List of MRT channels.
Values:
-
enumerator kMRT_Channel_0
MRT channel number 0
-
enumerator kMRT_Channel_1
MRT channel number 1
-
enumerator kMRT_Channel_2
MRT channel number 2
-
enumerator kMRT_Channel_3
MRT channel number 3
-
enumerator kMRT_Channel_0
-
enum _mrt_timer_mode
List of MRT timer modes.
Values:
-
enumerator kMRT_RepeatMode
Repeat Interrupt mode
-
enumerator kMRT_OneShotMode
One-shot Interrupt mode
-
enumerator kMRT_OneShotStallMode
One-shot stall mode
-
enumerator kMRT_RepeatMode
-
enum _mrt_interrupt_enable
List of MRT interrupts.
Values:
-
enumerator kMRT_TimerInterruptEnable
Timer interrupt enable
-
enumerator kMRT_TimerInterruptEnable
-
enum _mrt_status_flags
List of MRT status flags.
Values:
-
enumerator kMRT_TimerInterruptFlag
Timer interrupt flag
-
enumerator kMRT_TimerRunFlag
Indicates state of the timer
-
enumerator kMRT_TimerInterruptFlag
-
typedef enum _mrt_chnl mrt_chnl_t
List of MRT channels.
-
typedef enum _mrt_timer_mode mrt_timer_mode_t
List of MRT timer modes.
-
typedef enum _mrt_interrupt_enable mrt_interrupt_enable_t
List of MRT interrupts.
-
typedef enum _mrt_status_flags mrt_status_flags_t
List of MRT status flags.
-
typedef struct _mrt_config mrt_config_t
MRT configuration structure.
This structure holds the configuration settings for the MRT peripheral. To initialize this structure to reasonable defaults, call the MRT_GetDefaultConfig() function and pass a pointer to your config structure instance.
The config struct can be made const so it resides in flash
-
struct _mrt_config
- #include <fsl_mrt.h>
MRT configuration structure.
This structure holds the configuration settings for the MRT peripheral. To initialize this structure to reasonable defaults, call the MRT_GetDefaultConfig() function and pass a pointer to your config structure instance.
The config struct can be made const so it resides in flash
Public Members
-
bool enableMultiTask
true: Timers run in multi-task mode; false: Timers run in hardware status mode
-
bool enableMultiTask
Nboot
nboot status codes.
Values:
-
enumerator kStatus_NBOOT_Success
Operation completed successfully.
-
enumerator kStatus_NBOOT_Fail
Operation failed.
-
enumerator kStatus_NBOOT_InvalidArgument
Invalid argument passed to the function.
-
enumerator kStatus_NBOOT_RequestTimeout
Operation timed out.
-
enumerator kStatus_NBOOT_KeyNotLoaded
The requested key is not loaded.
-
enumerator kStatus_NBOOT_AuthFail
Authentication failed.
-
enumerator kStatus_NBOOT_OperationNotAvaialable
Operation not available on this HW.
-
enumerator kStatus_NBOOT_KeyNotAvailable
Key is not avaialble.
-
enumerator kStatus_NBOOT_IvCounterOverflow
Overflow of IV counter (PRINCE/IPED).
-
enumerator kStatus_NBOOT_SelftestFail
FIPS self-test failure.
-
enumerator kStatus_NBOOT_InvalidDataFormat
Invalid data format for example antipole
-
enumerator kStatus_NBOOT_IskCertUserDataTooBig
Size of User data in ISK certificate is greater than 96 bytes
-
enumerator kStatus_NBOOT_IskCertSignatureOffsetTooSmall
Signature offset in ISK certificate is smaller than expected
-
enumerator kStatus_NBOOT_MemcpyFail
Unexpected error detected during nboot_memcpy()
-
enumerator kStatus_NBOOT_Success
-
enum _nboot_bool
Boolean type for the NBOOT functions.
This type defines boolean values used by NBOOT functions that are not easily disturbed by Fault Attacks
Values:
-
enumerator kNBOOT_TRUE
Value for TRUE.
-
enumerator kNBOOT_TRUE256
Value for TRUE when P256 was used to sign the image.
-
enumerator kNBOOT_TRUE384
Value for TRUE when P384 was used to sign the image.
-
enumerator kNBOOT_FALSE
Value for FALSE.
-
enumerator kNBOOT_OperationAllowed
-
enumerator kNBOOT_OperationDisallowed
-
enumerator kNBOOT_TRUE
-
typedef int romapi_status_t
-
typedef uint32_t nboot_root_key_usage_t
-
typedef uint32_t nboot_root_key_revocation_t
-
typedef uint32_t nboot_root_key_type_and_length_t
-
typedef uint32_t nboot_soc_lifecycle_t
-
typedef uint32_t nboot_status_t
Type for nboot status codes.
-
typedef uint64_t nboot_status_protected_t
Type for nboot protected status codes.
-
typedef struct _nboot_secure_counter nboot_secure_counter_t
Data structure holding secure counter value used by nboot library.
-
typedef struct _nboot_context nboot_context_t
NBOOT context type.
This type defines the NBOOT context
-
typedef struct _nboot_rot_auth_parms nboot_rot_auth_parms_t
NBOOT type for the root of trust parameters.
This type defines the NBOOT root of trust parameters
-
typedef struct _nboot_sb3_load_manifest_parms nboot_sb3_load_manifest_parms_t
manifest loading parameters
This type defines the NBOOT SB3.1 manifest loading parameters
-
typedef struct _nboot_img_auth_ecdsa_parms nboot_img_auth_ecdsa_parms_t
Data structure holding input arguments to POR secure boot (authentication) algorithm. Shall be read from SoC trusted NVM or SoC fuses.
-
typedef struct _nboot_cmac_authenticate_parms nboot_img_authenticate_cmac_parms_t
Data structure holding input arguments for CMAC authentication.
-
typedef enum _nboot_bool nboot_bool_t
Boolean type for the NBOOT functions.
This type defines boolean values used by NBOOT functions that are not easily disturbed by Fault Attacks
-
status_t NBOOT_GenerateRandom(uint8_t *output, size_t outputByteLen)
This API function is used to generate random number with specified length.
- Parameters:
output – Pointer to random number buffer
outputByteLen – length of generated random number in bytes. Length has to be in range <1, 2^16>
- Return values:
kStatus_NBOOT_InvalidArgument – Invalid input parameters (Input pointers points to NULL or length is invalid)
kStatus_NBOOT_Success – Operation successfully finished
kStatus_NBOOT_Fail – Error occured during operation
-
nboot_status_t NBOOT_ContextInit(nboot_context_t *context)
The function is used for initializing of the nboot context data structure. It should be called prior to any other calls of nboot API.
- Parameters:
context – Pointer to nboot_context_t structure.
- Return values:
kStatus_NBOOT_Success – Operation successfully finished
kStatus_NBOOT_Fail – Error occured during operation
-
nboot_status_t NBOOT_ContextDeinit(nboot_context_t *context)
The function is used to deinitialize nboot context data structure. Its contents are overwritten with random data so that any sensitive data does not remain in memory.
- Parameters:
context – Pointer to nboot_context_t structure.
- Return values:
kStatus_NBOOT_Success – Operation successfully finished
kStatus_NBOOT_Fail – Error occured during operation
-
nboot_status_protected_t NBOOT_Sb3LoadManifest(nboot_context_t *context, uint32_t *manifest, nboot_sb3_load_manifest_parms_t *params)
Verify NBOOT SB3.1 manifest (header message)
This function verifies the NBOOT SB3.1 manifest (header message), initializes the context and loads keys into the CSS key store so that they can be used by nboot_sb3_load_block function. The NBOOT context has to be initialized by the function nboot_context_init before calling this function. Please note that this API is intended to be used only by users who needs to split FW update process (loading of SB3.1 file) to partial steps to customize whole operation. For regular SB3.1 processing, please use API described in chapter SBloader APIs.
- Parameters:
context – Pointer to nboot_context_t structure.
manifest – Pointer to the input manifest buffer
params – additional input parameters. Please refer to nboot_sb3_load_manifest_parms_t definition for details.
- Return values:
kStatus_NBOOT_Success – Operation successfully finished
kStatus_NBOOT_Fail – Error occured during operation
-
nboot_status_protected_t NBOOT_Sb3LoadBlock(nboot_context_t *context, uint32_t *block)
Verify NBOOT SB3.1 block.
This function verifies and decrypts an NBOOT SB3.1 block. Decryption is performed in-place. The NBOOT context has to be initialized by the function nboot_context_init before calling this function. Please note that this API is intended to be used only by users who needs to split FW update process (loading of SB3.1 file) to partial steps to customize whole operation. For regular SB3.1 processing, please use API described in chapter SBloader APIs.
- Parameters:
context – Pointer to nboot_context_t structure.
block – Pointer to the input SB3.1 data block
- Return values:
kStatus_NBOOT_Success – successfully finished
kStatus_NBOOT_Fail – occured during operation
-
nboot_status_protected_t NBOOT_ImgAuthenticateEcdsa(nboot_context_t *context, uint8_t imageStartAddress[], nboot_bool_t *isSignatureVerified, nboot_img_auth_ecdsa_parms_t *parms)
This function authenticates image with asymmetric cryptography. The NBOOT context has to be initialized by the function nboot_context_init before calling this function.
- Parameters:
context – Pointer to nboot_context_t structure.
imageStartAddress – Pointer to start of the image in memory.
isSignatureVerified – Pointer to memory holding function call result. After the function returns, the value will be set to kNBOOT_TRUE when the image is authentic. Any other value means the authentication does not pass.
parms – Pointer to a data structure in trusted memory, holding input parameters for the algorithm. The data structure shall be correctly filled before the function call.
- Return values:
kStatus_NBOOT_Success – Operation successfully finished
kStatus_NBOOT_Fail – Returned in all other cases. Doesn’t always mean invalid image, it could also mean transient error caused by short time environmental conditions.
-
nboot_status_protected_t NBOOT_ImgAuthenticateCmac(nboot_context_t *context, uint8_t imageStartAddress[], nboot_bool_t *isSignatureVerified, nboot_img_authenticate_cmac_parms_t *parms)
This function calculates the CMAC over the given image and compares it to the expected value. To be more resistant against SPA, it is recommended that imageStartAddress is word aligned. The NBOOT context has to be initialized by the nboot_context_init() before calling this function.
- Parameters:
context – Pointer to nboot_context_t structure.
imageStartAddress – Pointer to start of the image in memory.
isSignatureVerified – Pointer to memory holding function call result. After the function returns, the value will be set to
parms – Pointer to a data structure in trusted memory, holding the reference MAC. The data structure shall be correctly filled before the function call.
- Return values:
kStatus_NBOOT_Success –
kStatus_NBOOT_Fail –
-
FSL_ROMAPI_NBOOT_DRIVER_VERSION
ROMAPI_NBOOT driver version 2.0.0.
-
NXPCLHASH_WA_SIZE_MAX
Define the max workarea size required for this component.
-
NBOOT_ROOT_CERT_COUNT
-
NXPCLCSS_HASH_RTF_OUTPUT_SIZE_HAL
Size of RTF appendix to hash output buffer, in bytes.
-
NBOOT_KEYINFO_WORDLEN
-
NBOOT_CONTEXT_BYTELEN
-
NBOOT_CONTEXT_WORDLEN
-
kNBOOT_RootKeyUsage_DebugCA_ImageCA_FwCA_ImageKey_FwKey
NBOOT type for the root key usage.
This type defines the NBOOT root key usage; any other value means the root key is not valid (treat as if revoked).
-
kNBOOT_RootKeyUsage_DebugCA
-
kNBOOT_RootKeyUsage_ImageCA_FwCA
-
kNBOOT_RootKeyUsage_DebugCA_ImageCA_FwCA
-
kNBOOT_RootKeyUsage_ImageKey_FwKey
-
kNBOOT_RootKeyUsage_ImageKey
-
kNBOOT_RootKeyUsage_FwKey
-
kNBOOT_RootKeyUsage_Unused
-
kNBOOT_RootKey_Enabled
NBOOT type for the root key revocation.
This type defines the NBOOT root key revocation; any other value means the root key is revoked.
-
kNBOOT_RootKey_Revoked
-
kNBOOT_RootKey_Ecdsa_P256
NBOOT type specifying the elliptic curve to be used.
This type defines the elliptic curve type and length
-
kNBOOT_RootKey_Ecdsa_P384
-
nboot_lc_nxpBlank
Enumeration for SoC Lifecycle.
-
nboot_lc_nxpFab
-
nboot_lc_nxpDev
-
nboot_lc_nxpProvisioned
-
nboot_lc_oemOpen
-
nboot_lc_oemSecureWorld
-
nboot_lc_oemClosed
-
nboot_lc_oemLocked
-
nboot_lc_oemFieldReturn
-
nboot_lc_nxpFieldReturn
-
nboot_lc_shredded
-
uint32_t sc
-
uint32_t scAp
-
uint32_t totalBlocks
holds number of SB3 blocks. Initialized by nboot_sb3_load_header().
-
uint32_t processData
flag, initialized by nboot_sb3_load_header(). SB3 related flag set by NBOOT in case the nboot_sb3_load_block() provides plain data to output buffer (for processing by ROM SB3 loader
-
uint32_t timeout
timeout value for css operation. In case it is 0, infinite wait is performed
-
uint32_t keyinfo[(23U)]
data for NBOOT key management.
-
uint32_t context[((192U + (128U + 64U)) / sizeof(uint32_t))]
work area for NBOOT lib.
-
uint32_t uuid[4]
holds UUID value from NMPA
-
uint32_t prngReadyFlag
flag, used by nboot_rng_generate_lq_random() to determine whether CSS is ready to generate rnd number
-
uint32_t multipartMacBuffer[1024 / sizeof(uint32_t)]
-
uint32_t oemShareValidFlag
flag, used during TP to determine whether valid oemShare was set by nboot_tp_isp_gen_oem_master_share()
-
uint32_t oemShare[4]
buffer to store OEM_SHARE computed by nxpCLTrustProv_nboot_isp_gen_oem_master_share()
-
nboot_secure_counter_t secureCounter
Secure counter used by nboot
-
uint32_t rtf[((size_t)32U) / sizeof(uint32_t)]
-
uint32_t imageHash[48 / sizeof(uint32_t)]
-
uint32_t authStatus
-
nboot_root_key_revocation_t soc_rootKeyRevocation[(4U)]
Provided by caller based on NVM information in CFPA: ROTKH_REVOKE
-
uint32_t soc_imageKeyRevocation
Provided by caller based on NVM information in CFPA: IMAGE_KEY_REVOKE
-
uint32_t soc_rkh[12]
Provided by caller based on NVM information in CMPA: ROTKH (hash of hashes) In case of kNBOOT_RootKey_Ecdsa_P384, sock_rkh[0..11] are used In case of kNBOOT_RootKey_Ecdsa_P256, sock_rkh[0..7] are used
-
uint32_t soc_numberOfRootKeys
unsigned int, between minimum = 1 and maximum = 4;
-
nboot_root_key_usage_t soc_rootKeyUsage[(4U)]
CMPA
-
nboot_root_key_type_and_length_t soc_rootKeyTypeAndLength
static selection between ECDSA P-256 or ECDSA P-384 based root keys
-
nboot_soc_lifecycle_t soc_lifecycle
-
nboot_rot_auth_parms_t soc_RoTNVM
trusted information originated from CFPA and NMPA
-
uint32_t soc_trustedFirmwareVersion
Provided by caller based on NVM information in CFPA: Secure_FW_Version
-
uint8_t pckBlob[48]
-
nboot_rot_auth_parms_t soc_RoTNVM
trusted information originated from CFPA and NMPA
-
uint32_t soc_trustedFirmwareVersion
Provided by caller based on NVM information in CFPA: Secure_FW_Version
-
uint32_t expectedMAC[4]
expected MAC result
-
struct _nboot_secure_counter
- #include <fsl_nboot.h>
Data structure holding secure counter value used by nboot library.
-
struct _nboot_context
- #include <fsl_nboot.h>
NBOOT context type.
This type defines the NBOOT context
-
struct _nboot_rot_auth_parms
- #include <fsl_nboot.h>
NBOOT type for the root of trust parameters.
This type defines the NBOOT root of trust parameters
-
struct _nboot_sb3_load_manifest_parms
- #include <fsl_nboot.h>
manifest loading parameters
This type defines the NBOOT SB3.1 manifest loading parameters
-
struct _nboot_img_auth_ecdsa_parms
- #include <fsl_nboot.h>
Data structure holding input arguments to POR secure boot (authentication) algorithm. Shall be read from SoC trusted NVM or SoC fuses.
-
struct _nboot_cmac_authenticate_parms
- #include <fsl_nboot.h>
Data structure holding input arguments for CMAC authentication.
Nbot_hal
-
enum _nboot_hash_algo_t
Algorithm used for nboot HASH operation.
Values:
-
enumerator kHASH_Sha1
SHA_1
-
enumerator kHASH_Sha256
SHA_256
-
enumerator kHASH_Sha512
SHA_512
-
enumerator kHASH_Aes
AES
-
enumerator kHASH_AesIcb
AES_ICB
-
enumerator kHASH_Sha1
-
typedef uint32_t nboot_timestamp_t[2]
NBOOT type for a timestamp.
This type defines the NBOOT timestamp
-
typedef struct _nboot_sb3_header nboot_sb3_header_t
NBOOT SB3.1 header type.
This type defines the header used in the SB3.1 manifest
-
typedef struct _nboot_certificate_header_block nboot_certificate_header_block_t
NBOOT type for the header of the certificate block.
This type defines the NBOOT header of the certificate block, it is part of the nboot_certificate_block_t
-
typedef uint8_t nboot_ctrk_hash_t[(48u)]
-
typedef struct _nboot_ctrk_hash_table nboot_ctrk_hash_table_t
NBOOT type for the hash table.
This type defines the NBOOT hash table
-
typedef uint8_t nboot_ecc_coordinate_t[(48u)]
NBOOT type for an ECC coordinate.
This type defines the NBOOT ECC coordinate type ECC point coordinate, up to 384-bits. big endian.
-
typedef struct _nboot_root_certificate_block nboot_root_certificate_block_t
NBOOT type for the root certificate block.
This type defines the NBOOT root certificate block, it is part of the nboot_certificate_block_t
-
typedef struct _nboot_certificate_block nboot_certificate_block_t
NBOOT type for the certificate block.
This type defines the constant length part of an NBOOT certificate block
-
typedef enum _nboot_hash_algo_t nboot_hash_algo_t
Algorithm used for nboot HASH operation.
-
NBOOT_UUID_SIZE_IN_WORD
The size of the UUID.
-
NBOOT_UUID_SIZE_IN_BYTE
-
NBOOT_PUF_AC_SIZE_IN_BYTE
The size of the PUF activation code.
-
NBOOT_PUF_KC_SIZE_IN_BYTE
The size of the PUF key code.
-
NBOOT_KEY_STORE_SIZE_IN_BYTE
The size of the key store.
-
NBOOT_ROOT_ROTKH_SIZE_IN_WORD
The size of the root of trust key table hash.
-
NBOOT_ROOT_ROTKH_SIZE_IN_BYTE
-
NBOOT_KEY_BLOB_SIZE_IN_BYTE_256
The size of the blob with Key Blob.
-
NBOOT_KEY_BLOB_SIZE_IN_BYTE_384
-
NBOOT_KEY_BLOB_SIZE_IN_BYTE_MAX
-
NBOOT_DBG_AUTH_DBG_STATE_MASK
The mask of the value of the debug state .
-
NBOOT_DBG_AUTH_DBG_STATE_SHIFT
The shift inverted value of the debug state.
-
NBOOT_DBG_AUTH_DBG_STATE_ALL_DISABLED
The value with all debug feature disabled.
-
NBOOT_ROOT_OF_TRUST_HASH_SIZE_IN_BYTES
-
NBOOT_EC_COORDINATE_384_SIZE_IN_BYTES
-
NBOOT_EC_COORDINATE_MAX_SIZE
-
NBOOT_SB3_CHUNK_SIZE_IN_BYTES
-
NBOOT_SB3_BLOCK_HASH256_SIZE_IN_BYTES
-
NBOOT_SB3_BLOCK_HASH384_SIZE_IN_BYTES
-
NBOOT_SB3_MANIFEST_MAX_SIZE_IN_BYTES
-
NBOOT_SB3_BLOCK_MAX_SIZE_IN_BYTES
-
NBOOT_DICE_CSR_SIZE_IN_WORD
The size of the DICE certificate.
-
NBOOT_DICE_CSR_SIZE_IN_BYTES
-
NBOOT_DICE_CSR_ADDRESS
The physical address to put the DICE certificate.
-
NBOOT_IPED_IV_OFFSET
The offset for the PRCINE/IPED erase region return by nboot mem checker.
-
NBOOT_IMAGE_CMAC_UPDATE_NONE
-
NBOOT_IMAGE_CMAC_UPDATE_INDEX0
-
NBOOT_IMAGE_CMAC_UPDATE_INDEX1
-
NBOOT_IMAGE_CMAC_UPDATE_BOTH
-
NBOOT_IMAGE_CMAC_UPDATE_MASK
-
NBOOT_CMPA_CMAC_UPDATE_MASK
-
NBOOT_CMPA_CMAC_UPDATE_SHIFT
-
NBOOT_CMPA_UPDATE_CMAC_PFR
-
NBOOT_CMPA_UPDATE_CMAC_PFR_OTP_OEM_SECURE
-
NBOOT_CMPA_UPDATE_CMAC_PFR_OTP_OEM_CLOSE
-
NBOOT_CMPA_UPDATE_CMAC_PFR_OTP_OEM_LOCKED
-
struct _nboot_sb3_header
- #include <fsl_nboot_hal.h>
NBOOT SB3.1 header type.
This type defines the header used in the SB3.1 manifest
Public Members
-
uint32_t magic
offset 0x00: Fixed 4-byte string of ‘sbv3’ without the trailing NULL
-
uint32_t formatVersion
offset 0x04: (major = 3, minor = 1); The format version determines the manifest (block0) size.
-
uint32_t flags
offset 0x08: not defined yet, keep zero for future compatibility
-
uint32_t blockCount
offset 0x0C: Number of blocks not including the manifest (block0).
-
uint32_t blockSize
offset 0x10: Size in bytes of data block (repeated blockCount times for SB3 data stream).
-
nboot_timestamp_t timeStamp
offset 0x14: 64-bit value used as key derivation data.
-
uint32_t firmwareVersion
offset 0x1c: Version number of the included firmware
-
uint32_t imageTotalLength
offset 0x20: Total manifest length in bytes, including signatures etc.
-
uint32_t imageType
offset 0x24: image type and flags
-
uint32_t certificateBlockOffset
offset 0x28: Offset from start of header block to the certificate block.
-
uint8_t description[16]
offset 0x32: This field provides description of the file. It is an arbitrary string injected by the signing tool, which helps to identify the file.
-
uint32_t magic
-
struct _nboot_certificate_header_block
- #include <fsl_nboot_hal.h>
NBOOT type for the header of the certificate block.
This type defines the NBOOT header of the certificate block, it is part of the nboot_certificate_block_t
Public Members
-
uint32_t magic
magic number.
-
uint32_t formatMajorMinorVersion
format major minor version
-
uint32_t certBlockSize
Size of the full certificate block
-
uint32_t magic
-
struct _nboot_ctrk_hash_table
- #include <fsl_nboot_hal.h>
NBOOT type for the hash table.
This type defines the NBOOT hash table
-
struct nboot_ecdsa_public_key_t
- #include <fsl_nboot_hal.h>
NBOOT type for an ECC point.
This type defines the NBOOT ECC point type
Public Members
-
nboot_ecc_coordinate_t x
x portion of the ECDSA public key, up to 384-bits. big endian.
-
nboot_ecc_coordinate_t y
y portion of the ECDSA public key, up to 384-bits. big endian.
-
nboot_ecc_coordinate_t x
-
struct _nboot_root_certificate_block
- #include <fsl_nboot_hal.h>
NBOOT type for the root certificate block.
This type defines the NBOOT root certificate block, it is part of the nboot_certificate_block_t
Public Members
-
uint32_t flags
root certificate flags
-
nboot_ctrk_hash_table_t ctrkHashTable
hash table
-
nboot_ecdsa_public_key_t rootPublicKey
root public key
-
uint32_t flags
-
struct nboot_ecdsa_signature_t
- #include <fsl_nboot_hal.h>
NBOOT type for an ECC signature.
This type defines the NBOOT ECC signature type
Public Members
-
nboot_ecc_coordinate_t r
r portion of the ECDSA signature, up to 384-bits. big endian.
-
nboot_ecc_coordinate_t s
s portion of the ECDSA signature, up to 384-bits. big endian.
-
nboot_ecc_coordinate_t r
-
struct nboot_isk_block_t
- #include <fsl_nboot_hal.h>
NBOOT type for the isk block.
This type defines the constant length part of an NBOOT isk block
Public Members
-
uint32_t signatureOffset
Offset of signature in ISK block.
-
uint32_t constraints
Version number of signing certificate.
-
uint32_t iskFlags
Reserved for definiton of ISK certificate flags.
-
nboot_ecdsa_public_key_t iskPubKey
Public key of signing certificate. Variable length; only used to determine start address
-
nboot_ecdsa_public_key_t userData
Space for at lest one addition public key
-
nboot_ecdsa_signature_t iskSign
ISK signature
-
uint32_t signatureOffset
-
struct _nboot_certificate_block
- #include <fsl_nboot_hal.h>
NBOOT type for the certificate block.
This type defines the constant length part of an NBOOT certificate block
Public Members
-
nboot_isk_block_t iskBlock
Details of selected root certificate (root certificate which will be used for ISK signing/SB3 header signing)
-
nboot_isk_block_t iskBlock
OPAMP: Operational Amplifier
-
void OPAMP_Init(OPAMP_Type *base, const opamp_config_t *config)
Initialize OPAMP instance.
- Parameters:
base – OPAMP peripheral base address.
config – The pointer to opamp_config_t.
-
void OPAMP_Deinit(OPAMP_Type *base)
De-initialize OPAMP instance.
- Parameters:
base – OPAMP peripheral base address.
-
void OPAMP_GetDefaultConfig(opamp_config_t *config)
Get default configuration of OPAMP.
config->enable = false; config->mode = kOPAMP_LowNoiseMode; config->trimOption = kOPAMP_TrimOptionDefault; config->intRefVoltage = kOPAMP_IntRefVoltVddaDiv2; config->enablePosADCSw = false; config->posRefVoltage = kOPAMP_PosRefVoltVrefh3; config->posGain = kOPAMP_PosGainReserved; config->negGain = kOPAMP_NegGainBufferMode;
- Parameters:
config – The pointer to opamp_config_t.
-
static inline void OPAMP_DoPosGainConfig(OPAMP_Type *base, opamp_positive_gain_t option)
Configure OPAMP positive port gain.
- Parameters:
base – OPAMP peripheral base address.
option – OPAMP positive port gain.
-
static inline void OPAMP_DoNegGainConfig(OPAMP_Type *base, opamp_negative_gain_t option)
Configure OPAMP negative port gain.
- Parameters:
base – OPAMP peripheral base address.
option – OPAMP negative port gain.
-
FSL_OPAMP_DRIVER_VERSION
OPAMP driver version.
-
enum _opamp_mode
The enumeration of OPAMP mode, including low noise mode and high speed mode.
Values:
-
enumerator kOPAMP_LowNoiseMode
Set opamp mode as low noise mode.
-
enumerator kOPAMP_HighSpeedMode
Set opamp mode as high speed mode.
-
enumerator kOPAMP_LowNoiseMode
-
enum _opamp_bias_current_trim_option
The enumeration of bias current trim option.
Values:
-
enumerator kOPAMP_TrimOptionDefault
Default Bias current trim option.
-
enumerator kOPAMP_TrimOptionIncreaseCurrent
Trim option selected as increase current.
-
enumerator kOPAMP_TrimOptionDecreaseCurrent
Trim option selected as decrease current.
-
enumerator kOPAMP_TrimOptionFurtherDecreaseCurrent
Trim option selected as further decrease current.
-
enumerator kOPAMP_TrimOptionDefault
-
enum _opamp_internal_ref_voltage
The enumeration of internal reference voltage.
Values:
-
enumerator kOPAMP_IntRefVoltVddaDiv2
Internal reference voltage selected as Vdda/2.
-
enumerator kOPAMP_IntRefVoltVdda3V
Internal reference voltage selected as Vdda_3V.
-
enumerator kOPAMP_IntRefVoltVssa3V
Internal reference voltage selected as Vssa_3V.
-
enumerator kOPAMP_IntRefVoltNotAllowed
Internal reference voltage not allowed.
-
enumerator kOPAMP_IntRefVoltVddaDiv2
-
enum _opamp_positive_ref_voltage
The enumeration of positive reference voltage(please refer to manual use).
Values:
-
enumerator kOPAMP_PosRefVoltVrefh3
Positive part reference voltage select Vrefh3, connected from DAC output.
-
enumerator kOPAMP_PosRefVoltVrefh0
Positive part reference voltage select Vrefh0, connected from VDDA supply.
-
enumerator kOPAMP_PosRefVoltVrefh1
Positive part reference voltage select Vrefh1, connected from Voltage reference output.
-
enumerator kOPAMP_PosRefVoltVrefh4
Positive part reference voltage select 520mv or reserved.
-
enumerator kOPAMP_PosRefVoltVrefh3
-
enum _opamp_positive_gain
The enumeration of positive programmable gain (please refer to manual use).
Values:
-
enumerator kOPAMP_PosGainReserved
Positive Gain reserved.
-
enumerator kOPAMP_PosGainNonInvert1X
Positive non-inverting gain application 1X.
-
enumerator kOPAMP_PosGainNonInvert2X
Positive non-inverting gain application 2X.
-
enumerator kOPAMP_PosGainNonInvert4X
Positive non-inverting gain application 4X.
-
enumerator kOPAMP_PosGainNonInvert8X
Positive non-inverting gain application 8X.
-
enumerator kOPAMP_PosGainNonInvert16X
Positive non-inverting gain application 16X.
-
enumerator kOPAMP_PosGainNonInvert33X
Positive non-inverting gain application 33X.
-
enumerator kOPAMP_PosGainNonInvert64X
Positive non-inverting gain application 64X.
-
enumerator kOPAMP_PosGainReserved
-
enum _opamp_negative_gain
The enumeration of negative programmable gain.
Values:
-
enumerator kOPAMP_NegGainBufferMode
Negative Buffer Mode.
-
enumerator kOPAMP_NegGainInvert1X
Negative inverting gain application -1X.
-
enumerator kOPAMP_NegGainInvert2X
Negative inverting gain application -2X.
-
enumerator kOPAMP_NegGainInvert4X
Negative inverting gain application -4X.
-
enumerator kOPAMP_NegGainInvert8X
Negative inverting gain application -8X.
-
enumerator kOPAMP_NegGainInvert16X
Negative inverting gain application -16X.
-
enumerator kOPAMP_NegGainInvert33X
Negative inverting gain application -33X.
-
enumerator kOPAMP_NegGainInvert64X
Negative inverting gain application -64X.
-
enumerator kOPAMP_NegGainBufferMode
-
typedef enum _opamp_mode opamp_mode_t
The enumeration of OPAMP mode, including low noise mode and high speed mode.
-
typedef enum _opamp_bias_current_trim_option opamp_bias_current_trim_option_t
The enumeration of bias current trim option.
-
typedef enum _opamp_internal_ref_voltage opamp_internal_ref_voltage_t
The enumeration of internal reference voltage.
-
typedef enum _opamp_positive_ref_voltage opamp_positive_ref_voltage_t
The enumeration of positive reference voltage(please refer to manual use).
-
typedef enum _opamp_positive_gain opamp_positive_gain_t
The enumeration of positive programmable gain (please refer to manual use).
-
typedef enum _opamp_negative_gain opamp_negative_gain_t
The enumeration of negative programmable gain.
-
typedef struct _opamp_config opamp_config_t
OPAMP configuraion, including mode, internal reference voltage, positive gain, negative gain and so on.
-
struct _opamp_config
- #include <fsl_opamp.h>
OPAMP configuraion, including mode, internal reference voltage, positive gain, negative gain and so on.
Public Members
-
bool enable
Enable/disable OPAMP.
-
opamp_mode_t mode
Opamp mode, available values are kOPAMP_LowNoiseMode and kOPAMP_HighSpeedMode.
-
opamp_bias_current_trim_option_t trimOption
Bias current trim option, please refer to opamp_bias_current_trim_option_t.
-
opamp_internal_ref_voltage_t intRefVoltage
Internal reference voltage, please refer to opamp_internal_ref_voltage_t.
-
opamp_positive_ref_voltage_t posRefVoltage
Positive part reference voltage, please refer to opamp_positive_ref_voltage_t.
-
opamp_positive_gain_t posGain
Positive part programmable gain, please refer to opamp_positive_gain_t.
-
opamp_negative_gain_t negGain
Negative part programmable gain, please refer to opamp_negative_gain_t.
-
bool enablePosADCSw
Positive part reference voltage switch to ADC channel or not.
true Positive part reference voltage switch to ADC channel.
false Positive part reference voltage do not switch to ADC channel.
-
bool enable
OSTIMER: OS Event Timer Driver
-
void OSTIMER_Init(OSTIMER_Type *base)
Initializes an OSTIMER by turning its bus clock on.
-
void OSTIMER_Deinit(OSTIMER_Type *base)
Deinitializes a OSTIMER instance.
This function shuts down OSTIMER bus clock
- Parameters:
base – OSTIMER peripheral base address.
-
uint64_t OSTIMER_GrayToDecimal(uint64_t gray)
Translate the value from gray-code to decimal.
- Parameters:
gray – The gray value input.
- Returns:
The decimal value.
-
static inline uint64_t OSTIMER_DecimalToGray(uint64_t dec)
Translate the value from decimal to gray-code.
- Parameters:
dec – The decimal value.
- Returns:
The gray code of the input value.
-
uint32_t OSTIMER_GetStatusFlags(OSTIMER_Type *base)
Get OSTIMER status Flags.
This returns the status flag. Currently, only match interrupt flag can be got.
- Parameters:
base – OSTIMER peripheral base address.
- Returns:
status register value
-
void OSTIMER_ClearStatusFlags(OSTIMER_Type *base, uint32_t mask)
Clear Status Interrupt Flags.
This clears intrrupt status flag. Currently, only match interrupt flag can be cleared.
- Parameters:
base – OSTIMER peripheral base address.
mask – Clear bit mask.
- Returns:
none
-
status_t OSTIMER_SetMatchRawValue(OSTIMER_Type *base, uint64_t count, ostimer_callback_t cb)
Set the match raw value for OSTIMER.
This function will set a match value for OSTIMER with an optional callback. And this callback will be called while the data in dedicated pair match register is equals to the value of central EVTIMER. Please note that, the data format is gray-code, if decimal data was desired, please using OSTIMER_SetMatchValue().
- Parameters:
base – OSTIMER peripheral base address.
count – OSTIMER timer match value.(Value is gray-code format)
cb – OSTIMER callback (can be left as NULL if none, otherwise should be a void func(void)).
- Return values:
kStatus_Success – - Set match raw value and enable interrupt Successfully.
kStatus_Fail – - Set match raw value fail.
-
status_t OSTIMER_SetMatchValue(OSTIMER_Type *base, uint64_t count, ostimer_callback_t cb)
Set the match value for OSTIMER.
This function will set a match value for OSTIMER with an optional callback. And this callback will be called while the data in dedicated pair match register is equals to the value of central OS TIMER.
- Parameters:
base – OSTIMER peripheral base address.
count – OSTIMER timer match value.(Value is decimal format, and this value will be translate to Gray code internally.)
cb – OSTIMER callback (can be left as NULL if none, otherwise should be a void func(void)).
- Return values:
kStatus_Success – - Set match value and enable interrupt Successfully.
kStatus_Fail – - Set match value fail.
-
static inline void OSTIMER_SetMatchRegister(OSTIMER_Type *base, uint64_t value)
Set value to OSTIMER MATCH register directly.
This function writes the input value to OSTIMER MATCH register directly, it does not touch any other registers. Note that, the data format is gray-code. The function OSTIMER_DecimalToGray could convert decimal value to gray code.
- Parameters:
base – OSTIMER peripheral base address.
value – OSTIMER timer match value (Value is gray-code format).
-
static inline void OSTIMER_EnableMatchInterrupt(OSTIMER_Type *base)
Enable the OSTIMER counter match interrupt.
Enable the timer counter match interrupt. The interrupt happens when OSTIMER counter matches the value in MATCH registers.
- Parameters:
base – OSTIMER peripheral base address.
-
static inline void OSTIMER_DisableMatchInterrupt(OSTIMER_Type *base)
Disable the OSTIMER counter match interrupt.
Disable the timer counter match interrupt. The interrupt happens when OSTIMER counter matches the value in MATCH registers.
- Parameters:
base – OSTIMER peripheral base address.
-
static inline uint64_t OSTIMER_GetCurrentTimerRawValue(OSTIMER_Type *base)
Get current timer raw count value from OSTIMER.
This function will get a gray code type timer count value from OS timer register. The raw value of timer count is gray code format.
- Parameters:
base – OSTIMER peripheral base address.
- Returns:
Raw value of OSTIMER, gray code format.
-
uint64_t OSTIMER_GetCurrentTimerValue(OSTIMER_Type *base)
Get current timer count value from OSTIMER.
This function will get a decimal timer count value. The RAW value of timer count is gray code format, will be translated to decimal data internally.
- Parameters:
base – OSTIMER peripheral base address.
- Returns:
Value of OSTIMER which will be formated to decimal value.
-
static inline uint64_t OSTIMER_GetCaptureRawValue(OSTIMER_Type *base)
Get the capture value from OSTIMER.
This function will get a captured gray-code value from OSTIMER. The Raw value of timer capture is gray code format.
- Parameters:
base – OSTIMER peripheral base address.
- Returns:
Raw value of capture register, data format is gray code.
-
uint64_t OSTIMER_GetCaptureValue(OSTIMER_Type *base)
Get the capture value from OSTIMER.
This function will get a capture decimal-value from OSTIMER. The RAW value of timer capture is gray code format, will be translated to decimal data internally.
- Parameters:
base – OSTIMER peripheral base address.
- Returns:
Value of capture register, data format is decimal.
-
void OSTIMER_HandleIRQ(OSTIMER_Type *base, ostimer_callback_t cb)
OS timer interrupt Service Handler.
This function handles the interrupt and refers to the callback array in the driver to callback user (as per request in OSTIMER_SetMatchValue()). if no user callback is scheduled, the interrupt will simply be cleared.
- Parameters:
base – OS timer peripheral base address.
cb – callback scheduled for this instance of OS timer
- Returns:
none
-
FSL_OSTIMER_DRIVER_VERSION
OSTIMER driver version.
-
enum _ostimer_flags
OSTIMER status flags.
Values:
-
enumerator kOSTIMER_MatchInterruptFlag
Match interrupt flag bit, sets if the match value was reached.
-
enumerator kOSTIMER_MatchInterruptFlag
-
typedef void (*ostimer_callback_t)(void)
ostimer callback function.
PINT: Pin Interrupt and Pattern Match Driver
-
FSL_PINT_DRIVER_VERSION
-
enum _pint_pin_enable
PINT Pin Interrupt enable type.
Values:
-
enumerator kPINT_PinIntEnableNone
Do not generate Pin Interrupt
-
enumerator kPINT_PinIntEnableRiseEdge
Generate Pin Interrupt on rising edge
-
enumerator kPINT_PinIntEnableFallEdge
Generate Pin Interrupt on falling edge
-
enumerator kPINT_PinIntEnableBothEdges
Generate Pin Interrupt on both edges
-
enumerator kPINT_PinIntEnableLowLevel
Generate Pin Interrupt on low level
-
enumerator kPINT_PinIntEnableHighLevel
Generate Pin Interrupt on high level
-
enumerator kPINT_PinIntEnableNone
-
enum _pint_int
PINT Pin Interrupt type.
Values:
-
enumerator kPINT_PinInt0
Pin Interrupt 0
-
enumerator kPINT_SecPinInt0
Secure Pin Interrupt 0
-
enumerator kPINT_PinInt0
-
enum _pint_pmatch_input_src
PINT Pattern Match bit slice input source type.
Values:
-
enumerator kPINT_PatternMatchInp0Src
Input source 0
-
enumerator kPINT_PatternMatchInp1Src
Input source 1
-
enumerator kPINT_PatternMatchInp2Src
Input source 2
-
enumerator kPINT_PatternMatchInp3Src
Input source 3
-
enumerator kPINT_PatternMatchInp4Src
Input source 4
-
enumerator kPINT_PatternMatchInp5Src
Input source 5
-
enumerator kPINT_PatternMatchInp6Src
Input source 6
-
enumerator kPINT_PatternMatchInp7Src
Input source 7
-
enumerator kPINT_SecPatternMatchInp0Src
Input source 0
-
enumerator kPINT_SecPatternMatchInp1Src
Input source 1
-
enumerator kPINT_PatternMatchInp0Src
-
enum _pint_pmatch_bslice
PINT Pattern Match bit slice type.
Values:
-
enumerator kPINT_PatternMatchBSlice0
Bit slice 0
-
enumerator kPINT_SecPatternMatchBSlice0
Bit slice 0
-
enumerator kPINT_PatternMatchBSlice0
-
enum _pint_pmatch_bslice_cfg
PINT Pattern Match configuration type.
Values:
-
enumerator kPINT_PatternMatchAlways
Always Contributes to product term match
-
enumerator kPINT_PatternMatchStickyRise
Sticky Rising edge
-
enumerator kPINT_PatternMatchStickyFall
Sticky Falling edge
-
enumerator kPINT_PatternMatchStickyBothEdges
Sticky Rising or Falling edge
-
enumerator kPINT_PatternMatchHigh
High level
-
enumerator kPINT_PatternMatchLow
Low level
-
enumerator kPINT_PatternMatchNever
Never contributes to product term match
-
enumerator kPINT_PatternMatchBothEdges
Either rising or falling edge
-
enumerator kPINT_PatternMatchAlways
-
typedef enum _pint_pin_enable pint_pin_enable_t
PINT Pin Interrupt enable type.
-
typedef enum _pint_int pint_pin_int_t
PINT Pin Interrupt type.
-
typedef enum _pint_pmatch_input_src pint_pmatch_input_src_t
PINT Pattern Match bit slice input source type.
-
typedef enum _pint_pmatch_bslice pint_pmatch_bslice_t
PINT Pattern Match bit slice type.
-
typedef enum _pint_pmatch_bslice_cfg pint_pmatch_bslice_cfg_t
PINT Pattern Match configuration type.
-
typedef void (*pint_cb_t)(pint_pin_int_t pintr, uint32_t pmatch_status)
PINT Callback function.
-
typedef struct _pint_pmatch_cfg pint_pmatch_cfg_t
-
void PINT_Init(PINT_Type *base)
Initialize PINT peripheral.
This function initializes the PINT peripheral and enables the clock.
- Parameters:
base – Base address of the PINT peripheral.
- Return values:
None. –
-
void PINT_PinInterruptConfig(PINT_Type *base, pint_pin_int_t intr, pint_pin_enable_t enable, pint_cb_t callback)
Configure PINT peripheral pin interrupt.
This function configures a given pin interrupt.
- Parameters:
base – Base address of the PINT peripheral.
intr – Pin interrupt.
enable – Selects detection logic.
callback – Callback.
- Return values:
None. –
-
void PINT_PinInterruptGetConfig(PINT_Type *base, pint_pin_int_t pintr, pint_pin_enable_t *enable, pint_cb_t *callback)
Get PINT peripheral pin interrupt configuration.
This function returns the configuration of a given pin interrupt.
- Parameters:
base – Base address of the PINT peripheral.
pintr – Pin interrupt.
enable – Pointer to store the detection logic.
callback – Callback.
- Return values:
None. –
-
void PINT_PinInterruptClrStatus(PINT_Type *base, pint_pin_int_t pintr)
Clear Selected pin interrupt status only when the pin was triggered by edge-sensitive.
This function clears the selected pin interrupt status.
- Parameters:
base – Base address of the PINT peripheral.
pintr – Pin interrupt.
- Return values:
None. –
-
static inline uint32_t PINT_PinInterruptGetStatus(PINT_Type *base, pint_pin_int_t pintr)
Get Selected pin interrupt status.
This function returns the selected pin interrupt status.
- Parameters:
base – Base address of the PINT peripheral.
pintr – Pin interrupt.
- Return values:
status – = 0 No pin interrupt request. = 1 Selected Pin interrupt request active.
-
void PINT_PinInterruptClrStatusAll(PINT_Type *base)
Clear all pin interrupts status only when pins were triggered by edge-sensitive.
This function clears the status of all pin interrupts.
- Parameters:
base – Base address of the PINT peripheral.
- Return values:
None. –
-
static inline uint32_t PINT_PinInterruptGetStatusAll(PINT_Type *base)
Get all pin interrupts status.
This function returns the status of all pin interrupts.
- Parameters:
base – Base address of the PINT peripheral.
- Return values:
status – Each bit position indicates the status of corresponding pin interrupt. = 0 No pin interrupt request. = 1 Pin interrupt request active.
-
static inline void PINT_PinInterruptClrFallFlag(PINT_Type *base, pint_pin_int_t pintr)
Clear Selected pin interrupt fall flag.
This function clears the selected pin interrupt fall flag.
- Parameters:
base – Base address of the PINT peripheral.
pintr – Pin interrupt.
- Return values:
None. –
-
static inline uint32_t PINT_PinInterruptGetFallFlag(PINT_Type *base, pint_pin_int_t pintr)
Get selected pin interrupt fall flag.
This function returns the selected pin interrupt fall flag.
- Parameters:
base – Base address of the PINT peripheral.
pintr – Pin interrupt.
- Return values:
flag – = 0 Falling edge has not been detected. = 1 Falling edge has been detected.
-
static inline void PINT_PinInterruptClrFallFlagAll(PINT_Type *base)
Clear all pin interrupt fall flags.
This function clears the fall flag for all pin interrupts.
- Parameters:
base – Base address of the PINT peripheral.
- Return values:
None. –
-
static inline uint32_t PINT_PinInterruptGetFallFlagAll(PINT_Type *base)
Get all pin interrupt fall flags.
This function returns the fall flag of all pin interrupts.
- Parameters:
base – Base address of the PINT peripheral.
- Return values:
flags – Each bit position indicates the falling edge detection of the corresponding pin interrupt. 0 Falling edge has not been detected. = 1 Falling edge has been detected.
-
static inline void PINT_PinInterruptClrRiseFlag(PINT_Type *base, pint_pin_int_t pintr)
Clear Selected pin interrupt rise flag.
This function clears the selected pin interrupt rise flag.
- Parameters:
base – Base address of the PINT peripheral.
pintr – Pin interrupt.
- Return values:
None. –
-
static inline uint32_t PINT_PinInterruptGetRiseFlag(PINT_Type *base, pint_pin_int_t pintr)
Get selected pin interrupt rise flag.
This function returns the selected pin interrupt rise flag.
- Parameters:
base – Base address of the PINT peripheral.
pintr – Pin interrupt.
- Return values:
flag – = 0 Rising edge has not been detected. = 1 Rising edge has been detected.
-
static inline void PINT_PinInterruptClrRiseFlagAll(PINT_Type *base)
Clear all pin interrupt rise flags.
This function clears the rise flag for all pin interrupts.
- Parameters:
base – Base address of the PINT peripheral.
- Return values:
None. –
-
static inline uint32_t PINT_PinInterruptGetRiseFlagAll(PINT_Type *base)
Get all pin interrupt rise flags.
This function returns the rise flag of all pin interrupts.
- Parameters:
base – Base address of the PINT peripheral.
- Return values:
flags – Each bit position indicates the rising edge detection of the corresponding pin interrupt. 0 Rising edge has not been detected. = 1 Rising edge has been detected.
-
void PINT_PatternMatchConfig(PINT_Type *base, pint_pmatch_bslice_t bslice, pint_pmatch_cfg_t *cfg)
Configure PINT pattern match.
This function configures a given pattern match bit slice.
- Parameters:
base – Base address of the PINT peripheral.
bslice – Pattern match bit slice number.
cfg – Pointer to bit slice configuration.
- Return values:
None. –
-
void PINT_PatternMatchGetConfig(PINT_Type *base, pint_pmatch_bslice_t bslice, pint_pmatch_cfg_t *cfg)
Get PINT pattern match configuration.
This function returns the configuration of a given pattern match bit slice.
- Parameters:
base – Base address of the PINT peripheral.
bslice – Pattern match bit slice number.
cfg – Pointer to bit slice configuration.
- Return values:
None. –
-
static inline uint32_t PINT_PatternMatchGetStatus(PINT_Type *base, pint_pmatch_bslice_t bslice)
Get pattern match bit slice status.
This function returns the status of selected bit slice.
- Parameters:
base – Base address of the PINT peripheral.
bslice – Pattern match bit slice number.
- Return values:
status – = 0 Match has not been detected. = 1 Match has been detected.
-
static inline uint32_t PINT_PatternMatchGetStatusAll(PINT_Type *base)
Get status of all pattern match bit slices.
This function returns the status of all bit slices.
- Parameters:
base – Base address of the PINT peripheral.
- Return values:
status – Each bit position indicates the match status of corresponding bit slice. = 0 Match has not been detected. = 1 Match has been detected.
-
uint32_t PINT_PatternMatchResetDetectLogic(PINT_Type *base)
Reset pattern match detection logic.
This function resets the pattern match detection logic if any of the product term is matching.
- Parameters:
base – Base address of the PINT peripheral.
- Return values:
pmstatus – Each bit position indicates the match status of corresponding bit slice. = 0 Match was detected. = 1 Match was not detected.
-
static inline void PINT_PatternMatchEnable(PINT_Type *base)
Enable pattern match function.
This function enables the pattern match function.
- Parameters:
base – Base address of the PINT peripheral.
- Return values:
None. –
-
static inline void PINT_PatternMatchDisable(PINT_Type *base)
Disable pattern match function.
This function disables the pattern match function.
- Parameters:
base – Base address of the PINT peripheral.
- Return values:
None. –
-
static inline void PINT_PatternMatchEnableRXEV(PINT_Type *base)
Enable RXEV output.
This function enables the pattern match RXEV output.
- Parameters:
base – Base address of the PINT peripheral.
- Return values:
None. –
-
static inline void PINT_PatternMatchDisableRXEV(PINT_Type *base)
Disable RXEV output.
This function disables the pattern match RXEV output.
- Parameters:
base – Base address of the PINT peripheral.
- Return values:
None. –
-
void PINT_EnableCallback(PINT_Type *base)
Enable callback.
This function enables the interrupt for the selected PINT peripheral. Although the pin(s) are monitored as soon as they are enabled, the callback function is not enabled until this function is called.
- Parameters:
base – Base address of the PINT peripheral.
- Return values:
None. –
-
void PINT_DisableCallback(PINT_Type *base)
Disable callback.
This function disables the interrupt for the selected PINT peripheral. Although the pins are still being monitored but the callback function is not called.
- Parameters:
base – Base address of the peripheral.
- Return values:
None. –
-
void PINT_Deinit(PINT_Type *base)
Deinitialize PINT peripheral.
This function disables the PINT clock.
- Parameters:
base – Base address of the PINT peripheral.
- Return values:
None. –
-
void PINT_EnableCallbackByIndex(PINT_Type *base, pint_pin_int_t pintIdx)
enable callback by pin index.
This function enables callback by pin index instead of enabling all pins.
- Parameters:
base – Base address of the peripheral.
pintIdx – pin index.
- Return values:
None. –
-
void PINT_DisableCallbackByIndex(PINT_Type *base, pint_pin_int_t pintIdx)
disable callback by pin index.
This function disables callback by pin index instead of disabling all pins.
- Parameters:
base – Base address of the peripheral.
pintIdx – pin index.
- Return values:
None. –
-
PININT_BITSLICE_SRC_START
-
PININT_BITSLICE_SRC_MASK
-
PININT_BITSLICE_CFG_START
-
PININT_BITSLICE_CFG_MASK
-
PININT_BITSLICE_ENDP_MASK
-
PINT_PIN_INT_LEVEL
-
PINT_PIN_INT_EDGE
-
PINT_PIN_INT_FALL_OR_HIGH_LEVEL
-
PINT_PIN_INT_RISE
-
PINT_PIN_RISE_EDGE
-
PINT_PIN_FALL_EDGE
-
PINT_PIN_BOTH_EDGE
-
PINT_PIN_LOW_LEVEL
-
PINT_PIN_HIGH_LEVEL
-
struct _pint_pmatch_cfg
- #include <fsl_pint.h>
PLU: Programmable Logic Unit
-
void PLU_Init(PLU_Type *base)
Enable the PLU clock and reset the module.
Note
This API should be called at the beginning of the application using the PLU driver.
- Parameters:
base – PLU peripheral base address
-
void PLU_Deinit(PLU_Type *base)
Gate the PLU clock.
- Parameters:
base – PLU peripheral base address
-
static inline void PLU_SetLutInputSource(PLU_Type *base, plu_lut_index_t lutIndex, plu_lut_in_index_t lutInIndex, plu_lut_input_source_t inputSrc)
Set Input source of LUT.
Note: An external clock must be applied to the PLU_CLKIN input when using FFs. For each LUT, the slot associated with the output from LUTn itself is tied low.
- Parameters:
base – PLU peripheral base address.
lutIndex – LUT index (see plu_lut_index_t typedef enumeration).
lutInIndex – LUT input index (see plu_lut_in_index_t typedef enumeration).
inputSrc – LUT input source (see plu_lut_input_source_t typedef enumeration).
-
static inline void PLU_SetOutputSource(PLU_Type *base, plu_output_index_t outputIndex, plu_output_source_t outputSrc)
Set Output source of PLU.
Note: An external clock must be applied to the PLU_CLKIN input when using FFs.
- Parameters:
base – PLU peripheral base address.
outputIndex – PLU output index (see plu_output_index_t typedef enumeration).
outputSrc – PLU output source (see plu_output_source_t typedef enumeration).
-
static inline void PLU_SetLutTruthTable(PLU_Type *base, plu_lut_index_t lutIndex, uint32_t truthTable)
Set Truth Table of LUT.
- Parameters:
base – PLU peripheral base address.
lutIndex – LUT index (see plu_lut_index_t typedef enumeration).
truthTable – Truth Table value.
-
static inline uint32_t PLU_ReadOutputState(PLU_Type *base)
Read the current state of the 8 designated PLU Outputs.
Note: The PLU bus clock must be re-enabled prior to reading the Outpus Register if PLU bus clock is shut-off.
- Parameters:
base – PLU peripheral base address.
- Returns:
Current PLU output state value.
-
FSL_PLU_DRIVER_VERSION
Version 2.2.1
-
enum _plu_lut_index
Index of LUT.
Values:
-
enumerator kPLU_LUT_0
5-input Look-up Table 0
-
enumerator kPLU_LUT_1
5-input Look-up Table 1
-
enumerator kPLU_LUT_2
5-input Look-up Table 2
-
enumerator kPLU_LUT_3
5-input Look-up Table 3
-
enumerator kPLU_LUT_4
5-input Look-up Table 4
-
enumerator kPLU_LUT_5
5-input Look-up Table 5
-
enumerator kPLU_LUT_6
5-input Look-up Table 6
-
enumerator kPLU_LUT_7
5-input Look-up Table 7
-
enumerator kPLU_LUT_8
5-input Look-up Table 8
-
enumerator kPLU_LUT_9
5-input Look-up Table 9
-
enumerator kPLU_LUT_10
5-input Look-up Table 10
-
enumerator kPLU_LUT_11
5-input Look-up Table 11
-
enumerator kPLU_LUT_12
5-input Look-up Table 12
-
enumerator kPLU_LUT_13
5-input Look-up Table 13
-
enumerator kPLU_LUT_14
5-input Look-up Table 14
-
enumerator kPLU_LUT_15
5-input Look-up Table 15
-
enumerator kPLU_LUT_16
5-input Look-up Table 16
-
enumerator kPLU_LUT_17
5-input Look-up Table 17
-
enumerator kPLU_LUT_18
5-input Look-up Table 18
-
enumerator kPLU_LUT_19
5-input Look-up Table 19
-
enumerator kPLU_LUT_20
5-input Look-up Table 20
-
enumerator kPLU_LUT_21
5-input Look-up Table 21
-
enumerator kPLU_LUT_22
5-input Look-up Table 22
-
enumerator kPLU_LUT_23
5-input Look-up Table 23
-
enumerator kPLU_LUT_24
5-input Look-up Table 24
-
enumerator kPLU_LUT_25
5-input Look-up Table 25
-
enumerator kPLU_LUT_0
-
enum _plu_lut_in_index
Inputs of LUT. 5 input present for each LUT.
Values:
-
enumerator kPLU_LUT_IN_0
LUT input 0
-
enumerator kPLU_LUT_IN_1
LUT input 1
-
enumerator kPLU_LUT_IN_2
LUT input 2
-
enumerator kPLU_LUT_IN_3
LUT input 3
-
enumerator kPLU_LUT_IN_4
LUT input 4
-
enumerator kPLU_LUT_IN_0
-
enum _plu_lut_input_source
Available sources of LUT input.
Values:
-
enumerator kPLU_LUT_IN_SRC_PLU_IN_0
Select PLU input 0 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_PLU_IN_1
Select PLU input 1 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_PLU_IN_2
Select PLU input 2 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_PLU_IN_3
Select PLU input 3 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_PLU_IN_4
Select PLU input 4 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_PLU_IN_5
Select PLU input 5 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_LUT_OUT_0
Select LUT output 0 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_LUT_OUT_1
Select LUT output 1 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_LUT_OUT_2
Select LUT output 2 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_LUT_OUT_3
Select LUT output 3 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_LUT_OUT_4
Select LUT output 4 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_LUT_OUT_5
Select LUT output 5 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_LUT_OUT_6
Select LUT output 6 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_LUT_OUT_7
Select LUT output 7 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_LUT_OUT_8
Select LUT output 8 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_LUT_OUT_9
Select LUT output 9 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_LUT_OUT_10
Select LUT output 10 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_LUT_OUT_11
Select LUT output 11 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_LUT_OUT_12
Select LUT output 12 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_LUT_OUT_13
Select LUT output 13 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_LUT_OUT_14
Select LUT output 14 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_LUT_OUT_15
Select LUT output 15 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_LUT_OUT_16
Select LUT output 16 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_LUT_OUT_17
Select LUT output 17 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_LUT_OUT_18
Select LUT output 18 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_LUT_OUT_19
Select LUT output 19 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_LUT_OUT_20
Select LUT output 20 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_LUT_OUT_21
Select LUT output 21 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_LUT_OUT_22
Select LUT output 22 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_LUT_OUT_23
Select LUT output 23 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_LUT_OUT_24
Select LUT output 24 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_LUT_OUT_25
Select LUT output 25 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_FLIPFLOP_0
Select Flip-Flops state 0 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_FLIPFLOP_1
Select Flip-Flops state 1 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_FLIPFLOP_2
Select Flip-Flops state 2 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_FLIPFLOP_3
Select Flip-Flops state 3 to be connected to LUTn Input x
-
enumerator kPLU_LUT_IN_SRC_PLU_IN_0
-
enum _plu_output_index
PLU output multiplexer registers.
Values:
-
enumerator kPLU_OUTPUT_0
PLU OUTPUT 0
-
enumerator kPLU_OUTPUT_1
PLU OUTPUT 1
-
enumerator kPLU_OUTPUT_2
PLU OUTPUT 2
-
enumerator kPLU_OUTPUT_3
PLU OUTPUT 3
-
enumerator kPLU_OUTPUT_4
PLU OUTPUT 4
-
enumerator kPLU_OUTPUT_5
PLU OUTPUT 5
-
enumerator kPLU_OUTPUT_6
PLU OUTPUT 6
-
enumerator kPLU_OUTPUT_7
PLU OUTPUT 7
-
enumerator kPLU_OUTPUT_0
-
enum _plu_output_source
Available sources of PLU output.
Values:
-
enumerator kPLU_OUT_SRC_LUT_0
Select LUT0 output to be connected to PLU output
-
enumerator kPLU_OUT_SRC_LUT_1
Select LUT1 output to be connected to PLU output
-
enumerator kPLU_OUT_SRC_LUT_2
Select LUT2 output to be connected to PLU output
-
enumerator kPLU_OUT_SRC_LUT_3
Select LUT3 output to be connected to PLU output
-
enumerator kPLU_OUT_SRC_LUT_4
Select LUT4 output to be connected to PLU output
-
enumerator kPLU_OUT_SRC_LUT_5
Select LUT5 output to be connected to PLU output
-
enumerator kPLU_OUT_SRC_LUT_6
Select LUT6 output to be connected to PLU output
-
enumerator kPLU_OUT_SRC_LUT_7
Select LUT7 output to be connected to PLU output
-
enumerator kPLU_OUT_SRC_LUT_8
Select LUT8 output to be connected to PLU output
-
enumerator kPLU_OUT_SRC_LUT_9
Select LUT9 output to be connected to PLU output
-
enumerator kPLU_OUT_SRC_LUT_10
Select LUT10 output to be connected to PLU output
-
enumerator kPLU_OUT_SRC_LUT_11
Select LUT11 output to be connected to PLU output
-
enumerator kPLU_OUT_SRC_LUT_12
Select LUT12 output to be connected to PLU output
-
enumerator kPLU_OUT_SRC_LUT_13
Select LUT13 output to be connected to PLU output
-
enumerator kPLU_OUT_SRC_LUT_14
Select LUT14 output to be connected to PLU output
-
enumerator kPLU_OUT_SRC_LUT_15
Select LUT15 output to be connected to PLU output
-
enumerator kPLU_OUT_SRC_LUT_16
Select LUT16 output to be connected to PLU output
-
enumerator kPLU_OUT_SRC_LUT_17
Select LUT17 output to be connected to PLU output
-
enumerator kPLU_OUT_SRC_LUT_18
Select LUT18 output to be connected to PLU output
-
enumerator kPLU_OUT_SRC_LUT_19
Select LUT19 output to be connected to PLU output
-
enumerator kPLU_OUT_SRC_LUT_20
Select LUT20 output to be connected to PLU output
-
enumerator kPLU_OUT_SRC_LUT_21
Select LUT21 output to be connected to PLU output
-
enumerator kPLU_OUT_SRC_LUT_22
Select LUT22 output to be connected to PLU output
-
enumerator kPLU_OUT_SRC_LUT_23
Select LUT23 output to be connected to PLU output
-
enumerator kPLU_OUT_SRC_LUT_24
Select LUT24 output to be connected to PLU output
-
enumerator kPLU_OUT_SRC_LUT_25
Select LUT25 output to be connected to PLU output
-
enumerator kPLU_OUT_SRC_FLIPFLOP_0
Select Flip-Flops state(0) to be connected to PLU output
-
enumerator kPLU_OUT_SRC_FLIPFLOP_1
Select Flip-Flops state(1) to be connected to PLU output
-
enumerator kPLU_OUT_SRC_FLIPFLOP_2
Select Flip-Flops state(2) to be connected to PLU output
-
enumerator kPLU_OUT_SRC_FLIPFLOP_3
Select Flip-Flops state(3) to be connected to PLU output
-
enumerator kPLU_OUT_SRC_LUT_0
-
typedef enum _plu_lut_index plu_lut_index_t
Index of LUT.
-
typedef enum _plu_lut_in_index plu_lut_in_index_t
Inputs of LUT. 5 input present for each LUT.
-
typedef enum _plu_lut_input_source plu_lut_input_source_t
Available sources of LUT input.
-
typedef enum _plu_output_index plu_output_index_t
PLU output multiplexer registers.
-
typedef enum _plu_output_source plu_output_source_t
Available sources of PLU output.
Power Driver
-
enum _power_mode_config
Low Power Modes configuration.
Values:
-
enumerator kPmu_Sleep
-
enumerator kPmu_Deep_Sleep
-
enumerator kPmu_PowerDown
-
enumerator kPmu_Deep_PowerDown
-
enumerator kPmu_Sleep
-
enum _power_reset_cause
Device Reset Causes.
Values:
-
enumerator kRESET_CAUSE_POR
Power On Reset
-
enumerator kRESET_CAUSE_PADRESET
Hardware Pin Reset
-
enumerator kRESET_CAUSE_BODRESET
Brown-out Detector reset (either BODVBAT or BODCORE)
-
enumerator kRESET_CAUSE_ARMSYSTEMRESET
ARM System Reset
-
enumerator kRESET_CAUSE_WDTRESET
Watchdog Timer Reset
-
enumerator kRESET_CAUSE_SWRRESET
Software Reset
-
enumerator kRESET_CAUSE_CDOGRESET
Code Watchdog Reset
-
enumerator kRESET_CAUSE_DPDRESET_WAKEUPIO
Any of the 5 wake-up pins
-
enumerator kRESET_CAUSE_DPDRESET_RTC
Real Time Clock (RTC)
-
enumerator kRESET_CAUSE_DPDRESET_OSTIMER
OS Event Timer (OSTIMER)
-
enumerator kRESET_CAUSE_DPDRESET_WAKEUPIO_RTC
Any of the 5 wake-up pins and RTC (the 2 events occured within 1 nano-second of each other)
-
enumerator kRESET_CAUSE_DPDRESET_WAKEUPIO_OSTIMER
Any of the 5 wake-up pins and OSTIMER (the 2 events occured within 1 nano-second of each other)
-
enumerator kRESET_CAUSE_DPDRESET_RTC_OSTIMER
Real Time Clock or OS Event Timer (the 2 events occured within 1 nano-second of each other)
-
enumerator kRESET_CAUSE_DPDRESET_WAKEUPIO_RTC_OSTIMER
Any of the 5 wake-up pins or RTC or OS Event Timer (the 3 events occured within 1 nano-second of each other)
-
enumerator kRESET_CAUSE_NOT_RELEVANT
No reset cause (for example, this code is used when waking up from DEEP-SLEEP low power mode)
-
enumerator kRESET_CAUSE_NOT_DETERMINISTIC
Unknown Reset Cause. Should be treated like “Hardware Pin Reset” from an application point of view.
-
enumerator kRESET_CAUSE_POR
-
enum _power_boot_mode
Device Boot Modes.
Values:
-
enumerator kBOOT_MODE_POWER_UP
All non Low Power Mode wake up (Power On Reset, Pin Reset, BoD Reset, ARM System Reset … )
-
enumerator kBOOT_MODE_LP_DEEP_SLEEP
Wake up from DEEP-SLEEP Low Power mode
-
enumerator kBOOT_MODE_LP_POWER_DOWN
Wake up from POWER-DOWN Low Power mode
-
enumerator kBOOT_MODE_LP_DEEP_POWER_DOWN
Wake up from DEEP-POWER-DOWN Low Power mode
-
enumerator kBOOT_MODE_POWER_UP
-
enum _power_wakeup_pin_t
Device wake up pins events.
Values:
-
enumerator kWAKEUP_PIN_NONE
No wake up pin event
-
enumerator kWAKEUP_PIN_0
Wake up pin 0 event
-
enumerator kWAKEUP_PIN_1
Wake up pin 1 event
-
enumerator kWAKEUP_PIN_2
Wake up pin 2 event
-
enumerator kWAKEUP_PIN_3
Wake up pin 3 event
-
enumerator kWAKEUP_PIN_4
Wake up pin 4 event
-
enumerator kWAKEUP_PIN_MULTIPLE
More than 1 wake up pins events occured (within 1 nano-second of each other)
-
enumerator kWAKEUP_PIN_NONE
-
enum _power_pd_bit
analog components power modes control during low power modes
Values:
-
enumerator kPDRUNCFG_PD_DCDC
-
enumerator kPDRUNCFG_PD_BIAS
-
enumerator kPDRUNCFG_PD_BODCORE
-
enumerator kPDRUNCFG_PD_BODVDDMAIN
-
enumerator kPDRUNCFG_PD_FRO1M
-
enumerator kPDRUNCFG_PD_FRO192M
-
enumerator kPDRUNCFG_PD_FRO32K
-
enumerator kPDRUNCFG_PD_XTAL32K
-
enumerator kPDRUNCFG_PD_XTALHF
-
enumerator kPDRUNCFG_PD_PLL0
-
enumerator kPDRUNCFG_PD_PLL1
-
enumerator kPDRUNCFG_PD_USBFSPHY
-
enumerator kPDRUNCFG_PD_COMP
-
enumerator kPDRUNCFG_PD_LDOMEM
-
enumerator kPDRUNCFG_PD_LDOEFUSEPROG
-
enumerator kPDRUNCFG_PD_LDOXTALHF
-
enumerator kPDRUNCFG_PD_LDOFLASHNV
-
enumerator kPDRUNCFG_PD_PLL0_SSCG
-
enumerator kPDRUNCFG_PD_ROM
-
enumerator kPDRUNCFG_PD_HSCMP0
-
enumerator kPDRUNCFG_PD_HSCMP1
-
enumerator kPDRUNCFG_PD_HSCMP2
-
enumerator kPDRUNCFG_PD_OPAMP0
-
enumerator kPDRUNCFG_PD_OPAMP1
-
enumerator kPDRUNCFG_PD_OPAMP2
-
enumerator kPDRUNCFG_PD_VREF
-
enumerator kPDRUNCFG_PD_CMPBIAS
-
enumerator kPDRUNCFG_PD_HSCMP0_DAC
-
enumerator kPDRUNCFG_PD_HSCMP1_DAC
-
enumerator kPDRUNCFG_PD_HSCMP2_DAC
-
enumerator kPDRUNCFG_PD_DAC0
-
enumerator kPDRUNCFG_PD_DAC1
-
enumerator kPDRUNCFG_PD_DAC2
-
enumerator kPDRUNCFG_STOP_DAC0
-
enumerator kPDRUNCFG_STOP_DAC1
-
enumerator kPDRUNCFG_STOP_DAC2
-
enumerator kPDRUNCFG_ForceUnsigned
-
enumerator kPDRUNCFG_PD_DCDC
-
enum _power_sram_bit
SRAM instances bit masks.
Values:
-
enumerator kPOWER_SRAM_RAM_X0
RAM_X0
-
enumerator kPOWER_SRAM_RAM_00
RAM_00
-
enumerator kPOWER_SRAM_RAM_01
RAM_01
-
enumerator kPOWER_SRAM_RAM_02
RAM_02
-
enumerator kPOWER_SRAM_RAM_03
RAM_03
-
enumerator kPOWER_SRAM_RAM_10
RAM_10
-
enumerator kPOWER_SRAM_RAM_20
RAM_20
-
enumerator kPOWER_SRAM_RAM_30
RAM_30
-
enumerator kPOWER_SRAM_RAM_40
RAM_40
-
enumerator kPOWER_SRAM_RAM_41
RAM_41
-
enumerator kPOWER_SRAM_RAM_42
RAM_42
-
enumerator kPOWER_SRAM_RAM_43
RAM_43
-
enumerator kPOWER_SRAM_FLASHCACHE
Reserved. Flash Cache SRAM instance
-
enumerator kPOWER_SRAM_FLEXSPICACHE
Reserved. FlexSPI Cache SRAM instance
-
enumerator kPOWER_SRAM_FLEXSPIH2PREG
Reserved. FlexSPI Dual Port Register Files instances
-
enumerator kPOWER_SRAM_DSLP_MASK
Reserved. DEEP-SLEEP SRAM instances
-
enumerator kPOWER_SRAM_PDWN_MASK
Reserved. POWER-DOWN SRAM instances
-
enumerator kPOWER_SRAM_DPWD_MASK
Reserved. DEEP-POWER-DOWN SRAM instances (RAM_20 & RAM_30 excluded).
-
enumerator kPOWER_SRAM_ForceUnsigned
-
enumerator kPOWER_SRAM_RAM_X0
-
enum _power_sram_index
SRAM instances indexes.
Values:
-
enumerator kPOWER_SRAM_IDX_RAM_X0
RAM_X0
-
enumerator kPOWER_SRAM_IDX_RAM_00
RAM_00
-
enumerator kPOWER_SRAM_IDX_RAM_01
RAM_01
-
enumerator kPOWER_SRAM_IDX_RAM_02
RAM_02
-
enumerator kPOWER_SRAM_IDX_RAM_03
RAM_03
-
enumerator kPOWER_SRAM_IDX_RAM_10
RAM_10
-
enumerator kPOWER_SRAM_IDX_RAM_20
RAM_20
-
enumerator kPOWER_SRAM_IDX_RAM_30
RAM_30
-
enumerator kPOWER_SRAM_IDX_RAM_40
RAM_40
-
enumerator kPOWER_SRAM_IDX_RAM_41
RAM_41
-
enumerator kPOWER_SRAM_IDX_RAM_42
RAM_42
-
enumerator kPOWER_SRAM_IDX_RAM_43
RAM_43
-
enumerator kPOWER_SRAM_IDX_FLASHCACHE
Reserved. Flash Cache SRAM instance
-
enumerator kPOWER_SRAM_IDX_FLEXSPICACHE
Reserved. FlexSPI Cache SRAM instance
-
enumerator kPOWER_SRAM_IDX_FLEXSPIH2PREG
Reserved. FlexSPI Dual Port Register Files instances
-
enumerator kPOWER_SRAM_IDX_RAM_X0
-
enum _power_sram_pwr_mode
SRAM Power Mode.
Values:
-
enumerator kPOWER_SRAMPwrActive
Active
-
enumerator kPOWER_SRAMPwrLightSleep
RESERVED, DO NOT USE (Light Sleep)
-
enumerator kPOWER_SRAMPwrDeepSleep
Deep Sleep : SRAM content retained
-
enumerator kPOWER_SRAMPwrShutDown
Shutdown: SRAM content lost
-
enumerator kPOWER_SRAMPwrActive
-
enum _power_bod_vddmain_level
BOD VDDMAIN level.
Values:
-
enumerator kPOWER_BodVddmainLevel1000mv
VDDMAIN Brown out detector level 1V
-
enumerator kPOWER_BodVddmainLevel1100mv
VDDMAIN Brown out detector level 1.1V
-
enumerator kPOWER_BodVddmainLevel1200mv
VDDMAIN Brown out detector level 1.2V
-
enumerator kPOWER_BodVddmainLevel1300mv
VDDMAIN Brown out detector level 1.3V
-
enumerator kPOWER_BodVddmainLevel1400mv
VDDMAIN Brown out detector level 1.4V
-
enumerator kPOWER_BodVddmainLevel1500mv
VDDMAIN Brown out detector level 1.5V
-
enumerator kPOWER_BodVddmainLevel1600mv
VDDMAIN Brown out detector level 1.6V
-
enumerator kPOWER_BodVddmainLevel1650mv
VDDMAIN Brown out detector level 1.65V
-
enumerator kPOWER_BodVddmainLevel1700mv
VDDMAIN Brown out detector level 1.7V
-
enumerator kPOWER_BodVddmainLevel1750mv
VDDMAIN Brown out detector level 1.75V
-
enumerator kPOWER_BodVddmainLevel1800mv
VDDMAIN Brown out detector level 1.8V
-
enumerator kPOWER_BodVddmainLevel1900mv
VDDMAIN Brown out detector level 1.9V
-
enumerator kPOWER_BodVddmainLevel2000mv
VDDMAIN Brown out detector level 2V
-
enumerator kPOWER_BodVddmainLevel2100mv
VDDMAIN Brown out detector level 2.1V
-
enumerator kPOWER_BodVddmainLevel2200mv
VDDMAIN Brown out detector level 2.2V
-
enumerator kPOWER_BodVddmainLevel2300mv
VDDMAIN Brown out detector level 2.3V
-
enumerator kPOWER_BodVddmainLevel2400mv
VDDMAIN Brown out detector level 2.4V
-
enumerator kPOWER_BodVddmainLevel2500mv
VDDMAIN Brown out detector level 2.5V
-
enumerator kPOWER_BodVddmainLevel2600mv
VDDMAIN Brown out detector level 2.6V
-
enumerator kPOWER_BodVddmainLevel2700mv
VDDMAIN Brown out detector level 2.7V
-
enumerator kPOWER_BodVddmainLevel2800mv
VDDMAIN Brown out detector level 2.80 V
-
enumerator kPOWER_BodVddmainLevel2900mv
VDDMAIN Brown out detector level 2.9V
-
enumerator kPOWER_BodVddmainLevel3000mv
VDDMAIN Brown out detector level 3.0V
-
enumerator kPOWER_BodVddmainLevel3100mv
VDDMAIN Brown out detector level 3.1V
-
enumerator kPOWER_BodVddmainLevel3200mv
VDDMAIN Brown out detector level 3.2V
-
enumerator kPOWER_BodVddmainLevel3300mv
VDDMAIN Brown out detector level 3.3V
-
enumerator kPOWER_BodVddmainLevel1000mv
-
enum _power_bod_core_level
BOD core level.
Values:
-
enumerator kPOWER_BodCoreLevel0A600mv
core Brown out detector level 600mV for 0A
-
enumerator kPOWER_BodCoreLevel0A650mv
core Brown out detector level 650mV for 0A
-
enumerator kPOWER_BodCoreLevel0A700mv
core Brown out detector level 700mV for 0A
-
enumerator kPOWER_BodCoreLevel0A750mv
core Brown out detector level 750mV for 0A
-
enumerator kPOWER_BodCoreLevel0A800mv
core Brown out detector level 800mV for 0A
-
enumerator kPOWER_BodCoreLevel0A850mv
core Brown out detector level 850mV for 0A
-
enumerator kPOWER_BodCoreLevel0A900mv
core Brown out detector level 900mV for 0A
-
enumerator kPOWER_BodCoreLevel0A950mv
core Brown out detector level 950mV for 0A
-
enumerator kPOWER_BodCoreLevel1B929mv
core Brown out detector level 929mV for 1B
-
enumerator kPOWER_BodCoreLevel1B984mv
core Brown out detector level 984mV for 1B
-
enumerator kPOWER_BodCoreLevel1B1038mv
core Brown out detector level 1038mV for 1B
-
enumerator kPOWER_BodCoreLevel0A600mv
-
enum _power_bod_hyst
BODs (VDDMAIN & Core) Hysteresis control.
Values:
-
enumerator kPOWER_BodHystLevel25mv
BOD Hysteresis control level 25mv
-
enumerator kPOWER_BodHystLevel50mv
BOD Hysteresis control level 50mv
-
enumerator kPOWER_BodHystLevel75mv
BOD Hysteresis control level 75mv
-
enumerator kPOWER_BodHystLevel100mv
BOD Hysteresis control level 100mv
-
enumerator kPOWER_BodHystLevel25mv
-
enum _power_core_pwr_source
Core Power Source.
Values:
-
enumerator kPOWER_CoreSrcDCDC
DCDC
-
enumerator kPOWER_CoreSrcLDOCoreHP
LDO Core High Power Mode
-
enumerator kPOWER_CoreSrcLDOCoreLP
LDO Core Low Power Mode (DO NOT USE : Reserved for test purposes)
-
enumerator kPOWER_CoreSrcExternal
External (DO NOT USE : Reserved for test purposes)
-
enumerator kPOWER_CoreSrcDCDC
-
enum _power_core_pwr_state
Core Regulators Power State.
Values:
-
enumerator kPOWER_CorePwrDisable
Disable
-
enumerator kPOWER_CorePwrEnable
Enable
-
enumerator kPOWER_CorePwrDisable
-
enum _power_status
Generic Power Library APIs Status codes.
Values:
-
enumerator kPOWER_Status_Success
OK
-
enumerator kPOWER_Status_Fail
Generic error code
-
enumerator kPOWER_Status_Success
-
typedef enum _power_mode_config power_mode_cfg_t
Low Power Modes configuration.
-
typedef enum _power_reset_cause power_reset_cause_t
Device Reset Causes.
-
typedef enum _power_boot_mode power_boot_mode_t
Device Boot Modes.
-
typedef enum _power_wakeup_pin_t power_wakeup_pin_t
Device wake up pins events.
-
typedef enum _power_pd_bit pd_bit_t
analog components power modes control during low power modes
-
typedef enum _power_sram_bit power_sram_bit_t
SRAM instances bit masks.
-
typedef enum _power_sram_index power_sram_index_t
SRAM instances indexes.
-
typedef enum _power_sram_pwr_mode power_sram_pwr_mode_t
SRAM Power Mode.
-
typedef enum _power_bod_vddmain_level power_bod_vddmain_level_t
BOD VDDMAIN level.
-
typedef enum _power_bod_core_level power_bod_core_level_t
BOD core level.
-
typedef enum _power_bod_hyst power_bod_hyst_t
BODs (VDDMAIN & Core) Hysteresis control.
-
typedef enum _power_core_pwr_source power_core_pwr_source_t
Core Power Source.
-
typedef enum _power_core_pwr_state power_core_pwr_state_t
Core Regulators Power State.
-
typedef enum _power_status power_status_t
Generic Power Library APIs Status codes.
-
static inline void POWER_EnablePD(pd_bit_t en)
API to enable PDRUNCFG bit in the Syscon. Note that enabling the bit powers down the peripheral.
- Parameters:
en – peripheral for which to enable the PDRUNCFG bit
- Returns:
none
-
static inline void POWER_DisablePD(pd_bit_t en)
API to disable PDRUNCFG bit in the Syscon. Note that disabling the bit powers up the peripheral.
- Parameters:
en – peripheral for which to disable the PDRUNCFG bit
- Returns:
none
-
power_status_t POWER_PowerInit(void)
SoC Power Management Controller initialization.
- Returns:
power_status_t
-
power_status_t POWER_SetCorePowerSource(power_core_pwr_source_t pwr_source)
Selects the core logic supply source.
- Parameters:
pwr_source – : Defines which regulator will be used to power the part core logic (internally)
- Returns:
power_status_t
-
power_core_pwr_source_t POWER_GetCorePowerSource(void)
Returns the current core logic supply source.
- Returns:
power_core_pwr_source_t
-
power_status_t POWER_CorePowerSourceControl(power_core_pwr_source_t pwr_source, power_core_pwr_state_t pwr_state)
Allows to control the state (enabled or disabled) of the core logic internal regulators (DCDC, LDO_CORE)
- Parameters:
pwr_source – : Defines which regulator will be enabled or disabled
pwr_state – : Defines the state of the internal regulator indicated by pwr_source
- Returns:
power_status_t
-
power_status_t POWER_SRAMPowerModeControl(power_sram_bit_t sram_inst, power_sram_pwr_mode_t pwr_mode)
Allows to configure SRAM instances (low) power modes when the part is in ACTIVE mode.
- Parameters:
sram_inst – : Defines the SRAM instance(s) to be configured.
pwr_mode – : Defines the SRAM low power mode to be applied to all SRAM instances given by sram_inst
- Returns:
power_status_t
-
power_sram_pwr_mode_t POWER_GetSRAMPowerMode(power_sram_index_t sram_index)
- Parameters:
sram_index – : SRAM instances indexes
- Returns:
power_sram_pwr_mode_t
-
void POWER_EnterSleep(void)
Configures and enters in SLEEP low power mode.
- Returns:
Nothing
-
void POWER_EnterDeepSleep(uint32_t exclude_from_pd[2], uint32_t sram_retention_ctrl, uint32_t wakeup_interrupts[4], uint32_t hardware_wake_ctrl)
Configures and enters in DEEP-SLEEP low power mode.
- Parameters:
exclude_from_pd – Defines which analog peripherals shall NOT be powered down (it is a 2 x 32-bit vectors, aligned with “pd_bit_t” definition)
sram_retention_ctrl – Defines which SRAM instances will be put in “retention” mode during deep-sleep (aligned with “power_sram_bit_t” definition)
wakeup_interrupts – Defines which peripheral interrupts can be a wake-up source during deep-sleep (it is a 4 x 32-bit vectors, aligned with “WAKEUP_” definition)
hardware_wake_ctrl – configure DMA services during deep-sleep without waking up entire device (see “LOWPOWER_HWWAKE_*” definition).
- Returns:
Nothing
!!! IMPORTANT NOTES : 1 - CPU & System CLock frequency is switched to FRO12MHz and is NOT restored back by the API.
-
void POWER_EnterPowerDown(uint32_t exclude_from_pd[1], uint32_t sram_retention_ctrl, uint32_t wakeup_interrupts[4], uint32_t cpu_retention_addr)
Configures and enters in POWERDOWN low power mode.
- Parameters:
exclude_from_pd – Defines which analog peripherals shall NOT be powered down (it is a 1 x 32-bit vector, aligned with “pd_bit_t” definition)
sram_retention_ctrl – Defines which SRAM instances will be put in “retention” mode during power-down (aligned with “power_sram_bit_t” definition)
wakeup_interrupts – Defines which peripheral interrupts can be a wake-up source during power-down (it is a 2 x 32-bit vectors, aligned with “WAKEUP_” definition)
cpu_retention_addr – Must be:
Word aligned (address ending by 0x0, 0x4, 0x8 and 0xC).
Between 0x2000_0000 and 0x2000_09FC (inside RAM_00) or
Between 0x2000_1000 and 0x2000_19FC (inside RAM_01) or
Between 0x2000_2000 and 0x2000_29FC (inside RAM_02) or
Between 0x2000_3000 and 0x2000_39FC (inside RAM_03)
The CPU state will be stored in SRAM from “cpu_retention_addr” to “cpu_retention_addr + 1540”. Therefore, any data present in this area before calling the function will be lost.
- Returns:
Nothing
!!! IMPORTANT NOTES : 1 - CPU0 & System Clock frequency is switched to FRO12MHz and is NOT restored back by the API. 2 - It is the responsability of the user to make sure that SRAM instance containing the application software stack and variables WILL BE preserved during low power (via parameter "sram_retention_ctrl")
-
void POWER_EnterDeepPowerDown(uint32_t exclude_from_pd[1], uint32_t sram_retention_ctrl, uint32_t wakeup_interrupts[2], uint32_t wakeup_io_ctrl)
Configures and enters in DEEPPOWERDOWN low power mode.
- Parameters:
exclude_from_pd – Defines which analog peripherals shall NOT be powered down (it is a 1 x 32-bit vector, aligned with “pd_bit_t” definition)
sram_retention_ctrl – Defines which SRAM instances will be put in “retention” mode during deep power-down (aligned with “power_sram_bit_t” definition)
wakeup_interrupts – Defines which peripheral interrupts can be a wake-up source during deep power-down (it is a 2 x 32-bit vectors, aligned with “WAKEUP_” definition)
wakeup_io_ctrl – configure the 5 wake-up pins that can wake-up the part from deep power-down mode (see “LOWPOWER_WAKEUPIOSRC_*” definition)
- Returns:
Nothing
reset)!!! IMPORTANT NOTES : 1 - CPU0 & System Clock frequency is switched to FRO12MHz and is NOT restored back by the API. 2 - The HARD FAULT handler should execute from SRAM. (The Hard fault handler should initiate a full chip
-
void POWER_SetWakeUpPins(uint32_t wakeup_io_cfg_src, uint32_t wakeup_io_ctrl)
Configures the 5 wake-up pins to wake up the part in DEEP-SLEEP and POWER-DOWN low power modes.
- Parameters:
wakeup_io_cfg_src – : for all wake-up pins : indicates if the config is from IOCON (0) or from PMC (1).
wakeup_io_ctrl – the 5 wake-up pins configurations (see “LOWPOWER_WAKEUPIOSRC_*” definition)
- Returns:
Nothing
!!! IMPORTANT NOTES : 1 - To be called just before POWER_EnterDeepSleep() or POWER_EnterPowerDown().
-
void POWER_GetWakeUpCause(power_reset_cause_t *reset_cause, power_boot_mode_t *boot_mode, power_wakeup_pin_t *wakeup_pin_cause)
Return some key information related to the device reset causes / wake-up sources, for all power modes.
- Parameters:
reset_cause – : the device reset cause, according to the definition of power_reset_cause_t type.
boot_mode – : the device boot mode, according to the definition of power_boot_mode_t type.
wakeup_pin_cause – the wake-up pin sources, according to the definition of power_wakeup_pin_t type.
- Returns:
Nothing
-
void POWER_SetVoltageForFreq(uint32_t system_freq_hz)
Configures the device internal power control settings.
- Parameters:
system_freq_hz – operating frequency required (in Hertz).
- Returns:
Nothing
prepare on-chip power regulators (DC-DC Converter / Core and Always-on Low Drop-Out regulators) to deliver the amount of power needed for the requested performance level, as defined by the CPU operating frequency.
-
FSL_POWER_DRIVER_VERSION
power driver version 2.0.1.
-
WAKEUP_SYS
Low Power Modes Wake up sources.
-
WAKEUP_SDMA0
[SLEEP, DEEP SLEEP ]
-
WAKEUP_GPIO_GLOBALINT0
[SLEEP, DEEP SLEEP, POWER DOWN ]
-
WAKEUP_GPIO_GLOBALINT1
[SLEEP, DEEP SLEEP, POWER DOWN ]
-
WAKEUP_GPIO_INT0_0
[SLEEP, DEEP SLEEP ]
-
WAKEUP_GPIO_INT0_1
[SLEEP, DEEP SLEEP ]
-
WAKEUP_GPIO_INT0_2
[SLEEP, DEEP SLEEP ]
-
WAKEUP_GPIO_INT0_3
[SLEEP, DEEP SLEEP ]
-
WAKEUP_UTICK
[SLEEP, DEEP SLEEP ]
-
WAKEUP_MRT
[SLEEP, ]
-
WAKEUP_CTIMER0
[SLEEP, DEEP SLEEP ]
-
WAKEUP_CTIMER1
[SLEEP, DEEP SLEEP ]
-
WAKEUP_SCT
[SLEEP, ]
-
WAKEUP_CTIMER3
[SLEEP, DEEP SLEEP ]
-
WAKEUP_FLEXCOMM0
[SLEEP, DEEP SLEEP ]
-
WAKEUP_FLEXCOMM1
[SLEEP, DEEP SLEEP ]
-
WAKEUP_FLEXCOMM2
[SLEEP, DEEP SLEEP ]
-
WAKEUP_FLEXCOMM3
[SLEEP, DEEP SLEEP, POWER DOWN ]
-
WAKEUP_FLEXCOMM4
[SLEEP, DEEP SLEEP ]
-
WAKEUP_FLEXCOMM5
[SLEEP, DEEP SLEEP ]
-
WAKEUP_FLEXCOMM6
[SLEEP, DEEP SLEEP ]
-
WAKEUP_FLEXCOMM7
[SLEEP, DEEP SLEEP ]
-
WAKEUP_ADC0
[SLEEP, ]
-
WAKEUP_ADC1
[SLEEP, ]
-
WAKEUP_ACMP
[SLEEP, DEEP SLEEP, POWER DOWN ]
-
WAKEUP_DMIC
[SLEEP, ]
-
WAKEUP_HWVAD
[SLEEP, DEEP SLEEP, ]
-
WAKEUP_USB0_NEEDCLK
[SLEEP, DEEP SLEEP ]
-
WAKEUP_USB0
[SLEEP, DEEP SLEEP ]
-
WAKEUP_RTC_ALARM_WAKEUP
[SLEEP, DEEP SLEEP, POWER DOWN, DEEP POWER DOWN]
-
WAKEUP_EZH_ARCH_B
[SLEEP, ]
-
WAKEUP_WAKEUP_MAILBOX
[SLEEP, DEEP SLEEP, ]
-
WAKEUP_GPIO_INT0_4
[SLEEP, DEEP SLEEP ]
-
WAKEUP_GPIO_INT0_5
[SLEEP, DEEP SLEEP ]
-
WAKEUP_GPIO_INT0_6
[SLEEP, DEEP SLEEP ]
-
WAKEUP_GPIO_INT0_7
[SLEEP, DEEP SLEEP ]
-
WAKEUP_CTIMER2
[SLEEP, DEEP SLEEP ]
-
WAKEUP_CTIMER4
[SLEEP, DEEP SLEEP ]
-
WAKEUP_OS_EVENT_TIMER
[SLEEP, DEEP SLEEP, POWER DOWN, DEEP POWER DOWN]
-
WAKEUP_FLEXSPI
[SLEEP, ]
-
WAKEUP_CAN0_0
[SLEEP, ]
-
WAKEUP_CAN0_1
[SLEEP, ]
-
WAKEUP_SPIFILTER
[SLEEP, ]
-
WAKEUP_SEC_HYPERVISOR_CALL
[SLEEP, ]
-
WAKEUP_SEC_GPIO_INT0_0
[SLEEP, DEEP SLEEP ]
-
WAKEUP_SEC_GPIO_INT0_1
[SLEEP, DEEP SLEEP ]
-
WAKEUP_SEC_VIO
[SLEEP, ]
-
WAKEUP_CSS_IRQ0
[SLEEP, ]
-
WAKEUP_PKC
[SLEEP, ]
-
WAKEUP_PUF
[SLEEP, ]
-
WAKEUP_PQ
[SLEEP, ]
-
WAKEUP_SDMA1
[SLEEP, DEEP SLEEP ]
-
WAKEUP_LSPI_HS
[SLEEP, DEEP SLEEP ]
-
WAKEUP_CODE_WDG
[SLEEP, ]
-
WAKEUP_I3C
[SLEEP, DEEP SLEEP ]
-
WAKEUP_NEUTRON
[SLEEP, ]
-
WAKEUP_CSS_IRQ1
[SLEEP, ]
-
WAKEUP_ANA_GLITCH_DETECT
-
WAKEUP_DAC0
[SLEEP, DEEP SLEEP ]
-
WAKEUP_DAC1
[SLEEP, DEEP SLEEP ]
-
WAKEUP_DAC2
[SLEEP, DEEP SLEEP ]
-
WAKEUP_HS_COMP0
[SLEEP, ]
-
WAKEUP_HS_COMP1
[SLEEP, ]
-
WAKEUP_HS_COMP2
[SLEEP, ]
-
WAKEUP_FLEXPWM0_CAPTURE
[SLEEP, ]
-
WAKEUP_FLEXPWM0_FAULT
[SLEEP, ]
-
WAKEUP_FLEXPWM0_RELOAD_ERROR
[SLEEP, ]
-
WAKEUP_FLEXPWM0_COMPARE0
[SLEEP, ]
-
WAKEUP_FLEXPWM0_RELOAD0
[SLEEP, ]
-
WAKEUP_FLEXPWM0_COMPARE1
[SLEEP, ]
-
WAKEUP_FLEXPWM0_RELOAD1
[SLEEP, ]
-
WAKEUP_FLEXPWM0_COMPARE2
[SLEEP, ]
-
WAKEUP_FLEXPWM0_RELOAD2
[SLEEP, ]
-
WAKEUP_FLEXPWM0_COMPARE3
[SLEEP, ]
-
WAKEUP_FLEXPWM0_RELOAD3
[SLEEP, ]
-
WAKEUP_FLEXPWM1_CAPTURE
[SLEEP, ]
-
WAKEUP_FLEXPWM1_FAULT
[SLEEP, ]
-
WAKEUP_FLEXPWM1_RELOAD_ERROR
[SLEEP, ]
-
WAKEUP_FLEXPWM1_COMPARE0
[SLEEP, ]
-
WAKEUP_FLEXPWM1_RELOAD0
[SLEEP, ]
-
WAKEUP_FLEXPWM1_COMPARE1
[SLEEP, ]
-
WAKEUP_FLEXPWM1_RELOAD1
[SLEEP, ]
-
WAKEUP_FLEXPWM1_COMPARE2
[SLEEP, ]
-
WAKEUP_FLEXPWM1_RELOAD2
[SLEEP, ]
-
WAKEUP_FLEXPWM1_COMPARE3
[SLEEP, ]
-
WAKEUP_FLEXPWM1_RELOAD3
[SLEEP, ]
-
WAKEUP_ENC0_COMPARE
[SLEEP, ]
-
WAKEUP_ENC0_HOME
[SLEEP, ]
-
WAKEUP_ENC0_WDG
[SLEEP, ]
-
WAKEUP_ENC0_IDX
[SLEEP, ]
-
WAKEUP_ENC1_COMPARE
[SLEEP, ]
-
WAKEUP_ENC1_HOME
[SLEEP, ]
-
WAKEUP_ENC1_WDG
[SLEEP, ]
-
WAKEUP_ENC1_IDX
[SLEEP, ]
-
WAKEUP_ITRC
[SLEEP, DEEP SLEEP, POWER DOWN ]
-
WAKEUP_CF_DSP24L_IRQ0
[SLEEP, ]
-
WAKEUP_CF_DSP24L_IRQ1
[SLEEP, ]
-
WAKEUP_FTM0
[SLEEP, ]
-
LOWPOWER_HWWAKE_FORCED
Sleep Postpone (DEEP-SLEEP)
Force peripheral clocking to stay on during deep-sleep mode.
-
LOWPOWER_HWWAKE_PERIPHERALS
Wake for Flexcomms. Any Flexcomm FIFO reaching the level specified by its own TXLVL will cause \ peripheral clocking to wake up temporarily while the related status is asserted
-
LOWPOWER_HWWAKE_DMIC
Wake for DMIC. DMIC being busy will cause peripheral clocking to remain running until DMIC \ completes. Used in conjonction with LOWPOWER_HWWAKE_PERIPHERALS
-
LOWPOWER_HWWAKE_SDMA0
Wake for DMA0. DMA0 being busy will cause peripheral clocking to remain running until DMA \ completes. Used in conjonction with LOWPOWER_HWWAKE_PERIPHERALS or LOWPOWER_HWWAKE_DAC
-
LOWPOWER_HWWAKE_SDMA1
Wake for DMA1. DMA0 being busy will cause peripheral clocking to remain running until DMA \ completes. Used in conjonction with LOWPOWER_HWWAKE_PERIPHERALS or LOWPOWER_HWWAKE_DAC
-
LOWPOWER_HWWAKE_DAC
Wake for DAC0, DAC1, DAC2. Any DAC0/1/2 FIFO reaching the level specified by the configuration \ will generate an asynchronous SDMA0 request, and SDMA0 will wake up the bus \ clock temporarily to transfer data to DAC0/1/2.
-
LOWPOWER_HWWAKE_ENABLE_FRO192M
Need to be set if FRO192M is disable - via PDCTRL0 - in Deep Sleep mode and any of \ LOWPOWER_HWWAKE_PERIPHERALS, LOWPOWER_HWWAKE_SDMA0, LOWPOWER_HWWAKE_SDMA1 or LOWPOWER_HWWAKE_DAC is \ set
-
LOWPOWER_CPURETCTRL_ENA_DISABLE
CPU State retention (POWER-DOWN)
In POWER DOWN mode, CPU Retention is disabled
-
LOWPOWER_CPURETCTRL_ENA_ENABLE
In POWER DOWN mode, CPU Retention is enabled
-
LOWPOWER_WAKEUPIOSRC_PIO0_INDEX
Wake up I/O sources (DEEP POWER-DOWN)
Pin P1( 1)
-
LOWPOWER_WAKEUPIOSRC_PIO1_INDEX
Pin P0(28)
-
LOWPOWER_WAKEUPIOSRC_PIO2_INDEX
Pin P1(18)
-
LOWPOWER_WAKEUPIOSRC_PIO3_INDEX
Pin P1(30)
-
LOWPOWER_WAKEUPIOSRC_PIO4_INDEX
Pin P0(26)
-
LOWPOWER_WAKEUPIOSRC_DISABLE
Wake up is disable
-
LOWPOWER_WAKEUPIOSRC_RISING
Wake up on rising edge
-
LOWPOWER_WAKEUPIOSRC_FALLING
Wake up on falling edge
-
LOWPOWER_WAKEUPIOSRC_RISING_FALLING
Wake up on both rising or falling edges
-
LOWPOWER_WAKEUPIOSRC_PIO0MODE_INDEX
Pin P1( 1)
-
LOWPOWER_WAKEUPIOSRC_PIO1MODE_INDEX
Pin P0(28)
-
LOWPOWER_WAKEUPIOSRC_PIO2MODE_INDEX
Pin P1(18)
-
LOWPOWER_WAKEUPIOSRC_PIO3MODE_INDEX
Pin P1(30)
-
LOWPOWER_WAKEUPIOSRC_PIO4MODE_INDEX
Pin P0(26)
-
LOWPOWER_WAKEUPIOSRC_IO_MODE_PLAIN
Wake up Pad is plain input
-
LOWPOWER_WAKEUPIOSRC_IO_MODE_PULLDOWN
Wake up Pad is pull-down
-
LOWPOWER_WAKEUPIOSRC_IO_MODE_PULLUP
Wake up Pad is pull-up
-
LOWPOWER_WAKEUPIOSRC_IO_MODE_REPEATER
Wake up Pad is in repeater
-
LOWPOWER_WAKEUPIO_PIO0_DISABLEPULLUPDOWN_INDEX
Wake-up I/O 0 pull-up/down disable/enable control index
-
LOWPOWER_WAKEUPIO_PIO1_DISABLEPULLUPDOWN_INDEX
Wake-up I/O 1 pull-up/down disable/enable control index
-
LOWPOWER_WAKEUPIO_PIO2_DISABLEPULLUPDOWN_INDEX
Wake-up I/O 2 pull-up/down disable/enable control index
-
LOWPOWER_WAKEUPIO_PIO3_DISABLEPULLUPDOWN_INDEX
Wake-up I/O 3 pull-up/down disable/enable control index
-
LOWPOWER_WAKEUPIO_PIO4_DISABLEPULLUPDOWN_INDEX
Wake-up I/O 4 pull-up/down disable/enable control index
-
LOWPOWER_WAKEUPIO_PIO0_DISABLEPULLUPDOWN_MASK
Wake-up I/O 0 pull-up/down disable/enable mask
-
LOWPOWER_WAKEUPIO_PIO1_DISABLEPULLUPDOWN_MASK
Wake-up I/O 1 pull-up/down disable/enable mask
-
LOWPOWER_WAKEUPIO_PIO2_DISABLEPULLUPDOWN_MASK
Wake-up I/O 2 pull-up/down disable/enable mask
-
LOWPOWER_WAKEUPIO_PIO3_DISABLEPULLUPDOWN_MASK
Wake-up I/O 3 pull-up/down disable/enable mask
-
LOWPOWER_WAKEUPIO_PIO4_DISABLEPULLUPDOWN_MASK
Wake-up I/O 4 pull-up/down disable/enable mask
-
LOWPOWER_WAKEUPIO_PIO0_PULLUPDOWN_INDEX
Wake-up I/O 0 pull-up/down configuration index
-
LOWPOWER_WAKEUPIO_PIO1_PULLUPDOWN_INDEX
Wake-up I/O 1 pull-up/down configuration index
-
LOWPOWER_WAKEUPIO_PIO2_PULLUPDOWN_INDEX
Wake-up I/O 2 pull-up/down configuration index
-
LOWPOWER_WAKEUPIO_PIO3_PULLUPDOWN_INDEX
Wake-up I/O 3 pull-up/down configuration index
-
LOWPOWER_WAKEUPIO_PIO4_PULLUPDOWN_INDEX
Wake-up I/O 4 pull-up/down configuration index
-
LOWPOWER_WAKEUPIO_PIO0_PULLUPDOWN_MASK
Wake-up I/O 0 pull-up/down mask
-
LOWPOWER_WAKEUPIO_PIO1_PULLUPDOWN_MASK
Wake-up I/O 1 pull-up/down mask
-
LOWPOWER_WAKEUPIO_PIO2_PULLUPDOWN_MASK
Wake-up I/O 2 pull-up/down mask
-
LOWPOWER_WAKEUPIO_PIO3_PULLUPDOWN_MASK
Wake-up I/O 3 pull-up/down mask
-
LOWPOWER_WAKEUPIO_PIO4_PULLUPDOWN_MASK
Wake-up I/O 4 pull-up/down mask
-
LOWPOWER_WAKEUPIO_PULLDOWN
Select pull-down
-
LOWPOWER_WAKEUPIO_PULLUP
Select pull-up
-
LOWPOWER_WAKEUPIO_CFG_SRC_IOCON
Wake-up pins configuration (in/out, pull up/down plain input …) is coming from IOCON (valid for \ DEEP-SLEEP and POWER-DOWN)
-
LOWPOWER_WAKEUPIO_CFG_SRC_PMC
Wake-up pins configuration (in/out, pull up/down plain input …) is coming from PMC and set up via \ the second parameter (wakeup_io_ctrl) of POWER_SetWakeUpPins API (valid for DEEP-SLEEP and POWER-DOWN)
-
unsigned int fro_calib_Get_Lib_Ver(void)
-
void Chip_TIMER_Instance_Freq(CTIMER_Type *base, unsigned int ctimerFreq)
-
void USB_SOF_Event(void)
-
FSL_FRO_CALIB_DRIVER_VERSION
FRO_CALIB driver version 2.0.0.
-
FSL_COMPONENT_ID
POWERQUAD: PowerQuad hardware accelerator
-
void PQ_GetDefaultConfig(pq_config_t *config)
Get default configuration.
This function initializes the POWERQUAD configuration structure to a default value. FORMAT register field definitions Bits[15:8] scaler (for scaled ‘q31’ formats) Bits[5:4] external format. 00b=q15, 01b=q31, 10b=float Bits[1:0] internal format. 00b=q15, 01b=q31, 10b=float POWERQUAD->INAFORMAT = (config->inputAPrescale << 8U) | (config->inputAFormat << 4U) | config->machineFormat
For all Powerquad operations internal format must be float (with the only exception being the FFT related functions, ie FFT/IFFT/DCT/IDCT which must be set to q31). The default values are: config->inputAFormat = kPQ_Float; config->inputAPrescale = 0; config->inputBFormat = kPQ_Float; config->inputBPrescale = 0; config->outputFormat = kPQ_Float; config->outputPrescale = 0; config->tmpFormat = kPQ_Float; config->tmpPrescale = 0; config->machineFormat = kPQ_Float; config->tmpBase = 0xE0000000;
- Parameters:
config – Pointer to “pq_config_t” structure.
-
void PQ_SetConfig(POWERQUAD_Type *base, const pq_config_t *config)
Set configuration with format/prescale.
- Parameters:
base – POWERQUAD peripheral base address
config – Pointer to “pq_config_t” structure.
-
static inline void PQ_SetCoprocessorScaler(POWERQUAD_Type *base, const pq_prescale_t *prescale)
set coprocessor scaler for coprocessor instructions, this function is used to set output saturation and scaleing for input/output.
- Parameters:
base – POWERQUAD peripheral base address
prescale – Pointer to “pq_prescale_t” structure.
-
void PQ_Init(POWERQUAD_Type *base)
Initializes the POWERQUAD module.
- Parameters:
base – POWERQUAD peripheral base address.
-
void PQ_Deinit(POWERQUAD_Type *base)
De-initializes the POWERQUAD module.
- Parameters:
base – POWERQUAD peripheral base address.
-
void PQ_SetFormat(POWERQUAD_Type *base, pq_computationengine_t engine, pq_format_t format)
Set format for non-coprecessor instructions.
- Parameters:
base – POWERQUAD peripheral base address
engine – Computation engine
format – Data format
-
static inline void PQ_WaitDone(POWERQUAD_Type *base)
Wait for the completion.
- Parameters:
base – POWERQUAD peripheral base address
-
static inline void PQ_LnF32(float *pSrc, float *pDst)
Processing function for the floating-point natural log.
- Parameters:
*pSrc – points to the block of input data. The range of the input value is (0 +INFINITY).
*pDst – points to the block of output data
-
static inline void PQ_InvF32(float *pSrc, float *pDst)
Processing function for the floating-point reciprocal.
- Parameters:
*pSrc – points to the block of input data. The range of the input value is non-zero.
*pDst – points to the block of output data
-
static inline void PQ_SqrtF32(float *pSrc, float *pDst)
Processing function for the floating-point square-root.
- Parameters:
*pSrc – points to the block of input data. The range of the input value is [0 +INFINITY).
*pDst – points to the block of output data
-
static inline void PQ_InvSqrtF32(float *pSrc, float *pDst)
Processing function for the floating-point inverse square-root.
- Parameters:
*pSrc – points to the block of input data. The range of the input value is (0 +INFINITY).
*pDst – points to the block of output data
-
static inline void PQ_EtoxF32(float *pSrc, float *pDst)
Processing function for the floating-point natural exponent.
- Parameters:
*pSrc – points to the block of input data. The range of the input value is (-INFINITY +INFINITY).
*pDst – points to the block of output data
-
static inline void PQ_EtonxF32(float *pSrc, float *pDst)
Processing function for the floating-point natural exponent with negative parameter.
- Parameters:
*pSrc – points to the block of input data. The range of the input value is (-INFINITY +INFINITY).
*pDst – points to the block of output data
-
static inline void PQ_SinF32(float *pSrc, float *pDst)
Processing function for the floating-point sine.
- Parameters:
*pSrc – points to the block of input data. The input value is in radians, the range is (-INFINITY +INFINITY).
*pDst – points to the block of output data
-
static inline void PQ_CosF32(float *pSrc, float *pDst)
Processing function for the floating-point cosine.
- Parameters:
*pSrc – points to the block of input data. The input value is in radians, the range is (-INFINITY +INFINITY).
*pDst – points to the block of output data
-
static inline void PQ_BiquadF32(float *pSrc, float *pDst)
Processing function for the floating-point biquad.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
-
static inline void PQ_DivF32(float *x1, float *x2, float *pDst)
Processing function for the floating-point division.
Get x1 / x2.
- Parameters:
x1 – x1
x2 – x2
*pDst – points to the block of output data
-
static inline void PQ_Biquad1F32(float *pSrc, float *pDst)
Processing function for the floating-point biquad.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
-
static inline int32_t PQ_LnFixed(int32_t val)
Processing function for the fixed natural log.
- Parameters:
val – value to be calculated. The range of the input value is (0 +INFINITY).
- Returns:
returns ln(val).
-
static inline int32_t PQ_InvFixed(int32_t val)
Processing function for the fixed reciprocal.
- Parameters:
val – value to be calculated. The range of the input value is non-zero.
- Returns:
returns inv(val).
-
static inline uint32_t PQ_SqrtFixed(uint32_t val)
Processing function for the fixed square-root.
- Parameters:
val – value to be calculated. The range of the input value is [0 +INFINITY).
- Returns:
returns sqrt(val).
-
static inline int32_t PQ_InvSqrtFixed(int32_t val)
Processing function for the fixed inverse square-root.
- Parameters:
val – value to be calculated. The range of the input value is (0 +INFINITY).
- Returns:
returns 1/sqrt(val).
-
static inline int32_t PQ_EtoxFixed(int32_t val)
Processing function for the Fixed natural exponent.
- Parameters:
val – value to be calculated. The range of the input value is (-INFINITY +INFINITY).
- Returns:
returns etox^(val).
-
static inline int32_t PQ_EtonxFixed(int32_t val)
Processing function for the fixed natural exponent with negative parameter.
- Parameters:
val – value to be calculated. The range of the input value is (-INFINITY +INFINITY).
- Returns:
returns etonx^(val).
-
static inline int32_t PQ_SinQ31(int32_t val)
Processing function for the fixed sine.
- Parameters:
val – value to be calculated. The input value is [-1, 1] in Q31 format, which means [-pi, pi].
- Returns:
returns sin(val).
-
static inline int16_t PQ_SinQ15(int16_t val)
Processing function for the fixed sine.
- Parameters:
val – value to be calculated. The input value is [-1, 1] in Q15 format, which means [-pi, pi].
- Returns:
returns sin(val).
-
static inline int32_t PQ_CosQ31(int32_t val)
Processing function for the fixed cosine.
- Parameters:
val – value to be calculated. The input value is [-1, 1] in Q31 format, which means [-pi, pi].
- Returns:
returns cos(val).
-
static inline int16_t PQ_CosQ15(int16_t val)
Processing function for the fixed sine.
- Parameters:
val – value to be calculated. The input value is [-1, 1] in Q15 format, which means [-pi, pi].
- Returns:
returns sin(val).
-
static inline int32_t PQ_BiquadFixed(int32_t val)
Processing function for the fixed biquad.
- Parameters:
val – value to be calculated
- Returns:
returns biquad(val).
-
void PQ_VectorLnF32(float *pSrc, float *pDst, int32_t length)
Processing function for the floating-point vectorised natural log.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block of input data.
-
void PQ_VectorInvF32(float *pSrc, float *pDst, int32_t length)
Processing function for the floating-point vectorised reciprocal.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block of input data.
-
void PQ_VectorSqrtF32(float *pSrc, float *pDst, int32_t length)
Processing function for the floating-point vectorised square-root.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block of input data.
-
void PQ_VectorInvSqrtF32(float *pSrc, float *pDst, int32_t length)
Processing function for the floating-point vectorised inverse square-root.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block of input data.
-
void PQ_VectorEtoxF32(float *pSrc, float *pDst, int32_t length)
Processing function for the floating-point vectorised natural exponent.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block of input data.
-
void PQ_VectorEtonxF32(float *pSrc, float *pDst, int32_t length)
Processing function for the floating-point vectorised natural exponent with negative parameter.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block of input data.
-
void PQ_VectorSinF32(float *pSrc, float *pDst, int32_t length)
Processing function for the floating-point vectorised sine.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block of input data.
-
void PQ_VectorCosF32(float *pSrc, float *pDst, int32_t length)
Processing function for the floating-point vectorised cosine.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block of input data.
-
void PQ_VectorLnFixed32(int32_t *pSrc, int32_t *pDst, int32_t length)
Processing function for the Q31 vectorised natural log.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block of input data.
-
void PQ_VectorInvFixed32(int32_t *pSrc, int32_t *pDst, int32_t length)
Processing function for the Q31 vectorised reciprocal.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block of input data.
-
void PQ_VectorSqrtFixed32(int32_t *pSrc, int32_t *pDst, int32_t length)
Processing function for the 32-bit integer vectorised square-root.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block of input data.
-
void PQ_VectorInvSqrtFixed32(int32_t *pSrc, int32_t *pDst, int32_t length)
Processing function for the 32-bit integer vectorised inverse square-root.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block of input data.
-
void PQ_VectorEtoxFixed32(int32_t *pSrc, int32_t *pDst, int32_t length)
Processing function for the 32-bit integer vectorised natural exponent.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block of input data.
-
void PQ_VectorEtonxFixed32(int32_t *pSrc, int32_t *pDst, int32_t length)
Processing function for the 32-bit integer vectorised natural exponent with negative parameter.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block of input data.
-
void PQ_VectorSinQ15(int16_t *pSrc, int16_t *pDst, int32_t length)
Processing function for the Q15 vectorised sine.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block of input data.
-
void PQ_VectorCosQ15(int16_t *pSrc, int16_t *pDst, int32_t length)
Processing function for the Q15 vectorised cosine.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block of input data.
-
void PQ_VectorSinQ31(int32_t *pSrc, int32_t *pDst, int32_t length)
Processing function for the Q31 vectorised sine.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block of input data.
-
void PQ_VectorCosQ31(int32_t *pSrc, int32_t *pDst, int32_t length)
Processing function for the Q31 vectorised cosine.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block of input data.
-
void PQ_VectorLnFixed16(int16_t *pSrc, int16_t *pDst, int32_t length)
Processing function for the 16-bit integer vectorised natural log.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block of input data.
-
void PQ_VectorInvFixed16(int16_t *pSrc, int16_t *pDst, int32_t length)
Processing function for the 16-bit integer vectorised reciprocal.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block of input data.
-
void PQ_VectorSqrtFixed16(int16_t *pSrc, int16_t *pDst, int32_t length)
Processing function for the 16-bit integer vectorised square-root.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block of input data.
-
void PQ_VectorInvSqrtFixed16(int16_t *pSrc, int16_t *pDst, int32_t length)
Processing function for the 16-bit integer vectorised inverse square-root.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block of input data.
-
void PQ_VectorEtoxFixed16(int16_t *pSrc, int16_t *pDst, int32_t length)
Processing function for the 16-bit integer vectorised natural exponent.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block of input data.
-
void PQ_VectorEtonxFixed16(int16_t *pSrc, int16_t *pDst, int32_t length)
Processing function for the 16-bit integer vectorised natural exponent with negative parameter.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block of input data.
-
void PQ_VectorBiquadDf2F32(float *pSrc, float *pDst, int32_t length)
Processing function for the floating-point vectorised biquad direct form II.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block size of input data.
-
void PQ_VectorBiquadDf2Fixed32(int32_t *pSrc, int32_t *pDst, int32_t length)
Processing function for the 32-bit integer vectorised biquad direct form II.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block size of input data
-
void PQ_VectorBiquadDf2Fixed16(int16_t *pSrc, int16_t *pDst, int32_t length)
Processing function for the 16-bit integer vectorised biquad direct form II.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block size of input data
-
void PQ_VectorBiquadCascadeDf2F32(float *pSrc, float *pDst, int32_t length)
Processing function for the floating-point vectorised biquad direct form II.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block size of input data
-
void PQ_VectorBiquadCascadeDf2Fixed32(int32_t *pSrc, int32_t *pDst, int32_t length)
Processing function for the 32-bit integer vectorised biquad direct form II.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block size of input data
-
void PQ_VectorBiquadCascadeDf2Fixed16(int16_t *pSrc, int16_t *pDst, int32_t length)
Processing function for the 16-bit integer vectorised biquad direct form II.
- Parameters:
*pSrc – points to the block of input data
*pDst – points to the block of output data
length – the block size of input data
-
int32_t PQ_ArctanFixed(POWERQUAD_Type *base, int32_t x, int32_t y, pq_cordic_iter_t iteration)
Processing function for the fixed inverse trigonometric.
Get the inverse tangent, the behavior is like c function atan.
Note
The sum of x and y should not exceed the range of int32_t.
Note
Larger input number gets higher output accuracy, for example the arctan(0.5), the result of PQ_ArctanFixed(POWERQUAD, 100000, 200000, kPQ_Iteration_24) is more accurate than PQ_ArctanFixed(POWERQUAD, 1, 2, kPQ_Iteration_24).
- Parameters:
base – POWERQUAD peripheral base address
x – value of opposite
y – value of adjacent
iteration – iteration times
- Returns:
The return value is in the range of -2^26 to 2^26, which means -pi/2 to pi/2.
-
int32_t PQ_ArctanhFixed(POWERQUAD_Type *base, int32_t x, int32_t y, pq_cordic_iter_t iteration)
Processing function for the fixed inverse trigonometric.
Note
The sum of x and y should not exceed the range of int32_t.
Note
Larger input number gets higher output accuracy, for example the arctanh(0.5), the result of PQ_ArctanhFixed(POWERQUAD, 100000, 200000, kPQ_Iteration_24) is more accurate than PQ_ArctanhFixed(POWERQUAD, 1, 2, kPQ_Iteration_24).
- Parameters:
base – POWERQUAD peripheral base address
x – value of opposite
y – value of adjacent
iteration – iteration times
- Returns:
The return value is radians, 2^27 means pi. The range is -1.118 to 1.118 radians.
-
int32_t PQ_Arctan2Fixed(POWERQUAD_Type *base, int32_t x, int32_t y, pq_cordic_iter_t iteration)
Processing function for the fixed inverse trigonometric.
Get the inverse tangent, it calculates the angle in radians for the quadrant. The behavior is like c function atan2.
Note
The sum of x and y should not exceed the range of int32_t.
Note
Larger input number gets higher output accuracy, for example the arctan(0.5), the result of PQ_Arctan2Fixed(POWERQUAD, 100000, 200000, kPQ_Iteration_24) is more accurate than PQ_Arctan2Fixed(POWERQUAD, 1, 2, kPQ_Iteration_24).
- Parameters:
base – POWERQUAD peripheral base address
x – value of opposite
y – value of adjacent
iteration – iteration times
- Returns:
The return value is in the range of -2^27 to 2^27, which means -pi to pi.
-
static inline int32_t PQ_Biquad1Fixed(int32_t val)
Processing function for the fixed biquad.
- Parameters:
val – value to be calculated
- Returns:
returns biquad(val).
-
void PQ_TransformCFFT(POWERQUAD_Type *base, uint32_t length, void *pData, void *pResult)
Processing function for the complex FFT.
- Parameters:
base – POWERQUAD peripheral base address
length – number of input samples
pData – input data
pResult – output data.
-
void PQ_TransformRFFT(POWERQUAD_Type *base, uint32_t length, void *pData, void *pResult)
Processing function for the real FFT.
- Parameters:
base – POWERQUAD peripheral base address
length – number of input samples
pData – input data
pResult – output data.
-
void PQ_TransformIFFT(POWERQUAD_Type *base, uint32_t length, void *pData, void *pResult)
Processing function for the inverse complex FFT.
- Parameters:
base – POWERQUAD peripheral base address
length – number of input samples
pData – input data
pResult – output data.
-
void PQ_TransformCDCT(POWERQUAD_Type *base, uint32_t length, void *pData, void *pResult)
Processing function for the complex DCT.
- Parameters:
base – POWERQUAD peripheral base address
length – number of input samples
pData – input data
pResult – output data.
-
void PQ_TransformRDCT(POWERQUAD_Type *base, uint32_t length, void *pData, void *pResult)
Processing function for the real DCT.
- Parameters:
base – POWERQUAD peripheral base address
length – number of input samples
pData – input data
pResult – output data.
-
void PQ_TransformIDCT(POWERQUAD_Type *base, uint32_t length, void *pData, void *pResult)
Processing function for the inverse complex DCT.
- Parameters:
base – POWERQUAD peripheral base address
length – number of input samples
pData – input data
pResult – output data.
-
void PQ_BiquadBackUpInternalState(POWERQUAD_Type *base, int32_t biquad_num, pq_biquad_state_t *state)
Processing function for backup biquad context.
- Parameters:
base – POWERQUAD peripheral base address
biquad_num – biquad side
state – point to states.
-
void PQ_BiquadRestoreInternalState(POWERQUAD_Type *base, int32_t biquad_num, pq_biquad_state_t *state)
Processing function for restore biquad context.
- Parameters:
base – POWERQUAD peripheral base address
biquad_num – biquad side
state – point to states.
-
void PQ_BiquadCascadeDf2Init(pq_biquad_cascade_df2_instance *S, uint8_t numStages, pq_biquad_state_t *pState)
Initialization function for the direct form II Biquad cascade filter.
- Parameters:
*S – [inout] points to an instance of the filter data structure.
numStages – [in] number of 2nd order stages in the filter.
*pState – [in] points to the state buffer.
-
void PQ_BiquadCascadeDf2F32(const pq_biquad_cascade_df2_instance *S, float *pSrc, float *pDst, uint32_t blockSize)
Processing function for the floating-point direct form II Biquad cascade filter.
- Parameters:
*S – [in] points to an instance of the filter data structure.
*pSrc – [in] points to the block of input data.
*pDst – [out] points to the block of output data
blockSize – [in] number of samples to process.
-
void PQ_BiquadCascadeDf2Fixed32(const pq_biquad_cascade_df2_instance *S, int32_t *pSrc, int32_t *pDst, uint32_t blockSize)
Processing function for the Q31 direct form II Biquad cascade filter.
- Parameters:
*S – [in] points to an instance of the filter data structure.
*pSrc – [in] points to the block of input data.
*pDst – [out] points to the block of output data
blockSize – [in] number of samples to process.
-
void PQ_BiquadCascadeDf2Fixed16(const pq_biquad_cascade_df2_instance *S, int16_t *pSrc, int16_t *pDst, uint32_t blockSize)
Processing function for the Q15 direct form II Biquad cascade filter.
- Parameters:
*S – [in] points to an instance of the filter data structure.
*pSrc – [in] points to the block of input data.
*pDst – [out] points to the block of output data
blockSize – [in] number of samples to process.
-
void PQ_FIR(POWERQUAD_Type *base, const void *pAData, int32_t ALength, const void *pBData, int32_t BLength, void *pResult, uint32_t opType)
Processing function for the FIR.
- Parameters:
base – POWERQUAD peripheral base address
pAData – the first input sequence
ALength – number of the first input sequence
pBData – the second input sequence
BLength – number of the second input sequence
pResult – array for the output data
opType – operation type, could be PQ_FIR_FIR, PQ_FIR_CONVOLUTION, PQ_FIR_CORRELATION.
-
void PQ_FIRIncrement(POWERQUAD_Type *base, int32_t ALength, int32_t BLength, int32_t xOffset)
Processing function for the incremental FIR. This function can be used after pq_fir() for incremental FIR operation when new x data are available.
- Parameters:
base – POWERQUAD peripheral base address
ALength – number of input samples
BLength – number of taps
xOffset – offset for number of input samples
-
void PQ_MatrixAddition(POWERQUAD_Type *base, uint32_t length, void *pAData, void *pBData, void *pResult)
Processing function for the matrix addition.
- Parameters:
base – POWERQUAD peripheral base address
length – rows and cols for matrix. LENGTH register configuration: LENGTH[23:16] = M2 cols LENGTH[15:8] = M1 cols LENGTH[7:0] = M1 rows This could be constructed using macro POWERQUAD_MAKE_MATRIX_LEN.
pAData – input matrix A
pBData – input matrix B
pResult – array for the output data.
-
void PQ_MatrixSubtraction(POWERQUAD_Type *base, uint32_t length, void *pAData, void *pBData, void *pResult)
Processing function for the matrix subtraction.
- Parameters:
base – POWERQUAD peripheral base address
length – rows and cols for matrix. LENGTH register configuration: LENGTH[23:16] = M2 cols LENGTH[15:8] = M1 cols LENGTH[7:0] = M1 rows This could be constructed using macro POWERQUAD_MAKE_MATRIX_LEN.
pAData – input matrix A
pBData – input matrix B
pResult – array for the output data.
-
void PQ_MatrixMultiplication(POWERQUAD_Type *base, uint32_t length, void *pAData, void *pBData, void *pResult)
Processing function for the matrix multiplication.
- Parameters:
base – POWERQUAD peripheral base address
length – rows and cols for matrix. LENGTH register configuration: LENGTH[23:16] = M2 cols LENGTH[15:8] = M1 cols LENGTH[7:0] = M1 rows This could be constructed using macro POWERQUAD_MAKE_MATRIX_LEN.
pAData – input matrix A
pBData – input matrix B
pResult – array for the output data.
-
void PQ_MatrixProduct(POWERQUAD_Type *base, uint32_t length, void *pAData, void *pBData, void *pResult)
Processing function for the matrix product.
- Parameters:
base – POWERQUAD peripheral base address
length – rows and cols for matrix. LENGTH register configuration: LENGTH[23:16] = M2 cols LENGTH[15:8] = M1 cols LENGTH[7:0] = M1 rows This could be constructed using macro POWERQUAD_MAKE_MATRIX_LEN.
pAData – input matrix A
pBData – input matrix B
pResult – array for the output data.
-
void PQ_VectorDotProduct(POWERQUAD_Type *base, uint32_t length, void *pAData, void *pBData, void *pResult)
Processing function for the vector dot product.
- Parameters:
base – POWERQUAD peripheral base address
length – length of vector
pAData – input vector A
pBData – input vector B
pResult – array for the output data.
-
void PQ_MatrixInversion(POWERQUAD_Type *base, uint32_t length, void *pData, void *pTmpData, void *pResult)
Processing function for the matrix inverse.
- Parameters:
base – POWERQUAD peripheral base address
length – rows and cols for matrix. LENGTH register configuration: LENGTH[23:16] = M2 cols LENGTH[15:8] = M1 cols LENGTH[7:0] = M1 rows This could be constructed using macro POWERQUAD_MAKE_MATRIX_LEN.
pData – input matrix
pTmpData – input temporary matrix, pTmpData length not less than pData lenght and 1024 words is sufficient for the largest supported matrix.
pResult – array for the output data, round down for fixed point.
-
void PQ_MatrixTranspose(POWERQUAD_Type *base, uint32_t length, void *pData, void *pResult)
Processing function for the matrix transpose.
- Parameters:
base – POWERQUAD peripheral base address
length – rows and cols for matrix. LENGTH register configuration: LENGTH[23:16] = M2 cols LENGTH[15:8] = M1 cols LENGTH[7:0] = M1 rows This could be constructed using macro POWERQUAD_MAKE_MATRIX_LEN.
pData – input matrix
pResult – array for the output data.
-
void PQ_MatrixScale(POWERQUAD_Type *base, uint32_t length, float misc, const void *pData, void *pResult)
Processing function for the matrix scale.
- Parameters:
base – POWERQUAD peripheral base address
length – rows and cols for matrix. LENGTH register configuration: LENGTH[23:16] = M2 cols LENGTH[15:8] = M1 cols LENGTH[7:0] = M1 rows This could be constructed using macro POWERQUAD_MAKE_MATRIX_LEN.
misc – scaling parameters
pData – input matrix
pResult – array for the output data.
-
FSL_POWERQUAD_DRIVER_VERSION
Version.
-
enum pq_computationengine_t
powerquad computation engine
Values:
-
enumerator kPQ_CP_PQ
Math engine.
-
enumerator kPQ_CP_MTX
Matrix engine.
-
enumerator kPQ_CP_FFT
FFT engine.
-
enumerator kPQ_CP_FIR
FIR engine.
-
enumerator kPQ_CP_CORDIC
CORDIC engine.
-
enumerator kPQ_CP_PQ
-
enum pq_format_t
powerquad data structure format type
Values:
-
enumerator kPQ_16Bit
Int16 Fixed point.
-
enumerator kPQ_32Bit
Int32 Fixed point.
-
enumerator kPQ_Float
Float point.
-
enumerator kPQ_16Bit
-
enum pq_cordic_iter_t
CORDIC iteration.
Values:
-
enumerator kPQ_Iteration_8
Iterate 8 times.
-
enumerator kPQ_Iteration_16
Iterate 16 times.
-
enumerator kPQ_Iteration_24
Iterate 24 times.
-
enumerator kPQ_Iteration_8
-
typedef struct _pq_biquad_param pq_biquad_param_t
Struct to save biquad parameters.
-
typedef struct _pq_biquad_state pq_biquad_state_t
Struct to save biquad state.
-
typedef union _pq_float pq_float_t
Conversion between integer and float type.
-
PQ_VectorBiqaudDf2F32
-
PQ_VectorBiqaudDf2Fixed32
-
PQ_VectorBiqaudDf2Fixed16
-
PQ_VectorBiqaudCascadeDf2F32
-
PQ_VectorBiqaudCascadeDf2Fixed32
-
PQ_VectorBiqaudCascadeDf2Fixed16
-
PQ_Vector8BiqaudDf2CascadeF32
-
PQ_Vector8BiqaudDf2CascadeFixed32
-
PQ_Vector8BiqaudDf2CascadeFixed16
-
PQ_FLOAT32
-
PQ_FIXEDPT
-
CP_PQ
-
CP_MTX
-
CP_FFT
-
CP_FIR
-
CP_CORDIC
-
PQ_TRANS
-
PQ_TRIG
-
PQ_BIQUAD
-
PQ_TRANS_FIXED
-
PQ_TRIG_FIXED
-
PQ_BIQUAD_FIXED
-
PQ_INV
-
PQ_LN
-
PQ_SQRT
-
PQ_INVSQRT
-
PQ_ETOX
-
PQ_ETONX
-
PQ_DIV
-
PQ_SIN
-
PQ_COS
-
PQ_BIQ0_CALC
-
PQ_BIQ1_CALC
-
PQ_COMP0_ONLY
-
PQ_COMP1_ONLY
-
CORDIC_ITER(x)
-
CORDIC_MIU(x)
-
CORDIC_T(x)
-
CORDIC_ARCTAN
-
CORDIC_ARCTANH
-
INST_BUSY
-
PQ_ERRSTAT_OVERFLOW
-
PQ_ERRSTAT_NAN
-
PQ_ERRSTAT_FIXEDOVERFLOW
-
PQ_ERRSTAT_UNDERFLOW
-
PQ_TRANS_CFFT
-
PQ_TRANS_IFFT
-
PQ_TRANS_CDCT
-
PQ_TRANS_IDCT
-
PQ_TRANS_RFFT
-
PQ_TRANS_RDCT
-
PQ_MTX_SCALE
-
PQ_MTX_MULT
-
PQ_MTX_ADD
-
PQ_MTX_INV
-
PQ_MTX_PROD
-
PQ_MTX_SUB
-
PQ_VEC_DOTP
-
PQ_MTX_TRAN
-
PQ_FIR_FIR
-
PQ_FIR_CONVOLUTION
-
PQ_FIR_CORRELATION
-
PQ_FIR_INCREMENTAL
-
_pq_ln0(x)
-
_pq_inv0(x)
-
_pq_sqrt0(x)
-
_pq_invsqrt0(x)
-
_pq_etox0(x)
-
_pq_etonx0(x)
-
_pq_sin0(x)
-
_pq_cos0(x)
-
_pq_biquad0(x)
-
_pq_ln_fx0(x)
-
_pq_inv_fx0(x)
-
_pq_sqrt_fx0(x)
-
_pq_invsqrt_fx0(x)
-
_pq_etox_fx0(x)
-
_pq_etonx_fx0(x)
-
_pq_sin_fx0(x)
-
_pq_cos_fx0(x)
-
_pq_biquad0_fx(x)
-
_pq_div0(x)
-
_pq_div1(x)
-
_pq_ln1(x)
-
_pq_inv1(x)
-
_pq_sqrt1(x)
-
_pq_invsqrt1(x)
-
_pq_etox1(x)
-
_pq_etonx1(x)
-
_pq_sin1(x)
-
_pq_cos1(x)
-
_pq_biquad1(x)
-
_pq_ln_fx1(x)
-
_pq_inv_fx1(x)
-
_pq_sqrt_fx1(x)
-
_pq_invsqrt_fx1(x)
-
_pq_etox_fx1(x)
-
_pq_etonx_fx1(x)
-
_pq_sin_fx1(x)
-
_pq_cos_fx1(x)
-
_pq_biquad1_fx(x)
-
_pq_readMult0()
-
_pq_readAdd0()
-
_pq_readMult1()
-
_pq_readAdd1()
-
_pq_readMult0_fx()
-
_pq_readAdd0_fx()
-
_pq_readMult1_fx()
-
_pq_readAdd1_fx()
-
PQ_LN_INF
Parameter used for vector ln(x)
-
PQ_INV_INF
Parameter used for vector 1/x
-
PQ_SQRT_INF
Parameter used for vector sqrt(x)
-
PQ_ISQRT_INF
Parameter used for vector 1/sqrt(x)
-
PQ_ETOX_INF
Parameter used for vector e^x
-
PQ_ETONX_INF
Parameter used for vector e^(-x)
-
PQ_SIN_INF
Parameter used for vector sin(x)
-
PQ_COS_INF
Parameter used for vector cos(x)
-
PQ_RUN_OPCODE_R3_R2(BATCH_OPCODE, BATCH_MACHINE)
-
PQ_RUN_OPCODE_R5_R4(BATCH_OPCODE, BATCH_MACHINE)
-
PQ_RUN_OPCODE_R7_R6(BATCH_OPCODE, BATCH_MACHINE)
-
PQ_Vector8_FP(middle, last, BATCH_OPCODE, DOUBLE_READ_ADDERS, BATCH_MACHINE)
-
PQ_RUN_OPCODE_R2_R3(BATCH_OPCODE, BATCH_MACHINE)
-
PQ_RUN_OPCODE_R4_R5(BATCH_OPCODE, BATCH_MACHINE)
-
PQ_RUN_OPCODE_R6_R7(BATCH_OPCODE, BATCH_MACHINE)
-
PQ_Vector8_FX(middle, last, BATCH_OPCODE, DOUBLE_READ_ADDERS, BATCH_MACHINE)
-
PQ_Initiate_Vector_Func(pSrc, pDst)
Start 32-bit data vector calculation.
Start the vector calculation, the input data could be float, int32_t or Q31.
- Parameters:
pSrc – Pointer to the source data.
pDst – Pointer to the destination data.
-
PQ_End_Vector_Func()
End vector calculation.
This function should be called after vector calculation.
-
PQ_StartVector(PSRC, PDST, LENGTH)
Start 32-bit data vector calculation.
Start the vector calculation, the input data could be float, int32_t or Q31.
- Parameters:
PSRC – Pointer to the source data.
PDST – Pointer to the destination data.
LENGTH – Number of the data, must be multiple of 8.
-
PQ_StartVectorFixed16(PSRC, PDST, LENGTH)
Start 16-bit data vector calculation.
Start the vector calculation, the input data could be int16_t. This function should be use with PQ_Vector8Fixed16.
- Parameters:
PSRC – Pointer to the source data.
PDST – Pointer to the destination data.
LENGTH – Number of the data, must be multiple of 8.
-
PQ_StartVectorQ15(PSRC, PDST, LENGTH)
Start Q15-bit data vector calculation.
Start the vector calculation, the input data could be Q15. This function should be use with PQ_Vector8Q15. This function is dedicate for SinQ15/CosQ15 vector calculation. Because PowerQuad only supports Q31 Sin/Cos fixed function, so the input Q15 data is left shift 16 bits first, after Q31 calculation, the output data is right shift 16 bits.
- Parameters:
PSRC – Pointer to the source data.
PDST – Pointer to the destination data.
LENGTH – Number of the data, must be multiple of 8.
-
PQ_EndVector()
End vector calculation.
This function should be called after vector calculation.
-
PQ_Vector8F32(BATCH_OPCODE, DOUBLE_READ_ADDERS, BATCH_MACHINE)
Float data vector calculation.
Float data vector calculation, the input data should be float. The parameter could be PQ_LN_INF, PQ_INV_INF, PQ_SQRT_INF, PQ_ISQRT_INF, PQ_ETOX_INF, PQ_ETONX_INF. For example, to calculate sqrt of a vector, use like this:
#define VECTOR_LEN 8 float input[VECTOR_LEN] = {1.0, 2.0, 3.0, 4.0, 5.0, 6.0, 7.0, 8.0}; float output[VECTOR_LEN]; PQ_StartVector(input, output, VECTOR_LEN); PQ_Vector8F32(PQ_SQRT_INF); PQ_EndVector();
-
PQ_Vector8Fixed32(BATCH_OPCODE, DOUBLE_READ_ADDERS, BATCH_MACHINE)
Fixed 32bits data vector calculation.
Float data vector calculation, the input data should be 32-bit integer. The parameter could be PQ_LN_INF, PQ_INV_INF, PQ_SQRT_INF, PQ_ISQRT_INF, PQ_ETOX_INF, PQ_ETONX_INF. PQ_SIN_INF, PQ_COS_INF. When this function is used for sin/cos calculation, the input data should be in the format Q1.31. For example, to calculate sqrt of a vector, use like this:
#define VECTOR_LEN 8 int32_t input[VECTOR_LEN] = {1, 4, 9, 16, 25, 36, 49, 64}; int32_t output[VECTOR_LEN]; PQ_StartVector(input, output, VECTOR_LEN); PQ_Vector8F32(PQ_SQRT_INF); PQ_EndVector();
-
PQ_Vector8Fixed16(BATCH_OPCODE, DOUBLE_READ_ADDERS, BATCH_MACHINE)
Fixed 32bits data vector calculation.
Float data vector calculation, the input data should be 16-bit integer. The parameter could be PQ_LN_INF, PQ_INV_INF, PQ_SQRT_INF, PQ_ISQRT_INF, PQ_ETOX_INF, PQ_ETONX_INF. For example, to calculate sqrt of a vector, use like this:
#define VECTOR_LEN 8 int16_t input[VECTOR_LEN] = {1, 4, 9, 16, 25, 36, 49, 64}; int16_t output[VECTOR_LEN]; PQ_StartVector(input, output, VECTOR_LEN); PQ_Vector8F32(PQ_SQRT_INF); PQ_EndVector();
-
PQ_Vector8Q15(BATCH_OPCODE, DOUBLE_READ_ADDERS, BATCH_MACHINE)
Q15 data vector calculation.
Q15 data vector calculation, this function should only be used for sin/cos Q15 calculation, and the coprocessor output prescaler must be set to 31 before this function. This function loads Q15 data and left shift 16 bits, calculate and right shift 16 bits, then stores to the output array. The input range -1 to 1 means -pi to pi. For example, to calculate sin of a vector, use like this:
#define VECTOR_LEN 8 int16_t input[VECTOR_LEN] = {...} int16_t output[VECTOR_LEN]; const pq_prescale_t prescale = { .inputPrescale = 0, .outputPrescale = 31, .outputSaturate = 0 }; PQ_SetCoprocessorScaler(POWERQUAD, const pq_prescale_t *prescale); PQ_StartVectorQ15(pSrc, pDst, length); PQ_Vector8Q15(PQ_SQRT_INF); PQ_EndVector();
-
PQ_DF2_Vector8_FP(middle, last)
Float data vector biquad direct form II calculation.
Biquad filter, the input and output data are float data. Biquad side 0 is used. Example:
#define VECTOR_LEN 16 float input[VECTOR_LEN] = {1024.0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}; float output[VECTOR_LEN]; pq_biquad_state_t state = { .param = { .a_1 = xxx, .a_2 = xxx, .b_0 = xxx, .b_1 = xxx, .b_2 = xxx, }, }; PQ_BiquadRestoreInternalState(POWERQUAD, 0, &state); PQ_Initiate_Vector_Func(pSrc,pDst); PQ_DF2_Vector8_FP(false,false); PQ_DF2_Vector8_FP(true,true); PQ_End_Vector_Func();
-
PQ_DF2_Vector8_FX(middle, last)
Fixed data vector biquad direct form II calculation.
Biquad filter, the input and output data are fixed data. Biquad side 0 is used. Example:
#define VECTOR_LEN 16 int32_t input[VECTOR_LEN] = {1024, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}; int32_t output[VECTOR_LEN]; pq_biquad_state_t state = { .param = { .a_1 = xxx, .a_2 = xxx, .b_0 = xxx, .b_1 = xxx, .b_2 = xxx, }, }; PQ_BiquadRestoreInternalState(POWERQUAD, 0, &state); PQ_Initiate_Vector_Func(pSrc,pDst); PQ_DF2_Vector8_FX(false,false); PQ_DF2_Vector8_FX(true,true); PQ_End_Vector_Func();
-
PQ_Vector8BiquadDf2F32()
Float data vector biquad direct form II calculation.
Biquad filter, the input and output data are float data. Biquad side 0 is used. Example:
#define VECTOR_LEN 8 float input[VECTOR_LEN] = {1.0, 2.0, 3.0, 4.0, 5.0, 6.0, 7.0, 8.0}; float output[VECTOR_LEN]; pq_biquad_state_t state = { .param = { .a_1 = xxx, .a_2 = xxx, .b_0 = xxx, .b_1 = xxx, .b_2 = xxx, }, }; PQ_BiquadRestoreInternalState(POWERQUAD, 0, &state); PQ_StartVector(input, output, VECTOR_LEN); PQ_Vector8BiquadDf2F32(); PQ_EndVector();
-
PQ_Vector8BiquadDf2Fixed32()
Fixed 32-bit data vector biquad direct form II calculation.
Biquad filter, the input and output data are Q31 or 32-bit integer. Biquad side 0 is used. Example:
#define VECTOR_LEN 8 int32_t input[VECTOR_LEN] = {1, 2, 3, 4, 5, 6, 7, 8}; int32_t output[VECTOR_LEN]; pq_biquad_state_t state = { .param = { .a_1 = xxx, .a_2 = xxx, .b_0 = xxx, .b_1 = xxx, .b_2 = xxx, }, }; PQ_BiquadRestoreInternalState(POWERQUAD, 0, &state); PQ_StartVector(input, output, VECTOR_LEN); PQ_Vector8BiquadDf2Fixed32(); PQ_EndVector();
-
PQ_Vector8BiquadDf2Fixed16()
Fixed 16-bit data vector biquad direct form II calculation.
Biquad filter, the input and output data are Q15 or 16-bit integer. Biquad side 0 is used. Example:
#define VECTOR_LEN 8 int16_t input[VECTOR_LEN] = {1, 2, 3, 4, 5, 6, 7, 8}; int16_t output[VECTOR_LEN]; pq_biquad_state_t state = { .param = { .a_1 = xxx, .a_2 = xxx, .b_0 = xxx, .b_1 = xxx, .b_2 = xxx, }, }; PQ_BiquadRestoreInternalState(POWERQUAD, 0, &state); PQ_StartVector(input, output, VECTOR_LEN); PQ_Vector8BiquadDf2Fixed16(); PQ_EndVector();
-
PQ_DF2_Cascade_Vector8_FP(middle, last)
Float data vector direct form II biquad cascade filter.
The input and output data are float data. The data flow is input -> biquad side 1 -> biquad side 0 -> output.
#define VECTOR_LEN 16 float input[VECTOR_LEN] = {1024.0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}; float output[VECTOR_LEN]; pq_biquad_state_t state0 = { .param = { .a_1 = xxx, .a_2 = xxx, .b_0 = xxx, .b_1 = xxx, .b_2 = xxx, }, }; pq_biquad_state_t state1 = { .param = { .a_1 = xxx, .a_2 = xxx, .b_0 = xxx, .b_1 = xxx, .b_2 = xxx, }, }; PQ_BiquadRestoreInternalState(POWERQUAD, 0, &state0); PQ_BiquadRestoreInternalState(POWERQUAD, 1, &state1); PQ_Initiate_Vector_Func(pSrc, pDst); PQ_DF2_Cascade_Vector8_FP(false, false); PQ_DF2_Cascade_Vector8_FP(true, true); PQ_End_Vector_Func();
-
PQ_DF2_Cascade_Vector8_FX(middle, last)
Fixed data vector direct form II biquad cascade filter.
The input and output data are fixed data. The data flow is input -> biquad side 1 -> biquad side 0 -> output.
#define VECTOR_LEN 16 int32_t input[VECTOR_LEN] = {1024.0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}; int32_t output[VECTOR_LEN]; pq_biquad_state_t state0 = { .param = { .a_1 = xxx, .a_2 = xxx, .b_0 = xxx, .b_1 = xxx, .b_2 = xxx, }, }; pq_biquad_state_t state1 = { .param = { .a_1 = xxx, .a_2 = xxx, .b_0 = xxx, .b_1 = xxx, .b_2 = xxx, }, }; PQ_BiquadRestoreInternalState(POWERQUAD, 0, &state0); PQ_BiquadRestoreInternalState(POWERQUAD, 1, &state1); PQ_Initiate_Vector_Func(pSrc, pDst); PQ_DF2_Cascade_Vector8_FX(false, false); PQ_DF2_Cascade_Vector8_FX(true, true); PQ_End_Vector_Func();
-
PQ_Vector8BiquadDf2CascadeF32()
Float data vector direct form II biquad cascade filter.
The input and output data are float data. The data flow is input -> biquad side 1 -> biquad side 0 -> output.
#define VECTOR_LEN 8 float input[VECTOR_LEN] = {1, 2, 3, 4, 5, 6, 7, 8}; float output[VECTOR_LEN]; pq_biquad_state_t state0 = { .param = { .a_1 = xxx, .a_2 = xxx, .b_0 = xxx, .b_1 = xxx, .b_2 = xxx, }, }; pq_biquad_state_t state1 = { .param = { .a_1 = xxx, .a_2 = xxx, .b_0 = xxx, .b_1 = xxx, .b_2 = xxx, }, }; PQ_BiquadRestoreInternalState(POWERQUAD, 0, &state0); PQ_BiquadRestoreInternalState(POWERQUAD, 1, &state1); PQ_StartVector(input, output, VECTOR_LEN); PQ_Vector8BiquadDf2CascadeF32(); PQ_EndVector();
-
PQ_Vector8BiquadDf2CascadeFixed32()
Fixed 32-bit data vector direct form II biquad cascade filter.
The input and output data are fixed 32-bit data. The data flow is input -> biquad side 1 -> biquad side 0 -> output.
#define VECTOR_LEN 8 int32_t input[VECTOR_LEN] = {1, 2, 3, 4, 5, 6, 7, 8}; int32_t output[VECTOR_LEN]; pq_biquad_state_t state0 = { .param = { .a_1 = xxx, .a_2 = xxx, .b_0 = xxx, .b_1 = xxx, .b_2 = xxx, }, }; pq_biquad_state_t state1 = { .param = { .a_1 = xxx, .a_2 = xxx, .b_0 = xxx, .b_1 = xxx, .b_2 = xxx, }, }; PQ_BiquadRestoreInternalState(POWERQUAD, 0, &state0); PQ_BiquadRestoreInternalState(POWERQUAD, 1, &state1); PQ_StartVector(input, output, VECTOR_LEN); PQ_Vector8BiquadDf2CascadeFixed32(); PQ_EndVector();
-
PQ_Vector8BiquadDf2CascadeFixed16()
Fixed 16-bit data vector direct form II biquad cascade filter.
The input and output data are fixed 16-bit data. The data flow is input -> biquad side 1 -> biquad side 0 -> output.
#define VECTOR_LEN 8 int32_t input[VECTOR_LEN] = {1, 2, 3, 4, 5, 6, 7, 8}; int32_t output[VECTOR_LEN]; pq_biquad_state_t state0 = { .param = { .a_1 = xxx, .a_2 = xxx, .b_0 = xxx, .b_1 = xxx, .b_2 = xxx, }, }; pq_biquad_state_t state1 = { .param = { .a_1 = xxx, .a_2 = xxx, .b_0 = xxx, .b_1 = xxx, .b_2 = xxx, }, }; PQ_BiquadRestoreInternalState(POWERQUAD, 0, &state0); PQ_BiquadRestoreInternalState(POWERQUAD, 1, &state1); PQ_StartVector(input, output, VECTOR_LEN); PQ_Vector8BiquadDf2CascadeFixed16(); PQ_EndVector();
-
POWERQUAD_MAKE_MATRIX_LEN(mat1Row, mat1Col, mat2Col)
Make the length used for matrix functions.
-
PQ_Q31_2_FLOAT(x)
Convert Q31 to float.
-
PQ_Q15_2_FLOAT(x)
Convert Q15 to float.
-
struct pq_prescale_t
- #include <fsl_powerquad.h>
Coprocessor prescale.
Public Members
-
int8_t inputPrescale
Input prescale.
-
int8_t outputPrescale
Output prescale.
-
int8_t outputSaturate
Output saturate at n bits, for example 0x11 is 8 bit space, the value will be truncated at +127 or -128.
-
int8_t inputPrescale
-
struct pq_config_t
- #include <fsl_powerquad.h>
powerquad data structure format
Public Members
-
pq_format_t inputAFormat
Input A format.
-
int8_t inputAPrescale
Input A prescale, for example 1.5 can be 1.5*2^n if you scale by ‘shifting’ (‘scaling’ by a factor of n).
-
pq_format_t inputBFormat
Input B format.
-
int8_t inputBPrescale
Input B prescale.
-
pq_format_t outputFormat
Out format.
-
int8_t outputPrescale
Out prescale.
-
pq_format_t tmpFormat
Temp format.
-
int8_t tmpPrescale
Temp prescale.
-
pq_format_t machineFormat
Machine format.
-
uint32_t *tmpBase
Tmp base address.
-
pq_format_t inputAFormat
-
struct _pq_biquad_param
- #include <fsl_powerquad.h>
Struct to save biquad parameters.
Public Members
-
float v_n_1
v[n-1], set to 0 when initialization.
-
float v_n
v[n], set to 0 when initialization.
-
float a_1
a[1]
-
float a_2
a[2]
-
float b_0
b[0]
-
float b_1
b[1]
-
float b_2
b[2]
-
float v_n_1
-
struct _pq_biquad_state
- #include <fsl_powerquad.h>
Struct to save biquad state.
Public Members
-
pq_biquad_param_t param
Filter parameter.
-
uint32_t compreg
Internal register, set to 0 when initialization.
-
pq_biquad_param_t param
-
struct pq_biquad_cascade_df2_instance
- #include <fsl_powerquad.h>
Instance structure for the direct form II Biquad cascade filter.
Public Members
-
uint8_t numStages
Number of 2nd order stages in the filter.
-
pq_biquad_state_t *pState
Points to the array of state coefficients.
-
uint8_t numStages
-
union _pq_float
- #include <fsl_powerquad.h>
Conversion between integer and float type.
Public Members
-
float floatX
Float type.
-
uint32_t integerX
Unsigned interger type.
-
float floatX
PRINCE: PRINCE bus crypto engine
-
FSL_PRINCE_DRIVER_VERSION
PRINCE driver version 2.6.0.
Current version: 2.6.0
Change log:
Version 2.0.0
Initial version.
Version 2.1.0
Update for the A1 rev. of LPC55Sxx serie.
Version 2.2.0
Add runtime checking of the A0 and A1 rev. of LPC55Sxx serie to support both silicone revisions.
Version 2.3.0
Add support for LPC55S1x and LPC55S2x series
Version 2.3.0
Fix MISRA-2012 issues.
Version 2.3.1
Add support for LPC55S0x series
Version 2.3.2
Fix documentation of enumeration. Extend PRINCE example.
Version 2.4.0
Add support for LPC55S3x series
Version 2.5.0
Add PRINCE_Config() and PRINCE_Reconfig() features.
Version 2.5.1
Fix build error due to renamed symbols
Version 2.6.0
Renamed CSS to ELS
-
enum _skboot_status
Secure status enumeration.
Values:
-
enumerator kStatus_SKBOOT_Success
PRINCE Success
-
enumerator kStatus_SKBOOT_Fail
PRINCE Fail
-
enumerator kStatus_SKBOOT_InvalidArgument
PRINCE Invalid argument
-
enumerator kStatus_SKBOOT_KeyStoreMarkerInvalid
PRINCE Invalid marker
-
enumerator kStatus_SKBOOT_Success
-
enum _secure_bool
Secure boolean enumeration.
Values:
-
enumerator kSECURE_TRUE
PRINCE true
-
enumerator kSECURE_FALSE
PRINCE false
-
enumerator kSECURE_TRUE
-
enum _prince_region
Prince region.
Values:
-
enumerator kPRINCE_Region0
PRINCE region 0
-
enumerator kPRINCE_Region1
PRINCE region 1
-
enumerator kPRINCE_Region2
PRINCE region 2
-
enumerator kPRINCE_Region0
-
enum _prince_lock
Prince lock.
Values:
-
enumerator kPRINCE_Region0Lock
PRINCE region 0 lock
-
enumerator kPRINCE_Region1Lock
PRINCE region 1 lock
-
enumerator kPRINCE_Region2Lock
PRINCE region 2 lock
-
enumerator kPRINCE_MaskLock
PRINCE mask register lock
-
enumerator kPRINCE_Region0Lock
-
enum _prince_flags
Prince flag.
Values:
-
enumerator kPRINCE_Flag_None
PRINCE Flag None
-
enumerator kPRINCE_Flag_EraseCheck
PRINCE Flag Erase check
-
enumerator kPRINCE_Flag_WriteCheck
PRINCE Flag Write check
-
enumerator kPRINCE_Flag_None
-
typedef enum _skboot_status skboot_status_t
Secure status enumeration.
-
typedef enum _secure_bool secure_bool_t
Secure boolean enumeration.
-
typedef enum _prince_region prince_region_t
Prince region.
-
typedef enum _prince_lock prince_lock_t
Prince lock.
-
typedef enum _prince_flags prince_flags_t
Prince flag.
-
static inline void PRINCE_EncryptEnable(PRINCE_Type *base)
Enable data encryption.
This function enables PRINCE on-the-fly data encryption.
- Parameters:
base – PRINCE peripheral address.
-
static inline void PRINCE_EncryptDisable(PRINCE_Type *base)
Disable data encryption.
This function disables PRINCE on-the-fly data encryption.
- Parameters:
base – PRINCE peripheral address.
-
static inline bool PRINCE_IsEncryptEnable(PRINCE_Type *base)
Is Enable data encryption.
This function test if PRINCE on-the-fly data encryption is enabled.
- Parameters:
base – PRINCE peripheral address.
- Returns:
true if enabled, false if not
-
static inline void PRINCE_SetMask(PRINCE_Type *base, uint64_t mask)
Sets PRINCE data mask.
This function sets the PRINCE mask that is used to mask decrypted data.
- Parameters:
base – PRINCE peripheral address.
mask – 64-bit data mask value.
-
static inline void PRINCE_SetLock(PRINCE_Type *base, uint32_t lock)
Locks access for specified region registers or data mask register.
This function sets lock on specified region registers or mask register.
- Parameters:
base – PRINCE peripheral address.
lock – registers to lock. This is a logical OR of members of the enumeration prince_lock_t
-
status_t PRINCE_GenNewIV(prince_region_t region, uint8_t *iv_code, bool store, flash_config_t *flash_context)
Generate new IV code.
This function generates new IV code and stores it into the persistent memory. Ensure about 800 bytes free space on the stack when calling this routine with the store parameter set to true!
- Parameters:
region – PRINCE region index.
iv_code – IV code pointer used for storing the newly generated 52 bytes long IV code.
store – flag to allow storing the newly generated IV code into the persistent memory (FFR).
flash_context – pointer to the flash driver context structure.
- Returns:
kStatus_Success upon success
- Returns:
kStatus_Fail otherwise, kStatus_Fail is also returned if the key code for the particular PRINCE region is not present in the keystore (though new IV code has been provided)
-
status_t PRINCE_LoadIV(prince_region_t region, uint8_t *iv_code)
Load IV code.
This function enables IV code loading into the PRINCE bus encryption engine.
- Parameters:
region – PRINCE region index.
iv_code – IV code pointer used for passing the IV code.
- Returns:
kStatus_Success upon success
- Returns:
kStatus_Fail otherwise
-
status_t PRINCE_SetEncryptForAddressRange(prince_region_t region, uint32_t start_address, uint32_t length, flash_config_t *flash_context, bool regenerate_iv)
Allow encryption/decryption for specified address range.
This function sets the encryption/decryption for specified address range. The SR mask value for the selected Prince region is calculated from provided start_address and length parameters. This calculated value is OR’ed with the actual SR mask value and stored into the PRINCE SR_ENABLE register and also into the persistent memory (FFR) to be used after the device reset. It is possible to define several nonadjacent encrypted areas within one Prince region when calling this function repeatedly. If the length parameter is set to 0, the SR mask value is set to 0 and thus the encryption/decryption for the whole selected Prince region is disabled. Ensure about 800 bytes free space on the stack when calling this routine!
- Parameters:
region – PRINCE region index.
start_address – start address of the area to be encrypted/decrypted.
length – length of the area to be encrypted/decrypted.
flash_context – pointer to the flash driver context structure.
regenerate_iv – flag to allow IV code regenerating, storing into the persistent memory (FFR) and loading into the PRINCE engine
- Returns:
kStatus_Success upon success
- Returns:
kStatus_Fail otherwise
-
status_t PRINCE_GetRegionSREnable(PRINCE_Type *base, prince_region_t region, uint32_t *sr_enable)
Gets the PRINCE Sub-Region Enable register.
This function gets PRINCE SR_ENABLE register.
- Parameters:
base – PRINCE peripheral address.
region – PRINCE region index.
sr_enable – Sub-Region Enable register pointer.
- Returns:
kStatus_Success upon success
- Returns:
kStatus_InvalidArgument
-
status_t PRINCE_GetRegionBaseAddress(PRINCE_Type *base, prince_region_t region, uint32_t *region_base_addr)
Gets the PRINCE region base address register.
This function gets PRINCE BASE_ADDR register.
- Parameters:
base – PRINCE peripheral address.
region – PRINCE region index.
region_base_addr – Region base address pointer.
- Returns:
kStatus_Success upon success
- Returns:
kStatus_InvalidArgument
-
status_t PRINCE_SetRegionIV(PRINCE_Type *base, prince_region_t region, const uint8_t iv[8])
Sets the PRINCE region IV.
This function sets specified AES IV for the given region.
- Parameters:
base – PRINCE peripheral address.
region – Selection of the PRINCE region to be configured.
iv – 64-bit AES IV in little-endian byte order.
-
status_t PRINCE_SetRegionBaseAddress(PRINCE_Type *base, prince_region_t region, uint32_t region_base_addr)
Sets the PRINCE region base address.
This function configures PRINCE region base address.
- Parameters:
base – PRINCE peripheral address.
region – Selection of the PRINCE region to be configured.
region_base_addr – Base Address for region.
-
status_t PRINCE_SetRegionSREnable(PRINCE_Type *base, prince_region_t region, uint32_t sr_enable)
Sets the PRINCE Sub-Region Enable register.
This function configures PRINCE SR_ENABLE register.
- Parameters:
base – PRINCE peripheral address.
region – Selection of the PRINCE region to be configured.
sr_enable – Sub-Region Enable register value.
-
status_t PRINCE_FlashEraseWithChecker(flash_config_t *config, uint32_t start, uint32_t lengthInBytes, uint32_t key)
Erases the flash sectors encompassed by parameters passed into function.
This function erases the appropriate number of flash sectors based on the desired start address and length. It deals with the flash erase function complenentary to the standard erase API of the IAP1 driver. This implementation additionally checks if the whole encrypted PRINCE subregions are erased at once to avoid secrets revealing. The checker implementation is limited to one contiguous PRINCE-controlled memory area.
- Parameters:
config – The pointer to the flash driver context structure.
start – The start address of the desired flash memory to be erased. The start address needs to be prince-sburegion-aligned.
lengthInBytes – The length, given in bytes (not words or long-words) to be erased. Must be prince-sburegion-size-aligned.
key – The value used to validate all flash erase APIs.
- Returns:
kStatus_FLASH_Success API was executed successfully.
- Returns:
kStatus_FLASH_InvalidArgument An invalid argument is provided.
- Returns:
kStatus_FLASH_AlignmentError The parameter is not aligned with the specified baseline.
- Returns:
kStatus_FLASH_AddressError The address is out of range.
- Returns:
kStatus_FLASH_EraseKeyError The API erase key is invalid.
- Returns:
kStatus_FLASH_CommandFailure Run-time error during the command execution.
- Returns:
kStatus_FLASH_CommandNotSupported Flash API is not supported.
- Returns:
kStatus_FLASH_EccError A correctable or uncorrectable error during command execution.
- Returns:
kStatus_FLASH_EncryptedRegionsEraseNotDoneAtOnce Encrypted flash subregions are not erased at once.
-
status_t PRINCE_FlashProgramWithChecker(flash_config_t *config, uint32_t start, uint8_t *src, uint32_t lengthInBytes)
Programs flash with data at locations passed in through parameters.
This function programs the flash memory with the desired data for a given flash area as determined by the start address and the length. It deals with the flash program function complenentary to the standard program API of the IAP1 driver. This implementation additionally checks if the whole PRINCE subregions are programmed at once to avoid secrets revealing. The checker implementation is limited to one contiguous PRINCE-controlled memory area.
- Parameters:
config – The pointer to the flash driver context structure.
start – The start address of the desired flash memory to be programmed. Must be prince-sburegion-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 prince-sburegion-size-aligned.
- Returns:
kStatus_FLASH_Success API was executed successfully.
- Returns:
kStatus_FLASH_InvalidArgument An invalid argument is provided.
- Returns:
kStatus_FLASH_AlignmentError Parameter is not aligned with the specified baseline.
- Returns:
kStatus_FLASH_AddressError Address is out of range.
- Returns:
kStatus_FLASH_AccessError Invalid instruction codes and out-of bounds addresses.
- Returns:
kStatus_FLASH_CommandFailure Run-time error during the command execution.
- Returns:
kStatus_FLASH_CommandFailure Run-time error during the command execution.
- Returns:
kStatus_FLASH_CommandNotSupported Flash API is not supported.
- Returns:
kStatus_FLASH_EccError A correctable or uncorrectable error during command execution.
- Returns:
kStatus_FLASH_SizeError Encrypted flash subregions are not programmed at once.
-
FSL_PRINCE_DRIVER_SUBREGION_SIZE_IN_KB
-
FSL_PRINCE_DRIVER_MAX_FLASH_ADDR
-
ALIGN_DOWN(x, a)
PUF: Physical Unclonable Function
Puf_v3_driver
-
FSL_PUF_V3_DRIVER_VERSION
PUFv3 driver version. Version 2.0.3.
Current version: 2.0.3
Change log:
2.0.3
Update for various PUF CTRL wrapper
2.0.2
Fix MISRA issue in driver.
2.0.1
Fix PUF initialization issue and update driver to reflect SoC header changes.
2.0.0
Initial version.
Values:
-
enumerator kStatus_PUF_OperationNotAllowed
-
enumerator kStatus_PUF_AcNotForThisProductPhase1
-
enumerator kStatus_PUF_AcNotForThisProductPhase2
-
enumerator kStatus_PUF_AcCorruptedPhase1
-
enumerator kStatus_PUF_AcCorruptedPhase2
-
enumerator kStatus_PUF_AcAuthFailedPhase1
-
enumerator kStatus_PUF_NBOOT_AcAuthFailedPhase2
-
enumerator kStatus_PUF_QualityVerificationFail
-
enumerator kStatus_PUF_ContextIncorrect
-
enumerator kStatus_PUF_DestinationNotAllowed
-
enumerator kStatus_PUF_Failure
-
enumerator kStatus_PUF_OperationNotAllowed
-
typedef uint32_t puf_endianness_t
-
typedef uint32_t puf_key_dest_t
-
typedef uint32_t puf_key_scope_t
-
typedef uint32_t puf_result_code_t
-
typedef uint32_t puf_sec_level_t
-
puf_endianness_t dataEndianness
-
uint8_t CKGATING
-
puf_key_scope_t keyScopeStarted
-
puf_key_scope_t keyScopeEnrolled
-
uint32_t userCtx0
-
uint32_t userCtx1
-
void PUF_GetDefaultConfig(puf_config_t *conf)
brief Sets the default configuration of PUF
This function initialize PUF config structure to default values.
- Parameters:
conf – PUF configuration structure
-
status_t PUF_Init(PUF_Type *base, puf_config_t *conf)
brief Initialize PUF
This function enables power to PUF block and waits until the block initializes.
- Parameters:
conf – PUF configuration structure
- Returns:
Status of the init operation
-
void PUF_Deinit(PUF_Type *base, puf_config_t *conf)
brief Denitialize PUF
This function disables power to PUF SRAM and peripheral clock.
- Parameters:
base – PUF peripheral base address
conf – PUF configuration structure
-
status_t PUF_Enroll(PUF_Type *base, uint8_t *activationCode, size_t activationCodeSize, uint8_t *score)
brief Enroll PUF
This function derives a digital fingerprint, generates the corresponding Activation Code (AC) and returns it to be stored in an NVM or a file. This step needs to be performed only once for each device. This function may be permanently disallowed by a fuse.
- Parameters:
base – PUF peripheral base address
activationCode – [out] Word aligned address of the resulting activation code.
activationCodeSize – Size of the activationCode buffer in bytes. Shall be FSL_FEATURE_PUF_ACTIVATION_CODE_SIZE bytes.
score – Value of the PUF Score that was obtained during the enroll operation.
- Returns:
Status of enroll operation.
-
status_t PUF_Start(PUF_Type *base, const uint8_t *activationCode, size_t activationCodeSize, uint8_t *score)
brief Start PUF
The Activation Code generated during the Enroll operation is used to reconstruct the digital fingerprint. This needs to be done after every power-up and reset.
- Parameters:
base – PUF peripheral base address
activationCode – [in] Word aligned address of the input activation code.
activationCodeSize – Size of the activationCode buffer in bytes. Shall be FSL_FEATURE_PUF_ACTIVATION_CODE_SIZE bytes.
score – Value of the PUF Score that was obtained during the start operation. return Status of start operation.
-
status_t PUF_Stop(PUF_Type *base)
brief Stop PUF
The Stop operation removes all key material from PUF flipflops and PUF SRAM, and sets PUF to the Stopped state.
- Parameters:
base – PUF peripheral base address
- Returns:
Status of stop operation.
-
status_t PUF_GetKey(PUF_Type *base, puf_key_ctx_t *keyCtx, puf_key_dest_t keyDest, uint8_t *key, size_t keySize)
brief PUF Get Key
The Get Key operation derives a key from the intrinsic PUF key and externally provided context.
- Parameters:
base – PUF peripheral base address
keyCtx – PUF key context struct
keyDest – output destination of the derived PUF key
key – [out] Word aligned address of output key (only used when kPUF_KeyDestRegister).
keySize – Size of the derived key in bytes.
- Returns:
Status of get key operation.
-
status_t PUF_WrapGeneratedRandom(PUF_Type *base, puf_key_ctx_t *keyCtx, size_t keySize, uint8_t *keyCode, size_t keyCodeSize)
brief PUF Wrap generated random
The Wrap Generated Random operation wraps a random key into a Key Code (KC).
- Parameters:
base – PUF peripheral base address
keyCtx – PUF key context struct
keySize – Size of the key to be generated in bytes.
keyCode – [out] Word aligned address of the resulting key code.
keyCodeSize – Size of the output keycode in bytes.
- Returns:
Status of wrap generated random operation.
-
status_t PUF_Wrap(PUF_Type *base, puf_key_ctx_t *keyCtx, uint8_t *userKey, size_t userKeySize, uint8_t *keyCode, size_t keyCodeSize)
brief PUF Wrap user key
The Wrap operation wraps a user defined key into a Key Code (KC).
- Parameters:
base – PUF peripheral base address
keyCtx – PUF key context struct.
userKey – Word aligned address of input user key.
userKeySize – Size of the key to be wrapped in bytes.
keyCode – [out] Word aligned address of the resulting key code.
keyCodeSize – Size of the output keycode in bytes.
- Returns:
Status of wrap operation.
-
status_t PUF_Unwrap(PUF_Type *base, puf_key_dest_t keyDest, uint8_t *keyCode, size_t keyCodeSize, uint8_t *key, size_t keySize)
brief PUF Unwrap user key
The unwrap operation unwraps the key from a previously created Key Code (KC)
- Parameters:
base – PUF peripheral base address
keyDest – output destination of the unwraped PUF key
keyCode – [in] Word aligned address of the input key code.
keyCodeSize – Size of the input keycode in bytes.
key – Word aligned address of output key (only used when kPUF_KeyDestRegister).
keySize – Size of the key to be generated in bytes.
- Returns:
Status of unwrap operation.
-
status_t PUF_GenerateRandom(PUF_Type *base, uint8_t *data, size_t size)
brief Generate Random
The Generate Random operation outputs the requested amount of random data as specified in a provided context.
- Parameters:
base – PUF peripheral base address
size – Size of random data to be genarated in bytes.
- Returns:
Status of generate random operation.
-
status_t PUF_Zeroize(PUF_Type *base)
brief Zeroize PUF
This function clears all PUF internal logic and puts the PUF to zeroized state.
- Parameters:
base – PUF peripheral base address
- Returns:
Status of the zeroize operation.
-
status_t PUF_Test(PUF_Type *base, uint8_t *score)
brief Test PUF
With the Test PUF operation, diagnostics about the PUF quality is collected and presented in a PUF score.
- Parameters:
base – PUF peripheral base address
score – Value of the PUF Score that was obtained during the enroll operation.
- Returns:
Status of the test operation.
-
static inline void PUF_BlockCommand(PUF_Type *base, uint32_t mask)
Blocks specified PUF commands.
This function blocks PUF commands specified by mask parameter.
- Parameters:
base – PUF peripheral base address
mask – Mask of parameters which should be blocked until power-cycle.
- Returns:
Status of the test operation.
-
status_t PUF_SetLock(PUF_Type *base, puf_sec_level_t securityLevel)
brief Set lock of PUF operation
Lock the security level of PUF block until key generate, wrap or unwrap operation is completed. Note: Only security level defined in SEC_LOCK register can use PUFv3 or change its security level. Default setting after leaving ROM is Secure-Privilege
- Parameters:
base – PUF peripheral base address
securityLevel – Security level of PUF block.
- Returns:
Status of the test operation.
-
status_t PUF_SetCtxMask(PUF_Type *base, uint32_t appCtxMask)
brief Set App Context mask
This function sets Application defined context mask used in conjunction with key user context 2. Whenever bit in this register is 1, corresponding bit in user context 2 provided during key code creation should be zero only.
This register is only modifiable by task running at secure-privilege level.
- Parameters:
base – PUF peripheral base address
appCtxMask – Value of the Application defined context mask.
- Returns:
Status of the test operation.
-
kPUF_EndianLittle
-
kPUF_EndianBig
-
kPUF_KeyDestRegister
-
kPUF_KeyDestKeyBus
-
kPUF_KeyDestInvalid
-
kPUF_KeyAllowRegister
-
kPUF_KeyAllowKeyBus
-
kPUF_KeyAllowAll
-
kPUF_ResultOK
-
kPUF_AcNotForThisProductPhase1
-
kPUF_AcNotForThisProductPhase2
-
kPUF_AcCorruptedPhase1
-
kPUF_AcCorruptedPhase2
-
kPUF_AcAuthFailedPhase1
-
kPUF_AcAuthFailedPhase2
-
kPUF_QualityVerificationFail
-
kPUF_ContextIncorrect
-
kPUF_DestinationNotAllowed
-
kPUF_Failure
-
kPUF_NonsecureUser
-
kPUF_NonsecurePrivilege
-
kPUF_SecureUser
-
kPUF_SecurePrivilege
-
PUF_ACTIVATION_CODE_SIZE
-
PUF_GET_KEY_CODE_SIZE_FOR_KEY_SIZE(x)
-
SEC_LOCK_PATTERN
-
struct puf_config_t
- #include <fsl_puf_v3.h>
-
struct puf_key_ctx_t
- #include <fsl_puf_v3.h>
PWM: Pulse Width Modulator
-
status_t PWM_Init(PWM_Type *base, pwm_submodule_t subModule, const pwm_config_t *config)
Ungates the PWM submodule clock and configures the peripheral for basic operation.
This API should be called at the beginning of the application using the PWM driver. When user select PWMX, user must choose edge aligned output, becasue there are some limitation on center aligned PWMX output. When output PWMX in center aligned mode, VAL1 register controls both PWM period and PWMX duty cycle, PWMA and PWMB output will be corrupted. But edge aligned PWMX output do not have such limit. In master reload counter initialization mode, PWM period is depended by period of set LDOK in submodule 0 because this operation will reload register. Submodule 0 counter initialization cannot be master sync or master reload.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
config – Pointer to user’s PWM config structure.
- Returns:
kStatus_Success means success; else failed.
-
void PWM_Deinit(PWM_Type *base, pwm_submodule_t subModule)
Gate the PWM submodule clock.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to deinitialize
-
void PWM_GetDefaultConfig(pwm_config_t *config)
Fill in the PWM config struct with the default settings.
The default values are:
config->enableDebugMode = false; config->enableWait = false; config->reloadSelect = kPWM_LocalReload; config->clockSource = kPWM_BusClock; config->prescale = kPWM_Prescale_Divide_1; config->initializationControl = kPWM_Initialize_LocalSync; config->forceTrigger = kPWM_Force_Local; config->reloadFrequency = kPWM_LoadEveryOportunity; config->reloadLogic = kPWM_ReloadImmediate; config->pairOperation = kPWM_Independent;
- Parameters:
config – Pointer to user’s PWM config structure.
-
status_t PWM_SetupPwm(PWM_Type *base, pwm_submodule_t subModule, const pwm_signal_param_t *chnlParams, uint8_t numOfChnls, pwm_mode_t mode, uint32_t pwmFreq_Hz, uint32_t srcClock_Hz)
Sets up the PWM signals for a PWM submodule.
The function initializes the submodule according to the parameters passed in by the user. The function also sets up the value compare registers to match the PWM signal requirements. If the dead time insertion logic is enabled, the pulse period is reduced by the dead time period specified by the user. When user select PWMX, user must choose edge aligned output, becasue there are some limitation on center aligned PWMX output. Due to edge aligned PWMX is negative true signal, need to configure PWMX active low true level to get correct duty cycle. The half cycle point will not be exactly in the middle of the PWM cycle when PWMX enabled.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
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. Array size should not be more than 3 as each submodule has 3 pins to output PWM.
mode – PWM operation mode, options available in enumeration pwm_mode_t
pwmFreq_Hz – PWM signal frequency in Hz
srcClock_Hz – PWM source clock of correspond submodule in Hz. If source clock of submodule1,2,3 is from submodule0 AUX_CLK, its source clock is submodule0 source clock divided with submodule0 prescaler value instead of submodule0 source clock.
- Returns:
Returns kStatus_Fail if there was error setting up the signal; kStatus_Success otherwise
-
status_t PWM_SetupPwmPhaseShift(PWM_Type *base, pwm_submodule_t subModule, pwm_channels_t pwmChannel, uint32_t pwmFreq_Hz, uint32_t srcClock_Hz, uint8_t shiftvalue, bool doSync)
Set PWM phase shift for PWM channel running on channel PWM_A, PWM_B which with 50% duty cycle.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
pwmChannel – PWM channel to configure
pwmFreq_Hz – PWM signal frequency in Hz
srcClock_Hz – PWM main counter clock in Hz.
shiftvalue – Phase shift value, range in 0 ~ 50
doSync – true: Set LDOK bit for the submodule list; false: LDOK bit don’t set, need to call PWM_SetPwmLdok to sync update.
- Returns:
Returns kStatus_Fail if there was error setting up the signal; kStatus_Success otherwise
-
void PWM_UpdatePwmDutycycle(PWM_Type *base, pwm_submodule_t subModule, pwm_channels_t pwmSignal, pwm_mode_t currPwmMode, uint8_t dutyCyclePercent)
Updates the PWM signal’s dutycycle.
The function updates the PWM dutycyle to the new value that is passed in. If the dead time insertion logic is enabled then the pulse period is reduced by the dead time period specified by the user.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
pwmSignal – Signal (PWM A, PWM B, PWM X) to update
currPwmMode – The current PWM mode set during PWM setup
dutyCyclePercent – New PWM pulse width, value should be between 0 to 100 0=inactive signal(0% duty cycle)… 100=active signal (100% duty cycle)
-
void PWM_UpdatePwmDutycycleHighAccuracy(PWM_Type *base, pwm_submodule_t subModule, pwm_channels_t pwmSignal, pwm_mode_t currPwmMode, uint16_t dutyCycle)
Updates the PWM signal’s dutycycle with 16-bit accuracy.
The function updates the PWM dutycyle to the new value that is passed in. If the dead time insertion logic is enabled then the pulse period is reduced by the dead time period specified by the user.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
pwmSignal – Signal (PWM A, PWM B, PWM X) to update
currPwmMode – The current PWM mode set during PWM setup
dutyCycle – New PWM pulse width, value should be between 0 to 65535 0=inactive signal(0% duty cycle)… 65535=active signal (100% duty cycle)
-
void PWM_UpdatePwmPeriodAndDutycycle(PWM_Type *base, pwm_submodule_t subModule, pwm_channels_t pwmSignal, pwm_mode_t currPwmMode, uint16_t pulseCnt, uint16_t dutyCycle)
Update the PWM signal’s period and dutycycle for a PWM submodule.
The function updates PWM signal period generated by a specific submodule according to the parameters passed in by the user. This function can also set dutycycle weather you want to keep original dutycycle or update new dutycycle. Call this function in local sync control mode because PWM period is depended by
INIT and VAL1 register of each submodule. In master sync initialization control mode, call this function to update INIT and VAL1 register of all submodule because PWM period is depended by INIT and VAL1 register in submodule0. If the dead time insertion logic is enabled, the pulse period is reduced by the dead time period specified by the user. PWM signal will not be generated if its period is less than dead time duration.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
pwmSignal – Signal (PWM A or PWM B) to update
currPwmMode – The current PWM mode set during PWM setup, options available in enumeration pwm_mode_t
pulseCnt – New PWM period, value should be between 0 to 65535 0=minimum PWM period… 65535=maximum PWM period
dutyCycle – New PWM pulse width of channel, value should be between 0 to 65535 0=inactive signal(0% duty cycle)… 65535=active signal (100% duty cycle) You can keep original duty cycle or update new duty cycle
-
static inline void PWM_EnableInterrupts(PWM_Type *base, pwm_submodule_t subModule, uint32_t mask)
Enables the selected PWM interrupts.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
mask – The interrupts to enable. This is a logical OR of members of the enumeration pwm_interrupt_enable_t
-
static inline void PWM_DisableInterrupts(PWM_Type *base, pwm_submodule_t subModule, uint32_t mask)
Disables the selected PWM interrupts.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
mask – The interrupts to enable. This is a logical OR of members of the enumeration pwm_interrupt_enable_t
-
static inline uint32_t PWM_GetEnabledInterrupts(PWM_Type *base, pwm_submodule_t subModule)
Gets the enabled PWM interrupts.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
- Returns:
The enabled interrupts. This is the logical OR of members of the enumeration pwm_interrupt_enable_t
-
static inline void PWM_DMAFIFOWatermarkControl(PWM_Type *base, pwm_submodule_t subModule, pwm_watermark_control_t pwm_watermark_control)
Capture DMA Enable Source Select.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
pwm_watermark_control – PWM FIFO watermark and control
-
static inline void PWM_DMACaptureSourceSelect(PWM_Type *base, pwm_submodule_t subModule, pwm_dma_source_select_t pwm_dma_source_select)
Capture DMA Enable Source Select.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
pwm_dma_source_select – PWM capture DMA enable source select
-
static inline void PWM_EnableDMACapture(PWM_Type *base, pwm_submodule_t subModule, uint16_t mask, bool activate)
Enables or disables the selected PWM DMA Capture read request.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
mask – The DMA to enable or disable. This is a logical OR of members of the enumeration pwm_dma_enable_t
activate – true: Enable DMA read request; false: Disable DMA read request
-
static inline void PWM_EnableDMAWrite(PWM_Type *base, pwm_submodule_t subModule, bool activate)
Enables or disables the PWM DMA write request.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
activate – true: Enable DMA write request; false: Disable DMA write request
-
static inline uint32_t PWM_GetStatusFlags(PWM_Type *base, pwm_submodule_t subModule)
Gets the PWM status flags.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
- Returns:
The status flags. This is the logical OR of members of the enumeration pwm_status_flags_t
-
static inline void PWM_ClearStatusFlags(PWM_Type *base, pwm_submodule_t subModule, uint32_t mask)
Clears the PWM status flags.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
mask – The status flags to clear. This is a logical OR of members of the enumeration pwm_status_flags_t
-
static inline void PWM_StartTimer(PWM_Type *base, uint8_t subModulesToStart)
Starts the PWM counter for a single or multiple submodules.
Sets the Run bit which enables the clocks to the PWM submodule. This function can start multiple submodules at the same time.
- Parameters:
base – PWM peripheral base address
subModulesToStart – PWM submodules to start. This is a logical OR of members of the enumeration pwm_module_control_t
-
static inline void PWM_StopTimer(PWM_Type *base, uint8_t subModulesToStop)
Stops the PWM counter for a single or multiple submodules.
Clears the Run bit which resets the submodule’s counter. This function can stop multiple submodules at the same time.
- Parameters:
base – PWM peripheral base address
subModulesToStop – PWM submodules to stop. This is a logical OR of members of the enumeration pwm_module_control_t
-
FSL_PWM_DRIVER_VERSION
Version 2.9.0
-
enum _pwm_submodule
List of PWM submodules.
Values:
-
enumerator kPWM_Module_0
Submodule 0
-
enumerator kPWM_Module_1
Submodule 1
-
enumerator kPWM_Module_2
Submodule 2
-
enumerator kPWM_Module_0
-
enum _pwm_channels
List of PWM channels in each module.
Values:
-
enumerator kPWM_PwmB
-
enumerator kPWM_PwmA
-
enumerator kPWM_PwmX
-
enumerator kPWM_PwmB
-
enum _pwm_value_register
List of PWM value registers.
Values:
-
enumerator kPWM_ValueRegister_0
PWM Value0 register
-
enumerator kPWM_ValueRegister_1
PWM Value1 register
-
enumerator kPWM_ValueRegister_2
PWM Value2 register
-
enumerator kPWM_ValueRegister_3
PWM Value3 register
-
enumerator kPWM_ValueRegister_4
PWM Value4 register
-
enumerator kPWM_ValueRegister_5
PWM Value5 register
-
enumerator kPWM_ValueRegister_0
-
enum _pwm_value_register_mask
List of PWM value registers mask.
Values:
-
enumerator kPWM_ValueRegisterMask_0
PWM Value0 register mask
-
enumerator kPWM_ValueRegisterMask_1
PWM Value1 register mask
-
enumerator kPWM_ValueRegisterMask_2
PWM Value2 register mask
-
enumerator kPWM_ValueRegisterMask_3
PWM Value3 register mask
-
enumerator kPWM_ValueRegisterMask_4
PWM Value4 register mask
-
enumerator kPWM_ValueRegisterMask_5
PWM Value5 register mask
-
enumerator kPWM_ValueRegisterMask_0
-
enum _pwm_clock_source
PWM clock source selection.
Values:
-
enumerator kPWM_BusClock
The IPBus clock is used as the clock
-
enumerator kPWM_ExternalClock
EXT_CLK is used as the clock
-
enumerator kPWM_Submodule0Clock
Clock of the submodule 0 (AUX_CLK) is used as the source clock
-
enumerator kPWM_BusClock
-
enum _pwm_clock_prescale
PWM prescaler factor selection for clock source.
Values:
-
enumerator kPWM_Prescale_Divide_1
PWM clock frequency = fclk/1
-
enumerator kPWM_Prescale_Divide_2
PWM clock frequency = fclk/2
-
enumerator kPWM_Prescale_Divide_4
PWM clock frequency = fclk/4
-
enumerator kPWM_Prescale_Divide_8
PWM clock frequency = fclk/8
-
enumerator kPWM_Prescale_Divide_16
PWM clock frequency = fclk/16
-
enumerator kPWM_Prescale_Divide_32
PWM clock frequency = fclk/32
-
enumerator kPWM_Prescale_Divide_64
PWM clock frequency = fclk/64
-
enumerator kPWM_Prescale_Divide_128
PWM clock frequency = fclk/128
-
enumerator kPWM_Prescale_Divide_1
-
enum _pwm_force_output_trigger
Options that can trigger a PWM FORCE_OUT.
Values:
-
enumerator kPWM_Force_Local
The local force signal, CTRL2[FORCE], from the submodule is used to force updates
-
enumerator kPWM_Force_Master
The master force signal from submodule 0 is used to force updates
-
enumerator kPWM_Force_LocalReload
The local reload signal from this submodule is used to force updates without regard to the state of LDOK
-
enumerator kPWM_Force_MasterReload
The master reload signal from submodule 0 is used to force updates if LDOK is set
-
enumerator kPWM_Force_LocalSync
The local sync signal from this submodule is used to force updates
-
enumerator kPWM_Force_MasterSync
The master sync signal from submodule0 is used to force updates
-
enumerator kPWM_Force_External
The external force signal, EXT_FORCE, from outside the PWM module causes updates
-
enumerator kPWM_Force_ExternalSync
The external sync signal, EXT_SYNC, from outside the PWM module causes updates
-
enumerator kPWM_Force_Local
-
enum _pwm_output_state
PWM channel output status.
Values:
-
enumerator kPWM_HighState
The output state of PWM channel is high
-
enumerator kPWM_LowState
The output state of PWM channel is low
-
enumerator kPWM_NormalState
The output state of PWM channel is normal
-
enumerator kPWM_InvertState
The output state of PWM channel is invert
-
enumerator kPWM_MaskState
The output state of PWM channel is mask
-
enumerator kPWM_HighState
-
enum _pwm_init_source
PWM counter initialization options.
Values:
-
enumerator kPWM_Initialize_LocalSync
Local sync causes initialization
-
enumerator kPWM_Initialize_MasterReload
Master reload from submodule 0 causes initialization
-
enumerator kPWM_Initialize_MasterSync
Master sync from submodule 0 causes initialization
-
enumerator kPWM_Initialize_ExtSync
EXT_SYNC causes initialization
-
enumerator kPWM_Initialize_LocalSync
-
enum _pwm_load_frequency
PWM load frequency selection.
Values:
-
enumerator kPWM_LoadEveryOportunity
Every PWM opportunity
-
enumerator kPWM_LoadEvery2Oportunity
Every 2 PWM opportunities
-
enumerator kPWM_LoadEvery3Oportunity
Every 3 PWM opportunities
-
enumerator kPWM_LoadEvery4Oportunity
Every 4 PWM opportunities
-
enumerator kPWM_LoadEvery5Oportunity
Every 5 PWM opportunities
-
enumerator kPWM_LoadEvery6Oportunity
Every 6 PWM opportunities
-
enumerator kPWM_LoadEvery7Oportunity
Every 7 PWM opportunities
-
enumerator kPWM_LoadEvery8Oportunity
Every 8 PWM opportunities
-
enumerator kPWM_LoadEvery9Oportunity
Every 9 PWM opportunities
-
enumerator kPWM_LoadEvery10Oportunity
Every 10 PWM opportunities
-
enumerator kPWM_LoadEvery11Oportunity
Every 11 PWM opportunities
-
enumerator kPWM_LoadEvery12Oportunity
Every 12 PWM opportunities
-
enumerator kPWM_LoadEvery13Oportunity
Every 13 PWM opportunities
-
enumerator kPWM_LoadEvery14Oportunity
Every 14 PWM opportunities
-
enumerator kPWM_LoadEvery15Oportunity
Every 15 PWM opportunities
-
enumerator kPWM_LoadEvery16Oportunity
Every 16 PWM opportunities
-
enumerator kPWM_LoadEveryOportunity
-
enum _pwm_fault_input
List of PWM fault selections.
Values:
-
enumerator kPWM_Fault_0
Fault 0 input pin
-
enumerator kPWM_Fault_1
Fault 1 input pin
-
enumerator kPWM_Fault_2
Fault 2 input pin
-
enumerator kPWM_Fault_3
Fault 3 input pin
-
enumerator kPWM_Fault_0
-
enum _pwm_fault_disable
List of PWM fault disable mapping selections.
Values:
-
enumerator kPWM_FaultDisable_0
Fault 0 disable mapping
-
enumerator kPWM_FaultDisable_1
Fault 1 disable mapping
-
enumerator kPWM_FaultDisable_2
Fault 2 disable mapping
-
enumerator kPWM_FaultDisable_3
Fault 3 disable mapping
-
enumerator kPWM_FaultDisable_0
-
enum _pwm_fault_channels
List of PWM fault channels.
Values:
-
enumerator kPWM_faultchannel_0
-
enumerator kPWM_faultchannel_1
-
enumerator kPWM_faultchannel_0
-
enum _pwm_input_capture_edge
PWM capture edge select.
Values:
-
enumerator kPWM_Disable
Disabled
-
enumerator kPWM_FallingEdge
Capture on falling edge only
-
enumerator kPWM_RisingEdge
Capture on rising edge only
-
enumerator kPWM_RiseAndFallEdge
Capture on rising or falling edge
-
enumerator kPWM_Disable
-
enum _pwm_force_signal
PWM output options when a FORCE_OUT signal is asserted.
Values:
-
enumerator kPWM_UsePwm
Generated PWM signal is used by the deadtime logic.
-
enumerator kPWM_InvertedPwm
Inverted PWM signal is used by the deadtime logic.
-
enumerator kPWM_SoftwareControl
Software controlled value is used by the deadtime logic.
-
enumerator kPWM_UseExternal
PWM_EXTA signal is used by the deadtime logic.
-
enumerator kPWM_UsePwm
-
enum _pwm_chnl_pair_operation
Options available for the PWM A & B pair operation.
Values:
-
enumerator kPWM_Independent
PWM A & PWM B operate as 2 independent channels
-
enumerator kPWM_ComplementaryPwmA
PWM A & PWM B are complementary channels, PWM A generates the signal
-
enumerator kPWM_ComplementaryPwmB
PWM A & PWM B are complementary channels, PWM B generates the signal
-
enumerator kPWM_Independent
-
enum _pwm_register_reload
Options available on how to load the buffered-registers with new values.
Values:
-
enumerator kPWM_ReloadImmediate
Buffered-registers get loaded with new values as soon as LDOK bit is set
-
enumerator kPWM_ReloadPwmHalfCycle
Registers loaded on a PWM half cycle
-
enumerator kPWM_ReloadPwmFullCycle
Registers loaded on a PWM full cycle
-
enumerator kPWM_ReloadPwmHalfAndFullCycle
Registers loaded on a PWM half & full cycle
-
enumerator kPWM_ReloadImmediate
-
enum _pwm_fault_recovery_mode
Options available on how to re-enable the PWM output when recovering from a fault.
Values:
-
enumerator kPWM_NoRecovery
PWM output will stay inactive
-
enumerator kPWM_RecoverHalfCycle
PWM output re-enabled at the first half cycle
-
enumerator kPWM_RecoverFullCycle
PWM output re-enabled at the first full cycle
-
enumerator kPWM_RecoverHalfAndFullCycle
PWM output re-enabled at the first half or full cycle
-
enumerator kPWM_NoRecovery
-
enum _pwm_interrupt_enable
List of PWM interrupt options.
Values:
-
enumerator kPWM_CompareVal0InterruptEnable
PWM VAL0 compare interrupt
-
enumerator kPWM_CompareVal1InterruptEnable
PWM VAL1 compare interrupt
-
enumerator kPWM_CompareVal2InterruptEnable
PWM VAL2 compare interrupt
-
enumerator kPWM_CompareVal3InterruptEnable
PWM VAL3 compare interrupt
-
enumerator kPWM_CompareVal4InterruptEnable
PWM VAL4 compare interrupt
-
enumerator kPWM_CompareVal5InterruptEnable
PWM VAL5 compare interrupt
-
enumerator kPWM_CaptureX0InterruptEnable
PWM capture X0 interrupt
-
enumerator kPWM_CaptureX1InterruptEnable
PWM capture X1 interrupt
-
enumerator kPWM_CaptureB0InterruptEnable
PWM capture B0 interrupt
-
enumerator kPWM_CaptureB1InterruptEnable
PWM capture B1 interrupt
-
enumerator kPWM_CaptureA0InterruptEnable
PWM capture A0 interrupt
-
enumerator kPWM_CaptureA1InterruptEnable
PWM capture A1 interrupt
-
enumerator kPWM_ReloadInterruptEnable
PWM reload interrupt
-
enumerator kPWM_ReloadErrorInterruptEnable
PWM reload error interrupt
-
enumerator kPWM_Fault0InterruptEnable
PWM fault 0 interrupt
-
enumerator kPWM_Fault1InterruptEnable
PWM fault 1 interrupt
-
enumerator kPWM_Fault2InterruptEnable
PWM fault 2 interrupt
-
enumerator kPWM_Fault3InterruptEnable
PWM fault 3 interrupt
-
enumerator kPWM_CompareVal0InterruptEnable
-
enum _pwm_status_flags
List of PWM status flags.
Values:
-
enumerator kPWM_CompareVal0Flag
PWM VAL0 compare flag
-
enumerator kPWM_CompareVal1Flag
PWM VAL1 compare flag
-
enumerator kPWM_CompareVal2Flag
PWM VAL2 compare flag
-
enumerator kPWM_CompareVal3Flag
PWM VAL3 compare flag
-
enumerator kPWM_CompareVal4Flag
PWM VAL4 compare flag
-
enumerator kPWM_CompareVal5Flag
PWM VAL5 compare flag
-
enumerator kPWM_CaptureX0Flag
PWM capture X0 flag
-
enumerator kPWM_CaptureX1Flag
PWM capture X1 flag
-
enumerator kPWM_CaptureB0Flag
PWM capture B0 flag
-
enumerator kPWM_CaptureB1Flag
PWM capture B1 flag
-
enumerator kPWM_CaptureA0Flag
PWM capture A0 flag
-
enumerator kPWM_CaptureA1Flag
PWM capture A1 flag
-
enumerator kPWM_ReloadFlag
PWM reload flag
-
enumerator kPWM_ReloadErrorFlag
PWM reload error flag
-
enumerator kPWM_RegUpdatedFlag
PWM registers updated flag
-
enumerator kPWM_Fault0Flag
PWM fault 0 flag
-
enumerator kPWM_Fault1Flag
PWM fault 1 flag
-
enumerator kPWM_Fault2Flag
PWM fault 2 flag
-
enumerator kPWM_Fault3Flag
PWM fault 3 flag
-
enumerator kPWM_CompareVal0Flag
-
enum _pwm_dma_enable
List of PWM DMA options.
Values:
-
enumerator kPWM_CaptureX0DMAEnable
PWM capture X0 DMA
-
enumerator kPWM_CaptureX1DMAEnable
PWM capture X1 DMA
-
enumerator kPWM_CaptureB0DMAEnable
PWM capture B0 DMA
-
enumerator kPWM_CaptureB1DMAEnable
PWM capture B1 DMA
-
enumerator kPWM_CaptureA0DMAEnable
PWM capture A0 DMA
-
enumerator kPWM_CaptureA1DMAEnable
PWM capture A1 DMA
-
enumerator kPWM_CaptureX0DMAEnable
-
enum _pwm_dma_source_select
List of PWM capture DMA enable source select.
Values:
-
enumerator kPWM_DMARequestDisable
Read DMA requests disabled
-
enumerator kPWM_DMAWatermarksEnable
Exceeding a FIFO watermark sets the DMA read request
-
enumerator kPWM_DMALocalSync
A local sync (VAL1 matches counter) sets the read DMA request
-
enumerator kPWM_DMALocalReload
A local reload (STS[RF] being set) sets the read DMA request
-
enumerator kPWM_DMARequestDisable
-
enum _pwm_watermark_control
PWM FIFO Watermark AND Control.
Values:
-
enumerator kPWM_FIFOWatermarksOR
Selected FIFO watermarks are OR’ed together
-
enumerator kPWM_FIFOWatermarksAND
Selected FIFO watermarks are AND’ed together
-
enumerator kPWM_FIFOWatermarksOR
-
enum _pwm_mode
PWM operation mode.
Values:
-
enumerator kPWM_SignedCenterAligned
Signed center-aligned
-
enumerator kPWM_CenterAligned
Unsigned cente-aligned
-
enumerator kPWM_SignedEdgeAligned
Signed edge-aligned
-
enumerator kPWM_EdgeAligned
Unsigned edge-aligned
-
enumerator kPWM_SignedCenterAligned
-
enum _pwm_level_select
PWM output pulse mode, high-true or low-true.
Values:
-
enumerator kPWM_HighTrue
High level represents “on” or “active” state
-
enumerator kPWM_LowTrue
Low level represents “on” or “active” state
-
enumerator kPWM_HighTrue
-
enum _pwm_fault_state
PWM output fault status.
Values:
-
enumerator kPWM_PwmFaultState0
Output is forced to logic 0 state prior to consideration of output polarity control.
-
enumerator kPWM_PwmFaultState1
Output is forced to logic 1 state prior to consideration of output polarity control.
-
enumerator kPWM_PwmFaultState2
Output is tristated.
-
enumerator kPWM_PwmFaultState3
Output is tristated.
-
enumerator kPWM_PwmFaultState0
-
enum _pwm_reload_source_select
PWM reload source select.
Values:
-
enumerator kPWM_LocalReload
The local reload signal is used to reload registers
-
enumerator kPWM_MasterReload
The master reload signal (from submodule 0) is used to reload
-
enumerator kPWM_LocalReload
-
enum _pwm_fault_clear
PWM fault clearing options.
Values:
-
enumerator kPWM_Automatic
Automatic fault clearing
-
enumerator kPWM_ManualNormal
Manual fault clearing with no fault safety mode
-
enumerator kPWM_ManualSafety
Manual fault clearing with fault safety mode
-
enumerator kPWM_Automatic
-
enum _pwm_module_control
Options for submodule master control operation.
Values:
-
enumerator kPWM_Control_Module_0
Control submodule 0’s start/stop,buffer reload operation
-
enumerator kPWM_Control_Module_1
Control submodule 1’s start/stop,buffer reload operation
-
enumerator kPWM_Control_Module_2
Control submodule 2’s start/stop,buffer reload operation
-
enumerator kPWM_Control_Module_3
Control submodule 3’s start/stop,buffer reload operation
-
enumerator kPWM_Control_Module_0
-
typedef enum _pwm_submodule pwm_submodule_t
List of PWM submodules.
-
typedef enum _pwm_channels pwm_channels_t
List of PWM channels in each module.
-
typedef enum _pwm_value_register pwm_value_register_t
List of PWM value registers.
-
typedef enum _pwm_clock_source pwm_clock_source_t
PWM clock source selection.
-
typedef enum _pwm_clock_prescale pwm_clock_prescale_t
PWM prescaler factor selection for clock source.
-
typedef enum _pwm_force_output_trigger pwm_force_output_trigger_t
Options that can trigger a PWM FORCE_OUT.
-
typedef enum _pwm_output_state pwm_output_state_t
PWM channel output status.
-
typedef enum _pwm_init_source pwm_init_source_t
PWM counter initialization options.
-
typedef enum _pwm_load_frequency pwm_load_frequency_t
PWM load frequency selection.
-
typedef enum _pwm_fault_input pwm_fault_input_t
List of PWM fault selections.
-
typedef enum _pwm_fault_disable pwm_fault_disable_t
List of PWM fault disable mapping selections.
-
typedef enum _pwm_fault_channels pwm_fault_channels_t
List of PWM fault channels.
-
typedef enum _pwm_input_capture_edge pwm_input_capture_edge_t
PWM capture edge select.
-
typedef enum _pwm_force_signal pwm_force_signal_t
PWM output options when a FORCE_OUT signal is asserted.
-
typedef enum _pwm_chnl_pair_operation pwm_chnl_pair_operation_t
Options available for the PWM A & B pair operation.
-
typedef enum _pwm_register_reload pwm_register_reload_t
Options available on how to load the buffered-registers with new values.
-
typedef enum _pwm_fault_recovery_mode pwm_fault_recovery_mode_t
Options available on how to re-enable the PWM output when recovering from a fault.
-
typedef enum _pwm_interrupt_enable pwm_interrupt_enable_t
List of PWM interrupt options.
-
typedef enum _pwm_status_flags pwm_status_flags_t
List of PWM status flags.
-
typedef enum _pwm_dma_enable pwm_dma_enable_t
List of PWM DMA options.
-
typedef enum _pwm_dma_source_select pwm_dma_source_select_t
List of PWM capture DMA enable source select.
-
typedef enum _pwm_watermark_control pwm_watermark_control_t
PWM FIFO Watermark AND Control.
-
typedef enum _pwm_mode pwm_mode_t
PWM operation mode.
-
typedef enum _pwm_level_select pwm_level_select_t
PWM output pulse mode, high-true or low-true.
-
typedef enum _pwm_fault_state pwm_fault_state_t
PWM output fault status.
-
typedef enum _pwm_reload_source_select pwm_reload_source_select_t
PWM reload source select.
-
typedef enum _pwm_fault_clear pwm_fault_clear_t
PWM fault clearing options.
-
typedef enum _pwm_module_control pwm_module_control_t
Options for submodule master control operation.
-
typedef struct _pwm_signal_param pwm_signal_param_t
Structure for the user to define the PWM signal characteristics.
-
typedef struct _pwm_config pwm_config_t
PWM config structure.
This structure holds the configuration settings for the PWM peripheral. To initialize this structure to reasonable defaults, call the PWM_GetDefaultConfig() function and pass a pointer to your config structure instance.
The config struct can be made const so it resides in flash
-
typedef struct _pwm_fault_input_filter_param pwm_fault_input_filter_param_t
Structure for the user to configure the fault input filter.
-
typedef struct _pwm_fault_param pwm_fault_param_t
Structure is used to hold the parameters to configure a PWM fault.
-
typedef struct _pwm_input_capture_param pwm_input_capture_param_t
Structure is used to hold parameters to configure the capture capability of a signal pin.
-
void PWM_SetupInputCapture(PWM_Type *base, pwm_submodule_t subModule, pwm_channels_t pwmChannel, const pwm_input_capture_param_t *inputCaptureParams)
Sets up the PWM input capture.
Each PWM submodule has 3 pins that can be configured for use as input capture pins. This function sets up the capture parameters for each pin and enables the pin for input capture operation.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
pwmChannel – Channel in the submodule to setup
inputCaptureParams – Parameters passed in to set up the input pin
-
void PWM_SetupFaultInputFilter(PWM_Type *base, const pwm_fault_input_filter_param_t *faultInputFilterParams)
Sets up the PWM fault input filter.
- Parameters:
base – PWM peripheral base address
faultInputFilterParams – Parameters passed in to set up the fault input filter.
-
void PWM_SetupFaults(PWM_Type *base, pwm_fault_input_t faultNum, const pwm_fault_param_t *faultParams)
Sets up the PWM fault protection.
PWM has 4 fault inputs.
- Parameters:
base – PWM peripheral base address
faultNum – PWM fault to configure.
faultParams – Pointer to the PWM fault config structure
-
void PWM_FaultDefaultConfig(pwm_fault_param_t *config)
Fill in the PWM fault config struct with the default settings.
The default values are:
config->faultClearingMode = kPWM_Automatic; config->faultLevel = false; config->enableCombinationalPath = true; config->recoverMode = kPWM_NoRecovery;
- Parameters:
config – Pointer to user’s PWM fault config structure.
-
void PWM_SetupForceSignal(PWM_Type *base, pwm_submodule_t subModule, pwm_channels_t pwmChannel, pwm_force_signal_t mode)
Selects the signal to output on a PWM pin when a FORCE_OUT signal is asserted.
The user specifies which channel to configure by supplying the submodule number and whether to modify PWM A or PWM B within that submodule.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
pwmChannel – Channel to configure
mode – Signal to output when a FORCE_OUT is triggered
-
static inline void PWM_SetVALxValue(PWM_Type *base, pwm_submodule_t subModule, pwm_value_register_t valueRegister, uint16_t value)
Set the PWM VALx registers.
This function allows the user to write value into VAL registers directly. And it will destroying the PWM clock period set by the PWM_SetupPwm()/PWM_SetupPwmPhaseShift() functions. Due to VALx registers are bufferd, the new value will not active uless call PWM_SetPwmLdok() and the reload point is reached.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
valueRegister – VALx register that will be writen new value
value – Value that will been write into VALx register
-
static inline uint16_t PWM_GetVALxValue(PWM_Type *base, pwm_submodule_t subModule, pwm_value_register_t valueRegister)
Get the PWM VALx registers.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
valueRegister – VALx register that will be read value
- Returns:
The VALx register value
-
static inline void PWM_OutputTriggerEnable(PWM_Type *base, pwm_submodule_t subModule, pwm_value_register_t valueRegister, bool activate)
Enables or disables the PWM output trigger.
This function allows the user to enable or disable the PWM trigger. The PWM has 2 triggers. Trigger 0 is activated when the counter matches VAL 0, VAL 2, or VAL 4 register. Trigger 1 is activated when the counter matches VAL 1, VAL 3, or VAL 5 register.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
valueRegister – Value register that will activate the trigger
activate – true: Enable the trigger; false: Disable the trigger
-
static inline void PWM_ActivateOutputTrigger(PWM_Type *base, pwm_submodule_t subModule, uint16_t valueRegisterMask)
Enables the PWM output trigger.
This function allows the user to enable one or more (VAL0-5) PWM trigger.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
valueRegisterMask – Value register mask that will activate one or more (VAL0-5) trigger enumeration _pwm_value_register_mask
-
static inline void PWM_DeactivateOutputTrigger(PWM_Type *base, pwm_submodule_t subModule, uint16_t valueRegisterMask)
Disables the PWM output trigger.
This function allows the user to disables one or more (VAL0-5) PWM trigger.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
valueRegisterMask – Value register mask that will Deactivate one or more (VAL0-5) trigger enumeration _pwm_value_register_mask
-
static inline void PWM_SetupSwCtrlOut(PWM_Type *base, pwm_submodule_t subModule, pwm_channels_t pwmChannel, bool value)
Sets the software control output for a pin to high or low.
The user specifies which channel to modify by supplying the submodule number and whether to modify PWM A or PWM B within that submodule.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
pwmChannel – Channel to configure
value – true: Supply a logic 1, false: Supply a logic 0.
-
static inline void PWM_SetPwmLdok(PWM_Type *base, uint8_t subModulesToUpdate, bool value)
Sets or clears the PWM LDOK bit on a single or multiple submodules.
Set LDOK bit to load buffered values into CTRL[PRSC] and the INIT, FRACVAL and VAL registers. The values are loaded immediately if kPWM_ReloadImmediate option was choosen during config. Else the values are loaded at the next PWM reload point. This function can issue the load command to multiple submodules at the same time.
- Parameters:
base – PWM peripheral base address
subModulesToUpdate – PWM submodules to update with buffered values. This is a logical OR of members of the enumeration pwm_module_control_t
value – true: Set LDOK bit for the submodule list; false: Clear LDOK bit
-
static inline void PWM_SetPwmFaultState(PWM_Type *base, pwm_submodule_t subModule, pwm_channels_t pwmChannel, pwm_fault_state_t faultState)
Set PWM output fault status.
These bits determine the fault state for the PWM_A output in fault conditions and STOP mode. It may also define the output state in WAIT and DEBUG modes depending on the settings of CTRL2[WAITEN] and CTRL2[DBGEN]. This function can update PWM output fault status.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
pwmChannel – Channel to configure
faultState – PWM output fault status
-
static inline void PWM_SetupFaultDisableMap(PWM_Type *base, pwm_submodule_t subModule, pwm_channels_t pwmChannel, pwm_fault_channels_t pwm_fault_channels, uint16_t value)
Set PWM fault disable mapping.
Each of the four bits of this read/write field is one-to-one associated with the four FAULTx inputs of fault channel 0/1. The PWM output will be turned off if there is a logic 1 on an FAULTx input and a 1 in the corresponding bit of this field. A reset sets all bits in this field.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
pwmChannel – PWM channel to configure
pwm_fault_channels – PWM fault channel to configure
value – Fault disable mapping mask value enumeration pwm_fault_disable_t
-
static inline void PWM_OutputEnable(PWM_Type *base, pwm_channels_t pwmChannel, pwm_submodule_t subModule)
Set PWM output enable.
This feature allows the user to enable the PWM Output. Recommend to invoke this API after PWM and fault configuration. But invoke this API before configure MCTRL register is okay, such as set LDOK or start timer.
- Parameters:
base – PWM peripheral base address
pwmChannel – PWM channel to configure
subModule – PWM submodule to configure
-
static inline void PWM_OutputDisable(PWM_Type *base, pwm_channels_t pwmChannel, pwm_submodule_t subModule)
Set PWM output disable.
This feature allows the user to disable the PWM output. Recommend to invoke this API after PWM and fault configuration. But invoke this API before configure MCTRL register is okay, such as set LDOK or start timer.
- Parameters:
base – PWM peripheral base address
pwmChannel – PWM channel to configure
subModule – PWM submodule to configure
-
uint8_t PWM_GetPwmChannelState(PWM_Type *base, pwm_submodule_t subModule, pwm_channels_t pwmChannel)
Get the dutycycle value.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
pwmChannel – PWM channel to configure
- Returns:
Current channel dutycycle value.
-
status_t PWM_SetOutputToIdle(PWM_Type *base, pwm_channels_t pwmChannel, pwm_submodule_t subModule, bool idleStatus)
Set PWM output in idle status (high or low).
Note
This API should call after PWM_SetupPwm() APIs, and PWMX submodule is not supported.
- Parameters:
base – PWM peripheral base address
pwmChannel – PWM channel to configure
subModule – PWM submodule to configure
idleStatus – True: PWM output is high in idle status; false: PWM output is low in idle status.
- Returns:
kStatus_Fail if there was error setting up the signal; kStatus_Success if set output idle success
-
void PWM_SetClockMode(PWM_Type *base, pwm_submodule_t subModule, pwm_clock_prescale_t prescaler)
Set the pwm submodule prescaler.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
prescaler – Set prescaler value
-
void PWM_SetPwmForceOutputToZero(PWM_Type *base, pwm_submodule_t subModule, pwm_channels_t pwmChannel, bool forcetozero)
This function enables-disables the forcing of the output of a given eFlexPwm channel to logic 0.
- Parameters:
base – PWM peripheral base address
pwmChannel – PWM channel to configure
subModule – PWM submodule to configure
forcetozero – True: Enable the pwm force output to zero; False: Disable the pwm output resumes normal function.
-
void PWM_SetChannelOutput(PWM_Type *base, pwm_submodule_t subModule, pwm_channels_t pwmChannel, pwm_output_state_t outputstate)
This function set the output state of the PWM pin as requested for the current cycle.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
pwmChannel – PWM channel to configure
outputstate – Set pwm output state, see pwm_output_state_t.
-
status_t PWM_SetPhaseDelay(PWM_Type *base, pwm_channels_t pwmChannel, pwm_submodule_t subModule, uint16_t delayCycles)
This function set the phase delay from the master sync signal of submodule 0.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
pwmChannel – PWM channel to configure
delayCycles – Number of cycles delayed from submodule 0.
- Returns:
kStatus_Fail if the number of delay cycles is set larger than the period defined in submodule 0; kStatus_Success if set phase delay success
-
static inline void PWM_SetFilterSampleCount(PWM_Type *base, pwm_channels_t pwmChannel, pwm_submodule_t subModule, uint8_t filterSampleCount)
This function set the number of consecutive samples that must agree prior to the input filter.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
pwmChannel – PWM channel to configure
filterSampleCount – Number of consecutive samples.
-
static inline void PWM_SetFilterSamplePeriod(PWM_Type *base, pwm_channels_t pwmChannel, pwm_submodule_t subModule, uint8_t filterSamplePeriod)
This function set the sampling period of the fault pin input filter.
- Parameters:
base – PWM peripheral base address
subModule – PWM submodule to configure
pwmChannel – PWM channel to configure
filterSamplePeriod – Sampling period of input filter.
-
PWM_SUBMODULE_SWCONTROL_WIDTH
Number of bits per submodule for software output control
-
PWM_SUBMODULE_CHANNEL
Submodule channels include PWMA, PWMB, PWMX.
-
struct _pwm_signal_param
- #include <fsl_pwm.h>
Structure for the user to define the PWM signal characteristics.
Public Members
-
pwm_channels_t pwmChannel
PWM channel being configured; PWM A or PWM B
-
uint8_t dutyCyclePercent
PWM pulse width, value should be between 0 to 100 0=inactive signal(0% duty cycle)… 100=always active signal (100% duty cycle)
-
pwm_level_select_t level
PWM output active level select
-
uint16_t deadtimeValue
The deadtime value; only used if channel pair is operating in complementary mode
-
pwm_fault_state_t faultState
PWM output fault status
-
bool pwmchannelenable
Enable PWM output
-
pwm_channels_t pwmChannel
-
struct _pwm_config
- #include <fsl_pwm.h>
PWM config structure.
This structure holds the configuration settings for the PWM peripheral. To initialize this structure to reasonable defaults, call the PWM_GetDefaultConfig() function and pass a pointer to your config structure instance.
The config struct can be made const so it resides in flash
Public Members
-
bool enableDebugMode
true: PWM continues to run in debug mode; false: PWM is paused in debug mode
-
pwm_init_source_t initializationControl
Option to initialize the counter
-
pwm_clock_source_t clockSource
Clock source for the counter
-
pwm_clock_prescale_t prescale
Pre-scaler to divide down the clock
-
pwm_chnl_pair_operation_t pairOperation
Channel pair in indepedent or complementary mode
-
pwm_register_reload_t reloadLogic
PWM Reload logic setup
-
pwm_reload_source_select_t reloadSelect
Reload source select
-
pwm_load_frequency_t reloadFrequency
Specifies when to reload, used when user’s choice is not immediate reload
-
pwm_force_output_trigger_t forceTrigger
Specify which signal will trigger a FORCE_OUT
-
bool enableDebugMode
-
struct _pwm_fault_input_filter_param
- #include <fsl_pwm.h>
Structure for the user to configure the fault input filter.
Public Members
-
uint8_t faultFilterCount
Fault filter count
-
uint8_t faultFilterPeriod
Fault filter period;value of 0 will bypass the filter
-
bool faultGlitchStretch
Fault Glitch Stretch Enable: A logic 1 means that input fault signals will be stretched to at least 2 IPBus clock cycles
-
uint8_t faultFilterCount
-
struct _pwm_fault_param
- #include <fsl_pwm.h>
Structure is used to hold the parameters to configure a PWM fault.
Public Members
-
pwm_fault_clear_t faultClearingMode
Fault clearing mode to use
-
bool faultLevel
true: Logic 1 indicates fault; false: Logic 0 indicates fault
-
bool enableCombinationalPath
true: Combinational Path from fault input is enabled; false: No combination path is available
-
pwm_fault_recovery_mode_t recoverMode
Specify when to re-enable the PWM output
-
pwm_fault_clear_t faultClearingMode
-
struct _pwm_input_capture_param
- #include <fsl_pwm.h>
Structure is used to hold parameters to configure the capture capability of a signal pin.
Public Members
-
bool captureInputSel
true: Use the edge counter signal as source false: Use the raw input signal from the pin as source
-
uint8_t edgeCompareValue
Compare value, used only if edge counter is used as source
-
pwm_input_capture_edge_t edge0
Specify which edge causes a capture for input circuitry 0
-
pwm_input_capture_edge_t edge1
Specify which edge causes a capture for input circuitry 1
-
bool enableOneShotCapture
true: Use one-shot capture mode; false: Use free-running capture mode
-
uint8_t fifoWatermark
Watermark level for capture FIFO. The capture flags in the status register will set if the word count in the FIFO is greater than this watermark level
-
bool captureInputSel
Reset Driver
-
enum _SYSCON_RSTn
Enumeration for peripheral reset control bits.
Defines the enumeration for peripheral reset control bits in PRESETCTRL/ASYNCPRESETCTRL registers
Values:
-
enumerator kROM_RST_SHIFT_RSTn
ROM reset control .
-
enumerator kSRAM_CTRL1_RST_SHIFT_RSTn
SRAM Controller 1 reset control .
-
enumerator kSRAM_CTRL2_RST_SHIFT_RSTn
SRAM Controller 2 reset control .
-
enumerator kSRAM_CTRL3_RST_SHIFT_RSTn
SRAM Controller 3 reset control .
-
enumerator kSRAM_CTRL4_RST_SHIFT_RSTn
SRAM Controller 4 reset control .
-
enumerator kFLASH_RST_SHIFT_RSTn
FLASH reset control .
-
enumerator kFMC_RST_SHIFT_RSTn
FMC reset control .
-
enumerator kFLEXSPI_RST_SHIFT_RSTn
FLEXSPI reset control .
-
enumerator kMUX_RST_SHIFT_RSTn
MUX reset control .
-
enumerator kIOCON_RST_SHIFT_RSTn
IOCON reset control .
-
enumerator kGPIO0_RST_SHIFT_RSTn
GPIO0 reset control .
-
enumerator kGPIO1_RST_SHIFT_RSTn
GPIO1 reset control .
-
enumerator kGPIO2_RST_SHIFT_RSTn
GPIO2 reset control .
-
enumerator kGPIO3_RST_SHIFT_RSTn
GPIO3 reset control .
-
enumerator kPINT_RST_SHIFT_RSTn
PINT reset control .
-
enumerator kGINT_RST_SHIFT_RSTn
GINT reset control .
-
enumerator kDMA0_RST_SHIFT_RSTn
DMA0 reset control .
-
enumerator kCRC_RST_SHIFT_RSTn
CRC reset control .
-
enumerator kWWDT_RST_SHIFT_RSTn
WWDT reset control .
-
enumerator kRTC_RST_SHIFT_RSTn
RTC reset control .
-
enumerator kMAILBOX_RST_SHIFT_RSTn
MAILBOX reset control .
-
enumerator kADC0_RST_SHIFT_RSTn
ADC0 reset control .
-
enumerator kADC1_RST_SHIFT_RSTn
ADC1 reset control .
-
enumerator kDAC0_RST_SHIFT_RSTn
DAC0 reset control .
-
enumerator kMRT_RST_SHIFT_RSTn
MRT reset control .
-
enumerator kOSTIMER_RST_SHIFT_RSTn
OSTIMER reset control .
-
enumerator kSCT_RST_SHIFT_RSTn
SCT reset control .
-
enumerator kMCAN_RST_SHIFT_RSTn
MCAN reset control .
-
enumerator kUTICK_RST_SHIFT_RSTn
UTICK reset control .
-
enumerator kFC0_RST_SHIFT_RSTn
FC0 reset control .
-
enumerator kFC1_RST_SHIFT_RSTn
FC1 reset control .
-
enumerator kFC2_RST_SHIFT_RSTn
FC2 reset control .
-
enumerator kFC3_RST_SHIFT_RSTn
FC3 reset control .
-
enumerator kFC4_RST_SHIFT_RSTn
FC4 reset control .
-
enumerator kFC5_RST_SHIFT_RSTn
FC5 reset control .
-
enumerator kFC6_RST_SHIFT_RSTn
FC6 reset control .
-
enumerator kFC7_RST_SHIFT_RSTn
FC7 reset control .
-
enumerator kDMIC_RST_SHIFT_RSTn
DMIC reset control .
-
enumerator kCTIMER2_RST_SHIFT_RSTn
TIMER2 reset control .
-
enumerator kUSB0_DEV_RST_SHIFT_RSTn
USB0_DEV reset control .
-
enumerator kCTIMER0_RST_SHIFT_RSTn
TIMER0 reset control .
-
enumerator kCTIMER1_RST_SHIFT_RSTn
TIMER1 reset control .
-
enumerator kDMA1_RST_SHIFT_RSTn
DMA1 reset control .
-
enumerator kCMP_RST_SHIFT_RSTn
CMP reset control .
-
enumerator kFREQME_RST_SHIFT_RSTn
FREQME reset control .
-
enumerator kCDOG_RST_SHIFT_RSTn
Code Watchdog reset control
-
enumerator kRNG_RST_SHIFT_RSTn
RNG reset control .
-
enumerator kSYSCTL_RST_SHIFT_RSTn
SYSCTL reset control .
-
enumerator kUSB0HMR_RST_SHIFT_RSTn
USB0HMR reset control
-
enumerator kUSB0HSL_RST_SHIFT_RSTn
USB0HSL reset control
-
enumerator kCSS_RST_SHIFT_RSTn
CSS reset control .
-
enumerator kPOWERQUAD_RST_SHIFT_RSTn
PowerQuad reset control .
-
enumerator kCTIMER3_RST_SHIFT_RSTn
TIMER3 reset control .
-
enumerator kCTIMER4_RST_SHIFT_RSTn
TIMER4 reset control .
-
enumerator kPUF_RST_SHIFT_RSTn
PUF reset control
-
enumerator kPKC_RST_SHIFT_RSTn
PKC reset control .
-
enumerator kANACTRL_RST_SHIFT_RSTn
ANACTRL reset control .
-
enumerator kHSLSPI_RST_SHIFT_RSTn
HS LSPI reset control
-
enumerator kGPIOSEC_RST_SHIFT_RSTn
GPIO_SEC reset control .
-
enumerator kGPIO_SEC_INT_RST_SHIFT_RSTn
GPIO secure int reset control .
-
enumerator kI3C0_RST_SHIFT_RSTn
I3C0 reset control .
-
enumerator kENC0_RST_SHIFT_RSTn
ENC0 reset control .
-
enumerator kENC1_RST_SHIFT_RSTn
ENC1 reset control .
-
enumerator kPWM0_RST_SHIFT_RSTn
PWM0 reset control .
-
enumerator kPWM1_RST_SHIFT_RSTn
PWM1 reset control .
-
enumerator kAOI0_RST_SHIFT_RSTn
AOI0 reset control .
-
enumerator kAOI1_RST_SHIFT_RSTn
AOI1 reset control .
-
enumerator kFTM0_RST_SHIFT_RSTn
FTM0 reset control .
-
enumerator kDAC1_RST_SHIFT_RSTn
DAC1 reset control .
-
enumerator kDAC2_RST_SHIFT_RSTn
DAC2 reset control .
-
enumerator kOPAMP0_RST_SHIFT_RSTn
OPAMP0 reset control .
-
enumerator kOPAMP1_RST_SHIFT_RSTn
OPAMP1 reset control .
-
enumerator kOPAMP2_RST_SHIFT_RSTn
OPAMP2 reset control .
-
enumerator kHSCMP0_RST_SHIFT_RSTn
HSCMP0 reset control .
-
enumerator kHSCMP1_RST_SHIFT_RSTn
HSCMP1 reset control .
-
enumerator kHSCMP2_RST_SHIFT_RSTn
HSCMP2 reset control .
-
enumerator kVREF_RST_SHIFT_RSTn
VREF reset control .
-
enumerator kROM_RST_SHIFT_RSTn
-
typedef enum _SYSCON_RSTn SYSCON_RSTn_t
Enumeration for peripheral reset control bits.
Defines the enumeration for peripheral reset control bits in PRESETCTRL/ASYNCPRESETCTRL registers
-
typedef SYSCON_RSTn_t reset_ip_name_t
-
void RESET_SetPeripheralReset(reset_ip_name_t peripheral)
Assert reset to peripheral.
Asserts reset signal to specified peripheral module.
- Parameters:
peripheral – Assert reset to this peripheral. The enum argument contains encoding of reset register and reset bit position in the reset register.
-
void RESET_ClearPeripheralReset(reset_ip_name_t peripheral)
Clear reset to peripheral.
Clears reset signal to specified peripheral module, allows it to operate.
- Parameters:
peripheral – Clear reset to this peripheral. The enum argument contains encoding of reset register and reset bit position in the reset register.
-
void RESET_PeripheralReset(reset_ip_name_t peripheral)
Reset peripheral module.
Reset peripheral module.
- Parameters:
peripheral – Peripheral to reset. The enum argument contains encoding of reset register and reset bit position in the reset register.
-
static inline void RESET_ReleasePeripheralReset(reset_ip_name_t peripheral)
Release peripheral module.
Release peripheral module.
- Parameters:
peripheral – Peripheral to release. The enum argument contains encoding of reset register and reset bit position in the reset register.
-
FSL_RESET_DRIVER_VERSION
reset driver version 2.4.0
-
ADC_RSTS
Array initializers with peripheral reset bits
-
MCAN_RSTS
-
CRC_RSTS
-
CTIMER_RSTS
-
DMA_RSTS_N
-
FLEXCOMM_RSTS
-
GINT_RSTS
-
GPIO_RSTS_N
-
INPUTMUX_RSTS
-
IOCON_RSTS
-
FLASH_RSTS
-
MRT_RSTS
-
PINT_RSTS
-
CDOG_RSTS
-
RNG_RSTS
-
SCT_RSTS
-
USB0D_RST
-
USB0HMR_RST
-
USB0HSL_RST
-
UTICK_RSTS
-
WWDT_RSTS
-
OSTIMER_RSTS
-
I3C_RSTS
-
ENC_RSTS
-
PWM_RSTS
-
AOI_RSTS
-
DAC_RSTS
-
OPAMP_RSTS
-
HSCMP_RSTS
-
POWERQUAD_RSTS
-
PUF_RSTS
-
RTC_RSTS
-
USB0HSL_RSTS
-
USB0HMR_RSTS
-
USB0D_RSTS
RNG: Random Number Generator
-
FSL_RNG_DRIVER_VERSION
RNG driver version. Version 2.0.3.
Current version: 2.0.3
Change log:
Version 2.0.0
Initial version
Version 2.0.1
Fix MISRA C-2012 issue.
Version 2.0.2
Add RESET_PeripheralReset function inside RNG_Init and RNG_Deinit functions.
Version 2.0.3
Modified RNG_Init and RNG_GetRandomData functions, added rng_accumulateEntropy and rng_readEntropy functions.
These changes are reflecting recommended usage of RNG according to device UM.
-
void RNG_Init(RNG_Type *base)
Initializes the RNG.
This function initializes the RNG. When called, the RNG module and ring oscillator is enabled.
- Parameters:
base – RNG base address
- Returns:
If successful, returns the kStatus_RNG_Success. Otherwise, it returns an error.
-
void RNG_Deinit(RNG_Type *base)
Shuts down the RNG.
This function shuts down the RNG.
- Parameters:
base – RNG base address.
-
status_t RNG_GetRandomData(RNG_Type *base, void *data, size_t dataSize)
Gets random data.
This function gets random data from the RNG.
- Parameters:
base – RNG base address.
data – Pointer address used to store random data.
dataSize – Size of the buffer pointed by the data parameter.
- Returns:
random data
-
static inline uint32_t RNG_GetRandomWord(RNG_Type *base)
Returns random 32-bit number.
This function gets random number from the RNG.
- Parameters:
base – RNG base address.
- Returns:
random number
RTC: Real Time Clock
- void RTC_WriteRegister (__IO uint32_t *reg, uint32_t value)
Write value to RTC register.
Note
This API will write data to RTC register, all bus synchornous operation will be done.
- uint32_t RTC_ReadRegister (__I uint32_t *reg)
Read data from RTC register.
Note
This API will read the RTC’s register value.
-
void RTC_Init(RTC_Type *base, rtc_config_t *config)
Initalize the RTC mudule.
Note
This API should be called at the beginning of the application using the RTC driver. This API will help configure the calibration value, count down auto start, enable RTC timer and the initialized date for counting.
- Parameters:
base – RTC peripheral base address
config – configuration for initializing RTC.
-
static inline void RTC_Deinit(RTC_Type *base)
Stop the timer and gate the RTC clock.
- Parameters:
base – RTC peripheral base address
-
void RTC_GetDefaultConfig(RTC_Type *base, rtc_config_t *config)
Get default config for RTC setting. This configure structure will help setup calibration value, formated date value. And set if enable RTC timer and count down auto start function.
- Parameters:
base – RTC peripheral base address
config – Configure structure for setting RTC module. Refer to rtc_config_t.
-
status_t RTC_SetDatetime(RTC_Type *base, const rtc_datetime_t *datetime)
Sets the RTC date and time according to the given time structure.
The RTC counter must be stopped prior to calling this function as writes to the RTC seconds register will fail if the RTC counter is running.
- Parameters:
base – RTC peripheral base address
datetime – Pointer to structure where the date and time details to set are stored
- Returns:
kStatus_Success: Success in setting the time and starting the RTC kStatus_InvalidArgument: Error because the datetime format is incorrect
-
void RTC_GetDatetime(RTC_Type *base, rtc_datetime_t *datetime)
Gets the RTC time and stores it in the given time structure.
- Parameters:
base – RTC peripheral base address
datetime – Pointer to structure where the date and time details are stored.
-
static inline void RTC_SetSleepTime(RTC_Type *base, uint32_t value)
Sets the RTC sleep time.
The function will set the sleep time for counting down, if the value in SLEEPT register equals to 0, an interrupt will be generated if this interrupt is enabled.
- Parameters:
base – RTC peripheral base address
value – sleep time, uint is seconds.
-
static inline uint32_t RTC_GetSleepTime(RTC_Type *base)
Returns the current RTC sleep time value.
- Parameters:
base – RTC peripheral base address
- Returns:
The sleep remaining in register.
-
static inline void RTC_EnableInterrupts(RTC_Type *base, uint32_t mask)
Enables the selected RTC interrupts.
- Parameters:
base – RTC peripheral base address
mask – The interrupts to enable. Refer to the enumeration rtc_interrupt_enable_t
-
static inline void RTC_DisableInterrupts(RTC_Type *base, uint32_t mask)
Disables the selected RTC interrupts.
- 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
-
static inline uint32_t RTC_GetStatusFlags(RTC_Type *base)
Gets the RTC status flags.
- Parameters:
base – RTC peripheral base address
- Returns:
The status flags. This is the logical OR of members of the enumeration rtc_status_flags_t
-
static inline uint32_t RTC_GetRawInterruptStatus(RTC_Type *base)
Gets the RTC Raw interrupt status.
- Parameters:
base – RTC peripheral base address
- Returns:
The status flags. This is the logical OR of members of the enumeration rtc_status_flags_t
-
static inline uint32_t RTC_GetMaskedInterruptStatus(RTC_Type *base)
Gets the RTC status flags.
- Parameters:
base – RTC peripheral base address
- Returns:
The status flags. This is the logical OR of members of the enumeration rtc_status_flags_t
-
static inline void RTC_ClearMaskedInterruptStatus(RTC_Type *base, uint32_t mask)
Clear masked interrupt status.
- Parameters:
base – RTC peripheral base address.
mask – The interrupts to enable.
- Returns:
The status flags. This is the logical OR of members of the enumeration rtc_masked_interrupt_status_t
-
static inline void RTC_StartTimer(RTC_Type *base)
Starts the RTC time counter.
After calling this function, the timer counter increments once a second.
- Parameters:
base – RTC peripheral base address
-
static inline void RTC_StopTimer(RTC_Type *base)
Stops the RTC time counter.
RTC’s seconds register can be written to only when the timer is stopped.
- Parameters:
base – RTC peripheral base address
-
void RTC_EnableSleepAutoStart(RTC_Type *base, bool enable)
Enable the sleep count down auto Start.
- Parameters:
base – RTC peripheral base address
enable – 1 for enable, 0 for disable.
-
static inline void RTC_StartSleep(RTC_Type *base)
Start the count down manually.
- Parameters:
base – RTC peripheral base address
-
static inline void RTC_SetCalibrationValue(RTC_Type *base, uint32_t value)
Set calibration value. The calibration value decide the number of TFRO clock pulses in one tick.
- Parameters:
base – RTC peripheral base address
value – The value to be set.
-
static inline uint32_t RTC_GetCalibrationValue(RTC_Type *base)
Get the calibration value from register.
- Parameters:
base – RTC peripheral base address
-
FSL_RTC_DRIVER_VERSION
Version 2.1.0
-
enum _rtc_interrupt_enable
List of RTC interrupts.
Values:
-
enumerator kRTC_CountDownInterruptEnable
Count down interrupt.
-
enumerator kRTC_CountDownInterruptEnable
-
enum _rtc_status_flags
List of RTC flags.
Values:
-
enumerator kRTC_EnabledFlag
Flag for RTC enabled or not.
-
enumerator kRTC_FreezedFlag
Flag for RTC freezed or not.
-
enumerator kRTC_RunFlag
Flag for RTC running status.
-
enumerator kRTC_EnabledFlag
-
enum _rtc_raw_interrupt_status
List of RTC raw interrupt status.
Values:
-
enumerator kRTC_CountDownRawStatus
Raw interrupt status for count down finish.
-
enumerator kRTC_CountDownRawStatus
-
enum _rtc_masked_interrupt_status
List of RTC masked interrupt status.
Values:
-
enumerator kRTC_CountDownMaskedStatus
Masked interrupt status for count down finish.
-
enumerator kRTC_CountDownMaskedStatus
-
typedef enum _rtc_interrupt_enable rtc_interrupt_enable_t
List of RTC interrupts.
-
typedef enum _rtc_status_flags rtc_status_flags_t
List of RTC flags.
-
typedef enum _rtc_raw_interrupt_status rtc_raw_interrupt_status_t
List of RTC raw interrupt status.
-
typedef enum _rtc_masked_interrupt_status rtc_masked_interrupt_status_t
List of RTC masked interrupt status.
-
typedef struct _rtc_datetime rtc_datetime_t
Structure is used to hold the date and time.
-
typedef struct _rtc_config rtc_config_t
Structure used for configuration.
-
RTC_TFRO_FREQ
-
RTC_SYNC_TIME_OUT_TICKS
Time-out ticks is (in ARM clock ticks) that a bus synchronization wait should take. Worst-case wait is 3 TFRO ticks. Worst case ARM speed is full SFRO (no divider). Since the TFRO could be somewhat slower than spec’d, and the SFRO somewhat faster, we add 33% as margin - it is just for an emergency time-out.
-
struct _rtc_datetime
- #include <fsl_rtc.h>
Structure is used to hold the date and time.
Public Members
-
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.
-
uint16_t year
-
struct _rtc_config
- #include <fsl_rtc.h>
Structure used for configuration.
Public Members
-
bool enableAutoStart
Enable count down auto start.
-
bool enableTimer
Enable RTC timer.
-
bool enableAutoStart
Runbootloader
-
void bootloader_user_entry(void *arg)
Run the Bootloader API to force into the ISP mode base on the user arg.
- Parameters:
arg – Indicates API prototype fields definition. Refer to the above user_app_boot_invoke_option_t structure
-
FSL_ROMAPI_RUNBOOTLOADER_DRIVER_VERSION
ROMAPI_RUNBOOTLOADER driver version 2.0.0.
-
uint32_t boot_image_index
-
uint32_t reserved
-
uint32_t boot_interface
-
uint32_t mode
-
uint32_t tag
-
struct user_app_boot_invoke_option_t B
-
uint32_t U
-
union user_app_boot_invoke_option_t option
-
struct user_app_boot_invoke_option_t
- #include <fsl_runbootloader.h>
-
union option
-
struct B
Sbloader
-
enum _sectionType
sb3 section definitions
section type
Values:
-
enumerator kSectionNone
end or invalid
-
enumerator kSectionDataRange
-
enumerator kSectionDiffUpdate
-
enumerator kSectionDDRConfig
-
enumerator kSectionRegister
-
enumerator kSectionNone
Values:
-
enumerator kFwVerChk_Id_none
-
enumerator kFwVerChk_Id_nonsecure
-
enumerator kFwVerChk_Id_secure
-
enumerator kFwVerChk_Id_none
-
enum _loader_command_sb3
loader command enum
Values:
-
enumerator kSB3_CmdInvalid
-
enumerator kSB3_CmdErase
-
enumerator kSB3_CmdLoad
-
enumerator kSB3_CmdExecute
-
enumerator kSB3_CmdCall
-
enumerator kSB3_CmdProgramFuse
-
enumerator kSB3_CmdProgramIFR
-
enumerator kSB3_CmdLoadCmac
-
enumerator kSB3_CmdCopy
-
enumerator kSB3_CmdLoadHashLocking
-
enumerator kSB3_CmdLoadKeyBlob
-
enumerator kSB3_CmdConfigMem
-
enumerator kSB3_CmdFillMem
-
enumerator kSB3_CmdFwVerCheck
-
enumerator kSB3_CmdInvalid
-
enum kb_operation_t
Details of the operation to be performed by the ROM.
The kRomAuthenticateImage operation requires the entire signed image to be available to the application.
Values:
-
enumerator kRomAuthenticateImage
Authenticate a signed image.
-
enumerator kRomLoadImage
Load SB file.
-
enumerator kRomOperationCount
-
enumerator kRomAuthenticateImage
SB loader status codes.
Values:
-
enumerator kStatusRomLdrSectionOverrun
-
enumerator kStatusRomLdrSignature
-
enumerator kStatusRomLdrSectionLength
-
enumerator kStatusRomLdrUnencryptedOnly
-
enumerator kStatusRomLdrEOFReached
-
enumerator kStatusRomLdrChecksum
-
enumerator kStatusRomLdrCrc32Error
-
enumerator kStatusRomLdrUnknownCommand
-
enumerator kStatusRomLdrIdNotFound
-
enumerator kStatusRomLdrDataUnderrun
-
enumerator kStatusRomLdrJumpReturned
-
enumerator kStatusRomLdrCallFailed
-
enumerator kStatusRomLdrKeyNotFound
-
enumerator kStatusRomLdrSecureOnly
-
enumerator kStatusRomLdrResetReturned
-
enumerator kStatusRomLdrRollbackBlocked
-
enumerator kStatusRomLdrInvalidSectionMacCount
-
enumerator kStatusRomLdrUnexpectedCommand
-
enumerator kStatusRomLdrBadSBKEK
-
enumerator kStatusRomLdrPendingJumpCommand
-
enumerator kStatusRomLdrSectionOverrun
-
enum _fw_version_check_option
Values:
-
enumerator kRomLdr_FwCheckOption_SecureVersion
-
enumerator kRomLdr_FwCheckOption_NonSecureVersion
-
enumerator kRomLdr_FwCheckOption_SecureVersion
-
typedef uint8_t chunk_v3_t[16]
-
typedef struct _ldr_buf ldr_buf_t
-
typedef struct _ldr_Context_v3 ldr_Context_v3_t
Provides forward reference to the loader context definition.
-
typedef status_t (*pLdrFnc_v3_t)(ldr_Context_v3_t *content)
Function pointer definition for all loader action functions.
-
typedef enum _sectionType section_type_t
sb3 section definitions
section type
-
typedef struct range_header sb3_data_range_header_t
section data range structure
-
typedef struct range_header_expansion sb3_data_range_expansion_t
-
typedef struct copy_memory_expansion sb3_copy_memory_expansion_t
-
typedef struct copy sb3_copy_memory_t
-
typedef struct load_keyblob sb3_load_keyblob_t
-
typedef struct fill_memory_expansion sb3_fill_memory_expansion_t
-
typedef struct fill_memory sb3_fill_memory_t
-
typedef struct config_memory sb3_config_memory_t
-
typedef struct fw_ver_check sb3_fw_ver_check_t
-
typedef struct section_header sb3_section_header_t
sb3 DATA section header format
-
typedef enum _loader_command_sb3 sb3_cmd_t
loader command enum
-
typedef uint8_t chunk_t[16]
-
typedef struct _boot_cmd boot_cmd_t
Boot command definition.
-
typedef struct _boot_hdr1 boot_hdr1_t
Definition for boot image file header chunk 1.
-
typedef struct _boot_hdr2 boot_hdr2_t
Definition for boot image file header chunk 2.
-
typedef struct _ldr_Context ldr_Context_t
Provides forward reference to the loader context definition.
-
typedef status_t (*pLdrFnc_t)(ldr_Context_t *context)
Function pointer definition for all loader action functions.
-
typedef status_t (*pJumpFnc_t)(uint32_t parameter)
Jump command function pointer definition.
-
typedef status_t (*pCallFnc_t)(uint32_t parameter, uint32_t *func)
Call command function pointer definition.
-
typedef struct Crc32Data crc32_data_t
State information for the CRC32 algorithm.
-
typedef struct soc_memory_map_struct soc_mem_regions_t
-
typedef struct arena_context arena_context_t
-
typedef struct mem_region mem_region_t
Memory region information table.
-
typedef struct memory_attribute_struct mem_attribute_t
Memory Attribute Structure.
-
typedef struct memory_context_struct mem_context_t
Memory context structure.
-
typedef struct api_memory_region_interface api_memory_region_interface_t
Memory region interface structure.
-
typedef struct memory_map_entry api_memory_map_entry_t
Memory entry data structure.
-
typedef struct api_core_context api_core_context_t
The API context structure.
-
status_t Sbloader_Init(api_core_context_t *ctx)
Perform the Sbloader runtime environment initialization This API is used for initializing the sbloader state machine before calling the api_sbloader_pump. This API should be called after the iap_api_init API.
- Parameters:
ctx – Pointer to IAP API core context structure.
- Return values:
kStatus_Success – Api was executed succesfuly.
-
status_t Sbloader_Pump(api_core_context_t *ctx, uint8_t *data, uint32_t length)
Handle the SB data stream This API is used for handling the secure binary(SB3.1 format) data stream, which is used for image update, lifecycle advancing, etc. This API should be called after the iap_api_init and api_sbloader_init APIs.
- Parameters:
ctx – Pointer to IAP API core context structure.
data – Pointer to source data that is the sb file buffer data.
length – The size of the process buffer data.
- Return values:
kStatus_Success – Api was executed succesfuly.
kStatus_InvalidArgument – An invalid argument is provided.
kStatus_Fail – API execution failed.
-
status_t Sbloader_Finalize(api_core_context_t *ctx)
Finish the sbloader handling The API is used for finalizing the sbloader operations.
- Parameters:
ctx – Pointer to IAP API core context structure.
- Return values:
kStatus_Success – Api was executed succesfuly.
-
SB3_BYTES_PER_CHUNK
Defines the number of bytes in a cipher block (chunk). This is dictated by the encryption algorithm.
-
SB3_DATA_RANGE_HEADER_FLAGS_ERASE_MASK
bit 0
-
SB3_DATA_RANGE_HEADER_FLAGS_LOAD_MASK
bit 1
-
SBLOADER_V3_CMD_SET_ALL
The all of the allowed command.
-
SBLOADER_V3_CMD_SET_IN_ISP_MODE
The allowed command set in ISP mode.
-
SBLOADER_V3_CMD_SET_IN_REC_MODE
The allowed command set in recovery mode.
-
SB3_DATA_BUFFER_SIZE_IN_BYTE
-
SB_FILE_MAJOR_VERSION
Determines the version of SB loader implementation (1: sb1.0; 2: sb2.0; 3.1: sb3.1)
-
SB_FILE_MINOR_VERSION
-
kStatusGroup_SBLoader
Bootloader status group numbers.
-
RAM_REGION_COUNT
Contiguous RAM region count.
-
FLASH_REGION_COUNT
Contiguous FLASH region count.
-
FFR_REGION_COUNT
Contiguous FFR region count.
-
MEM_INTERFACE_COUNT
Memory Interface count.
-
FLEXSPINOR_REGION_COUNT
Contiguous FLEXSPINOR meomry count.
-
BYTES_PER_CHUNK
Defines the number of bytes in a cipher block (chunk). This is dictated by the encryption algorithm.
-
SB_SECTION_COUNT_MAX
-
BOOT_SIGNATURE
Boot image signature in 32-bit little-endian format “PMTS”.
-
BOOT_SIGNATURE2
Boot image signature in 32-bit little-endian format “ltgs”.
-
FFLG_DISPLAY_PROGRESS
These define file header flags.
-
SFLG_SECTION_BOOTABLE
These define section header flags.
-
CFLG_LAST_TAG
These define boot command flags.
-
ROM_ERASE_ALL_MASK
ROM_ERASE_CMD flags.
-
ROM_ERASE_ALL_UNSECURE_MASK
-
ROM_JUMP_SP_MASK
ROM_JUMP_CMD flags.
-
ROM_MEM_DEVICE_ID_SHIFT
Memory device id shift at sb command flags.
-
ROM_MEM_DEVICE_ID_MASK
Memory device id mask.
-
ROM_MEM_GROUP_ID_SHIFT
Memory group id shift at sb command flags.
-
ROM_MEM_GROUP_ID_MASK
Memory group id flags mask.
-
ROM_PROG_8BYTE_MASK
ROM_PROG_CMD flags.
-
ROM_NOP_CMD
These define the boot command tags.
-
ROM_TAG_CMD
-
ROM_LOAD_CMD
-
ROM_FILL_CMD
-
ROM_JUMP_CMD
-
ROM_CALL_CMD
-
ROM_MODE_CMD
-
ROM_ERASE_CMD
-
ROM_RESET_CMD
-
ROM_MEM_ENABLE_CMD
-
ROM_PROG_CMD
-
ROM_FW_VER_CHK
-
SBLOADER_CMD_SET_IN_ISP_MODE
-
SBLOADER_CMD_SET_IN_REC_MODE
-
ROM_BOOT_SECTION_ID
Plugin return codes.
-
ROM_BOOT_IMAGE_ID
-
struct _ldr_buf
- #include <fsl_sbloader_v3.h>
-
struct range_header
- #include <fsl_sbloader_v3.h>
section data range structure
-
struct range_header_expansion
- #include <fsl_sbloader_v3.h>
-
struct copy_memory_expansion
- #include <fsl_sbloader_v3.h>
-
struct copy
- #include <fsl_sbloader_v3.h>
-
struct load_keyblob
- #include <fsl_sbloader_v3.h>
-
struct fill_memory_expansion
- #include <fsl_sbloader_v3.h>
Public Members
-
uint32_t pattern
word to be used as pattern
-
uint32_t pattern
-
struct fill_memory
- #include <fsl_sbloader_v3.h>
-
struct config_memory
- #include <fsl_sbloader_v3.h>
Public Members
-
uint32_t address
address of config blob
-
uint32_t address
-
struct fw_ver_check
- #include <fsl_sbloader_v3.h>
-
struct section_header
- #include <fsl_sbloader_v3.h>
sb3 DATA section header format
-
struct kb_region_t
- #include <fsl_sbloader_v3.h>
Memory region definition.
-
struct kb_load_sb_t
- #include <fsl_sbloader_v3.h>
-
struct kb_authenticate_t
- #include <fsl_sbloader_v3.h>
-
struct kb_options_t
- #include <fsl_sbloader_v3.h>
Public Members
-
uint32_t version
Should be set to KbootApiVersion.
-
uint8_t *buffer
Caller-provided buffer used by Kboot.
-
uint32_t version
-
struct _ldr_Context_v3
- #include <fsl_sbloader_v3.h>
Loader context definition.
Public Members
-
pLdrFnc_v3_t Action
pointer to loader action function
-
uint32_t block_size
size of each block in bytes
-
uint32_t block_data_size
data size in bytes (NBOOT_SB3_CHUNK_SIZE_IN_BYTES)
-
uint32_t block_data_total
data max size in bytes (block_size * data_size
-
uint32_t block_buffer_size
block0 and block size
-
uint32_t processedBlocks
will be used for both block0 and blockx
-
bool in_data_block
data block offset in a block. in progress of handling a data block within a block
-
bool in_data_section
in progress of handling a data section within a data block
-
bool in_data_range
in progress of handling a data range within a data section
-
uint32_t commandSet
support command set during sb file handling
-
uint8_t data_buffer[(MAX(128, NBOOT_KEY_BLOB_SIZE_IN_BYTE_MAX))]
temporary data buffer
-
kb_options_t fromAPI
options from ROM API
-
pLdrFnc_v3_t Action
-
struct _boot_cmd
- #include <fsl_sbloader.h>
Boot command definition.
Public Members
-
uint8_t checksum
8-bit checksum over command chunk
-
uint8_t tag
command tag (identifier)
-
uint16_t flags
command flags (modifier)
-
uint32_t address
address argument
-
uint32_t count
count argument
-
uint32_t data
data argument
-
uint8_t checksum
-
struct _boot_hdr1
- #include <fsl_sbloader.h>
Definition for boot image file header chunk 1.
Public Members
-
uint32_t hash
last 32-bits of SHA-1 hash
-
uint32_t signature
must equal “STMP”
-
uint8_t major
major file format version
-
uint8_t minor
minor file format version
-
uint16_t fileFlags
global file flags
-
uint32_t fileChunks
total chunks in the file
-
uint32_t hash
-
struct _boot_hdr2
- #include <fsl_sbloader.h>
Definition for boot image file header chunk 2.
Public Members
-
uint32_t bootOffset
chunk offset to the first boot section
-
uint32_t bootSectID
section ID of the first boot section
-
uint16_t keyCount
number of keys in the key dictionary
-
uint16_t keyOffset
chunk offset to the key dictionary
-
uint16_t hdrChunks
number of chunks in the header
-
uint16_t sectCount
number of sections in the image
-
uint32_t bootOffset
-
struct Crc32Data
- #include <fsl_sbloader.h>
State information for the CRC32 algorithm.
Public Members
-
uint32_t currentCrc
Current CRC value.
-
uint32_t byteCountCrc
Number of bytes processed.
-
uint32_t currentCrc
-
struct _ldr_Context
- #include <fsl_sbloader.h>
Loader context definition.
Public Members
-
pLdrFnc_t Action
pointer to loader action function
-
uint32_t fileChunks
chunks remaining in file
-
uint32_t sectChunks
chunks remaining in section
-
uint32_t bootSectChunks
number of chunks we need to complete the boot section
-
uint32_t receivedChunks
number of chunks we need to complete the boot section
-
uint16_t fileFlags
file header flags
-
uint16_t keyCount
number of keys in the key dictionary
-
uint32_t objectID
ID of the current boot section or image
-
crc32_data_t crc32
crc calculated over load command payload
-
uint8_t *src
source buffer address
-
chunk_t initVector
decryption initialization vector
-
chunk_t dek
chunk size DEK if the image is encrypted
-
chunk_t scratchPad
chunk size scratch pad area
-
boot_cmd_t bootCmd
current boot command
-
uint32_t skipCount
Number of chunks to skip
-
bool skipToEnd
true if skipping to end of file
-
uint32_t offsetSignatureBytes
offset to signagure block header in bytesn
-
pLdrFnc_t Action
-
struct soc_memory_map_struct
- #include <fsl_sbloader.h>
-
struct arena_context
- #include <fsl_sbloader.h>
-
struct mem_region
- #include <fsl_sbloader.h>
Memory region information table.
-
struct memory_attribute_struct
- #include <fsl_sbloader.h>
Memory Attribute Structure.
-
struct memory_context_struct
- #include <fsl_sbloader.h>
Memory context structure.
-
struct api_memory_region_interface
- #include <fsl_sbloader.h>
Memory region interface structure.
-
struct memory_map_entry
- #include <fsl_sbloader.h>
Memory entry data structure.
-
struct api_core_context
- #include <fsl_sbloader.h>
The API context structure.
-
union __unnamed36__
Public Members
-
kb_authenticate_t authenticate
Settings for kb_authenticate_t operation.
-
kb_load_sb_t loadSB
Settings for kb_load_sb_t operation.
-
kb_authenticate_t authenticate
-
struct ramRegions
-
struct flashRegions
-
struct ffrRegions
-
struct flexspiNorRegions
SCTimer: SCTimer/PWM (SCT)
-
status_t SCTIMER_Init(SCT_Type *base, const sctimer_config_t *config)
Ungates the SCTimer clock and configures the peripheral for basic operation.
Note
This API should be called at the beginning of the application using the SCTimer driver.
- Parameters:
base – SCTimer peripheral base address
config – Pointer to the user configuration structure.
- Returns:
kStatus_Success indicates success; Else indicates failure.
-
void SCTIMER_Deinit(SCT_Type *base)
Gates the SCTimer clock.
- Parameters:
base – SCTimer peripheral base address
-
void SCTIMER_GetDefaultConfig(sctimer_config_t *config)
Fills in the SCTimer configuration structure with the default settings.
The default values are:
config->enableCounterUnify = true; config->clockMode = kSCTIMER_System_ClockMode; config->clockSelect = kSCTIMER_Clock_On_Rise_Input_0; config->enableBidirection_l = false; config->enableBidirection_h = false; config->prescale_l = 0U; config->prescale_h = 0U; config->outInitState = 0U; config->inputsync = 0xFU;
- Parameters:
config – Pointer to the user configuration structure.
-
status_t SCTIMER_SetupPwm(SCT_Type *base, const sctimer_pwm_signal_param_t *pwmParams, sctimer_pwm_mode_t mode, uint32_t pwmFreq_Hz, uint32_t srcClock_Hz, uint32_t *event)
Configures the PWM signal parameters.
Call this function to configure the PWM signal period, mode, duty cycle, and edge. This function will create 2 events; one of the events will trigger on match with the pulse value and the other will trigger when the counter matches the PWM period. The PWM period event is also used as a limit event to reset the counter or change direction. Both events are enabled for the same state. The state number can be retrieved by calling the function SCTIMER_GetCurrentStateNumber(). The counter is set to operate as one 32-bit counter (unify bit is set to 1). The counter operates in bi-directional mode when generating a center-aligned PWM.
Note
When setting PWM output from multiple output pins, they all should use the same PWM mode i.e all PWM’s should be either edge-aligned or center-aligned. When using this API, the PWM signal frequency of all the initialized channels must be the same. Otherwise all the initialized channels’ PWM signal frequency is equal to the last call to the API’s pwmFreq_Hz.
- Parameters:
base – SCTimer peripheral base address
pwmParams – PWM parameters to configure the output
mode – PWM operation mode, options available in enumeration sctimer_pwm_mode_t
pwmFreq_Hz – PWM signal frequency in Hz
srcClock_Hz – SCTimer counter clock in Hz
event – Pointer to a variable where the PWM period event number is stored
- Returns:
kStatus_Success on success kStatus_Fail If we have hit the limit in terms of number of events created or if an incorrect PWM dutycylce is passed in.
-
void SCTIMER_UpdatePwmDutycycle(SCT_Type *base, sctimer_out_t output, uint8_t dutyCyclePercent, uint32_t event)
Updates the duty cycle of an active PWM signal.
Before calling this function, the counter is set to operate as one 32-bit counter (unify bit is set to 1).
- Parameters:
base – SCTimer peripheral base address
output – The output to configure
dutyCyclePercent – New PWM pulse width; the value should be between 1 to 100
event – Event number associated with this PWM signal. This was returned to the user by the function SCTIMER_SetupPwm().
-
static inline void SCTIMER_EnableInterrupts(SCT_Type *base, uint32_t mask)
Enables the selected SCTimer interrupts.
- Parameters:
base – SCTimer peripheral base address
mask – The interrupts to enable. This is a logical OR of members of the enumeration sctimer_interrupt_enable_t
-
static inline void SCTIMER_DisableInterrupts(SCT_Type *base, uint32_t mask)
Disables the selected SCTimer interrupts.
- Parameters:
base – SCTimer peripheral base address
mask – The interrupts to enable. This is a logical OR of members of the enumeration sctimer_interrupt_enable_t
-
static inline uint32_t SCTIMER_GetEnabledInterrupts(SCT_Type *base)
Gets the enabled SCTimer interrupts.
- Parameters:
base – SCTimer peripheral base address
- Returns:
The enabled interrupts. This is the logical OR of members of the enumeration sctimer_interrupt_enable_t
-
static inline uint32_t SCTIMER_GetStatusFlags(SCT_Type *base)
Gets the SCTimer status flags.
- Parameters:
base – SCTimer peripheral base address
- Returns:
The status flags. This is the logical OR of members of the enumeration sctimer_status_flags_t
-
static inline void SCTIMER_ClearStatusFlags(SCT_Type *base, uint32_t mask)
Clears the SCTimer status flags.
- Parameters:
base – SCTimer peripheral base address
mask – The status flags to clear. This is a logical OR of members of the enumeration sctimer_status_flags_t
-
static inline void SCTIMER_StartTimer(SCT_Type *base, uint32_t countertoStart)
Starts the SCTimer counter.
Note
In 16-bit mode, we can enable both Counter_L and Counter_H, In 32-bit mode, we only can select Counter_U.
- Parameters:
base – SCTimer peripheral base address
countertoStart – The SCTimer counters to enable. This is a logical OR of members of the enumeration sctimer_counter_t.
-
static inline void SCTIMER_StopTimer(SCT_Type *base, uint32_t countertoStop)
Halts the SCTimer counter.
- Parameters:
base – SCTimer peripheral base address
countertoStop – The SCTimer counters to stop. This is a logical OR of members of the enumeration sctimer_counter_t.
-
status_t SCTIMER_CreateAndScheduleEvent(SCT_Type *base, sctimer_event_t howToMonitor, uint32_t matchValue, uint32_t whichIO, sctimer_counter_t whichCounter, uint32_t *event)
Create an event that is triggered on a match or IO and schedule in current state.
This function will configure an event using the options provided by the user. If the event type uses the counter match, then the function will set the user provided match value into a match register and put this match register number into the event control register. The event is enabled for the current state and the event number is increased by one at the end. The function returns the event number; this event number can be used to configure actions to be done when this event is triggered.
- Parameters:
base – SCTimer peripheral base address
howToMonitor – Event type; options are available in the enumeration sctimer_interrupt_enable_t
matchValue – The match value that will be programmed to a match register
whichIO – The input or output that will be involved in event triggering. This field is ignored if the event type is “match only”
whichCounter – SCTimer counter to use. In 16-bit mode, we can select Counter_L and Counter_H, In 32-bit mode, we can select Counter_U.
event – Pointer to a variable where the new event number is stored
- Returns:
kStatus_Success on success kStatus_Error if we have hit the limit in terms of number of events created or if we have reached the limit in terms of number of match registers
-
void SCTIMER_ScheduleEvent(SCT_Type *base, uint32_t event)
Enable an event in the current state.
This function will allow the event passed in to trigger in the current state. The event must be created earlier by either calling the function SCTIMER_SetupPwm() or function SCTIMER_CreateAndScheduleEvent() .
- Parameters:
base – SCTimer peripheral base address
event – Event number to enable in the current state
-
status_t SCTIMER_IncreaseState(SCT_Type *base)
Increase the state by 1.
All future events created by calling the function SCTIMER_ScheduleEvent() will be enabled in this new state.
- Parameters:
base – SCTimer peripheral base address
- Returns:
kStatus_Success on success kStatus_Error if we have hit the limit in terms of states used
-
uint32_t SCTIMER_GetCurrentState(SCT_Type *base)
Provides the current state.
User can use this to set the next state by calling the function SCTIMER_SetupNextStateAction().
- Parameters:
base – SCTimer peripheral base address
- Returns:
The current state
-
static inline void SCTIMER_SetCounterState(SCT_Type *base, sctimer_counter_t whichCounter, uint32_t state)
Set the counter current state.
The function is to set the state variable bit field of STATE register. Writing to the STATE_L, STATE_H, or unified register is only allowed when the corresponding counter is halted (HALT bits are set to 1 in the CTRL register).
- Parameters:
base – SCTimer peripheral base address
whichCounter – SCTimer counter to use. In 16-bit mode, we can select Counter_L and Counter_H, In 32-bit mode, we can select Counter_U.
state – The counter current state number (only support range from 0~31).
-
static inline uint16_t SCTIMER_GetCounterState(SCT_Type *base, sctimer_counter_t whichCounter)
Get the counter current state value.
The function is to get the state variable bit field of STATE register.
- Parameters:
base – SCTimer peripheral base address
whichCounter – SCTimer counter to use. In 16-bit mode, we can select Counter_L and Counter_H, In 32-bit mode, we can select Counter_U.
- Returns:
The the counter current state value.
-
status_t SCTIMER_SetupCaptureAction(SCT_Type *base, sctimer_counter_t whichCounter, uint32_t *captureRegister, uint32_t event)
Setup capture of the counter value on trigger of a selected event.
- Parameters:
base – SCTimer peripheral base address
whichCounter – SCTimer counter to use. In 16-bit mode, we can select Counter_L and Counter_H, In 32-bit mode, we can select Counter_U.
captureRegister – Pointer to a variable where the capture register number will be returned. User can read the captured value from this register when the specified event is triggered.
event – Event number that will trigger the capture
- Returns:
kStatus_Success on success kStatus_Error if we have hit the limit in terms of number of match/capture registers available
-
void SCTIMER_SetCallback(SCT_Type *base, sctimer_event_callback_t callback, uint32_t event)
Receive noticification when the event trigger an interrupt.
If the interrupt for the event is enabled by the user, then a callback can be registered which will be invoked when the event is triggered
- Parameters:
base – SCTimer peripheral base address
event – Event number that will trigger the interrupt
callback – Function to invoke when the event is triggered
-
static inline void SCTIMER_SetupStateLdMethodAction(SCT_Type *base, uint32_t event, bool fgLoad)
Change the load method of transition to the specified state.
Change the load method of transition, it will be triggered by the event number that is passed in by the user.
- Parameters:
base – SCTimer peripheral base address
event – Event number that will change the method to trigger the state transition
fgLoad – The method to load highest-numbered event occurring for that state to the STATE register.
true: Load the STATEV value to STATE when the event occurs to be the next state.
false: Add the STATEV value to STATE when the event occurs to be the next state.
-
static inline void SCTIMER_SetupNextStateActionwithLdMethod(SCT_Type *base, uint32_t nextState, uint32_t event, bool fgLoad)
Transition to the specified state with Load method.
This transition will be triggered by the event number that is passed in by the user, the method decide how to load the highest-numbered event occurring for that state to the STATE register.
- Parameters:
base – SCTimer peripheral base address
nextState – The next state SCTimer will transition to
event – Event number that will trigger the state transition
fgLoad – The method to load the highest-numbered event occurring for that state to the STATE register.
true: Load the STATEV value to STATE when the event occurs to be the next state.
false: Add the STATEV value to STATE when the event occurs to be the next state.
-
static inline void SCTIMER_SetupNextStateAction(SCT_Type *base, uint32_t nextState, uint32_t event)
Transition to the specified state.
- Deprecated:
Do not use this function. It has been superceded by SCTIMER_SetupNextStateActionwithLdMethod
This transition will be triggered by the event number that is passed in by the user.
- Parameters:
base – SCTimer peripheral base address
nextState – The next state SCTimer will transition to
event – Event number that will trigger the state transition
-
static inline void SCTIMER_SetupEventActiveDirection(SCT_Type *base, sctimer_event_active_direction_t activeDirection, uint32_t event)
Setup event active direction when the counters are operating in BIDIR mode.
- Parameters:
base – SCTimer peripheral base address
activeDirection – Event generation active direction, see sctimer_event_active_direction_t.
event – Event number that need setup the active direction.
-
static inline void SCTIMER_SetupOutputSetAction(SCT_Type *base, uint32_t whichIO, uint32_t event)
Set the Output.
This output will be set when the event number that is passed in by the user is triggered.
- Parameters:
base – SCTimer peripheral base address
whichIO – The output to set
event – Event number that will trigger the output change
-
static inline void SCTIMER_SetupOutputClearAction(SCT_Type *base, uint32_t whichIO, uint32_t event)
Clear the Output.
This output will be cleared when the event number that is passed in by the user is triggered.
- Parameters:
base – SCTimer peripheral base address
whichIO – The output to clear
event – Event number that will trigger the output change
-
void SCTIMER_SetupOutputToggleAction(SCT_Type *base, uint32_t whichIO, uint32_t event)
Toggle the output level.
This change in the output level is triggered by the event number that is passed in by the user.
- Parameters:
base – SCTimer peripheral base address
whichIO – The output to toggle
event – Event number that will trigger the output change
-
static inline void SCTIMER_SetupCounterLimitAction(SCT_Type *base, sctimer_counter_t whichCounter, uint32_t event)
Limit the running counter.
The counter is limited when the event number that is passed in by the user is triggered.
- Parameters:
base – SCTimer peripheral base address
whichCounter – SCTimer counter to use. In 16-bit mode, we can select Counter_L and Counter_H, In 32-bit mode, we can select Counter_U.
event – Event number that will trigger the counter to be limited
-
static inline void SCTIMER_SetupCounterStopAction(SCT_Type *base, sctimer_counter_t whichCounter, uint32_t event)
Stop the running counter.
The counter is stopped when the event number that is passed in by the user is triggered.
- Parameters:
base – SCTimer peripheral base address
whichCounter – SCTimer counter to use. In 16-bit mode, we can select Counter_L and Counter_H, In 32-bit mode, we can select Counter_U.
event – Event number that will trigger the counter to be stopped
-
static inline void SCTIMER_SetupCounterStartAction(SCT_Type *base, sctimer_counter_t whichCounter, uint32_t event)
Re-start the stopped counter.
The counter will re-start when the event number that is passed in by the user is triggered.
- Parameters:
base – SCTimer peripheral base address
whichCounter – SCTimer counter to use. In 16-bit mode, we can select Counter_L and Counter_H, In 32-bit mode, we can select Counter_U.
event – Event number that will trigger the counter to re-start
-
static inline void SCTIMER_SetupCounterHaltAction(SCT_Type *base, sctimer_counter_t whichCounter, uint32_t event)
Halt the running counter.
The counter is disabled (halted) when the event number that is passed in by the user is triggered. When the counter is halted, all further events are disabled. The HALT condition can only be removed by calling the SCTIMER_StartTimer() function.
- Parameters:
base – SCTimer peripheral base address
whichCounter – SCTimer counter to use. In 16-bit mode, we can select Counter_L and Counter_H, In 32-bit mode, we can select Counter_U.
event – Event number that will trigger the counter to be halted
-
static inline void SCTIMER_SetupDmaTriggerAction(SCT_Type *base, uint32_t dmaNumber, uint32_t event)
Generate a DMA request.
DMA request will be triggered by the event number that is passed in by the user.
- Parameters:
base – SCTimer peripheral base address
dmaNumber – The DMA request to generate
event – Event number that will trigger the DMA request
-
static inline void SCTIMER_SetCOUNTValue(SCT_Type *base, sctimer_counter_t whichCounter, uint32_t value)
Set the value of counter.
The function is to set the value of Count register, Writing to the COUNT_L, COUNT_H, or unified register is only allowed when the corresponding counter is halted (HALT bits are set to 1 in the CTRL register).
- Parameters:
base – SCTimer peripheral base address
whichCounter – SCTimer counter to use. In 16-bit mode, we can select Counter_L and Counter_H, In 32-bit mode, we can select Counter_U.
value – the counter value update to the COUNT register.
-
static inline uint32_t SCTIMER_GetCOUNTValue(SCT_Type *base, sctimer_counter_t whichCounter)
Get the value of counter.
The function is to read the value of Count register, software can read the counter registers at any time..
- Parameters:
base – SCTimer peripheral base address
whichCounter – SCTimer counter to use. In 16-bit mode, we can select Counter_L and Counter_H, In 32-bit mode, we can select Counter_U.
- Returns:
The value of counter selected.
-
static inline void SCTIMER_SetEventInState(SCT_Type *base, uint32_t event, uint32_t state)
Set the state mask bit field of EV_STATE register.
- Parameters:
base – SCTimer peripheral base address
event – The EV_STATE register be set.
state – The state value in which the event is enabled to occur.
-
static inline void SCTIMER_ClearEventInState(SCT_Type *base, uint32_t event, uint32_t state)
Clear the state mask bit field of EV_STATE register.
- Parameters:
base – SCTimer peripheral base address
event – The EV_STATE register be clear.
state – The state value in which the event is disabled to occur.
-
static inline bool SCTIMER_GetEventInState(SCT_Type *base, uint32_t event, uint32_t state)
Get the state mask bit field of EV_STATE register.
Note
This function is to check whether the event is enabled in a specific state.
- Parameters:
base – SCTimer peripheral base address
event – The EV_STATE register be read.
state – The state value.
- Returns:
The the state mask bit field of EV_STATE register.
true: The event is enable in state.
false: The event is disable in state.
-
static inline uint32_t SCTIMER_GetCaptureValue(SCT_Type *base, sctimer_counter_t whichCounter, uint8_t capChannel)
Get the value of capture register.
This function returns the captured value upon occurrence of the events selected by the corresponding Capture Control registers occurred.
- Parameters:
base – SCTimer peripheral base address
whichCounter – SCTimer counter to use. In 16-bit mode, we can select Counter_L and Counter_H, In 32-bit mode, we can select Counter_U.
capChannel – SCTimer capture register of capture channel.
- Returns:
The SCTimer counter value at which this register was last captured.
-
void SCTIMER_EventHandleIRQ(SCT_Type *base)
SCTimer interrupt handler.
- Parameters:
base – SCTimer peripheral base address.
-
FSL_SCTIMER_DRIVER_VERSION
Version
-
enum _sctimer_pwm_mode
SCTimer PWM operation modes.
Values:
-
enumerator kSCTIMER_EdgeAlignedPwm
Edge-aligned PWM
-
enumerator kSCTIMER_CenterAlignedPwm
Center-aligned PWM
-
enumerator kSCTIMER_EdgeAlignedPwm
-
enum _sctimer_counter
SCTimer counters type.
Values:
-
enumerator kSCTIMER_Counter_L
16-bit Low counter.
-
enumerator kSCTIMER_Counter_H
16-bit High counter.
-
enumerator kSCTIMER_Counter_U
32-bit Unified counter.
-
enumerator kSCTIMER_Counter_L
-
enum _sctimer_input
List of SCTimer input pins.
Values:
-
enumerator kSCTIMER_Input_0
SCTIMER input 0
-
enumerator kSCTIMER_Input_1
SCTIMER input 1
-
enumerator kSCTIMER_Input_2
SCTIMER input 2
-
enumerator kSCTIMER_Input_3
SCTIMER input 3
-
enumerator kSCTIMER_Input_4
SCTIMER input 4
-
enumerator kSCTIMER_Input_5
SCTIMER input 5
-
enumerator kSCTIMER_Input_6
SCTIMER input 6
-
enumerator kSCTIMER_Input_7
SCTIMER input 7
-
enumerator kSCTIMER_Input_0
-
enum _sctimer_out
List of SCTimer output pins.
Values:
-
enumerator kSCTIMER_Out_0
SCTIMER output 0
-
enumerator kSCTIMER_Out_1
SCTIMER output 1
-
enumerator kSCTIMER_Out_2
SCTIMER output 2
-
enumerator kSCTIMER_Out_3
SCTIMER output 3
-
enumerator kSCTIMER_Out_4
SCTIMER output 4
-
enumerator kSCTIMER_Out_5
SCTIMER output 5
-
enumerator kSCTIMER_Out_6
SCTIMER output 6
-
enumerator kSCTIMER_Out_7
SCTIMER output 7
-
enumerator kSCTIMER_Out_8
SCTIMER output 8
-
enumerator kSCTIMER_Out_9
SCTIMER output 9
-
enumerator kSCTIMER_Out_0
-
enum _sctimer_pwm_level_select
SCTimer PWM output pulse mode: high-true, low-true or no output.
Values:
-
enumerator kSCTIMER_LowTrue
Low true pulses
-
enumerator kSCTIMER_HighTrue
High true pulses
-
enumerator kSCTIMER_LowTrue
-
enum _sctimer_clock_mode
SCTimer clock mode options.
Values:
-
enumerator kSCTIMER_System_ClockMode
System Clock Mode
-
enumerator kSCTIMER_Sampled_ClockMode
Sampled System Clock Mode
-
enumerator kSCTIMER_Input_ClockMode
SCT Input Clock Mode
-
enumerator kSCTIMER_Asynchronous_ClockMode
Asynchronous Mode
-
enumerator kSCTIMER_System_ClockMode
-
enum _sctimer_clock_select
SCTimer clock select options.
Values:
-
enumerator kSCTIMER_Clock_On_Rise_Input_0
Rising edges on input 0
-
enumerator kSCTIMER_Clock_On_Fall_Input_0
Falling edges on input 0
-
enumerator kSCTIMER_Clock_On_Rise_Input_1
Rising edges on input 1
-
enumerator kSCTIMER_Clock_On_Fall_Input_1
Falling edges on input 1
-
enumerator kSCTIMER_Clock_On_Rise_Input_2
Rising edges on input 2
-
enumerator kSCTIMER_Clock_On_Fall_Input_2
Falling edges on input 2
-
enumerator kSCTIMER_Clock_On_Rise_Input_3
Rising edges on input 3
-
enumerator kSCTIMER_Clock_On_Fall_Input_3
Falling edges on input 3
-
enumerator kSCTIMER_Clock_On_Rise_Input_4
Rising edges on input 4
-
enumerator kSCTIMER_Clock_On_Fall_Input_4
Falling edges on input 4
-
enumerator kSCTIMER_Clock_On_Rise_Input_5
Rising edges on input 5
-
enumerator kSCTIMER_Clock_On_Fall_Input_5
Falling edges on input 5
-
enumerator kSCTIMER_Clock_On_Rise_Input_6
Rising edges on input 6
-
enumerator kSCTIMER_Clock_On_Fall_Input_6
Falling edges on input 6
-
enumerator kSCTIMER_Clock_On_Rise_Input_7
Rising edges on input 7
-
enumerator kSCTIMER_Clock_On_Fall_Input_7
Falling edges on input 7
-
enumerator kSCTIMER_Clock_On_Rise_Input_0
-
enum _sctimer_conflict_resolution
SCTimer output conflict resolution options.
Specifies what action should be taken if multiple events dictate that a given output should be both set and cleared at the same time
Values:
-
enumerator kSCTIMER_ResolveNone
No change
-
enumerator kSCTIMER_ResolveSet
Set output
-
enumerator kSCTIMER_ResolveClear
Clear output
-
enumerator kSCTIMER_ResolveToggle
Toggle output
-
enumerator kSCTIMER_ResolveNone
-
enum _sctimer_event_active_direction
List of SCTimer event generation active direction when the counters are operating in BIDIR mode.
Values:
-
enumerator kSCTIMER_ActiveIndependent
This event is triggered regardless of the count direction.
-
enumerator kSCTIMER_ActiveInCountUp
This event is triggered only during up-counting when BIDIR = 1.
-
enumerator kSCTIMER_ActiveInCountDown
This event is triggered only during down-counting when BIDIR = 1.
-
enumerator kSCTIMER_ActiveIndependent
-
enum _sctimer_event
List of SCTimer event types.
Values:
-
enumerator kSCTIMER_InputLowOrMatchEvent
-
enumerator kSCTIMER_InputRiseOrMatchEvent
-
enumerator kSCTIMER_InputFallOrMatchEvent
-
enumerator kSCTIMER_InputHighOrMatchEvent
-
enumerator kSCTIMER_MatchEventOnly
-
enumerator kSCTIMER_InputLowEvent
-
enumerator kSCTIMER_InputRiseEvent
-
enumerator kSCTIMER_InputFallEvent
-
enumerator kSCTIMER_InputHighEvent
-
enumerator kSCTIMER_InputLowAndMatchEvent
-
enumerator kSCTIMER_InputRiseAndMatchEvent
-
enumerator kSCTIMER_InputFallAndMatchEvent
-
enumerator kSCTIMER_InputHighAndMatchEvent
-
enumerator kSCTIMER_OutputLowOrMatchEvent
-
enumerator kSCTIMER_OutputRiseOrMatchEvent
-
enumerator kSCTIMER_OutputFallOrMatchEvent
-
enumerator kSCTIMER_OutputHighOrMatchEvent
-
enumerator kSCTIMER_OutputLowEvent
-
enumerator kSCTIMER_OutputRiseEvent
-
enumerator kSCTIMER_OutputFallEvent
-
enumerator kSCTIMER_OutputHighEvent
-
enumerator kSCTIMER_OutputLowAndMatchEvent
-
enumerator kSCTIMER_OutputRiseAndMatchEvent
-
enumerator kSCTIMER_OutputFallAndMatchEvent
-
enumerator kSCTIMER_OutputHighAndMatchEvent
-
enumerator kSCTIMER_InputLowOrMatchEvent
-
enum _sctimer_interrupt_enable
List of SCTimer interrupts.
Values:
-
enumerator kSCTIMER_Event0InterruptEnable
Event 0 interrupt
-
enumerator kSCTIMER_Event1InterruptEnable
Event 1 interrupt
-
enumerator kSCTIMER_Event2InterruptEnable
Event 2 interrupt
-
enumerator kSCTIMER_Event3InterruptEnable
Event 3 interrupt
-
enumerator kSCTIMER_Event4InterruptEnable
Event 4 interrupt
-
enumerator kSCTIMER_Event5InterruptEnable
Event 5 interrupt
-
enumerator kSCTIMER_Event6InterruptEnable
Event 6 interrupt
-
enumerator kSCTIMER_Event7InterruptEnable
Event 7 interrupt
-
enumerator kSCTIMER_Event8InterruptEnable
Event 8 interrupt
-
enumerator kSCTIMER_Event9InterruptEnable
Event 9 interrupt
-
enumerator kSCTIMER_Event10InterruptEnable
Event 10 interrupt
-
enumerator kSCTIMER_Event11InterruptEnable
Event 11 interrupt
-
enumerator kSCTIMER_Event12InterruptEnable
Event 12 interrupt
-
enumerator kSCTIMER_Event0InterruptEnable
-
enum _sctimer_status_flags
List of SCTimer flags.
Values:
-
enumerator kSCTIMER_Event0Flag
Event 0 Flag
-
enumerator kSCTIMER_Event1Flag
Event 1 Flag
-
enumerator kSCTIMER_Event2Flag
Event 2 Flag
-
enumerator kSCTIMER_Event3Flag
Event 3 Flag
-
enumerator kSCTIMER_Event4Flag
Event 4 Flag
-
enumerator kSCTIMER_Event5Flag
Event 5 Flag
-
enumerator kSCTIMER_Event6Flag
Event 6 Flag
-
enumerator kSCTIMER_Event7Flag
Event 7 Flag
-
enumerator kSCTIMER_Event8Flag
Event 8 Flag
-
enumerator kSCTIMER_Event9Flag
Event 9 Flag
-
enumerator kSCTIMER_Event10Flag
Event 10 Flag
-
enumerator kSCTIMER_Event11Flag
Event 11 Flag
-
enumerator kSCTIMER_Event12Flag
Event 12 Flag
-
enumerator kSCTIMER_BusErrorLFlag
Bus error due to write when L counter was not halted
-
enumerator kSCTIMER_BusErrorHFlag
Bus error due to write when H counter was not halted
-
enumerator kSCTIMER_Event0Flag
-
typedef enum _sctimer_pwm_mode sctimer_pwm_mode_t
SCTimer PWM operation modes.
-
typedef enum _sctimer_counter sctimer_counter_t
SCTimer counters type.
-
typedef enum _sctimer_input sctimer_input_t
List of SCTimer input pins.
-
typedef enum _sctimer_out sctimer_out_t
List of SCTimer output pins.
-
typedef enum _sctimer_pwm_level_select sctimer_pwm_level_select_t
SCTimer PWM output pulse mode: high-true, low-true or no output.
-
typedef struct _sctimer_pwm_signal_param sctimer_pwm_signal_param_t
Options to configure a SCTimer PWM signal.
-
typedef enum _sctimer_clock_mode sctimer_clock_mode_t
SCTimer clock mode options.
-
typedef enum _sctimer_clock_select sctimer_clock_select_t
SCTimer clock select options.
-
typedef enum _sctimer_conflict_resolution sctimer_conflict_resolution_t
SCTimer output conflict resolution options.
Specifies what action should be taken if multiple events dictate that a given output should be both set and cleared at the same time
-
typedef enum _sctimer_event_active_direction sctimer_event_active_direction_t
List of SCTimer event generation active direction when the counters are operating in BIDIR mode.
-
typedef enum _sctimer_event sctimer_event_t
List of SCTimer event types.
-
typedef void (*sctimer_event_callback_t)(void)
SCTimer callback typedef.
-
typedef enum _sctimer_interrupt_enable sctimer_interrupt_enable_t
List of SCTimer interrupts.
-
typedef enum _sctimer_status_flags sctimer_status_flags_t
List of SCTimer flags.
-
typedef struct _sctimer_config sctimer_config_t
SCTimer configuration structure.
This structure holds the configuration settings for the SCTimer peripheral. To initialize this structure to reasonable defaults, call the SCTMR_GetDefaultConfig() function and pass a pointer to the configuration structure instance.
The configuration structure can be made constant so as to reside in flash.
-
SCT_EV_STATE_STATEMSKn(x)
-
struct _sctimer_pwm_signal_param
- #include <fsl_sctimer.h>
Options to configure a SCTimer PWM signal.
Public Members
-
sctimer_out_t output
The output pin to use to generate the PWM signal
-
sctimer_pwm_level_select_t level
PWM output active level select.
-
uint8_t dutyCyclePercent
PWM pulse width, value should be between 0 to 100 0 = always inactive signal (0% duty cycle) 100 = always active signal (100% duty cycle).
-
sctimer_out_t output
-
struct _sctimer_config
- #include <fsl_sctimer.h>
SCTimer configuration structure.
This structure holds the configuration settings for the SCTimer peripheral. To initialize this structure to reasonable defaults, call the SCTMR_GetDefaultConfig() function and pass a pointer to the configuration structure instance.
The configuration structure can be made constant so as to reside in flash.
Public Members
-
bool enableCounterUnify
true: SCT operates as a unified 32-bit counter; false: SCT operates as two 16-bit counters. User can use the 16-bit low counter and the 16-bit high counters at the same time; for Hardware limit, user can not use unified 32-bit counter and any 16-bit low/high counter at the same time.
-
sctimer_clock_mode_t clockMode
SCT clock mode value
-
sctimer_clock_select_t clockSelect
SCT clock select value
-
bool enableBidirection_l
true: Up-down count mode for the L or unified counter false: Up count mode only for the L or unified counter
-
bool enableBidirection_h
true: Up-down count mode for the H or unified counter false: Up count mode only for the H or unified counter. This field is used only if the enableCounterUnify is set to false
-
uint8_t prescale_l
Prescale value to produce the L or unified counter clock
-
uint8_t prescale_h
Prescale value to produce the H counter clock. This field is used only if the enableCounterUnify is set to false
-
uint8_t outInitState
Defines the initial output value
-
uint8_t inputsync
SCT INSYNC value, INSYNC field in the CONFIG register, from bit9 to bit 16. it is used to define synchronization for input N: bit 9 = input 0 bit 10 = input 1 bit 11 = input 2 bit 12 = input 3 All other bits are reserved (bit13 ~bit 16). How User to set the the value for the member inputsync. IE: delay for input0, and input 1, bypasses for input 2 and input 3 MACRO definition in user level. #define INPUTSYNC0 (0U) #define INPUTSYNC1 (1U) #define INPUTSYNC2 (2U) #define INPUTSYNC3 (3U) User Code. sctimerInfo.inputsync = (1 << INPUTSYNC2) | (1 << INPUTSYNC3);
-
bool enableCounterUnify
SPI: Serial Peripheral Interface Driver
SPI DMA Driver
-
status_t 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.
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.
- 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.
-
status_t SPI_MasterTransferDMA(SPI_Type *base, spi_dma_handle_t *handle, spi_transfer_t *xfer)
Perform a non-blocking SPI transfer using DMA.
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.
-
status_t SPI_MasterHalfDuplexTransferDMA(SPI_Type *base, spi_dma_handle_t *handle, spi_half_duplex_transfer_t *xfer)
Transfers a block of data using a DMA method.
This function using polling way to do the first half transimission and using DMA way to do the srcond half transimission, the transfer mechanism is half-duplex. When do the second half transimission, code will return right away. When all data is transferred, the callback function is called.
- Parameters:
base – SPI base pointer
handle – A pointer to the spi_master_dma_handle_t structure which stores the transfer state.
xfer – A pointer to the spi_half_duplex_transfer_t structure.
- Returns:
status of status_t.
-
static inline status_t 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.
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.
-
static inline status_t SPI_SlaveTransferDMA(SPI_Type *base, spi_dma_handle_t *handle, spi_transfer_t *xfer)
Perform a non-blocking SPI transfer using DMA.
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.
-
void SPI_MasterTransferAbortDMA(SPI_Type *base, spi_dma_handle_t *handle)
Abort a SPI transfer using DMA.
- Parameters:
base – SPI peripheral base address.
handle – SPI DMA handle pointer.
-
status_t SPI_MasterTransferGetCountDMA(SPI_Type *base, spi_dma_handle_t *handle, size_t *count)
Gets the master DMA transfer remaining bytes.
This function gets the master DMA transfer remaining bytes.
- Parameters:
base – SPI peripheral base address.
handle – A pointer to the spi_dma_handle_t structure which stores the transfer state.
count – A number of bytes transferred by the non-blocking transaction.
- Returns:
status of status_t.
-
static inline void SPI_SlaveTransferAbortDMA(SPI_Type *base, spi_dma_handle_t *handle)
Abort a SPI transfer using DMA.
- Parameters:
base – SPI peripheral base address.
handle – SPI DMA handle pointer.
-
static inline status_t SPI_SlaveTransferGetCountDMA(SPI_Type *base, spi_dma_handle_t *handle, size_t *count)
Gets the slave DMA transfer remaining bytes.
This function gets the slave DMA transfer remaining bytes.
- Parameters:
base – SPI peripheral base address.
handle – A pointer to the spi_dma_handle_t structure which stores the transfer state.
count – A number of bytes transferred by the non-blocking transaction.
- Returns:
status of status_t.
-
FSL_SPI_DMA_DRIVER_VERSION
SPI DMA driver version 2.1.1.
-
typedef struct _spi_dma_handle spi_dma_handle_t
-
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.
-
struct _spi_dma_handle
- #include <fsl_spi_dma.h>
SPI DMA transfer handle, users should not touch the content of the handle.
Public Members
-
volatile bool txInProgress
Send transfer finished
-
volatile bool rxInProgress
Receive transfer finished
-
uint8_t bytesPerFrame
Bytes in a frame for SPI transfer
-
uint8_t lastwordBytes
The Bytes of lastword for master
-
dma_handle_t *txHandle
DMA handler for SPI send
-
dma_handle_t *rxHandle
DMA handler for SPI receive
-
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
-
uint32_t instance
Index of SPI instance
-
const uint8_t *txNextData
The pointer of next time tx data
-
const uint8_t *txEndData
The pointer of end of data
-
uint8_t *rxNextData
The pointer of next time rx data
-
uint8_t *rxEndData
The pointer of end of rx data
-
uint32_t dataBytesEveryTime
Bytes in a time for DMA transfer, default is DMA_MAX_TRANSFER_COUNT
-
volatile bool txInProgress
SPI Driver
-
FSL_SPI_DRIVER_VERSION
SPI driver version.
-
enum _spi_xfer_option
SPI transfer option.
Values:
-
enumerator kSPI_FrameDelay
A delay may be inserted, defined in the DLY register.
-
enumerator kSPI_FrameAssert
SSEL will be deasserted at the end of a transfer
-
enumerator kSPI_FrameDelay
-
enum _spi_shift_direction
SPI data shifter direction options.
Values:
-
enumerator kSPI_MsbFirst
Data transfers start with most significant bit.
-
enumerator kSPI_LsbFirst
Data transfers start with least significant bit.
-
enumerator kSPI_MsbFirst
-
enum _spi_clock_polarity
SPI clock polarity configuration.
Values:
-
enumerator kSPI_ClockPolarityActiveHigh
Active-high SPI clock (idles low).
-
enumerator kSPI_ClockPolarityActiveLow
Active-low SPI clock (idles high).
-
enumerator kSPI_ClockPolarityActiveHigh
-
enum _spi_clock_phase
SPI clock phase configuration.
Values:
-
enumerator kSPI_ClockPhaseFirstEdge
First edge on SCK occurs at the middle of the first cycle of a data transfer.
-
enumerator kSPI_ClockPhaseSecondEdge
First edge on SCK occurs at the start of the first cycle of a data transfer.
-
enumerator kSPI_ClockPhaseFirstEdge
-
enum _spi_txfifo_watermark
txFIFO watermark values
Values:
-
enumerator kSPI_TxFifo0
SPI tx watermark is empty
-
enumerator kSPI_TxFifo1
SPI tx watermark at 1 item
-
enumerator kSPI_TxFifo2
SPI tx watermark at 2 items
-
enumerator kSPI_TxFifo3
SPI tx watermark at 3 items
-
enumerator kSPI_TxFifo4
SPI tx watermark at 4 items
-
enumerator kSPI_TxFifo5
SPI tx watermark at 5 items
-
enumerator kSPI_TxFifo6
SPI tx watermark at 6 items
-
enumerator kSPI_TxFifo7
SPI tx watermark at 7 items
-
enumerator kSPI_TxFifo0
-
enum _spi_rxfifo_watermark
rxFIFO watermark values
Values:
-
enumerator kSPI_RxFifo1
SPI rx watermark at 1 item
-
enumerator kSPI_RxFifo2
SPI rx watermark at 2 items
-
enumerator kSPI_RxFifo3
SPI rx watermark at 3 items
-
enumerator kSPI_RxFifo4
SPI rx watermark at 4 items
-
enumerator kSPI_RxFifo5
SPI rx watermark at 5 items
-
enumerator kSPI_RxFifo6
SPI rx watermark at 6 items
-
enumerator kSPI_RxFifo7
SPI rx watermark at 7 items
-
enumerator kSPI_RxFifo8
SPI rx watermark at 8 items
-
enumerator kSPI_RxFifo1
-
enum _spi_data_width
Transfer data width.
Values:
-
enumerator kSPI_Data4Bits
4 bits data width
-
enumerator kSPI_Data5Bits
5 bits data width
-
enumerator kSPI_Data6Bits
6 bits data width
-
enumerator kSPI_Data7Bits
7 bits data width
-
enumerator kSPI_Data8Bits
8 bits data width
-
enumerator kSPI_Data9Bits
9 bits data width
-
enumerator kSPI_Data10Bits
10 bits data width
-
enumerator kSPI_Data11Bits
11 bits data width
-
enumerator kSPI_Data12Bits
12 bits data width
-
enumerator kSPI_Data13Bits
13 bits data width
-
enumerator kSPI_Data14Bits
14 bits data width
-
enumerator kSPI_Data15Bits
15 bits data width
-
enumerator kSPI_Data16Bits
16 bits data width
-
enumerator kSPI_Data4Bits
-
enum _spi_ssel
Slave select.
Values:
-
enumerator kSPI_Ssel0
Slave select 0
-
enumerator kSPI_Ssel1
Slave select 1
-
enumerator kSPI_Ssel2
Slave select 2
-
enumerator kSPI_Ssel3
Slave select 3
-
enumerator kSPI_Ssel0
-
enum _spi_spol
ssel polarity
Values:
-
enumerator kSPI_Spol0ActiveHigh
-
enumerator kSPI_Spol1ActiveHigh
-
enumerator kSPI_Spol3ActiveHigh
-
enumerator kSPI_SpolActiveAllHigh
-
enumerator kSPI_SpolActiveAllLow
-
enumerator kSPI_Spol0ActiveHigh
SPI transfer status.
Values:
-
enumerator kStatus_SPI_Busy
SPI bus is busy
-
enumerator kStatus_SPI_Idle
SPI is idle
-
enumerator kStatus_SPI_Error
SPI error
-
enumerator kStatus_SPI_BaudrateNotSupport
Baudrate is not support in current clock source
-
enumerator kStatus_SPI_Timeout
SPI timeout polling status flags.
-
enumerator kStatus_SPI_Busy
-
enum _spi_interrupt_enable
SPI interrupt sources.
Values:
-
enumerator kSPI_RxLvlIrq
Rx level interrupt
-
enumerator kSPI_TxLvlIrq
Tx level interrupt
-
enumerator kSPI_RxLvlIrq
-
enum _spi_statusflags
SPI status flags.
Values:
-
enumerator kSPI_TxEmptyFlag
txFifo is empty
-
enumerator kSPI_TxNotFullFlag
txFifo is not full
-
enumerator kSPI_RxNotEmptyFlag
rxFIFO is not empty
-
enumerator kSPI_RxFullFlag
rxFIFO is full
-
enumerator kSPI_TxEmptyFlag
-
typedef enum _spi_xfer_option spi_xfer_option_t
SPI transfer option.
-
typedef enum _spi_shift_direction spi_shift_direction_t
SPI data shifter direction options.
-
typedef enum _spi_clock_polarity spi_clock_polarity_t
SPI clock polarity configuration.
-
typedef enum _spi_clock_phase spi_clock_phase_t
SPI clock phase configuration.
-
typedef enum _spi_txfifo_watermark spi_txfifo_watermark_t
txFIFO watermark values
-
typedef enum _spi_rxfifo_watermark spi_rxfifo_watermark_t
rxFIFO watermark values
-
typedef enum _spi_data_width spi_data_width_t
Transfer data width.
-
typedef enum _spi_ssel spi_ssel_t
Slave select.
-
typedef enum _spi_spol spi_spol_t
ssel polarity
-
typedef struct _spi_delay_config spi_delay_config_t
SPI delay time configure structure. Note: The DLY register controls several programmable delays related to SPI signalling, it stands for how many SPI clock time will be inserted. The maxinun value of these delay time is 15.
-
typedef struct _spi_master_config spi_master_config_t
SPI master user configure structure.
-
typedef struct _spi_slave_config spi_slave_config_t
SPI slave user configure structure.
-
typedef struct _spi_transfer spi_transfer_t
SPI transfer structure.
-
typedef struct _spi_half_duplex_transfer spi_half_duplex_transfer_t
SPI half-duplex(master only) transfer structure.
-
typedef struct _spi_config spi_config_t
Internal configuration structure used in ‘spi’ and ‘spi_dma’ driver.
-
typedef struct _spi_master_handle spi_master_handle_t
Master handle type.
-
typedef spi_master_handle_t spi_slave_handle_t
Slave handle type.
-
typedef void (*spi_master_callback_t)(SPI_Type *base, spi_master_handle_t *handle, status_t status, 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 slave callback for finished transmit.
-
typedef void (*flexcomm_spi_master_irq_handler_t)(SPI_Type *base, spi_master_handle_t *handle)
Typedef for master interrupt handler.
-
typedef void (*flexcomm_spi_slave_irq_handler_t)(SPI_Type *base, spi_slave_handle_t *handle)
Typedef for slave interrupt handler.
-
volatile uint8_t s_dummyData[]
SPI default SSEL COUNT.
Global variable for dummy data value setting.
-
SPI_DUMMYDATA
SPI dummy transfer data, the data is sent while txBuff is NULL.
-
SPI_RETRY_TIMES
Retry times for waiting flag.
-
SPI_DATA(n)
-
SPI_CTRLMASK
-
SPI_ASSERTNUM_SSEL(n)
-
SPI_DEASSERTNUM_SSEL(n)
-
SPI_DEASSERT_ALL
-
SPI_FIFOWR_FLAGS_MASK
-
SPI_FIFOTRIG_TXLVL_GET(base)
-
SPI_FIFOTRIG_RXLVL_GET(base)
-
struct _spi_delay_config
- #include <fsl_spi.h>
SPI delay time configure structure. Note: The DLY register controls several programmable delays related to SPI signalling, it stands for how many SPI clock time will be inserted. The maxinun value of these delay time is 15.
Public Members
-
uint8_t preDelay
Delay between SSEL assertion and the beginning of transfer.
-
uint8_t postDelay
Delay between the end of transfer and SSEL deassertion.
-
uint8_t frameDelay
Delay between frame to frame.
-
uint8_t transferDelay
Delay between transfer to transfer.
-
uint8_t preDelay
-
struct _spi_master_config
- #include <fsl_spi.h>
SPI master user configure structure.
Public Members
-
bool enableLoopback
Enable loopback for test purpose
-
bool enableMaster
Enable SPI at initialization time
-
spi_clock_polarity_t polarity
Clock polarity
-
spi_clock_phase_t phase
Clock phase
-
spi_shift_direction_t direction
MSB or LSB
-
uint32_t baudRate_Bps
Baud Rate for SPI in Hz
-
spi_data_width_t dataWidth
Width of the data
-
spi_ssel_t sselNum
Slave select number
-
spi_spol_t sselPol
Configure active CS polarity
-
uint8_t txWatermark
txFIFO watermark
-
uint8_t rxWatermark
rxFIFO watermark
-
spi_delay_config_t delayConfig
Delay configuration.
-
bool enableLoopback
-
struct _spi_slave_config
- #include <fsl_spi.h>
SPI slave user configure structure.
Public Members
-
bool enableSlave
Enable SPI at initialization time
-
spi_clock_polarity_t polarity
Clock polarity
-
spi_clock_phase_t phase
Clock phase
-
spi_shift_direction_t direction
MSB or LSB
-
spi_data_width_t dataWidth
Width of the data
-
spi_spol_t sselPol
Configure active CS polarity
-
uint8_t txWatermark
txFIFO watermark
-
uint8_t rxWatermark
rxFIFO watermark
-
bool enableSlave
-
struct _spi_transfer
- #include <fsl_spi.h>
SPI transfer structure.
Public Members
-
const uint8_t *txData
Send buffer
-
uint8_t *rxData
Receive buffer
-
uint32_t configFlags
Additional option to control transfer, spi_xfer_option_t.
-
size_t dataSize
Transfer bytes
-
const uint8_t *txData
-
struct _spi_half_duplex_transfer
- #include <fsl_spi.h>
SPI half-duplex(master only) transfer structure.
Public Members
-
const uint8_t *txData
Send buffer
-
uint8_t *rxData
Receive buffer
-
size_t txDataSize
Transfer bytes for transmit
-
size_t rxDataSize
Transfer bytes
-
uint32_t configFlags
Transfer configuration flags, spi_xfer_option_t.
-
bool isPcsAssertInTransfer
If PCS pin keep assert between transmit and receive. true for assert and false for deassert.
-
bool isTransmitFirst
True for transmit first and false for receive first.
-
const uint8_t *txData
-
struct _spi_config
- #include <fsl_spi.h>
Internal configuration structure used in ‘spi’ and ‘spi_dma’ driver.
-
struct _spi_master_handle
- #include <fsl_spi.h>
SPI transfer handle structure.
Public Members
-
const uint8_t *volatile txData
Transfer buffer
-
uint8_t *volatile rxData
Receive buffer
-
volatile size_t txRemainingBytes
Number of data to be transmitted [in bytes]
-
volatile size_t rxRemainingBytes
Number of data to be received [in bytes]
-
volatile int8_t toReceiveCount
The number of data expected to receive in data width. Since the received count and sent count should be the same to complete the transfer, if the sent count is x and the received count is y, toReceiveCount is x-y.
-
size_t totalByteCount
A number of transfer bytes
-
volatile uint32_t state
SPI internal state
-
spi_master_callback_t callback
SPI callback
-
void *userData
Callback parameter
-
uint8_t dataWidth
Width of the data [Valid values: 1 to 16]
-
uint8_t sselNum
Slave select number to be asserted when transferring data [Valid values: 0 to 3]
-
uint32_t configFlags
Additional option to control transfer
-
uint8_t txWatermark
txFIFO watermark
-
uint8_t rxWatermark
rxFIFO watermark
-
const uint8_t *volatile txData
SYSCTL: I2S bridging and signal sharing Configuration
-
void SYSCTL_Init(SYSCTL_Type *base)
SYSCTL initial.
- Parameters:
base – Base address of the SYSCTL peripheral.
-
void SYSCTL_Deinit(SYSCTL_Type *base)
SYSCTL deinit.
- Parameters:
base – Base address of the SYSCTL peripheral.
-
void SYSCTL_SetFlexcommShareSet(SYSCTL_Type *base, uint32_t flexCommIndex, uint32_t sckSet, uint32_t wsSet, uint32_t dataInSet, uint32_t dataOutSet)
SYSCTL share set configure for flexcomm.
- Parameters:
base – Base address of the SYSCTL peripheral.
flexCommIndex – index of flexcomm, reference _sysctl_share_src
sckSet – share set for sck,reference _sysctl_share_set_index
wsSet – share set for ws, reference _sysctl_share_set_index
dataInSet – share set for data in, reference _sysctl_share_set_index
dataOutSet – share set for data out, reference _sysctl_dataout_mask
-
void SYSCTL_SetShareSet(SYSCTL_Type *base, uint32_t flexCommIndex, sysctl_fcctrlsel_signal_t signal, uint32_t set)
SYSCTL share set configure for separate signal.
- Parameters:
base – Base address of the SYSCTL peripheral
flexCommIndex – index of flexcomm,reference _sysctl_share_src
signal – FCCTRLSEL signal shift
set – share set for sck, reference _sysctl_share_set_index
-
void SYSCTL_SetShareSetSrc(SYSCTL_Type *base, uint32_t setIndex, uint32_t sckShareSrc, uint32_t wsShareSrc, uint32_t dataInShareSrc, uint32_t dataOutShareSrc)
SYSCTL share set source configure.
- Parameters:
base – Base address of the SYSCTL peripheral
setIndex – index of share set, reference _sysctl_share_set_index
sckShareSrc – sck source for this share set,reference _sysctl_share_src
wsShareSrc – ws source for this share set,reference _sysctl_share_src
dataInShareSrc – data in source for this share set,reference _sysctl_share_src
dataOutShareSrc – data out source for this share set,reference _sysctl_dataout_mask
-
void SYSCTL_SetShareSignalSrc(SYSCTL_Type *base, uint32_t setIndex, sysctl_sharedctrlset_signal_t signal, uint32_t shareSrc)
SYSCTL sck source configure.
- Parameters:
base – Base address of the SYSCTL peripheral
setIndex – index of share set, reference _sysctl_share_set_index
signal – FCCTRLSEL signal shift
shareSrc – sck source fro this share set,reference _sysctl_share_src
-
FSL_SYSCTL_DRIVER_VERSION
Group sysctl driver version for SDK.
Version 2.0.5.
-
enum _sysctl_share_set_index
SYSCTL share set.
Values:
-
enumerator kSYSCTL_ShareSet0
share set 0
-
enumerator kSYSCTL_ShareSet1
share set 1
-
enumerator kSYSCTL_ShareSet0
-
enum _sysctl_fcctrlsel_signal
SYSCTL flexcomm signal.
Values:
-
enumerator kSYSCTL_FlexcommSignalSCK
SCK signal
-
enumerator kSYSCTL_FlexcommSignalWS
WS signal
-
enumerator kSYSCTL_FlexcommSignalDataIn
Data in signal
-
enumerator kSYSCTL_FlexcommSignalDataOut
Data out signal
-
enumerator kSYSCTL_FlexcommSignalSCK
-
enum _sysctl_share_src
SYSCTL flexcomm index.
Values:
-
enumerator kSYSCTL_Flexcomm0
share set 0
-
enumerator kSYSCTL_Flexcomm1
share set 1
-
enumerator kSYSCTL_Flexcomm2
share set 2
-
enumerator kSYSCTL_Flexcomm4
share set 4
-
enumerator kSYSCTL_Flexcomm5
share set 5
-
enumerator kSYSCTL_Flexcomm6
share set 6
-
enumerator kSYSCTL_Flexcomm7
share set 7
-
enumerator kSYSCTL_Flexcomm0
-
enum _sysctl_dataout_mask
SYSCTL shared data out mask.
Values:
-
enumerator kSYSCTL_Flexcomm0DataOut
share set 0
-
enumerator kSYSCTL_Flexcomm1DataOut
share set 1
-
enumerator kSYSCTL_Flexcomm2DataOut
share set 2
-
enumerator kSYSCTL_Flexcomm4DataOut
share set 4
-
enumerator kSYSCTL_Flexcomm5DataOut
share set 5
-
enumerator kSYSCTL_Flexcomm6DataOut
share set 6
-
enumerator kSYSCTL_Flexcomm7DataOut
share set 7
-
enumerator kSYSCTL_Flexcomm0DataOut
-
enum _sysctl_sharedctrlset_signal
SYSCTL flexcomm signal.
Values:
-
enumerator kSYSCTL_SharedCtrlSignalSCK
SCK signal
-
enumerator kSYSCTL_SharedCtrlSignalWS
WS signal
-
enumerator kSYSCTL_SharedCtrlSignalDataIn
Data in signal
-
enumerator kSYSCTL_SharedCtrlSignalDataOut
Data out signal
-
enumerator kSYSCTL_SharedCtrlSignalSCK
-
typedef enum _sysctl_fcctrlsel_signal sysctl_fcctrlsel_signal_t
SYSCTL flexcomm signal.
-
typedef enum _sysctl_sharedctrlset_signal sysctl_sharedctrlset_signal_t
SYSCTL flexcomm signal.
USART: Universal Synchronous/Asynchronous Receiver/Transmitter Driver
USART DMA Driver
-
status_t USART_TransferCreateHandleDMA(USART_Type *base, usart_dma_handle_t *handle, usart_dma_transfer_callback_t callback, void *userData, dma_handle_t *txDmaHandle, dma_handle_t *rxDmaHandle)
Initializes the USART handle which is used in transactional functions.
- Parameters:
base – USART peripheral base address.
handle – Pointer to usart_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.
-
status_t USART_TransferSendDMA(USART_Type *base, usart_dma_handle_t *handle, usart_transfer_t *xfer)
Sends data using DMA.
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 – USART peripheral base address.
handle – USART handle pointer.
xfer – USART DMA transfer structure. See usart_transfer_t.
- Return values:
kStatus_Success – if succeed, others failed.
kStatus_USART_TxBusy – Previous transfer on going.
kStatus_InvalidArgument – Invalid argument.
-
status_t USART_TransferReceiveDMA(USART_Type *base, usart_dma_handle_t *handle, usart_transfer_t *xfer)
Receives data using DMA.
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:
base – USART peripheral base address.
handle – Pointer to usart_dma_handle_t structure.
xfer – USART DMA transfer structure. See usart_transfer_t.
- Return values:
kStatus_Success – if succeed, others failed.
kStatus_USART_RxBusy – Previous transfer on going.
kStatus_InvalidArgument – Invalid argument.
-
void USART_TransferAbortSendDMA(USART_Type *base, usart_dma_handle_t *handle)
Aborts the sent data using DMA.
This function aborts send data using DMA.
- Parameters:
base – USART peripheral base address
handle – Pointer to usart_dma_handle_t structure
-
void USART_TransferAbortReceiveDMA(USART_Type *base, usart_dma_handle_t *handle)
Aborts the received data using DMA.
This function aborts the received data using DMA.
- Parameters:
base – USART peripheral base address
handle – Pointer to usart_dma_handle_t structure
-
status_t USART_TransferGetReceiveCountDMA(USART_Type *base, usart_dma_handle_t *handle, uint32_t *count)
Get the number of bytes that have been received.
This function gets the number of bytes that have been received.
- Parameters:
base – USART peripheral base address.
handle – USART handle pointer.
count – Receive bytes count.
- Return values:
kStatus_NoTransferInProgress – No receive in progress.
kStatus_InvalidArgument – Parameter is invalid.
kStatus_Success – Get successfully through the parameter
count
;
-
status_t USART_TransferGetSendCountDMA(USART_Type *base, usart_dma_handle_t *handle, uint32_t *count)
Get the number of bytes that have been sent.
This function gets the number of bytes that have been sent.
- Parameters:
base – USART peripheral base address.
handle – USART handle pointer.
count – Sent bytes count.
- Return values:
kStatus_NoTransferInProgress – No receive in progress.
kStatus_InvalidArgument – Parameter is invalid.
kStatus_Success – Get successfully through the parameter
count
;
-
FSL_USART_DMA_DRIVER_VERSION
USART dma driver version.
-
typedef struct _usart_dma_handle usart_dma_handle_t
-
typedef void (*usart_dma_transfer_callback_t)(USART_Type *base, usart_dma_handle_t *handle, status_t status, void *userData)
UART transfer callback function.
-
struct _usart_dma_handle
- #include <fsl_usart_dma.h>
UART DMA handle.
Public Members
-
USART_Type *base
UART peripheral base address.
-
usart_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
-
USART_Type *base
USART Driver
-
status_t USART_Init(USART_Type *base, const usart_config_t *config, uint32_t srcClock_Hz)
Initializes a USART instance with user configuration structure and peripheral clock.
This function configures the USART module with the user-defined settings. The user can configure the configuration structure and also get the default configuration by using the USART_GetDefaultConfig() function. Example below shows how to use this API to configure USART.
usart_config_t usartConfig; usartConfig.baudRate_Bps = 115200U; usartConfig.parityMode = kUSART_ParityDisabled; usartConfig.stopBitCount = kUSART_OneStopBit; USART_Init(USART1, &usartConfig, 20000000U);
- Parameters:
base – USART peripheral base address.
config – Pointer to user-defined configuration structure.
srcClock_Hz – USART clock source frequency in HZ.
- Return values:
kStatus_USART_BaudrateNotSupport – Baudrate is not support in current clock source.
kStatus_InvalidArgument – USART base address is not valid
kStatus_Success – Status USART initialize succeed
-
void USART_CalcTimeoutConfig(uint32_t target_us, uint8_t *rxTimeoutPrescaler, uint32_t *rxTimeoutcounter, uint32_t srcClock_Hz)
Calculate the USART instance RX timeout prescaler and counter.
This function for calculate the USART RXFIFO timeout config. This function is used to calculate suitable prescaler and counter for target_us.
usart_config_t config; config.rxWatermark = kUSART_RxFifo2; config.rxTimeout.enable = true; config.rxTimeout.resetCounterOnEmpty = true; config.rxTimeout.resetCounterOnReceive = true; USART_CalcTimeoutConfig(200U, &config.rxTimeout.prescaler, &config.rxTimeout.counter, CLOCK_GetFreq(kCLOCK_BusClk));
- Parameters:
target_us – Time for rx timeout unit us.
rxTimeoutPrescaler – The prescaler to be setted after function.
rxTimeoutcounter – The counter to be setted after function.
srcClock_Hz – The clockSrc for rx timeout.
-
void USART_SetRxTimeoutConfig(USART_Type *base, const usart_rx_timeout_config *config)
Sets the USART instance RX timeout config.
This function configures the USART RXFIFO timeout config. This function is used to config the USART RXFIFO timeout config after the USART module is initialized by the USART_Init.
- Parameters:
base – USART peripheral base address.
config – pointer to receive timeout configuration structure.
-
void USART_Deinit(USART_Type *base)
Deinitializes a USART instance.
This function waits for TX complete, disables TX and RX, and disables the USART clock.
- Parameters:
base – USART peripheral base address.
-
void USART_GetDefaultConfig(usart_config_t *config)
Gets the default configuration structure.
This function initializes the USART configuration structure to a default value. The default values are: usartConfig->baudRate_Bps = 115200U; usartConfig->parityMode = kUSART_ParityDisabled; usartConfig->stopBitCount = kUSART_OneStopBit; usartConfig->bitCountPerChar = kUSART_8BitsPerChar; usartConfig->loopback = false; usartConfig->enableTx = false; usartConfig->enableRx = false;
- Parameters:
config – Pointer to configuration structure.
-
status_t USART_SetBaudRate(USART_Type *base, uint32_t baudrate_Bps, uint32_t srcClock_Hz)
Sets the USART instance baud rate.
This function configures the USART module baud rate. This function is used to update the USART module baud rate after the USART module is initialized by the USART_Init.
USART_SetBaudRate(USART1, 115200U, 20000000U);
- Parameters:
base – USART peripheral base address.
baudrate_Bps – USART baudrate to be set.
srcClock_Hz – USART clock source frequency in HZ.
- Return values:
kStatus_USART_BaudrateNotSupport – Baudrate is not support in current clock source.
kStatus_Success – Set baudrate succeed.
kStatus_InvalidArgument – One or more arguments are invalid.
-
status_t USART_Enable32kMode(USART_Type *base, uint32_t baudRate_Bps, bool enableMode32k, uint32_t srcClock_Hz)
Enable 32 kHz mode which USART uses clock from the RTC oscillator as the clock source.
Please note that in order to use a 32 kHz clock to operate USART properly, the RTC oscillator and its 32 kHz output must be manully enabled by user, by calling RTC_Init and setting SYSCON_RTCOSCCTRL_EN bit to 1. And in 32kHz clocking mode the USART can only work at 9600 baudrate or at the baudrate that 9600 can evenly divide, eg: 4800, 3200.
- Parameters:
base – USART peripheral base address.
baudRate_Bps – USART baudrate to be set..
enableMode32k – true is 32k mode, false is normal mode.
srcClock_Hz – USART clock source frequency in HZ.
- Return values:
kStatus_USART_BaudrateNotSupport – Baudrate is not support in current clock source.
kStatus_Success – Set baudrate succeed.
kStatus_InvalidArgument – One or more arguments are invalid.
-
void USART_Enable9bitMode(USART_Type *base, bool enable)
Enable 9-bit data mode for USART.
This function set the 9-bit mode for USART module. The 9th bit is not used for parity thus can be modified by user.
- Parameters:
base – USART peripheral base address.
enable – true to enable, false to disable.
-
static inline void USART_SetMatchAddress(USART_Type *base, uint8_t address)
Set the USART slave address.
This function configures the address for USART module that works as slave in 9-bit data mode. When the address detection is enabled, the frame it receices with MSB being 1 is considered as an address frame, otherwise it is considered as data frame. Once the address frame matches slave’s own addresses, this slave is addressed. This address frame and its following data frames are stored in the receive buffer, otherwise the frames will be discarded. To un-address a slave, just send an address frame with unmatched address.
Note
Any USART instance joined in the multi-slave system can work as slave. The position of the address mark is the same as the parity bit when parity is enabled for 8 bit and 9 bit data formats.
- Parameters:
base – USART peripheral base address.
address – USART slave address.
-
static inline void USART_EnableMatchAddress(USART_Type *base, bool match)
Enable the USART match address feature.
- Parameters:
base – USART peripheral base address.
match – true to enable match address, false to disable.
-
static inline uint32_t USART_GetStatusFlags(USART_Type *base)
Get USART status flags.
This function get all USART status flags, the flags are returned as the logical OR value of the enumerators _usart_flags. To check a specific status, compare the return value with enumerators in _usart_flags. For example, to check whether the TX is empty:
if (kUSART_TxFifoNotFullFlag & USART_GetStatusFlags(USART1)) { ... }
- Parameters:
base – USART peripheral base address.
- Returns:
USART status flags which are ORed by the enumerators in the _usart_flags.
-
static inline void USART_ClearStatusFlags(USART_Type *base, uint32_t mask)
Clear USART status flags.
This function clear supported USART status flags. The mask is a logical OR of enumeration members. See kUSART_AllClearFlags. For example:
USART_ClearStatusFlags(USART1, kUSART_TxError | kUSART_RxError)
- Parameters:
base – USART peripheral base address.
mask – status flags to be cleared.
-
static inline void USART_EnableInterrupts(USART_Type *base, uint32_t mask)
Enables USART interrupts according to the provided mask.
This function enables the USART interrupts according to the provided mask. The mask is a logical OR of enumeration members. See _usart_interrupt_enable. For example, to enable TX empty interrupt and RX full interrupt:
USART_EnableInterrupts(USART1, kUSART_TxLevelInterruptEnable | kUSART_RxLevelInterruptEnable);
- Parameters:
base – USART peripheral base address.
mask – The interrupts to enable. Logical OR of _usart_interrupt_enable.
-
static inline void USART_DisableInterrupts(USART_Type *base, uint32_t mask)
Disables USART interrupts according to a provided mask.
This function disables the USART interrupts according to a provided mask. The mask is a logical OR of enumeration members. See _usart_interrupt_enable. This example shows how to disable the TX empty interrupt and RX full interrupt:
USART_DisableInterrupts(USART1, kUSART_TxLevelInterruptEnable | kUSART_RxLevelInterruptEnable);
- Parameters:
base – USART peripheral base address.
mask – The interrupts to disable. Logical OR of _usart_interrupt_enable.
-
static inline uint32_t USART_GetEnabledInterrupts(USART_Type *base)
Returns enabled USART interrupts.
This function returns the enabled USART interrupts.
- Parameters:
base – USART peripheral base address.
-
static inline void USART_EnableTxDMA(USART_Type *base, bool enable)
Enable DMA for Tx.
-
static inline void USART_EnableRxDMA(USART_Type *base, bool enable)
Enable DMA for Rx.
-
static inline void USART_EnableCTS(USART_Type *base, bool enable)
Enable CTS. This function will determine whether CTS is used for flow control.
- Parameters:
base – USART peripheral base address.
enable – Enable CTS or not, true for enable and false for disable.
-
static inline void USART_EnableContinuousSCLK(USART_Type *base, bool enable)
Continuous Clock generation. By default, SCLK is only output while data is being transmitted in synchronous mode. Enable this funciton, SCLK will run continuously in synchronous mode, allowing characters to be received on Un_RxD independently from transmission on Un_TXD).
- Parameters:
base – USART peripheral base address.
enable – Enable Continuous Clock generation mode or not, true for enable and false for disable.
-
static inline void USART_EnableAutoClearSCLK(USART_Type *base, bool enable)
Enable Continuous Clock generation bit auto clear. While enable this cuntion, the Continuous Clock bit is automatically cleared when a complete character has been received. This bit is cleared at the same time.
- Parameters:
base – USART peripheral base address.
enable – Enable auto clear or not, true for enable and false for disable.
-
static inline void USART_SetRxFifoWatermark(USART_Type *base, uint8_t water)
Sets the rx FIFO watermark.
- Parameters:
base – USART peripheral base address.
water – Rx FIFO watermark.
-
static inline void USART_SetTxFifoWatermark(USART_Type *base, uint8_t water)
Sets the tx FIFO watermark.
- Parameters:
base – USART peripheral base address.
water – Tx FIFO watermark.
-
static inline void USART_WriteByte(USART_Type *base, uint8_t data)
Writes to the FIFOWR register.
This function writes data to the txFIFO directly. The upper layer must ensure that txFIFO has space for data to write before calling this function.
- Parameters:
base – USART peripheral base address.
data – The byte to write.
-
static inline uint8_t USART_ReadByte(USART_Type *base)
Reads the FIFORD register directly.
This function reads data from the rxFIFO directly. The upper layer must ensure that the rxFIFO is not empty before calling this function.
- Parameters:
base – USART peripheral base address.
- Returns:
The byte read from USART data register.
-
static inline uint8_t USART_GetRxFifoCount(USART_Type *base)
Gets the rx FIFO data count.
- Parameters:
base – USART peripheral base address.
- Returns:
rx FIFO data count.
-
static inline uint8_t USART_GetTxFifoCount(USART_Type *base)
Gets the tx FIFO data count.
- Parameters:
base – USART peripheral base address.
- Returns:
tx FIFO data count.
-
void USART_SendAddress(USART_Type *base, uint8_t address)
Transmit an address frame in 9-bit data mode.
- Parameters:
base – USART peripheral base address.
address – USART slave address.
-
status_t USART_WriteBlocking(USART_Type *base, const uint8_t *data, size_t length)
Writes to the TX register using a blocking method.
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.
- Parameters:
base – USART peripheral base address.
data – Start address of the data to write.
length – Size of the data to write.
- Return values:
kStatus_USART_Timeout – Transmission timed out and was aborted.
kStatus_InvalidArgument – Invalid argument.
kStatus_Success – Successfully wrote all data.
-
status_t USART_ReadBlocking(USART_Type *base, uint8_t *data, size_t length)
Read RX data register using a blocking method.
This function polls the RX register, waits for the RX register to be full or for RX FIFO to have data and read data from the TX register.
- Parameters:
base – USART peripheral base address.
data – Start address of the buffer to store the received data.
length – Size of the buffer.
- Return values:
kStatus_USART_FramingError – Receiver overrun happened while receiving data.
kStatus_USART_ParityError – Noise error happened while receiving data.
kStatus_USART_NoiseError – Framing error happened while receiving data.
kStatus_USART_RxError – Overflow or underflow rxFIFO happened.
kStatus_USART_Timeout – Transmission timed out and was aborted.
kStatus_Success – Successfully received all data.
-
status_t USART_TransferCreateHandle(USART_Type *base, usart_handle_t *handle, usart_transfer_callback_t callback, void *userData)
Initializes the USART handle.
This function initializes the USART handle which can be used for other USART transactional APIs. Usually, for a specified USART instance, call this API once to get the initialized handle.
- Parameters:
base – USART peripheral base address.
handle – USART handle pointer.
callback – The callback function.
userData – The parameter of the callback function.
-
status_t USART_TransferSendNonBlocking(USART_Type *base, usart_handle_t *handle, usart_transfer_t *xfer)
Transmits a buffer of data using the interrupt method.
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 IRQ handler, the USART driver calls the callback function and passes the kStatus_USART_TxIdle as status parameter.
- Parameters:
base – USART peripheral base address.
handle – USART handle pointer.
xfer – USART transfer structure. See usart_transfer_t.
- Return values:
kStatus_Success – Successfully start the data transmission.
kStatus_USART_TxBusy – Previous transmission still not finished, data not all written to TX register yet.
kStatus_InvalidArgument – Invalid argument.
-
void USART_TransferStartRingBuffer(USART_Type *base, usart_handle_t *handle, uint8_t *ringBuffer, size_t ringBufferSize)
Sets up the RX ring buffer.
This function sets up the RX ring buffer to a specific USART handle.
When the RX ring buffer is used, data received are stored into the ring buffer even when the user doesn’t call the USART_TransferReceiveNonBlocking() API. If there is already data 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
ringBufferSize
is 32, then only 31 bytes are used for saving data.- Parameters:
base – USART peripheral base address.
handle – USART 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.
-
void USART_TransferStopRingBuffer(USART_Type *base, usart_handle_t *handle)
Aborts the background transfer and uninstalls the ring buffer.
This function aborts the background transfer and uninstalls the ring buffer.
- Parameters:
base – USART peripheral base address.
handle – USART handle pointer.
-
size_t USART_TransferGetRxRingBufferLength(usart_handle_t *handle)
Get the length of received data in RX ring buffer.
- Parameters:
handle – USART handle pointer.
- Returns:
Length of received data in RX ring buffer.
-
void USART_TransferAbortSend(USART_Type *base, usart_handle_t *handle)
Aborts the interrupt-driven data transmit.
This function aborts the interrupt driven data sending. The user can get the remainBtyes to find out how many bytes are still not sent out.
- Parameters:
base – USART peripheral base address.
handle – USART handle pointer.
-
status_t USART_TransferGetSendCount(USART_Type *base, usart_handle_t *handle, uint32_t *count)
Get the number of bytes that have been sent out to bus.
This function gets the number of bytes that have been sent out to bus by interrupt method.
- Parameters:
base – USART peripheral base address.
handle – USART handle pointer.
count – Send bytes count.
- Return values:
kStatus_NoTransferInProgress – No send in progress.
kStatus_InvalidArgument – Parameter is invalid.
kStatus_Success – Get successfully through the parameter
count
;
-
status_t USART_TransferReceiveNonBlocking(USART_Type *base, usart_handle_t *handle, usart_transfer_t *xfer, size_t *receivedBytes)
Receives a buffer of data using an interrupt method.
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 USART driver. When the new data arrives, the receive request is serviced first. When all data is received, the USART driver notifies the upper layer through a callback function and passes the status parameter kStatus_USART_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 parameterreceivedBytes
set to 5. For the left 5 bytes, newly arrived data is saved from the xfer->data[5]. When 5 bytes are received, the USART 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 – USART peripheral base address.
handle – USART handle pointer.
xfer – USART transfer structure, see usart_transfer_t.
receivedBytes – Bytes received from the ring buffer directly.
- Return values:
kStatus_Success – Successfully queue the transfer into transmit queue.
kStatus_USART_RxBusy – Previous receive request is not finished.
kStatus_InvalidArgument – Invalid argument.
-
void USART_TransferAbortReceive(USART_Type *base, usart_handle_t *handle)
Aborts the interrupt-driven data receiving.
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 – USART peripheral base address.
handle – USART handle pointer.
-
status_t USART_TransferGetReceiveCount(USART_Type *base, usart_handle_t *handle, uint32_t *count)
Get the number of bytes that have been received.
This function gets the number of bytes that have been received.
- Parameters:
base – USART peripheral base address.
handle – USART handle pointer.
count – Receive bytes count.
- Return values:
kStatus_NoTransferInProgress – No receive in progress.
kStatus_InvalidArgument – Parameter is invalid.
kStatus_Success – Get successfully through the parameter
count
;
-
void USART_TransferHandleIRQ(USART_Type *base, usart_handle_t *handle)
USART IRQ handle function.
This function handles the USART transmit and receive IRQ request.
- Parameters:
base – USART peripheral base address.
handle – USART handle pointer.
-
FSL_USART_DRIVER_VERSION
USART driver version.
Error codes for the USART driver.
Values:
-
enumerator kStatus_USART_TxBusy
Transmitter is busy.
-
enumerator kStatus_USART_RxBusy
Receiver is busy.
-
enumerator kStatus_USART_TxIdle
USART transmitter is idle.
-
enumerator kStatus_USART_RxIdle
USART receiver is idle.
-
enumerator kStatus_USART_TxError
Error happens on txFIFO.
-
enumerator kStatus_USART_RxError
Error happens on rxFIFO.
-
enumerator kStatus_USART_RxRingBufferOverrun
Error happens on rx ring buffer
-
enumerator kStatus_USART_NoiseError
USART noise error.
-
enumerator kStatus_USART_FramingError
USART framing error.
-
enumerator kStatus_USART_ParityError
USART parity error.
-
enumerator kStatus_USART_BaudrateNotSupport
Baudrate is not support in current clock source
-
enumerator kStatus_USART_TxBusy
-
enum _usart_sync_mode
USART synchronous mode.
Values:
-
enumerator kUSART_SyncModeDisabled
Asynchronous mode.
-
enumerator kUSART_SyncModeSlave
Synchronous slave mode.
-
enumerator kUSART_SyncModeMaster
Synchronous master mode.
-
enumerator kUSART_SyncModeDisabled
-
enum _usart_parity_mode
USART parity mode.
Values:
-
enumerator kUSART_ParityDisabled
Parity disabled
-
enumerator kUSART_ParityEven
Parity enabled, type even, bit setting: PE|PT = 10
-
enumerator kUSART_ParityOdd
Parity enabled, type odd, bit setting: PE|PT = 11
-
enumerator kUSART_ParityDisabled
-
enum _usart_stop_bit_count
USART stop bit count.
Values:
-
enumerator kUSART_OneStopBit
One stop bit
-
enumerator kUSART_TwoStopBit
Two stop bits
-
enumerator kUSART_OneStopBit
-
enum _usart_data_len
USART data size.
Values:
-
enumerator kUSART_7BitsPerChar
Seven bit mode
-
enumerator kUSART_8BitsPerChar
Eight bit mode
-
enumerator kUSART_7BitsPerChar
-
enum _usart_clock_polarity
USART clock polarity configuration, used in sync mode.
Values:
-
enumerator kUSART_RxSampleOnFallingEdge
Un_RXD is sampled on the falling edge of SCLK.
-
enumerator kUSART_RxSampleOnRisingEdge
Un_RXD is sampled on the rising edge of SCLK.
-
enumerator kUSART_RxSampleOnFallingEdge
-
enum _usart_txfifo_watermark
txFIFO watermark values
Values:
-
enumerator kUSART_TxFifo0
USART tx watermark is empty
-
enumerator kUSART_TxFifo1
USART tx watermark at 1 item
-
enumerator kUSART_TxFifo2
USART tx watermark at 2 items
-
enumerator kUSART_TxFifo3
USART tx watermark at 3 items
-
enumerator kUSART_TxFifo4
USART tx watermark at 4 items
-
enumerator kUSART_TxFifo5
USART tx watermark at 5 items
-
enumerator kUSART_TxFifo6
USART tx watermark at 6 items
-
enumerator kUSART_TxFifo7
USART tx watermark at 7 items
-
enumerator kUSART_TxFifo0
-
enum _usart_rxfifo_watermark
rxFIFO watermark values
Values:
-
enumerator kUSART_RxFifo1
USART rx watermark at 1 item
-
enumerator kUSART_RxFifo2
USART rx watermark at 2 items
-
enumerator kUSART_RxFifo3
USART rx watermark at 3 items
-
enumerator kUSART_RxFifo4
USART rx watermark at 4 items
-
enumerator kUSART_RxFifo5
USART rx watermark at 5 items
-
enumerator kUSART_RxFifo6
USART rx watermark at 6 items
-
enumerator kUSART_RxFifo7
USART rx watermark at 7 items
-
enumerator kUSART_RxFifo8
USART rx watermark at 8 items
-
enumerator kUSART_RxFifo1
-
enum _usart_interrupt_enable
USART interrupt configuration structure, default settings all disabled.
Values:
-
enumerator kUSART_TxErrorInterruptEnable
-
enumerator kUSART_RxErrorInterruptEnable
-
enumerator kUSART_TxLevelInterruptEnable
-
enumerator kUSART_RxLevelInterruptEnable
-
enumerator kUSART_TxIdleInterruptEnable
Transmitter idle.
-
enumerator kUSART_CtsChangeInterruptEnable
Change in the state of the CTS input.
-
enumerator kUSART_RxBreakChangeInterruptEnable
Break condition asserted or deasserted.
-
enumerator kUSART_RxStartInterruptEnable
Rx start bit detected.
-
enumerator kUSART_FramingErrorInterruptEnable
Framing error detected.
-
enumerator kUSART_ParityErrorInterruptEnable
Parity error detected.
-
enumerator kUSART_NoiseErrorInterruptEnable
Noise error detected.
-
enumerator kUSART_AutoBaudErrorInterruptEnable
Auto baudrate error detected.
-
enumerator kUSART_RxTimeoutInterruptEnable
Receive timeout detected.
-
enumerator kUSART_AllInterruptEnables
-
enumerator kUSART_TxErrorInterruptEnable
-
enum _usart_flags
USART status flags.
This provides constants for the USART status flags for use in the USART functions.
Values:
-
enumerator kUSART_TxError
TXERR bit, sets if TX buffer is error
-
enumerator kUSART_RxError
RXERR bit, sets if RX buffer is error
-
enumerator kUSART_TxFifoEmptyFlag
TXEMPTY bit, sets if TX buffer is empty
-
enumerator kUSART_TxFifoNotFullFlag
TXNOTFULL bit, sets if TX buffer is not full
-
enumerator kUSART_RxFifoNotEmptyFlag
RXNOEMPTY bit, sets if RX buffer is not empty
-
enumerator kUSART_RxFifoFullFlag
RXFULL bit, sets if RX buffer is full
-
enumerator kUSART_RxIdleFlag
Receiver idle.
-
enumerator kUSART_TxIdleFlag
Transmitter idle.
-
enumerator kUSART_CtsAssertFlag
CTS signal high.
-
enumerator kUSART_CtsChangeFlag
CTS signal changed interrupt status.
-
enumerator kUSART_BreakDetectFlag
Break detected. Self cleared when rx pin goes high again.
-
enumerator kUSART_BreakDetectChangeFlag
Break detect change interrupt flag. A change in the state of receiver break detection.
-
enumerator kUSART_RxStartFlag
Rx start bit detected interrupt flag.
-
enumerator kUSART_FramingErrorFlag
Framing error interrupt flag.
-
enumerator kUSART_ParityErrorFlag
parity error interrupt flag.
-
enumerator kUSART_NoiseErrorFlag
Noise error interrupt flag.
-
enumerator kUSART_AutobaudErrorFlag
Auto baudrate error interrupt flag, caused by the baudrate counter timeout before the end of start bit.
-
enumerator kUSART_RxTimeoutFlag
RXTIMEOUT bit, sets if RX FIFO Timeout.
-
enumerator kUSART_AllClearFlags
-
enumerator kUSART_TxError
-
typedef enum _usart_sync_mode usart_sync_mode_t
USART synchronous mode.
-
typedef enum _usart_parity_mode usart_parity_mode_t
USART parity mode.
-
typedef enum _usart_stop_bit_count usart_stop_bit_count_t
USART stop bit count.
-
typedef enum _usart_data_len usart_data_len_t
USART data size.
-
typedef enum _usart_clock_polarity usart_clock_polarity_t
USART clock polarity configuration, used in sync mode.
-
typedef enum _usart_txfifo_watermark usart_txfifo_watermark_t
txFIFO watermark values
-
typedef enum _usart_rxfifo_watermark usart_rxfifo_watermark_t
rxFIFO watermark values
-
typedef struct _usart_rx_timeout_config usart_rx_timeout_config
USART receive timeout configuration structure.
-
typedef struct _usart_config usart_config_t
USART configuration structure.
-
typedef struct _usart_transfer usart_transfer_t
USART transfer structure.
-
typedef struct _usart_handle usart_handle_t
-
typedef void (*usart_transfer_callback_t)(USART_Type *base, usart_handle_t *handle, status_t status, void *userData)
USART transfer callback function.
-
typedef void (*flexcomm_usart_irq_handler_t)(USART_Type *base, usart_handle_t *handle)
Typedef for usart interrupt handler.
-
uint32_t USART_GetInstance(USART_Type *base)
Returns instance number for USART peripheral base address.
-
USART_FIFOTRIG_TXLVL_GET(base)
-
USART_FIFOTRIG_RXLVL_GET(base)
-
UART_RETRY_TIMES
Retry times for waiting flag.
Defining to zero means to keep waiting for the flag until it is assert/deassert in blocking transfer, otherwise the program will wait until the UART_RETRY_TIMES counts down to 0, if the flag still remains unchanged then program will return kStatus_USART_Timeout. It is not advised to use this macro in formal application to prevent any hardware error because the actual wait period is affected by the compiler and optimization.
-
struct _usart_rx_timeout_config
- #include <fsl_usart.h>
USART receive timeout configuration structure.
Public Members
-
bool enable
Enable RX timeout
-
bool resetCounterOnEmpty
Enable RX timeout counter reset when RX FIFO becames empty.
-
bool resetCounterOnReceive
Enable RX timeout counter reset when RX FIFO receives data from the transmitter side.
-
uint32_t counter
RX timeout counter
-
uint8_t prescaler
RX timeout prescaler
-
bool enable
-
struct _usart_config
- #include <fsl_usart.h>
USART configuration structure.
Public Members
-
uint32_t baudRate_Bps
USART baud rate
-
usart_parity_mode_t parityMode
Parity mode, disabled (default), even, odd
-
usart_stop_bit_count_t stopBitCount
Number of stop bits, 1 stop bit (default) or 2 stop bits
-
usart_data_len_t bitCountPerChar
Data length - 7 bit, 8 bit
-
bool loopback
Enable peripheral loopback
-
bool enableRx
Enable RX
-
bool enableTx
Enable TX
-
bool enableContinuousSCLK
USART continuous Clock generation enable in synchronous master mode.
-
bool enableMode32k
USART uses 32 kHz clock from the RTC oscillator as the clock source.
-
bool enableHardwareFlowControl
Enable hardware control RTS/CTS
-
usart_txfifo_watermark_t txWatermark
txFIFO watermark
-
usart_rxfifo_watermark_t rxWatermark
rxFIFO watermark
-
usart_sync_mode_t syncMode
Transfer mode select - asynchronous, synchronous master, synchronous slave.
-
usart_clock_polarity_t clockPolarity
Selects the clock polarity and sampling edge in synchronous mode.
-
usart_rx_timeout_config rxTimeout
rx timeout configuration
-
uint32_t baudRate_Bps
-
struct _usart_transfer
- #include <fsl_usart.h>
USART transfer structure.
Public Members
-
size_t dataSize
The byte count to be transfer.
-
size_t dataSize
-
struct _usart_handle
- #include <fsl_usart.h>
USART handle structure.
Public Members
-
const 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.
-
usart_transfer_callback_t callback
Callback function.
-
void *userData
USART callback function parameter.
-
volatile uint8_t txState
TX transfer state.
-
volatile uint8_t rxState
RX transfer state
-
uint8_t txWatermark
txFIFO watermark
-
uint8_t rxWatermark
rxFIFO watermark
-
const uint8_t *volatile txData
-
union __unnamed77__
Public Members
-
uint8_t *data
The buffer of data to be transfer.
-
uint8_t *rxData
The buffer to receive data.
-
const uint8_t *txData
The buffer of data to be sent.
-
uint8_t *data
UTICK: MictoTick Timer Driver
-
void UTICK_Init(UTICK_Type *base)
Initializes an UTICK by turning its bus clock on.
-
void UTICK_Deinit(UTICK_Type *base)
Deinitializes a UTICK instance.
This function shuts down Utick bus clock
- Parameters:
base – UTICK peripheral base address.
-
uint32_t UTICK_GetStatusFlags(UTICK_Type *base)
Get Status Flags.
This returns the status flag
- Parameters:
base – UTICK peripheral base address.
- Returns:
status register value
-
void UTICK_ClearStatusFlags(UTICK_Type *base)
Clear Status Interrupt Flags.
This clears intr status flag
- Parameters:
base – UTICK peripheral base address.
- Returns:
none
-
void UTICK_SetTick(UTICK_Type *base, utick_mode_t mode, uint32_t count, utick_callback_t cb)
Starts UTICK.
This function starts a repeat/onetime countdown with an optional callback
- Parameters:
base – UTICK peripheral base address.
mode – UTICK timer mode (ie kUTICK_onetime or kUTICK_repeat)
count – UTICK timer mode (ie kUTICK_onetime or kUTICK_repeat)
cb – UTICK callback (can be left as NULL if none, otherwise should be a void func(void))
- Returns:
none
-
void UTICK_HandleIRQ(UTICK_Type *base, utick_callback_t cb)
UTICK Interrupt Service Handler.
This function handles the interrupt and refers to the callback array in the driver to callback user (as per request in UTICK_SetTick()). if no user callback is scheduled, the interrupt will simply be cleared.
- Parameters:
base – UTICK peripheral base address.
cb – callback scheduled for this instance of UTICK
- Returns:
none
-
FSL_UTICK_DRIVER_VERSION
UTICK driver version 2.0.5.
-
enum _utick_mode
UTICK timer operational mode.
Values:
-
enumerator kUTICK_Onetime
Trigger once
-
enumerator kUTICK_Repeat
Trigger repeatedly
-
enumerator kUTICK_Onetime
-
typedef enum _utick_mode utick_mode_t
UTICK timer operational mode.
-
typedef void (*utick_callback_t)(void)
UTICK callback function.
VREF: Voltage Reference Driver
-
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.
This function must be called before calling all other VREF driver functions, read/write registers, and configurations 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.
vref_config_t vrefConfig; VREF_GetDefaultConfig(VREF, &vrefConfig); vrefConfig.bufferMode = kVREF_ModeHighPowerBuffer; VREF_Init(VREF, &vrefConfig);
- Parameters:
base – VREF peripheral address.
config – Pointer to the configuration structure.
-
void VREF_Deinit(VREF_Type *base)
Stops and disables the clock for the VREF module.
This function should be called to shut down the module. This is an example.
vref_config_t vrefUserConfig; VREF_GetDefaultConfig(VREF, &vrefUserConfig); VREF_Init(VREF, &vrefUserConfig); ... VREF_Deinit(VREF);
- Parameters:
base – VREF peripheral address.
-
void VREF_GetDefaultConfig(vref_config_t *config)
Initializes the VREF configuration structure.
This function initializes the VREF configuration structure to default values. This is an example.
config->bufferMode = kVREF_ModeHighPowerBuffer; config->enableInternalVoltageRegulator = true; config->enableChopOscillator = true; config->enableHCBandgap = true; config->enableCurvatureCompensation = true; config->enableLowPowerBuff = true;
- Parameters:
config – Pointer to the initialization structure.
-
void VREF_SetVrefTrimVal(VREF_Type *base, uint8_t trimValue)
Sets a TRIM value for the accurate 1.0V bandgap output.
This function sets a TRIM value for the reference voltage. It will trim the accurate 1.0V bandgap by 0.5mV each step.
- Parameters:
base – VREF peripheral address.
trimValue – Value of the trim register to set the output reference voltage (maximum 0x3F (6-bit)).
-
void VREF_SetTrim21Val(VREF_Type *base, uint8_t trim21Value)
Sets a TRIM value for the accurate buffered VREF output.
This function sets a TRIM value for the reference voltage. If buffer mode be set to other values (Buf21 enabled), it will trim the VREF_OUT by 0.1V each step from 1.0V to 2.1V.
Note
When Buf21 is enabled, the value of UTRIM[TRIM2V1] should be ranged from 0b0000 to 0b1011 in order to trim the output voltage from 1.0V to 2.1V, other values will make the VREF_OUT to default value, 1.0V.
- Parameters:
base – VREF peripheral address.
trim21Value – Value of the trim register to set the output reference voltage (maximum 0xF (4-bit)).
-
uint8_t VREF_GetVrefTrimVal(VREF_Type *base)
Reads the trim value.
This function gets the TRIM value from the UTRIM register. It reads UTRIM[VREFTRIM] (13:8)
- Parameters:
base – VREF peripheral address.
- Returns:
6-bit value of trim setting.
-
uint8_t VREF_GetTrim21Val(VREF_Type *base)
Reads the VREF 2.1V trim value.
This function gets the TRIM value from the UTRIM register. It reads UTRIM[TRIM2V1] (3:0),
- Parameters:
base – VREF peripheral address.
- Returns:
4-bit value of trim setting.
-
FSL_VREF_DRIVER_VERSION
Version 2.4.0.
-
enum _vref_buffer_mode
VREF buffer modes.
Values:
-
enumerator kVREF_ModeBandgapOnly
Bandgap enabled/standby.
-
enumerator kVREF_ModeLowPowerBuffer
Low-power buffer mode enabled
-
enumerator kVREF_ModeHighPowerBuffer
High-power buffer mode enabled
-
enumerator kVREF_ModeBandgapOnly
-
typedef enum _vref_buffer_mode vref_buffer_mode_t
VREF buffer modes.
-
typedef struct _vref_config vref_config_t
The description structure for the VREF module.
-
struct _vref_config
- #include <fsl_vref.h>
The description structure for the VREF module.
Public Members
-
vref_buffer_mode_t bufferMode
Buffer mode selection
-
bool enableInternalVoltageRegulator
Provide additional supply noise rejection.
-
bool enableChopOscillator
Enable Chop oscillator.
-
bool enableHCBandgap
Enable High-Accurate bandgap.
-
bool enableCurvatureCompensation
Enable second order curvature compensation.
-
bool enableLowPowerBuff
Provides bias current for other peripherals.
-
vref_buffer_mode_t bufferMode
WWDT: Windowed Watchdog Timer Driver
-
void WWDT_GetDefaultConfig(wwdt_config_t *config)
Initializes WWDT configure structure.
This function initializes the WWDT configure structure to default value. The default value are:
config->enableWwdt = true; config->enableWatchdogReset = false; config->enableWatchdogProtect = false; config->enableLockOscillator = false; config->windowValue = 0xFFFFFFU; config->timeoutValue = 0xFFFFFFU; config->warningValue = 0;
See also
wwdt_config_t
- Parameters:
config – Pointer to WWDT config structure.
-
void WWDT_Init(WWDT_Type *base, const wwdt_config_t *config)
Initializes the WWDT.
This function initializes the WWDT. When called, the WWDT runs according to the configuration.
Example:
wwdt_config_t config; WWDT_GetDefaultConfig(&config); config.timeoutValue = 0x7ffU; WWDT_Init(wwdt_base,&config);
- Parameters:
base – WWDT peripheral base address
config – The configuration of WWDT
-
void WWDT_Deinit(WWDT_Type *base)
Shuts down the WWDT.
This function shuts down the WWDT.
- Parameters:
base – WWDT peripheral base address
-
static inline void WWDT_Enable(WWDT_Type *base)
Enables the WWDT module.
This function write value into WWDT_MOD register to enable the WWDT, it is a write-once bit; once this bit is set to one and a watchdog feed is performed, the watchdog timer will run permanently.
- Parameters:
base – WWDT peripheral base address
-
static inline void WWDT_Disable(WWDT_Type *base)
Disables the WWDT module.
- Deprecated:
Do not use this function. It will be deleted in next release version, for once the bit field of WDEN written with a 1, it can not be re-written with a 0.
This function write value into WWDT_MOD register to disable the WWDT.
- Parameters:
base – WWDT peripheral base address
-
static inline uint32_t WWDT_GetStatusFlags(WWDT_Type *base)
Gets all WWDT status flags.
This function gets all status flags.
Example for getting Timeout Flag:
uint32_t status; status = WWDT_GetStatusFlags(wwdt_base) & kWWDT_TimeoutFlag;
- Parameters:
base – WWDT peripheral base address
- Returns:
The status flags. This is the logical OR of members of the enumeration _wwdt_status_flags_t
-
void WWDT_ClearStatusFlags(WWDT_Type *base, uint32_t mask)
Clear WWDT flag.
This function clears WWDT status flag.
Example for clearing warning flag:
WWDT_ClearStatusFlags(wwdt_base, kWWDT_WarningFlag);
- Parameters:
base – WWDT peripheral base address
mask – The status flags to clear. This is a logical OR of members of the enumeration _wwdt_status_flags_t
-
static inline void WWDT_SetWarningValue(WWDT_Type *base, uint32_t warningValue)
Set the WWDT warning value.
The WDWARNINT register determines the watchdog timer counter value that will generate a watchdog interrupt. When the watchdog timer counter is no longer greater than the value defined by WARNINT, an interrupt will be generated after the subsequent WDCLK.
- Parameters:
base – WWDT peripheral base address
warningValue – WWDT warning value.
-
static inline void WWDT_SetTimeoutValue(WWDT_Type *base, uint32_t timeoutCount)
Set the WWDT timeout value.
This function sets the timeout value. Every time a feed sequence occurs the value in the TC register is loaded into the Watchdog timer. Writing a value below 0xFF will cause 0xFF to be loaded into the TC register. Thus the minimum time-out interval is TWDCLK*256*4. If enableWatchdogProtect flag is true in wwdt_config_t config structure, any attempt to change the timeout value before the watchdog counter is below the warning and window values will cause a watchdog reset and set the WDTOF flag.
- Parameters:
base – WWDT peripheral base address
timeoutCount – WWDT timeout value, count of WWDT clock tick.
-
static inline void WWDT_SetWindowValue(WWDT_Type *base, uint32_t windowValue)
Sets the WWDT window value.
The WINDOW register determines the highest TV value allowed when a watchdog feed is performed. If a feed sequence occurs when timer value is greater than the value in WINDOW, a watchdog event will occur. To disable windowing, set windowValue to 0xFFFFFF (maximum possible timer value) so windowing is not in effect.
- Parameters:
base – WWDT peripheral base address
windowValue – WWDT window value.
-
void WWDT_Refresh(WWDT_Type *base)
Refreshes the WWDT timer.
This function feeds the WWDT. This function should be called before WWDT timer is in timeout. Otherwise, a reset is asserted.
- Parameters:
base – WWDT peripheral base address
-
FSL_WWDT_DRIVER_VERSION
Defines WWDT driver version.
-
WWDT_FIRST_WORD_OF_REFRESH
First word of refresh sequence
-
WWDT_SECOND_WORD_OF_REFRESH
Second word of refresh sequence
-
enum _wwdt_status_flags_t
WWDT status flags.
This structure contains the WWDT status flags for use in the WWDT functions.
Values:
-
enumerator kWWDT_TimeoutFlag
Time-out flag, set when the timer times out
-
enumerator kWWDT_WarningFlag
Warning interrupt flag, set when timer is below the value WDWARNINT
-
enumerator kWWDT_TimeoutFlag
-
typedef struct _wwdt_config wwdt_config_t
Describes WWDT configuration structure.
-
struct _wwdt_config
- #include <fsl_wwdt.h>
Describes WWDT configuration structure.
Public Members
-
bool enableWwdt
Enables or disables WWDT
-
bool enableWatchdogReset
true: Watchdog timeout will cause a chip reset false: Watchdog timeout will not cause a chip reset
-
bool enableWatchdogProtect
true: Enable watchdog protect i.e timeout value can only be changed after counter is below warning & window values false: Disable watchdog protect; timeout value can be changed at any time
-
bool enableLockOscillator
true: Disabling or powering down the watchdog oscillator is prevented Once set, this bit can only be cleared by a reset false: Do not lock oscillator
-
uint32_t windowValue
Window value, set this to 0xFFFFFF if windowing is not in effect
-
uint32_t timeoutValue
Timeout value
-
uint32_t warningValue
Watchdog time counter value that will generate a warning interrupt. Set this to 0 for no warning
-
uint32_t clockFreq_Hz
Watchdog clock source frequency.
-
bool enableWwdt