

#### **Freescale Semiconductor**

Order this document by AN1753/D

# AN1753

## Implementing a FLASH Memory System in an MC68HC711E9 Design

By Joe Haas

Applications Engineering TSG Body Electronics and Strategic Industrial Division Austin, Texas

### Introduction

FLASH technology offers several advantages to a M68HC11 microcontroller design. Field updates, lower-power consumption, and increased memory densities are but a few of the potential benefits of incorporating external FLASH memory as a firmware/data media. However, several drawbacks can provide significant obstacles to implementation on a M68HC11 system.

Most of the difficulties with a FLASH memory implementation derive from the fact that FLASH requires an algorithm to program data. Many FLASH devices cannot perform read operations during a programming cycle, so the algorithm must be maintained in a memory device physically separated from the FLASH to be programmed. Thus, an additional memory device is needed to hold the programming algorithm. Typically, this device will occupy the upper slot in the M68HC11 memory map to maintain the interrupt vectors. This necessitates the need for a jump table to route these static interrupt vectors which increases interrupt response latency. Any interrupts that are desired for the programming algorithm also must be subjected to an arbitration

© Freescale Semiconductor, Inc., 2004. All rights reserved. © Motorola, Inc., 1998

AN1753





mechanism which adds both latency and documentation overhead for firmware development and maintenence.

Bootstrap mode of the M68HC11 Family could be used to upload a FLASH programming algorithm, but this also has several drawbacks. For example:

- The MCU RAM is limited in size, so it cannot hold an algorithm of any complexity. External RAM may be available, depending on the design.
- If external RAM is non-volitile, its use as a temporary program space could corrupt previously stored data.
- Bootstrap mode requires a special data sequence which is not compatible with manual download from a terminal and thus requires the use of a special boot loader running on the host system.
- Depending on the MCU crystal frequency, the bootstrap serial communication parameters can specify an odd serial data rate which isn't supported by a standard boot loader.

For most applications, any one of these difficulties, much less all of them, could easily eliminate the possiblity of implementing a FLASH device.

This application note describes a single board computer (SBC) design which uses a FLASH device as its main program/data storage media. The emphasis is on the hardware and firmware techniques used to implement the FLASH programming system as well as its impact on firmware development. Also, an example of a retrofit design is included to illustrate how these techniques are modified to convert an existing EPROM-based design to FLASH.



### System Requirements

While many aspects of the SBC design presented here can be varied to fit the needs of a particular application, there are some features that must be present to support the FLASH system as described here. Typically, FLASH data originates from a host system (for instance, a PC) which necessitates the need for a programming host connector. The host port connector must bring out the MODA/MODB pins, as well as the SCI (serial communications interface) pins (PD0/PD1), ~XIRQ (optional), and RESET. If a FLASH device is used that requires an external V<sub>PP</sub> source, this signal also is required on the host port. This requirement depends on the system design. The V<sub>PP</sub> source can be placed on the target system, but will represent a fixed cost in the final design that will erode per-unit cost margins. Moving this source off target onto a host programming interface can reduce overall costs if the number of target systems is significantly higher than the number of programming systems. Finally, a small segment (four to six bytes) of MCU EEPROM must be reserved for use by the programming firmware.

Providing the ~XIRQ signal to the host system is optional. Doing so will allow in-circuit factory programming of the 68HC711E9 EPROM. The same host system can be used for both FLASH and MCU EPROM programming operations which support a factory environment where virgin MCU and FLASH devices may be placed on the target circuit board for in-circuit programming as part of the test procedure. In this case, special considerations should be given to the ~XIRQ circuit, if it is used in the target design, as this signal is subjected to voltage levels in excess of 5 volts during MCU EPROM programming operations.

#### Host Interface Description

**Figure 1** shows the schematic for the SBC system used in this example. The host port connector is implemented with a 10-pin dual row connector (P1) which connects to a programming interface card. Most of the signal connections are straightforward except for the RXD (PD0) signal. Here, a resistor is used to passively switch the RXD signal when the programming interface is connected. This allows the target system to share the serial port between the FLASH programming host and another target resource.



Semiconductor, Inc.

Freescale

## **Freescale Semiconductor, Inc.**

**Application Note** 





With the programming module removed, the RXD signal passes from the target RS-232 receiver (U9) to the MCU (U1) via resistor R2. The only consideration is to keep the resistor value low enough that it will not interact with the input capacitance of the MCU to form a low pass filter while providing enough impedance that driver contention is eliminated.

To eliminate filter effects, the following must be satisfied:

$$r < 1/(2\pi 3 fc)$$

Where r is the value of R2 in ohms, f is the maximum desired baud rate (bits per second), and c is the total capacitance of PD0 in farads (input and stray capacitance). 3f is used here to account for the third order harmonics which can be a significant component of a square wave signal. At 115 Kbaud, this value calculates to approximately 80 k $\Omega$  – in practice, values of 1 K to 10 K are recomended.

The only difficulty with this mechanism involves the nature of the target resource; it must be able to tolerate the serial traffic that is present during programming without producing unknown or undesirable results.

**NOTE:** The FLASH programming baud rate usually is not related to the target resource baud rate. This can compound the difficulty due to the fact that a baud rate mismatch can cause known data streams at one baud rate to appear as pseudo-random data streams at another. For situations where this is a problem, a more involved switching mechanism may be required.

As mentioned earlier, a specialized programming interface card can offer a convenient and cost-effective host interface. The programming interface card used in this design is shown in Figure 2 and features an RS-232 transceiver, SCI loop-back switch,  $V_{PP}$  voltage converter, and reset controller. The reset controller is implemented with an MC68HC705K1 microcontroller which contains a simple program that interprets the control switches and manipulates the target MCU signals appropriately.



**Application Note** 



Figure 2. Host Programming Adapter Schematic

![](_page_5_Figure_5.jpeg)

AN1753

![](_page_6_Picture_0.jpeg)

The following describes the button functions:

- Target RESET (SW1) Connected to the target reset I/O (input/output) signal. When activated in boot mode, the target PD0 and PD1 signals are briefly "shorted" to loop-back the MCU SCI activity. In normal mode, the target system is simply reset (no loop-back).
- MONITOR (SW2) When in the normal mode, this function toggles the host RXD source between the target PD0 and PD1 signals. A third state connects the host RXD/TXD to the target PD0/PD1 (respectively). This function is not active in bootstrap mode.
- MODE (SW3) This toggles the target system between normal mode and boot mode. The MODA/MODB control output is high-Z for normal mode and V<sub>OL</sub> for bootstrap mode.
- V<sub>PP</sub> ON (SW4) In bootstrap mode, allows the V<sub>PP</sub> source to be toggled on and off. This function is not active in normal mode.

The monitor function uses the module's loop-back switch to selectively route the target RXD and TXD signals (MCU PD0/1) to the host serial port when the target is in normal mode. This allows the host to easily trace serial data from either side of the target system's SCI interface which can be useful as a system level debugging tool.

Program Listings — Host Interface Reset Controller — Listing 1

shows the reset controller assembly source code. The code structure is relatively straightforward, consisting of the initialization, main loop, and ~IRQ service routine. Initialization begins at the ENTRY label and consists of setting the port A and port B DDRs (data direction register) and initializing the port outputs. The main loop begins at the TOP label which continuously polls the push button inputs. If a button push is detected, the firmware loops until it is released. Switch edges are debounced by a 20-ms timer to help prevent false signals due to switch noise. After switch release is detected, the firmware processes the selected button's function.

![](_page_7_Picture_0.jpeg)

The interrupt routine at IRQI traps falling edges of the reset button. Since the reset button is also connected to the target reset signal, resets originating with the target system will be trapped also. This way, the reset sequence is handled properly, no matter what the reset source.

#### System Memory Map

**Figure 3** illustrates the memory map of the SBC that is being demonstrated in this application note. In addition to the normal MCU resources (on-chip RAM, I/O registers, and EEPROM), there are a FLASH memory device, two external RAMs, and some external registers. The FLASH and RAM slots can contain devices of up to 4 Mbit (512 K x 8). Since this far exceeds the 64-K addressing space of the M68HC11, a bank switching scheme is used to page through the large density devices using I/O signals to resolve the upper physical address signals.

While the RAM device(s) simply use direct replacement to resolve the upper address signals, the paging scheme for the FLASH device is a bit more complicated.

First, we desire a fixed portion of the FLASH memory to be visible in the upper portion of the MCU memory map (\$8000 through \$FFFF). This will hold the MCU interrupt vectors as well as up to 32 Kbytes of kernal ROM, which is intended to hold the core of the SBC operating system. Intuitively, this window should reside at the top of the FLASH ROM physical address space where the banked address signals A[18:15] are [1111]. This forces any access to MCU addresses in the range of \$8000 to \$FFFF to access FLASH memory at physical addresses \$78000 through \$7FFFF regardless of the current bank setting.

