Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Скачиваний:
87
Добавлен:
01.03.2016
Размер:
3.56 Mб
Скачать

RM0016

Flash program memory and data EEPROM

 

 

The HVOFF flag can also be polled by the application which can execute other instructions (RWW) during the actual programming phase of the DATA.

The EOP and WR_PG_DIS bits of the FLASH_IAPSR register can be checked to determine if the fast block programming operation has been correctly completed.

Caution: The data programmed in the block are not guaranteed when the block is not blank before the fast block program operation.

Block erasing

A block erase allows a whole block to be erased.

To erase a whole block, the ERASE/NERASE bits in the FLASH_CR2 and FLASH_NCR2 registers must be previously set/cleared to enable block erasing (see Section 4.8.2: Flash control register 2 (FLASH_CR2) and Section 4.8.3: Flash complementary control register 2 (FLASH_NCR2)). The block is then erased by writing ‘0x00 00 00 00’ to any word inside the block. The word start address must end with ‘0’, ‘4’, ‘8’, or ‘C’.

The EOP and the WR_PG_DIS control flags of the FLASH_IAPSR together with the Flash interrupt can be used to determine if the operation has been correctly completed.

Table 5.

Block size

 

 

STM8 microcontroller family

Block size

 

 

 

 

Low density STM8S and STM8AF

64 bytes

 

 

Medium density STM8S and STM8AF (up to 32 Kbytes)

128 bytes

 

 

High density STM8S and STM8AF (up to 128 Kbytes)

128 bytes

 

 

 

4.6.5Option byte programming

Option byte programming is very similar to data EEPROM byte programming.

The application writes directly to the target address. The program does not stop and the write operation is performed using the RWW capability.

Refer to the datasheet for details of the option byte contents.

4.7ICP and IAP

The in-circuit programming (ICP) method is used to update the entire content of the memory, using the SWIM interface to load the user application into the microcontroller. ICP offers quick and efficient design iterations and eliminates unnecessary package handling or socketing of devices. The SWIM interface (single wire interface module) uses the SWIM pin to connect to the programming tool.

In contrast to the ICP method, in-application programming (IAP) can use any communication interface supported by the microcontroller (I/Os, I2C, SPI, USART...) to download the data to be programmed in the memory. IAP allows the Flash program memory content to be reprogrammed during application execution. Nevertheless, part of the application must have been previously programmed in the Flash program memory using ICP.

Refer to the STM8S and STM8AF Flash programming manual (PM0051) and STM8 SWIM protocol and debug manual (UM0470) for more information on programming procedures.

Doc ID 14587 Rev 9

49/454

Flash program memory and data EEPROM

RM0016

 

 

 

 

 

Table 6.

Memory access versus programming method(1)

 

 

Mode

ROP

Memory Area

Access from

 

core

 

 

 

 

 

 

 

 

 

 

 

 

User boot code area (UBC)

R/E

 

 

Readout

 

 

 

 

Main program

R/W/E(2)

 

 

protection

 

 

 

 

Data EEPROM area (DATA)

R/W(3)

 

 

enabled

User, IAP, and bootloader (if

 

Option bytes

R

 

 

 

available)

 

 

User boot code area (UBC)

(4)

 

 

 

R/E

 

 

Readout

 

 

 

 

Main program

R/W/E(2)

 

 

protection

 

 

 

 

Data EEPROM area (DATA)

R/W(3)

 

 

disabled

 

 

 

Option bytes

R/W(5)

 

 

 

User boot code area (UBC)

P

 

 

Readout

 

 

 

 

Main program

P

 

 

protection

 

 

 

 

Data EEPROM area (DATA)

P

 

 

enabled

 

 

 

 

 

SWIM active

 

Option bytes

(6)

 

P/WROP

(ICP mode)

 

User boot code area (UBC)

(4)

 

 

 

R/E

 

 

Readout

 

 

 

 

Main program

R/W/E(2)

 

 

protection

 

 

 

 

Data EEPROM area (DATA)

R/W(3)

 

 

disabled

 

 

 

Option bytes

R/W(5)

1.R/W/E = Read, write, and execute

R/E = Read and execute (write operation forbidden) R = Read (write and execute operations forbidden)

P = The area cannot be accessed (read, execute and write operations forbidden) P/WROP = Protected, write forbidden except for ROP option byte.

2.The Flash program memory is write protected (locked) until the correct MASS key is written in the FLASH_PUKR. It is possible to lock the memory again by resetting the PUL bit in the FLASH_IAPSR register. If incorrect keys are provided, the device must be reset and new keys programmed.

3.The data memory is write protected (locked) until the correct MASS key is written in the FLASH_DUKR. It is possible to lock the memory again by resetting the DUL bit in the IAPSR register. If incorrect keys are provided, another key program sequence can be performed without resetting the device.

4.To program the UBC area, the application must first clear the UBC option byte.

5.The option bytes are write protected (locked) until the correct MASS key is written in the FLASH_DUKR (with OPT set to 1). It is possible to lock the memory again by resetting the DUL bit in the FLASH_IAPSR register. If incorrect keys are provided, another key program sequence can be performed without resetting the device.

6.When ROP is removed, the whole memory is erased, including the option bytes.

50/454

Doc ID 14587 Rev 9

Соседние файлы в папке Минимум документации STM8