

# **Advance Information**

# MC6804P2 8-BIT MICROCOMPUTER

This document contains information on a new product. Specifications and information herein are subject to change without notice.

| Paragraph<br>Number                                                                                                                  | Title                                                                                                                                                                                                                                                                                                                                    |                                                                                                                            |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                                                                                                                                      | Section 1<br>Introduction                                                                                                                                                                                                                                                                                                                |                                                                                                                            |  |  |  |
| 1.1<br>1.2                                                                                                                           | General                                                                                                                                                                                                                                                                                                                                  | 3-185<br>3-185                                                                                                             |  |  |  |
|                                                                                                                                      | Section 2                                                                                                                                                                                                                                                                                                                                |                                                                                                                            |  |  |  |
| 2.1<br>2.1.1<br>2.1.2<br>2.1.3<br>2.1.4<br>2.1.5<br>2.1.6<br>2.1.7<br>2.2<br>2.3<br>2.4<br>2.4.1<br>2.4.2<br>2.4.3<br>2.4.4<br>2.4.5 | Functional Pin Description, Memory, CPU, And Registers Functional Pin Description. V <sub>CC</sub> and V <sub>SS</sub> . IRQ XTAL and EXTAL. TIMER. RESET MDS Input/Output Lines (PA0-PA7, PB0-PB7, PC0-PC3). Memory Central Processing Unit. Registers. Accumulator (A). Indirect Registers (X, Y) Program Counter. Flags (C, Z). Stack | 3-188<br>3-188<br>3-188<br>3-188<br>3-188<br>3-189<br>3-189<br>3-189<br>3-189<br>3-191<br>3-191<br>3-191<br>3-192<br>3-192 |  |  |  |
|                                                                                                                                      | Section 3<br>Timer                                                                                                                                                                                                                                                                                                                       |                                                                                                                            |  |  |  |
| 3.1<br>3.2<br>3.2.1<br>3.2.2<br>3.2.3                                                                                                | Introduction<br>Timer Registers<br>Timer Count Register (TCR)<br>Timer Status/Control Register (TSCR)<br>Timer Prescaler Register                                                                                                                                                                                                        | 3-193<br>3-195<br>3-195<br>3-195<br>3-195<br>3-196                                                                         |  |  |  |
|                                                                                                                                      | Section 4                                                                                                                                                                                                                                                                                                                                |                                                                                                                            |  |  |  |

# TABLE OF CONTENTS

| 4.1   | Interrupt              | 3-197 |
|-------|------------------------|-------|
| 4.1.1 | Edge-Sensitive Option  | 3-197 |
| 4.1.2 | Level-Sensitive Option | 3-197 |
| 4.1.3 | Power Up and Timing    | 3-197 |

MC6804P2

# TABLE OF CONTENTS (Continued)

| Paragraph<br>Number | Title                            | Page<br>Numbe |
|---------------------|----------------------------------|---------------|
| 4.2                 | Self-Test                        | 3-199         |
| 4.3                 | Reset                            | 3-199         |
| 4.4                 | Internal Clock Generator Options | 3-199         |

#### Section 5

#### Input/Output Ports

| 5.1   | Input/Output                  | 3-204 |
|-------|-------------------------------|-------|
| 5.2   | Registers                     | 3-206 |
| 5.2.1 | Port Data Registers           | 3-206 |
| 5.2.2 | Port Data Direction Registers | 3-206 |

#### Section 6

#### Software And Instruction Set

| 6.1     | Software                       | 3-207 |
|---------|--------------------------------|-------|
| 6.1.1   | Bit Manipulation               | 3-207 |
| 6.1.2   | Addressing Modes               | 3-208 |
| 6.1.2.1 | Immediate                      | 3-208 |
| 6.1.2.2 | Direct                         | 3-208 |
| 6.1.2.3 | Short Direct                   | 3-208 |
| 6.1.2.4 | Extended                       | 3-208 |
| 6.1.2.5 | Relative                       | 3-208 |
| 6.1.2.6 | Bit Set/Clear                  | 3-208 |
| 6.1.2.7 | Bit Test And Branch            | 3-209 |
| 6.1.2.8 | Register-Indirect              | 3-209 |
| 6.1.2.9 | Inherent                       | 3-209 |
| 6.2     | Instruction Set.               | 3-209 |
| 6.2.1   | Register/Memory Instructions   | 3-209 |
| 6.2.2   | Read-Modify-Write Instructions | 3-209 |
| 6.2.3   | Branch Instructions            | 3-209 |
| 6.2.4   | Bit Manipulation Instructions  | 3-209 |
| 6.2.5   | Control Instructions           | 3-213 |
| 6.2.6   | Alphabetical Listing           | 3-213 |
| 6.2.7   | Opcode Map Summary             | 3-213 |
| 6.3     | Implied Instructions           | 3-213 |

#### Section 7

#### **Electrical Specifications**

| 7.1 | Introduction            | 3-218 |
|-----|-------------------------|-------|
| 7.2 | Maximum Ratings         | 3-218 |
| 7.3 | Thermal Characteristics | 3-218 |

# TABLE OF CONTENTS (Continued)

| Paragraph<br>Number | Title                              |       |  |
|---------------------|------------------------------------|-------|--|
| 7.4                 | Power Considerations               | 3-219 |  |
| 7.5                 | Electrical Characteristics.        | 3-219 |  |
| 7.6                 | Switching Characteristics          | 3-219 |  |
| 7.7                 | Port DC Electrical Characteristics | 3-220 |  |
|                     | Section 8                          |       |  |
|                     | Ordering Information               |       |  |
| 8.1                 |                                    | 3-221 |  |
| 8.1.1               | EPROMs                             | 3-221 |  |
| 8.1.2               | MDOS Disk File                     | 3-221 |  |
| 8.2                 | Verification Media                 | 3-221 |  |
| 8.3                 | ROM Verification Units (RVUs)      | 3-222 |  |
| 8.4                 | Flexible Disks                     | 3-222 |  |
|                     | Section 9                          |       |  |
|                     | Mechanical Data                    |       |  |
| 9.1                 | Pin Assignment                     | 3-224 |  |

# LIST OF ILLUSTRATIONS

| Figure<br>Number                       | Title                                                                                                                                                                                                                                                                                  | Page<br>Number                                     |
|----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|
| 1-1                                    | MC6804P2 MCU Block Diagram                                                                                                                                                                                                                                                             | 3-187                                              |
| 2-1<br>2-2                             | MC6804P2 MCU Address Map<br>Programming Model                                                                                                                                                                                                                                          | 3-190<br>3-191                                     |
| 3-1 <sup>-</sup>                       | Timer Block Diagram                                                                                                                                                                                                                                                                    | 3-194                                              |
| 4-1<br>4-2<br>4-3<br>4-4<br>4-5<br>4-6 | Reset and Interrupt Processing Flowchart.<br>Self-Test Circuit.<br>Power-Up Reset Delay Circuit.<br>Clock Generator Options.<br>Crystal Motional Arm Parameters and Suggested PC Board Layout<br>Typical Frequency Selection for Resistor-Capacitor Oscillator Option<br>(CL = 17 pF). | 3-198<br>3-200<br>3-201<br>3-201<br>3-202<br>3-202 |
| 4-7                                    | Clock Generator Timing Diagram                                                                                                                                                                                                                                                         | 3-203                                              |
| 5-1<br>5-2                             | Typical I/O Port Circuitry<br>Typical Port Connections                                                                                                                                                                                                                                 | 3-204<br>3-205                                     |
| 6-1                                    | Bit Manipulation Example                                                                                                                                                                                                                                                               | 3-207                                              |
| 7-1<br>7-2<br>7-3                      | LSTTL Equivalent Test Load (Port B)<br>CMOS Equivalent Test Load (Ports A, B, C)<br>LSTTL Equivalent Test Load (Ports A, C, and TIMER)                                                                                                                                                 | 3-218<br>3-218<br>3-218                            |
| 8-1                                    | Ordering Form                                                                                                                                                                                                                                                                          | 3-223                                              |

# LIST OF TABLES

| Table<br>Number                               | Title                                                                                                                                                                                                                         | Page<br>Number                                              |
|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|
| 3-1                                           | Prescaler Coding Table                                                                                                                                                                                                        | 3-193                                                       |
| 6-1<br>6-2<br>6-3<br>6-4<br>6-5<br>6-6<br>6-7 | Register/Memory Instructions.<br>Read-Modify-Write Instructions.<br>Branch Instructions.<br>Bit Manipulation Instructions.<br>Control Instructions.<br>Instruction Set.<br>MC6804P2 Microcomputer Instruction Set Opcode Map. | 3-210<br>3-211<br>3-212<br>3-212<br>3-214<br>3-215<br>3-216 |

# SECTION 1 INTRODUCTION

#### 1.1 GENERAL

The MC6804P2 microcomputer unit (MCU) is a member of the M6804 Family of very low-cost single-chip microcomputers. This 8-bit microcomputer contains a CPU, on-chip CLOCK, ROM, RAM, I/O, and TIMER. It is designed for the user who needs an economical microcomputer with the proven capabilities of the M6800-based instruction set.

#### **1.2 FEATURES**

The following are some of the hardware and software features of the MC6804P2 MCU.

#### HARDWARE FEATURES

- 5-Volt Single Supply
- Pin Compatible with the MC6805P2 and MC68705P3
- 32 Bytes of RAM
- Memory Mapped I/O
- 1024 Bytes of Program ROM
- 64 Bytes of Data ROM
- 20 Bidirectional I/O Lines (Eight Lines with High Current Sink Capability)
- On-Chip Clock Generator
- Self-Test Mode
- Master Reset
- Complete Development System Support on EXORciser
- Software Programmable 8-Bit Timer Control Register and Timer Prescaler (7 Bits, 2n)
- Timer Pin is Programmable as Input or Output
- On-Chip Circuit for ROM Verify

#### SOFTWARE FEATURES

- Similar to M6805 HMOS Family
- Byte Efficient Instruction Set
- Easy to Program
- True Bit Manipulation
- Bit Test and Branch Instruction

#### SOFTWARE FEATURES (Continued)

- Separate Flags for Interrupt and Normal Processing
- Versatile Indirect Registers
- Conditional Branches
- Single Instruction Memory Examine/Change
- True LIFO Stack Eliminates Stack Pointer
- Nine Powerful Addressing Modes
- Any Bit in Data Space Memory May be Tested
- Any Bit in Data Space Memory Capable of Being Written to May be Set or Cleared

#### USER SELECTABLE OPTIONS

- 20 Bidirectional I/O Lines with LSTTL, LSTTL/CMOS, or Open-Drain Interface
- Crystal or Low-Cost Resistor-Capacitor Oscillator
- Mask Selectable Edge- or Level-Sensitive Interrupt Pin

# MC6804P2



NOTE: 8-Bit indirect registers X and Y, although shown as part of the CPU, are actually located in the 32×8 RAM at locations \$80 and \$81.



## SECTION 2 FUNCTIONAL PIN DESCRIPTION, MEMORY, CPU, AND REGISTERS

This section provides a description of the functional pins, memory spaces, the central processing unit (CPU), and the various registers and flags.

#### 2.1 FUNCTIONAL PIN DESCRIPTION

#### 2.1.1 VCC and VSS

Power is supplied to the MCU using these two pins. VCC is power and VSS is the ground connection.

#### 2.1.2 IRQ

This pin provides the capability for asynchronously applying an external interrupt to the MCU. Refer to **4.1 INTERRUPT** for additional information.

#### 2.1.3 XTAL and EXTAL

These pins provide connections to the on-chip clock oscillator circuit. A crystal, a resistor and capacitor, or an external signal, depending on the user selectable manufacturing mask option, can be connected to these pins to provide a system clock source with various stability/cost tradeoffs. Lead lengths and stray capacitance on these two pins should be minimized. Refer to **4.4 INTERNAL CLOCK GENERATOR OPTIONS** for recommendations concerning these inputs.

#### 2.1.4 TIMER

In the input mode, the timer pin is connected to the prescaler input and serves as the timer clock. In the output mode, the timer pin signals that a time out of the timer has occurred. Refer to **SECTION 3 TIMER** for additional information.

