High level interface to the onboard Non-Volatile memory (Internal Flash, RRAM, OTP region).
Onboard NVM provides non-volatile storage for factory settings, secure data, user firmware, configuration, and bulk data.
This driver allows data to be read from and written to NVM. It also provides the ability to obtain information about the address and characteristics of the NVM block(s) contained on the device. During NVM write time, the device should not be reset (including XRES pin, software reset, and watchdog) or unexpected changes may be made to portions of the NVM. Also, the low-voltage detect circuits should be configured to generate an interrupt instead of a reset.
Following code snippet demonstrates how to fetch NVM characteristics. Refer mtb_hal_nvm_info_t for more information.
Following code snippet demonstrates blocking NVM write. It uses a constant array with a size equaling the size of one NVM row/block. It uses blocking NVM write operation which blocks the caller until the write is completed. It then verifies the NVM data by comparing the NVM data with the written data.
API Reference | |
NVM HAL Results | |
NVM specific return codes. | |
Data Structures | |
struct | mtb_hal_nvm_region_info_t |
Information about a single region of NVM memory. More... | |
struct | mtb_hal_nvm_info_t |
Information about all of the regions of NVM memory. More... | |
Enumerations | |
enum | mtb_hal_nvm_type_t { MTB_HAL_NVM_TYPE_INVALID = 0U , MTB_HAL_NVM_TYPE_FLASH = 1U , MTB_HAL_NVM_TYPE_RRAM = 2U , MTB_HAL_NVM_TYPE_OTP = 3U } |
Enum of Non-volatile memory (NVM) types. More... | |
Functions | |
void | mtb_hal_nvm_get_info (mtb_hal_nvm_t *obj, mtb_hal_nvm_info_t *info) |
Get details about the NVM memory regions such as NVM type, start address, size, is_erase_required, and erase values etc. More... | |
cy_rslt_t | mtb_hal_nvm_read (mtb_hal_nvm_t *obj, uint32_t address, uint8_t *data, size_t size) |
Read size amount of data starting from the given address of NVM. More... | |
cy_rslt_t | mtb_hal_nvm_erase (mtb_hal_nvm_t *obj, uint32_t address) |
Erase one block of NVM starting at the given address. More... | |
cy_rslt_t | mtb_hal_nvm_write (mtb_hal_nvm_t *obj, uint32_t address, const uint32_t *data) |
This function erases the block, if required, and writes the new data into the block starting at the given address. More... | |
cy_rslt_t | mtb_hal_nvm_program (mtb_hal_nvm_t *obj, uint32_t address, const uint32_t *data) |
Program one block with the provided data starting at the given address. More... | |
const mtb_hal_nvm_region_info_t * | mtb_hal_nvm_get_region_for_address (mtb_hal_nvm_t *obj, uint32_t addr, uint32_t length) |
Find the nvm region based on given address and length. More... | |
struct mtb_hal_nvm_region_info_t |
Data Fields | ||
---|---|---|
mtb_hal_nvm_type_t | nvm_type | NVM type. |
uint32_t | start_address | Base address of the distinct NVM region. |
uint32_t | offset | Offset to the address in the distinct NVM region. |
uint32_t | size | Size of the distinct NVM region. |
uint32_t | sector_size | Sector size of the distinct NVM region. |
uint32_t | block_size | Block size (programming granularity) of the distinct NVM region. |
bool | is_erase_required | true = erase required before program, false = erase not required before program. |
uint8_t | erase_value | NVM erase value (if applicable). |
struct mtb_hal_nvm_info_t |
Data Fields | ||
---|---|---|
uint8_t | region_count | The number of distinct NVM regions. |
const mtb_hal_nvm_region_info_t * | regions | Array of the distinct NVM regions. |
enum mtb_hal_nvm_type_t |
void mtb_hal_nvm_get_info | ( | mtb_hal_nvm_t * | obj, |
mtb_hal_nvm_info_t * | info | ||
) |
Get details about the NVM memory regions such as NVM type, start address, size, is_erase_required, and erase values etc.
Refer mtb_hal_nvm_info_t, mtb_hal_nvm_region_info_t for more information.
[in] | obj | The NVM object. |
[out] | info | The NVM characteristic info. |
Refer Snippet 1: Get NVM Characteristics for more information.
Get details about the NVM memory regions such as NVM type, start address, size, is_erase_required, and erase values etc.
Description: Provides a high level interface for interacting with the Infineon embedded non-volatile memory (NVM). This is wrapper around the lower level PDL API.
SPDX-License-Identifier: Apache-2.0
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
cy_rslt_t mtb_hal_nvm_read | ( | mtb_hal_nvm_t * | obj, |
uint32_t | address, | ||
uint8_t * | data, | ||
size_t | size | ||
) |
Read size amount of data starting from the given address of NVM.
[in] | obj | The NVM object. |
[in] | address | Address to begin reading from. |
[out] | data | The buffer to read data into. |
[in] | size | The number of bytes to read. |
Refer Snippet 2: Blocking NVM Erase-Write and Read for more information.
cy_rslt_t mtb_hal_nvm_erase | ( | mtb_hal_nvm_t * | obj, |
uint32_t | address | ||
) |
Erase one block of NVM starting at the given address.
The address must be at block boundary. This will block until the erase operation is complete.
[in] | obj | The NVM object |
[in] | address | The block address to be erased |
Refer Snippet 2: Blocking NVM Erase-Write and Read for more information.
cy_rslt_t mtb_hal_nvm_write | ( | mtb_hal_nvm_t * | obj, |
uint32_t | address, | ||
const uint32_t * | data | ||
) |
This function erases the block, if required, and writes the new data into the block starting at the given address.
The address must be at block boundary. This will block until the write operation is complete.
data
to be written must be located in the SRAM memory region.[in] | obj | The NVM object |
[in] | address | The address of the block to be written |
[in] | data | The data buffer to be written to the NVM block |
Refer Snippet 2: Blocking NVM Erase-Write and Read for more information.
cy_rslt_t mtb_hal_nvm_program | ( | mtb_hal_nvm_t * | obj, |
uint32_t | address, | ||
const uint32_t * | data | ||
) |
Program one block with the provided data starting at the given address.
The address must be at block boundary. This will block until the write operation is complete.
data
to be programmed must be located in the SRAM memory region.[in] | obj | The NVM object |
[in] | address | The address of the block to be programmed |
[in] | data | The data buffer to be programmed to the NVM block |
const mtb_hal_nvm_region_info_t * mtb_hal_nvm_get_region_for_address | ( | mtb_hal_nvm_t * | obj, |
uint32_t | addr, | ||
uint32_t | length | ||
) |
Find the nvm region based on given address and length.
If "length is zero and address is not in any nvm region" or if "length is not zero and address is not in any nvm region" or if "length is not zero and address is one nvm region but address + length goes into another nvm region", the function will return Null.
[in] | obj | The NVM object |
[in] | addr | The start address of the block |
[in] | length | The legnth to block |