Boot loader features, Application and boot loader flash sections, Application section – Rainbow Electronics ATmega128L User Manual

Page 266: Boot loader section – bls, Boot loader support – read, Boot loader, Atmega128(l)

Advertising
background image

266

ATmega128(L)

2467B–09/01

Boot Loader Support
– Read-While-Write
Self-Programming

The Boot Loader Support provides a real Read-While-Write self-programming mecha-
nism for downloading and uploading program code by the MCU itself. This feature
allows flexible application software updates controlled by the MCU using a Flash-resi-
dent Boot Loader program. The Boot Loader program can use any available data
interface and associated protocol to read code and write (program) that code into the
Flash memory, or read the code from the program memory. The program code within
the Boot Loader section has the capability to write into the entire Flash, including the
Boot Loader Memory. The Boot Loader can thus even modify itself, and it can also
erase itself from the code if the feature is not needed anymore. The size of the Boot
Loader Memory is configurable with fuses and the Boot Loader has two separate sets of
Boot Lock Bits which can be set independently. This gives the user a unique flexibility to
select different levels of protection.

Boot Loader Features

Read-While-Write Self-Programming

Flexible Boot Memory Size

High Security (Separate Boot Lock Bits for a Flexible Protection)

Separate Fuse to Select Reset Vector

Optimized Page

(1)

Size

Code Efficient Algorithm

Efficient Read-Modify-Write Support

Note:

1. A page is a section in the flash consisting of several bytes (see

Table 124 on page

283)

used during programming. The page organization does not affect normal

operation.

Application and Boot
Loader Flash Sections

The Flash memory is organized in two main sections, the Application section and the
Boot loader section (see

Figure 133). The size of the different sections is configured by

the BOOTSZ fuses as shown in

Table on page 277 and Figure 133. These two sections

can have different level of protection since they have different sets of lock-bits.

Application Section

The application section is the section of the Flash that is used for storing the application
code. The protection level for the application section can be selected by the application
boot lock bits (Boot Lock bits 0), see

Table on page 268. The application section can

never store any Boot Loader code since the SPM instruction is disabled when executed
from the application section.

Boot Loader Section – BLS

While the application section is used for storing the application code, the The Boot
Loader software must be located in the BLS since the SPM instruction can initiate a pro-
gramming when executing from the BLS only. The SPM instruction can access the
entire Flash, including the BLS itself. The protection level for the Boot Loader section
can be selected by the Boot Loader lock bits (Boot Lock bits 1), see

Table 110 on page

269.

Read-While-Write and No
Read-While-Write Flash
Sections

Whether the CPU supports Read-While-Write or if the CPU is halted during a Boot
Loader software update is dependent on which address that is being programmed. In
addition to the two sections that are configurable by the BOOTSZ fuses as described
above, the Flash is also divided into two fixed sections, the Read-While-Write (RWW)
section and the No Read-While-Write (NRWW) section. The limit between the RWW-
and NRWW sections is given in

Table Note: on page 277 and Figure 133 on page 268.

The main difference between the two sections is:

When erasing or writing a page located inside the RWW section, the NRWW section
can be read during the operation.

When erasing or writing a page located inside the NRWW section, the CPU is halted
during the entire operation.

Advertising