#### 2.1.5 RESET

The  $\overrightarrow{\text{RESET}}$  pin is used to restart the processor of the MC6804P2 to the beginning of a program. This pin, together with the MDS pin, is also used to select the operating mode of the MC6804P2. If the MDS pin is at zero volts, the normal mode is selected and the program counter is loaded with the user restart vector. However, if the MDS pin is at +5 volts, then pins PA6 and PA7 are decoded to allow selection of the operating mode. Refer to **4.3 RESET** for additional information.

# MC6804P2

#### 2.1.6 MDS

The MDS (mode select) pin is used to place the MCU into special operating modes. If MDS is held at +5 volts at the exit of the reset state, the decoded state of PA6 and PA7 is latched to determine the operating mode (single-chip, self-test, or ROM verify). However, if MDS is held at zero volts at the exit of the reset state, the single-chip operating mode is automatically selected (regardless of PA6 and PA7 state).

For those users familiar with the MC6801 microcomputer, mode selection is similar but much less complex in the MC6804P2. No special external diodes, switches, transistors, etc. are required in the MC6804P2.

#### 2.1.7 Input/Output Lines (PA0-PA7, PB0-PB7, PC0-PC3)

These 20 lines are arranged into two 8-bit ports (A and B) and one 4-bit port (C). All lines are programmable as either inputs or outputs under software control of the data direction registers. Refer to **SECTION 5 INPUT/OUTPUT PORTS** for additional information.

#### 2.2 MEMORY

The MCU operates in three different memory spaces: program space, data space, and stack space. A representation of these memory spaces is shown in Figure 2-1. The program space (Figure 2-1a) contains all of the instructions that are to be executed, as well as the data required for the immediate addressing mode instructions, and the self-test and user vectors. The data space (Figure 2-1b) contains all of the RAM locations, plus I/O locations and some ROM used for storage of tables and constants. The stack space (Figure 2-1c) contains RAM which is used for stacking subroutine and interrupt return addresses.

The MCU is capable of addressing 4096 bytes of program space memory with its program counter and 256 bytes of data space memory with its instructions. The data space memory contains three bytes for port data registers, three bytes for port data direction registers, one byte for timer status/control, 64 bytes ROM, 32 bytes RAM (which includes two bytes for X and Y indirect registers), two bytes for timer prescaler and count registers, and one byte for the accumulator. The program space section including 288 bytes of self-test ROM, 1016 bytes program ROM, and eight bytes of vectors for self-test and user programs.

#### 2.3 CENTRAL PROCESSING UNIT

The CPU of the M6804 Family is implemented independently from the I/O or memory configuration. Consequently, it can be treated as an independent central processor communicating with I/O and memory via internal addresses, data, and control buses.

# MC6804P2

| (a) Program Space Memory Map |                |
|------------------------------|----------------|
| ·····                        | \$000          |
| Reserved (All Ones)          | ***            |
|                              | \$ADF<br>\$AE0 |
| Self-Test ROM                |                |
|                              | SREE           |
|                              | \$C00          |
|                              |                |
| Program ROM                  |                |
|                              | \$FF7          |
| Self-Test IRQ Vector         | \$FF8-\$FF9    |
| Self-Test Restart Vector     | \$FFA-\$FFB    |
| User IRQ Vector              | \$FFC-\$FFD    |
| User Restart Vector          | \$FFE-\$FFF    |

(c) Stack Space Memory Map

| Level 1 |  |
|---------|--|
| Level 2 |  |
| Level 3 |  |
| Level 4 |  |

| Port A Data Register       900         Port B Data Register       900         1       1       1       Port C Data Reg.       900         Not Used       900       900       900       900         Port A Data Direction Register       900       900       900       900         Port B Data Direction Register       900       900       900       900         Port B Data Direction Register       900       900       900       900       900         1       1       1       1       Port C DDR       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900       900                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                      | (b)  | Data   | Spac    | e Memory Map     |       |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|------|--------|---------|------------------|-------|
| Port B Data Register     \$0'       1     1     1     Port C Data Reg.     \$0'       Not Used     \$0'     \$0'       Port A Data Direction Register     \$0'       Port B Data Direction Register     \$0'       Port B Data Direction Register     \$0'       I     1     1     Port C DDR       Not Used     \$0'       Not Used     \$0'       Not Used     \$0'       Timer Status Control Register     \$0'       Future Expansion     \$11       Stat     \$11       User Data Space ROM     \$50'       Future Expansion     \$7'       Indirect Register X     \$8'       Data Space RAM     \$9'       Stat     \$11       Future Expansion     \$7'       Indirect Register Y     \$8'       Data Space RAM     \$9'       Stat     \$12       Prescaler Register     \$7       State Space Register     \$7       State Space RAM     \$9'       State Space RAM     \$9'       State Space Register     \$7       State Spa                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                      |      | Port   | A Dat   | ta Register      | \$00  |
| 1       1       1       Port C Data Reg.       \$02         Not Used       \$02       Port A Data Direction Register       \$00         Port B Data Direction Register       \$00       \$01         1       1       1       Port C DDR       \$00         Not Used       \$00       Not Used       \$00         Timer Status Control Register       \$00       \$00         Future Expansion       \$11       \$20         User Data Space ROM       \$56         Future Expansion       \$7         Indirect Register X       \$88         Data Space RAM       \$99         SA       \$40         Future Expansion       \$7         Indirect Register Y       \$8         Data Space RAM       \$99         SA       \$40         Future Expansion       \$7         Indirect Register Y       \$8         Data Space RAM       \$99         \$14       \$15         \$15       \$16         SA       \$17         Prescaler Register       \$56         \$18       \$10         SA       \$10         SA       \$10         SA       \$10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                      |      | Port   | B Dat   | a Register       | \$01  |
| Not Used     900       Port A Data Direction Register     900       Port B Data Direction Register     900       1     1     1     Port C DDR       Not Used     900       Timer Status Control Register     900       Future Expansion     901       State Data Space ROM     900       Future Expansion     900       Future Expansion     900       Future Expansion     900       State Register X     900       State Register Y     980       Data Space RAM     991       Future Expansion     914       Future Expansion     914       State Register Y     915       Posta Space RAM     915       State Register Y     914       State Register     915       State Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 1                    | 1    | 1      | 1       | Port C Data Reg. | \$02  |
| Port A Data Direction Register       \$00         Port B Data Direction Register       \$00         1       1       1       Port C DDR       \$00         Not Used       \$00       \$00       \$00         Timer Status Control Register       \$00       \$00         Future Expansion       \$11       \$11       \$20         User Data Space ROM       \$56       \$56         Future Expansion       \$7       \$66         Future Expansion       \$7       \$60         Data Space ROM       \$56       \$60         Data Space RAM       \$99       \$64         Future Expansion       \$7       \$64         Future Expansion       \$7       \$64         Future Register X       \$88       \$89         Data Space RAM       \$99       \$64         Future Expansion       \$7       \$7         Prescaler Register       \$7       \$7         Prescaler Register       \$7       \$7         Prescaler Register       \$7       \$7         Timer Count Register       \$7       \$7         Prescaler Register       \$7       \$7         Accumulator       \$7       \$7         Timer Count                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      |      |        | Not     | Used             | \$03  |
| Port B Data Direction Register         502           1         1         1         Port C DDR         500           Not Used         S00         S00         500           Timer Status Control Register         500         500           Future Expansion         S11         520           User Data Space ROM         550           Future Expansion         550           Future Expansion         570           Indirect Register X         580           Data Space RAM         581           Data Space RAM         591           Future Expansion         542           Prescaler Register         581           Future Expansion         581           Sata Space RAM         591           Future Expansion         541           Future Expansion<                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                      | Port | A Da   | ita Dir | ection Register  | \$04  |
| 1     1     1     Port C DDR     \$00       Not Used     \$00       Timer Status Control Register     \$00       Future Expansion     \$11       Future Expansion                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                      | Port | B Da   | ita Dir | ection Register  | \$05  |
| Not Used       \$0.         Timer Status Control Register       \$00.         Future Expansion       \$11         \$20       User Data Space ROM         Future Expansion       \$50         Future Expansion       \$50         Future Expansion       \$7         Indirect Register X       \$80         Indirect Register Y       \$8         Data Space RAM       \$90         Future Expansion       \$7         Prescaler Register       \$F         Prescaler Register       \$F         Timer Count Register       \$F         Accumulator       \$F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1                    | 1    | 1      | 1       | Port C DDR       | \$06  |
| Timer Status Control Register \$00<br>Future Expansion \$11<br>User Data Space ROM \$50<br>Future Expansion \$7<br>Indirect Register X \$88<br>Indirect Register Y \$8<br>Data Space RAM \$9<br>Future Expansion \$7<br>Prescaler Register \$F<br>Timer Count Register \$F<br>Accumulator \$F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                      | _    |        | Not     | Used             | \$07  |
| Future Expansion     \$00       Future Expansion     \$11       \$20     \$21       User Data Space ROM     \$56       Future Expansion     \$7       Indirect Register X     \$80       Data Space RAM     \$99       Future Expansion     \$7       Future Expansion     \$7       Prescaler Register     \$60       Future Expansion     \$7       Future Expansion     \$99       Future Expansion     \$91       SA     \$92       Future Expansion     \$93       Future Expansion     \$94       SA     \$95       Future Expansion     \$95       SA     \$95                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                      | Time | or Sta | tus Cr  | ontrol Begister  | \$08  |
| Future Expansion       \$11         \$20       \$21         User Data Space ROM       \$56         Future Expansion       \$7         Indirect Register X       \$80         Indirect Register Y       \$8         Data Space RAM       \$99         Future Expansion       \$7         Future Expansion       \$91         Future Expansion       \$92         Future Expansion       \$91         Future Expansion       \$92         Future Expansion       \$91         Future Expansion       \$92         Future Expansion       \$93         Future Expansion       \$92         Future Expansion       \$93         Future Expansion       \$93         Future Expansion       \$93         Second Register       \$93         Future Expansion       \$93         Second Register       \$94         Second Register       \$95         Future Count Register       \$95         Second Register       \$95         <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                      |      |        |         |                  | \$0A  |
| \$11         \$20         User Data Space ROM         \$50         \$60         Future Expansion         \$7         Indirect Register X         \$80         Indirect Register Y         \$81         Data Space RAM         \$90         \$4         Future Expansion         \$4         \$1         \$4         \$5         \$6         \$6         \$7         Indirect Register Y         \$8         Data Space RAM         \$90         \$4         \$1         \$4         \$5         \$6         \$6         \$6         \$6         \$7         \$8         \$9         \$4         \$6         \$6         \$6         \$7         \$1         \$1         \$1         \$2         \$2         \$3         \$4         \$4         \$5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                      |      | Eut    | ture F  | xpansion         |       |
| User Data Space ROM  Future Expansion  Future Expansion  Future Register X  Data Space RAM  Future Expansion  Future Space RAM  Selection  Select |                      |      |        |         | , panoloni       | ¢1E   |
| User Data Space ROM<br>Future Expansion<br>Future Expansion<br>S7<br>Indirect Register X<br>Baseline Space RAM<br>Data Space RAM<br>Future Expansion<br>Future Expansion<br>S4<br>Prescaler Register<br>S4<br>S4<br>S4<br>S4<br>S4<br>S4<br>S4<br>S4<br>S4<br>S4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      |      |        |         |                  | \$20  |
| Space RAM       \$50         Future Expansion       \$7         Indirect Register X       \$80         Indirect Register Y       \$8         Data Space RAM       \$90         Future Expansion       \$7         Future Expansion       \$60         Future Expansion       \$61         Prescaler Register       \$7         Timer Count Register       \$7         Accumulator       \$7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Line Data Grand BOM  |      |        |         |                  | ļ     |
| Future Expansion<br>Future Expansion<br>1ndirect Register X<br>Indirect Register Y<br>88<br>Data Space RAM<br>S9<br>Future Expansion<br>Future Expansion<br>SF<br>Prescaler Register<br>SF<br>Timer Count Register<br>SF<br>Accumulator<br>SF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                      |      |        |         |                  |       |
| Future Expansion \$7<br>Indirect Register X \$8<br>Indirect Register Y \$8<br>Data Space RAM \$9<br>Future Expansion \$4<br>Prescaler Register \$F<br>Timer Count Register \$F<br>Accumulator \$F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                      |      |        |         |                  | \$5F  |
| \$7       Indirect Register X       \$8         Indirect Register Y       \$8         Data Space RAM       \$9         Future Expansion       \$A         Prescaler Register       \$F         Timer Count Register       \$F         Accumulator       \$F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Euture Expansion     |      |        |         | \$00             |       |
| Indirect Register X \$8<br>Indirect Register Y \$8<br>Data Space RAM \$9<br>Future Expansion \$F<br>Prescaler Register \$F<br>Timer Count Register \$F<br>Accumulator \$F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                      |      |        |         |                  | \$7F  |
| Indirect Register Y \$8<br>Data Space RAM \$9<br>Future Expansion \$F<br>Prescaler Register \$F<br>Timer Count Register \$F<br>Accumulator \$F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Indirect Register X  |      |        |         | \$80             |       |
| S8:<br>Data Space RAM<br>S4<br>Future Expansion<br>Frescaler Register<br>Timer Count Register<br>SF<br>Accumulator                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Indirect Register Y  |      |        |         | \$81             |       |
| Data Space RAM \$99<br>Future Expansion \$F<br>Prescaler Register \$F<br>Timer Count Register \$F<br>Accumulator \$F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                      |      |        |         |                  | \$82  |
| Future Expansion<br>Prescaler Register<br>Firmer Count Register<br>Accumulator<br>\$F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                      |      | Da     | ta Sn   | ace BAM          | ļ     |
| Future Expansion<br>Future Expansion<br>\$F<br>Prescaler Register<br>\$F<br>Timer Count Register<br>\$F<br>Accumulator<br>\$F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                      |      | 00     | to op   |                  |       |
| Future Expansion \$F<br>Prescaler Register \$F<br>Timer Count Register \$F<br>Accumulator \$F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                      |      |        |         |                  | \$9F  |
| Future Expansion       \$F         Prescaler Register       \$F         Timer Count Register       \$F         Accumulator       \$F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                      |      |        |         |                  | ,\$A0 |
| %F     %F       Prescaler Register     %F       Timer Count Register     %F       Accumulator     %F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                      |      | Fu     | ture E  | xpansion         |       |
| Prescaler Register       \$F         Timer Count Register       \$F         Accumulator       \$F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                      |      |        |         |                  |       |
| Timer Count Register \$F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Prescaler Register   |      |        |         |                  |       |
| Accumulator \$F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Timer Count Register |      |        |         |                  | \$FE  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | L                    |      | /      | Accun   | nulator          | \$FF  |

