|  | MCUXpresso SDK API Reference Manual
    Rev 2.11.0
    NXP Semiconductors | 
| Data Structures | |
| union | pflash_prot_status_t | 
| PFlash protection status.  More... | |
| struct | flash_config_t | 
| Flash driver state information.  More... | |
| Flash version | |
| #define | FSL_FLASH_DRIVER_VERSION (MAKE_VERSION(3U, 1U, 2U)) | 
| Flash driver version for SDK.  More... | |
| #define | FSL_FLASH_DRIVER_VERSION_ROM (MAKE_VERSION(3U, 0U, 0U)) | 
| Flash driver version for ROM.  More... | |
| Initialization | |
| status_t | FLASH_Init (flash_config_t *config) | 
| Initializes the global flash properties structure members.  More... | |
| Erasing | |
| status_t | FLASH_Erase (flash_config_t *config, uint32_t start, uint32_t lengthInBytes, uint32_t key) | 
| Erases the Dflash sectors encompassed by parameters passed into function.  More... | |
| status_t | FLASH_EraseSectorNonBlocking (flash_config_t *config, uint32_t start, uint32_t key) | 
| Erases the Dflash sectors encompassed by parameters passed into function.  More... | |
| status_t | FLASH_EraseAll (flash_config_t *config, uint32_t key) | 
| Erases entire flexnvm.  More... | |
| Programming | |
| 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.  More... | |
| status_t | FLASH_ProgramOnce (flash_config_t *config, uint32_t index, uint8_t *src, uint32_t lengthInBytes) | 
| Program the Program-Once-Field through parameters.  More... | |
| Reading | |
| status_t | FLASH_ReadResource (flash_config_t *config, uint32_t start, uint8_t *dst, uint32_t lengthInBytes, ftfx_read_resource_opt_t option) | 
| Reads the resource with data at locations passed in through parameters.  More... | |
| status_t | FLASH_ReadOnce (flash_config_t *config, uint32_t index, uint8_t *dst, uint32_t lengthInBytes) | 
| Reads the Program Once Field through parameters.  More... | |
| Verification | |
| status_t | FLASH_VerifyErase (flash_config_t *config, uint32_t start, uint32_t lengthInBytes, ftfx_margin_value_t margin) | 
| Verifies an erasure of the desired flash area at a specified margin level.  More... | |
| status_t | FLASH_VerifyEraseAll (flash_config_t *config, ftfx_margin_value_t margin) | 
| Verifies erasure of the entire flash at a specified margin level.  More... | |
| status_t | FLASH_VerifyProgram (flash_config_t *config, uint32_t start, uint32_t lengthInBytes, const uint8_t *expectedData, ftfx_margin_value_t margin, uint32_t *failedAddress, uint32_t *failedData) | 
| Verifies programming of the desired flash area at a specified margin level.  More... | |
| Security | |
| status_t | FLASH_GetSecurityState (flash_config_t *config, ftfx_security_state_t *state) | 
| Returns the security state via the pointer passed into the function.  More... | |
| status_t | FLASH_SecurityBypass (flash_config_t *config, const uint8_t *backdoorKey) | 
| Allows users to bypass security with a backdoor key.  More... | |
| Protection | |
| status_t | FLASH_IsProtected (flash_config_t *config, uint32_t start, uint32_t lengthInBytes, flash_prot_state_t *protection_state) | 
| Returns the protection state of the desired flash area via the pointer passed into the function.  More... | |
| status_t | FLASH_IsExecuteOnly (flash_config_t *config, uint32_t start, uint32_t lengthInBytes, flash_xacc_state_t *access_state) | 
| Returns the access state of the desired flash area via the pointer passed into the function.  More... | |
| status_t | FLASH_PflashSetProtection (flash_config_t *config, pflash_prot_status_t *protectStatus) | 
| Sets the PFlash Protection to the intended protection status.  More... | |
| status_t | FLASH_PflashGetProtection (flash_config_t *config, pflash_prot_status_t *protectStatus) | 
| Gets the PFlash protection status.  More... | |
| Properties | |
| status_t | FLASH_GetProperty (flash_config_t *config, flash_property_tag_t whichProperty, uint32_t *value) | 
| Returns the desired flash property.  More... | |
| commantStatus | |
| status_t | FLASH_GetCommandState (void) | 
| Get previous command status.  More... | |
| union pflash_prot_status_t | 
| Data Fields | |
| uint32_t | protl | 
| PROT[31:0] .  More... | |
| uint32_t | proth | 
| PROT[63:32].  More... | |
| uint8_t | protsl | 
| PROTS[7:0] .  More... | |
| uint8_t | protsh | 
| PROTS[15:8] .  More... | |
| uint32_t pflash_prot_status_t::protl | 
| uint32_t pflash_prot_status_t::proth | 
| uint8_t pflash_prot_status_t::protsl | 
| uint8_t pflash_prot_status_t::protsh | 
| struct flash_config_t | 
An instance of this structure is allocated by the user of the flash driver and passed into each of the driver APIs.
| #define FSL_FLASH_DRIVER_VERSION (MAKE_VERSION(3U, 1U, 2U)) | 
Version 3.1.2.
| #define FSL_FLASH_DRIVER_VERSION_ROM (MAKE_VERSION(3U, 0U, 0U)) | 
Version 3.0.0.
| enum flash_prot_state_t | 
| enum flash_xacc_state_t | 
| enum flash_property_tag_t | 
| status_t FLASH_Init | ( | flash_config_t * | config | ) | 
This function checks and initializes the Flash module for the other Flash APIs.
| config | Pointer to the storage for the driver runtime state. | 
| kStatus_FTFx_Success | API was executed successfully. | 
| kStatus_FTFx_InvalidArgument | An invalid argument is provided. | 
| kStatus_FTFx_ExecuteInRamFunctionNotReady | Execute-in-RAM function is not available. | 
| kStatus_FTFx_PartitionStatusUpdateFailure | Failed to update the partition status. | 
| status_t FLASH_Erase | ( | flash_config_t * | config, | 
| uint32_t | start, | ||
| uint32_t | lengthInBytes, | ||
| uint32_t | key | ||
| ) | 
This function erases the appropriate number of flash sectors based on the desired start address and length.
| config | The pointer to the storage for the driver runtime state. | 
| start | The start address of the desired flash memory to be erased. The start address does not need to be sector-aligned but must be word-aligned. | 
| lengthInBytes | The length, given in bytes (not words or long-words) to be erased. Must be word-aligned. | 
| key | The value used to validate all flash erase APIs. | 
| kStatus_FTFx_Success | API was executed successfully; the appropriate number of flash sectors based on the desired start address and length were erased successfully. | 
| kStatus_FTFx_InvalidArgument | An invalid argument is provided. | 
| kStatus_FTFx_AlignmentError | The parameter is not aligned with the specified baseline. | 
| kStatus_FTFx_AddressError | The address is out of range. | 
| kStatus_FTFx_EraseKeyError | The API erase key is invalid. | 
| kStatus_FTFx_ExecuteInRamFunctionNotReady | Execute-in-RAM function is not available. | 
| kStatus_FTFx_AccessError | Invalid instruction codes and out-of bounds addresses. | 
| kStatus_FTFx_ProtectionViolation | The program/erase operation is requested to execute on protected areas. | 
| kStatus_FTFx_CommandFailure | Run-time error during the command execution. | 
| status_t FLASH_EraseSectorNonBlocking | ( | flash_config_t * | config, | 
| uint32_t | start, | ||
| uint32_t | key | ||
| ) | 
This function erases one flash sector size based on the start address, and it is executed asynchronously.
NOTE: This function can only erase one flash sector at a time, and the other commands can be executed after the previous command has been completed.
| config | The pointer to the storage for the driver runtime state. | 
| start | The start address of the desired flash memory to be erased. The start address does not need to be sector-aligned but must be word-aligned. | 
| key | The value used to validate all flash erase APIs. | 
| kStatus_FTFx_Success | API was executed successfully. | 
| kStatus_FTFx_InvalidArgument | An invalid argument is provided. | 
| kStatus_FTFx_AlignmentError | The parameter is not aligned with the specified baseline. | 
| kStatus_FTFx_AddressError | The address is out of range. | 
| kStatus_FTFx_EraseKeyError | The API erase key is invalid. | 
| status_t FLASH_EraseAll | ( | flash_config_t * | config, | 
| uint32_t | key | ||
| ) | 
| config | Pointer to the storage for the driver runtime state. | 
| key | A value used to validate all flash erase APIs. | 
| kStatus_FTFx_Success | API was executed successfully; the all pflash and flexnvm were erased successfully, the swap and eeprom have been reset to unconfigured state. | 
| kStatus_FTFx_InvalidArgument | An invalid argument is provided. | 
| kStatus_FTFx_EraseKeyError | API erase key is invalid. | 
| kStatus_FTFx_ExecuteInRamFunctionNotReady | Execute-in-RAM function is not available. | 
| kStatus_FTFx_AccessError | Invalid instruction codes and out-of bounds addresses. | 
| kStatus_FTFx_ProtectionViolation | The program/erase operation is requested to execute on protected areas. | 
| kStatus_FTFx_CommandFailure | Run-time error during command execution. | 
| kStatus_FTFx_PartitionStatusUpdateFailure | Failed to update the partition status. | 
| status_t FLASH_Program | ( | flash_config_t * | config, | 
| uint32_t | start, | ||
| uint8_t * | src, | ||
| uint32_t | lengthInBytes | ||
| ) | 
This function programs the flash memory with the desired data for a given flash area as determined by the start address and the length.
| 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. | 
| kStatus_FTFx_Success | API was executed successfully; the desired data were programed successfully into flash based on desired start address and length. | 
| kStatus_FTFx_InvalidArgument | An invalid argument is provided. | 
| kStatus_FTFx_AlignmentError | Parameter is not aligned with the specified baseline. | 
| kStatus_FTFx_AddressError | Address is out of range. | 
| kStatus_FTFx_ExecuteInRamFunctionNotReady | Execute-in-RAM function is not available. | 
| kStatus_FTFx_AccessError | Invalid instruction codes and out-of bounds addresses. | 
| kStatus_FTFx_ProtectionViolation | The program/erase operation is requested to execute on protected areas. | 
| kStatus_FTFx_CommandFailure | Run-time error during the command execution. | 
| status_t FLASH_ProgramOnce | ( | flash_config_t * | config, | 
| uint32_t | index, | ||
| uint8_t * | src, | ||
| uint32_t | lengthInBytes | ||
| ) | 
This function Program the Program-once-feild with given index and length.
| config | A pointer to the storage for the driver runtime state. | 
| index | The index indicating the area of program once field to be read. | 
| src | A pointer to the source buffer of data that is used to store data to be write. | 
| lengthInBytes | The length, given in bytes (not words or long-words), to be programmed. Must be word-aligned. | 
| kStatus_FTFx_Success | API was executed successfully; The index indicating the area of program once field was programed successfully. | 
| kStatus_FTFx_InvalidArgument | An invalid argument is provided. | 
| kStatus_FTFx_ExecuteInRamFunctionNotReady | Execute-in-RAM function is not available. | 
| kStatus_FTFx_AccessError | Invalid instruction codes and out-of bounds addresses. | 
| kStatus_FTFx_ProtectionViolation | The program/erase operation is requested to execute on protected areas. | 
| kStatus_FTFx_CommandFailure | Run-time error during the command execution. | 
| status_t FLASH_ReadResource | ( | flash_config_t * | config, | 
| uint32_t | start, | ||
| uint8_t * | dst, | ||
| uint32_t | lengthInBytes, | ||
| ftfx_read_resource_opt_t | option | ||
| ) | 
This function reads the flash memory with the desired location for a given flash area as determined by the start address and length.
| config | A pointer to the storage for the driver runtime state. | 
| start | The start address of the desired flash memory to be programmed. Must be word-aligned. | 
| dst | A pointer to the destination buffer of data that is used to store data to be read. | 
| lengthInBytes | The length, given in bytes (not words or long-words), to be read. Must be word-aligned. | 
| option | The resource option which indicates which area should be read back. | 
| kStatus_FTFx_Success | API was executed successfully; the data have been read successfully from program flash IFR, data flash IFR space, and the Version ID field. | 
| kStatus_FTFx_InvalidArgument | An invalid argument is provided. | 
| kStatus_FTFx_AlignmentError | Parameter is not aligned with the specified baseline. | 
| kStatus_FTFx_ExecuteInRamFunctionNotReady | Execute-in-RAM function is not available. | 
| kStatus_FTFx_AccessError | Invalid instruction codes and out-of bounds addresses. | 
| kStatus_FTFx_ProtectionViolation | The program/erase operation is requested to execute on protected areas. | 
| kStatus_FTFx_CommandFailure | Run-time error during the command execution. | 
| status_t FLASH_ReadOnce | ( | flash_config_t * | config, | 
| uint32_t | index, | ||
| uint8_t * | dst, | ||
| uint32_t | lengthInBytes | ||
| ) | 
This function reads the read once feild with given index and length.
| config | A pointer to the storage for the driver runtime state. | 
| index | The index indicating the area of program once field to be read. | 
| dst | A pointer to the destination buffer of data that is used to store data to be read. | 
| lengthInBytes | The length, given in bytes (not words or long-words), to be programmed. Must be word-aligned. | 
| kStatus_FTFx_Success | API was executed successfully; the data have been successfuly read form Program flash0 IFR map and Program Once field based on index and length. | 
| kStatus_FTFx_InvalidArgument | An invalid argument is provided. | 
| kStatus_FTFx_ExecuteInRamFunctionNotReady | Execute-in-RAM function is not available. | 
| kStatus_FTFx_AccessError | Invalid instruction codes and out-of bounds addresses. | 
| kStatus_FTFx_ProtectionViolation | The program/erase operation is requested to execute on protected areas. | 
| kStatus_FTFx_CommandFailure | Run-time error during the command execution. | 
| status_t FLASH_VerifyErase | ( | flash_config_t * | config, | 
| uint32_t | start, | ||
| uint32_t | lengthInBytes, | ||
| ftfx_margin_value_t | margin | ||
| ) | 
This function checks the appropriate number of flash sectors based on the desired start address and length to check whether the flash is erased to the specified read margin level.
| config | A pointer to the storage for the driver runtime state. | 
| start | The start address of the desired flash memory to be verified. The start address does not need to be sector-aligned but must be word-aligned. | 
| lengthInBytes | The length, given in bytes (not words or long-words), to be verified. Must be word-aligned. | 
| margin | Read margin choice. | 
| kStatus_FTFx_Success | API was executed successfully; the specified FLASH region has been erased. | 
| kStatus_FTFx_InvalidArgument | An invalid argument is provided. | 
| kStatus_FTFx_AlignmentError | Parameter is not aligned with specified baseline. | 
| kStatus_FTFx_AddressError | Address is out of range. | 
| kStatus_FTFx_ExecuteInRamFunctionNotReady | Execute-in-RAM function is not available. | 
| kStatus_FTFx_AccessError | Invalid instruction codes and out-of bounds addresses. | 
| kStatus_FTFx_ProtectionViolation | The program/erase operation is requested to execute on protected areas. | 
| kStatus_FTFx_CommandFailure | Run-time error during the command execution. | 
| status_t FLASH_VerifyEraseAll | ( | flash_config_t * | config, | 
| ftfx_margin_value_t | margin | ||
| ) | 
This function checks whether the flash is erased to the specified read margin level.
| config | A pointer to the storage for the driver runtime state. | 
| margin | Read margin choice. | 
| kStatus_FTFx_Success | API was executed successfully; all program flash and flexnvm were in erased state. | 
| kStatus_FTFx_InvalidArgument | An invalid argument is provided. | 
| kStatus_FTFx_ExecuteInRamFunctionNotReady | Execute-in-RAM function is not available. | 
| kStatus_FTFx_AccessError | Invalid instruction codes and out-of bounds addresses. | 
| kStatus_FTFx_ProtectionViolation | The program/erase operation is requested to execute on protected areas. | 
| kStatus_FTFx_CommandFailure | Run-time error during the command execution. | 
| status_t FLASH_VerifyProgram | ( | flash_config_t * | config, | 
| uint32_t | start, | ||
| uint32_t | lengthInBytes, | ||
| const uint8_t * | expectedData, | ||
| ftfx_margin_value_t | margin, | ||
| uint32_t * | failedAddress, | ||
| uint32_t * | failedData | ||
| ) | 
This function verifies the data programmed in the flash memory using the Flash Program Check Command and compares it to the expected data for a given flash area as determined by the start address and length.
| config | A pointer to the storage for the driver runtime state. | 
| start | The start address of the desired flash memory to be verified. Must be word-aligned. | 
| lengthInBytes | The length, given in bytes (not words or long-words), to be verified. Must be word-aligned. | 
| expectedData | A pointer to the expected data that is to be verified against. | 
| margin | Read margin choice. | 
| failedAddress | A pointer to the returned failing address. | 
| failedData | A pointer to the returned failing data. Some derivatives do not include failed data as part of the FCCOBx registers. In this case, zeros are returned upon failure. | 
| kStatus_FTFx_Success | API was executed successfully; the desired data have been successfully programed into specified FLASH region. | 
| kStatus_FTFx_InvalidArgument | An invalid argument is provided. | 
| kStatus_FTFx_AlignmentError | Parameter is not aligned with specified baseline. | 
| kStatus_FTFx_AddressError | Address is out of range. | 
| kStatus_FTFx_ExecuteInRamFunctionNotReady | Execute-in-RAM function is not available. | 
| kStatus_FTFx_AccessError | Invalid instruction codes and out-of bounds addresses. | 
| kStatus_FTFx_ProtectionViolation | The program/erase operation is requested to execute on protected areas. | 
| kStatus_FTFx_CommandFailure | Run-time error during the command execution. | 
| status_t FLASH_GetSecurityState | ( | flash_config_t * | config, | 
| ftfx_security_state_t * | state | ||
| ) | 
This function retrieves the current flash security status, including the security enabling state and the backdoor key enabling state.
| config | A pointer to storage for the driver runtime state. | 
| state | A pointer to the value returned for the current security status code: | 
| kStatus_FTFx_Success | API was executed successfully; the security state of flash was stored to state. | 
| kStatus_FTFx_InvalidArgument | An invalid argument is provided. | 
| status_t FLASH_SecurityBypass | ( | flash_config_t * | config, | 
| const uint8_t * | backdoorKey | ||
| ) | 
If the MCU is in secured state, this function unsecures the MCU by comparing the provided backdoor key with ones in the flash configuration field.
| config | A pointer to the storage for the driver runtime state. | 
| backdoorKey | A pointer to the user buffer containing the backdoor key. | 
| kStatus_FTFx_Success | API was executed successfully. | 
| kStatus_FTFx_InvalidArgument | An invalid argument is provided. | 
| kStatus_FTFx_ExecuteInRamFunctionNotReady | Execute-in-RAM function is not available. | 
| kStatus_FTFx_AccessError | Invalid instruction codes and out-of bounds addresses. | 
| kStatus_FTFx_ProtectionViolation | The program/erase operation is requested to execute on protected areas. | 
| kStatus_FTFx_CommandFailure | Run-time error during the command execution. | 
| status_t FLASH_IsProtected | ( | flash_config_t * | config, | 
| uint32_t | start, | ||
| uint32_t | lengthInBytes, | ||
| flash_prot_state_t * | protection_state | ||
| ) | 
This function retrieves the current flash protect status for a given flash area as determined by the start address and length.
| config | A pointer to the storage for the driver runtime state. | 
| start | The start address of the desired flash memory to be checked. Must be word-aligned. | 
| lengthInBytes | The length, given in bytes (not words or long-words) to be checked. Must be word-aligned. | 
| protection_state | A pointer to the value returned for the current protection status code for the desired flash area. | 
| kStatus_FTFx_Success | API was executed successfully; the protection state of specified FLASH region was stored to protection_state. | 
| kStatus_FTFx_InvalidArgument | An invalid argument is provided. | 
| kStatus_FTFx_AlignmentError | Parameter is not aligned with specified baseline. | 
| kStatus_FTFx_AddressError | The address is out of range. | 
| status_t FLASH_IsExecuteOnly | ( | flash_config_t * | config, | 
| uint32_t | start, | ||
| uint32_t | lengthInBytes, | ||
| flash_xacc_state_t * | access_state | ||
| ) | 
This function retrieves the current flash access status for a given flash area as determined by the start address and length.
| config | A pointer to the storage for the driver runtime state. | 
| start | The start address of the desired flash memory to be checked. Must be word-aligned. | 
| lengthInBytes | The length, given in bytes (not words or long-words), to be checked. Must be word-aligned. | 
| access_state | A pointer to the value returned for the current access status code for the desired flash area. | 
| kStatus_FTFx_Success | API was executed successfully; the executeOnly state of specified FLASH region was stored to access_state. | 
| kStatus_FTFx_InvalidArgument | An invalid argument is provided. | 
| kStatus_FTFx_AlignmentError | The parameter is not aligned to the specified baseline. | 
| kStatus_FTFx_AddressError | The address is out of range. | 
| status_t FLASH_PflashSetProtection | ( | flash_config_t * | config, | 
| pflash_prot_status_t * | protectStatus | ||
| ) | 
| config | A pointer to storage for the driver runtime state. | 
| protectStatus | The expected protect status to set to the PFlash protection register. Each bit is corresponding to protection of 1/32(64) of the total PFlash. The least significant bit is corresponding to the lowest address area of PFlash. The most significant bit is corresponding to the highest address area of PFlash. There are two possible cases as shown below: 0: this area is protected. 1: this area is unprotected. | 
| kStatus_FTFx_Success | API was executed successfully; the specified FLASH region is protected. | 
| kStatus_FTFx_InvalidArgument | An invalid argument is provided. | 
| kStatus_FTFx_CommandFailure | Run-time error during command execution. | 
| status_t FLASH_PflashGetProtection | ( | flash_config_t * | config, | 
| pflash_prot_status_t * | protectStatus | ||
| ) | 
| config | A pointer to the storage for the driver runtime state. | 
| protectStatus | Protect status returned by the PFlash IP. Each bit is corresponding to the protection of 1/32(64) of the total PFlash. The least significant bit corresponds to the lowest address area of the PFlash. The most significant bit corresponds to the highest address area of PFlash. There are two possible cases as shown below: 0: this area is protected. 1: this area is unprotected. | 
| kStatus_FTFx_Success | API was executed successfully; the Protection state was stored to protectStatus; | 
| kStatus_FTFx_InvalidArgument | An invalid argument is provided. | 
| status_t FLASH_GetProperty | ( | flash_config_t * | config, | 
| flash_property_tag_t | whichProperty, | ||
| uint32_t * | value | ||
| ) | 
| 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. | 
| kStatus_FTFx_Success | API was executed successfully; the flash property was stored to value. | 
| kStatus_FTFx_InvalidArgument | An invalid argument is provided. | 
| kStatus_FTFx_UnknownProperty | An unknown property tag. | 
| status_t FLASH_GetCommandState | ( | void | ) | 
This function is used to obtain the execution status of the previous command.
| kStatus_FTFx_Success | The previous command is executed successfully. | 
| kStatus_FTFx_ExecuteInRamFunctionNotReady | Execute-in-RAM function is not available. | 
| kStatus_FTFx_AccessError | Invalid instruction codes and out-of bounds addresses. | 
| kStatus_FTFx_ProtectionViolation | The program/erase operation is requested to execute on protected areas. | 
| kStatus_FTFx_CommandFailure | Run-time error during the command execution. |