In addition to the kernal window at \$8000–\$FFFF, a separate 8-Kbyte window is used to access the remainder of the FLASH device at MCU addresses \$2000 through \$3FFF (referred to as "mirroring"). Addresses in this range will access the full physical device map from \$00000 to \$7FFFF, depending on the combination of A[12:0] and the bank selects. The A[18:13] vector for the mirror window is determined only by the value of the bank register.

![](_page_8_Picture_0.jpeg)

Application Note System Requirements

![](_page_8_Figure_3.jpeg)

### Figure 3. Target System Memory Map

A logic circuit is used to combine the MCU address signals and the bank select signals into a physical address vector that can be connected to the FLASH device. This logic circuit needs to force the physical address[18:15] to [1111] for MCU \$8000–\$FFFF and pass the bank selects to the physical address [18:13] for accesses at MCU \$2000–\$3FFF. Since the kernal window takes the upper half of the memory map, the A15 signal can be used to force the physical address source. Since the resulting physical address is connected exclusively to the FLASH device, only A15 is needed to switch between the two FLASH windows.

Since the logic required to implement this project is relatively simple, a behavioral level schematic was sketched using off-the-shelf logic

![](_page_9_Picture_0.jpeg)

devices. The schematic's sum-of-products representations were then extracted manually as shown in **Table 1**.

| fA[18:15] | = ~(~lat[5:2] * ~A15)                                |
|-----------|------------------------------------------------------|
|           | = lat[5:2] + A15                                     |
| fA[14:13] | = ~(~(lat[1:0] * ~A15) * ~(A[14:13] * A15))          |
|           | = ((lat[1:0] * ~A15) + (A[14:13] * A15))             |
| ~fcs      | = ~(~(~(~A15 * ~A14 * A13) * ~A15) * E)              |
|           | = ~(A[15] * E + ~A[15] * ~A[14] * A[13] * E)         |
| ~rcs      | = ~(E * ~A15 * A14 * ~A13)                           |
| ~acs      | = ~(E * ~A15 * A14 * A13)                            |
| lef       | = ~A15 * ~A14 * ~A13 * ~A12 * ~A10 * A9 * E * ~R/W   |
| ~ref      | = ~(~A15 * ~A14 * ~A13 * ~A12 * ~A10 * A9 * E * R/W) |
| ler       | = ~A15 * ~A14 * ~A13 * ~A12 * A10 * ~A9 * E * ~R/W   |
| ~rer      | = ~(~A15 * ~A14 * ~A13 * ~A12 * A10 * ~A9 * E * R/W) |

Table 1. SBC Memory System Logic Equations

Table 1 forms the basis of the HDL (hardware definition language) file used to generate the JEDEC (Joint Electron Device Engineering Council) fuse map for an FPGA (field programmable gate array). (The complete HDL design file appears in **Program Listings — FPGA HDL Listing — Listing 2**.) The fA[18:13] vector represents the physical FLASH address. (A[12:0] are obtained directly from the MCU.) The use of an FPGA is not required, but it offers many advantages over discrete logic implementation. As can be seen in **Table 1**, several logic devices would be required to implement the logic functions shown. This greatly increases the component count and board space required to implement the design, problems which can be eliminated by using the appropriate FPGA.

![](_page_10_Picture_0.jpeg)

### Programmer Core

With the key aspects of the target design frozen, consider now the techniques needed to use the FLASH programming system. The key to the FLASH system described here lies in the use of some subtleties of the 68HC711's bootstrap mode.

The key bootstrap mode features of interest are:

- When reset is in bootstrap mode, the MCU EPROM is forced on temporarily.
- While waiting for a download to begin, a serial break or ASCII NULL character received at the SCI will force the MCU instruction fetch to jump to EEPROM at \$B600 and begin executing code there.
- When reset in boot mode, the MCU sends a break to the SCI.

For this application, the FLASH programming firmware is placed in the MCU EPROM, which is off in normal mode, allowing the programming firmware to be "hidden" from the target application. To the application firmware developer, the system looks like a 68HC711 in expanded mode, with an extended array of memory resources. It is only necessary that the developer be concerned with these two FLASH system requirements:

- The EEPROM locations at \$B600-\$B605 are reserved for FLASH (holds jump to MCU EPROM and three FLASH personality data bytes).
- FLASH uses MCU RAM during programming mode.

The latter is important only if the system must use battery maintenance of MCU RAM for non-volatile storage. Since there are sufficient resources for ample external NVRAM, this should not be an issue in most designs.

![](_page_11_Picture_0.jpeg)

FLASH Operation The first step in initiating the FLASH program mode is to connect the programming interface and place the system in programming mode. This will reset the target MCU in bootstrap mode and set the loop-back switch to the MCU. When reset in bootstrap, the M68HC11 Family will issue a break to the SCI subsystem. By looping back the serial break that originates from the 68HC711E9, the MCU is forced to jump to \$B600 (the start of EEPROM). A pre-placed JMP instruction at \$B600 (programmed along with MCU EPROM) allows the system automatically to execute MCU EPROM code with no host intervention. A timer on the reset controller switches the loop-back to feed-through so that commands and data may be exchanged between the host and target systems after the reset sequence is complete.

This topology provides a scenario for getting the MCU to execute ROM code out of a bootstrap reset. Now the ROM code must manipulate some additional resources to get the system into a mode which will allow FLASH programming to occur. The ROM code must:

- Run the FLASH command processor
- Turn on MCU EPROM
- Turn on expanded mode (set MDA bit in HPRIO)

While in bootstrap mode, the expanded mode cannot be enabled until the MCU EPROM is turned on, which requires a subsequent MCU reset to take effect. This step could be performed automatically by the MCU EPROM code but is probably best left as a host command function. To illustrate why, consider that the MCU EPROM must be turned off at the completion of the FLASH programming session. A programming session can consist of several data upload operations, depending on how many devices are to be programmed and how their data is segmented. This can make it difficult for the target system to determine when the host is actually finished. The best scenario is for the host to explicitly command the target to turn off EPROM, with the same being true for EPROM on.

The full reset sequence for a programming session would then proceed this way:

- Reset in bootstrap mode
- Host commands EPROM on

![](_page_12_Picture_0.jpeg)

- Reset again (still in bootstrap mode)
- Perform programming operations
- Host commands EPROM off
- Reset in normal mode

FLASH AlgorithmThe bulk of the FLASH algorithm was derived from a simple command<br/>line-based EPROM programmer written for the M68HC11 (reference 1).<br/>This code uses a command and parameter parsing system to perform<br/>device selection, programming operations, status, and download and<br/>upload protocols, etc. The original device selection topology was kept<br/>such that each device in the memory map appears as a separate<br/>selectable device to the algorithm.

The command lines are gathered by the SCI in interrupt mode, which buffers incoming characters until a  $\langle cr \rangle$  (\$0D) is received. A system flag is then set which signals the command parser to examine the buffer for valid command/parameter combinations.

<XON>/<XOFF> handshaking is also supported to control ASCII upload/download transfers. Handshaking is important because the programming sequence can take up to several milliseconds and the buffer must be frozen in that time to ensure data integrity until all the data has been transferred to the target device.

The heart of the data transfer system was adapted from the BUFFALO S-record transfer code. This code has been modified to support buffered data, as well as the xmodem transfer protocol. The xmodem transfer protocol (aka the Christiensen Protocol) transfers Freescale S-record data in 128-byte blocks and features flow control and error detection with retries. While S-records feature a line-by-line checksum which can be used to validate the data integrity of the line, typical ASCII transfer protocols do not provide for error detection or retries so the only recourse for a checksum error at the target is to discard the entire line and continue to the next line which requires another pass to fully program the device.

A checksum error in the xmodem protocol causes the data block to be resent (up to a pre-determined maximum retry count). In this way, the

system can not only detect errors, but also can recover from them. If the original data is error free, there is a measure of assurance that xmodem will transfer the data so that it is received in its entirety.

Two subroutines are used to access the target devices:

- REDbyt
- PGMbyt

These routines use the (X) index register and a bank register to point to a physical device address which is provided with the upload data from the host using Freescale S28 or S37 record formats. The BANK command allows manual selection of 64-K segments so that the Freescale S19 format can be used. REDbyt and PGMbyt call the address parser subroutine addrFLA to resolve the bank select address bits for the selected device and present them accordingly. The index register is then converted to an MCU logical address which points to the desired physical address. Once this procedure is complete, the MCU can present indexed read/write sequences to the target device to perform the desired operation.

A personality system is used which allows the device to be defined for the programming algorithm. This is important because the algorithm must distinguish between FLASH, NVRAM, shadowRAM, and EEPROM technologies. While most devices allow data simply to be read in programming mode, some require a pre-command before data can be presented to the device. To accomplish this, each device in the system has its own read/write subroutine which handles any required command sequences.

![](_page_14_Picture_0.jpeg)

## **Retrofit Example**

![](_page_14_Figure_4.jpeg)

### Figure 4. EPROM-Based Design Example