Figure 2-1. MC6804P2 MCU Address Map

#### 2.4 REGISTERS

The M6804 Family CPU has four registers and two flags available to the programmer. They are shown in Figure 2-2 and are explained in the following paragraphs.



Figure 2-2. Programming Model

#### 2.4.1 Accumulator (A)

The accumulator is an 8-bit general purpose register used in all arithmetic calculations, logical operations, and data manipulations. The accumulator is implemented as the highest RAM location (\$FF) in data space and thus implies that several instructions exist which are not explicitly implemented. Refer to **6.3 IMPLIED INSTRUCTIONS** for additional information.

#### 2.4.2 Indirect Registers (X, Y)

These two indirect registers are used to maintain pointers to other memory locations in data space. They are used in the register-indirect addressing mode, and can be accessed with the direct, indirect, short direct, or bit set/clear addressing modes. These registers are implemented as two of the 32 RAM locations (\$80, \$81) and as such generate implied instructions and may be manipulated in a manner similar to any RAM memory location in data space. Refer to **6.3 IMPLIED INSTRUC-TIONS** for additional information.

#### 2.4.3 Program Counter (PC)

The program counter is a 12-bit register that contains the address of the next ROM word to be used (may be opcode, operand, or address of operand). The 12-bit program counter is contained in PCL (low byte) and PCH (high nibble).

#### 2.4.4 Flags (C, Z)

The carry (C) bit is set on a carry or a borrow out of the ALU. It is cleared if the result of an arithmetic operation does not result in a carry or a borrow. The (C) bit is also set to the value of the bit tested in a bit test instruction, and participates in the rotate left instruction.

The zero (Z) bit is set if the result of the last arithmetic or logical operation was equal to zero, otherwise it is cleared.

There are two sets of these flags, one set is for interrupt processing, the other for all other routines. When an interrupt occurs, a context switch is made from the program flags to the interrupt flags (interrupt mode). An RTI forces the context switch back to the program flags (program mode). While in either mode, only the flags for that mode are available. Further, the interrupt flags will not be cleared upon entering the interrupt mode. Instead, the flags will be as they were at the exit of the last interrupt mode. Both sets of flags are cleared by reset.

#### 2.4.5 Stack

There is a true LIFO stack incorporated in the MC6804P2 which eliminates the need for a stack pointer. Stack space is implemented in separate RAM (12-bits wide) shown in Figure 2-1c. Whenever a subroutine call (or interrupt) occurs, the contents of the PC are shifted into the top register of the stack. At the same time (same cycle), the top register is shifted to the next level deeper. This happens to all registers with the bottom register falling out the bottom of the stack.

Whenever a subroutine or interrupt return occurs, the top register is shifted into the PC and all lower registers are shifted up one level higher. The stack RAM is four levels deep. If the stack is pulled more than four times without any pushes, the address that was stored in the bottom level will be shifted into the PC.

# SECTION 3 TIMER

#### 3.1 INTRODUCTION

A block diagram of the MC6804P2 timer circuitry is shown in Figure 3-1. The timer logic in the MCU is comprised of a simple 8-bit counter (timer count register, TCR) with a 7-bit prescaler, and a timer status/control register (TSCR). The timer count register, which may be loaded under program control, is decremented towards zero by a clock input (prescaler output). The prescaler is used to extend the maximum interval of the overall timer. The prescaler tap is selected by bits 0-2 (PS0-PS2) of the timer status/control register. Bits PS0-PS2 control the actual division of the prescaler within the range of divide-by-1 (2<sup>0</sup>) to divide-by-128 (2<sup>7</sup>). The timer count register (TCR) and prescaler are decremented on rising clock edges. The coding of the TCSR PS0-PS2 bits produce a division in the prescaler as shown in Table 3-1.

Table 3-1. Prescaler Coding Table

| PS2 | PS1 | PS0 | Divide By | PS2 | PS1 | PS0 | Divide By |
|-----|-----|-----|-----------|-----|-----|-----|-----------|
| 0   | 0   | 0   | 1         | 1   | . 0 | 0   | 16        |
| 0   | 0   | 1   | 2         | 1   | 0   | 1   | 32        |
| 0   | 1   | 0   | 4         | 1   | 1   | 0   | 64        |
| _ 0 | 1   | 1   | 8         | 1   | 1   | 1   | 128       |

The TIMER pin may be programmed as either an input or an output depending on the status of TOUT (TSCR bit 5). Refer to Figure 3-1. In the input mode, TOUT is a logic zero and the TIMER pin is connected directly to the prescaler input. Therefore, the timer prescaler is clocked by the signal applied from the TIMER pin. The prescaler then divides its clock input by a value determined by the coding of the TSCR bits PS0-PS2 as shown in Table 3-1. The divided prescaler output then clocks the 8-bit timer count register (TCR). When the TCR is decremented to zero, it sets the TMZ bit in the timer status/control register (TSCR). The TMZ bit can be tested under program control to perform a timer function whenever it goes high. The frequency of the external clock applied to the TIMER pin must be less than  $t_{byte}$  (fosc/48).

In the output mode, TOUT is a logic one and the TIMER pin is connected to the DOUT latch. Therefore, the timer prescaler is clocked by the internal sync pulse (divide-by-48 of the internal oscillator). Operation is similar to that described above for the input mode. However, in the output mode, the low-to-high TMZ bit transition is used to latch the DOUT bit of the TSCR and provide it as output for the TIMER pin.

#### NOTE

TMZ is normally set to logic one when the timer times out (TCR decrements to \$00); however, it may be set by a write of \$00 to the TCR or by a write to bit 7 of the TSCR.



ω

| τουτ | Prescaler<br>Clock | TIMER<br>Pin |
|------|--------------------|--------------|
| 0    | TIMER Pin          | Input Mode   |
| :1   | Sync               | Output Mode  |

Figure 3-1. Timer Block Diagram

During reset, the timer count register and prescaler are set to \$FF, while the timer status/control register is cleared to \$00 and the DOUT LATCH (TIMER pin is in the high-impedance input mode) is forced to a logic high. The prescaler and timer count register are implemented in data space RAM locations (\$FD, \$FE); therefore, they are both readable and writeable. A write to either will predominate over the TCR decrement-to-\$00 function; i.e., if a write and a TCR decrement-to-\$00 occur simultaneously, the write will take precedence, and the TMZ bit is not set until the next timer time out.

#### 3.2 TIMER REGISTERS

#### 3.2.1 Timer Count Register (TCR)



The timer count register indicates the state of the internal 8-bit counter.

#### 3.2.2 Timer Status/Control Register (TSCR)

| _ | 7                  | 6        | 5    | 4    | 3   | 2   | 1   | 0   |  |  |  |  |  |
|---|--------------------|----------|------|------|-----|-----|-----|-----|--|--|--|--|--|
|   | TMZ                | Not Used | TOUT | DOUT | PSI | PS2 | PS1 | PS0 |  |  |  |  |  |
|   | TSCR Address≕ \$09 |          |      |      |     |     |     |     |  |  |  |  |  |

b7,TMZ Low-to-high transition indicates the timer count register has decremented to zero since the timer status/control register was last read. Cleared by a read of TSCR register if TMZ was read as a logic one.

b6 Not used.

- b5, TOUT When low, this bit selects the input mode for the timer. When high, the output mode is selected.
- b4, DOUT Data sent to the timer output pin when TMZ is set high (output mode only).
- b3, PSI Used to initialize the prescaler and inhibit its counting while PSI = 0. The initialized value is set to \$FF. The timer count register will also be inhibited (contents unchanged). When PSI = 1 the prescaler begins to count downward.
- b0, b1, b2These bits are used to select the prescaler divide-by ratio; therefore, effectingPS0-PS1the clock input frequency to the timer count register.

# MC6804P2

#### 3.2.3 Timer Prescaler Register



The timer prescaler register indicates the state of the internal 7-bit prescaler. This 7-bit prescaler divide ratio is normally determined by bits PS0-PS2 of the timer status/control register (see Table 3-1).

# SECTION 4 INTERRUPT, SELF-TEST, RESET, AND INTERNAL CLOCK GENERATOR

#### 4.1 INTERRUPT

The MC6804P2 can be interrupted by applying a logic low signal to the IRQ pin; however, a mask option selected at the time of manufacture determines whether the negative-going edge or the actual low level is sensed to indicate an interrupt.

#### 4.1.1 Edge-Sensitive Option

When the IRQ pin is pulled low, the internal interrupt request latch is set. Prior to each instruction fetch, the interrupt request latch is tested and, if its output is low, an interrupt sequence is initiated at the end of the current instruction (provided the interrupt mask is cleared). Figure 4-1 contains a flowchart which illustrates both the reset and interrupt sequence. The interrupt sequence consists of one cycle during which: the interrupt request latch is cleared, the interrupt mode flags are selected, the PC is saved on the stack, the interrupt mask is set, and the IRQ vector (single chip mode = \$FFC/\$FFD, self-test mode = \$FF8/\$FF9) is loaded into the PC. Internal processing of the interrupt continues until an RTI (return from interrupt) instruction is processed. During the RTI instruction, the interrupt mask is cleared and the program mode flags are selected. The next instruction of the program is then fetched and executed. Once the interrupt was initially detected and the interrupt sequence started, the interrupt request latch is cleared so that the next (second) interrupt may be detected even while the previous (first) one is being serviced. However, even though the second interrupt sets the interrupt request latch during processing of the first interrupt, the second interrupt sequence will not be initiated until completion of the interrupt service routine for the first interrupt. Completion of an interrupt service routine is always accomplished using an RTI instruction to return to the main program. The interrupt mask (which is not directly available to the programmer) is cleared during the last cycle of the RTI instruction.

