Datasheet
FLASH-1 Program Operation
MC68HC908AZ60A • MC68HC908AS60A • MC68HC908AS60E Data Sheet, Rev. 6
Freescale Semiconductor 57
3. Write to any FLASH-1 address within the row address range desired with any data.
4. Wait for time, t
NVS
.
5. Set the HVEN bit.
6. Wait for time, t
PGS
.
7. Write data byte to the FLASH-1 address to be programmed.
8. Wait for time, t
 PROG
.
9. Repeat step 7 and 8 until all the bytes within the row are programmed.
10. Clear the PGM bit.
11. Wait for time, t
NVH
.
12. Clear the HVEN bit.
13. Wait for a time, t
RCV
, after which the memory can be accessed in normal read mode.
The FLASH Programming Algorithm Flowchart is shown in Figure 4-4.
NOTE
A. Programming and erasing of FLASH locations can not be performed by 
code being executed from the same FLASH array.
B. While these operations must be performed in the order shown, other 
unrelated operations may occur between the steps. Care must be taken 
however to ensure that these operations do not access any address within 
the FLASH array memory space such as the COP Control Register 
(COPCTL) at $FFFF.
C. It is highly recommended that interrupts be disabled during 
program/erase operations.
D. Do not exceed t
 PROG 
maximum or t
HV 
maximum. t
HV 
is defined as the 
cumulative high voltage programming time to the same row before next 
erase. t
HV 
must satisfy this condition: t
NVS
+ t
NVH
 + t
PGS
 + (t
PROG
X 64) 
≤
 t
HV 
max. Please also see 28.1.14 FLASH Memory Characteristics.
E. The time between each FLASH address change (step 7 to step 7), or the 
time between the last FLASH address programmed to clearing the PGM bit 
(step 7 to step 10) must not exceed the maximum programming time, t
PROG
max.
F. Be cautious when programming the FLASH-1 array to ensure that 
non-FLASH locations are not used as the address that is written to when 
selecting either the desired row address range in step 3 of the algorithm or 
the byte to be programmed in step 7 of the algorithm. This applies 
particularly to:
$FFD2-$FFD3 and $FFDA-$FFFF: Vector area on
MC68HC908AS60A (40 bytes)
$FFCC-$FFFF: Vector area on MC68HC908AZ60A (52 bytes)