**Figure 4** illustrates the block diagram of an MCU-based system that uses EPROM memories for code and data storage. It is desired that this system be converted so that FLASH devices may be used, but only minimal hardware modifications are allowed due to cost constraints. A

32 K x 8 EPROM (U3) is the primary code memory and is located at the top of the memory map as shown in **Figure 5**. A 64 K x 8 EPROM (U4) is used to hold secondary code and data for the application. Since these two devices would exceed the available MCU address space, U4 is bank switched in a 16-K window with provisions to allow expansion to a 128 K x 8 device. Since only three bank select lines are required, they are derived directly from MCU I/O pins.

![](_page_15_Figure_4.jpeg)

Figure 5. Retrofit Example System Memory Map

The primary difference between this system and the SBC presented earlier lies in the fact the U3 kernal memory is only accessible via a single window in the memory map. Furthermore, several MCU resources also occupy this memory space during bootstrap mode, including the MCU EPROM, which provides serious hurdles to implementing the FLASH system.

![](_page_16_Picture_0.jpeg)

The bootROM and EEPROM conflicts can be addressed in firmware. For the EEPROM, this part of the FLASH array will never be accessible anyway, so no system code or data will ever need to be written to this area. For reliability reasons, it is necessary to write those FLASH locations to \$00 during the FLASH pre-erase cycle. Since the EEPROM cannot be turned off without an MCU reset, the only choice is for the firmware to blind write these locations. This can be accomplished because the M68HC11 Family drives external address and data during writes to internal resources. This allows FLASH programming commands to be written to the device, but prevents reads from the FLASH because the internal resource takes priority. While not optimal, this will at least serve to improve reliability by reducing over-erase stress on these memory cells.

Since the bootROM overlaps memory that is accessible in the MCU's normal mode, it is desirable that the system be able to read/write/verify these memory locations. This can be done by briefly turning off the bootROM using the RBOOT bit in the HPRIO register. It is important to suspend all interrupts for this process and that ~XIRQ must not be enabled. This is because the bootROM holds the interrupt vectors for the bootstrap mode and an interrupt which occurs while the bootROM is off will result in a false vector fetch, causing unrecoverable system disruption. Since the FLASH algorithm used here depends on interrupts, they can not be disabled entirely, but instead must be disabled only during the time that the bootROM is off.

The MCU EPROM conflict is more difficult to overcome as the EPROM cannot be turned off and on like the bootROM (a reset is required). Since it covers a large and important area of the memory map, it also can not be ignored, and blind programming is not acceptable as there is no way to ensure data integrity without overstressing the FLASH core. The only viable alternative is to use the external RAM (U5) to hold the FLASH algorithm so that the MCU EPROM can be turned off.

Normally, this would offer another difficulty due to the fact that the RAM at U5 is an NVRAM and holds vital system data that would have to be saved and restored by the host system. In this case, however, the RAM at U5 is a shadow RAM which means that this device keeps non-volatile data in a shadow EEPROM array separate from the SRAM array (all on

the same die). Special read sequences initiate store-and-retrieval operations which copy data between the U5 SRAM and EEPROM. This means that the FLASH algorithm can be copied into the SRAM array without disturbing the shadow EEPROM data which eliminates the need for the host to save and restore the RAM data. When the programming operation is complete, the original U5 data is restored automatically on system power-up.

Because the FLASH algorithm must be copied to SRAM, an additional step is required in the reset sequence.

- Reset in bootstrap mode
- Host commands EPROM on (set ROMON bit in CONFIG)
- Reset again (still in bootstrap mode)
- Copy algorithm to U5 RAM
- Turn EPROM off; clear ROMON bit in CONFIG
- Reset again (still in bootstrap mode)
- Perform programming operations
- Reset in normal mode (cycle target system power to restore U5 data)

At this point, the system behaves the same as described under the SBC system. The host may read, write, and erase the U3 and U4 devices as needed using the commands provided by the FLASH algorithm operating in the U5 RAM.

![](_page_18_Picture_0.jpeg)

Retrofit Hardware Changes The required target hardware changes to the retrofit system are:

- Expand U3 and U4 sockets to 32 pins and connect ~WE and  $V_{\text{PP}}$  signals.
- Add programming mode connector. This system already has an external serial port connection, so the mode connector only requires the MODA/B, RESET, and V<sub>PP</sub> signals. (+5 V is also added to support the programming mode interface.)

As is readily apparent, the hardware changes are minimal. The costs associated with these changes will focus on the minimal engineering effort to modify the PCB layout and the re-tooling costs from the PCB vendor. In this case, the increased component costs are less than 0.5 percent of the finished product cost.

While the modifications to the target system are a relatively small part of the overall product cost, the addition of the programming adapter results in a noticeable cost increase. Even so, these costs can be minimized as the design of Figure 6 illustrates. This is a simple example of a host interface card which uses a simple toggle switch to select the mode and enable V<sub>PP</sub> and an inexpensive DC-DC converter to develop the FLASH V<sub>PP</sub> voltage.

**NOTE:** The serial loop-back switch is not present in this module. Since cost is an issue, the loop-back switch was omitted, which requires the host to send the break signal or ASCII-NULL after each reset.

![](_page_19_Picture_0.jpeg)

**Application Note** 

![](_page_19_Figure_3.jpeg)

Figure 6. Simplified Host Programming Adapter Schematic

**Freescale Semiconductor, Inc.** 

![](_page_20_Picture_0.jpeg)

While this retrofit example illustrates a means to implementing FLASH on an existing design with minimal hardware changes, some compromises are necessary to meet that end. Some systems may not have a RAM array available as temporary algorithm storage. In those that do, it may not be feasible to use a shadow RAM because these devices are available only from a limited number of suppliers. For these situations, it may be necessary to implement the techniques described for the SBC design which would require additional hardware modifications. These trade-offs must be examined by the system designer to determine the best and most cost-effective route to upgrade their system.

## Conclusion

The systems and techniques described in this application note demonstrate the feasibility of implementing an external FLASH memory system in a M68HC11 design with minimal hardware/firmware overhead. Since the FLASH support is virtually transparent to the MCU normal mode, it requires a minimum of effort on the part of firmware designers to avoid resource conflicts. In addition, firmware and data updates are straightforward and can be accomplished using a simple terminal program running on the host PC.

![](_page_21_Picture_0.jpeg)

## **Program Listings**

#### Host Interface Reset Controller — Listing 1

"6805" 1 PROC 2 3 5 ; flash mode controller for the FFlash programming system. 6 7 ; Using 4 buttons, this system controls the reset, moda/b, 8 ; vpp, and communications switching. 9 ; 10 ; RESET(PA3/~IRQ): when a target reset is sensed: 11 ;NORM: no action 12 ; PGM: for 300 ms after ~reset is released, close 13 the SHORT connection to feed back the MCU ; 14 break signal. Use the ~irg to detect the ; 15 falling edge of ~reset. ; 16 ; 17 VPP(PA0): ; 18 PGM: This switch toggles the ~vppen signal (PB1). ; 19 ; NORM: switch has no effect. 20 ; 21 ; MODE(PA1): Toggles the MODA/B signal (PB0) between logic 0 22 ; and hi-z. Any activity on this input also disables 23 Vpp. MODA/B = 0 is PGM mode...MODA/B = hi-z is NORM ; 24 mode. ; 25 ; 26 MONITOR(PA2): ; 27 PGM: this switch has no effect ; 28 NORM: This switch cycles through three states: ; 29 ; mode SHORT txm OPEN rxm 30 I/0: 1 1 0 0 ; 31 0 1 0 0 mon TX: 32 0 0 0 1 mon RX: 33 PGM reset: 1 1 0 0 34 PGM mode: 0 1 1 0 (same as I/O) ; 35 36 I/O is for normal communications with the target. ; 37 mon TX monitors info originating FROM target. ; 38 mon RX monitors info directed TO target. ; 39 The state status is saved so that after entering PGM 40 mode and returning to NORM mode, the state setting is 41 restored to the last selected. ; 42 ; 43 ; POR:

![](_page_22_Picture_0.jpeg)

## Freescale Semiconductor, Inc.