#### 4.1.2 Level-Sensitive Option

The actual operation of the level-sensitive and edge-sensitive options are similar except that the level-sensitive option does not have an interrupt request latch. With no interrupt request latch, the logic level of the  $\overline{IRQ}$  pin is checked for detection of the interrupt. Also, in the interrupt sequence, there is no need to clear the interrupt request latch. These differences are illustrated in the flowchart of Figure 4-1.

#### 4.1.3 Power Up and Timing

During the power-up sequence the interrupt mask is set to preclude any false or "ghost" interrupts from occurring. To clear the interrupt mask, the programmer should write a JSR (instead of a JMP) instruction to an initialization routine as the first instruction in a program. The initialization routine



Figure 4-1. Reset and Interrupt Processing Flowchart

should end with an RTI (instead of RTS). Maximum interrupt response time is six machine (t<sub>byte)</sub> cycles (see **4.4 INTERNAL CLOCK GENERATOR OPTIONS**). This includes five machine cycles for the longest instruction, plus one machine cycle for stacking the PC and switching flags. Minimum response time is one machine cycle for stacking PC and switching flags (see **2.4.4 Flags (C, Z)**).

#### 4.2 SELF-TEST

The MC6804P2 MCU has a unique internal ROM-based off-line self-test capability using signature analysis techniques. A test program stored in the on-chip ROM is initiated by configuring pins PA6 and PA7 during reset. The test results are sampled on a cycle-by-cycle basis by a 16-bit on-chip signature analysis register configured as a linear feedback shift register (LFSR) using the standard CCITT CRC16 polynomial. A schematic diagram of the self-test connections is shown in Figure 4-2. To perform a test of the MCU, connect it as shown in Figure 4-2a and monitor the LEDs for a 00100 (\$04) pattern.

A special ROM self-test utilizing the signature analysis circuitry is also included. To initiate a test of the ROM, connect the circuit as shown in Figure 4-2b. This mode also uses the on-chip signature analysis register to verify the contents of the custom ROM by monitoring an internal bus. The "Good" LED indicates that all ROM words have been read and that the result was the correct signature.

The on-chip self-test and the ROM test are the basis of Motorola's production testing for the MC6804P2. These tests have been fault graded using statistical methods (refer to "The M6804 Built-In Self-Test", Proceedings of 1983 International Test Conference, pp. 295-300, Oct. 1983) and have been found to provide high fault coverage using automatic test equipment (ATE) or the circuit of Figure 4-2.

#### 4.3 RESET

The MCU can be reset in two ways: by initial power up (see Figure 4-1) and by the external reset input (RESET). During power up, a delay of tRHL is needed before allowing the RESET input to go high. This time delay allows the internal clock generator to stabilize. Connecting a capacitor and resistor to the RESET input, as shown in Figure 4-3, typically provides sufficient delay.

#### 4.4 INTERNAL CLOCK GENERATOR OPTIONS

The internal clock generator circuit is designed to require a minimum of external components. A crystal, a resistor-capacitor, or an external signal may be used to generate a system clock with various stability/cost tradeoffs. A manufacturing mask option is required to select either the crystal oscillator or the RC oscillator circuit. The different clock generator option connection methods are shown in Figure 4-4, crystal specifications and suggested PC board layouts are given in Figure 4-5, resistor-capacitor selection graph is given in Figure 4-6, and a timing diagram is illustrated in Figure 4-7. The crystal oscillator startup time is a function of many variables: crystal parameters (especially RS), oscillator load capacitance (CL), IC parameters, ambient temperature, and supply voltage. To ensure rapid oscillator startup, neither the crystal characteristics nor the load capacitance should exceed recommendations.

The oscillator output frequency is internally divided by four to produce the internal  $\phi$ 1 and  $\phi$ 2 clocks. The  $\phi$ 1 clock is divided by twelve to produce a machine byte (cycle) clock. A byte cycle is the smallest unit needed to execute any operation (i.e., increment the program counter). An instruction may need two, four, or five byte cycles to execute.



(b) Simple ROM Verify Test





Figure 4-3. Power-Up Reset Delay Circuit







Figure 4-5. Crystal Motional Arm Parameters and Suggested PC Board Layout



Figure 4-6. Typical Frequency Selection For Resistor-Capacitor Oscillator Option ( $C_L = 17 \text{ pF}$ )



## SECTION 5 INPUT/OUTPUT PORTS

#### 5.1 INPUT/OUTPUT

There are 20 input/output pins. All pins (port A, B, and C) are programmable as either inputs or outputs under software control of the corresponding data direction register (DDR). The port I/O programming is accomplished by writing the corresponding bit in the port DDR to a logic one for output or a logic zero for input. On reset, all the DDRs are initialized to a logic zero state to put the ports in the input mode. The port output registers are not initialized on reset but should be initialized before changing the DDR bits to avoid undefined levels. When programmed as outputs, the latched output data is readable as input data, regardless of the logic levels at the output pin due to output loading; see Figure 5-1. All input/output pins are LSTTL compatible as both inputs and outputs. In addition, all three ports may have one of two mask options: 1) internal pullup resistor for CMOS output compatibility, or 2) open drain output. The address map in Figure 2-1 gives the address of data registers and DDRs. The register configuration is discussed under the registers paragraph below and Figure 5-2 provides some examples of port connections.



Figure 5-1. Typical I/O Port Circuitry





CMOS or LSTTL Driving Port B Directly

(a) Input Mode



CMOS and LSTTL Driving Port C Directly



CMOS loads and bit 4 driving one LSTTL load directly (using CMOS output option).



Port B, bit 0, and bit 1 programmed as output, driving LEDs directly.

P'B0

12



Port C open drain option, with bits 0-3 programmed as output, driving CMOS load via wired-ORed configuration.

(b) Output Mode

Figure 5-2. Typical Port Connections

The latched output data bit (see Figure 5-1) may always be written. Therefore, any write to a port writes to all of its data bits even though the port DDR is set to input. This may be used to initialize the data registers and avoid undefined outputs; however, care must be exercised when using read-modify-write instructions since the data read corresponds to the pin level if the DDR is an input (0) and corresponds to the latched output data when the DDR is an output (1). The 20 bidirectional lines may be configured by port to be LSTTL (standard configuration), LSTTL/CMOS (mask option), or open drain (mask option). Port B outputs are LED compatible.

#### NOTE

The mask option only allows changes by port. For example, if the customer wishes PA7 to be open drain, then PA0-PA7 must all be open drain.

#### 5.2 REGISTERS

The registers described below are implemented as RAM locations and thus may be read or written.

#### 5.2.1 Port Data Register



The source of data read from the port data register will be the port I/O pin or previously latched output data depending upon the contents of the corresponding data direction register (DDR). The destination of data written to the port data register will be an output data latch. If the corresponding data direction register (DDR) for the port I/O pin is programmed as an output, the data will then appear on the port pin.

#### 5.2.2 Port Data Direction Register



The port DDRs configure the port pins as either inputs or outputs. Each port pin can be programmed individually to act as an input or an output. A zero in the pins corresponding bit position will program that pin as an input while a one in the pins corresponding bit position will program that pin as an output.

# SECTION 6 SOFTWARE AND INSTRUCTION SET

#### 6.1 SOFTWARE

#### 6.1.1 Bit Manipulation

The MC6804P2 MCU has the ability to set or clear any register or single random access memory (RAM) writable bit with a single instruction (BSET, BCLR). Any bit in data space, including ROM, can be tested, using the BRSET and BRCLR instructions, and the program may branch as a result of its state. The carry bit is set to the value of the bit referenced by BRSET or BRCLR. A rotate instruction may then be used to accumulate serial input data in a RAM location or register. The capability to work with any bit in RAM, ROM, or I/O allows the user to have individual flags in RAM or to handle I/O bits as control lines.

The coding example in Figure 6-1 illustrates the usefulness of the bit manipulation and test instructions. Assume that the MCU is to communicate with an external serial device. The external device has a data ready signal, a data output line, and a clock line (to clock data one bit at a time, MSB first, out of the device). The MCU waits until the data is ready, clocks the external device, picks up the data in the carry flag (C bit), clears the clock line, and finally accumulates the data bit in the accumulator.



Figure 6-1. Bit Manipulation Example

#### 6.1.2 Addressing Modes

The MC6804P2 MCU has nine addressing modes which are explained briefly in the following paragraphs. The MC6804P2 deals with objects in three different address spaces: program space, data space, and stack space. Program space contains the instructions which are to be executed, plus the data for immediate mode instructions. Data space contains all of the RAM locations, X and Y registers, accumulator, timer, I/O locations, and some ROM (for storage of tables and constants). Stack space contains RAM for use in stacking the return addresses for subroutines and interrupts.

The term "Effective Address" (EA) is used in describing the address modes. EA is defined as the address from which the argument for an instruction is fetched or stored.

**6.1.2.1 IMMEDIATE.** In the immediate addressing mode, the operand is located in program ROM and is contained in a byte following the opcode. The immediate addressing mode is used to access constants which do not change during program execution (e.g., a constant used to initialize a loop counter).

**6.1.2.2 DIRECT.** In the direct addressing mode, the effective address of the argument is contained in a single byte following the opcode byte. Direct addressing allows the user to directly address the 256 bytes in data space memory with a single two-byte instruction.

**6.1.2.3 SHORT DIRECT.** The MCU also has four locations in data space RAM (\$80, \$81, \$82, \$83) which may be used in a short-direct addressing mode. In this mode the lower two bits of the opcode determines the data space RAM location, and the instruction is only one byte. Short direct addressing is a subset of the direct addressing mode. (The X and Y registers are at locations \$80 and \$81 respectively.)

**6.1.2.4 EXTENDED.** In the extended addressing mode, the effective address is obtained by concatenating the four least significant bits of the opcode with the byte following the opcode (12-bit address). Instructions using the extended addressing mode (JMP, JSR) are capable of branching anywhere in program space. An extended addressing mode instruction is two bytes long.

**6.1.2.5 RELATIVE.** The relative addressing mode is only used in conditional branch instructions. In relative addressing, the address is formed by adding the sign extended lower five bits of the opcode (the offset) to the program counter if and only if the condition is true. Otherwise, control proceeds to the next instruction. The span of relative addressing is from -15 to +16 from the opcode address. The programmer need not worry about calculating the correct offset when using the Motorola assembler since it calculates the proper offset and checks to see if it is within the span of the branch.

**6.1.2.6 BIT SET/CLEAR.** In the bit set/clear addressing mode, the bit to be set or cleared is part of the opcode, and the byte following the opcode specifies the direct address of the byte in which the specified bit is to be set or cleared. Thus, any bit in the 256 locations of data space memory, which can be written to, can be set or cleared.

**6.1.2.7 BIT TEST AND BRANCH.** The bit test and branch addressing mode is a combination of direct addressing and relative addressing. The bit which is to be tested is included in the opcode, and the data space address of the byte to be tested is in the single byte immediately following the opcode byte. The third byte is sign extended to twelve bits and becomes the offset added to the program counter if the condition is true. The single three-byte instruction allows the program to branch based on the condition of any bit in data space memory. The span of branching is from -125 to +130 from the opcode address. The state of the tested bit is also transferred to the carry flag.

**6.1.2.8 REGISTER-INDIRECT.** In the register-indirect addressing mode, the operand is at the address (in data space) pointed to by the contents of one of the indirect registers (X or Y). The particular X or Y register is selected by bit 4 of the opcode. Bit 4 of the opcode is then decoded into an address which selects the desired X or Y register (\$80 or \$81). A register-indirect instruction is one byte<sub>1</sub>long.

**6.1.2.9 INHERENT.** In the inherent addressing mode, all the information necessary to execute the instruction is contained in the opcode. These instructions are one byte long.

#### 6.2 INSTRUCTION SET

