Datasheet
FLASH Memory
Technical Data MC68HC908JB8•MC68HC08JB8•MC68HC08JT8 — Rev. 2.3
58 FLASH Memory Freescale Semiconductor
4.7 FLASH Program Operation
Programming of the FLASH memory is done on a row basis. A row 
consists of 64 consecutive bytes starting from addresses $XX00, 
$XX40, $XX80 or $XXC0. The procedure for programming a row of the 
FLASH memory is outlined below:
1. Set the PGM bit. This configures the memory for program 
operation and enables the latching of address and data for 
programming.
2. Write any data to any FLASH address within the address range of 
the row to be programmed.
3. Wait for a time, t
nvs
 (5 µs).
4. Set the HVEN bit.
5. Wait for a time, t
pgs
 (10 µs).
6. Write data to the byte being programmed.
7. Wait for time, t
PROG 
(20 µs).
8. Repeat step 6 and 7 until all the bytes within the row are 
programmed.
9. Clear the PGM bit.
10. Wait for time, t
nvh
 (5 µs).
11. Clear the HVEN bit.
12. After time, t
rcv
 (1 µs), the memory can be accessed in read mode 
again.
This program sequence is repeated throughout the memory until all data 
is programmed.
NOTE: Programming and erasing of FLASH locations cannot be performed by 
code being executed from the FLASH memory. While these operations 
must be performed in the order shown, other unrelated operations may 
occur between the steps. Do not exceed t
PROG
 maximum (see 18.13 
Memory Characteristics).
Figure 4-3 shows a flowchart representation for programming the 
FLASH memory.