| 44  | ;    | On powe    | er-up,        | the port initial                    | ization i         | s as follows: *              |
|-----|------|------------|---------------|-------------------------------------|-------------------|------------------------------|
| 45  | ;    | PB0 = :    | inputno       | pull-downs                          |                   | ×                            |
| 46  | ;    | PB1 = 1    | 1             |                                     |                   | ×                            |
| 47  | ;    | pulldov    | wn reg        |                                     |                   | *                            |
| 48  | ;    | PA0 = 2    | input         | 0                                   |                   | ×                            |
| 49  | ;    | PA1 = 2    | input         | 0                                   |                   | ×                            |
| 50  | ;    | PA2 = 2    | input         | 0                                   |                   | ×                            |
| 51  | ;    | PA3 = :    | input         | 1                                   |                   | ×                            |
| 52  | ;    | PA4 = 0    | C             | n/a                                 | (= 0)             | *                            |
| 53  | ;    | PA5 = 2    | 1             | n/a                                 | (= 0)             | ×                            |
| 54  | ;    | PA6 = 1    | 1             | n/a                                 | (= 0)             | ×                            |
| 55  | ;    | PA7 = 0    | C             | n/a                                 | (= 0)             | ×                            |
| 56  | ;    |            |               |                                     |                   | ×                            |
| 57  | ;**  | *******    | * * * * * * * | * * * * * * * * * * * * * * * * * * | * * * * * * * * * | *************************jmh |
| 58  |      |            |               |                                     |                   |                              |
| 59  |      | ;Thu, I    | Dec 5,        | 1996, 11:14                         |                   |                              |
| 60  |      |            |               |                                     |                   |                              |
| 61  |      |            | INCLUD        | E "a.equ"                           |                   |                              |
| 188 |      | ;          | ORG           | MOR                                 |                   |                              |
| 189 |      | ;          | FCB           | LEVEL   LVIE   SWAIT                | ; mask op         | otion register settings      |
| 190 |      |            |               |                                     |                   |                              |
| 191 |      |            | ORG           | ROM                                 |                   |                              |
| 192 |      |            |               |                                     |                   |                              |
| 193 | 0200 | 9C ENTRY H | RSP           |                                     |                   | ; reset stack                |
| 194 | 0201 | A608       | LDA           | #restarg                            |                   | ; set the pull-downs         |
| 195 | 0203 | В710       | STA           | PDRA                                |                   |                              |
| 196 | 0205 | A601       | LDA           | #modab                              |                   |                              |
| 197 | 0207 | В711       | STA           | PDRB                                |                   |                              |
| 198 | 0209 | A602       | LDA           | #vppen                              |                   | ; set DDRs                   |
| 199 | 020B | в701       | STA           | IDRB                                |                   |                              |
| 200 | 020D | в705       | STA           | IDDRB                               |                   |                              |
| 201 | 020F | A660       | LDA           | #OPEN txm                           |                   |                              |
| 202 | 0211 | в700       | STA           | IDRA                                |                   |                              |
| 203 | 0213 | B7E2       | STA           | MONREG                              |                   | ; init monitor register      |
| 204 | 0215 | A6F0       | LDA           | #rxm OPEN txm SH                    | IORT              |                              |
| 205 | 0217 | в704       | STA           | IDDRA                               |                   |                              |
| 206 | 0219 | A603       | LDA           | #RT1 RT0                            |                   | ; set the RTI timer, 65.5ms, |
|     |      |            |               | ·                                   |                   | ; NO RTI                     |
| 207 | 021B | в708       | STA           | TSCR                                |                   |                              |
| 208 | 021D | A682       | LDA           | #IRQE IRQR                          |                   | ; enable irq                 |
| 209 | 021F | B70A       | STA           | ISCR                                |                   |                              |
| 210 | 0221 | 9A         | CLI           |                                     |                   | ; enable ints                |
| 211 |      |            |               |                                     |                   |                              |
| 212 | 0222 | 01050C TOP | BRCLR         | MODAB,IDDRB,:01                     |                   | ; skip vpp if normal mode    |
| 213 | 0225 | AD52       | BSR           | VPPSW                               |                   |                              |
| 214 | 0227 | 2408       | BCC           | :01                                 |                   | ; no switch                  |
| 215 | 0229 | B601       | LDA           | IDRB                                |                   |                              |
| 216 | 022B | A802       | EOR           | #vppen                              |                   | ; toggle VPP                 |
| 217 | 022D | A4FE       | ND            | #~modab                             |                   | ; always leave this one = 0  |
| 218 | 022F | в701       | STA           | IDRB                                |                   |                              |
|     |      |            |               |                                     |                   |                              |

![](_page_23_Picture_0.jpeg)

## **Application Note**

| 219        | 0231         | AD57 :01     | BSR    | MODSW                       |                               |
|------------|--------------|--------------|--------|-----------------------------|-------------------------------|
| 220        | 0233         | 2421         | BCC    | :02                         | ; no mode switch              |
| 221        | 0235         | A602         | LDA    | #vppen                      | ; disable VPP                 |
| 222        | 0237         | В701         | STA    | IDRB                        |                               |
| 223        | 0239         | B605         | LDA    | IDDRB                       | ; toggle mode                 |
| 224        | 023B         | A801         | EOR    | #modab                      |                               |
| 225        | 023D         | в705         | STA    | IDDRB                       |                               |
| 226        | 023F         | 000506       | BRSET  | MODAB, IDDRB, dopgmrst      | ;skip mon restore if PGM mode |
| 227        | 0242         | B6E2         | LDA    | MONREG                      | ; restore monitor setting     |
| 228        | 0244         | в700         | STA    | IDRA                        | 5                             |
| 229        | 0246         | 200E         | BRA    | :02                         |                               |
| 230        |              |              |        |                             |                               |
| 231        | 0248         | dopamrs      | st     |                             |                               |
| 232        | 0248         | 1700         | BCLR   | RESTARG, IDRA               |                               |
| 233        | 024A         | 1604         | BSET   | RESTARG, IDDRA              | ; force retarg low to         |
| 234        | 024C         | 9D           | NOP    |                             | ;autotrip the target reset    |
| 235        | 024D         | 9D           | NOP    |                             | ,                             |
| 236        | 024E         | 9D           | NOP    |                             |                               |
| 237        | 021E<br>024F | ענ<br>ז תפ   | NOP    |                             |                               |
| 238        | 0250         | 9D           | NOP    |                             |                               |
| 230        | 0250         | 9D           | NOD    |                             |                               |
| 240        | 0252         | 2660         |        | #tym ODFN                   | : set I/O mode                |
| 241        | 0252         | R700         | STA    |                             |                               |
| 242        | 0251         | 000509 .02   | BDCLL  | MODAR IDDRR TOD             | : skip mon if DGM mode        |
| 242        | 0250         | יסס יסס יסצ  | DRDEI  | MODAB, IDDIG, IOF           | ; monitor gwitch?             |
| 243        | 0255         | ADJE<br>24CE | DOR    | TOD                         | , monitor switch:             |
| 244        | 0250         | 24CJ         |        |                             | , 110,                        |
| 245        | 0250         | B000<br>D4E0 |        |                             |                               |
| 240        | 0255         | A4F0         |        |                             | ·                             |
| 247        | 0201         | A100<br>A610 |        |                             | ; no,                         |
| 249        | 0205         | A010<br>2007 |        |                             | , Set State 2                 |
| 25U        | 0267         | 200A         | BRA    | doall                       |                               |
| 251<br>252 | 0000         | <b>N</b> 110 | CMD    | U                           |                               |
| 252        | 0269         | AIIU NOTI    | CMP    | #rxm                        | ; is state 2?                 |
| 253        | 026B         | 2604         | BNE    | not2                        | ; no,                         |
| 254        | 0260         | A640         | LDA    | #txm                        | ; set state 3                 |
| 255        | 026F         | 2002         | BRA    | doall                       |                               |
| 256        | 0001         |              |        |                             |                               |
| 25/<br>250 | UZ/I         | not2         |        |                             |                               |
| 258        |              | <i>i</i>     | CMP #t | .xm                         | ; is state 3?                 |
| 259        | 0071         | i            | BNE no |                             | ; no,                         |
| 260        | 0271         | A660         | LDA    | #txm OPEN                   | ; set state 1                 |
| 261        | 0273         | B700 doall   | STA    | IDRA                        |                               |
| 262        | 0275         | B7E2         | STA    | MONREG                      |                               |
| 263        | 0277         | 20A9         | BRA    | TOP                         |                               |
| 264        |              |              | ;      |                             |                               |
| 265        |              |              | ;      |                             |                               |
| 266        |              |              | ; the  | xxxSW routines test for swi | tcn closure (with debounce).  |
| 267        |              |              | ; On r | return, C = 0 no switch C   | 2 = 1, switch cycled.         |
| 268        |              |              |        |                             |                               |
| 269        | 0279         | 01000C       | VPPSW  | BRCLR vPPON, IDRA,:04       |                               |
| 270        | 027C         | AD2A         |        | BSR dly20ms                 |                               |

![](_page_24_Picture_0.jpeg)

Application Note Program Listings

| 0        |
|----------|
|          |
|          |
|          |
|          |
|          |
| 0        |
|          |
| 0        |
|          |
|          |
| Т        |
| Ē        |
|          |
| 0        |
| 0        |
|          |
|          |
|          |
| 0        |
|          |
|          |
|          |
| <u> </u> |
|          |
|          |
| U        |
| Ū        |
| Ä        |
| ¥.       |
| U        |
|          |
| L.       |