The MC6804P2 MCU has a set of 42 basic instructions, which when combined with nine addressing modes produce 242 usable opcodes. They can be divided into five different types: register/memory, read-modify-write, branch, bit manipulation, and control. The following paragraphs briefly explain each type. All the instructions within a given type are presented in individual tables.

#### 6.2.1 Register/Memory Instructions

Most of these instructions use two operands. One operand is the accumulator and the other operand is obtained from memory using one of the addressing modes. The jump unconditional (JMP) and jump to subroutine (JSR) instructions have no register operands. Refer to Table 6-1.

#### 6.2.2 Read-Modify-Write Instructions

These instructions read a memory location or a register, modify or test its contents, and write the modified value back to memory or to the register. There are ten instructions which utilize read-modify-write cycles. All INC and DEC forms along with all bit manipulation instructions use this method. Refer to Table 6-2.

#### 6.2.3 Branch Instructions

The branch instructions cause a branch from the program when a certain condition is met. Refer to Table 6-3.

#### 6.2.4 Bit Manipulation Instructions

These instructions are used on any bit in data space memory. One group either sets or clears. The other group performs the bit test branch operations. Refer to Table 6-4.

#### Table 6-1. Register/Memory Instructions

|                                   |      |          | Addressing Modes |            |             |        |            |             |        |            |             |          |            |             |                |            |             |              |            |                |                  |
|-----------------------------------|------|----------|------------------|------------|-------------|--------|------------|-------------|--------|------------|-------------|----------|------------|-------------|----------------|------------|-------------|--------------|------------|----------------|------------------|
|                                   |      |          | Indi             | rect       |             | 1      | mmedia     | te          |        | Direct     |             | Inherent |            |             | Extended       |            |             | Short-Direct |            |                |                  |
| Function                          | Mnem | Opc<br>X | ode<br>Y         | #<br>Bytes | #<br>Cycles | Opcode | #<br>Bytes | #<br>Cycles | Opcode | #<br>Bytes | #<br>Cycles | Opcode   | #<br>Bytes | #<br>Cycles | Opcode         | #<br>Bytes | #<br>Cycles | Opcode       | #<br>Bytes | #<br>Cycles    | Special<br>Notes |
| Load A from Memory                | LDA  | EO       | F0               | 1          | 4           | E8 -   | 2          | 4           | F8     | 2          | 4           | -        | -          | -           |                |            | -           | AC-AF        | 1          | 4              | 1                |
| Load XP from Memory               | LDXI |          |                  | -          | -           | в0     | 3          | 4           | -      | -          | -           | -        | -          | -           | -              | -          | -           | -            | -          | _              | 4                |
| Load YP from Memory               | LDYI |          |                  | -          | -           | B0     | 3          | 4           | -      | -          | -           | -        | -          |             |                | -          | -           | - '          |            | -              | 4                |
| Store A in Memory                 | STA  | E1       | F1               | 1          | 4           | -      | -          | -           | F9     | 2          | 4           | -        | -          | -           |                | -          | -           | BC-BF        | 1          | 4              | 2                |
| Add to A                          | ADD  | E2       | F2               | 1          | 4           | EA     | 2          | 4           | FA     | 2          | 4           | -        |            | -           | -              | -          | -           |              |            | -              | -                |
| Subtract from A                   | SUB  | E3       | F3               | 1          | 4           | EB     | 2          | 4           | FB     | 2          | 4           | -        |            | -           | -              |            |             | -            | -          | -              |                  |
| Arithmetic Compare<br>with Memory | СМР  | E4       | F4               | 1.         | 4           | EC     | . 2        | 4           | FC     | 2          | 4           | -        | -          | -           |                | -          | -           | — .          |            |                | _                |
| AND Memory to A                   | AND  | E5       | F5               | 1          | 4           | ED     | 2          | 4           | FD     | 2          | 4           | -        | -          | -           | -              | -          | -           | -            | -          |                | ·                |
| Jump to Subroutine                | JSR  | _        | -                | -          |             |        | -          | -           | -      | _          | -           | -        |            | -           | 8 (TAR)        | 2          | 4           | -            | -          | — <sup>°</sup> | 3                |
| Jump Unconditional                | JMP  |          | -                |            | ~           | -      | -          | -           | -      | -          | -           | -        | -          | ] –         | 9 (TAR)        | 2          | 4           | -            | · —        | -              | 3                |
| Clear A                           | CLRA | -        |                  | -          | -           |        | · ·        | -           | FB     | 2          | 4           | -        |            | -           | - <sup>1</sup> | -          | -           | -            | -          | -              |                  |
| Clear XP                          | CLRX | -        | -                | -          |             | -      | -          | -           | FB     | 2          | 4           | -        |            | -           | -              | -          | -           | -            |            |                | *                |
| Clear YP                          | CLRY | -        | <sup>1</sup>     | -          | -           | -      |            | -           | FB     | 2          | 4           |          |            |             |                | _          | -           |              | -          | ~              | -                |
| Complement A                      | сома | -        | -                | ·          | -           |        |            | -           | -      | — .        | -           | B4       | 1          | 4           | -              | -          | -           |              | -          | - :            |                  |
| Move Immediate Value<br>to Memory | MVI  |          | -                |            | -           | в0     | 3          | 4           | B0     | 3          | 4           | -        | -          | -           | -              | -          | -           |              |            | `              | 5                |
| Rotate A Left and Carry           | ROLA | -        | -                | -          | <u>-</u>    |        | ~          |             | -      | ·          | -           | B5       | 1          | 4           | -              | -          | -           | -            | -          | -              | _                |
| Arithmetic Left Shift of A        | ASLA | -        | -                |            | -           | -      | -          |             | FA     | 2          | 4           | -        | -          | -           | - `            |            | -           | -            | —          | <del>~</del> . | -                |

#### SPECIAL NOTES

1. In Short-Direct addressing, the LDA mnemonic represents opcode AC, AD, AE, and AF. This is equivalent to RAM locations \$80 (AC), \$81 (AD), \$82 (AE), and \$83 (AF) 2. In Short-Direct addressing, the STA mnemonic represents opcode BC, BD, BE, and BF. This is equivalent to RAM locations \$80 (BC), \$81 (BD), \$82 (BE), and \$83 (BF).

3. In Extended addressing, the four LSBs of the opcode (Mnemonic JSR and JMP) are formed by the four MSBs of the target address.

4. In Immediate addressing, the LDXI and LDYI are mnemonics which are recognized as follows:

LDXI = MVI \$80,data

LDYI = MVI \$81,data Where data is a one-byte hexadecimal number.

5. In both Immediate and Direct addressing, the MVI instruction has the same opcode (80).

#### Table 6-2. Read-Modify-Write Instructions

|                           |      |     |     |       |        | Add    | ressing Mo | odes   |        |             |        | 1       |
|---------------------------|------|-----|-----|-------|--------|--------|------------|--------|--------|-------------|--------|---------|
|                           |      |     | ind | irect |        |        | Direct     |        |        | Short-Direc | t      |         |
|                           |      | Орс | ode | #     | #      |        | #          | #      |        | #           | #      | Special |
| Function                  | Mnem | X   | Y   | Bytes | Cycles | Opcode | Bytes      | Cycles | Opcode | Bytes       | Cycles | Notes   |
| Increment Memory Location | INC  | E6  | F6  | 1     | 4      | FE     | 2          | 4      | A8-AB  | .1          | 4      | 1, 3    |
| Increment A               | INCA | _   | _   | -     |        | FE     | 2          | 4      |        | -           |        |         |
| Increment X               | INCX |     | -   |       | -      | -      | -          |        | A8     | 1           | 4      | -       |
| Increment Y               | INCY |     | -   | -     |        | -      | -          |        | A9     | 1           | 4      |         |
| Decrement Memory Location | DEC  | E7  | F7  | 1     | 4      | FF     | 2          | 4      | B8-BB  | 1           | 4      | 2, 4    |
| Decrement A               | DECA | _   | -   |       | -      | FF     | 2          | 4      |        | _           | -      |         |
| Decrement X               | DECX |     | —   | -     |        | _      |            | -      | B8     | 1           | 4      |         |
| Decrement Y               | DECY | _   |     |       |        | -      | _          |        | B9     | 1           | 4      | -       |

#### SPECIAL NOTES

1. In Short-Direct addressing, the INC mnemonic represents opcode A8, A9, AA, and AB. These are equivalent to RAM locations \$80 (A8), \$81 (A9), \$82 (AA), and \$83 (AB).

2. In Short-Direct addressing, the DEC mnemonic represents opcode B8, B9, BA, and BB. These are equivalent to RAM locations \$80 (B8), \$81 (B9), \$82 (BA), and \$83 (BB).

3. In Indirect addressing, the INC mnemonic represents opcode E6 or F6, and causes the location pointed to by X (E6 opcode) or Y (F6 opcode) to be incremented.

4. In Indirect addressing, the INC mnemonic represents opcode E7 or F7, and causes the location pointed to by X (E7 opcode) or Y (F7 opcode) to be incremented.

#### Table 6-3. Branch Instructions

|                          |       | Rela   | ļ          |             |                  |
|--------------------------|-------|--------|------------|-------------|------------------|
| Function                 | Mnem  | Opcode | #<br>Bytes | #<br>Cycles | Special<br>Notes |
| Branch if Carry Clear    | BCC   | 40-5F  | 1          | 2           | 1                |
| Branch if Higher or Same | (BHS) | 40-5F  | 1          | 2           | 1, 2             |
| Branch if Carry Set      | BCS   | 60-7F  | 1.         | 2           | 1.               |
| Branch if Lower          | (BLO) | 60-7F  | 1          | 2           | 1, 3             |
| Branch if Not Equal      | BNE   | 00-1F  | 1          | 2           | 1                |
| Branch if Equal          | BEQ   | 20-3F  | 1          | 2           | 1                |

#### SPECIAL NOTES

Each mnemonic of the Branch Instructions covers a range of 32 opcodes; e.g., BCC ranges from 40 through 5F. The
actual memory location (target address) to which the branch is made is formed by adding the sign extended lower five
bits of the opcode to the contents of the program counter.

The BHS instruction (shown in parentheses) is identical to the BCC instruction. The C bit is clear if the register was higher or the same as the location in the memory to which it was compared.

 The BLO instruction (shown in parentheses) is identical to the BCS instruction. The C bit is set if the register was lower than the location in memory to which it was compared.

#### Table 6-4. Bit Manipulation Instructions

|                           |                 | [      |            | ]           |          |            |             |                 |
|---------------------------|-----------------|--------|------------|-------------|----------|------------|-------------|-----------------|
|                           |                 | В      | it Set/Cle | ar          | Bit T    | est and B  | ranch       |                 |
| Function                  | Mnem            | Opcode | #<br>Bytes | #<br>Cycles | Opcode   | #<br>Bytes | #<br>Cycles | Special<br>Note |
| Branch IFF Bit n is set   | BRSET n (n=0 7) | -      |            |             | C8+n     | 3          | 5           | 1               |
| Branch IFF Bit n is clear | BRCLR n (n=0 7) | -      | -          |             | C0 + n   | 3          | 5           | 1               |
| Set Bit n                 | BSET n (n=07)   | D8+n   | 2          | 4           | <u> </u> |            | -           | 1               |
| Clear Bit n               | BCLR n (n=07)   | D0+n   | 2          | 4           | _        |            | -           | 1               |

#### SPECIAL NOTE

1. The opcode is formed by adding the bit number (0-7) to the basic opcode. For example: to clear bit six using the BSET6 instruction the opcode becomes DE (D8+6); BCLR5 becomes (C0+5); etc.

#### 6.2.5 Control Instructions

The control instructions control the MCU operations during program execution. Refer to Table 6-5.

#### 6.2.6 Alphabetical Listing

The complete instruction set is given in alphabetical order in Table 6-6. There are certain mnemonics recognized by the Motorola assembler and converted to other instructions. The fact that all registers and accumulator are in RAM allows many implied instructions to exist. The implied instructions recognized by the Motorola assembler are identified in Table 6-6.

#### 6.2.7 Opcode Map Summary

