Atmel ATmega128 Manual page 273

8-bit avr microcontroller with 128k bytes in-system programmable flash
Hide thumbs Also See for ATmega128:
Table of Contents

Advertisement

Boot Loader
Support – Read-
While-Write
Self-
Programming
Boot Loader
Features
Application and
Boot Loader Flash
Sections
Application Section
Boot Loader Section –
BLS
Read-While-Write
and No Read-
While-Write Flash
Sections
2467S–AVR–07/09
The Boot Loader Support provides a real Read-While-Write Self-Programming mechanism for
downloading and uploading program code by the MCU itself. This feature allows flexible applica-
tion software updates controlled by the MCU using a Flash-resident 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 mem-
ory. 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 differ-
ent levels of protection.
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
(1)
Optimized Page
Size
Code Efficient Algorithm
Efficient Read-Modify-Write Support
Note:
1. A page is a section in the flash consisting of several bytes (see
during programming. The page organization does not affect normal operation.
The Flash memory is organized in two main sections, the Application section and the Boot
Loader section (see
Figure
fuses as shown in
Table on page 284
level of protection since they have different sets of Lock bits.
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
Loader code since the SPM instruction is disabled when executed from the application section.
While the application section is used for storing the application code, the The Boot Loader soft-
ware must be located in the BLS since the SPM instruction can initiate a programming 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
Whether the CPU supports Read-While-Write or if the CPU is halted during a Boot Loader soft-
ware 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
Note: on page 284
and
Figure 133 on page
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.
Note that the user software can never read any code that is located inside the RWW section dur-
ing a Boot Loader software operation. The syntax "Read-While-Write section" refers to which
133). The size of the different sections is configured by the BOOTSZ
and
Figure
275. The application section can never store any Boot
Table 109 on page
275. The main difference between the two sections
ATmega128
Table 123 on page
133. These two sections can have different
276.
291) used
Table
273

Advertisement

Table of Contents
loading
Need help?

Need help?

Do you have a question about the ATmega128 and is the answer not in the manual?

This manual is also suitable for:

Atmega128l

Table of Contents

Save PDF