| 271    | 027E | 010007 |         | BRCLF | R vPPON,IDE | RA,:04                          |
|--------|------|--------|---------|-------|-------------|---------------------------------|
| 272    | 0281 | 0000FD | :03     | BRSET | ſ           | vPPON, IDRA,:03                 |
| 273    | 0284 | AD22   |         | BSR   |             | dly20ms                         |
| 274    | 0286 | 99     |         | SEC   |             |                                 |
| 275    | 0287 | 81     |         | RTS   |             |                                 |
| 276    |      |        |         |       |             |                                 |
| 277    | 0288 | 98     | :04     | CLC   |             |                                 |
| 278    | 0289 | 81     |         | RTS   |             |                                 |
| 279    |      |        |         |       |             |                                 |
| 280    | 028A | 0300FB | MODSW   | BRCLE | ર           | MODE, IDRA, :04                 |
| 281    | 028D | AD19   |         | BSR   |             | dly20ms                         |
| 282    | 028F | 0300F6 |         | BRCLE | ર           | MODE, IDRA, :04                 |
| 283    | 0292 | 0200FD | :05     | BRSET | ſ           | MODE, IDRA, :05                 |
| 284    | 0295 | AD11   |         | BSR   |             | dly20ms                         |
| 285    | 0297 | 99     |         | SEC   |             |                                 |
| 286    | 0298 | 81     |         | RTS   |             |                                 |
| 287    |      |        |         |       |             |                                 |
| 288    | 0299 | 0500EC | MONSW   | BRCLF | ર           | MONITOR, IDRA,:04               |
| 289    | 029C | AD0A   |         | BSR   |             | dly20ms                         |
| 290    | 029E | 0500E7 |         | BRCLF | ર           | MONITOR, IDRA, :04              |
| 291    | 02A1 | 0400FD | :06     | BRSET | ſ           | MONITOR, IDRA, :06              |
| 292    | 02A4 | AD02   |         | BSR   |             | dly20ms                         |
| 293    | 02A6 | 99     |         | SEC   |             | -                               |
| 294    | 02A7 | 81     |         | RTS   |             |                                 |
| 295    |      |        |         | ;     |             |                                 |
| 296    |      |        |         | ;     |             |                                 |
| 297    |      |        |         | ; dly | vlms does a | a simple dex loop to delay 20ms |
| 298    |      |        |         | -     |             |                                 |
| 299    | 02A8 | A614   | dly20ms | LDA   | #20         |                                 |
| 300    | 02AA | AD04   | :07     | BSR   | dly1ms      |                                 |
| 301    | 02AC | 4A     |         | DECA  | -           |                                 |
| 302    | 02AD | 26FB   |         | BNE   | :07         |                                 |
| 303    | 02AF | 81     |         | RTS   |             |                                 |
| 304    |      |        |         |       |             |                                 |
| 305    | 02B0 | АЕАб   | dly1ms  | LDX   | #166        | ; set count for 1ms (@2mhz      |
| 306    | 02B2 | 9D     | :08     | NOP   |             | ; delay 12~ per count           |
| 307    | 02B3 | 9D     |         | NOP   |             |                                 |
| 308    | 02B4 | 2046   |         | BRA   | newdly1     | ; patch in a fix for ms1val     |
| 309    |      |        |         |       | -           | -                               |
| 310    |      |        | ;       | BRA   | :09         |                                 |
| 311    | 02B6 | 5A     | :09     | DECX  |             |                                 |
| 312    | 02B7 | 26F9   |         | BNE   | :08         |                                 |
| 313    | 02B9 | 81     |         | RTS   |             |                                 |
| 314    |      |        |         | ;     |             |                                 |
| 315    |      |        |         | ;     |             |                                 |
| 316    |      |        |         | ; RTI | II does the | e ~~1 sec timer.                |
| 317    |      |        |         |       |             |                                 |
| 318    | 02BA | B608   | RTII    | LDA   | TSCR        |                                 |
| 319    | 02BC | AA04   |         | ORA   | #RTIFR      |                                 |
| 320    | 02BE | B708   |         | STA   | TSCR        | ; reset flag                    |
| 321    | 02C0 | 3AE0   |         | DEC   | prescaler   | . 10000 1143                    |
|        |      |        |         |       | -           |                                 |
| A N 14 | 750  |        |         |       |             |                                 |
|        | 100  |        |         |       |             |                                 |

![](_page_25_Picture_0.jpeg)

**Application Note** 

| 322<br>323 | 02C2<br>02C4 | 260B<br>A60F |       | BNE<br>LDA | :10<br>#psval          | ; | not sec yet,              |
|------------|--------------|--------------|-------|------------|------------------------|---|---------------------------|
| 324        | 02C6         | B7E0         |       | STA        | prescaler              |   |                           |
| 325        | 02C8         | B6E1         |       | LDA        | TIMER1                 |   |                           |
| 326        | 02CA         | 2703         |       | BEQ        | :10                    | ; | no value to decrement,    |
| 327        | 02CC         | 4A           |       | DECA       |                        |   |                           |
| 328        | 02CD         | B7E1         |       | STA        | TIMER1                 | ; | new timer value           |
| 329        | 02CF         | 80           | :10   | RTI        |                        |   |                           |
| 330        |              |              |       | ;          |                        |   |                           |
| 331        |              |              |       | ;          |                        |   |                           |
| 332        |              |              |       | ; ope      | erate the reset detect | a | lg.                       |
| 333        |              |              |       |            |                        |   |                           |
| 334        | 02D0         | 010504       | IRQI  | BRCLF      | R MODAB, IDDRB, :11    | ; | skip reset if normal mode |
| 335        | 02D3         | A6C0         |       | LDA        | #SHORT txm             |   |                           |
| 336        | 02D5         | в700         |       | STA        | IDRA                   |   |                           |
| 337        | 02D7         | CD02A8       | :11   | JSR        | dly20ms                |   |                           |
| 338        | 02DA         | 1704         |       | BCLR       | RESTARG, IDDRA         | ; | force reset sw = input    |
| 339        | 02DC         | 0700FD       | :12   | BRCLF      | R RESTARG, IDRA, :12   |   |                           |
| 340        | 02DF         | 01050F       |       | BRCLF      | RMODAB,IDDRB,nopgm     | ; | skip reset if normal mode |
| 341        | 02E2         | A61E         |       | LDA        | #30                    | ; | delay 600ms               |
| 342        | 02E4         | B7E3         |       | STA        | TEMP                   |   |                           |
| 343        | 02E6         | CD02A8       | :13   | JSR        | dly20ms                |   |                           |
| 344        | 02E9         | 3AE3         |       | DEC        | TEMP                   |   |                           |
| 345        | 02EB         | 26F9         |       | BNE        | :13                    |   |                           |
| 346        | 02ED         | A660         |       | LDA        | #OPEN txm              |   |                           |
| 347        | 02EF         | в700         |       | STA        | IDRA                   |   |                           |
| 348        | 02F1         | CD02A8       | nopgm | JSR        | dly20ms                |   |                           |
| 349        | 02F4         | A682         |       | LDA        | #IRQE IRQR             |   |                           |
| 350        | 02F6         | B70A         |       | STA        | ISCR                   |   |                           |
| 351        | 02F8         | 80           |       | RTI        |                        |   |                           |

![](_page_26_Picture_0.jpeg)

#### FPGA HDL Listing — Listing 2