Table 6-7 contains an opcode map for the instructions used on the MCU.

#### 6.3 IMPLIED INSTRUCTIONS

Since the accumulator and all other registers are located in RAM many implied instructions exist. The assembler-recognized implied instructions are given in Table 6-6. Some examples not recognized by the assembler are shown below.

| BCLR,7 \$FF  | Ensures accumulator is plus     |
|--------------|---------------------------------|
| BSET,7 \$FF  | Ensures accumulator is minus    |
| BRCLR,7 \$FF | Branch iff accumulator is plus  |
| BRSET,7 \$FF | Branch iff accumulator is minus |
| BRCLR,7 \$80 | Branch iff X is plus (BXPL)     |
| BRSET,7 \$80 | Branch iff X is minus (BXMI)    |
| BRCLR,7 \$81 | Branch iff Y is plus (BYPL)     |
| BRSET,7 \$81 | Branch iff Y is minus (BYMI)    |

#### Table 6-5. Control Instructions

|                        |      |        |             |             | Add    | ressing Mo | odes        |        |            |             | ]                |
|------------------------|------|--------|-------------|-------------|--------|------------|-------------|--------|------------|-------------|------------------|
|                        |      | S      | Short-Direc | et          |        | Inherent   |             |        | 1          |             |                  |
| Function               | Mnem | Opcode | #<br>Bytes  | #<br>Cycles | Opcode | #<br>Bytes | #<br>Cycles | Opcode | #<br>Bytes | #<br>Cycles | Special<br>Notes |
| Transfer A to X        | TAX  | BC     | 1           | 4           | -      | -          | -           | -      | -          | -           | -                |
| Transfer A to Y        | TAY  | BD     | 1           | 4           | -      |            |             | -      |            | -           | -                |
| Transfer X to A        | TXA  | AC     | 1           | 4           | -      | -          | -           | -      |            | -           | - 1              |
| Transfer Y to A        | TYA  | AD     | 1           | 4           | -      | -          | -           | _ ·    |            |             | -                |
| Return from Subroutine | RTS  | _      |             | -           | B3     | 1          | 2           | -      | -          | _           | -                |
| Return from Interrupt  | RTI  | -      | -           |             | B2     | 1          | 2           | -      |            | -           | -                |
| No-Operation           | NOP  | _      |             | -           |        | -          | -           |        | -          |             | 1                |

#### SPECIAL NOTE

1. The NOP instruction is equivalent to a branch if equal (BEQ) to the location designated by PC+1.

MC6804P2

#### Table 6-6. Instruction Set

