Datasheet
346
Atmel | SMART SAM D21 [DATASHEET]
Atmel-42181C–SAM-D21_Datasheet–07/2014
21.6.2 Basic Operations
21.6.2.1  Initialization
After power up, the NVM Controller goes through a power-up sequence. During this time, access to the NVM Controller 
from the AHB bus is halted. Upon power-up completion, the NVM Controller is operational without any need for user 
configuration. 
21.6.2.2  Enabling, Disabling and Resetting
Not applicable.
21.6.3 Memory Organization
Refer to “Physical Memory Map” on page 22 for memory sizes and addresses for each device. 
The NVM is organized into rows, where each row contains four pages, as shown in Figure 21-2. The NVM has a row-
erase granularity, while the write granularity is by page. In other words, a single row erase will erase all four pages in the 
row, while four write operations are used to write the complete row. 
Figure 21-2. Row Organization
The NVM block contains a calibration and auxiliary space that is memory mapped. Refer to Figure 21-3
for details.
The calibration and auxiliary space contains factory calibration and system configuration information. This space can be 
read from the AHB bus in the same way as the main NVM main address space.
In addition, a boot loader section can be allocated at the beginning of the main array, and an EEPROM emulation area 
can be allocated at the end of the NVM main address space.
Figure 21-3. NVM Memory Organization
The lower rows in the NVM main address space can be allocated as a boot loader section by using the BOOTPROT 
fuses, and the upper rows can be allocated to EEPROM emulation, as shown in Figure 21-4. The boot loader section is 
protected by the lock bit(s) corresponding to this address space and by the BOOTPROT[2:0] fuse. The EEPROM rows 
can be written regardless of the region lock status. The number of rows protected by BOOTPROT and the number of 
rows allocated to EEPROM emulation are given in Table 21-2 and Table 21-3, respectively. 
Page (n * 4) + 0Row n Page (n * 4) + 1Page (n * 4) + 2Page (n * 4) + 3
NVM Base Address
Calibration and 
auxiliary space
NVM Main 
Address Space
NVM Base Address + NVM size
NVM Base Address + 0x00800000