| ;*****  | ******               | *****                           | ******************                      |
|---------|----------------------|---------------------------------|-----------------------------------------|
| TITLE   | 'HCll ba<br>J indexe | nk expander<br>er.PDS           |                                         |
| REVISIO | DN 1.1               |                                 |                                         |
| AUTHOR  | Joe Haa              | IS                              |                                         |
| COMPANY | [<br>                |                                 |                                         |
| DATE 17 | / Novemb             | er 1996                         |                                         |
| ;       | DATE 12              | 2 November 1996                 | - Creation                              |
| ;       | Tue, De              | ec 17, 1996, 14                 | :42                                     |
| ;       | Removed              | 1 fLAT.SETF and                 | fLAT.RSTF equations (were invalid)      |
| ;       | changed              | l lefck to acti                 | ve hi                                   |
| ;       | design               | verified in-ci                  | rcuit by logic analyzer                 |
| CHIP k  | oank_log             | icll MACH215                    |                                         |
| ;*****  | ******               | ****                            | *********                               |
| ;PIN    | 1                    | qnd                             |                                         |
| PIN     | 72                   | D[50]                           | PAIR fLAT[50]                           |
| PIN     | 10                   | A[11]                           | COMB                                    |
| PTN     | 11                   | A[10]                           | COMB                                    |
| ; PTN   | 12                   | and                             |                                         |
| PTN     | 13                   | A[9]                            | COMB                                    |
| PTN     | 15                   | A[15]                           | COMB                                    |
| PTN     | 14                   | A[14]                           | COMB                                    |
| PTN     | 9                    | A[13]                           | COMB                                    |
| PIN     | 8                    | A[12]                           | COMB                                    |
| PIN     | 2116                 | rA[1813]                        | LAT                                     |
| ;PIN    | 22                   | VCC                             |                                         |
| ;PIN    | 23                   | and                             |                                         |
| PIN     | 24                   | /rcs                            | COMB                                    |
| PIN     | 25                   | /acs                            | COMB                                    |
| PIN     | 26                   | lea                             | COMB                                    |
| PIN     | 27                   | /rec                            | COMB                                    |
| PIN     | 28                   | /iocs0                          | COMB                                    |
| PIN     | 29                   | /iocs1                          | COMB                                    |
| PIN     | 30                   | /WR                             | COMB                                    |
| PIN     | 31                   | /RWO                            | COMB                                    |
| PIN     | 32                   | Е                               | COMB                                    |
| PIN     | 33                   | RW                              | COMB                                    |
| ;PIN    | 34                   | gnd                             |                                         |
| PIN     | 35                   | lefck                           | COMB                                    |
| PI      | 36                   | lef                             | COMB                                    |
| PIN     | 4237                 | fA[1813]                        | COMB                                    |
| PIN     | 43                   | /fcs                            | COMB                                    |
| ;PIN    | 44                   | VCC                             |                                         |
|         |                      |                                 |                                         |
| NODE    | ?                    | fLAT[50]                        | LAT                                     |
| NODE    | ?                    | DOE                             | СОМВ                                    |
| ;*****  | ******               | * * * * * * * * * * * * * * * * | *************************************** |
| EQUATIO | ONS                  |                                 |                                         |
|         | 5.7.7                |                                 |                                         |
| KWO = F | לש<br>זייז + די      |                                 |                                         |
| WK = /H | KW ^ E               |                                 |                                         |
|         |                      |                                 |                                         |
| AN1753  |                      |                                 |                                         |

![](_page_27_Picture_0.jpeg)

```
RWO.TRST = VCC
WR.TRST = VCC
D[5..0] = (/A[15] * /A[14] * /A[13] * /A[12] * /A[11] * /A[10] * A[9] * E * RW) *
fLAT[5..0] +
         (/A[15] * /A[14] * /A[13] * /A[12] * /A[11] * A[10] * /A[9] * E * RW) *
rA[18..13]
DOE = (/A[15] * /A[14] * /A[13] * /A[12] * /A[11] * /A[10] * A[9]) +
      (/A[15] * /A[14] * /A[13] * /A[12] * /A[11] * A[10] * /A[9])
D[5..0].TRST = DOE * E * RW
fLAT[5...0] = D[5...0]
fLAT[5..0].CLKF = lefck
lef = /A[15] * /A[14] * /A[13] * /A[12] * /A[11] * /A[10] * A[9] * E * /RW
lef.TRST = VCC
fA[18..15] = A[15] + fLAT[5..2]
fA[14] = (A[14] * A[15]) + (/A[15] * fLAT[1])
fA[13] = (A[13] * A[15]) + (/A[15] * fLAT[0])
fA[18..13].TRST = VCC
fcs = A[15] * E + /A[15] * /A[14] * A[13] * E
fcs.TRST = VCC
rA[18..13] = D[5..0]
rA[18..13].CLKF = /A[15] * /A[14] * /A[13] * /A[12] * /A[11] * A[10] * /A[9] * E * /RW
rA[18..13].SETF = gnd
rA[18..13].RSTF = gnd
rA[18..13].TRST = VCC
rcs = /A[15] * A[14] * /A[13] * E
rcs.TRST = VCC
acs = /A[15] * A[14] * A[13] * E
acs.TRST = VCC
iocs0 = /A[15] * /A[14] * /A[13] * /A[12] * A[11] * A[10] * /A[9] * E
iocs1 = /A[15] * /A[14] * /A[13] * /A[12] * A[11] * A[10] * A[9] * E
iocs0.TRST = VCC
iocs1.TRST = VCC
lea = /A[15] * /A[14] * /A[13] * /A[12] * /A[11] * A[10] * A[9] * E * /RW
rec = /A[15] * /A[14] * /A[13] * /A[12] * A[11] * /A[10] * /A[9]* E * RW
lea.TRST = VCC
rec.TRST = VCC
```

![](_page_28_Picture_0.jpeg)

### FLASH Algorithm Listing — Listing 3

|           |           | PROC                           | с "68нС11'                            | n                                       |
|-----------|-----------|--------------------------------|---------------------------------------|-----------------------------------------|
| 2 =       | FFFF      | ROMON EQU                      | ~0                                    | ; development trap                      |
| 3         |           | ;                              |                                       |                                         |
| 4         |           | ; * * * * * * * * * * *        | *****                                 | * * * * * * * * * * * * * * * * * * * * |
| 5         |           | ;* FF-FLAS                     | SH programmer firm                    | ware for 68HC711E9 *                    |
| 6         |           | :* Writter                     | by: Joseph M Ha                       | as Originated Feb-05-93 *               |
| 5<br>7    |           | :* Revisio                     | n MFZ-11 Retrofit                     | $T_{11} - 30 - 95$                      |
| ,<br>8    |           | **********                     | *****                                 | ****                                    |
| 0         |           |                                |                                       |                                         |
| 9<br>10   |           | /<br>:**** Dorrigi             | on II- at own ****                    |                                         |
| 10        |           | , """ Revisi                   | on History """"                       | a a a a a multi manabit dani a          |
| 12        |           | ;in 64K bank                   | command to allow                      | access to multi-megable device          |
| 13        |           | ;u3hilim nov                   | / stores a1812.                       | all references to A16 now deal          |
|           |           | ;with a181                     | .6                                    |                                         |
| 14        |           | ;eflas now h                   | andles multi-mega                     | bit devicestechnically                  |
| 15        |           | ; abandoned (                  | 13n1 and usn1                         |                                         |
| 16        |           | ;                              | orr commands                          |                                         |
| 17        |           | ,<br>; * * * * * * * * * * * * | *****                                 | * * * * * * * * * * * * * * * * * * * * |
| 18        |           | ;* END OF                      | REVISION HISTORY                      | *                                       |
| 19        |           | ;* Last re                     | elease date: Fri                      | , Jun 30, 1995, 16:05 *                 |
| 20        |           | ; * * * * * * * * * * *        | * * * * * * * * * * * * * * * * * * * | * * * * * * * * * * * * * * * * * * *   |
| 1443      |           | ;                              |                                       |                                         |
| 1444      |           | ;                              |                                       |                                         |
| 1445      |           | ; REDL                         | yt qets byte in (I                    | 3) from (X) addr of target device       |
| 1446      |           |                                | 1 - 5                                 | , , , , , , , , , , , , , , , , , , , , |
| 1447 D742 |           | REDbyt                         |                                       |                                         |
| 1448 D742 | 2 3C      | PSHX                           |                                       |                                         |
| 1449 D743 | 8 8D07    | BSR                            | bvtSET                                | ; set addr                              |
| 1450 D745 | BDD81D    | JSR                            | adrFLA                                |                                         |
| 1451 D748 | E600      | LDAB                           | 0.X                                   | ; get EPROM                             |
| 1452 D74A | 38        |                                | 0,11                                  |                                         |
| 1453 D74F | 2 20      | RTS                            |                                       |                                         |
| 1454      |           | ;                              |                                       |                                         |
| 1455      |           | ;                              |                                       |                                         |
| 1456      |           | ,<br>; hvts                    | SET sets the bank                     | addr bits for the current device        |
| 1457      |           | / Dycc                         | DI SCES CHE Dank                      | addi bits for the carrent acvice        |
| 1458 D740 | r         | byt SFT                        |                                       | : check devitym                         |
| 1459 D740 | -<br>D630 | LUVB                           | DFVwin                                | / check deveyp                          |
| 1460 D74C | 2 D039    | CMDR                           | #II/win                               |                                         |
| 1460 D746 |           | CMPD                           | #U4WIII                               |                                         |
| 1462 1462 | 2000      | DINE                           | DyLSU                                 |                                         |
| 1463 D752 | 2 9C17    | bytSU4CPX                      | HiLim+1                               | ; use hilim for address limit<br>; test |
| 1464 D754 | 2302      | BLS                            | :64                                   | ; yes,                                  |
| 1465 D756 | 5 0D      | byter SEC                      | -                                     | ; set address err                       |
| 1466 D757 | 7 39      | RTS                            |                                       |                                         |
| 1467      |           |                                |                                       |                                         |

#### AN1753

![](_page_29_Picture_0.jpeg)

## **Application Note**

| 1468 D758 | 9C14         | :64   | CPX       | LoLim+1            | ; is out of flash?             |
|-----------|--------------|-------|-----------|--------------------|--------------------------------|
| 1469 D75A | 25FA         |       | BLO       | byter              | ; yes,                         |
| 1470 D75C | 0C           |       | CLC       |                    |                                |
| 1471 D75D | 39           |       | RTS       |                    |                                |
| 1472      |              |       |           |                    |                                |
| 1473 D75E |              | bytSU | J         |                    | ; set SPBNK bits A unused on   |
|           |              |       |           |                    | ; entry                        |
| 1474 D75E | 3C           |       | PSHX      |                    |                                |
| 1475 D75F | C120         |       | CMPB      | #U3win             | ; is U3?                       |
| 1476 D761 | 2716         |       | BEQ       | :65                | ; yes,                         |
| 1477 D763 | 8F           |       | XGDX      |                    | ; DO MEZ-11 U5 BANKS           |
| 1478 D764 | 84E0         |       | ANDA      | #%11100000         | ; mask hi addrs                |
| 1479 D766 | 44           |       | LSRA      |                    |                                |
| 1480 D767 | 44           |       | LSRA      |                    |                                |
| 1481 D768 | 44           |       | LSRA      |                    |                                |
| 1482 D769 | 44           |       | LSRA      |                    |                                |
| 1483 D76A | 44           |       | LSRA      |                    |                                |
| 1484 D76B | D62F         |       | LDAB      | FBANK              |                                |
| 1485 D76D | C4F8         |       | ANDB      | #%11111000         |                                |
| 1486 D76F | 1B           |       | ABA       |                    |                                |
| 1487 D770 | 972F         |       | STAA      | FBANK              |                                |
| 1488 D772 | B70400       |       | STAA      | rbank              |                                |
| 1489 D775 | 8F           |       | XGDX      |                    |                                |
| 1490 D776 | 38           |       | PULX      |                    |                                |
| 1491 D777 | 0C           |       | CLC       |                    |                                |
| 1492 D778 | 39           |       | RTS       |                    |                                |
| 1493      |              |       |           |                    |                                |
| 1494 D779 | 8F           | :65   | XGDX      |                    | ; DO MEZ-11 U3 BANKS           |
| 1495 D77A | 49           |       | ROLA      |                    |                                |
| 1496 D77B | 49           |       | ROLA      |                    |                                |
| 1497 D77C | 49           |       | ROLA      |                    |                                |
| 1498 D77D | 49           |       | ROLA      |                    |                                |
| 1499 D77E | 8407         |       | ANDA      | #%00000111         | ; mask hi addrs                |
| 1500 D780 | D62F         |       | LDAB      | FBANK              |                                |
| 1501 D782 | C438         |       | ANDB      | #%00111000         |                                |
| 1502 D784 | 1B           |       | ABA       |                    |                                |
| 1503 D785 | 972F         |       | STAA      | FBANK              |                                |
| 1504 D787 | В70200       |       | STAA      | fbank              |                                |
| 1505 D78A | 8F           |       | XGDX      |                    |                                |
| 1506 D78B | 38           |       | PULX      |                    |                                |
| 1507 D78C | 0C           |       | CLC       |                    |                                |
| 1508 D78D | 39           |       | RTS       |                    |                                |
| 1509      |              |       | ;         |                    |                                |
| 1510      |              |       | ;         |                    |                                |
| 1511      |              |       | ;PGMbyt p | programs, verifies | byte in (A) at device addr (X) |
| 1512      | 24           | ··    | C 1       | Daim               |                                |
| 1513 D78E | 30           | Verii |           | PSHX               |                                |
| 1514 D78F | BDD81D       |       | JSR       | adrf'LA            |                                |
| 1515 D792 | 0600         |       |           | #ILAPV             | ; Ilash pgm verity             |
| 1510 D794 | E/UU<br>1020 |       | STAB      | υ,Χ                | , sena data to target          |
| DIN UTCT  | TORC         |       | PDHI      |                    |                                |
|           |              |       |           |                    |                                |

AN1753

![](_page_30_Picture_0.jpeg)

| 1518 | D798   | 1838     |       | PULY   |                  |   |                            |
|------|--------|----------|-------|--------|------------------|---|----------------------------|
| 1519 | d79A   | 01       |       | NOP    |                  |   |                            |
| 1520 | D79B   | 01       |       | NOP    |                  |   |                            |
| 1521 | D79C   | 01       |       | NOP    |                  |   |                            |
| 1522 | D79D   | 01       |       | NOP    |                  | ; | ~=5+6+(2*4)=17 = 8.5uS     |
| 1523 | D79E   | E600     |       | LDAB   | 0,X              | ; | get data                   |
| 1524 | D7A0   | 11       |       | CBA    |                  | ; | compare device to orig     |
| 1525 | D7A1   | 38       |       | PULX   |                  |   |                            |
| 1526 | D7A2   | 39       |       | RTS    |                  |   |                            |
| 1527 |        |          |       |        |                  |   |                            |
| 1528 |        |          |       |        |                  |   |                            |
| 1529 | D7A3   | OF       | PGMby | t      | SEI              |   |                            |
| 1530 | D7A4   | 12288004 |       | BRSET  | FLAG2,FFSKIQ,:66 | ; | no \$FF skip allowed       |
| 1531 | D7A8   | 81FF     |       | CMPA   | #\$FF            | ; | do \$FF skip?              |
| 1532 | D7AA   | 272A     |       | BEQ    | FFskip           | ; | yes,                       |
| 1533 | D7AC   | 37       | :66   | PSHB   |                  |   |                            |
| 1534 | D7AD m | L        |       | BOOTOF |                  | ; | turn off bootrom           |
| 1535 | D7AD   | 8D9D     |       | BSR    | bytSET           | ; | test addr                  |
| 1536 | D7AF   | 2408     |       | BCC    | :67              |   |                            |
| 1537 | D7B1   | 142720   |       | BSET   | PGMER, DAE       | ; | address error              |
| 1538 | D7B4   | BDD9F3   |       | JSR    | FLASHon          | ; | flash error led            |
| 1539 | D7B7   | 201C     |       | BRA    | PGMqq            |   |                            |
| 1540 |        |          |       |        |                  |   |                            |
| 1541 | D7B9   |          | :67   |        |                  |   |                            |
| 1542 |        |          | ;     | STAA   | 0,X              | ; | write byte                 |
| 1543 | D7B9   | C619     |       | LDAB   | #25              | ; | set cycle count            |
| 1544 | D7BB   | D721     |       | STAB   | TMP2             |   |                            |
| 1545 | D7BD   | D639     |       | LDAB   | DEVwin           | ; | is U3?                     |
| 1546 | D7BF   | C120     |       | CMPB   | #U3win           |   |                            |
| 1547 | D7C1   | 2704     |       | BEQ    | :68              | ; | yes,                       |
| 1548 | D7C3   | C601     |       | LDAB   | #1               |   |                            |
| 1549 | D7C5   | D721     |       | STAB   | TMP2             | ; | set all others for 1 cycle |
| 1550 | D7C7   | 8D10     | :68   | BSR    | Progl            | ; | prog pulse 1ms             |
| 1551 | D7C9   | 11       |       | CBA    |                  | ; | verify byte                |
| 1552 | D7CA   | 2709     |       | BEQ    | :69              | ; | is ok,                     |
| 1553 | D7CC   | 7A0021   |       | DEC    | TMP2             | ; | next cycle                 |
| 1554 | D7CF   | 26F6     |       | BNE    | :68              | ; | not done,                  |
| 1555 | D7D1 m | L        | PGMer | r      | BOOTON           | ; | turn on bootrom            |
| 1556 | D7D1   | 33       |       | PULB   |                  |   |                            |
| 1557 | D7D2   | 0D       |       | SEC    |                  | ; | set byte err               |
| 1558 | D7D3   | 0 E      |       | CLI    |                  |   |                            |
| 1559 | D7D4   | 39       |       | RTS    |                  |   |                            |
| 1560 |        |          |       |        |                  |   |                            |
| 1561 | D7D5   |          | :69   |        |                  |   |                            |
| 1562 | D7D5   |          | PGMqq |        |                  |   |                            |
| 1563 | D7D5 m | L        |       | BOOTON |                  | ; | turn on bootrom            |
| 1564 | D7D5   | 33       |       | PULB   |                  |   |                            |
| 1565 | D7D6   | 0C       | FFski | pCLC   |                  | ; | ok exit                    |
| 1566 | D7D7   | ΟE       |       | CLI    |                  |   |                            |
| 1567 | D7D8   | 39       |       | RTS    |                  |   |                            |
| 1568 |        |          |       | ;      |                  |   |                            |
|      |        |          |       |        |                  |   |                            |
|      |        |          |       |        |                  |   |                            |

![](_page_31_Picture_0.jpeg)

**Application Note** 

| 1569       |           |       | ;          |                                                          |                                     |
|------------|-----------|-------|------------|----------------------------------------------------------|-------------------------------------|
| 1570       |           |       | ; Progl wr | tes (a) to the d                                         | rurrent device                      |
| 1571       |           |       | , 11091    |                                                          |                                     |
| 1572 D7D0  | 140020    | rog1  | DCET       | ETAC mal                                                 | · got for 1mg                       |
| 1572 D7D9  | 140020 P. | rogr  | IDID       | FLAG, IIISI                                              |                                     |
| 1573 D7DC  | D639 P.   | rogx  | LDAB       |                                                          | , IS 03?                            |
| 15/4 D/DE  | CIZU      |       | CMPB       | #03win                                                   |                                     |
| 1575 D7E0  | 2603      |       | BNE        | :70                                                      | ; no,                               |
| 1576 D7E2  | 8D11      |       | BSR        | wrFLA                                                    |                                     |
| 1577 D7E4  | 39        |       | RTS        |                                                          |                                     |
| 1578       |           |       |            |                                                          |                                     |
| 1579 D7E5  | 8D01 :    | 70    | BSR        | wrRAM                                                    | ; do U4/5                           |
| 1580 D7E7  | 39        |       | RTS        |                                                          |                                     |
| 1581       |           |       | ;          |                                                          |                                     |
| 1582       |           |       | ;          |                                                          |                                     |
| 1583       |           |       | ; wr?? is  | a collection of a                                        | routines that handle the            |
| 1584       |           |       | : programm | ing operations of                                        | f all supported devices             |
| 1585       |           |       | ; dovigos  | that subseribe to                                        | the multi pulse programming         |
| 1505       |           |       | · util not | CIIAC SUBSCIEDE CO                                       | o che muiti puise piogramming       |
| 1500       |           |       | , will rec | $\frac{\operatorname{urn} W}{C} = 0.  \operatorname{sn}$ | Igie write devices (ie., rams)      |
| 1587       |           |       | , return w | (B) = read of f                                          | bgm'd byte (lor verily).            |
| 1588       |           |       | ; A=data,  | x=addr                                                   |                                     |
| 1589       |           |       |            |                                                          |                                     |
| 1590 D7E8  | 3C w:     | rRAM  | PSHX       |                                                          | ; save addr                         |
| 1591 D7E9  | 8D32      |       | BSR        | adrFLA                                                   | ; set write address                 |
| 1592 D7EB  | A700      |       | STAA       | 0,X                                                      | ; send data to target               |
| 1593 D7ED  | D600      |       | LDAB       | \$0                                                      | ; clear bus                         |
| 1594 D7EF  | D647      |       | LDAB       | \$47                                                     |                                     |
| 1595 D7F1  | E600      |       | LDAB       | 0,X                                                      | ; read data for verify              |
| 1596 D7F3  | 38        |       | PULX       |                                                          | ; restore addr                      |
| 1597 D7F4  | 39        |       | RTS        |                                                          |                                     |
| 1598       |           |       |            |                                                          |                                     |
| 1599       |           |       |            |                                                          |                                     |
| 1600 D7F5  | 3C W      | rFT.Δ | рсну       |                                                          | : save addr                         |
| 1601 D7F6  | 8D25      |       | RCD        | adrein                                                   | ; set write address                 |
| 1602 D7F0  | 0020      |       |            |                                                          | , flach new and                     |
| 1002 D7F0  | 040       |       |            | HIIAPG                                                   | , mash pan cuu                      |
| 1603 D7FA  | E/00      |       | SIAB       | υ,Χ                                                      | , send data to target               |
| 1604 D/FC  | 10        |       | -TAB       | 0                                                        |                                     |
| 1605 D7FD  | E700      |       | STAB       | 0,X                                                      | ; send data to target               |
| 1606 D'/FF | C609      |       | LDAB       | #9                                                       | ; delay 12us                        |
| 1607 D801  | 5A :'     | 71    | DECB       |                                                          |                                     |
| 1608 D802  | 26FD      |       | BNE        | :71                                                      |                                     |
| 1609 D804  | C6C0      |       | LDAB       | #flaPV                                                   | ; flash pgm verify                  |
| 1610 D806  | E700      |       | STAB       | 0,X                                                      | ; send data to target               |
| 1611 D808  | 183C      |       | PSHY       |                                                          |                                     |
| 1612 D80A  | 1838      |       | PULY       |                                                          |                                     |
| 1613 D80C  | 01        |       | NOP        |                                                          |                                     |
| 1614 D80D  | 01        |       | NOP        |                                                          |                                     |
| 1615 D80E  | 01        |       | NOP        |                                                          |                                     |
| 1616 D80F  | 01        |       | NOP        |                                                          | = -2 + 6 + (2 + 4) = 17 = 8 5 + 128 |
| 1617 0810  | E600      |       | LDAR       | 0 X                                                      | : aet data                          |
| 1610 DOID  | 20        |       | UII V      |                                                          | , yet uata<br>· rogtoro oddr        |
| 1610 D012  | 20        |       |            |                                                          | , respore addr                      |
| ΤΡΤΑ ΠΑΤ3  | 59        |       | KTS        |                                                          |                                     |

AN1753

![](_page_32_Picture_0.jpeg)

Application Note Program Listings

| 1620      |      |            |                      |                                   |
|-----------|------|------------|----------------------|-----------------------------------|
| 1621 D814 | 3C   | FLwrRM PSI | НХ                   |                                   |
| 1622 D815 | 8D06 | BSR        | adrFLA               | ; set phys address                |
| 1623 D817 | C600 | LDAE       | 3 #flaRM             | ; set for read mem mode           |
| 1624 D819 | E700 | STAE       | 30,X                 | ; send data to target             |
| 1625 D81B | 38   | PULX       | x                    |                                   |
| 1626 D81C | 39   | RTS        |                      |                                   |
| 1627      |      | ;          |                      |                                   |
| 1628      |      | ;          |                      |                                   |
| 1629      |      | ; ad       | drFLA moves addr in  | (X) to window @ selected device:  |
| 1630      |      | ;          | U3: \$2000-3FFF      | %00100000 = U3win                 |
| 1631      |      | ;          | U4: \$6000-7FFF      | %01100000 = U4win                 |
| 1632      |      | ;          | U5: \$4000-5FFF      | %01000000 = U5win                 |
| 1633      |      | ; f        | files that program t | these devices must start @ \$0000 |
|           |      | ; a        | and proceed          |                                   |
| 1634      |      | ; t        | lo \$FFFF.           |                                   |
| 1635      |      |            |                      |                                   |
| 1636 D81D | 36   | adrFLA PSH | A                    |                                   |
| 1637 D81E | 8F   | XGDX       | ζ.                   |                                   |
| 1638 D81F | 841F | ANDA       | A #%00011111         | ; mask hi addrs                   |
| 1639 D821 | 9A39 | ORA        | A DEVwin             | ; combine window mask             |
| 1640 D823 | 8F   | XGDX       | ζ.                   | ; back to X                       |
| 1641 D824 | 32   | PULA       | Ŧ                    |                                   |
| 1642 D825 | 39   | RTS        |                      |                                   |

![](_page_33_Picture_0.jpeg)

## References

Motorola's HC05/08 Website:

http://www.mcu.motsps.com/index.html

![](_page_34_Picture_0.jpeg)

Application Note References

![](_page_35_Picture_0.jpeg)

#### How to Reach Us:

Home Page: www.freescale.com

E-mail: support@freescale.com

#### **USA/Europe or Locations Not Listed:**

Freescale Semiconductor Technical Information Center, CH370 1300 N. Alma School Road Chandler, Arizona 85224 +1-800-521-6274 or +1-480-768-2130 support@freescale.com

#### Europe, Middle East, and Africa:

Freescale Halbleiter Deutschland GmbH Technical Information Center Schatzbogen 7 81829 Muenchen, Germany +44 1296 380 456 (English) +46 8 52200080 (English) +49 89 92103 559 (German) +33 1 69 35 48 48 (French) support@freescale.com

#### Japan:

Freescale Semiconductor Japan Ltd. Headquarters ARCO Tower 15F 1-8-1, Shimo-Meguro, Meguro-ku, Tokyo 153-0064 Japan 0120 191014 or +81 3 5437 9125 support.japan@freescale.com

#### Asia/Pacific:

Freescale Semiconductor Hong Kong Ltd. Technical Information Center 2 Dai King Street Tai Po Industrial Estate Tai Po, N.T., Hong Kong +800 2666 8080 support.asia@freescale.com

#### For Literature Requests Only:

Freescale Semiconductor Literature Distribution Center P.O. Box 5405 Denver, Colorado 80217 1-800-441-2447 or 303-675-2140 Fax: 303-675-2150 LDCForFreescaleSemiconductor@hibbertgroup.com

Information in this document is provided solely to enable system and software implementers to use Freescale Semiconductor products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits or integrated circuits based on the information in this document. Freescale Semiconductor reserves the right to make changes without further notice to any products herein. Freescale Semiconductor makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does Freescale Semiconductor assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters which may be provided in Freescale Semiconductor data sheets and/or specifications can and do vary in different applications and actual performance may vary over time. All operating parameters, including "Typicals" must be validated for each customer application by customer's technical experts. Freescale Semiconductor does not convey any license under its patent rights nor the rights of others. Freescale Semiconductor products are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which the failure of the Freescale Semiconductor product could create a situation where personal injury or death may occur. Should Buyer purchase or use Freescale Semiconductor products for any such unintended or unauthorized application, Buyer shall indemnify and hold Freescale Semiconductor and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claim alleges that Freescale Semiconductor was negligent regarding the design or manufacture of the part.

![](_page_35_Picture_17.jpeg)

For More Information On This Product, Go to: www.freescale.com