|          |          |           |             | Α               | ddressing Mo    | odes         |          |          |          | FI       | ags        |
|----------|----------|-----------|-------------|-----------------|-----------------|--------------|----------|----------|----------|----------|------------|
| r        |          |           |             | Short           | Bit Set         | Bit-Test-    | Register | 1        | 1        |          | 1          |
| Mnemonic | Inherent | Immediate | Direct      | Direct          | Clear           | Branch       | Indirect | Extended | Relative | Z        | с          |
| ADD      | 1        | ×         | x           |                 |                 |              | ×        |          | 1        | <u>^</u> | ^          |
| AND      | 1        | ×         |             |                 |                 |              | X        |          |          | ∧        | •          |
| ASLA     |          |           | Assemt      | pler converts   | this to "ADD    | \$FF''       |          |          |          | •        | •          |
| BCC      |          |           |             |                 |                 |              |          |          | X        | •        | •          |
| BCLR     |          |           | · · · · · · |                 | ×               |              |          | 1        |          | •        |            |
| BCS      |          |           |             |                 |                 |              |          |          | x        | •        | •          |
| BEQ      |          |           |             |                 |                 |              |          |          | ×        | •        | •          |
| BHS      |          |           | Assemt      | oler converts   | this to "BCC    |              |          |          |          | •        | •          |
| BLO      |          |           | Assemt      | oler converts   | this to "BCS    |              |          |          |          | •        | •          |
| BNE      | 1        |           | · · ·       |                 | 1               |              |          | 1        | x        | •        | •          |
| BRCLR    |          |           |             |                 |                 | X            |          |          |          | •        | Λ          |
| BRSET    |          |           |             |                 |                 | X            |          |          |          | •        | ^          |
| BSET     |          |           |             |                 | X               |              | 1        | 1        |          | •        | •          |
| CLRA     |          |           | Assemt      | pler converts   | this to "SUB    | \$FF''       |          |          |          | ^        | ^          |
| CLRX     |          | 1         | Assemt      | oler converts   | this to "MVI    | \$80,#0''    |          | 1        |          |          | •          |
| CLRY     |          | 1         | Assemb      | oler converts   | this to "MVI    | \$81,#0"     | t        |          |          | •        | •          |
| CMP      |          | X         | ×           | [               | 1               | 1            | ×        |          |          | A        | A          |
| СОМА     | ×        |           |             |                 | 1               |              | 1        | l        |          | ^        | A          |
| DEC      |          |           | ×           | X               |                 |              | ×        | h        |          | Δ        | · · ·      |
| DECA     |          | 11        | Assemt      | pler converts   | this to "DEC    | \$FF''       |          | [        |          | Λ        | · · ·      |
| DECX     |          | 11        | Assemt      | pler converts   | this to "DEC    | \$80''       | 1        |          |          | A        |            |
| DECY     |          |           | Assemt      | oler converts   | this to "DEC    | \$81''       |          | 1        |          | ^        | •          |
| INC      |          |           | × ×         | ×               | 1               | 1            | ×        | · ····   |          | Δ.       | •          |
| INCA     |          | 1         | Assem       | oler converts   | this to "INC    | \$FF''       |          |          |          | Λ        | •          |
| INCX     |          |           | Assemi      | oler converts   | this to "INC    | \$80''       |          |          |          | Λ        | •          |
| INCY     |          |           | Assemb      | oler converts   | this to "INC    | \$81''       |          | 1        |          | ^        | •          |
| JMP      |          | 11        |             | I               |                 | 1            |          | X        |          | •        | · ·        |
| JSR      |          |           |             |                 |                 |              |          | ×        |          | •        | •          |
| LDA      | +        | X         | x           | ×               |                 | +            | X        | 1        |          | ^        | •          |
| LDXI     |          |           | Assem       | oler converts   | this to "MVI    | \$80, DATA'' |          | 1        |          | •        | •          |
| LDYI     |          | 1         | Assemi      | oler converts   | this to "MVI    | \$81, DATA'' |          | f        |          | •        | •          |
| MVI      |          | X         | ×           | 1               | T               |              |          | F        |          | •        |            |
| NOP      |          |           | Assem       | pler converts   | this to "BEQ    | (PC) + 1"    |          | t        |          | •        | <u>├</u> ─ |
| ROLA     |          |           |             |                 | 1               | 1            |          | 1        |          | Δ.       | A          |
| RTI      | X        |           |             |                 | 1               |              |          | 1        |          | A        | A .        |
| RTS      | x        |           |             |                 |                 |              |          | 1        |          | •        | •          |
| STA      |          |           | Х           | ×               | 1               |              | x        | ·        |          | ٨        | •          |
| SUB      | 1        | X         | Х           | 1               | 1               | 1            | ×        |          |          | ٨        | Λ          |
| TAX      |          | ••••••    | Assem       | oler converts   | this to "STA    | 80''         | <b>.</b> | •        | · ··     | •        | •          |
| TAY      |          |           | Assemb      | ler converts t  | his to "STA \$  | 81"          |          |          |          | •        | •          |
| TXA      |          |           | Assem       | oler converts t | this to "LDA \$ | 80''         |          |          |          | •        | •          |
| TYA      |          |           | Assemb      | oler converts t | this to "LDA \$ | 81''         |          |          |          | •        | •          |

Flag Symbols: Z=Zero, C=Carry/Borrow, A=Test and Set if True, Cleared Otherwise, •= Not Affected

#### Table 6-7. MC6804P2 Microcomputer

| •                | [                 |                   |                   | Branch In         | structions        | <u> </u>          | · · · · · ·       |                   |   |
|------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|---|
| Hi               | 0<br>0000         | 1 0001            | 2<br>0010         | 3<br>0011         | <b>4</b><br>0100  | 5<br>0101         | 6<br>0110         | 7<br>0111         |   |
| 0<br>0000        | 2<br>BNE<br>1 REL | 2<br>BNE<br>1 REL | 2<br>BEQ<br>1 REL | 2<br>BEQ<br>1 REL | 2<br>BCC<br>1 REL | 2<br>BCC<br>1 REL | 2<br>BCS<br>1 REL | BCS<br>1 REL      |   |
| 1<br>0001        | 2<br>BNE<br>1 REL | 2<br>BNE<br>1 REL | 2<br>BEQ<br>1 REL | 2<br>BEQ<br>1 REL | 2<br>BCC<br>1 REL | 2<br>BCC<br>1 REL | 2<br>BCS<br>1 REL | 2<br>BCS<br>1 REL |   |
| 2<br>0010        | 2<br>BNE<br>1 REL | 2<br>BNE<br>1 REL | 2<br>BEQ<br>1 REL | 2<br>BEQ<br>1 REL | 2<br>BCC<br>1 REL | 2<br>BCC<br>1 REL | 2<br>BCS<br>1 REL | BCS<br>1 REL      |   |
| 3<br>0011        | 2<br>BNE<br>1 REL | 2<br>BNE<br>1 REL | 2<br>BEQ<br>1 REL | 2<br>BEQ<br>1 REL | 2<br>BCC<br>1 REL | 2<br>BCC<br>1 REL | BCS<br>1 REL      | 2<br>BCS<br>1 REL |   |
| <b>4</b><br>0100 | 2<br>BNE<br>1 REL | 2<br>BNE<br>1 REL | 2<br>BEQ<br>1 REL | 2<br>BEQ<br>1 REL | BCC<br>1 REL      | BCC<br>BCC<br>REL | 2<br>BCS<br>1 REL | 2<br>BCS<br>1 REL |   |
| 5<br>0101        | BNE<br>1 REL      | BNE<br>1 REL      | BEQ<br>1 REL      | BEQ<br>1 REL      | BCC<br>1 REL      | BCC<br>BCC<br>REL | BCS<br>1 REL      | BCS<br>BCS        |   |
| 6<br>0110        | BNE<br>1 REL      | BNE<br>1 REL      | 2<br>BEQ<br>1 REL | BEQ<br>1 REL      | BCC<br>1 REL      | BCC<br>1 REL      | BCS<br>1 REL      | BCS<br>1 REL      |   |
| 7<br>0111        | BNE<br>1 REL      | BNE<br>BNE<br>REL | BEQ<br>1 REL      | BEQ<br>1 REL      | BCC<br>1 REL      | BCC<br>BCC<br>REL | BCS<br>1 REL      | BCS<br>1 REL      |   |
| 8<br>1000        | BNE<br>BNE<br>REL | BNE<br>1 REL      | 2<br>BEQ<br>1 REL | 2<br>BEQ<br>1 REL | 2<br>BCC<br>1 REL | BCC<br>BCC<br>REL | 2<br>BCS<br>1 REL | BCS<br>1 REL      |   |
| 9<br>1001        | BNE<br>1 REL      | 2<br>BNE<br>1 REL | 2<br>BEQ<br>1 REL | BEQ<br>1 REL      | 2<br>BCC<br>1 REL | BCC<br>1 REL      | 2<br>BCS<br>1 REL | 2<br>BCS<br>1 REL |   |
| A<br>1010        | 2<br>BNE<br>1 REL | 2<br>BNE<br>2 REL | 2<br>BEQ<br>1 REL | 2<br>BEQ<br>1 REL | BCC<br>1 REL      | BCC<br>1 REL      | BCS<br>1 REL      | 2<br>BCS<br>1 REL |   |
| B<br>1011        | 2<br>BNE<br>1 REL | 2<br>BNE<br>1 REL | 2<br>BEQ<br>1 REL | 2<br>BEQ<br>1 REL | BCC<br>1 REL      | BCC<br>BCC<br>REL | 2<br>BCS<br>1 REL | 2<br>BCS<br>1 REL |   |
| C<br>1100        | 2<br>BNE<br>1 REL | 2<br>BNE<br>1 REL | BEQ<br>1 REL      | 2<br>BEQ<br>1 REL | BCC<br>BCC        | BCC<br>1 REL      | BCS<br>1 REL      | BCS<br>1 REL      |   |
| D<br>1101        | 2<br>BNE<br>1 REL | 2<br>BNE<br>1 REL | 2<br>BEQ<br>1 REL | BEQ<br>1 REL      | BCC<br>BCC<br>REL | 2<br>BCC<br>1 REL | BCS<br>1 REL      | 2<br>BCS<br>1 REL | i |
| E<br>1110        | 2<br>BNE<br>1 REL | 2<br>BNE<br>1 REL | 2<br>BEQ<br>1 REL | 2<br>BEQ<br>1 REL | BCC<br>1 REL      | 2<br>BCC<br>1 REL | 2<br>BCS<br>1 REL | 2<br>BCS<br>1 REL |   |
| F<br>1111        | 2<br>BNE<br>1 REL | 2<br>BNE<br>1 REL | 2<br>BEQ<br>1 REL | 2<br>BEQ<br>1 REL | 2<br>BCC<br>1 BEL | 2<br>BCC<br>1 REL | 2<br>BCS<br>1 REL | 2<br>BCS<br>1 REL |   |

Abbreviations for Address Modes

INH Inherent

- S-D Short Direct
- B-T-B Bit Test and Branch
- IMM Immediate
- DIR Direct
- EXT Extended
- REL Relative
- BSC Bit Set/Clear

R-IND Register Indirect

Indicates Instruction Reserved for Future Use Indicates Illegal Instruction

\*

#

3

# MC6804P2

# Instruction Set Opcode Map

|   | F             | egi<br>ead | ster/Memo<br>/Modify/W | ry, Control, a<br>/rite Instructio | nd |            | Bit Man<br>Instru | ipi<br>cti | ulation<br>ions | Register/Memory and<br>Read/Modify/Write |              |   |              |           |
|---|---------------|------------|------------------------|------------------------------------|----|------------|-------------------|------------|-----------------|------------------------------------------|--------------|---|--------------|-----------|
|   | 8             | Τ          | 9                      | A<br>1010                          | (  | B 1011     | C<br>1100         |            | D<br>1101       |                                          | E 1110       |   | F            | Hi        |
|   | 4<br>ISBn     | 4          | IMPn                   | *                                  | 4  | M\/I       | 5 BRCI PO         | 4          | BCLPO           | 4                                        |              | 4 |              | 0         |
|   | 2 EXT         | 2          | EXT                    |                                    | 3  | IMM        | 3 B-T-B           | 2          | BCENO           | 1                                        |              | 1 | R-IND        | 0000      |
|   | JSRn          | 4          | JMPn                   | *                                  | ł  | •          | 5 BRCLR1          | 4          | BCLR1           | 4                                        | STA          | 4 | STA          | 1         |
|   | 4 EXT         | 4          | EXI                    |                                    | 2  |            | 3 B-1-B           | 4          | BSC             | 4                                        | R-IND        | 4 | R-IND        | 0001      |
|   | JSRn<br>2 EXT | 2          | JMPn<br>EXT            | * .                                | 1  | RTI<br>INH | BRCLR2<br>з вт-в  | 2          | BCLR2<br>BSC    | 1                                        | ADD<br>R-IND | 1 | ADD<br>R-IND | 2<br>0010 |
|   | JSBn          | 4          | JMPn                   | *                                  | 2  | BTS        | 5<br>BBCLB3       | 4          | BCLB3           | 4                                        | SUB          | 4 | SUB          | 3         |
|   | 2 EXT         | 2          | EXT                    |                                    | 1  | INH        | 3 B-T-B           | 2          | BSC             | 1                                        | R-IND        | 1 | R-IND        | 0011      |
|   | JSRn          | 4          | JMPn                   | *                                  | 4  | COMA       | BRCLR4            | 4          | BCLR4           | 4                                        | СМР          | 4 | СМР          | 4         |
|   | 4 EXT         | 4          | EXI                    |                                    | 4  |            | 3 B-1-B           | 4          | BSC             | 4                                        | R-IND        | 4 |              | 0100      |
|   | JSRn<br>2 EXT | 2          | JMPn<br>EXT            | *                                  | 1  | ROLA       | BRCLR5<br>3 в-т-в | 2          | BCLR5<br>BSC    | 1                                        | AND<br>R-IND | 1 | AND<br>R-IND | 5<br>0101 |
|   | ISBn          | 4          | IMPn                   | *                                  |    | *          | 5<br>BBCLB6       | 4          | BCI B6          | 4                                        |              | 4 | INC          | 6         |
|   | 2 EXT         | 2          | EXT                    |                                    |    |            | 3 B-T-B           | 2          | BSC             | 1                                        | R-IND        | 1 | R-IND        | 0110      |
| 1 | JSRn          | 4          | JMPn                   | *                                  |    | *          | BRCLR7            | 4          | BCLR7           | 4                                        | DEC          | 4 | DEC          | 7         |
|   |               | 4          | EXI                    | 4                                  | 4  |            | 3 B I B<br>5      | 4          | BSC             | 4                                        | R-IND        | 4 | R-IND        | 0111      |
|   | JSRn<br>2 EXT | 2          | JMPn<br>EXT            | INC<br>1 S-D                       | 1  | DEC<br>s-d | BRSET0<br>3 в-т-в | 2          | BSET0<br>BSC    | 2                                        | L'DA<br>IMM  | 2 |              | 8<br>1000 |
|   | ISBn          | 4          | IMPn                   | 4<br>INC                           | 4  | DEC        | 5<br>BRSET1       | 4          | BSET1           |                                          | #            | 4 | STA          | 0         |
|   | 2 EXT         | 2          | EXT                    | 1                                  | 1  | S-D        | 3 B-T-B           | 2          | BSC             |                                          |              | 2 | DIR          | 1001      |
| ľ | JSRn          | 4          | JMPn                   | 4 INC                              | 4  | DEC        | 5 BRSET2          | 4          | BSET2           | 4                                        | ADD          | 4 | ADD          | А         |
|   | 2 EXT         | 2          | EXT                    | 1 S-D                              | 1  | S-D        | 3 B-T-B           | 2          | BSC             | 2                                        | IMM          | 2 | DIR          | 1010      |
|   | JSRn<br>2 EXT | 2          | JMPn<br>EXT            | INC<br>1 S-D                       | 1  | DEC<br>s-d | BRSET3<br>3 B·T·B | 2          | BSET3<br>BSC    |                                          | SUB<br>IMM   | 2 |              | B<br>1011 |
|   | ISBn          | 4          | IMPn                   | 4<br>1 D A                         | 4  | STA        | 5 BRSETA          | 4          | BSETA           | 4                                        | CMP          |   | CMP          | C         |
|   | 2 EXT         | 2          | EXT                    | 1S-D                               | 1  | S-D        | 3 B-T-B           | 2          | BSC             | 2                                        |              |   | DIR          | 1100      |
| 1 | JSRn          | 4          | JMPn                   | 4<br>LDA                           | 4  | STA        | 5<br>BRSET5       | 4          | BSET5           | 4                                        | AND          | 4 | AND          | D         |
|   | EXT           | 2          | EXT                    | 1 S-D                              | 1  | S-D        | 3 B-T-B           | 2          | BSC             | 2                                        | IMM          | 2 | DIR          | 1101      |
|   | JRSn          |            | JMPn                   | LDA                                | 4  | STA        | BRSET6            | 4          | BSET6           |                                          | #            | 4 | INC          | E         |
|   |               | 4          |                        | 4                                  | 4  | 0.7.4      | 5                 | 4          | 830             | -                                        |              | 4 | DIR          |           |
| : | JSRn<br>2 EXT | 2          | JMPn<br>EXT            | LDA<br>1 S-D                       | 1  | STA<br>S-D | BRSET7<br>з в-т-в | 2          | BSE17<br>BSC    |                                          | #            | 2 | DEC          | F<br>1111 |





# SECTION 7 ELECTRICAL SPECIFICATIONS

#### 7.1 INTRODUCTION

This section contains the electrical specifications and associated timing for the MC6804P2.

#### 7.2 MAXIMUM RATINGS

| Rating                                                     | Symbol | Value             | Unit |
|------------------------------------------------------------|--------|-------------------|------|
| Supply Voltage                                             | VCC    | -0.3 to +7.0      | V    |
| Input Voltage                                              | Vin    | -0.3 to +7.0      | V    |
| Operating Temperature Range (Comm.)                        | TA     | 0 to 70           | °C   |
| Operating Temperature Range (Ind.)                         | Тд     | - 40 to 85        | °C   |
| Storage Temperature Range                                  | Tstg   | - 55 to 150       | °С   |
| Junction Temperature Range<br>Plastic<br>Ceramic<br>Cerdip | Tj     | 150<br>175<br>175 | °C/W |

This device contains circuitry to protect the inputs against damage due to high static voltages of electric fields; however, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit. For proper operation its recommended that  $V_{in}$  and  $V_{out}$  be constrained to the range  $V_{SS} \leq (V_{in} \text{ or } V_{out}) \leq V_{CC}$ . Reliability of operation is enhanced if unused inputs except EXTAL are connected to an appropriate logic voltage level (e.g., either  $V_{SS} \text{ or } V_{CC}$ ).

#### 7.3 THERMAL CHARACTERISTICS

| Characteristic     | Symbol | Value | Unit |
|--------------------|--------|-------|------|
| Thermal Resistance |        |       |      |
| Plastic            |        | 70    |      |
| Ceramic            | θια    | 50    | °C/W |
| Cerdip             |        | 60    |      |



Test Load (Port B)

Figure 7-2. CMOS Equivalent Test Load (Ports A, B, C)



#### 7.4 POWER CONSIDERATIONS

The average chip-junction temperature, TJ, in °C can be obtained from:  $T_{J} = T_{A} + (P_{D} \cdot \theta_{J}_{A})$ (1) Where:  $T_{A} = Ambient Temperature, °C$   $\theta_{JA} = Package Thermal Resistance, Junction-to-Ambient, °C/W$   $P_{D} = P_{INT} + P_{PORT}$   $P_{INT} = I_{CC} \times V_{CC}, Watts - Chip Internal Power$   $P_{PORT} = Port Power Dissipation, Watts - User Determined$ 

For most applications PPORT ≪PINT and can be neglected. PPORT may become significant if the device is configured to drive Darlington bases or sink LED loads.

An approximate relationship between PD and TJ (if PPORT is neglected) is:

 $P_{D} = K \div (T_{J} + 273^{\circ}C)$ 

Solving equations 1 and 2 for K gives:

 $K = P_{D} \cdot (T_{A} + 273^{\circ}C) + \theta_{JA} \cdot P_{D}^{2}$ 

Where K is a constant pertaining to the particular part. K can be determined from equation 3 by measuring P<sub>D</sub> (at equilibrium) for a known T<sub>A</sub>. Using this value of K the values of P<sub>D</sub> and T<sub>J</sub> can be obtained by solving equations (1) and (2) iteratively for any value of T<sub>A</sub>.

# **7.5 ELECTRICAL CHARACTERISTICS** (V<sub>CC</sub> = +5.0 Vdc $\pm$ 0.5 Vdc, V<sub>SS</sub> = 0 Vdc, T<sub>A</sub> = 0°C to 70°C, unless otherwise noted)

| Characteristic                             | Symbol          | Min   | Тур | Max | Unit |
|--------------------------------------------|-----------------|-------|-----|-----|------|
| Internal Power Dissipation-No Port Loading | PINT            |       | 150 | -   | mW   |
| Input High Voltage                         | ViH             | 2.0   | -   | Vcc | V    |
| Input Low Voltage                          | VIL             | - 0.3 | -   | 0.8 | V    |
| Input Capacitance                          | C <sub>in</sub> |       | 10  | -   | pF   |
| Input Current (IRQ, RESET)                 | lin             |       | 2   | 20  | μΑ   |

# **7.6 SWITCHING CHARACTERISTICS** ( $V_{CC} = +5.0 \text{ Vdc} \pm 0.5 \text{ Vdc}$ ; $V_{SS} = \text{GND}$ , $T_A = 0^{\circ}\text{C}$ to 70°C, unless otherwise noted)

| Characteristic                                               |                  | Min                 | Тур | Max  | Unit |
|--------------------------------------------------------------|------------------|---------------------|-----|------|------|
| Oscillator Frequency                                         | fosc             | 4.0                 |     | 11.0 | MHz  |
| Bit Time                                                     | <sup>t</sup> bit | 0.364               |     | 1.0  | μs   |
| Byte Cycle Time                                              | tbyte            | 4.36                |     | 12.0 | μs   |
| IRO and TIMER Pulse Width                                    | tWL, tWH         | 2xt <sub>byte</sub> | -   | -    | -    |
| RESET Pulse Width                                            | trwl             | 2xt <sub>byte</sub> | -   | -    |      |
| <b>RESET</b> Delay Time (External Capacitance = 1.0 $\mu$ F) | <sup>t</sup> RHL | 100                 | -   |      | ms   |

(2)

(3)

# 7.7 PORT DC ELECTRICAL CHARACTERISTICS ( $V_{CC} = +5.0 \text{ Vdc} \pm 0.5 \text{ Vdc}$ , $V_{SS} = \text{GND}$ , $T_A = 0^{\circ}\text{C}$ to 70°C, unless otherwise noted)

| Characteristic                                           | Symbol          | Min                  | Typ   | Max   | Unit           |
|----------------------------------------------------------|-----------------|----------------------|-------|-------|----------------|
| Ports A and C (Standard)                                 | 1 - ,           |                      | .,,,, |       | 1              |
| Output Low Voltage, II oad = 0.4 mA                      | Vol             | -                    | -     | 0.5   | V              |
| Output High Voltage, $I_{l oad} = -50 \ \mu A$           | VOH             | 2.3                  | _     | -     | V              |
| Input High Voltage                                       | V <sub>1H</sub> | 2.0                  | _     | Vcc   | V              |
| Input Low Voltage                                        | VII             | - 0.3                |       | 0.8   | V              |
| Hi-Z State Input Current                                 | ITSI            | _                    | 4     | 40    | μA             |
| Ports A and C (Open Drain                                | n)              |                      |       |       |                |
| Output Low Voltage, ILoad=0.4 mA                         | VOL             | -                    | ~     | 0.5   | V              |
| Input High Voltage                                       | VIH             | ·2.0                 | _     | Vcc   | V              |
| Input Low Voltage                                        | VIL             | - 0.3                | _     | 0.8   | V              |
| Hi-Z State Input Current                                 | ITSI            | ~                    | 4     | 40    | μA             |
| Open Drain Leakage (V <sub>out</sub> = V <sub>CC</sub> ) | LOD             | -                    | 4     | 40    | . μΑ           |
| Ports A and C (CMOS Driv                                 | e)              |                      |       |       |                |
| Output Low Voltage, I <sub>Load</sub> =0.4 mA (Sink)     | VOL             | -                    | -     | 0.5   | V              |
| Output High Voltage, $I_{Load} = -10 \ \mu A$            | ∨он             | V <sub>CC</sub> -1.0 | -     | -     | V              |
| Output High Voltage, $I_{Load} = -100 \mu A$             | VOH             | 2.3                  | -     | -     | V <sup>1</sup> |
| Input High Voltage, ILoad = - 300 µA Max                 | VIH             | 2.0                  | -     | VCC   | V              |
| Input Low Voltage, ILoad = - 300 µA Max                  | VIL             | - 0.3                |       | 0.8   | V              |
| Hi-Z State Input Current (Vin=0.4 V to VCC)              | ITSI            | _                    | -     | - 300 | μA             |
| Port B (Standard)                                        |                 |                      |       |       |                |
| Output Low Voltage, I <sub>Load</sub> = 1.0 mA           | VOL             | -                    |       | 0.5   | V              |
| Output Low Voltage, ILoad = 10 mA (Sink)                 | VOL             | -                    | -     | 1.5   | V              |
| Output High Voltage, I <sub>Load</sub> = - 100 µA        | Vон             | 2.3                  | -     | -     | V              |
| Input High Voltage                                       | VIH             | 2.0                  |       | Vcc   | V              |
| Input Low Voltage                                        | VIL             | - 0.3                | -     | 0.8   | V              |
| Hi-Z State Input Current                                 | ITSI            | -                    | 8     | 80    | μA             |
| Port B (Open Drain)                                      |                 |                      |       |       |                |
| Output Low Voltage, I <sub>LOad</sub> = 1.0 mA           | VOL             | -                    | -     | 0.5   | V              |
| Output Low Voltage, I <sub>Load</sub> = 10 mA (Sink)     | Vol             | -                    | -     | 1.5   | V              |
| Input High Voltage                                       | V <sub>1H</sub> | 2.0                  | _     | Vcc   | V              |
| Input Low Voltage                                        | VIL             | -0.3                 |       | 0.8   | V              |
| Hi-Z State Input Current                                 | ITSI            | -                    | 8     | 80    | μΑ             |
| Open Drain Leakage (V <sub>out</sub> = V <sub>CC</sub> ) | LOD             | -                    | 8     | 80    | μA             |
| Port B (CMOS Drive)                                      |                 |                      |       |       |                |
| Output Low Voltage, ILoad = 1.0 mA                       | VOL             | -                    | ·     | 0.5   | V              |
| Output High Voltage, ILoad = 10 mA (Sink)                | VOL             | -                    | . –   | 1.5   | V.             |
| Output High Voltage, $I_{Load} = -10 \ \mu A$            | VOH             | V <sub>CC</sub> -1.0 | -     | -     | V              |
| Output High Voltage, $I_{Load} = -50 \ \mu A$            | ∨он             | 2.3                  |       | -     | V              |
| Input High Voltage, I <sub>Load</sub> = - 300 µA Max     | VIH             | 2.0                  | -     | Vcc   | V              |
| Input Low Voltage, $I_{Load} = -300 \ \mu A Max$         | VIL             | -0.3                 |       | 0.8   | V              |
| Hi-Z State Input Current (Vin=0.4 V to VCC)              | ITSI            | _                    | _     | - 300 | μA             |

# SECTION 8 ORDERING INFORMATION

#### 8.1 INTRODUCTION

The following information is required when ordering a custom MCU. The information may be transmitted to Motorola in the following media:

EPROM(s), MCM2716 or MCM2532 MDOS, disk file

To initiate a ROM pattern for the MCU, it is necessary to first contact your local field service office, local sales person, or your local Motorola representative.

#### 8.1.1 EPROMs

An MCM2716 or MCM2532 type EPROM, programmed with the customer program (positive logic sense for address and data), may be submitted for pattern generation. Since all program and data space information will fit on one MCM2716 or MCM2532 EPROM, the EPROM must be programmed as follows in order to emulate the MC6804P2 MCU. For an MCM2716, start the data space ROM at EPROM address \$020 and start program space ROM at EPROM address \$400 and continue to memory space \$7FF. Memory space \$7F8 through \$7FB are reserved for Motorola self-test vectors. For an MCM2532, the memory map shown in Figure 2-1 can be used. All unused bytes, including the user's space, must be set to zero. For shipment to Motorola, the EPROMs should be placed in a conductive IC carrier and packed securely. Do not use styrofoam.

#### 8.1.2 MDOS Disk File

An MDOS disk, programmed with the customer program (positive logic sense for address and data), may be submitted for pattern generation. When using the MDOS disk, include the entire memory image of both data and program space. All unused bytes, including the user's space, must be set to zero.

#### 8.2 VERIFICATION MEDIA

All original pattern media (EPROMs or floppy disk) are filed for contractual purposes and are not returned. A computer listing of the ROM code will be generated and returned along with a listing verification form. The listing should be thoroughly checked and the verification form completed, signed, and returned to Motorola. The signed verification form constitutes the contractural agreement for creation of the customer mask. If desired, Motorola will program a blank MCM2716, MCM2532, or MDOS disk (**supplied by the customer**) from the data file used to create the custom mask to aid in the verification process.

#### 8.3 ROM VERIFICATION UNITS (RVUs)

Ten MCUs containing the customer's ROM pattern will be sent for program verification. These units will have been made using the custom mask but are for the purpose of ROM verification only. For expediency they are usually unmarked, packaged in ceramic, and tested only at room temperature and five volts. These RVUs are included in the mask charge and are not production parts. These RVUs are not backed nor guaranteed by Motorola Quality Assurance.

#### 8.4 FLEXIBLE DISKS

The disk media submitted must be single-sided, single density, 8-inch, MDOS compatible floppies. The customer must clearly label the disk with the ROM pattern file name. The minimum MDOS system files as well as the absolute binary object file (filename.LO type of file) from the M6805 cross assembler must be on the disk. An object file made from a memory dump; using the ROLLOUT command is also admissable. Consider submitting a source listing as well as: filename, .LX (EXORciser loadable format). This file will of course be kept confidential and is used 1) to speed up the process in house if any problems arise, and 2) to speed up our customer to factory interface if a user finds any software errors and needs assistance quickly from the factory representative.

MDOS is Motorola's Disk Operating System available on development systems such as EXORciser, EXORset, etc.

# MC6804P2

#### **OPTION LIST**

Select the options for the MCU from the following list. A manufacturing mask will be generated from this information. Select one in each section.

| Internal Oscillator Input |                |                                        |            |  |
|---------------------------|----------------|----------------------------------------|------------|--|
| Crystal                   |                |                                        |            |  |
| Resistor-Capacito         | r              |                                        |            |  |
| Interrupt Trigger         |                |                                        |            |  |
| 🗆 Edge-Sensitive          |                |                                        |            |  |
| Level- and Edge-          | Sensitive      |                                        |            |  |
| Output Drive (Select one  | Option per Por | t)                                     |            |  |
|                           | LSTTL          | CMOS/LSTTL                             | Open Drain |  |
| Port A                    |                |                                        |            |  |
| Port B                    |                |                                        |            |  |
| Port C                    |                |                                        |            |  |
| Customer Name             |                |                                        |            |  |
| Address                   |                | ······                                 |            |  |
| City                      |                | State                                  | Zip        |  |
| Phone ( )                 | E              | xtension                               | ·          |  |
| Contact Ms/Mr             |                | · · · · · · · · · · · · · · · · · · ·  |            |  |
| Customer Part Number      |                |                                        |            |  |
|                           |                |                                        |            |  |
| Pattern Media             |                |                                        |            |  |
| □ MCM2532 EPROM           |                |                                        |            |  |
| ☐ MCM2716 EPROM           |                |                                        |            |  |
| MDOS Disk File  (Nata)    |                |                                        |            |  |
|                           |                | ······································ |            |  |
|                           |                |                                        |            |  |

Note: Other Media require prior factory approval.

Signature\_\_\_\_\_\_

Figure 8.1 Ordering Form

# SECTION 9 MECHANICAL DATA

This section contains the pin assignment and package dimension diagrams for the MC6804P2 microcomputer.

#### 9.1 PIN ASSIGNMENT

| 1                 |    | _  |              |
|-------------------|----|----|--------------|
| vssC              |    | 28 | RESET        |
|                   | 2  | 27 | PA7          |
| v <sub>cc</sub> d | 3  | 26 | PA6          |
| EXTAL             | 4  | 25 | PA5          |
| XTAL C            | 5  | 24 | PA4          |
|                   | 6  | 23 | PA3          |
| TIMER 🕻           | 7  | 22 | PA2          |
| РС0 🕻             | 8  | 21 | DPA1         |
| PC1 🖸             | 9  | 20 | DPA0         |
| PC2 🕻             | 10 | 19 | р РВ7        |
| РСЗ 🕻             | 11 | 18 | р РВ6        |
| РВО 🕻             | 12 | 17 | р РВ5        |
| РВ1 🕻             | 13 | 16 | р РВ4        |
| РВ2 🕻             | 14 | 15 | <b>1</b> PB3 |
|                   |    |    |              |