Operating Modes and On-Chip Memory
M68HC11E Family Data Sheet, Rev. 5.1
48
Freescale Semiconductor
2.4.1 Programming an Individual EPROM Address
In this method, the MCU programs its own EPROM by controlling the PPROG register (EPROG in
MC68HC711E20). Use these procedures to program the EPROM through the MCU with:
The ROMON bit set in the CONFIG register
The 12-volt nominal programming voltage present on the XIRQ/VPPE pin
The IRQ pin must be pulled high.
NOTE
Any operating mode can be used.
This example applies to all devices with EPROM/OTPROM except for the MC68HC711E20.
EPROG
LDAB
#$20
STAB
$103B
Set ELAT bit in (EPGM = 0) to enable
EPROM latches.
STAA
$0,X
Store data to EPROM address
LDAB
#$21
STAB
$103B
Set EPGM bit with ELAT = 1 to enable
EPROM programming voltage
JSR
DLYEP
Delay 2–4 ms
CLR
$103B
Turn off programming voltage and set
to READ mode
This example applies only to MC68HC711E20.
EPROG
LDAB
#$20
STAB
$1036
Set ELAT bit (EPGM = 0) to enable
EPROM latches.
STAA
$0,X
Store data to EPROM address
LDAB
#$21
STAB
$1036
Set EPGM bit with ELAT = 1 to enable
EPROM programming voltage
JSR
DLYEP
Delay 2–4 ms
CLR
$1036
Turn off programming voltage and set
to READ mode
2.4.2 Programming the EPROM with Downloaded Data
When using this method, the EPROM is programmed by software while in the special test or bootstrap
modes. User-developed software can be uploaded through the SCI or a ROM-resident EPROM
programming utility can be used. The 12-volt nominal programming voltage must be present on the
XIRQ/VPPE pin. To use the resident utility, bootload a 3-byte program consisting of a single jump
instruction to $BF00. $BF00 is the starting address of a resident EPROM programming utility. The utility
program sets the X and Y index registers to default values, then receives programming data from an
external host, and puts it in EPROM. The value in IX determines programming delay time. The value in
IY is a pointer to the first address in EPROM to be programmed (default = $D000).
When the utility program is ready to receive programming data, it sends the host the $FF character. Then
it waits. When the host sees the $FF character, the EPROM programming data is sent, starting with the
first location in the EPROM array. After the last byte to be programmed is sent and the corresponding
verification data is returned, the programming operation is terminated by resetting the MCU.
included at the back of this document.