## M68HC16 Family

## **MC68HC16Z1**

USER'S MANUAL



MC68HC16Z

**USER'S MANUAL** 

| Introduction                             | 1 |
|------------------------------------------|---|
| Nomenclature                             | 2 |
| Overview                                 | 3 |
| System Integration Module                | 4 |
| Central Processing Unit                  | 5 |
| Analog-to-Digital Converter              | 6 |
| Queued Serial Module                     | 7 |
| General-Purpose Timer                    | 8 |
| Standby RAM Module                       | 9 |
| Electrical Characteristics               | Α |
| Ordering Information and Mechanical Data | В |
| Development Support                      | С |
| Register Summary                         |   |
|                                          |   |

Index

| 1 | Introduction                             |
|---|------------------------------------------|
| 2 | Nomenclature                             |
| 3 | Overview                                 |
| 4 | System Integration Module                |
| 5 | Central Processing Unit                  |
| 6 | Analog-to-Digital Converter              |
| 7 | Queued Serial Module                     |
| 8 | General-Purpose Timer                    |
| 9 | Standby RAM Module                       |
| Α | Electrical Characteristics               |
| В | Ordering Information and Mechanical Data |
| С | Development Support                      |
| D | Register Summary                         |
|   | Index                                    |

### MC68HC16Z1 USER'S MANUAL

#### TABLE OF CONTENTS

#### Paragraph

#### Title

Page

#### Section 1 Introduction

#### Section 2 Nomenclature

| 2.1 | Symbols and Operators    |     |
|-----|--------------------------|-----|
| 2.2 | CPU16 Registers          |     |
| 2.3 | Pin and Signal Mnemonics |     |
| 2.4 | Register Mnemonics       | 2–5 |
| 2.5 | Conventions              |     |

#### Section 3 Overview

| 3.1   | MC68HC16Z1 Features                              | 3–1 |
|-------|--------------------------------------------------|-----|
| 3.1.1 | System Integration Module                        | 3–1 |
| 3.1.2 | CPU16                                            | 3–1 |
| 3.1.3 | Analog-to-Digital Converter                      |     |
| 3.1.4 | Queued Serial Module                             |     |
| 3.1.5 | General-Purpose Timer                            |     |
| 3.1.6 | Standby Ram                                      |     |
| 3.2   | System Block Diagram and Pin Assignment Diagrams | 3–2 |
| 3.3   | Pin Descriptions                                 |     |
| 3.4   | Signal Descriptions                              |     |
| 3.5   | Intermodule Bus                                  |     |
| 3.6   | System Memory Maps                               |     |
| 3.6.1 | Internal Register Map                            |     |
| 3.6.2 | System Memory Maps                               |     |
| 3.7   | System Reset                                     |     |
| 3.7.1 | System Reset Mode Selection                      |     |
| 3.7.2 | MCU Module Pin Function During Reset             |     |
|       |                                                  |     |

MOTOROLA

#### Paragraph

#### Title

Page

#### Section 4 System Integration Module

| 4.1      | System Configuration and Protection4-2 |
|----------|----------------------------------------|
| 4.1.1    | Module Mapping4-4                      |
| 4.1.2    | Interrupt Arbitration4-4               |
| 4.1.3    | Show Internal Cycles4-4                |
| 4.1.4    | Factory Test Mode4-5                   |
| 4.1.5    | Register Access4-5                     |
| 4.1.6    | Reset Status4-5                        |
| 4.1.7    | Bus Monitor4-5                         |
| 4.1.8    | Halt Monitor4-6                        |
| 4.1.9    | Spurious Interrupt Monitor4-6          |
| 4.1.10   | Software Watchdog4-6                   |
| 4.1.11   | Periodic Interrupt Timer4-8            |
| 4.1.12   | Low-Power STOP Operation 4-10          |
| 4.1.13   | Freeze Operation                       |
| 4.2      | System Clock                           |
| 4.2.1    | Clock Sources 4-11                     |
| 4.2.2    | Clock Synthesizer Operation 4-12       |
| 4.2.3    | External Bus Clock 4-18                |
| 4.2.4    | Low-Power Operation 4–18               |
| 4.2.5    | Loss of Reference Signal 4-19          |
| 4.3      | External Bus Interface 4-19            |
| 4.3.1    | Bus Signals 4–21                       |
| 4.3.1.1  | Address Bus 4-21                       |
| 4.3.1.2  | Address Strobe 4-21                    |
| 4.3.1.3  | Data Bus 4-21                          |
| 4.3.1.4  | Data Strobe4-22                        |
| 4.3.1.5  | Read/Write Signal 4-22                 |
| 4.3.1.6  | Size Signals                           |
| 4.3.1.7  | Function Codes4-22                     |
| 4.3.1.8  | Data and Size Acknowledge Signals      |
| 4.3.1.9  | Bus Error Signal 4–23                  |
| 4.3.1.10 |                                        |
| 4.3.1.11 | Autovector Signal 4-24                 |
| 4.3.2    | Dynamic Bus Sizing                     |
| 4.3.3    | Operand Alignment 4-25                 |
| 4.3.4    | Misaligned Operands 4-25               |
| 4.3.5    | Operand Transfer Cases 4-26            |

iv

Title

#### MC68HC16Z1

**USER'S MANUAL** 

Paragraph

| 4.3.5.1  | Byte Operand to 8-Bit Port (ADDR0 = 0/1)      |      |
|----------|-----------------------------------------------|------|
| 4.3.5.2  | Byte Operand to 16-Bit Port, Even (ADDR0 = 0) | 4–28 |
| 4.3.5.3  | Byte Operand to 16-Bit Port, Odd (ADDR0 = 1)  | 4–29 |
| 4.3.5.4  | Word Operand to 8-Bit Port, Aligned           | 4–30 |
| 4.3.5.5  | Word Operand to 8-Bit Port, Misaligned        | 4–31 |
| 4.3.5.6  | Word Operand to 16-Bit Port, Aligned          | 4–32 |
| 4.3.5.7  | Word Operand to 16-Bit Port, Misaligned       | 4–33 |
| 4.3.5.8  | Long-Word Operand to 8-Bit Port, Aligned      | 4–34 |
| 4.3.5.9  | Long-Word Operand to 8-Bit Port, Misaligned   | 4–35 |
| 4.3.5.10 | Long-Word Operand to 16-Bit Port, Aligned     | 4–36 |
| 4.3.5.11 | Long-Word Operand to 16-Bit Port, Misaligned  | 4–37 |
| 4.4      | Bus Operation                                 |      |
| 4.4.1    | Synchronization to CLKOUT                     | 4–38 |
| 4.4.2    | Regular Bus Cycles                            | 4–39 |
| 4.4.2.1  | Read Cycle                                    | 4–40 |
| 4.4.2.2  | Write Cycle                                   | 4–42 |
| 4.4.3    | Fast Termination Cycles                       | 4–43 |
| 4.4.3.1  | Fast-Termination Read Cycle                   | 4–45 |
| 4.4.3.2  | Fast-Termination Write Cycle                  | 4–45 |
| 4.4.4    | CPU Space Cycles                              | 4–46 |
| 4.4.4.1  | Breakpoint Acknowledge Cycle                  | 4–47 |
| 4.4.4.2  | LPSTOP Broadcast Cycle                        | 4–50 |
| 4.4.5    | Bus Exception Control Cycles                  | 4–50 |
| 4.4.5.1  | Bus Errors                                    | 4–52 |
| 4.4.5.2  | Double Bus Faults                             | 4–52 |
| 4.4.5.3  | Halt Operation                                | 4–53 |
| 4.4.6    | External Bus Arbitration                      | 4–54 |
| 4.4.6.1  | Bus Request                                   | 4–56 |
| 4.4.6.2  | Bus Grant                                     | 4–57 |
| 4.4.6.3  | Bus Grant Acknowledge                         | 4–57 |
| 4.4.6.4  | Bus Arbitration Control.                      | 4–57 |
| 4.4.6.5  | Slave (Factory Test) Mode Arbitration         | 4–59 |
| 4.4.6.6  | Show Cycles                                   | 4–59 |
| 4.5 F    | Reset                                         |      |
| 4.5.1    | Reset Exception Processing                    | 4–60 |
| 4.5.2    | Reset Control Logic                           |      |
| 4.5.3    | Reset Mode Selection                          |      |
| 4.5.3.1  | Data Bus Mode Selection                       |      |
| 4.5.3.2  | Clock Mode Selection                          |      |
| 4.5.3.3  | Breakpoint Mode Selection                     | 4–64 |
|          |                                               |      |

#### ۷

| Paragrap         | h Title                                             | Page    |
|------------------|-----------------------------------------------------|---------|
| 4.5.4            | MCU Module Pin Function During Reset                | 4–65    |
| 4.5.5            | Pin State During Reset                              |         |
| 4.5.5.1          | Reset States of SIM Pins                            |         |
| 4.5.5.2          | Reset States of Pins Assigned to Other MCU Modul    | es 4–67 |
| 4.5.6            | Reset Timing                                        |         |
| 4.5.7            | Power-On Reset                                      |         |
| 4.5.7.1          | Use of Three-State Control Pin                      | 4–70    |
| 4.5.8            | Reset Processing Summary                            |         |
| 4.5.9            | Reset Status Register                               |         |
| 4.6              | Interrupts                                          | 4–72    |
| 4.6.1            | Interrupt Exception Processing                      |         |
| 4.6.2            | Interrupt Priority and Recognition                  | 4–72    |
| 4.6.3            | Interrupt Acknowledge and Arbitration               | 4–73    |
| 4.6.4            | Interrupt Processing Summary                        | 4–75    |
| 4.6.5            | Interrupt Acknowledge Bus Cycles                    | 4–76    |
| 4.6.5.1          | External Bus Cycle Terminated by Data and Size      |         |
|                  | Acknowledge Signals                                 |         |
| 4.6.5.2          | External Bus Cycle Terminated by External Autovec   | tor     |
|                  | Signal                                              |         |
| 4.6.5.3          | Spurious Interrupt Cycle                            |         |
| 4.7              | Chip Selects                                        |         |
| 4.7.1            | Chip-Select Registers                               |         |
| 4.7.1.1          | Chip-Select Pin Assignment Registers                |         |
| 4.7.1.2          | Chip-Select Base Address Registers                  |         |
| 4.7.1 <i>.</i> 3 | Chip-Select Option Registers                        |         |
| 4.7.1.4          | Port C Data Register                                |         |
| 4.7.2            | Chip-Select Operation                               |         |
| 4.7.3            | Using Chip-Select Signals for Interrupt Acknowledge |         |
| 4.7.4            | Chip-Select Reset Operation                         |         |
| 4.8              | Parallel Input/Output Ports                         |         |
| 4.8.1            | Pin Assignment Registers                            |         |
| 4.8.2            | Data Direction Registers                            |         |
| 4.8.3            | Data Registers                                      |         |
| 4.9              | Factory Test                                        | 4–97    |

#### Section 5 Central Processing Unit

| 5.1   | Register Model  |
|-------|-----------------|
| 5.1.1 | Accumulators5-3 |

| Paragrap | h Title                                                 | Page |
|----------|---------------------------------------------------------|------|
| 5.1.2    | Index Registers                                         | 5–3  |
| 5.1.3    | Stack Pointer                                           | 5–3  |
| 5.1.4    | Program Counter                                         | 5–4  |
| 5.1.5    | Condition Code Register                                 | 5–4  |
| 5.1.6    | Address Extension Register and Address Extension Fields | 5–5  |
| 5.1.7    | Multiply and Accumulate Registers                       | 5–5  |
| 5.2      | Memory Management                                       | 5–6  |
| 5.2.1    | Address Extension                                       | 5–6  |
| 5.2.2    | Extension Fields                                        | 5–6  |
| 5.3      | Data Types                                              | 5–6  |
| 5.4      | Memory Organization                                     | 5–7  |
| 5.5      | Addressing Modes                                        |      |
| 5.5.1    | Immediate Addressing Modes                              | 5–10 |
| 5.5.2    | Extended Addressing Modes                               | 5–10 |
| 5.5.3    | Indexed Addressing Modes                                | 5–10 |
| 5.5.4    | Inherent Addressing Mode                                | 5–10 |
| 5.5.5    | Accumulator Offset Addressing Mode                      | 5–11 |
| 5.5.6    | Relative Addressing Modes                               | 5–11 |
| 5.5.7    | Post-Modified Index Addressing Mode                     | 5–11 |
| 5.5.8    | Use of HC16 Indexed Mode to Replace HC11 Direct Mode    | 5–11 |
| 5.6      | Instruction Set                                         |      |
| 5.6.1    | Data Movement Instructions                              | 5–11 |
| 5.6.1.1  | Load Instructions                                       | 5–12 |
| 5.6.1.2  | Move Instructions                                       | 5–12 |
| 5.6.1.3  | Store Instructions                                      | 5–13 |
| 5.6.1.4  | Transfer Instructions                                   | 5–13 |
| 5.6.1.5  | Exchange Instructions                                   | 5–14 |
| 5.6.2    | Mathematic Instructions                                 | 5–14 |
| 5.6.2.1  | Addition and Subtraction Instructions                   | 5–14 |
| 5.6.2.2  | Binary Coded Decimal Instructions                       | 5–15 |
| 5.6.2.3  | Compare and Test Instructions                           | 5–16 |
| 5.6.2.4  | Multiplication and Division Instructions                | 5–16 |
| 5.6.2.5  | Decrement and Increment Instructions                    | 5–17 |
| 5.6.2.6  | Clear, Complement and Negate Instructions               | 5–18 |
| 5.6.2.7  | Boolean Logic Instructions                              |      |
| 5.6.3    | Bit Test and Manipulation Instructions                  | 5–19 |
| 5.6.4    | Shift and Rotate Instructions                           |      |
| 5.6.5    | Program Control Instructions                            | 5–23 |
| 5.6.5.1  | Short Branch Instructions                               | 5–23 |
| 5.6.5.2  | Long Branch Instructions                                | 5–25 |

MOTOROLA

#### vii

#### Daga

#### Paragraph Title Page 5.6.5.3 5.6.5.4 5.6.5.5 5.6.5.6 5.6.6 5.6.6.1 5.6.6.2 5.6.7 5.6.8 5.6.9 5.6.10 Stop and Wait Instructions ...... 5-36 5.6.11 Background Mode and Null Operations ...... 5-37 5.6.12 Instruction Set Summary......5-38 Comparison of CPU16 and MC68HC11 Instruction Sets...... 5-55 5.7 5.8 5.9 5.9.1 5.9.2 5.9.3 5.10 Execution Process 5-60 5.10.1 5.11 5.12 5.12.1 5.12.2 5.12.3 5.12.4 5.12.4.1 5.12.4.2 Synchronous Exceptions ...... 5-64 5.12.5 5.12.6 5.13 5.13.15.13.1.1 IPIPE0/IPIPE1 Multiplexing......5-65 Combining Opcode Tracking with Other Capabilities.......... 5-66 5.13.1.2 5.13.2 Breakpoints......5-66 5.13.3 Opcode Tracking and Breakpoints......5-67 5.13.4 Background Debugging Mode......5-67 Enabling BDM ...... 5-67 5.13.4.1 5.13.4.2

#### Paragraph

#### Title

Page

| 1 BKPT Signal             |                                                                            |
|---------------------------|----------------------------------------------------------------------------|
|                           |                                                                            |
| Entering BDM              |                                                                            |
|                           |                                                                            |
| Returning from BDM        | 5–69                                                                       |
|                           |                                                                            |
| Digital Signal Processing | 5–71                                                                       |
|                           | Entering BDM<br>BDM Commands<br>Returning from BDM<br>BDM Serial Interface |

#### Section 6 Analog-to-Digital Converter

| 6.1     | Overview                                  | 1 |
|---------|-------------------------------------------|---|
| 6.2     | External Connections                      | 1 |
| 6.2.1   | Analog Input Pins6-3                      | 3 |
| 6.2.2   | Analog Reference Pins6-3                  | 3 |
| 6.2.3   | Analog Supply Pins6-3                     | 3 |
| 6.3     | Programmer's Model6-3                     | 3 |
| 6.4     | ADC Bus Interface Unit                    | 4 |
| 6.5     | Special Operating Modes                   | 4 |
| 6.5.1   | Low-Power Stop Mode6-4                    | 4 |
| 6.5.2   | Freeze Mode6-4                            | 4 |
| 6.6     | Analog Subsystem6-4                       | 5 |
| 6.6.1   | Multiplexer6-4                            | 5 |
| 6.6.2   | Sample Capacitors and Buffer Amplifier6-0 | 6 |
| 6.6.3   | RC DAC Array6-0                           | 6 |
| 6.6.4   | Comparator6-                              | 7 |
| 6.7     | Digital Control Subsystem6-               | 7 |
| 6.7.1   | Control/Status Registers6-                | 7 |
| 6.7.2   | Clock and Prescaler Control6-             |   |
| 6.7.3   | Sample Time6-4                            | 8 |
| 6.7.4   | Resolution6-4                             | 8 |
| 6.7.5   | Conversion Control Logic6-4               | 9 |
| 6.7.5.1 | Conversion Parameters6-4                  | 9 |
| 6.7.5.2 | Conversion Modes6-4                       | 9 |
| 6.7.6   | Conversion Timing6-14                     | 4 |
| 6.7.7   | Successive Approximation Register         | 7 |
| 6.7.8   | Result Registers 6-1                      | 7 |

MOTOROLA ix

#### Paragraph

#### Title

Page

#### Section 7 Queued Serial Module

| 7.1     | General7-1                         |
|---------|------------------------------------|
| 7.2     | QSM Registers and Address Map7-2   |
| 7.2.1   | QSM Global Registers7-3            |
| 7.2.1.1 | Low-power Stop Operation7-3        |
| 7.2.1.2 | Freeze Operation7-3                |
| 7.2.1.3 | QSM Interrupts7-4                  |
| 7.2.2   | QSM Pin Control Registers7-5       |
| 7.3     | Queued Serial Peripheral Interface |
| 7.3.1   | QSPI Registers7-7                  |
| 7.3.1.1 | Control Registers7-8               |
| 7.3.1.2 | Status Register7-8                 |
| 7.3.2   | QSPI RAM                           |
| 7.3.2.1 | Receive Data RAM7-8                |
| 7.3.2.2 | Transmit Data RAM7-9               |
| 7.3.2.3 | Command RAM7-9                     |
| 7.3.3   | QSPI Pins                          |
| 7.3.4   | QSPI Operation7-10                 |
| 7.3.5   | QSPI Operating Modes7-11           |
| 7.3.5.1 | Master Mode7-18                    |
| 7.3.5.2 | Master Wraparound7-21              |
| 7.3.5.3 | Slave Mode7-22                     |
| 7.3.5.4 | Slave Wraparound Mode7-23          |
| 7.3.6   | Peripheral Chip Selects7-23        |
| 7.4     | Serial Communication Interface     |
| 7.4.1   | SCI Registers7-24                  |
| 7.4.1.1 | Control Registers7-24              |
| 7.4.1.2 | Status Register7-27                |
| 7.4.1.3 | Data Register7-27                  |
| 7.4.2   | SCI Pins                           |
| 7.4.3   | SCI Operation7-28                  |
| 7.4.3.1 | Definition of Terms7-28            |
| 7.4.3.2 | Serial Formats7-28                 |
| 7.4.3.3 | Baud Clock7-29                     |
| 7.4.3.4 | Parity Checking7-29                |
| 7.4.3.5 | Transmitter Operation7-30          |
| 7.4.3.6 | Receiver Operation7-31             |

MC68HC16Z1 USER'S MANUAL

#### Paragraph

#### Title

Page

| 7.4.3.7 | Idle-Line Detection |  |
|---------|---------------------|--|
| 7.4.3.8 | Receiver Wakeup     |  |
| 7.4.3.9 | Internal Loop       |  |
| 7.5     | QSM Initialization  |  |

#### Section 8 General-Purpose Timer

| 8.1     | General8-                                    | 1  |
|---------|----------------------------------------------|----|
| 8.2     | GPT Registers and Address Map8-              | ·2 |
| 8.3     | Special Modes of Operation                   | .3 |
| 8.3.1   | Low-power Stop Mode8-                        | .3 |
| 8.3.2   | Freeze Mode8-                                | .3 |
| 8.3.3   | Single-Step Mode8-                           | 4  |
| 8.3.4   | Test Mode8-                                  | 4  |
| 8.4     | Polled and Interrupt-Driven Operation8-      | 4  |
| 8.4.1   | Polled Operation8-                           | -5 |
| 8.4.2   | GPT Interrupts8-                             | -5 |
| 8.5     | Pin Descriptions                             | ·7 |
| 8.5.1   | Input Capture Pins (IC[1:3])8-               | ·7 |
| 8.5.2   | Input Capture/Output Compare Pin (IC4/OC5)8- | ·7 |
| 8.5.3   | Output Compare Pins (OC[1:4])8-              | ·8 |
| 8.5.4   | Pulse Accumulator Input Pin (PAI)8-          | ·8 |
| 8.5.5   | Pulse-Width Modulation (PWMA, PWMB)8-        | ·8 |
| 8.5.6   | Auxiliary Timer Clock Input (PCLK)8-         | ·8 |
| 8.6     | General-Purpose I/O8-                        | ·8 |
| 8.7     | Prescaler                                    | .9 |
| 8.8     | Capture/Compare Unit                         | 1  |
| 8.8.1   | Timer Counter                                | 1  |
| 8.8.2   | Input Capture Functions                      | 1  |
| 8.8.3   | Output Compare Functions                     | 4  |
| 8.8.3.1 | Output Compare 1 8-1                         | 5  |
| 8.8.3.2 | Forced Output Compare                        |    |
| 8.9     | Input Capture 4/Output Compare 5             | 5  |
| 8.10    | Pulse Accumulator                            | 6  |
| 8.11    | Pulse-Width Modulation Unit                  | 7  |
| 8.11.1  | PWM Counter                                  | 9  |
| 8.11.2  | PWM Function                                 | 0  |

Paragraph

#### Title

Page

#### Section 9 Standby RAM Module

| 9.1 | SRAM Register Block                  |  |
|-----|--------------------------------------|--|
| 9.2 | SRAM Array Address Mapping           |  |
| 9.3 | SRAM Array Address Space Type        |  |
| 9.4 | Normal Access                        |  |
| 9.5 | Standby and Low-Power Stop Operation |  |
| 9.6 | Reset                                |  |

#### Appendix A Electrical Characteristics

#### Appendix B Mechanical Data and Ordering Information

#### Appendix C Development Support

| C.1 | M68HC16EVB Evaluation Board | .C-' | 1 |
|-----|-----------------------------|------|---|
|-----|-----------------------------|------|---|

#### Appendix D Register Summary

| D.1     | Central Processing Unit                           | D–2  |
|---------|---------------------------------------------------|------|
| D.1.1   | CPU16 Register Model                              | D–2  |
| D.1.2   | CCR — Condition Code Register                     | D–3  |
| D.2     | Analog-to-Digital Converter Module                | D-4  |
| D.2.1   | ADCMCR — ADC Module Configuration Register        | D–5  |
| D.2.2   | ADTEST — ADC Test Register                        | D–5  |
| D.2.3   | PORTADA — Port ADA Data Register                  | D–5  |
| D.2.4   | ADCTL0 — A/D Control Register 0                   | D–6  |
| D.2.5   | ADCTL1 — A/D Control Register 1                   | D–7  |
| D.2.6   | ADSTAT — ADC Status Register                      | D–9  |
| D.2.7   | RSLT[0:7] — ADC Result Registers                  | D–10 |
| D.2.7.1 | RJURR — Unsigned Right-Justified Result Registers | D–10 |
| D.2.7.2 | LJSRR — Signed Left-Justified Result Registers    | D–10 |
| D.2.7.3 | LJURR — Unsigned Left-Justified Result Registers  | D–10 |

#### General-Purpose Timer......D-11 D.3 D.3.1 GPTMCR — GPT Module Configuration Register ......D-11 GPTMTR --- GPT Module Test Register (Reserved) ......D-12 D.3.2 D.3.3 ICR — GPT Interrupt Configuration Register ......D-12 D.3.4 DDRGP --- Port GP Data Direction Register ......D-13 PORTGP --- Port GP Data Register......D-13 D.3.5 OC1M --- OC1 Action Mask Register.....D-13 OC1D --- OC1 Action Data Register......D-13 D.3.6 TCNT --- Timer Counter Register ......D-13 D.3.7 PACTL— Pulse Accumulator Control Register ......D-14 PACNT — Pulse Accumulator Counter ......D-14 D.3.8 TIC[1:3] — Input Capture Registers 1-3 ......D-15 D.3.9 TOC[1:4] --- Output Compare Registers 1-4 ......D-15 D.3.10 TI4/O5 — Input Capture 4/Output Compare 5 Register ......D-15 TCTL1/TCTL2 — Timer Control Registers 1 and 2......D-15 D.3.11 D.3.12 TMSK1/TMSK2 — Timer Interrupt Mask Registers 1 and 2......D-16 D.3.13 TFLG1/TFLG2 — Timer Interrupt Flag Registers 1 and 2......D-17 D.3.14 CFORC — Compare Force Register ......D-18 PWMC — PWM Control Register C ......D-18 PWMA/PWMB --- PWM Registers A/B ......D-19 D.3.15 D.3.16 PWMCNT --- PWM Count Register ......D-19 D.3.17 PWMBUFA — PWM Buffer Register A ......D-19 PWMBUFB --- PWM Buffer Register B ......D-19 D.3.18 PRESCL — GPT Prescaler ......D-19 System Integration Module......D-20 D.4 D.4.1 SIMCR — Module Configuration Register ......D-22 D.4.2 SIMTR — System Integration Test Register......D-23 D.4.3 SYNCR — Clock Synthesizer Control Register ......D-23 D.4.4 RSR --- Reset Status Register ......D-24 SIMTRE — System Integration Test Register (ECLK)......D-24 D.4.5 D.4.6 PORTE0/PORTE1 — Port E Data Register......D-24 D.4.7 DDRE — Port E Data Direction Register ......D-25 D.4.8 PEPAR — Port E Pin Assignment Register......D-25

# D.4.8PEPAR — Port E Pin Assignment Register......D-25D.4.9PORTF0/PORTF1— Port F Data Register.....D-25D.4.10DDRF — Port F Data Direction Register.....D-25D.4.11PFPAR — Port F Pin Assignment Register.....D-26D.4.12SYPCR — System Protection Control Register .....D-26D.4.13PICR — Periodic Interrupt Control Register .....D-27D.4.14PITR — Periodic Interrupt Timer Register .....D-27D.4.15SWSR — Software Service Register ......D-28

MOTOROLA

#### Page

Paragraph

#### Title

#### Paragraph

#### Title

| D.4.16 | TSTMSRA — Master Shift Register AD-28                    |
|--------|----------------------------------------------------------|
| D.4.17 | TSTMSRB — Master Shift Register BD-28                    |
| D.4.18 | TSTSC — Test Module Shift CountD-28                      |
| D.4.19 | TSTRC — Test Module Repetition CountD-28                 |
| D.4.20 | CREG — Test Submodule Control RegisterD-28               |
| D.4.21 | DREG — Distributed RegisterD-28                          |
| D.4.22 | PORTC — PORTC Data RegisterD-28                          |
| D.4.23 | CSPAR0 — Chip Select Pin Assignment Register 0D-29       |
| D.4.24 | CSPAR1 — Chip Select Pin Assignment Register 1D-29       |
| D.4.25 | CSBARBT — Chip Select Base Address Register Boot ROMD-29 |
| D.4.26 | CSBAR[0:10] — Chip Select Base Address RegistersD-29     |
| D.4.27 | CSORBT — Chip Select Option Register Boot ROMD-30        |
| D.4.28 | CSOR[0:10] — Chip Select Option RegistersD-30            |
| D.5    | Standby RAM ModuleD-32                                   |
| D.5.1  | RAMMCR — RAM Module Configuration RegisterD-32           |
| D.5.2  | RAMTST — RAM Test RegisterD-33                           |
| D.5.3  | RAMBAH — Array Base Address Register HighD-33            |
| D.5.4  | RAMBAL — Array Base Address Register LowD-33             |
| D.6    | Queued Serial ModuleD-34                                 |
| D.6.1  | QSMCR — QSM Configuration RegisterD-34                   |
| D.6.2  | QTEST — QSM Test RegisterD-35                            |
| D.6.3  | QILR — QSM Interrupt Level RegisterD-35                  |
|        | QIVR — QSM Interrupt Vector RegisterD-35                 |
| D.6.4  | PORTQS — Port QS Data RegisterD-36                       |
| D.6.5  | PQSPAR — Pin Assignment RegisterD-36                     |
|        | DDRQS — Data Direction RegisterD-36                      |
| D.6.6  | SPCR0 — QSPI Control Register 0D-37                      |
| D.6.7  | SPCR1 — QSPI Control Register 1D-38                      |
| D.6.8  | SPCR2 — QSPI Control Register 2D-38                      |
| D.6.9  | SPCR3 — QSPI Control Register 3D-39                      |
|        | SPSR — QSPI Status RegisterD-39                          |
| D.6.10 | RR[0:F] — Receive Data RAMD-40                           |
| D.6.11 | TR[0:F] — Transmit Data RAMD-40                          |
| D.6.12 | CR[0:F] — Command RAMD-41                                |
| D.6.13 | SCCR0 — SCI Control Register 0D-42                       |
| D.6.14 | SCCR1 — SCI Control Register 1D-42                       |
| D.6.15 | SCSR — SCI Status RegisterD-44                           |
| D.6.16 | SCDR — SCI Data RegisterD-45                             |
|        |                                                          |

#### Index

#### LIST OF ILLUSTRATIONS

#### Figure

| 3–1  | MC68HC16Z1 Block Diagram3-                                    | 3 |
|------|---------------------------------------------------------------|---|
| 3–2  | MC68HC16Z1 Pin Assignment for 132-Pin Package                 | 4 |
| 3–3  | MC68HC16Z1 Pin Assignment for 144-Pin Package                 | 5 |
| 3–4  | Internal Register Addresses                                   |   |
| 3–5  | Pseudolinear Addressing/Combined Program and Data Spaces 3-13 | 3 |
| 3–6  | Pseudolinear Addressing/Separated Program and Data Spaces 3-1 | 4 |
|      |                                                               | _ |
| 4–1  | System Integration Module Block Diagram4-                     |   |
| 4–2  | System Configuration and Protection4-                         |   |
| 4–3  | Periodic Interrupt Timer and Software Watchdog Timer4-        |   |
| 4–4  | System Clock Block Diagram 4-1                                |   |
| 4–5  | MC68HC16Z1 Basic System 4-2                                   |   |
| 4–6  | Operand Byte Order 4-2                                        |   |
| 4–7  | Byte Operand to 8-Bit Port (ADDR0 = 0, ADDR0 = 1) 4-2         |   |
| 4–8  | Byte Operand to 16-Bit Port, Even (ADDR0 = 0) 4-2             |   |
| 49   | Byte Operand to 16-Bit Port, Odd (ADDR0 = 1) 4-2              |   |
| 4–10 | Word Operand to 8-Bit Port, Aligned 4-3                       |   |
| 4–11 | Word Operand to 8-Bit Port, Misaligned 4-3                    |   |
| 4–12 | Word Operand to 16-Bit Port, Aligned 4-3                      | 2 |
| 4–13 | Word Operand to 16-Bit Port, Misaligned 4-3                   | 3 |
| 4–14 | Long-Word Operand to 8-Bit Port, Aligned 4-3-                 | 4 |
| 4–15 | Long-Word Operand to 8-Bit Port, Misaligned 4-3               | 5 |
| 4–16 | Long-Word Operand to 16-Bit Port, Aligned 4-3                 | 6 |
| 4–17 | Long-Word Operand to 16-Bit Port, Misaligned                  | 7 |
| 4–18 | Word Read Cycle Flowchart 4-4                                 |   |
| 4–19 | Write Cycle Flowchart 4-4                                     | 2 |
| 4–20 | Fast-Termination Timing                                       | 4 |
| 4-21 | CPU Space Address Encoding                                    |   |
| 4–22 | Breakpoint Operation Flow                                     |   |
| 4–23 | Breakpoint Acknowledge Cycle Timing 4-4                       | 9 |
| 4–24 | LPSTOP Interrupt Mask Level 4-5                               |   |
| 4–25 | HALT Timing                                                   |   |
| 4–26 | Bus Arbitration Flowchart for Single Request                  |   |
| 4–27 | Bus Arbitration State Diagram                                 |   |
| 4–28 | Data Bus Mode Select Conditioning                             |   |
| 4–29 | Power-On Reset Timing                                         |   |
|      |                                                               |   |

#### LIST OF ILLUSTRATIONS (Continued)

| Figure | Title                                        | Page |
|--------|----------------------------------------------|------|
| 4–30   | Interrupt Acknowledge Cycle Flowchart        | 4–77 |
| 4–31   | Interrupt Acknowledge Cycle Timing           | 4–78 |
| 4–32   | Autovector Operation Timing                  |      |
| 4–33   | Basic M68HC16 System                         |      |
| 4–34   | Chip-Select Circuit Block Diagram            |      |
| 4–35   | Flow Diagram for Chip Select                 |      |
| 4–36   | CPU Space Encoding for Interrupt Acknowledge |      |
| 5–1    | CPU16 Register Model                         | 5–2  |
| 5–2    | Condition Code Register                      | 5–4  |
| 5–3    | Data Types and Memory Organization           | 5–8  |
| 5–4    | Instruction Execution Model                  |      |
| 5–5    | Exception Stack Frame Format                 | 5–63 |
| 5–6    | BDM Serial I/O Block Diagram                 | 5–70 |
| 6–1    | ADC Block Diagram                            | 6–2  |
| 6–2    | 8-Bit Conversion Timing                      | 6–15 |
| 6–3    | 10-Bit Conversion Timing                     | 6–16 |
| 7–1    | QSM Block Diagram                            | 7–1  |
| 7–2    | QSPI Block Diagram                           | 7–7  |
| 7–3    | QSPI RAM                                     | 7–9  |
| 7–4    | Flowchart of QSPI Initialization Operation   | 7–12 |
| 7–5    | Flowchart of QSPI Master Operation           | 7–13 |
| 7–6    | Flowchart of QSPI Slave Operation            |      |
| 7–7    | SCI Transmitter Block Diagram                | 7–25 |
| 7–8    | SCI Receiver Block Diagram                   | 7–26 |
| 8—1    | GPT Block Diagram                            | 8–2  |
| 8–2    | Prescaler Block Diagram                      |      |
| 8–3    | Capture/Compare Block Unit Diagram           |      |
| 8–4    | Input Capture Timing Example                 |      |
| 8–5    | Pulse Accumulator Block Diagram              |      |
| 8–6    | PWM Block Diagram                            |      |
| A–1    | CLKOUT Output Timing Diagram                 |      |
| A–2    | External Clock Input Timing Diagram          |      |
| A–3    | ECLK Output Timing Diagram                   |      |
| A-4    | Read Cycle Timing Diagram                    |      |
| A–5    | Write Cycle Timing Diagram                   | A–20 |
| A–6    | Show Cycle Timing Diagram                    | A–22 |

#### LIST OF ILLUSTRATIONS (Continued)

#### Title

#### Page

| A7   | Reset and Data Bus Mode Select Timing Diagram         | A–24 |
|------|-------------------------------------------------------|------|
| A8   | Bus Arbitration Timing Diagram — Active Bus Case      | A–26 |
| A9   | Bus Arbitration Timing Diagram — Idle Bus Case        | A–28 |
| A–10 | Fast Termination Read Cycle Timing Diagram            | A–30 |
| A-11 | Fast Termination Write Cycle Timing Diagram           | A–32 |
| A–12 | ECLK Timing Diagram                                   | A–34 |
| A–13 | Chip Select Timing Diagram                            | A–36 |
| A–14 | Background Debugging Mode Timing Diagram —            |      |
|      | Serial Communication                                  | A–38 |
| A–15 | Background Debugging Mode Timing Diagram —            |      |
|      | Freeze Assertion                                      |      |
| A–16 | QSPI Timing Master, CPHA = 0                          | A–40 |
| A–17 | QSPI Timing Master, CPHA = 1                          | A–40 |
| A-18 | QSPI Timing Slave, CPHA = 0                           | A–42 |
| A–19 | QSPI Timing Slave, CPHA = 1                           | A–42 |
|      |                                                       |      |
| B–1  | 132-Pin Plastic Surface Mount Package Pin Assignments |      |
| B–2  | 132-Pin Package Dimensions                            |      |
| B–3  | 132-Pin Molded Carrier Ring Assembly                  | B–4  |
| B–4  | 144-Pin Plastic Surface Mount Package Pin Assignments | B–6  |
| B–5  | 144-Pin Package Dimensions                            | B–7  |
| B–6  | 144-Pin Molded Carrier Ring Assembly                  | B–8  |
|      |                                                       |      |

Figure

#### LIST OF TABLES

#### Table

#### Title

| 3–1  | MC68HC16Z1 Driver Types                      |      |
|------|----------------------------------------------|------|
| 3–2  | MC68HC16Z1 Pin Characteristics               | 3–6  |
| 3–3  | MC68HC16Z1 Power Connections                 | 3–7  |
| 3–4  | MC68HC16Z1 Signal Characteristics            | 3–8  |
| 3–5  | MC68HC16Z1 Signal Function                   | 3–9  |
| 3–6  | SIM Reset Mode Selection                     |      |
| 3–7  | Module Reset Pin Function                    | 3–16 |
| 4–1  | Show Cycle Enable Bits                       | 4–5  |
| 4–2  | Bus Monitor Period                           |      |
| 4–3  | MODCLK Pin and SWP Bit During Reset          | 4–7  |
| 4–4  | Software Watchdog Ratio                      | 4–7  |
| 4–5  | MODCLK Pin and PTP Bit at Reset              | 4–9  |
| 4–6  | Periodic Interrupt Priority                  | 4–9  |
| 4–7  | Clock Control Multipliers                    |      |
| 4–8  | System Frequencies from 32.768-kHz Reference |      |
| 4–9  | Clock Control                                |      |
| 4–10 | Size Signal Encoding                         | 4–22 |
| 4–11 | Address Space Encoding                       | 4–23 |
| 4–12 | Effect of DSACK Signals                      | 4–24 |
| 4–13 | Operand Alignment                            | 4–26 |
| 4–14 | DSACK, BERR, and HALT Assertion Results      |      |
| 4–15 | Reset Source Summary                         |      |
| 4–16 | Reset Mode Selection                         |      |
| 4–17 | Module Pin Functions                         | 4–65 |
| 4–18 | SIM Pin Reset States                         | 4–67 |
| 4–19 | Module Pin Reset States                      | 4–68 |
| 4–20 | Chip-Select Pin Functions                    | 4–83 |
| 4–21 | Pin Assignment Field Encoding                |      |
| 4–22 | Block Size Encoding                          | 4–85 |
| 4–23 | Option Register Function Summary             | 4–86 |
| 4–24 | CSBOOT Base and Option Register Reset Values | 4–96 |
| 5-1  | Addressing Modes                             | 5–9  |
| 5–2  | Load Summary                                 |      |
| 5–3  | Move Summary                                 | 5–12 |

#### LIST OF TABLES (Continued)

#### Table

#### Title

| 5–4  | Store Summary                             |
|------|-------------------------------------------|
| 5–5  | Transfer Summary5-13                      |
| 5–6  | Exchange Summary                          |
| 5–7  | Addition Summary                          |
| 5–8  | Subtraction Summary                       |
| 5–9  | BCD Summary 5-15                          |
| 5–10 | Compare and Test Summary 5-16             |
| 5-11 | Multiplication and Division Summary       |
| 5–12 | Decrement and Increment Summary           |
| 5–13 | Clear, Complement and Negate Summary 5-18 |
| 5–14 | Boolean Logic Summary                     |
| 5-15 | Bit Test and Manipulation Summary         |
| 5–16 | Logic Shift Summary                       |
| 5-17 | Arithmetic Shift Summary                  |
| 5-18 | Rotate Summary                            |
| 5–19 | Short Branch Summary                      |
| 5–20 | Long Branch Instructions                  |
| 5-21 | Bit Condition Branch Summary              |
| 5–22 | Jump Summary                              |
| 5–23 | Subroutine Summary                        |
| 5–24 | Interrupt Summary                         |
| 5–25 | Indexing Summary                          |
| 5–26 | Address Extension Summary                 |
| 5–27 | Stacking Summary                          |
| 5–28 | Condition Code Summary                    |
| 5–29 | DSP Summary                               |
| 5–30 | Stop and Wait Summary                     |
| 5-31 | Background Mode and Null Operations       |
| 5–32 | HC16 Implementation of HC11 Instructions  |
| 5–33 | Basic Instruction Formats                 |
| 5–34 | Exception Vector Table                    |
| 5-35 | IPIPE0/IPIPE1 Encoding                    |
| 5-36 | Command Summary                           |
| 6–1  | FRZ Field Selection                       |
| 6–2  | Multiplexer Channels                      |
| 6–3  | Prescaler Output                          |
| 6-4  | STS Field Selection                       |
| 6–5  | ADC Conversion Modes                      |
| 6–6  | Single-Channel Conversions                |
|      |                                           |

#### LIST OF TABLES (Continued)

| Table | Title                                            | Page |
|-------|--------------------------------------------------|------|
| 6–7   | Multiple-Channel Conversions                     | 6–13 |
| 7–1   | QSM Pin Functions                                | 7–5  |
| 7–2   | QSPI Pin Function                                | 7–10 |
| 7–3   | BITS Encoding                                    | 7–20 |
| 7-4   | SCI Pin Function                                 | 7–27 |
| 7–5   | Serial Frame Formats                             | 7–29 |
| 7–6   | Effect of Parity Checking on Data Size           | 7–30 |
| 8–1   | GPT Status Flags                                 | 8–5  |
| 8–2   | GPT Interrupt Sources                            | 8–6  |
| 8–3   | PWM Frequency Range Using 16.78 MHz System Clock | 8–19 |
| A–1   | Maximum Ratings                                  | A–2  |
| A–2   | Thermal Characteristics                          | A–3  |
| A–3   | Clock Control Timing                             | A–4  |
| A–4   | DC Characteristics                               | A–5  |
| A–5   | AC Timing                                        | A–7  |
| A–6   | Background Debugging Mode Timing                 | A–10 |
| A–7   | ECLK Bus Timing                                  | A–10 |
| A–8   | QSPI Timing                                      | A–11 |
| A–9   | ADC Maximum Ratings                              |      |
| A–10  | ADC DC Electrical Characteristics (Operating)    | A–13 |
| A–11  | ADC AC Characteristics (Operating)               | A–14 |
| A–12  | ADC Conversion Characteristics (Operating)       | A–14 |
| B–1   | MC68HC16Z1 Ordering Information                  | B–10 |
| C–1   | MC68HC16Z1 Development Tools                     | C–1  |
| D–1   | MC68HC16Z1 Module Address Map                    |      |
| D–2   | ADC Module Address Map                           |      |
| D-3   | GPT Address Map                                  |      |
| D-4   | SIM Address Map                                  |      |
| D-5   | SRAM Address Map                                 |      |
| D6    | QSM Address Map                                  |      |
| D–7   | MC68HC16Z1 Module Address Map                    |      |
| D-8   | Register Bit and Field Mnemonics                 | D–51 |

#### SECTION 1 INTRODUCTION

The MC68HC16Z1 is a high-speed 16-bit control unit that is upwardly code compatible with M68HC11 controllers. It is a member of the M68HC16 Family of modular microcontrollers.

M68HC16 controllers are built up from standard modules that interface via a common internal bus. Standardization facilitates rapid development of devices tailored for specific applications.

The MC68HC16Z1 incorporates a true 16-bit central processing unit (CPU16), a system integration module (SIM), an 8/10-bit analog-to-digital converter (ADC), a queued serial module (QSM), a general-purpose timer (GPT), and a 1024-byte standby RAM (SRAM). These modules are interconnected by the intermodule bus (IMB).

Maximum system clock for the MC68HC16Z1 is 16.78 MHz. A phase-locked loop circuit synthesizes the clock from a frequency reference. Either a crystal (nominal frequency: 32.768 kHz) or an externally generated signal can be used. System hardware and software support changes in clock rate during operation. Because the MC68HC16Z1 is a fully static design, register and memory contents are not affected by clock rate changes.

High-density complementary metal-oxide semiconductor (HCMOS) architecture makes the basic power consumption of the MC68HC16Z1 low. Power consumption can be minimized by stopping the system clock. The M68HC16 instruction set includes a low-power stop (LPSTOP) command that efficiently implements this capability.

Documentation for the Modular Microcontroller Family follows the modular construction of the devices in the product line. Each device has a comprehensive user's manual which provides sufficient information for normal operation of the device. The user's manual is supplemented by module reference manuals that provide detailed information about module operation and applications. Refer to Motorola publication *Advanced Microcontroller Unit (AMCU) Literature* (BR1116/D) for a complete listing of documentation to supplement this manual.

INTRODUCTION

INTRODUCTION

#### SECTION 2 NOMENCLATURE

The following nomenclature is used throughout the manual. Nomenclature used only in certain sections, such as register bit mnemonics, is provided in those sections.

#### 2.1 Symbols and Operators

- + Addition
- -- Subtraction or negation (twos complement)
- \* -- Multiplication
- / Division
- > Greater
- < --- Less
- = Equal
- $\geq$  Equal or greater
- $\leq$  Equal or less
- ≠ Not equal
- — AND
- + -- Inclusive OR (OR)
- $\oplus$  Exclusive OR (EOR)
- NOT Complementation
  - : Concatenation
  - ⇒ Transferred
  - $\Leftrightarrow$  Exchanged
  - $\pm$  Sign bit; also used to show tolerance
  - « --- Sign extension
  - % Binary value
  - \$ Hexadecimal value

#### 2.2 CPU16 Registers

- A Accumulator A
- AM Accumulator M
  - B Accumulator B
- CCR Condition code register
  - D Accumulator D
  - E Accumulator E
  - EK Extended addressing extension field
  - IR MAC multiplicand register
  - HR MAC multiplier register
  - IX Index register X
  - IY Index register Y
  - IZ Index register Z
  - K Address extension register
  - PC Program counter
  - PK Program counter extension field
  - SK Stack pointer extension field
  - SL Multiply and accumulate sign latch
  - SP Stack pointer
  - XK Index register X extension field
  - YK Index register Y extension field
  - ZK Index register Z extension field
- XMSK Modulo addressing index register X mask
- YMSK Modulo addressing index register Y mask
  - S Stop disable control bit
  - MV AM overflow indicator
    - H Half carry indicator
  - EV AM extended overflow indicator
  - N Negative indicator
  - Z Zero indicator
  - V Twos complement overflow indicator
  - C Carry/borrow indicator
  - IP Interrupt priority field
  - SM Saturation mode control bit
  - PK Program counter extension field

#### 2.3 Pin and Signal Mnemonics

- AN[7:0] ADC Analog Inputs
- ADDR[23:0] Address Bus
  - AS Address Strobe
  - AVEC Autovector
  - BERR Bus Error
    - BG Bus Grant
  - BGACK Bus Grant Acknowledge
    - BKPT Breakpoint
      - BR Bus Request
  - CLKOUT System Clock
  - CS[10:0] Chip Selects
  - CSBOOT Boot ROM Chip Select
- DATA[15:0] Data Bus
  - DS Data Strobe
- DSACK[1:0] Data and Size Acknowledge
  - DSCLK Development Serial Clock
    - ECLK 6800 Bus Clock
      - DSI Development Serial Input
    - DSO Development Serial Output
    - EXTAL External Crystal Oscillator Connection
    - FC[2:0] Function Codes
  - FREEZE Freeze
    - HALT Halt
    - IC[4:1] Input Capture
- IPIPE0/IPIPE1 Instruction Pipeline MUX
  - IRQ[7:0] Interrupt Request
    - MISO Master In Slave Out
  - MODCLK Clock Mode Select
    - MOSI Master Out Slave In
    - OC[5:1] Output Compare
  - PADA[7:0] ADC I/O Port A
    - PAI Pulse Accumulator Input
    - PCLK Pulse Accumulator Clock
    - PC[6:0] SIM I/O Port C
    - PCS[3:0] Peripheral Chip Selects
      - PE[7:0] SIM I/O Port E
      - PF[7:0] SIM I/O Port F

MC68HC16Z1 USER'S MANUAL

#### NOMENCLATURE

2

PGP[7:0] - GPT I/O Port

PQS[7:0] — QSM I/O Port

PWMA, PWMB — Pulse Width Modulator Output

QUOT — Quotient Out

RW - Read/Write

- RESET Reset
  - RXD SCI Receive Data
  - SCK QSPI Serial Clock
- SIZ[1:0] Size
  - SS Slave Select
  - TSC Three-State Control
- TSTME Test Mode Enable
  - TXD SCI Transmit Data
- VDDA/VSSA A/D Converter Power
  - V<sub>DDSYN</sub> Clock Synthesizer Power
  - V<sub>RH</sub>/V<sub>RL</sub> A/D Reference Voltage
- V<sub>SSE</sub>/V<sub>DDE</sub> External Peripheral Power (Source and Drain)
  - V<sub>SSI</sub>/V<sub>DDI</sub> Internal Module Power (Source and Drain)
    - VSTBY Standby RAM Power
      - XFC External Filter Capacitor Connection
    - XTAL External Crystal Oscillator Connection

#### 2.4 Register Mnemonics

ADCMCR — ADC Module Configuration Register ADCTL0 — A/D Control Register 0 ADCTL1 — A/D Control Register 1 ADSTAT — ADC Status Register ADTEST — ADC Test Register CFORC — Compare Force Register CREG — Test Submodule Control Register CSBARBT — Chip Select Base Address Register Boot ROM CSBAR[0:10] — Chip Select Base Address Registers CSORBT — Chip Select Option Register Boot ROM CSPAR0 — Chip Select Pin Assignment Register 0 CSPAR1 — Chip Select Pin Assignment Register 1 DDRE — Port E Data Direction Register DDRF — Port F Data Direction Register DDRGP — Port GP Data Direction Register PORTQS — Data Direction Register DREG — Distributed Register GPTMCR — GPT Module Configuration Register GPTMTR — GPT Module Test Register (Reserved) ICR — GPT Interrupt Configuration Register OC1D — OC1 Action Data Register OC1M — OC1 Action Mask Register PACNT — Pulse Accumulator Counter PACNT — Pulse Accumulator Counter PACTL — Pulse Accumulator Control Register PEPAR — Port E Pin Assignment Register PFPAR — Port F Pin Assignment Register PICR — Periodic Interrupt Control Register PITR — Periodic Interrupt Timer Register PORTADA — Port ADA Data Register PORTC — Port C Data Register PORTE — Port E Data Register PORTF — Port F Data Register PORTGP — Port GP Data Register PORTQS — Port QS Data Register PQSPAR — Port QS Pin Assignment Register PRESCL — GPT Prescaler PWMA — PWM Control Register A PWMB — PWM Control Register B PWMBUFA — PWM Buffer Register A PWMBUFB — PWM Buffer Register B PWMC — PWM Control Register C PWMCNT — PWM Count Register

QIVR — QSM Interrupt Vector Register

QSMCR — QSM Configuration Register

QTEST — QSM Test Register

RAMBAH — Array Base Address Register High

RAMBAL — Array Base Address Register Low

RAMMCR — RAM Module Configuration Register

RAMTST — RAM Test Register

RSLT[0:7] — ADC Result Registers

RSR — Reset Status Register

SCCR0 — SCI Control Register 0

SCCR1 — SCI Control Register 1

SCDR — SCI Data Register

SCSR — SCI Status Register

SIMCR — Module Configuration Register

SIMTR — System Integration Test Register

SIMTRE — System Integration Test Register (ECLK)

SPCR0 — QSPI Control Register 0

SPCR1 — QSPI Control Register 1

SPCR2 — QSPI Control Register 2

SPCR3 — QSPI Control Register 3

SPSR — QSPI Status Register

SWSR — Software Service Register

SYNCR — Clock Synthesizer Control Register

SYPCR — System Protection Control Register

TCNT — Timer Counter Register

TCTL1 — Timer Control Register 1

TCTL2 — Timer Control Register 2

TFLG1/TFLG2 — Timer Interrupt Flag Registers 1 and 2

TI4/O5 — Input Capture 4/Output Compare 5 Register

TIC[1:3] — Input Capture Registers 1-3

TMSK1 — Timer Interrupt Mask Register 1

TMSK2 — Timer Interrupt Mask Register 2

TOC[1:4] — Output Compare Registers 1-4

TSTMSRA — Master Shift Register A

TSTMSRB — Master Shift Register B

TSTRC — Test Module Repetition Count

TSTSC — Test Module Shift Count

#### 2.5 Conventions

Logic level one is the voltage that corresponds to a Boolean true (1) state.

Logic level zero is the voltage that corresponds to a Boolean false (0) state.

Set refers specifically to establishing logic level one on a bit or bits.

Clear refers specifically to establishing logic level zero on a bit or bits.

**Asserted** means that a signal is in active logic state. An active low signal changes from logic level one to logic level zero when asserted, and an active high signal changes from logic level zero to logic level one.

**Negated** means that an asserted signal changes logic state. An active low signal changes from logic level zero to logic level one when negated, and an active high signal changes from logic level one to logic level zero.

**A specific mnemonic** within a range is referred to by mnemonic and number. A15 is bit 15 of Accumulator A; ADDR7 is line 7 of the address bus; CSOR0 is chip-select option register 0. **A range of mnemonics** is referred to by mnemonic and the numbers that define the range. AM[35:30] are bits 35 to 30 of Accumulator M; CSOR[0:5] are the first six option registers

**Parentheses** are used to indicate the content of a register or memory location, rather than the register or memory location itself. (A) is the content of Accumulator A. (M : M + 1) is the content of the word at address M.

**LSB** means least significant bit or bits. **MSB** means most significant bit or bits. References to low and high bytes are spelled out.

**LSW** means least significant word or words. **MSW** means most significant word or words.

ADDR is the address bus. ADDR[7:0] are the eight LSB of the address bus.

**DATA** is the data bus. DATA[15:8] are the eight MSB of the data bus.

#### NOMENCLATURE

MC68HC16Z1 USER'S MANUAL



This section surveys the entire MC68HC16Z1 modular microcontroller. It lists features of each of the modules, shows device functional divisions and pinouts, summarizes signal and pin functions, discusses the intermodule bus, and provides system memory maps. Timing and electrical specifications for the entire microcontroller and for individual modules are provided in **APPENDIX A ELECTRICAL CHARACTERISTICS**. Comprehensive module register descriptions and memory maps are provided in **APPENDIX D REGISTER SUMMARY**.

#### 3.1 MC68HC16Z1 Features

The following paragraphs highlight capabilities of each of the microcontroller modules. Each module is discussed separately in a subsequent section of this manual.

#### 3.1.1 System Integration Module

- External Bus Support
- Programmable Chip-Select Outputs
- System Protection Logic
- Watchdog Timer, Clock Monitor, and Bus Monitor
- Two 8-Bit Dual Function Ports
- One 7-Bit Dual Function Port
- Phase-Locked Loop (PLL) Clock System

#### 3.1.2 CPU16

- 16-Bit Architecture
- Full Set of 16-Bit Instructions
- Three 16-Bit Index Registers
- Two 16-Bit Accumulators
- Control-Oriented Digital Signal Processing Capability
- 1 Megabyte of Program Memory and 1 Megabyte of Data Memory
- High-Level Language Support
- Fast Interrupt Response Time
- Background Debugging Mode
- Fully Static Operation

MC68HC16Z1 USER'S MANUAL OVERVIEW

## 3.1.3 Analog-to-Digital Converter

- Eight Channels, Eight Result Registers
- Eight Automated Modes
- Three Result Alignment Modes
- One 8-Bit Digital Input Port

## 3.1.4 Queued Serial Module

- Enhanced Serial Communication Interface
- Queued Serial Peripheral Interface
- One 8-Bit Dual Function Port

## 3.1.5 General-Purpose Timer

- Two 16-Bit Free-Running Counters with Prescaler
- Three Input Capture Channels
- Four Output Compare Channels
- One Input Capture/Output Compare Channel
- One Pulse Accumulator/Event Counter Input
- Two Pulse Width Modulation Outputs
- One 8-Bit Dual Function Port
- Two Optional Discrete Inputs
- Optional External Clock Input

## 3.1.6 Standby Ram

- 1024-Byte Static Ram
- External Standby Voltage Supply Input

## 3.2 System Block Diagram and Pin Assignment Diagrams

Figure 3–1 is a functional diagram of the MC68HC16Z1. Although diagram blocks represent the relative size of the physical modules, there is not a one-toone correspondence between location and size of blocks in the diagram and location and size of integrated-circuit modules. Figure 3–2 is a pin assignment drawing based on a 132-pin plastic surface-mount package. Refer to **APPENDIX B MECHANICAL SPECIFICATIONS AND ORDERING INFORMATION** for package dimensions. All pin functions and signal names are shown in these drawings. See subsequent paragraphs in this section for pin and signal descriptions.



Figure 3-1. MC68HC16Z1 Block Diagram

MC68HC16Z1 USER'S MANUAL

| ſ                                     |          | H        | 16 T PCS3/PQS6 | 15 🔲 PCS2PQS5 | 14 H PCS1/POS4 | 13 TD PCS0/SS/POS3 | F        | 11 HOSIPOSI | 10 HISOPOSO | 9 🗖 V <sub>SSE</sub> |             |                                                                    | H      |             |           | ELE<br>~   | ][<br>- 8 |              | 130 II IC4/OC5/OC1/PGP7 | H    | F.       | 127 PWMB | H       | H        |             | 76     |           | ÌE  | 1<br>H   | H        | ΙĒ               |          | 1                |          |     |
|---------------------------------------|----------|----------|----------------|---------------|----------------|--------------------|----------|-------------|-------------|----------------------|-------------|--------------------------------------------------------------------|--------|-------------|-----------|------------|-----------|--------------|-------------------------|------|----------|----------|---------|----------|-------------|--------|-----------|-----|----------|----------|------------------|----------|------------------|----------|-----|
| TxD/PQS7                              | 18       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           | (          | )`        |              | . –                     | -    | *        | -        | -       | -        | -           | - 1    |           |     |          |          |                  | 116      |                  | R/CSO    |     |
| ADDR1                                 | 19       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 115      |                  | 2/CS5/P  | °C2 |
| ADDR2 🖂                               | 20       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 114      | E FC             | C1/CS4/P | PC1 |
|                                       | 21       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 113      |                  | DDE      |     |
| V <sub>SSE</sub>                      | 22       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 112      |                  | SSE      |     |
| ADDR3 🖂                               | 23       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 111      | TT FC            | 0/CS3/P  | 00  |
| ADDR4 🖂                               | 24       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 110      |                  | SBOOT    |     |
| ADDR5 🖂                               | 25       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 109      |                  | ATA0     |     |
| ADDR6 🎞                               | 26       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 108      |                  | ATA1     |     |
| ADDR7 🖂                               | 27       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 107      |                  | ATA2     |     |
| ADDR8                                 | 28       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 106      |                  | ATA3     |     |
| V <sub>SSI</sub> 🖂                    | 29       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 105      | ې 🖂              | SSI      |     |
| ADDR9 🖽                               | 30       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 104      |                  | ATA4     |     |
| ADDR10                                | 31       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 103      | 1 D/             |          |     |
| ADDR11                                | 32       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 102      | 1                | ATA6     |     |
| ADDR12                                | 33       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 101      |                  |          |     |
| ADDR13                                | 34       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 100      |                  |          |     |
| ADDR14                                | 35       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 99       |                  |          |     |
| ADDR15                                | 36       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 98       |                  | DDE      |     |
| ADDR16                                | 37       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 97       | ₽ V <sub>€</sub> |          |     |
|                                       | 38       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 96       |                  | ATA10    |     |
|                                       | 39       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 95       |                  |          |     |
|                                       | 40       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 94       |                  |          |     |
|                                       | 41       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 93       |                  |          |     |
|                                       | 42       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 92       |                  |          |     |
| V <sub>SSA</sub> []]<br>ANO/PADAO []] | 43       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 91<br>00 |                  | DDR0     |     |
|                                       | 44       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 90<br>89 |                  | SACKO/P  | En  |
|                                       | 45<br>46 |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 88<br>88 |                  | SACK1/P  |     |
|                                       | 40<br>47 |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 87       |                  | VEC/PE2  | E 1 |
|                                       | 48       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 86       |                  | S/PE4    |     |
| AN5/PADA5                             | 49       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 85       |                  | S/PE5    |     |
|                                       | 50       |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        |             |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  | 84       |                  |          |     |
| nn LL                                 |          | _        | ~              | ~             | -              | 6                  | 6        | ~           | ~           | ~                    | <b>-</b> -  | - 0                                                                | -      | -           | 6         | <u>د</u> ۱ |           |              |                         | _    | ~        | ~        | -       | <u>م</u> | <b>6</b> 1  |        | <u> </u>  |     |          | ~        |                  |          |                  | DDF      |     |
| L                                     |          | <u>0</u> | 8              | òĩ            | 5              | کت<br>T            | 8        | 5           | 28          | 8                    | ωü          | о<br>П                                                             | ន      | 2           | 8         | 8:         | 0 0<br>TT | 88           |                         | 7    | <u>۲</u> | кі<br>ГТ | Ň       | 12       |             | 3 2    | < 7<br>TT | 28  | òò       | òò       | 38               |          | 1                |          |     |
|                                       |          | П        | Н              | Ц             | П              | Ц                  | Н        | Н           | Н           | Ы                    | ٦F          | IН                                                                 | Н      | Ш           | Ы         | ШĿ         | ١Ŀ        | ЪЦ           | Н                       | П    | Ц        | Н        | Ц       | ЫI       | 3 t         | 36     | ٦F        | 16  | ıН       | Н        | IН               |          |                  |          |     |
|                                       |          | ۲<br>۳   | 9Ye            | ¥2            | VSTBY          | XTAL               | VDDSYN [ | EXTAL       | NSS <       | ã                    | Ч<br>К<br>К | 2 2<br>2 2<br>2 2<br>2 2<br>2 2<br>2 2<br>2 2<br>2 2<br>2 2<br>2 2 | CLKOUT | 5           | ŝ         | ž          | 82        | <u> 종</u> [뉴 | HALT                    | BERR | RQ7/PF7  | RO6/PF6  | RO5/PF5 | IRO4/PF4 | f i         | HUZPTZ | Ē         | ≷ا≷ | SIZ1/PE7 | SIZ0/PE6 | V <sub>SSE</sub> |          |                  |          |     |
|                                       |          | _        | PAL            | ¥.            | Š              | z                  | ğ        | ۲           | > :         | >                    | × >         | '>                                                                 | R      | ğı          | Ť         | ğ          |           |              | I王                      | ᇤ    | ŝ        | ଛି।      | ŝ       | Ξi       | <b>S</b> I8 | SIZ.   | × ×       | 5 " | 5        | 10Z      | >                |          |                  |          |     |
|                                       |          |          | AN6/PADA6      | AN7/PADA7     |                |                    | -        |             |             |                      |             |                                                                    | Ö      | FREEZE/QUOT | TSTME/TSC | BKPT/DSCLK |           | RESET        |                         |      | ₫        | Ĕ        | Щ,      | Ĕ        | Ĕ ŝ         | Ξļġ    | ÉŻ        |     | 3        | S        | i                |          |                  |          |     |
|                                       |          |          | <              | •             |                |                    |          |             |             |                      |             |                                                                    |        | Ē           | ۴I        | ¥ -        |           | -            |                         |      |          |          |         |          |             |        | S         | Ē   |          |          |                  |          |                  |          |     |
|                                       |          |          |                |               |                |                    |          |             |             |                      |             |                                                                    |        | u.          |           |            |           |              |                         |      |          |          |         |          |             |        |           |     |          |          |                  |          |                  |          |     |

Figure 3-2. MC68HC16Z1 Pin Assignment for 132-Pin Package

MOTOROLA 3–4





#### 3.3 Pin Descriptions

The tables below summarize functional characteristics of MC68HC16Z1 pins. Table 3–1 shows types of output drivers. Table 3–2 shows all inputs and outputs. Digital inputs and outputs use CMOS logic levels. An entry in the Discrete I/O column indicates that a pin can also be used for general-purpose input, output, or both — I/O port designation is given when it applies. Table 3–3 shows characteristics of power pins. Refer to Figure 3–1 for port organization.

| Туре | 1/0 | Description                                                                                                                                                                                                                                  |
|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Α    | 0   | Output-only signals that are always driven; no external pullup required                                                                                                                                                                      |
| Aw   | 0   | Type A output with weak P-channel pullup during reset                                                                                                                                                                                        |
| В    | 0   | Three-state output that includes circuitry to pull up output before high impedance is established, to ensure rapid rise time. An external holding resistor is required to maintain logic level while the pin is in the high-impedance state. |
| Во   | 0   | Type B output that can be operated in an open-drain mode                                                                                                                                                                                     |

Table 3-1. MC68HC16Z1 Driver Types

|  | Table | 3–2. | MC68HC16Z1 | Pin | Characteristics |
|--|-------|------|------------|-----|-----------------|
|--|-------|------|------------|-----|-----------------|

| Pin<br>Mnemonic         | Output<br>Driver | Input<br>Synchronized | input<br>Hysteresis | Discrete<br>I/O | Port<br>Designation |
|-------------------------|------------------|-----------------------|---------------------|-----------------|---------------------|
| ADDR23/CS10/ECLK        | A                | Y                     | N                   | 0               | _                   |
| ADDR[22:19]/CS[9:6]     | A                | Y                     | N                   | 0               | C[6:3]              |
| ADDR[18:0]              | Α                | Y                     | N                   | —               | ·                   |
| AN[7:0] <sup>1</sup>    | -                | Y                     | N                   | 1               | ADA[7:0]            |
| ĀS                      | В                | Y                     | N                   | I/O             | E5                  |
| AVEC                    | В                | Y                     | N                   | I/O             | E2                  |
| BERR                    | В                | Y                     | N                   |                 |                     |
| BG/CS1                  | В                |                       |                     |                 |                     |
| BGACK/CS2               | В                | Y                     | N                   |                 |                     |
| BKPT/DSCKL              |                  | Y                     | Y                   |                 |                     |
| BR/CS0                  | В                | Y                     | N                   | 0               | Separate            |
| CLKOUT                  | A                |                       |                     |                 |                     |
| CSBOOT                  | В                |                       |                     |                 |                     |
| DATA[15:0] <sup>1</sup> | AW               | Y                     | N                   |                 |                     |
| DS                      | В                | Y                     | N                   | I/O             | E4                  |
| DSACK1                  | В                | Y                     | N                   | I/O             | E1                  |
| DSACKO                  | В                | Y                     | N                   | I/O             | E0                  |
| DSI/IPIPE1              | A                | Y                     | Y                   |                 | Separate            |
| DSO/IPIPE0              | A                |                       |                     |                 | Separate            |
| EXTAL <sup>2</sup>      |                  |                       | Special             |                 |                     |

| Pin<br>Mnemonic         | Output<br>Driver | Input<br>Synchronized | input<br>Hysteresis | Discrete<br>I/O | Port<br>Designation |
|-------------------------|------------------|-----------------------|---------------------|-----------------|---------------------|
| FC[2:0]/CS[5:3]         | A                | Y                     | N                   | 0               | C[2:0]              |
| FREEZE/QUOT             | A                |                       |                     | —               |                     |
| HALT                    | Во               | Y                     | N                   | —               |                     |
| IC4/OC5                 | A                | Y                     | Y                   | I/O             | GP4                 |
| IC[3:1]                 | A                | Y                     | Y                   | I/O             | GP[7:5]             |
| IRQ[7:1]                | В                | Y                     | Y                   | I/O             | F[7:1]              |
| MISO                    | Во               | Y                     | Y                   | I/O             | QS0                 |
| MODCLK <sup>1</sup>     | В                | Y                     | N                   | I/O             | F0                  |
| MOSI                    | Во               | Y                     | Y                   | I/O             | QS1                 |
| OC[4:1]                 | A                | Y                     | Y                   | 1/0             | GP[3:0]             |
| PAI <sup>3</sup>        | -                | Y                     | Y                   | I               | Separate            |
| PCLK <sup>3</sup>       | -                | Y                     | Y                   | I               | Separate            |
| PCS0/SS                 | Во               | Y                     | Y                   | I/O             | QS3                 |
| PCS[3:1]                | Во               | Y                     | Y                   | 1/0             | QS[6:4]             |
| PWMA, PWMB <sup>4</sup> | A                | —                     | —                   | 0               | Separate            |
| R/W                     | A                | Y                     | N                   | _               | —                   |
| RESET                   | Во               | Y                     | Y                   |                 |                     |
| RXD                     | _                | N                     | N                   |                 |                     |
| SCK                     | Во               | Y                     | Y                   | I/O             | QS2                 |
| SIZ[1:0]                | В                | Y                     | N                   | I/O             | E[7:6]              |
| TSTME/TSC               | -                | Y                     | Y                   |                 |                     |
| TXD                     | Во               | Y                     | Y                   | I/O             | QS7                 |
| V <sub>RH</sub> 5       | —                |                       |                     |                 |                     |
| V <sub>RL</sub> 5       | -                | —                     |                     |                 |                     |
| XFC <sup>2</sup>        | _                |                       |                     | Special         |                     |
| XTAL <sup>2</sup>       | -                |                       |                     | Special         |                     |

## Table 3-2. MC68HC16Z1 Pin Characteristics (Continued)

NOTES

1. DATA[15:0] are synchronized during reset only. MODCLK, MCCI and ADC pins are DATAL IS of all synchronized during reserving. McDefaile ADC pins and synchronized only when used as input port pins.
 EXTAL, XFC, and XTAL are clock reference connections.
 PAI and PCLK can be used for discrete input, but are not part of an I/O port.
 PWMA and PWMB can be used for discrete output, but are not part of an I/O port.

5. VRH and VRL are ADC reference voltage inputs.

## Table 3-3. MC68HC16Z1 Power Connections

| V <sub>STBY</sub>                  | Standby RAM Power/Clock Synthesizer Power   |
|------------------------------------|---------------------------------------------|
| VDDSYN                             | Clock Synthesizer Power                     |
| V <sub>DDA</sub> /V <sub>SSA</sub> | A/D Converter Power                         |
| V <sub>SSE</sub> /V <sub>DDE</sub> | External Periphery Power (Source and Drain) |
| V <sub>SSI</sub> /V <sub>DDI</sub> | Internal Module Power (Source and Drain)    |

#### 3.4 Signal Descriptions

The following tables are a quick reference to MC68HC16Z1 signals. Table 3–4 shows signal origin, type, and active state. Table 3–5 describes signal functions. Both tables are sorted alphabetically by mnemonic. MCU pins often have multiple functions — more than one description can apply to a pin.

| Signal     | MCU    | Signal       | Active        |
|------------|--------|--------------|---------------|
| Name       | Module | Туре         | State         |
| ADDR[23:0] | SIM    | Bus          |               |
| AN[7:0]    | ADC    | Input        |               |
| AS         | SIM    | Output       | 0             |
| AVEC       | SIM    | Input        | 0             |
| BERR       | SIM    | Input        | 0             |
| BG         | SIM    | Output       | 0             |
| BGACK      | SIM    | Input        | 0             |
| ВКРТ       | CPU16  | Input        | 0             |
| BR         | SIM    | Input        | 0             |
| CLKOUT     | SIM    | Output       |               |
| CS[10:0]   | SIM    | Output       | 0             |
| CSBOOT     | SIM    | Output       | 0             |
| DATA[15:0] | SIM    | Bus          |               |
| DS         | SIM    | Output       | 0             |
| DSACK[1:0] | SIM    | Input        | 0             |
| DSCLK      | CPU16  | Input        | Serial Clock  |
| DSI        | CPU16  | Input        | (Serial Data) |
| DSO        | CPU16  | Output       | (Serial Data) |
| EXTAL      | SIM    | Input        |               |
| FC[2:0]    | SIM    | Output       |               |
| FREEZE     | SIM    | Output       | 1             |
| HALT       | SIM    | Input/Output | 0             |
| IC[4:1]    | GPT    | Input        |               |
| IPIPE0     | CPU16  | Output       |               |
| IPIPE1     | CPU16  | Output       | <u> </u>      |
| IRQ[7:1]   | SIM    | Input        | 0             |
| MISO       | QSM    | Input/Output |               |
| MODCLK     | SIM    | Input        | _             |
| MOSI       | QSM    | Input/Output |               |
| OC[5:1]    | GPT    | Output       | _             |
| PADA[7:0]  | ADC    | Input        | (Port)        |
| PAI        | GPT    | Input        |               |
| PC[6:0]    | SIM    | Output       | (Port)        |

Table 3-4. MC68HC16Z1 Signal Characteristics

| Signal<br>Name | MCU<br>Module | Signal<br>Type | Active<br>State |
|----------------|---------------|----------------|-----------------|
| PE[7:0]        | SIM           | Input/Output   | (Port)          |
| PF[7:0]        | SIM           | Input/Output   | (Port)          |
| PGP[7:0]       | GPT           | Input/Output   | (Port)          |
| PQS[7:0]       | QSM           | Input/Output   | (Port)          |
| PCLK           | GPT           | Input          |                 |
| PCS[3:0]       | QSM           | Input/Output   |                 |
| PWMA, PWMB     | GPT           | Output         |                 |
| QUOT           | SIM           | Output         |                 |
| R/W            | SIM           | Output         | 1/0             |
| RESET          | SIM           | Input/Output   | 0               |
| RXD            | QSM           | Input          |                 |
| SCK            | QSM           | Input/Output   |                 |
| SIZ[1:0]       | SIM           | Output         |                 |
| SS             | QSM           | Input          | 0               |
| TSC            | SIM           | Input          |                 |
| TSTME          | SIM           | Input          | 0               |
| TXD            | QSM           | Output         |                 |
| VRH            | ADC           | Input          |                 |
| VRL            | ADC           | Input          |                 |
| XFC            | SIM           | Input          |                 |
| XTAL           | SIM           | Output         |                 |

## Table 3-4. MC68HC16Z1 Signal Characteristics (Continued)

## Table 3-5. MC68HC16Z1 Signal Function

| Signal Name              | Mnemonic    | Function                                                     |
|--------------------------|-------------|--------------------------------------------------------------|
| Address Strobe           | ĀS          | Indicates that a valid address is on the address bus         |
| Autovector               | AVEC        | Requests an automatic vector during interrupt acknowledge    |
| Bus Error                | BERR        | Indicates that a bus error has occurred                      |
| Bus Grant                | BG          | Indicates that the MCU has relinquished the bus              |
| Bus Grant<br>Acknowledge | BGACK       | Indicates that an external device has assumed bus mastership |
| Breakpoint               | BKPT        | Signals a hardware breakpoint to the CPU                     |
| Bus Request              | BR          | Indicates that an external device requires bus mastership    |
| Chip Selects             | CS[10:0]    | Select external devices at programmed addresses              |
| Boot Chip Select         | CSBOOT      | Chip select for external boot startup ROM                    |
| Address Bus              | ADDR[19:0]  | 20-bit address bus used by CPU16                             |
| Address Bus              | ADDR[23:20] | 4 MSB on IMB, test only, outputs follow ADDR19               |
| ADC Analog Input         | AN[7:0]     | Inputs to ADC MUX                                            |
| System Clockout          | CLKOUT      | System clock output                                          |
| Data Bus                 | DATA[15:0]  | 16-bit data bus                                              |

## Table 3-5. MC68HC16Z1 Signal Function (Continued)

| Signal Name                          | Mnemonic                          | Function                                                                                                                                                                 |
|--------------------------------------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Data Strobe                          | DS                                | During a read cycle, indicates that an external device should<br>place valid data on the data bus. During a write cycle, indicates<br>that valid data is on the data bus |
| Halt                                 | HALT                              | Suspend external bus activity                                                                                                                                            |
| Interrupt Request Level              | IRQ[7:1]                          | Provides an interrupt priority level to the CPU                                                                                                                          |
| Data and Size<br>Acknowledge         | DSACK[1:0]                        | Provide asynchronous data transfers and dynamic bus sizing                                                                                                               |
| Peripheral Chip Select               | PCS[3:0]                          | QSPI peripheral chip selects                                                                                                                                             |
| Reset                                | RESET                             | System reset                                                                                                                                                             |
| Test Mode Enable                     | TSTME                             | Hardware enable for SIM test mode                                                                                                                                        |
| Development Serial In,<br>Out, Clock | DSI, DSO,<br>DSCLK                | Serial I/O and clock for background debug mode                                                                                                                           |
| Crystal Oscillator                   | EXTAL, XTAL                       | Connections for clock synthesizer circuit reference;<br>a crystal or an external oscillator can be used                                                                  |
| Function Codes                       | FC[2:0]                           | Identify processor state and current address space                                                                                                                       |
| Freeze                               | FREEZE                            | Indicates that the CPU has entered background mode                                                                                                                       |
| Instruction Pipeline                 | PIPE[1:0]                         | Indicate instruction pipeline activity                                                                                                                                   |
| Master In Slave Out                  | MISO                              | Serial input to QSPI in master mode;<br>serial output from QSPI in slave mode                                                                                            |
| Clock Mode Select                    | MODCLK                            | Selects the source and type of system clock                                                                                                                              |
| Master Out Slave In                  | MOSI                              | Serial output from QSPI in master mode;<br>serial input to QSPI in slave mode                                                                                            |
| Port ADA                             | PADA[7:0]                         | ADC digital input port signals                                                                                                                                           |
| Port C                               | PC[6:0]                           | SIM digital output port signals                                                                                                                                          |
| Port E                               | PE[7:0]                           | SIM digital I/O port signals                                                                                                                                             |
| Port F                               | PF[7:0]                           | SIM digital I/O port signals                                                                                                                                             |
| Port GP                              | PGP[7:0]                          | GPT digital I/O port signals                                                                                                                                             |
| Port QS                              | PQS[7:0]                          | QSM digital I/O port signals                                                                                                                                             |
| Quotient Out                         | QUOT                              | Provides the quotient bit of the polynomial divider                                                                                                                      |
| Read/Write                           | R∕₩                               | Indicates the direction of data transfer on the bus                                                                                                                      |
| SCI Receive Data                     | RXD                               | Serial input to the SCI                                                                                                                                                  |
| QSPI Serial Clock                    | SCK                               | Clock output from QSPI in master mode;<br>clock input to QSPI in slave mode                                                                                              |
| Size SIZ[1:0                         |                                   | Indicates the number of bytes to be transferred during a bus cycle                                                                                                       |
| Slave Select                         | SS                                | Causes serial transmission when QSPI is in slave mode;<br>causes mode fault in master mode                                                                               |
| Three-State Control                  | TSC                               | Places all output drivers in a high-impedance state                                                                                                                      |
| SCI Transmit Data                    | TXD                               | Serial output from the SCI                                                                                                                                               |
| ADC Reference Voltage                | V <sub>RH</sub> , V <sub>RL</sub> | Provide precise reference for A/D conversion                                                                                                                             |
| External Filter<br>Capacitor         | XFC                               | Connection for external phase-locked loop filter capacitor                                                                                                               |

#### 3.5 Intermodule Bus

The intermodule bus (IMB) is a standardized bus developed to facilitate design of modular microcontrollers. The modules in the MC68HC16Z1 communicate with one another and with external components via the IMB. Although the full IMB supports 24 address and 16 data lines, the CPU16 module in the MC68HC16Z1 uses only 16 data lines and 20 address lines. ADDR[23:20] are tied to ADDR19 when processor driven. ADDR[23:20] are brought out to pins for test purposes only.

#### 3.6 System Memory Maps

Figures 3–3 through 3–5 are MC68HC16Z1 memory maps. Figure 3–3 shows IMB addresses of internal registers and the SRAM array. Figures 3–4 and 3–5 show system memory maps that use different external decoding schemes.

#### 3.6.1 Internal Register Map

In Figure 3–3, IMB ADDR[23:20] are represented by the letter Y. The value represented by Y determines the base address of MCU module control registers. In the MC68HC16Z1, Y is equal to M111, where M is the logic state of the module mapping (MM) bit in the system integration module configuration register (SIMCR). Since the CPU16 uses only ADDR[19:0], and ADDR[23:20] follow the logic state of ADDR19 when CPU driven, the CPU cannot access IMB addresses from \$080000 to \$F7FFFF. In order for the MCU to function correctly, MM must be set (Y must equal \$F). If M is cleared, internal registers are mapped to base address \$700000, and are inaccessible until a reset occurs. The SRAM array is positioned by a base address register in the SRAM CTRL block. Unimplemented blocks are mapped externally.

## 3.6.2 Pseudolinear Address Maps

Figures 3–4 and 3–5 both show the complete CPU16 pseudolinear address space. Address space can be split into physically distinct program and data spaces by decoding the MCU function code outputs. Figure 3–4 shows the memory map of a system that has combined program and data spaces. Figure 3–5 shows the memory map when MCU function code outputs are decoded.

Reset and exception vectors are mapped into bank 0 and cannot be relocated. The CPU16 program counter, stack pointer, and Z index register can be initialized to any address in pseudolinear memory, but exception vectors are limited to 16-bit addresses — to access locations outside of bank 0 during exception handler routines (including interrupt exceptions), a jump table must be used. Refer to **SECTION 5 CENTRAL PROCESSING UNIT** for more information concerning memory management, extended addressing, and exception processing. Refer to **SECTION 4 SYSTEM INTEGRATION MODULE** for more information concerning function codes, address space types, resets, and interrupts.







MC68HC16Z1 USER'S MANUAL



# Figure 3–5. Pseudolinear Addressing With Combined Program and Data Spaces





## 3.7 System Reset

The following information is a concise reference only. MC68HC16Z1 system reset is a complex operation — to understand operation during and after reset, refer to SECTION 4 SYSTEM INTEGRATION MODULE, paragraph 4.5 Reset.

## 3.7.1 System Reset Mode Selection

The logic states of certain data bus pins during reset determine system integration module operating configuration. In addition, the state of the MODCLK pin determines system clock source and the state of the  $\overline{\rm BKPT}$  pin determines what happens during subsequent breakpoint assertions. Table 3–6 is a summary of reset mode selection options.

| Mode Select Pin                           | Default Function<br>(Pin Left High)                                                 | Alternate Function<br>(Pin Pulled Low)                             |
|-------------------------------------------|-------------------------------------------------------------------------------------|--------------------------------------------------------------------|
| DATA0                                     | CSBOOT 16-Bit                                                                       | CSBOOT 8-Bit                                                       |
| DATA1                                     | CS0<br>CS1<br>CS2                                                                   | BR<br>BG<br>BGACK                                                  |
| DATA2                                     | CS3<br>CS4<br>CS5                                                                   | FC0<br>FC1<br>FC2                                                  |
| DATA3<br>DATA4<br>DATA5<br>DATA6<br>DATA7 | <u>CS6</u><br><u>CS7-CS6</u><br><u>CS8-CS6</u><br><u>CS9-CS6</u><br><u>CS10-CS6</u> | ADDR19<br>ADDR[20:19]<br>ADDR[21:19]<br>ADDR[22:19]<br>ADDR[23:19] |
| DATA8                                     | DSACK0, DSACK1,<br>AVEC, DS, AS,<br>SIZE                                            | PORTE                                                              |
| DATA9                                     | IRQ7-IRQ1<br>MODCLK                                                                 | PORTF                                                              |
| DATA11                                    | Test Mode Disabled                                                                  | Test Mode Enabled                                                  |
| MODCLK                                    | VCO = System Clock                                                                  | EXTAL = System Clock                                               |
| BKPT                                      | Background Mode Disabled                                                            | Background Mode Enabled                                            |

Table 3-6. SIM Reset Mode Selection

## 3.7.2 MCU Module Pin Function During Reset

Generally, module pins default to port functions, and input/output ports are set to input state. This is accomplished by disabling pin functions in the appropriate control registers, and by clearing the appropriate port data direction registers. Table 3–7 is a summary of module pin function following reset.

| Module | Pin Mnemonic      | Function          |
|--------|-------------------|-------------------|
| ADC    | PADA[7:0]/AN[7:0] | DISCRETE INPUT    |
|        | VRH               | REFERENCE VOLTAGE |
|        | VRL               | REFERENCE VOLTAGE |
| CPU    | DSI/IPIPE1        | DSI/IPIPE1        |
|        | DSO/IPIPE0        | DSO/IPIPE0        |
|        | BKPT/DSCKL        | BKPT/DSCKL        |
| GPT    | PGP7/IC4/OC5      | DISCRETE INPUT    |
|        | PGP[6:3]/OC[4:1]  | DISCRETE INPUT    |
|        | PGP[2:0]/IC[3:1]  | DISCRETE INPUT    |
|        | PAI               | DISCRETE INPUT    |
|        | PCLK              | DISCRETE INPUT    |
|        | PWMA, PWMB        | DISCRETE OUTPUT   |
| QSM    | PQS7/TXD          | DISCRETE INPUT    |
|        | PQS[6:4]/PCS[3:1] | DISCRETE INPUT    |
|        | PQS3/PCS0/SS      | DISCRETE INPUT    |
|        | PQS2/SCK          | DISCRETE INPUT    |
|        | PQS1/MOSI         | DISCRETE INPUT    |
|        | PQS0/MISO         | DISCRETE INPUT    |
|        | RXD               | RXD               |

#### Table 3–7. Module Reset Pin Function

## SECTION 4 SYSTEM INTEGRATION MODULE

The MC68HC16Z1 system integration module (SIM) consists of five functional blocks. Figure 4–1 is a block diagram of the SIM. Refer to **APPENDIX D REGISTER SUMMARY** for more information.

The system configuration and protection block controls configuration parameters and provides bus and software watchdog monitors. In addition, it provides a periodic interrupt generator to support execution of time-critical control routines.

The system clock generates clock signals used by the SIM, other IMB modules, and external devices.

The external bus interface handles the transfer of information between IMB modules and external address space.

The chip-select block provides 12 chip-select signals. Each chip-select signal has an associated base register and option register that contain the programmable characteristics of that chip select.

The system test block incorporates hardware necessary for testing the MCU. It is used to perform factory tests, and its use in normal applications is not supported.



Figure 4–1. System Integration Module Block Diagram

## 4.1 System Configuration and Protection

This functional block controls MC68HC16Z1 module configuration, preserves reset status, monitors internal activity, and provides periodic interrupt generation. Figure 4–2 is a block diagram of the submodule.



Figure 4-2. System Configuration and Protection

## 4.1.1 Module Mapping

Control registers for all the modules in the microcontroller are mapped into a 4-Kbyte block. The state of the module mapping (MM) bit in the SIM module configuration register (MCR) determines where the control register block is located in the system memory map. When MM = 0, register addresses range from \$7FF000 to \$7FFFFF; when MM = 1, register addresses range from \$FFF000 to \$FFFFFF.

In the MC68HC16Z1, ADDR[23:20] follow the logic state of ADDR19 unless externally driven. MM corresponds to IMB ADDR23. If MM is cleared, the SIM maps IMB modules into address space \$7FF000-\$7FFFFF, which is inaccessible to the CPU16. Modules remain inaccessible until reset occurs. The reset state of MM is one, but the bit is one-time writable. Initialization software should make certain it remains set.

#### 4.1.2 Interrupt Arbitration

Each module that can generate interrupt requests has an interrupt arbitration (IARB) field. Arbitration between interrupt requests of the same priority is performed by means of serial contention between IARB field bit values. Contention must take place whenever an interrupt request is acknowledged, even when there is only a single pending request. In order for contention to take place, an IARB field must have a non-zero value. If an interrupt request from a module with an IARB field value of %0000 is recognized, the CPU16 processes a spurious interrupt exception.

Because the SIM routes external interrupt requests to the CPU16, the SIM IARB field value is used for arbitration between internal and external interrupts of the same priority. The reset value of IARB for the SIM is %1111, and the reset IARB value for all other modules is %0000 — this prevents SIM interrupts from being discarded during initialization. Refer to **4.6 Interrupts** for a comprehensive discussion of interrupt arbitration.

#### 4.1.3 Show Internal Cycles

A show cycle allows internal bus transfers to be externally monitored. The SHEN field in the MCR determines what the external bus interface does during internal transfer operations. Table 4–1 shows whether data is driven externally, and whether external bus arbitration can occur. Refer to **4.4.6.6 Show Cycles** for more information.

Table 4–1. Show Cycle Enable Bits

| SHEN | Action                                                                                           |
|------|--------------------------------------------------------------------------------------------------|
| 00   | Show cycles disabled, external arbitration enabled                                               |
| 01   | Show cycles enabled, external arbitration disabled                                               |
| 10   | Show cycles enabled, external arbitration enabled                                                |
| 11   | Show cycles enabled, external arbitration enabled;<br>Internal activity is halted by a bus grant |

## 4.1.4 Factory Test Mode

The internal IMB can be slaved to an external master for direct module testing. This mode is reserved for factory testing. Slave mode is enabled by holding DATA11 low during reset. The slave enabled (SLVEN) bit is a read-only bit that shows the reset state of DATA11.

#### 4.1.5 Register Access

Although the module configuration register contains a user/supervisor mode bit, SUPV, that is used to control access in some members of the modular microcontroller family, the MC68HC16Z1 always operates in the supervisor access mode. The state of SUPV has no meaning in the MC68HC16Z1.

#### 4.1.6 Reset Status

The reset status register (RSR) shows internal MCU status during reset. Refer to **4.5.9 Reset Status Register** for more information.

#### 4.1.7 Bus Monitor

The internal bus monitor checks for excessively long data and size acknowledge (DSACK) or autovector (AVEC) signal response times during normal bus cycles. The monitor asserts the internal bus error (BERR) signal when response time is excessive.

DSACK and AVEC response times are measured in clock cycles. Maximum allowable response time can be selected by setting the bus monitor timing (BMT) field in the system protection control register (SYPCR). Table 4–2 shows possible periods.

| BMT | <b>Bus Monitor Timeout Period</b> |  |  |  |
|-----|-----------------------------------|--|--|--|
| 00  | 64 System Clocks                  |  |  |  |
| 01  | 32 System Clocks                  |  |  |  |
| 10  | 16 System Clocks                  |  |  |  |
| 11  | 8 System Clocks                   |  |  |  |

| Table 4-2. Bus Monito | or Period |
|-----------------------|-----------|
|-----------------------|-----------|

The monitor does not check DSACK response on the external bus unless the CPU16 initiates a bus cycle. The BME bit in SYPCR enables the internal bus monitor for internal to external bus cycles. If a system contains external bus masters, an external bus monitor must be implemented, and the internal to external bus monitor option must be disabled.

When monitoring transfers to an 8-bit port, the bus monitor does not reset until both byte accesses of a word transfer are completed. Monitor timeout period must be at least twice the number of clocks that a single byte access requires.

#### 4.1.8 Halt Monitor

The halt monitor responds to an assertion of the HALT signal on the internal bus. Refer to **4.4.5.2 Double Bus Fault** for more information. Halt monitor reset can be inhibited by the halt monitor (HME) bit in SYPCR.

#### 4.1.9 Spurious Interrupt Monitor

During interrupt exception processing, the CPU16 normally acknowledges an interrupt request, arbitrates among various sources of interrupt, recognizes the highest priority source, and then acquires a vector or responds to a request for autovectoring. The spurious interrupt monitor asserts the internal bus error signal (BERR) if no interrupt arbitration occurs during interrupt exception processing. The assertion of BERR causes the CPU16 to load the spurious interrupt exception vector into the program counter. The spurious interrupt monitor cannot be disabled. Refer to **4.6 Interrupts** for a comprehensive discussion of interrupts. Detailed information concerning interrupt exception processing is contained in **SECTION 5 CENTRAL PROCESSING UNIT**.

#### 4.1.10 Software Watchdog

The software watchdog is controlled by the software watchdog enable (SWE) bit in SYPCR. When enabled, the watchdog requires that a service sequence be written to software service register SWSR on a periodic basis. If servicing does not take place, the watchdog times out and asserts the reset signal.

Perform a software watchdog service sequence as follows:

- a. Write \$55 to SWSR.
- b. Write \$AA to SWSR.

Both writes must occur in the order listed prior to timeout, but any number of instructions can be executed between the two writes.

Watchdog clock rate is affected by the software watchdog prescale (SWP) and software watchdog timing (SWT) fields in SYPCR.

MOTOROLA 4–6 SWP determines system clock prescaling for the watchdog timer. Either no prescaling or prescaling by a factor of 512 can be selected. The value of SWP is affected by the state of the MODCLK pin during reset, as shown in Table 4–3. System software can change SWP value.

#### Table 4–3. MODCLK Pin and SWP Bit During Reset

| MODCLK             | SWP       |
|--------------------|-----------|
| 0 (External Clock) | 1 (+ 512) |
| 1 (Internal Clock) | 0 (+ 1)   |

The SWT field selects the divide ratio used to establish software watchdog timeout period. Timeout period is given by the following equations.

Timeout Period = 1/(EXTAL Frequency/Divide Ratio) or Timeout Period = Divide Ratio/EXTAL Frequency

Table 4–4 gives the ratio for each combination of SWP and SWT bits. When SWT[1:0] are modified, a watchdog service sequence must be performed before the new timeout period can take effect.

| SWP | SWT | Ratio                                                 |
|-----|-----|-------------------------------------------------------|
| 0   | 00  | 2 <sup>9</sup>                                        |
| 0   | 01  | 2 <sup>11</sup>                                       |
| 0   | 10  | 2 <sup>13</sup>                                       |
| 0   | 11  | 2 <sup>15</sup>                                       |
| 1   | 00  | 2 <sup>18</sup>                                       |
| 1   | 01  | 2 <sup>20</sup><br>2 <sup>22</sup><br>2 <sup>24</sup> |
| 1   | 10  | 222                                                   |
| 1   | 11  | 2 <sup>24</sup>                                       |

## Table 4-4.Software Watchdog Ratio

Figure 4–3 is a block diagram of the watchdog timer and the clock control for the periodic interrupt timer.



Figure 4–3. Periodic Interrupt Timer and Software Watchdog Timer

#### 4.1.11 Periodic Interrupt Timer

The periodic interrupt timer allows a user to generate interrupts of specific priority at predetermined intervals. This capability is often used to schedule control system tasks that must be performed within time constraints. The timer consists of a prescaler, a modulus counter, and registers that determine interrupt timing, priority and vector assignment. Refer to **SECTION 5 CENTRAL PROCESSING UNIT** for detailed information concerning interrupt exception processing.

The periodic interrupt modulus counter is clocked by a signal derived from the buffered crystal oscillator (EXTAL) input pin unless an external frequency source is used. The value of the periodic timer prescaler (PTP) bit in the periodic interrupt timer register (PITR) determines system clock prescaling for the watchdog timer. Either no prescaling or prescaling by a factor of 512 can be selected. The value of PTP is affected by the state of the MODCLK pin during reset, as shown in Table 4–5. System software can change PTP value.

MOTOROLA 4–8 SYSTEM INTEGRATION MODULE

### Table 4–5. MODCLK Pin and PTP Bit at Reset

| MODCLK             | РТР       |
|--------------------|-----------|
| 0 (External Clock) | 1 (+ 512) |
| 1 (Internal Clock) | 0 (+ 1)   |

Either clock signal (EXTAL or EXTAL + 512) is divided by four before driving the modulus counter (PITCLK). The modulus counter is initialized by writing a value to the periodic timer modulus (PITM) field. A zero value turns off the periodic timer. When the modulus counter value reaches zero, an interrupt is generated. The modulus counter is then reloaded with the value in PITM and counting repeats. If a new value is written to PITR, it is loaded into the modulus counter when the current count is completed.

Use the following expression to calculate timer period.

PIT Period = [(PIT Modulus)(Prescaler value)(4)]/EXTAL Frequency

Interrupt priority and vectoring are determined by the values of the periodic interrupt request level (PIRQL) and periodic interrupt vector (PIV) fields in the periodic interrupt control register (PICR).

Content of PIRQL is compared to the CPU16 interrupt priority mask to determine whether the interrupt is recognized. Table 4–6 shows priority of PIRQL values. Due to SIM hardware prioritization, a PIT interrupt is serviced before an external IRQ of the same priority. The periodic timer continues to run when the interrupt is disabled.

| renoule interrupt rinoity |                             |  |  |  |
|---------------------------|-----------------------------|--|--|--|
| PIRQL                     | Priority Level              |  |  |  |
| 000                       | Periodic Interrupt Disabled |  |  |  |
| 001                       | Interrupt Priority Level 1  |  |  |  |
| 010                       | Interrupt Priority Level 2  |  |  |  |
| 011                       | Interrupt Priority Level 3  |  |  |  |
| 100                       | Interrupt Priority Level 4  |  |  |  |
| 101                       | Interrupt Priority Level 5  |  |  |  |
| 110                       | Interrupt Priority Level 6  |  |  |  |
| 111                       | Interrupt Priority Level 7  |  |  |  |

| Т        | able  | 4–6. |          |
|----------|-------|------|----------|
| Periodic | Inter | rupt | Priority |

The PIV field contains the periodic interrupt vector. The vector is placed on the IMB when an interrupt request is made. The vector number is multiplied by two to form the vector offset, which is added to \$0000 to obtain the address of the vector. Reset value of the PIV field is \$0F, which generates the uninitialized interrupt vector.

#### 4.1.12 Low-Power STOP Operation

When the CPU16 executes the LPSTOP instruction, the current interrupt priority mask is stored in the clock control logic, internal clocks are disabled according to the state of the STSIM bit in the SYNCR, and the MC68HC16Z1 enters low-power stop mode. The bus monitor, halt monitor, and spurious interrupt monitor are all inactive during low-power stop.

During low-power stop, the clock input to the software watchdog timer is disabled, and the timer stops. The software watchdog begins to run again on the first rising clock edge after low-power stop ends. The watchdog is not reset by low-power stop — a service sequence must be performed to reset the timer.

The periodic interrupt timer does not respond to the LPSTOP instruction. It continues to run at the same frequency as EXTAL during LPSTOP. A PIT interrupt can bring the MCU out of low-power stop condition if it has a higher priority than the interrupt mask value stored in the clock control logic when low-power stop is initiated. To stop the periodic interrupt timer, PITR must be loaded with a zero value before the LPSTOP instruction is executed.

#### 4.1.13 Freeze Operation

The FREEZE signal is used to halt MCU operations during debugging. FREEZE is asserted internally by the CPU16 if a breakpoint occurs while background mode is enabled. When FREEZE is asserted, only the bus monitor, software watchdog, and periodic interrupt timer are affected. The halt monitor and spurious interrupt monitor continue to operate normally. Setting the freeze bus monitor (FRZBM) bit in the MCR disables the bus monitor when FREEZE is asserted, and setting the freeze software watchdog (FRZSW) bit disables the software watchdog and the periodic interrupt timer when FREEZE is asserted. When FRZSW is set, FREEZE assertion must be at least two times the PIT clock source period to ensure an accurate number of PIT counts.

#### 4.2 System Clock

The system clock in the SIM provides timing signals for the IMB modules and for an external peripheral bus. Because the MC68HC16Z1 is a fully static design, register and memory contents are not affected when clock rate changes. System hardware and software support changes in clock rate during operation. The system clock signal can be generated in three ways. An internal phaselocked loop can synthesize the clock from either an internal or an external frequency source, or the clock signal can be input from an external source.

Figure 4–4 is a block diagram of the system clock.



1. MUST BE LOW-LEAKAGE CAPACITOR (INSULATION RESISTANCE 30,000 M $\Omega$  OR GREATER). 2. CAPACITANCE BASED ON A TEST CIRCUIT CONSTRUCTED WITH A DAISHINKU DMX-38 32,768 kHz CRYSTAL.



#### 4.2.1 Clock Sources

The state of the clock mode (MODCLK) pin during reset determines clock source. When MODCLK is held high during reset, the clock synthesizer generates a clock signal from either an internal or an external reference frequency — clock synthesizer control register SYNCR determines operating frequency and various modes of operation. When MODCLK is held low during reset, the clock synthesizer is disabled, and an external system clock signal must be applied — SYNCR control bits have no effect.

A reference crystal must be connected between the EXTAL and XTAL pins in order to use the internal oscillator. A 32.768-kHz watch crystal is recommended — these crystals are readily available and inexpensive. MC68HC16Z1 clock synthesizer specifications (**APPENDIX A**, Table A–3, Clock Control Timing) are based upon a typical 32.768-kHz crystal.

| MC68HC16Z1    | SYSTEM | INTEGRATION | MODULE |
|---------------|--------|-------------|--------|
| USER'S MANUAL |        |             |        |

MOTOROLA 4–11 4

If an external reference signal or an external system clock signal is applied via the EXTAL pin, the XTAL pin must be left floating. External reference signal frequency must be less than or equal to maximum specified reference frequency. External system clock signal frequency must be less than or equal to maximum specified system clock frequency.

When either an external reference signal or an external system clock signal are applied, duty cycle of the input is critical, especially at operating frequencies close to maximum. The relationship between clock signal duty cycle and clock signal period is expressed:

Minimum external clock period =

minimum external clock high/low time 50% – percentage variation of external clock input duty cycle

#### 4.2.2 Clock Synthesizer Operation

A voltage controlled oscillator (VCO) generates the system clock signal. A portion of the clock signal is fed back to a divider/counter. The divider controls the frequency of one input to a phase comparator. The other phase comparator input is a reference signal, either from the internal crystal oscillator or from an external source. The comparator generates a control signal proportional to the difference in phase between its two inputs. The signal is low-pass filtered and used to correct VCO output frequency.

The synthesizer locks when VCO frequency is identical to reference frequency. Lock time is affected by the filter time constant and by the amount of difference between the two comparator inputs. Whenever comparator input changes, the synthesizer must relock. Lock status is shown by the SLOCK bit in SYNCR.

The MC68HC16Z1 does not come out of reset state until the synthesizer locks. Crystal type, characteristic frequency, and layout of external oscillator circuitry affect lock time.

The low-pass filter requires an external low-leakage capacitor, typically 0.1  $\mu$ F with an insulation resistance specification of 30,000 M $\Omega$  or greater, connected between the XFC and V<sub>DDSYN</sub> pins.

 $V_{DDSYN}$  is used to power the clock circuits. A separate power source increases MCU noise immunity and can be used to run the clock when the MCU is powered down. A quiet power supply must be used as the  $V_{DDSYN}$  source. Adequate external bypass capacitors should be placed as close as possible to the  $V_{DDSYN}$  pin to assure stable operating frequency.

4

When the clock synthesizer is used, control register SYNCR determines operating frequency and various modes of operation. Because the CPU16 in the MC68HC16Z1 operates only in supervisor mode, SYNCR can be read or written at any time.

The SYNCR X bit controls a divide by two prescaler that is not in the synthesizer feedback loop. Setting X doubles clock speed without changing VCO speed — there is no VCO relock delay. The SYNCR W bit controls a 3-bit prescaler in the feedback divider. Setting W increases VCO speed by a factor of four. The SYNCR Y field determines the count modulus for a modulo 64 down counter, causing it to divide by a value of Y + 1. When either W or Y value changes, there is a VCO relock delay (**APPENDIX A**, Table A–3, Clock Control Timing).

Clock frequency is determined by SYNCR bit settings as follows:

$$F_{SYSTEM} = F_{REFERENCE} [4(Y + 1)(2^{2W + X})]$$

In order for the device to perform correctly, the clock frequency selected by the W, X, and Y bits must be within the limits specified for the MCU.

VCO frequency is determined by:

$$F_{VCO} = F_{SYSTEM} (2 - X)$$

The reset state of SYNCR (\$3F00) produces a modulus-64 count — system frequency is 256 times reference frequency.

Table 4–7 shows multipliers for various combinations of SYNCR bits. The range of possible system frequencies can exceed the maximum specified system clock frequency. For instance, with a 32.768-kHz reference and a maximum system frequency of 16.78 MHz (**APPENDIX A**, Table A–3, Clock Control Timing), W and X must not both be set at any count modulus greater than Y = %001111. Table 4–8 shows available clock frequencies for a 16.78 MHz system with a 32.768-kHz reference.

## Table 4-7. Clock Control Multipliers

To obtain clock frequency, find counter modulus in leftmost column, then multiply reference frequency by value in appropriate prescaler cell. Shaded cells are values that exceed specifications for the MC68HC16Z1.

| Modulus |            |            |            |            |
|---------|------------|------------|------------|------------|
| Y       | [W:X] = 00 | [W:X] = 01 | [W:X] = 10 | [W:X] = 11 |
| 000000  | 4          | 8          | 16         | 32         |
| 000001  | 8          | 16         | 32         | 64         |
| 000010  | 12         | 24         | 48         | 96         |
| 000011  | 16         | 32         | 64         | 128        |
| 000100  | 20         | 40         | 80         | 160        |
| 000101  | 24         | 48         | 96         | 192        |
| 000110  | 28         | 56         | 112        | 224        |
| 000111  | 32         | 64         | 128        | 256        |
| 001000  | 36         | 72         | 144        | 288        |
| 001001  | 40         | 80         | 160        | 320        |
| 001010  | 44         | 88         | 176        | 352        |
| 001011  | 48         | 96         | 192        | 384        |
| 001100  | 52         | 104        | 208        | 416        |
| 001101  | 56         | 112        | 224        | 448        |
| 001110  | 60         | 120        | 240        | 480        |
| 001111  | 64         | 128        | 256        | 512        |
| 010000  | 68         | 136        | 272        | 544        |
| 010001  | 72         | 144        | 288        | 576        |
| 010010  | 76         | 152        | 304        | 608        |
| 010011  | 80         | 160        | 320        | 640        |
| 010100  | 84         | 168        | 336        | 672        |
| 010101  | 88         | 176        | 352        | 704        |
| 010110  | 92         | 184        | 368        | 736        |
| 010111  | 96         | 192        | 384        | 768        |
| 011000  | 100        | 200        | 400        | 800        |
| 011001  | 104        | 208        | 416        | 832        |
| 011010  | 108        | 216        | 432        | 864        |
| 011011  | 112        | 224        | 448        | 896        |
| 011100  | 116        | 232        | 464        | 928        |
| 011101  | 120        | 240        | 480        | 960        |
| 011110  | 124        | 248        | 496        | 992        |
| 011111  | 128        | 256        | 512        | 1024       |

| Modulus | Prescalers |            |            |            |
|---------|------------|------------|------------|------------|
| Y       | [W:X] = 00 | [W:X] = 01 | [W:X] = 10 | [W:X] = 11 |
| 100000  | 132        | 264        | 528        | 1056       |
| 100001  | 136        | 272        | 544        | 1088       |
| 100010  | 140        | 280        | 560        | 1120       |
| 100011  | 144        | 288        | 576        | 1152       |
| 100100  | 148        | 296        | 592        | 1184       |
| 100101  | 152        | 304        | 608        | 1216       |
| 100110  | 156        | 312        | 624        | 1248       |
| 100111  | 160        | 320        | 640        | 1280       |
| 101000  | 164        | 328        | 656        | 1312       |
| 101001  | 168        | 336        | 672        | 1344       |
| 101010  | 172        | 344        | 688        | 1376       |
| 101011  | 176        | 352        | 704        | 1408       |
| 101100  | 180        | 360        | 720        | 1440       |
| 101101  | 184        | 368        | 736        | 1472       |
| 101110  | 188        | 376        | 752        | 1504       |
| 101111  | 192        | 384        | 768        | 1536       |
| 110000  | 196        | 392        | 784        | 1568       |
| 110001  | 200        | 400        | 800        | 1600       |
| 110010  | 204        | 408        | 816        | 1632       |
| 110011  | 208        | 416        | 832        | 1664       |
| 110100  | 212        | 424        | 848        | 1696       |
| 110101  | 216        | 432        | 864        | 1728       |
| 110110  | 220        | 440        | 880        | 1760       |
| 110111  | 224        | 448        | 896        | 1792       |
| 111000  | 228        | 456        | 912        | 1824       |
| 111001  | 232        | 464        | 928        | 1856       |
| 111010  | 236        | 472        | 944        | 1888       |
| 111011  | 240        | 480        | 960        | 1920       |
| 111100  | 244        | 488        | 976        | 1952       |
| 111101  | 248        | 496        | 992        | 1984       |
| 111110  | 252        | 504        | 1008       | 2016       |
| 111111  | 256        | 512        | 1024       | 2048       |

## Table 4–7. Clock Control Multipliers (Continued)

#### Table 4-8. System Frequencies from 32.768-kHz Reference

To obtain clock frequency, find counter modulus in leftmost column, then look in appropriate prescaler cell. Empty cells represent values that exceed MC68HC16Z1 maximum system frequency specification.

| Modulus | Prescaler  |            |            |            |
|---------|------------|------------|------------|------------|
| Y       | [W:X] = 00 | [W:X] = 01 | [W:X] = 10 | [W:X] = 11 |
| 000000  | 131        | 262        | 524        | 1049       |
| 000001  | 262        | 524        | 1049       | 2097       |
| 000010  | 393        | 786        | 1573       | 3146       |
| 000011  | 524        | 1049       | 2097       | 4194       |
| 000100  | 655        | 1311       | 2621       | 5243       |
| 000101  | 786        | 1573       | 3146       | 6291       |
| 000110  | 918        | 1835       | 3670       | 7340       |
| 000111  | 1049       | 2097       | 4194       | 8389       |
| 001000  | 1180       | 2359       | 4719       | 9437       |
| 001001  | 1311       | 2621       | 5243       | 10486      |
| 001010  | 1442       | 2884       | 5767       | 11534      |
| 001011  | 1573       | 3146       | 6291       | 12583      |
| 001100  | 1704       | 3408       | 6816       | 13631      |
| 001101  | 1835       | 3670       | 7340       | 14680      |
| 001110  | 1966       | 3932       | 7864       | 15729      |
| 001111  | 2097       | 4194       | 8389       | 16777      |
| 010000  | 2228       | 4456       | 8913       | 17826      |
| 010001  | 2359       | 4719       | 9437       | 18874      |
| 010010  | 2490       | 4981       | 9961       | 19923      |
| 010011  | 2621       | 5243       | 10486      | 20972      |
| 010100  | 2753       | 5505       | 11010      | 22020      |
| 010101  | 2884       | 5767       | 11534      | 23069      |
| 010110  | 3015       | 6029       | 12059      | 24117      |
| 010111  | 3146       | 6291       | 12583      | 25166      |
| 011000  | 3277       | 6554       | 13107      | 26214      |
| 011001  | 3408       | 6816       | 13631      | 27263      |
| 011010  | 3539       | 7078       | 14156      | 28312      |
| 011011  | 3670       | 7340       | 14680      | 29360      |
| 011100  | 3801       | 7602       | 15204      | 30409      |
| 011101  | 3932       | 7864       | 15729      | 31457      |
| 011110  | 4063       | 8126       | 16253      | 32506      |
| 011111  | 4194       | 8389       | 16777      | 33554      |

| Y      | [W:X] = 00 | [W:X] = 01 | [W:X] = 10 | [W:X] = 11 |
|--------|------------|------------|------------|------------|
| 100000 | 4325       | 8651       | 17302      | 34603      |
| 100001 | 4456       | 8913       | 17826      | 35652      |
| 100010 | 4588       | 9175       | 18350      | 36700      |
| 100011 | 4719       | 9437       | 18874      | 37749      |
| 100100 | 4850       | 9699       | 19399      | 38797      |
| 100101 | 4981       | 9961       | 19923      | 39846      |
| 100110 | 5112       | 10224      | 20447      | 40894      |
| 100111 | 5243       | 10486      | 20972      | 41943      |
| 101000 | 5374       | 10748      | 21496      | 42992      |
| 101001 | 5505       | 11010      | 22020      | 44040      |
| 101010 | 5636       | 11272      | 22544      | 45089      |
| 101011 | 5767       | 11534      | 23069      | 46137      |
| 101100 | 5898       | 11796      | 23593      | 47186      |
| 101101 | 6029       | 12059      | 24117      | 48234      |
| 101110 | 6160       | 12321      | 24642      | 49283      |
| 101111 | 6291       | 12583      | 25166      | 50332      |
| 110000 | 6423       | 12845      | 25690      | 51380      |
| 110001 | 6554       | 13107      | 26214      | 52428      |
| 110010 | 6685       | 13369      | 26739      | 53477      |
| 110011 | 6816       | 13631      | 27263      | 54526      |
| 110100 | 6947       | 13894      | 27787      | 55575      |
| 110101 | 7078       | 14156      | 28912      | 56623      |
| 110110 | 7209       | 14418      | 28836      | 57672      |
| 110111 | 7340       | 14680      | 29360      | 58720      |
| 111000 | 7471       | 14942      | 2988       | 59769      |
| 111001 | 7602       | 15204      | 30409      | 60817      |
| 111010 | 7733       | 15466      | 30933      | 61866      |
| 111011 | 7864       | 15729      | 31457      | 62915      |
| 111100 | 7995       | 15991      | 31982      | 63963      |
| 111101 | 8126       | 16253      | 32506      | 65011      |
| 111110 | 8258       | 16515      | 33030      | 66060      |
| 111111 | 8389       | 16777      | 33554      | 67109      |

Table 4–8. System Frequencies from 32.768-kHz Reference(Continued)

#### 4.2.3 External Bus Clock

The state of the external clock division bit (EDIV) in SYNCR determines clock rate for the external bus clock signal (ECLK) available on pin ADDR23. ECLK is a bus clock for MC6800 devices and peripherals. ECLK frequency can be set to system clock frequency divided by eight or system clock frequency divided by sixteen. The clock is enabled by the CS10 field in chip select pin assignment register 1 (CSPAR1). The operation of the external bus clock during low-power stop is described below. Refer to **4.7 Chip Selects** for more information concerning the external bus clock.

#### 4.2.4 Low-Power Operation

Low-power operation is initiated by the CPU16. To reduce power consumption selectively, the CPU can set the STOP bits in each module configuration register. To reduce overall microcontroller power consumption to a minimum, the CPU can execute the LPSTOP instruction, which causes the SIM to turn off the system clock.

When individual module STOP bits are set, clock signals inside each module are turned off, but module registers are still accessible.

When the CPU executes LPSTOP, a special CPU space bus cycle writes a copy of the current interrupt mask into the clock control logic. The SIM brings the MCU out of low-power operation when either an interrupt of higher priority than the stored mask or a reset occurs. Refer to **4.4.4.2 LPSTOP Broadcast Cycles** and **SECTION 5 CENTRAL PROCESSING UNIT** for more information.

During a low-power stop, unless the system clock signal is supplied by an external source, and that source is removed, SIM clock control logic and the SIM clock signal (SIMCLK) continue to operate. The periodic interrupt timer and input logic for the RESET and IRQ pins are clocked by SIMCLK. The SIM can also continue to generate the CLKOUT signal while in low-power mode.

The stop mode system integration module clock (STSIM) and stop mode external clock (STEXT) bits in SYNCR determine clock operation during low-power stop. Table 4–9 summarizes the effects of STSIM and STEXT with various clock sources. MODCLK value is the logic level on the MODCLK pin during the last reset prior to LPSTOP execution. Any clock in the off state is held low.

| Mode Pins |        | ns                    | SYNC  | R Bits | Clock Source          |                       |
|-----------|--------|-----------------------|-------|--------|-----------------------|-----------------------|
| LPSTOP    | MODCLK | EXTAL                 | STSIM | STEXT  | SIMCLK                | CLKOUT                |
| No        | 0      | External<br>Clock     | X     | x      | External<br>Clock     | External<br>Clock     |
| Yes       | 0      | External<br>Clock     | 0     | 0      | External<br>Clock     | Off                   |
| Yes       | 0      | External<br>Clock     | 0     | 1      | External<br>Clock     | External<br>Clock     |
| Yes       | 0      | External<br>Clock     | 1     | 0      | External<br>Clock     | Off                   |
| Yes       | 0      | External<br>Clock     | 1     | 1      | External<br>Clock     | External<br>Clock     |
| No        | 1      | Crystal/<br>Reference | X     | x      | VCO                   | VCO                   |
| Yes       | 1      | Crystal/<br>Reference | 0     | 0      | Crystal/<br>Reference | Off                   |
| Yes       | 1      | Crystal/<br>Reference | 0     | 1      | Crystal/<br>Reference | Crystal/<br>Reference |
| Yes       | 1      | Crystal/<br>Reference | 1     | 0      | VCO                   | Off                   |
| Yes       | 1      | Crystal/<br>Reference | 1     | 1      | VCO                   | VCO                   |

Table 4–9. Clock Control

#### 4.2.5 Loss of Reference Signal

The state of the reset enable (RSTEN) bit in SYNCR determines what happens when clock logic detects a reference failure.

When RSTEN is cleared (default state out of reset), the clock synthesizer is forced into an operating condition referred to as limp mode. Limp mode frequency varies from device to device, but maximum limp frequency does not exceed one half maximum system clock when X = 0, or maximum system clock frequency when X = 1.

When RSTEN is set, the SIM resets the MCU.

The limp status bit (SLIMP) in SYNCR indicates whether the synthesizer has a reference signal. It is set when a reference failure is detected.

#### 4.3 External Bus Interface

The external bus interface (EBI) transfers information between the internal MCU bus and external devices. Figure 4–5 shows a basic system with external memory and peripherals.



1. CAN BE DECODED TO PROVIDE ADDITIONAL ADDRESS SPACE. 2. VARIES DEPENDING UPON PERIPHERAL MEMORY SIZE.



The external bus has 24 address lines and 16 data lines. ADDR[19:0] are normal address outputs, ADDR[23:20] follow the output state of ADDR19.

A three-line handshaking interface performs external bus arbitration. The interface supports byte, word, and long-word transfers. The EBI performs dynamic sizing for data accesses.

SYSTEM INTEGRATION MODULE

The maximum number of bits transferred during an access is referred to as port width. Widths of 8 and 16 bits can be accessed by means of asynchronous bus cycles controlled by the data size (SIZ0 and SIZ1) and the data and size acknowledge (DSACK0 and DSACK1) signals. Multiple bus cycles may be required for a dynamically-sized transfer.

To add flexibility and minimize the necessity for external logic, MCU chip-select logic can be synchronized with EBI transfers. Refer to **4.7 Chip Selects** for more information.

## 4.3.1 Bus Signals

The address bus provides addressing information to external devices. The data bus transfers 8-bit and 16-bit data between the MCU and external devices. Strobe signals, one for the address bus and another for the data bus, indicate the validity of an address and provide timing information for data.

Control signals indicate the beginning of each bus cycle, the address space it is to take place in, the size of the transfer, and the type of cycle. External devices decode these signals and respond to transfer data and terminate the bus cycle. The EBI operates in an asynchronous mode for any port width.

#### 4.3.1.1 Address Bus

Bus signals ADDR[19:0] define the address of the byte (or the most significant byte) to be transferred during a bus cycle. The MCU places the address on the bus at the beginning of a bus cycle. The address is valid while  $\overline{\text{AS}}$  is asserted.

## 4.3.1.2 Address Strobe

Address strobe  $(\overline{AS})$  is a timing signal that indicates the validity of an address on the address bus and of many control signals. It is asserted one-half clock after the beginning of a bus cycle.

#### 4.3.1.3 Data Bus

Bus signals DATA[15:0] comprise a bidirectional, nonmultiplexed parallel bus that transfers data to or from the MCU. A read or write operation can transfer 8 or 16 bits of data in one bus cycle. During a read cycle, the data is latched by the MCU on the last falling edge of the clock for that bus cycle. For a write cycle, all 16 bits of the data bus are driven, regardless of the port width or operand size. The MCU places the data on the data bus one-half clock cycle after  $\overline{AS}$  is asserted in a write cycle.

## 4.3.1.4 Data Strobe

Data strobe  $(\overline{DS})$  is a timing signal. For a read cycle, the MCU asserts  $\overline{DS}$  to signal an external device to place data on the bus.  $\overline{DS}$  is asserted at the same time as  $\overline{AS}$  during a read cycle. For a write cycle,  $\overline{DS}$  signals an external device that data on the bus is valid. The MCU asserts  $\overline{DS}$  one full clock cycle after the assertion of  $\overline{AS}$  during a write cycle.

## 4.3.1.5 Read/Write Signal

The read/write (R/W) signal determines the direction of the transfer during a bus cycle. This signal changes state, when required, at the beginning of a bus cycle, and is valid while  $\overline{AS}$  is asserted. R/W only transitions when a write cycle is preceded by a read cycle or vice versa. The signal may remain low for two consecutive write cycles.

## 4.3.1.6 Size Signals

The size signals (SIZ[1:0]) indicate the number of bytes remaining to be transferred during an operand cycle. They are valid while the address strobe  $(\overline{AS})$  is asserted. Table 4–10 shows SIZ0 and SIZ1 encoding.

Table 4–10. Size Signal Encoding

| SIZ1 | SIZO | Transfer Size |
|------|------|---------------|
| 0    | 1    | Byte          |
| 1    | 0    | Word          |
| 1    | 1    | 3 Byte        |
| 0    | 0    | Long Word     |

## 4.3.1.7 Function Codes

Function code signals FC[2:0] are generated by the CPU16. The function codes can be considered address extensions that designate which of eight external address spaces is accessed during a bus cycle.

Because the CPU16 always operates in supervisor mode (FC2 = 1), address spaces 0 to 3 are not used. Address space 7 is designated CPU space. CPU space is used for control information not normally associated with read or write bus cycles. Function codes are valid while  $\overline{\text{AS}}$  is asserted. Table 4–11 shows address space encoding.

# Table 4–11.Address Space Encoding

| FC2 | FC1 | FC0 | Address Space |
|-----|-----|-----|---------------|
| 1   | 0   | 0   | Reserved      |
| 1   | 0   | 1   | Data Space    |
| 1   | 1   | 0   | Program Space |
| 1   | 1   | 1   | CPU Space     |

# 4.3.1.8 Data and Size Acknowledge Signals

During normal bus transfers, external devices assert the data and size acknowledge signals (DSACK1 and DSACK0) to indicate port width to the MCU. During a read cycle, these signals tell the MCU to terminate the bus cycle and to latch data. During a write cycle, the signals also indicate that an external device has successfully stored data and that the cycle may terminate. DSACK1 and DSACK0 can also be supplied internally by chip-select logic. Refer to **4.7** Chip Selects for more information.

## 4.3.1.9 Bus Error Signal

The bus error (BERR) signal is asserted in the absence of DSACK to indicate a bus error condition. It can also be asserted in conjunction with DSACK to indicate a bus error condition, provided it meets the appropriate timing requirements. Refer to **4.4.5 Bus Exception Control Cycles** for more information.

The internal bus monitor can be used to generate the BERR signal for internal and internal-to-external transfers. An external bus master must provide its own BERR generation and drive the BERR pin, because the internal BERR monitor has no information about transfers initiated by an external bus master. Refer to **4.4.6 Bus Arbitration** for more information.

## 4.3.1.10 Halt Signal

The halt signal (HALT) can be asserted by an external device to cause single bus cycle operation. HALT is typically used for debugging purposes. When BERR and HALT are asserted simultaneously, the MC68HC16Z1 acts as though BERR alone is asserted. This may not be true of other modular microcontrollers. Refer to **4.4.5 Bus Exception Control Cycles** for more information.

## 4.3.1.11 Autovector Signal

The autovector signal ( $\overline{AVEC}$ ) can be used to terminate external interrupt acknowledge cycles. Assertion of  $\overline{AVEC}$  causes the CPU16 to generate vector numbers to locate an interrupt handler routine. If it is continuously asserted, autovectors are generated for all external interrupt requests.  $\overline{AVEC}$  is ignored during all other bus cycles. Refer to **4.6 Interrupts** for more information.  $\overline{AVEC}$  for external interrupt requests can also be supplied internally by chipselect logic. Refer to **4.7 Chip Selects** for more information. The autovector function is disabled when there is an external bus master. Refer to **4.4.6 Bus Arbitration** for more information.

## 4.3.2 Dynamic Bus Sizing

The MCU dynamically interprets the port size of an addressed device during each bus cycle, allowing operand transfers to or from 8-bit and 16-bit ports.

During an operand transfer cycle, an external device signals its port size and indicates completion of the bus cycle to the MCU through the use of the DSACK inputs, as shown in Table 4–12. Chip-select logic can generate data and size acknowledge signals for an external device. Refer to **4.7 Chip Selects** for more information.

Table 4–12. Effect of DSACK Signals

| DSACK1 | DSACKO | Result                                         |
|--------|--------|------------------------------------------------|
| 1      | 1      | Insert Wait States in Current Bus Cycle        |
| 1      | 0      | Complete Cycle — Data Bus Port Size is 8 Bits  |
| 0      | 1      | Complete Cycle — Data Bus Port Size is 16 Bits |
| 0      | 0      | Reserved                                       |

For example, if the CPU is executing an instruction that reads a long-word operand from a 16-bit port, the MCU latches the 16 bits of valid data and then runs another bus cycle to obtain the other 16 bits. The operation for an 8-bit port is similar, but requires four read cycles. The addressed device uses the DSACK signals to indicate the port width. For instance, a 16-bit device always returns DSACK for a 16-bit port (regardless of whether the bus cycle is a byte or word operation).

Dynamic bus sizing requires that the portion of the data bus used for a transfer to or from a particular port size be fixed. A 16-bit port must reside on data bus bits [15:0], and an 8-bit port must reside on data bus bits [15:8]. This minimizes

the number of bus cycles needed to transfer data and ensures that the MCU transfers valid data.

The MCU always attempts to transfer the maximum amount of data on all bus cycles. For a word operation, it is assumed that the port is 16 bits wide when the bus cycle begins.

Operand bytes are designated as shown in Figure 4–6. OP0 – OP3 represent the order of access. For instance, OP0 is the most significant byte of a longword operand, and is accessed first, while OP3, the least significant byte, is accessed last. The two bytes of a word-length operand are OP0 (most significant) and OP1. The single byte of a byte-length operand is OP0.

| Operand    |     |    |    | Byte | Order |   |     |   |
|------------|-----|----|----|------|-------|---|-----|---|
|            | 31  | 24 | 23 | 16   | 15    | 8 | 7   | 0 |
| Long Word  | OP0 |    |    | OP1  | OP2   |   | OP3 |   |
| Three Byte |     |    |    | OP0  | OP1   |   | OP2 |   |
| Word       |     |    |    |      | OP0   |   | OP1 |   |
| Byte       |     |    |    |      |       |   | OP0 |   |

Figure 4–6. Operand Byte Order

## 4.3.3 Operand Alignment

The EBI data multiplexer establishes the necessary connections for different combinations of address and data sizes. The multiplexer takes the two bytes of the 16-bit bus and routes them to their required positions. Positioning of bytes is determined by the size and address outputs. SIZ1 and SIZ0 indicate the remaining number of bytes to be transferred during the current bus cycle. The number of bytes transferred is equal to or less than the size indicated by SIZ1 and SIZ0, depending on port width.

ADDR0 also affects the operation of the data multiplexer. During an operand transfer, ADDR[23:1] indicate the word base address of the portion of the operand to be accessed, and ADDR0 indicates the byte offset from the base. Bear in mind the fact that ADDR[23:20] follow the state of ADDR19 in the MC68HC16Z1.

## 4.3.4 Misaligned Operands

CPU16 processor architecture uses a basic operand size of 16 bits. An operand is misaligned when it overlaps a word boundary. This is determined by the value of ADDR0. When ADDR0 = 0 (an even address), the address is on a word and byte boundary. When ADDR0 = 1 (an odd address), the address is

| MC68HC16Z1          |   |
|---------------------|---|
| <b>USER'S MANUA</b> | L |

SYSTEM INTEGRATION MODULE

on a byte boundary only. A byte operand is aligned at any address; a word or long-word operand is misaligned at an odd address.

In the MC68HC16Z1, the largest amount of data that can be transferred by a single bus cycle is an aligned word. If the MCU transfers a long-word operand via a 16-bit port, the most significant operand word is transferred on the first bus cycle and the least significant operand word on a following bus cycle.

The CPU16 can perform misaligned word transfers. This capability makes it compatible with the MC68HC11 CPU. The CPU16 treats misaligned long-word transfers as two misaligned word transfers. Other modular microcontrollers have wider CPU architectures that support different long-word transfer cases.

#### 4.3.5 Operand Transfer Cases

Table 4–13 summarizes how operands are aligned for various types of transfers. OPn entries are portions of a requested operand that are read or written during a bus cycle and are defined by SIZ1, SIZ0, and ADDR0 for that bus cycle. The following paragraphs discuss all the allowable transfer cases in detail.

| Transfer Case                                      | SIZ1 | SIZO | ADDRO | DSACK1 | DSACKO | DATA<br>[15:8] | DATA<br>[7:0] |
|----------------------------------------------------|------|------|-------|--------|--------|----------------|---------------|
| Byte to 8-bit Port (Even/Odd)                      | 0    | 1    | Х     | 1      | 0      | OP0            | (OP0)         |
| Byte to 16-bit Port (Even)                         | 0    | 1    | 0     | 0      | Х      | OP0            | (OP0)         |
| Byte to 16-bit Port (Odd)                          | 0    | 1    | 1     | 0      | Х      | (OP0)          | OP0           |
| Word to 8-bit Port (Aligned)                       | 1    | 0    | 0     | 1      | 0      | OPO            | (OP1)         |
| Word to 8-bit Port (Misaligned)                    | 1    | 0    | 1     | 1      | 0      | OP0            | (OP0)         |
| Word to 16-bit Port (Aligned)                      | 1    | 0    | 0     | 0      | X      | OP0            | OP1           |
| Word to 16-bit Port (Misaligned)                   | 1    | 0    | 1     | 0      | X      | (OP0)          | OP0           |
| 3 Byte to 8-bit Port (Aligned) <sup>3</sup>        | 1    | 1    | 0     | 1      | 0      | OP0            | (OP1)         |
| 3 Byte to 8-bit Port (Misaligned) <sup>3</sup>     | 1    | 1    | 1     | 1      | 0      | OP0            | (OP0)         |
| 3 Byte to 16-bit Port (Aligned) <sup>4</sup>       | 1    | 1    | 0     | 0      | X      | OP0            | OP1           |
| 3 Byte to 16-bit Port (Misaligned) <sup>3</sup>    | 1    | 1    | 1     | 0      | Х      | (OP0)          | OP0           |
| Long Word to 8-bit Port (Aligned)                  | 0    | 0    | 0     | 1      | 0      | OP0            | (OP1)         |
| Long Word to 8-bit Port (Misaligned) <sup>4</sup>  | 1    | 0    | 1     | 1      | 0      | OP0            | (OP0)         |
| Long Word to 16-bit Port (Aligned)                 | 0    | 0    | 0     | 0      | X      | OP0            | OP1           |
| Long Word to 16-bit Port (Misaligned) <sup>4</sup> | 1    | 0    | 1     | 0      | X      | (OP0)          | OP0           |

 Table 4–13. Operand Alignment

NOTES:

1. X in a column means that the state of the signal has no effect.

2. Operands in parentheses are ignored by the CPU16 during read cycles.

3. Three-byte transfer cases occur only as a result of an aligned long word to byte transfer.

4. The CPU16 treats misaligned long-word transfers as two misaligned word transfers.

## 4.3.5.1 Byte Operand to 8-Bit Port (ADDR0 = 0/1)

To initiate a transfer, the MCU places the desired address on the address bus and drives the size pins to indicate a single-byte operand.



Figure 4-7. Byte Operand to 8-Bit Port (ADDR0 = 0, ADDR0 = 1)

For a read operation, the 8-bit peripheral responds by placing OP0 on DATA[15:8] and asserting DSACK0. The MCU reads OP0 from DATA[15:8] and ignores DATA[7:0].

For a write operation, the MCU drives OP0 on both bytes of the data bus. The peripheral determines operand size and transfers the data to the specified address, then asserts DSACK0 to terminate the bus cycle.

## 4.3.5.2 Byte Operand to 16-Bit Port, Even (ADDR0 = 0)

To initiate transfer, the MCU places the desired address on the address bus and drives the size pins to indicate a single-byte operand.



#### Figure 4–8. Byte Operand to 16-Bit Port, Even (ADDR0 = 0)

For a read operation, the 16-bit peripheral responds by placing OP0 on DATA[15:8] and asserting DSACK1. The MCU reads the data from DATA[15:8] and ignores DATA[7:0].

For a write operation, the MCU drives OP0 on both bytes of the data bus. The peripheral determines operand size and transfers the data to the specified address, then asserts DSACK1 to terminate the bus cycle.

# 4.3.5.3 Byte Operand to 16-Bit Port, Odd (ADDR0 = 1)

To initiate transfer, the MCU places the desired address on the address bus and drives the size pins to indicate a single-byte operand.



Figure 4-9. Byte Operand to 16-Bit Port, Odd (ADDR0 = 1)

For a read operation, the 16-bit peripheral responds by placing OP0 on DATA[7:0] and asserting DSACK1. The MCU then reads the data from DATA[7:0] and ignores DATA[15:8].

For a write operation, the MCU drives OP0 on both bytes of the data bus. The peripheral determines operand size and transfers OP0 to the specified address, then asserts DSACK1 to terminate the bus cycle.

## 4.3.5.4 Word Operand to 8-Bit Port, Aligned

To initiate transfer, the MCU places the desired address on the address bus and drives the size pins to indicate a word operand.

|          | 15  | 8 | 7 |       | 0 |      |      |       |        |        |
|----------|-----|---|---|-------|---|------|------|-------|--------|--------|
| Operand  | OPO |   |   | OP1   |   |      |      |       |        |        |
| Data Bus | 15  | 8 | 7 |       | 0 | SIZ1 | SIZ2 | ADDR0 | DSACK1 | DSACK0 |
| Cycle 1  | OP0 |   |   | (OP1) |   | 1    | 0    | 0     | 1      | 0      |
| Cycle 2  | OP1 |   |   | (OP1) |   | 0    | 1    | 1     | 1      | 0      |

Figure 4-10. Word Operand to 8-Bit Port, Aligned

For a read operation, the 8-bit peripheral responds by placing OP0 on DATA[15:8] and asserting DSACK0. The MCU reads OP0 from DATA[15:8] and ignores DATA[7:0], then decrements the transfer size counter, increments the address, and performs a byte operand to 8-bit port transfer of OP1.

For a write operation, the MCU drives OP0 on DATA[15:8] and OP1 on DATA[7:0]. The 8-bit peripheral transfers OP0 from DATA[15:8] to the specified address, then asserts  $\overrightarrow{\text{DSACK0}}$  to indicate that the first byte has been transferred. The MCU then decrements the transfer size counter, increments the address, and performs a byte operand to 8-bit port transfer of OP1.

# 4.3.5.5 Word Operand to 8-Bit Port, Misaligned

To initiate transfer, the MCU places the desired address on the address bus and drives the size pins to indicate a word operand.



Figure 4–11. Word Operand to 8-Bit Port, Misaligned

For a read operation, the 8-bit peripheral responds by placing OP0 on DATA[15:8] and asserting DSACK0. The MCU reads the upper operand byte from DATA[15:8] and ignores DATA[7:0]. The MCU then decrements the transfer size counter, increments the address, and performs a byte operand to 8-bit port transfer of OP1.

For a write operation, the MCU drives OP0 on DATA[15:8] and OP1 on DATA[7:0]. The 8-bit peripheral transfers OP0 to the specified address, then asserts DSACK0 to indicate that the first byte of word data has been received. The MCU then decrements the transfer size counter, increments the address, and performs a byte operand to 8-bit port transfer of OP1.

4

#### 4.3.5.6 Word Operand to 16-Bit Port, Aligned

To initiate transfer, the MCU places the desired address on the address bus and drives the size pins to indicate a word operand.

|          | 15 |     | 8 | 7 |     | 0 |      |      |       |        |        |
|----------|----|-----|---|---|-----|---|------|------|-------|--------|--------|
| Operand  |    | OP0 |   |   | OP1 |   |      |      |       |        |        |
| Data Bus | 15 |     | 8 | 7 |     | 0 | SIZ1 | SIZ2 | ADDR0 | DSACK1 | DSACK0 |
| Cycle 1  |    | OP0 |   |   | OP1 |   | 1    | 0    | 0     | 0      | х      |

Figure 4-12. Word Operand to 16-Bit Port, Aligned

For a read operation, the peripheral responds by placing OP0 on DATA[15:8] and OP1 on DATA[7:0], then asserts DSACK1 to indicate a 16-bit port. When DSACK1 is asserted, the MCU reads DATA[15:8] and terminates the cycle.

For a write operation, the MCU drives the word operand on DATA[15:0]. The peripheral device then reads the entire operand from DATA[15:0] and asserts DSACK1 to terminate the bus cycle.

## 4.3.5.7 Word Operand to 16-Bit Port, Misaligned

To initiate transfer, the MCU places the desired address on the address bus and drives the size pins to indicate a word operand.

|          | 15    | 8 | 7 |       | 0 |      |      |       |        |        |
|----------|-------|---|---|-------|---|------|------|-------|--------|--------|
| Operand  |       |   |   | OP0   |   |      |      |       |        |        |
|          | OP1   |   |   |       |   |      |      |       |        |        |
| Data Bus | 15    | 8 | 7 |       | 0 | SIZ1 | SIZ2 | ADDR0 | DSACK1 | DSACK0 |
| Cycle 1  | (OP0) |   |   | OP0   |   | 1    | 0    | 1     | 0      | x      |
| Cycle 2  | OP1   |   |   | (OP1) |   | 0    | 1    | 0     | 0      | Х      |

Figure 4-13. Word Operand to 16-Bit Port, Misaligned

For a read operation, the peripheral responds by placing OP0 on DATA[7:0] and asserting DSACK1 to indicate a 16-bit port. When DSACK1 is asserted, the MCU reads OP0 from DATA[7:0], decrements the transfer size counter, increments the address, and performs a byte operand from 8-bit port transfer to acquire OP1.

For a write operation, the MCU first drives OP0 on DATA[7:0] and duplicates it on DATA[15:8]. The peripheral device reads OP0 from DATA[7:0] and asserts DSACK1. The MCU decrements the transfer size counter, increments the address, and performs a byte operand to 8-bit port transfer of OP1.

## 4.3.5.8 Long-Word Operand to 8-Bit Port, Aligned

The MCU drives the address bus with the desired address and the size pins to indicate a long word operand.

|          | 15 | 8  | 7 |       | 0 |      |      |       |        |        |
|----------|----|----|---|-------|---|------|------|-------|--------|--------|
| Operand  | 0  | P0 |   | OP1   |   |      |      |       |        |        |
|          | 0  | P2 |   | OP3   |   | ]    |      |       |        |        |
| Data Bus | 15 | 8  | 7 |       | 0 | SIZ1 | SIZ2 | ADDR0 | DSACK1 | DSACKO |
| Cycle 1  | 0  | P0 | ( | (OP1) |   | 0    | 0    | 0     | 1      | 0      |
| Cycle 2  | 0  | P1 | ( | (OP1) |   | ] 1  | 1    | 1     | 1      | 0      |
| Cycle 3  | 0  | P2 | ( | (OP2) |   | 1    | 0    | 0     | 1      | 0      |
| Cycle 4  | 0  | P3 | ( | (OP3) |   | ] 0  | 1    | 1     | 1      | 0      |

## Figure 4-14. Long-Word Operand to 8-Bit Port, Aligned

For a read operation, the peripheral places OP0 on DATA[15:8] and asserts DSACK0 to indicate an 8-bit port. The MCU reads OP0 from DATA[15:8] and ignores DATA[7:0]. The MCU then decrements the transfer size counter, increments the address, initiates a new cycle, and reads OP1 from DATA[15:8]. The process repeats for OP2 and OP3.

For a write operation, the MCU drives OP0 and OP1 on DATA[15:0]. The peripheral device then reads only OP0 from DATA[15:8] and asserts DSACK0 to indicate an 8-bit port. The MCU then decrements the transfer size counter, increments the address, and writes OP1 to DATA[15:8]. The process repeats for OP2 and OP3.

# 4.3.5.9 Long-Word Operand to 8-Bit Port, Misaligned

The CPU16 treats misaligned long words as two misaligned words. The MCU drives the address bus with the desired address and the size pins to indicate a word operand.

|          | 15  | 8 | 7    | 0  |      |      |       |        |       |
|----------|-----|---|------|----|------|------|-------|--------|-------|
| Operand  |     |   | OP   | 2  |      |      |       |        |       |
|          | OP1 |   | OP   | 2  |      |      |       |        |       |
|          | OP3 |   |      |    |      |      |       |        |       |
| Data Bus | 15  | 8 | 7    | 0  | SIZ1 | SIZ2 | ADDR0 | DSACK1 | DSACK |
| Cycle 1  | OP0 |   | (OP( | )) | 1    | 0    | 1     | 1      | 0     |
| Cycle 2  | OP1 |   | (OP  | 1) | 0    | 1    | 0     | 1      | 0     |
| Cycle 3  | OP2 |   | (OP2 | 2) | 1    | 0    | 1     | 1      | 0     |
| Cycle 4  | OP3 |   | (OP: | 3) | 0    | 1    | 0     | 1      | 0     |

Figure 4–15. Long-Word Operand to 8-Bit Port, Misaligned

For a read operation, the 8-bit peripheral responds by placing OP0 on DATA[15:8] and asserting DSACK0. The MCU reads OP0 from DATA[15:8] and ignores DATA[7:0]. The MCU then decrements the transfer size counter, increments the address, and performs a byte operand to 8-bit port transfer of OP1. One misaligned word has been read — the process repeats for the second word (OP2 and OP3).

For a write operation, the MCU drives OP0 on DATA[15:8] and OP1 on DATA [7:0]. The 8-bit peripheral transfers OP0 to the specified address, then asserts DSACK0 to indicate that the first byte of word data has been received. The MCU then decrements the transfer size counter, increments the address, and performs a byte operand to 8-bit port transfer of OP1. One misaligned word has been written — the process repeats for the second word (OP2 and OP3).

## 4.3.5.10 Long-Word Operand to 16-Bit Port, Aligned

The MCU drives the address bus with the desired address and drives the size pins to indicate a long-word operand.

|          | 15  | 8 | 7   | 0 |      |      |       |        |        |
|----------|-----|---|-----|---|------|------|-------|--------|--------|
| Operand  | OPO |   | OP1 |   |      |      |       |        |        |
|          | OP2 |   | OP3 |   |      |      |       |        |        |
| Data Bus | 15  | 8 | 7   | 0 | SIZ1 | SIZ2 | ADDR0 | DSACK1 | DSACK0 |
| Cycle 1  | OPO |   | OP1 |   | 0    | 0    | 0     | 0      | Х      |
| Cycle 2  | OP2 |   | OP2 |   | 1    | 0    | 0     | 0      | X      |

#### Figure 4-16. Long-Word Operand to 16-Bit Port, Aligned

For a read operation, the 16-bit peripheral responds by placing OP0 on DATA[15:8] and OP1 on DATA[7:0], then asserts DSACK1 to indicate a 16-bit port. The MCU reads OP0 and OP1 from DATA[15:0]. The process repeats for OP2 and OP3.

For a write operation, the MCU drives OP0 on DATA[15:8] and OP1 on DATA[7:0]. The peripheral device reads OP0 and OP1 from DATA[15:0] and asserts DSACK1 to indicate a 16-bit port. The process repeats for OP2 and OP3.

# 4.3.5.11 Long-Word Operand to 16-Bit Port, Misaligned

The CPU16 treats misaligned long-word transfers as two misaligned word transfers. The MCU drives the address bus with the desired address and drives the size pins to indicate a word operand.

|          | 15    | 8 | 7     | 0 |      |      |       |        |        |
|----------|-------|---|-------|---|------|------|-------|--------|--------|
| Operand  |       |   | OP0   |   |      |      |       |        |        |
|          | OP1   |   | OP2   |   |      |      |       |        |        |
|          | OP3   |   |       |   |      |      |       |        |        |
| Data Bus | 15    | 8 | 7     | 0 | SIZ1 | SIZ2 | ADDR0 | DSACK1 | DSACK0 |
| Cycle 1  | (OP0) |   | OP0   |   | 1    | 0    | 1     | 0      | х      |
| Cycle 2  | OP1   |   | (OP1) |   | 0    | 1    | 0     | 0      | х      |
| Cycle 3  | (OP2) |   | OP2   |   | 1    | 0    | 1     | 0      | х      |
| Cycle 4  | OP3   |   | (OP3) |   | 0    | 1    | 0     | 0      | х      |

Figure 4-17. Long-Word Operand to 16-Bit Port, Misaligned

For a read operation, the peripheral responds by placing OP0 on DATA[7:0] and asserting DSACK1 to indicate a 16-bit port. When DSACK1 is asserted, the MCU reads OP0 from DATA[7:0], decrements the transfer size counter, increments the address, and performs a byte operand from 8-bit port transfer to acquire OP1. The process is repeated for OP2 and OP3.

For a write operation, the MCU first drives OP0 on DATA[7:0] and duplicates it on DATA[15:8]. The peripheral device reads OP0 from DATA[7:0] and asserts DSACK1. The MCU decrements the transfer size counter, increments the address, and performs a byte operand to 8-bit port transfer of OP1. The process is repeated for OP2 and OP3.

## 4.4 Bus Operation

Internal microcontroller modules are typically accessed in 2 system clock cycles, with no wait states. Regular external bus cycles use handshaking between the MCU and external peripherals to manage transfer size and data — these accesses take three system clock cycles, again with no wait states. During regular cycles, wait states can be inserted as needed by bus control logic. Refer to **4.4.2 Regular Bus Cycles** for more information. Fast-termination cycles, which are two-cycle external accesses with no wait states, use chip-select logic to generate handshaking signals internally. Chip-select logic can also be used to insert wait states before internal generation of handshaking signals. Refer to **4.4.3 Fast Termination Cycles** and **4.7 Chip Selects** for more information. Bus control signal timing as well as chip-select signal timing are specified in **APPENDIX A ELECTRICAL CHARACTERISTICS**.

The MCU is responsible for deskewing signals it issues at both the start and the end of a cycle. In addition, the MCU is responsible for deskewing acknowledge and data signals from peripheral devices.

## 4.4.1 Synchronization to CLKOUT

External devices connected to the MCU bus can operate at clock frequencies different from that of the MCU so long as they satisfy the interface signal timing constraints. Although bus cycles are classified as asynchronous, they are interpreted relative to the MCU system clock output (CLKOUT).

Descriptions are made in terms of individual system clock states, labelled {S0, S1, S2,..., SN} in the appropriate timing diagrams. The designation "state" refers to the logic level of the clock signal, and does not correspond to any implemented machine state. A clock cycle consists of two successive states. Refer to **APPENDIX A ELECTRICAL CHARACTERISTICS** for more information.

Bus cycles terminated by DSACK assertion normally require a minimum of three CLKOUT cycles. To support systems that use CLKOUT to generate DSACK and other inputs, asynchronous input setup time and asynchronous input hold times are specified. When these specifications are met, the MCU is guaranteed to recognize the appropriate signal on a specific edge of the CLKOUT signal.

For a read cycle, when assertion of  $\overrightarrow{\text{DSACK}}$  is recognized on a particular falling edge of the clock, valid data is latched into the MCU on the next falling clock edge, provided that the data meets the data setup time. In this case, the parameter for asynchronous operation can be ignored.

When a system asserts  $\overline{\text{DSACK}}$  for the required window around the falling edge of S2 and obeys the bus protocol by maintaining  $\overline{\text{DSACK}}$  and  $\overline{\text{BERR}}$ or  $\overline{\text{HALT}}$  until and throughout the clock edge that negates  $\overline{\text{AS}}$  (with the appropriate asynchronous input hold time), no wait states are inserted. The bus cycle runs at the maximum speed of three clocks per cycle.

To assure proper operation in a system synchronized to CLKOUT, when BERR (or BERR and HALT) is asserted after DSACK, BERR (or BERR and HALT) assertion must satisfy the appropriate data-in setup and hold times prior to the falling edge of the clock cycle after DSACK is recognized.

## 4.4.2 Regular Bus Cycles

The following discussion pertains to cycles using external bus control logic. Refer to **4.4.3 Fast Termination Cycles** for information concerning fast cycles.

To initiate a transfer, the MCU asserts an address and the SIZ[1:0] signals. The SIZ signals and ADDR0 are externally decoded to select the active portion of the data bus (refer to **4.3.2 Dynamic Bus Sizing**). When  $\overline{AS}$ ,  $\overline{DS}$ , and R/W are valid, a peripheral device either places data on the bus (read cycle) or latches data from the bus (write cycle), then asserts a  $\overline{DSACK[1:0]}$  combination that indicates port size.

The DSACK[1:0] signals can be asserted before the data from a peripheral device is valid on a read cycle. To ensure that valid data is latched into the MCU, a maximum period between DSACK assertion and DS assertion is specified.

There is no specified maximum for the period between AS assertion and DSACK assertion. Although the MCU can transfer data in a minimum of three clock cycles when the cycle is terminated with DSACK, the MCU inserts wait cycles in clock period increments until either DSACK signal goes low.

## NOTE

The SIM bus monitor asserts BERR when response time exceeds a predetermined limit. Bus monitor period is determined by the BMT field in SYPCR. The bus monitor cannot be disabled; maximum monitor period is 64 system clock cycles. If no peripheral responds to an access or if an access is invalid, external logic should assert the  $\overline{\text{BERR}}$  or  $\overline{\text{HALT}}$  signals to abort the bus cycle (when  $\overline{\text{BERR}}$  and  $\overline{\text{HALT}}$  are asserted simultaneously, the CPU16 acts as though only  $\overline{\text{BERR}}$  is asserted). If bus termination signals are not asserted within a specified period, the bus monitor terminates the cycle.

#### 4.4.2.1 Read Cycle

During a read cycle, the MCU transfers data from an external memory or peripheral device. If the instruction specifies a long-word or word operation, the MCU attempts to read two bytes at once. For a byte operation, the MCU reads one byte. The portion of the data bus from which each byte is read depends on operand size, peripheral address, and peripheral port size. Refer to **4.3.2 Dynamic Bus Sizing** and **4.3.4 Misaligned Operands** for more information. Figure 4–18 is a flowchart of a word read cycle.



## Figure 4–18. Word Read Cycle Flowchart

State 0 (S0) — The read cycle starts. The MCU places an address on ADDR [23:0] and function codes on FC[2:0]. In the MC68HC16Z1, ADDR[23:20] always follow the state of ADDR19, and FC2 is always equal to one. The MCU drives R/W high for a read cycle. Size signals SIZ[1:0] become valid, indicating the number of bytes to be read.

State 1 (S1) — The MCU asserts  $\overline{AS}$  indicating that the address on the address bus is valid. The MCU also asserts  $\overline{DS}$ , indicating that data can be placed on the bus.

State 2 (S2) — External logic decodes ADDR[23:0], FC[1:0], R/W, SIZ[1:0], and  $\overline{\text{DS}}$ . One or both of DATA[15:8] and DATA[7:0] are selected, and the responding device places data on that portion of the bus. Concurrently, the device asserts the appropriate  $\overline{\text{DSACK}}$  signals. If the MCU is to latch the data in minimum cycle time, at least one  $\overline{\text{DSACK}}$  signal must change state by the end of S2 in order to satisfy asynchronous input setup time requirements. If wait states are to be inserted, both  $\overline{\text{DSACK}}$  and  $\overline{\text{DSACK}}$  must remain negated throughout the asynchronous input setup and hold times at the end of S2.

State 3 (S3) — When a change in one or both of the DSACK signals has been recognized, the MCU latches data from the bus on the next falling edge of the clock (S4), and the cycle terminates (S5). If neither DSACK signal changes state by the start of S3, the MCU inserts wait states instead of proceeding to S4 and S5. While wait states are added, the MCU continues to sample the DSACK signals on falling edges of the clock until a change in one or more is recognized. In effect, S3 repeats until a change in the DSACK signals is detected.

State 4 (S4) — The MCU latches data on the falling edge at the end of S4.

State 5 (S5) — The MCU negates  $\overline{AS}$  and  $\overline{DS}$ , but holds the address valid to provide address hold time for memory systems. R/W, SIZ[1:0], and FC[2:0] also remain valid throughout S5. The external device must maintain data and assert the  $\overline{DSACK}$  signals until it detects the negation of either  $\overline{AS}$  or  $\overline{DS}$  it must remove the data and negate  $\overline{DSACK}$  within approximately one clock period after sensing the negation of  $\overline{AS}$  or  $\overline{DS}$ . Signals that remain asserted beyond this limit can be prematurely detected during the next bus cycle.

MOTOROLA

4-42

During a write cycle, the MCU transfers data to an external memory or peripheral device. If the instruction specifies a long-word or word operation, the MCU attempts to write two bytes at once. For a byte operation, the MCU writes one byte. The portion of the data bus upon which each byte is written depends on operand size, peripheral address, and peripheral port size. Refer to **4.3.2 Dynamic Bus Sizing** and **4.3.4 Misaligned Operands** for more information. Figure 4–19 is a flowchart of a write-cycle operation for a word transfer.





Figure 4–19. Write Cycle Flowchart

State 0 (S0) — The MCU places an address on ADDR[23:0] and function codes on FC[2:0]. In the MC68HC16Z1, ADDR[23:20] always follow the state of ADDR19, and FC2 is always equal to one. The MCU drives  $R/\overline{W}$  low for a write cycle. Size signals SIZ[1:0] become valid, indicating the number of bytes to be written.

State 1 (S1) — The MCU asserts  $\overline{AS}$ , indicating that the address on the address bus is valid.

MC68HC16Z1 USER'S MANUAL State 2 (S2) — The MCU places the data to be written onto DATA[15:0], then begins to sample the DSACK signals. External logic decodes ADDR[23:0], FC[1:0], R/W, SIZ[1:0], and AS. One or both of DATA[15:8] and DATA[7:0] are selected, and appropriate DSACK signals are asserted. If the cycle is to end in minimum time, the MCU must recognize a change in at least one DSACK signal by the end of S2. If wait states are to be inserted, both DSACK1 and DSACK0 must remain negated throughout the asynchronous input setup and hold times at the end of S2.

State 3 (S3) — The MCU asserts DS to indicate that data is stable on the data bus, and the selected peripheral latches the data. When a change in one or both of the DSACK signals has already been recognized, S4 elapses, and the cycle terminates during S5. If neither DSACK signal changes state by the start of S3, the MCU inserts wait states instead of proceeding to S4 and S5. While wait states are added, the MCU continues to sample the DSACK signals on falling edges of the clock until a change in one or more is recognized. In effect, S3 repeats until a change in the DSACK signals is detected.

State 4 (S4) — The MCU issues no new control signals during S4.

State 5 (S5) — The MCU negates  $\overline{AS}$  and  $\overline{DS}$ , but holds the address and data valid to provide address hold time for memory systems. R/W, SIZ[1:0], and FC[2:0] also remain valid throughout S5. The external device must assert the DSACK signals until it detects the negation of either  $\overline{AS}$  or  $\overline{DS}$ . It must negate DSACK within approximately one clock period after sensing the negation of  $\overline{AS}$  or  $\overline{DS}$ . Signals that remain asserted beyond this limit can be prematurely detected during the next bus cycle.

#### 4.4.3 Fast Termination Cycles

When an external device has a fast access time, the chip-select circuit fasttermination option can provide a two-cycle external bus transfer. Since the chip-select circuits are driven from the system clock, the bus cycle termination is inherently synchronized with the system clock.

Fast termination cycles use internal handshaking signals generated by the chipselect logic. To initiate a transfer, the MCU asserts an address and the SIZ[1:0] signals. When  $\overline{AS}$ ,  $\overline{DS}$ , and  $\overline{R/W}$  are valid, a peripheral device either places data on the bus (read cycle) or latches data from the bus (write cycle). At the appropriate time, chip-select logic asserts data and size acknowledge signals.

The DSACK option fields in the chip-select option registers determine whether internally generated DSACK or externally generated DSACK are used. Refer to **4.7.1 Chip-Select Registers** for information about fast-termination setup.

To use fast-termination, an external device must be fast enough to have data ready, within the specified setup time, by the falling edge of S4. Figure 4–20 shows the DSACK timing for two wait states in read, and a fast-termination read and write.

When fast termination is in use,  $\overline{\text{DS}}$  is asserted during read cycles but notduring write cycles. The STRB field in the chip-select option register used must be programmed with the address strobe encoding in order to assert the chip select signal for a fast-termination write.



Figure 4-20. Fast-Termination Timing

MOTOROLA 4–44

# 4.4.3.1 Fast-Termination Read Cycle

A fast-termination read cycle takes place in much the same way as a regular read cycle, except that the clock states for external handshaking are omitted.

State 0 (S0) — The read cycle starts. The MCU places an address on ADDR[23:0] and function codes on FC[2:0]. In the MC68HC16Z1, ADDR[23:20] always follow the state of ADDR19, and FC2 is always equal to one. The MCU drives R/W high for a read cycle. Size signals SIZ[1:0] become valid, indicating the number of bytes to be read.

State 1 (S1) — The MCU asserts  $\overline{\text{AS}}$  indicating that the address on the address bus is valid. The MCU also asserts  $\overline{\text{DS}}$ , indicating to external devices that data can be placed on the data bus. External logic decodes ADDR[23:0], FC[1:0], R/W, and SIZ[1:0]. One or both of DATA[15:8] and DATA[7:0] are selected, and the responding device places data on that portion of the bus.

State 4 (S4) — Appropriate internal  $\overrightarrow{\text{DSACK}}$  signals are generated and the MCU latches data on the falling edge of S4.

State 5 (S5) — The MCU negates  $\overline{AS}$  and  $\overline{DS}$ , but holds the address valid to provide address hold time for memory systems. R/W, SIZ[1:0], and FC[2:0] also remain valid throughout S5. The external device must maintain data until it detects the negation of either  $\overline{AS}$  or  $\overline{DS}$ ; it must remove the data within approximately one clock period after sensing the negation of  $\overline{AS}$  or  $\overline{DS}$ . Signals that remain asserted longer can be prematurely detected during the next bus cycle.

## 4.4.3.2 Fast-Termination Write Cycle

A fast-termination write cycle takes place in much the same way as a regular write cycle, except that the clock states for external handshaking are omitted.

State 0 (S0) — The MCU places an address on ADDR[23:0] and function codes on FC[2:0]. In the MC68HC16Z1, ADDR[23:20] always follow the state of ADDR19, and FC2 is always equal to one. The MCU drives  $R/\overline{W}$  low for a write cycle. Size signals SIZ[1:0] become valid, indicating the number of bytes to be written.

State 1 (S1) — The MCU asserts  $\overline{AS}$ , indicating that the address on the address bus is valid. External logic decodes ADDR[23:0], FC[1:0], R/W, SIZ[1:0], and  $\overline{AS}$ .

State 4 (S4) — Data driven onto DATA[15:0] becomes valid, and the selected peripheral latches the data. Appropriate internal DSACK signals are generated.

State 5 (S5) — The MCU negates  $\overline{AS}$ , but holds address and data valid to provide address hold time for memory systems. R/W, SIZ[1:0], and FC[2:0] also remain valid throughout S5.

#### 4.4.4 CPU Space Cycles

Function code signals FC[2:0] designate which of eight external address spaces is accessed during a bus cycle. Address space 7 is designated CPU space. CPU space is used for control information not normally associated with read or write bus cycles. Function codes are valid only while AS is asserted. Refer to **4.3.1.7 Function Codes** for more information on codes and encoding.

During a CPU space access, ADDR[19:16] are encoded to reflect the type of access being made. Three encodings are used by the MC68HC16Z1, as shown in Figure 4–21. These encodings represent breakpoint acknowledge (Type \$0) cycles, low power stop broadcast (Type \$3) cycles, and interrupt acknowledge (Type \$F) cycles. Type 0 and type 3 cycles are discussed below. Refer to **4.6 Interrupts** for a comprehensive discussion of interrupt acknowledge bus cycles.



Figure 4-21. CPU Space Address Encoding

# 4.4.4.1 Breakpoint Acknowledge Cycle

Breakpoints are used to stop program execution at a predefined point during system development. In the MC68HC16Z1, breakpoints are treated as a type of exception processing. Breakpoints can be used alone or in conjunction with the background debugging mode. See SECTION 5 CENTRAL PROCESSING UNIT for more information on exception processing and the background debugging mode.

The MC68HC16Z1 has only one source and type of breakpoint — a hardware breakpoint initiated by assertion of the BKPT input. Other modular microcontrollers may have more than one source or type. The breakpoint acknowledge cycle discussed here is the bus cycle that occurs as a part of breakpoint exception processing when a breakpoint is initiated while background debugging mode is not enabled.

 $\overline{BKPT}$  is sampled on the same clock phase as data. If  $\overline{BKPT}$  is valid, the data is tagged as it enters the CPU pipeline. When  $\overline{BKPT}$  is asserted while data is valid during an instruction prefetch, the acknowledge cycle occurs immediately after that instruction has executed. When  $\overline{BKPT}$  is asserted while data is valid during an operand fetch, the acknowledge cycle occurs immediately after execution of the instruction during which it is latched. If  $\overline{BKPT}$  is asserted for only one bus cycle and a pipe flush occurs before  $\overline{BKPT}$  is detected by the CPU, no acknowledge cycle occurs. To ensure detection,  $\overline{BKPT}$  can be asserted until a breakpoint acknowledge cycle is recognized.

When BKPT assertion is acknowledged by the CPU, the MC68HC16Z1 performs a word read from CPU space address \$00001E. This corresponds to the breakpoint number field (ADDR[4:2]) and the type bit (T) being set to all ones (source 7, type 1). If this bus cycle is terminated by BERR or by DSACK, the MCU performs breakpoint exception processing.

The breakpoint operation flow is shown in Figure 4–22. Figure 4–23 is the timing diagram for the breakpoint acknowledge cycle.



Figure 4-22. Breakpoint Operation Flow

MOTOROLA 4–48

SYSTEM INTEGRATION MODULE

MC68HC16Z1 USER'S MANUAL



Figure 4–23. Breakpoint Acknowledge Cycle Timing (Exception Signaled)

SYSTEM INTEGRATION MODULE

## 4.4.4.2 LPSTOP Broadcast Cycle

Low-power stop is initiated by the CPU16. Individual modules can be stopped by setting the STOP bits in each module configuration register, or the SIM can turn off system clocks after execution of the LPSTOP instruction. When the CPU executes LPSTOP, the LPSTOP broadcast cycle is generated. The SIM brings the MCU out of low-power mode when either an interrupt of higher priority than the stored mask or a reset occurs. Refer to **4.2.4 Low-Power Stop Operation** and **SECTION 5 CENTRAL PROCESSING UNIT** for more information.

During an LPSTOP broadcast cycle, the CPU performs a CPU space write to address \$3FFFE. This write puts a copy of the interrupt mask value in the clock control logic. The mask is encoded on the data bus as shown in Figure 4–24. The LPSTOP CPU space cycle is shown externally (if the bus is available) as an indication to external devices that the MCU is going into low-power stop mode. The SIM provides an internally generated DSACK response to this cycle. The timing of this bus cycle is the same as for a fast write cycle.

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1      | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|--------|---|
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | I | P MASH | < |

#### Figure 4-24. LPSTOP Interrupt Mask Level

#### 4.4.5 Bus Exception Control Cycles

An external device or a chip-select circuit must assert at least one of the DSACK[1:0] signals or the AVEC signal to terminate a bus cycle normally (refer to **4.3.1 Bus Signals**). Bus exception control cycles are used when bus cycles are not terminated in the expected manner. There are two sources of bus exception control cycles.

Bus error signal (BERR).

The internal bus monitor asserts internal BERR when neither DSACK nor AVEC is asserted within a specified period after assertion of AS.

The spurious interrupt monitor asserts internal BERR when an interrupt request is acknowledged and no IARB contention occurs. BERR assertion terminates a cycle and causes the MCU to process a bus error exception.

External devices can assert BERR to indicate an external bus error.

Halt signal (HALT).

HALT can be asserted by an external device to cause single bus cycle operation. HALT is typically used for debugging purposes.

To properly control termination of a bus cycle for a bus error condition, DSACK. BERR, and HALT must be asserted and negated synchronously with the rising edge of CLKOUT. This assures that setup time and hold time requirements are met for the same falling edge of the MCU clock when two signals are asserted simultaneously (see APPENDIX A ELECTRICAL CHARACTERISTICS). External circuitry that provides these signals must be designed with these constraints in mind, or the internal bus monitor must be used.

The acceptable bus cycle terminations for asynchronous cycles in relation to DSACKx assertion are summarized in Table 4–14.

| Type<br>of<br>Termination | Control<br>Signal | Rising<br>St | ted on<br>Edge of<br>ate | Description<br>of<br>Result             |  |  |
|---------------------------|-------------------|--------------|--------------------------|-----------------------------------------|--|--|
|                           |                   | S            | S+2                      |                                         |  |  |
| NORMAL                    | DSACK             | A            | RA                       | Normal cycle terminate and continue.    |  |  |
|                           | BERR              | NA           | NA                       |                                         |  |  |
|                           | HALT              | NA           | X                        |                                         |  |  |
| HALT                      | DSACK             | A            | RA                       | Normal cycle terminate and halt.        |  |  |
|                           | BERR              | NA           | NA                       | Continue when HALT is negated.          |  |  |
|                           | HALT              | A/RA         | RA                       |                                         |  |  |
| BUS ERROR 1               | DSACK             | NA/A         | X                        | Terminate and take bus error exception. |  |  |
|                           | BERR              | A            | RA                       |                                         |  |  |
|                           | HALT              | NA           | X                        |                                         |  |  |
| BUS ERROR 2               | DSACK             | Α            | Х                        | Terminate and take bus error exception. |  |  |
|                           | BERR              | A            | RA                       |                                         |  |  |
|                           | HALT              | NA           | NA                       |                                         |  |  |
| BUS ERROR 3               | DSACK             | NA/A         | Х                        | Terminate and take bus error exception. |  |  |
|                           | BERR              | A            | RA                       |                                         |  |  |
|                           | HALT              | A/S          | RA                       |                                         |  |  |
| BUS ERROR 4               | DSACK             | Α            | Х                        | Terminate and take bus error exception. |  |  |
|                           | BERR              | NA           | Α                        |                                         |  |  |
|                           | HALT              | NA           | Α                        |                                         |  |  |

Table 4-14. DSACK, BERR, and HALT Assertion Results

NOTES:

A = Signal is asserted in this bus state.

NA = Signal is not asserted in this state.

RA = Signal was asserted in previous state and remains asserted in this state.

S = The number of current even bus state (e.g., S2, S4, etc.). X = Don't care.

#### 4.4.5.1 Bus Errors

The CPU16 treats bus errors as a type of exception. Bus error exception processing begins when the CPU detects assertion of the IMB BERR signal.

BERR assertions do not force immediate exception processing. The signal is synchronized with normal bus cycles and is latched into the CPU16 at the end of the bus cycle in which it was asserted. Since bus cycles can overlap instruction boundaries, bus error exception processing may not occur at the end of the instruction in which the bus cycle begins. Timing of BERR detection/acknowledge is dependent upon several factors:

Which bus cycle of an instruction is terminated by assertion of BERR.

The number of bus cycles in the instruction during which BERR is asserted.

The number of bus cycles in the instruction following the instruction in which BERR is asserted.

Whether BERR is asserted during a program space access or a data space access.

Because of these factors, it is impossible to predict precisely how long after occurrence of a bus error the bus error exception is processed.

#### CAUTION

The external bus interface does not latch data when an external bus cycle is terminated by a bus error. When this occurs during an instruction prefetch, the IMB precharge state (bus pulled high, or \$FF) is latched into the CPU16 instruction register, with indeterminate results.

#### 4.4.5.2 Double Bus Faults

Exception processing for bus error exceptions follows the standard exception processing sequence (refer to **SECTION 5 CENTRAL PROCESSING UNIT** for more information concerning exceptions). However, two special cases of bus error, called double bus faults, can abort exception processing.

BERR assertion is not detected until an instruction is complete. The BERR latch is cleared by the first instruction of the BERR exception handler. Double bus fault occurs in two ways:

- 1. When bus error exception processing begins and a second BERR is detected before the first instruction of the first exception handler is executed.
- 2. When one or more bus errors occur before the first instruction after a RESET exception is executed.

Multiple bus errors within a single instruction which can generate multiple bus cycles cause a single bus error exception after the instruction has executed.

Immediately after assertion of a second BERR, the MCU halts and drives the HALT line low. Only a reset can restart a halted MCU. However, bus arbitration can still occur (refer to **4.4.6 Bus Arbitration**). A bus error or address error that occurs after exception processing has completed (during the execution of the exception handler routine, or later) does not cause a double bus fault.

#### 4.4.5.3 Halt Operation

When  $\overrightarrow{HALT}$  is asserted while  $\overrightarrow{BERR}$  is not asserted, the MCU halts external bus activity after negation of  $\overrightarrow{DSACK}$ . The MCU may complete the current word transfer in progress. For a long-word to byte transfer, this could be after S2 or S4. For a word to byte transfer, activity ceases after S2 (refer to Figure 4–25).

Negating and reasserting  $\overrightarrow{HALT}$  in accordance with timing requirements provides single-step (bus cycle to bus cycle) operation. The  $\overrightarrow{HALT}$  signal affects external bus cycles only, so that a program which does not use external bus can continue executing. During dynamically-sized 8-bit transfers, external bus activity may not stop at the next cycle boundary. Occurrence of a bus error while  $\overrightarrow{HALT}$  is asserted causes the CPU16 to process a bus error exception.

When the MCU completes a bus cycle while the  $\overline{HALT}$  signal is asserted, the data bus goes to high-impedance state and the  $\overline{AS}$  and  $\overline{DS}$  signals are driven to their inactive states. Address, function code, size, and read/write signals remain in the same state.

The halt operation has no effect on bus arbitration (refer to **4.4.6 Bus Arbitration**). However, when external bus arbitration occurs while the MCU is halted, address and control signals go to high-impedance state. If HALT is still asserted when the MCU regains control of the bus, address, function code, size, and read/write signals revert to the previous driven states. The MCU cannot service interrupt requests while halted.



Figure 4–25. HALT Timing

# 4.4.6 External Bus Arbitration

MCU bus design provides for a single bus master at any one time. Either the MCU or an external device can be master. Bus arbitration protocols determine when an external device can become bus master. Bus arbitration requests are recognized during normal processing, HALT assertion, and when the CPU has halted due to a double bus fault.

The bus controller in the MCU manages bus arbitration signals so that the MCU has the lowest priority. External devices that need to obtain the bus must assert bus arbitration signals in the sequences described in the following paragraphs.

Systems that include several devices that can become bus master require external circuitry to assign priorities to the devices, so that when two or more external devices attempt to become bus master at the same time, the one having the highest priority becomes bus master first. The protocol sequence is:

- A. An external device asserts bus request signal (BR);
- B. The MCU asserts the bus grant signal (BG) to indicate that the bus is available;
- C. An external device asserts the bus grant acknowledge (BGACK) signal to indicate that it has assumed bus mastership.

BR can be asserted during a bus cycle or between cycles. BG is asserted in response to BR. To guarantee operand coherency, BG is only asserted at the end of operand transfer.

If more than one external device can be bus master, required external arbitration must begin when a requesting device receives  $\overline{BG}$ . An external device must assert  $\overline{BGACK}$  when it assumes mastership, and must maintain  $\overline{BGACK}$  assertion as long as it is bus master.

Two conditions must be met for an external device to assume bus mastership. The device must receive  $\overline{BG}$  through the arbitration process, and  $\overline{BGACK}$  must be inactive, indicating that no other bus master is active. This technique allows processing of bus requests during data transfer cycles.

 $\overrightarrow{BG}$  is negated a few clock cycles after  $\overrightarrow{BGACK}$  transition. However, if bus requests are still pending after  $\overrightarrow{BG}$  is negated, the MCU asserts  $\overrightarrow{BG}$  again within a few clock cycles. This additional  $\overrightarrow{BG}$  assertion allows external arbitration circuitry to select the next bus master before the current master has released the bus.

Figure 4–26 is a flowchart of bus arbitration for a single device. The flowchart shows  $\overline{BR}$  negated at the same time  $\overline{BGACK}$  is asserted.



Figure 4-26. Bus Arbitration Flowchart for Single Request

#### 4.4.6.1 Bus Request

External devices capable of becoming bus masters request the bus by asserting the  $\overline{BR}$  signal. In a system with a number of devices capable of bus mastership, a wired-OR can connect the bus request line from each device to the MCU. After it has completed any current bus cycle, the MCU asserts  $\overline{BG}$ , then releases the bus when  $\overline{BGACK}$  is asserted.

If no acknowledge signal is received, the MCU remains bus master. This prevents interference with ordinary processing if the arbitration circuitry responds to noise or if an external device negates a request after mastership has been granted.

MOTOROLA 4–56 SYSTEM INTEGRATION MODULE

## 4.4.6.2 Bus Grant

The MC68HC16Z1 supports operand coherency. When an operand transfer requires multiple bus cycles, the MCU does not release the bus until the entire transfer is complete. The assertion of bus grant is subject to certain constraints:

The minimum time for  $\overline{BG}$  assertion after  $\overline{BR}$  assertion depends on internal synchronization.

During an external transfer, the MCU does not assert  $\overline{BG}$  until after the last cycle of the transfer (determined by SIZ[1:0] and  $\overline{DSACK[1:0]}$  signals).

When SHEN bits are both set and the CPU is making internal accesses, the MCU does not assert  $\overline{BG}$  until the CPU finishes the internal transfers.

Externally, the  $\overline{BG}$  signal can be routed through a daisy-chained network or a priority-encoded network. The MCU is not affected by the method of arbitration as long as the protocol is obeyed.

#### 4.4.6.3 Bus Grant Acknowledge

When bus protocols are obeyed, a device becomes the active bus master when it asserts BGACK. An external device cannot request and be granted the bus while another device is the active bus master. A device remains the bus master until it negates BGACK. BGACK must not be negated until all required bus cycles are completed.

When a device receives the bus and asserts  $\overrightarrow{BGACK}$ , it must also negate  $\overrightarrow{BR}$ . If  $\overrightarrow{BR}$  remains asserted after  $\overrightarrow{BGACK}$  assertion, the MCU assumes that another device is requesting the bus and prepares to issue another  $\overrightarrow{BG}$ .

Since external devices have priority, the MCU cannot regain control of the external bus until all pending external bus requests have been satisfied.

#### 4.4.6.4 Bus Arbitration Control

The bus arbitration control unit in the MCU is implemented with a finite-state machine. All asynchronous inputs to the MCU are internally synchronized in a maximum of two CLKOUT cycles. Figure 4–27 is the bus arbitration state diagram. Input signals labeled R and A are internal versions of the bus request and bus grant acknowledge signals that are internally synchronized to the system clock. The bus grant output is labeled G and the internal high-impedance control signal is labeled T. If T is true, the address, data, and control buses are placed in the high-impedance state after the next rising edge following the negation of  $\overline{AS}$ .



## Figure 4-27. Bus Arbitration State Diagram

4

State changes occur on the next rising edge of CLKOUT after the internal signal is valid. The BG signal transitions on the falling edge of the clock after a state is reached during which G changes. The bus control signals (controlled by T) are driven by the MCU immediately following a state change, when bus mastership is returned to the MCU. State 0, in which G and T are both negated, is the state of the bus arbiter while the MCU is bus master. Request R and acknowledge A keep the arbiter in state 0 as long as they are both negated.

## 4.4.6.5 Slave (Factory Test) Mode Arbitration

This mode is used for factory production testing of internal modules. It is not supported as a user operating mode. Slave mode is enabled by holding DATA11 low during reset. In slave mode, when  $\overline{BG}$  is asserted, the MCU is slaved to an external master that has full access to all internal registers.

#### 4.4.6.6 Show Cycles

The MCU normally performs internal data transfers without affecting the external bus, but it is possible to "show" these transfers during debugging.  $\overline{AS}$  is not asserted externally during show cycles.

Show cycles are controlled by the SHEN field in the SIMCR (refer to **4.1.3 Show Internal Cycles**). This field is cleared by reset. When show cycles are disabled, the address bus, function codes, size, and read/write signals reflect internal bus activity, but AS and DS are not asserted externally and external data bus pins are in high-impedance state during internal accesses.

When show cycles are enabled, DS is asserted externally during internal cycles, and internal data is driven out on the external data bus. Since internal cycles normally continue to run when the external bus is granted away, one SHEN encoding halts internal bus activity while there is an external master.

SIZ[1:0] signals reflect bus allocation during show cycles — only the appropriate portion of the data bus is valid during the cycle. During a byte write to an internal address, the portion of the bus that represents the byte that is not written reflects internal bus conditions, and is indeterminate. During a byte write to an external address, the data multiplexer in the SIM causes the value of the byte that is written to be driven out on both bytes of the data bus.

A state-by-state description of show cycle timing follows. Refer to **APPENDIX A ELECTRICAL CHARACTERISTICS** for specific timing information.

State 0 (S0) — Address and function codes become valid,  $R/\overline{W}$  is driven to indicate a show read or write cycle, and the size pins indicate the number of bytes to transfer. During a read, the addressed peripheral drives the data bus, and the user must take care to avoid bus conflicts.

State 41 (S41) —  $\overline{\text{DS}}$  is asserted to indicate that address information is valid.

State 42 (S42) — No change. The bus controller remains in S42 until the internal read cycle is complete.

State 43 (S43) —  $\overline{\text{DS}}$  is negated to indicate that show data is valid on the next falling edge of CLKOUT. External data bus drivers are enabled so that data becomes valid on the external bus as soon as it is available on the internal bus.

State 0 (S0) — ADDR[23:0], FC[2:0], R/W, and SIZ[1:0] pins change state to begin the next cycle. Data from the preceding cycle is valid through S0.

## 4.5 Reset

Reset occurs when an active low logic level on the RESET pin is clocked into the SIM. The RESET input is synchronized to the system clock — if there is no clock when RESET is asserted, reset does not occur until the clock starts. Resets are clocked in order to allow completion of write cycles in progress at the time RESET is asserted.

Reset procedures handle system initialization and recovery from catastrophic failure. The MC68HC16Z1 performs resets with a combination of hardware and software. The system integration module determines whether a reset is valid, asserts control signals, performs basic system configuration and boot ROM selection based on hardware mode-select inputs, then passes control to the CPU16.

## 4.5.1 Reset Exception Processing

The CPU16 processes resets as a type of asynchronous exception. An exception is an event that preempts normal processing. Exception processing makes the transition from normal instruction execution to execution of a routine that deals with an exception. Each exception has an assigned vector that points to an associated handler routine. These vectors are stored in a vector table located in the first 512 bytes of address bank 0. The CPU16 uses vector numbers to calculate displacement into the table. Refer to **SECTION 5 CENTRAL PROCESSING UNIT** for more information concerning exceptions.

Reset is the highest-priority CPU16 exception. Unlike all other exceptions, a reset occurs at the end of a bus cycle, and not at an instruction boundary. Handling resets in this way prevents write cycles in progress at the time the reset signal is asserted from being corrupted. However, any processing in progress is aborted by the reset exception, and cannot be restarted. Only essential reset tasks are performed during exception processing. Other initialization tasks must be accomplished by the exception handler routine.

**4.5.8 Reset Processing Summary** contains details of exception processing.

#### 4.5.2 Reset Control Logic

SIM reset control logic determines the cause of a reset, synchronizes request signals to CLKOUT, and asserts reset control signals. Reset control logic can drive three different internal signals.

EXTRST (external reset) drives the external reset pin.

CLKRST (clock reset) resets the clock module.

MSTRST (master reset) goes to all other internal circuits.

All resets are gated by CLKOUT. Asynchronous resets are assumed to be catastrophic. An asynchronous reset can occur on any clock edge. Synchronous resets are timed (CLKOUT) to occur at the end of bus cycles. The internal bus monitor is automatically enabled for synchronous resets — when a bus cycle does not terminate normally, the bus monitor terminates it. Table 4–15 is a summary of reset sources.

| Туре              | Source   | Timing       | Reset Lines Asserted by<br>Controller |        |        |
|-------------------|----------|--------------|---------------------------------------|--------|--------|
| EXTERNAL          | External | Synchronous  | MSTRST                                | CLKRST | EXTRST |
| POWER UP          | EBI      | Asynchronous | MSTRST                                | CLKRST | EXTRST |
| SOFTWARE WATCHDOG | Monitor  | Asynchronous | MSTRST                                | CLKRST | EXTRST |
| HALT              | Monitor  | Asynchronous | MSTRST                                | CLKRST | EXTRST |
| LOSS OF CLOCK     | Clock    | Synchronous  | MSTRST                                | CLKRST | EXTRST |
| TEST              | Test     | Synchronous  | MSTRST                                | _      | EXTRST |

Table 4-15. Reset Source Summary

Internal single byte or aligned word writes are guaranteed valid for synchronous resets. External writes are also guaranteed to complete, provided the external configuration logic on the data bus is conditioned as shown in Figure 4–28.

## 4.5.3 Reset Mode Selection

The logic states of certain data bus pins during reset determine SIM operating configuration. In addition, the state of the MODCLK pin determines system clock source and the state of the  $\overline{\rm BKPT}$  pin determines what happens during subsequent breakpoint assertions. Table 4–16 is a summary of reset mode selection options.

| Mode Select Pin                           | Default Function<br>(Pin Left High)                                                                                                                                                                                                                                                            | Alternate Function<br>(Pin Pulled Low)                             |
|-------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|
| DATA0                                     | CSBOOT 16-Bit                                                                                                                                                                                                                                                                                  | CSBOOT 8-Bit                                                       |
| DATA1                                     | CS0<br>CS1<br>CS2                                                                                                                                                                                                                                                                              | BR<br>BG<br>BGACK                                                  |
| DATA2                                     | CS3<br>CS4<br>CS5                                                                                                                                                                                                                                                                              | FC0<br>FC1<br>FC2                                                  |
| DATA3<br>DATA4<br>DATA5<br>DATA6<br>DATA7 | $     \overline{CS6}     \overline{CS7} - \underline{CS6}     \overline{CS8} - \underline{CS6}     \overline{CS9} - \underline{CS6}     \overline{CS9} - \underline{CS6}     \overline{CS10} - \underline{CS6}     \overline{CS10} - \underline{CS6}     \overline{CS10} - \underline{CS6}   $ | ADDR19<br>ADDR[20:19]<br>ADDR[21:19]<br>ADDR[22:19]<br>ADDR[23:19] |
| DATA8                                     | D <u>SACK0, DSACK1,</u><br>AVEC, DS, AS,<br>SIZE                                                                                                                                                                                                                                               | PORTE                                                              |
| DATA9                                     | IRQ7 - IRQ1<br>MODCLK                                                                                                                                                                                                                                                                          | PORTF                                                              |
| DATA11                                    | Test Mode Disabled                                                                                                                                                                                                                                                                             | Test Mode Enabled                                                  |
| MODCLK                                    | VCO = System Clock                                                                                                                                                                                                                                                                             | EXTAL = System Clock                                               |
| BKPT                                      | Background Mode Disabled                                                                                                                                                                                                                                                                       | Background Mode Enabled                                            |

Table 4-16. Reset Mode Selection

#### 4.5.3.1 Data Bus Mode Selection

All data lines have weak internal pull-up drivers. When pins are held high by the internal drivers, the MCU uses a default operating configuration. However, specific lines can be held low externally to achieve an alternate configuration.

#### NOTE

External bus loading can overcome the weak internal pull-up drivers on data bus lines, and hold pins low during reset.

Use an active device to hold data bus lines low. Data bus configuration logic must release the bus prior to the first bus cycle after reset in order to prevent conflict with external memory devices. The first bus cycle occurs 10 CLKOUT cycles after RESET is released. If external mode selection logic causes a conflict of this type, an isolation resistor on the driven lines may be required. Figure 4–28 shows a recommended method for conditioning the mode select signals.



\* OPTIONAL, TO PREVENT CONFLICT ON RESET NEGATION

## Figure 4–28. Data Bus Mode Select Conditioning

Data bus mode select current is specified in **APPENDIX A ELECTRICAL CHARACTERISTICS**. Do not confuse pin function with pin electrical state. Refer to **4.5.5 Pin State During Reset** for more information.

DATA0 determines the function of the boot ROM chip-select signal (CSBOOT). Unlike other chip-select signals, CSBOOT is active at the release of reset. During reset exception processing, the MCU fetches initialization vectors from word addresses \$0000 to \$0006 in bank 0 of program space. An external memory device containing vectors located at these addresses can be enabled by CSBOOT after a reset. The logic level of DATA0 during reset selects boot ROM port size for dynamic bus allocation. When DATA0 is held low, port size is 8 bits; when DATA0 is held high, either by the weak internal pull-up driver or by an external pull-up, port size is 16 bits. Refer to **4.7.4 Chip-Select Reset Operation** for more information.

DATA1 and DATA2 determine the functions of  $\overline{CS[2:0]}$  and  $\overline{CS[5:3]}$ , respectively. DATA[7:3] determine the functions of an associated chip select and all lower-numbered chip-selects down through  $\overline{CS6}$ . For example, if DATA5 is pulled low during reset, CS[8:6] are assigned alternate function as ADDR[21:19], and CS[10:9] remain chip-selects. Because ADDR[23:20] follow the state of ADDR19 in the CPU16, DATA[7:4] have limited use. Refer to **4.7.4 Chip-Select Reset Operation** for more information.

DATA8 determines the function of the DSACK0, DSACK1, AVEC, DS, AS, and SIZE pins. If DATA8 is held low during reset, these pins are used for discrete I/O (Port E).

DATA9 determines the function of interrupt request pins IRQ[7:0] and the clock mode select pin (MODCLK). When DATA9 is held low during reset, these pins are used for discrete I/O (Port F).

DATA11 determines whether the SIM operates in test mode out of reset. This capability is used for factory testing of the MC68HC16Z1.

#### 4.5.3.2 Clock Mode Selection

The state of the clock mode (MODCLK) pin during reset determines what clock source the MCU uses. When MODCLK is held high during reset, the clock signal is generated from a reference frequency. When MODCLK is held low during reset, the clock synthesizer is disabled, and an external system clock signal must be applied. Refer to **4.2 System Clock** for more information.

#### NOTE

If the MODCLK pin is also used as a parallel port pin, make certain that bus loading does not overcome the weak internal pull-up driver during reset and cause inadvertent clock mode selection.

#### 4.5.3.3 Breakpoint Mode Selection

The MC68HC16Z1 uses internal and external breakpoint ( $\overline{BKPT}$ ) signals. During reset exception processing, at the release of the  $\overline{RESET}$  signal, the CPU16 samples these signals to determine how to handle breakpoints.

If either BKPT signal is at logic level zero when sampled, an internal BDM flag is set, and the CPU16 enters background debugging mode whenever either BKPT input is subsequently asserted.

If both  $\overline{\text{BKPT}}$  inputs are at logic level one when sampled, BKPT exception processing begins whenever either  $\overline{\text{BKPT}}$  signal is subsequently asserted.

Refer to SECTION 5 CENTRAL PROCESSING UNIT for more information on background debugging mode and exceptions. Refer to 4.4.4 CPU Space Cycles for information concerning breakpoint acknowledge bus cycles.

## 4.5.4 MCU Module Pin Function During Reset

Generally, module pins default to port functions, and input/output ports are set to input state. This is accomplished by disabling pin functions in the appropriate control registers, and by clearing the appropriate port data direction registers. Refer to individual module sections in this manual for more information. Table 4–17 is a summary of module pin function out of reset. Refer to **APPENDIX D REGISTER SUMMARY** for register function and reset state.

| Module | Pin Mnemonic      | Function          |  |  |
|--------|-------------------|-------------------|--|--|
| ADC    | PADA[7:0]/AN[7:0] | DISCRETE INPUT    |  |  |
|        | VRH               | REFERENCE VOLTAGE |  |  |
|        | V <sub>RL</sub>   | REFERENCE VOLTAGE |  |  |
| CPU    | DSI/IPIPE1        | DSI/IPIPE1        |  |  |
|        | DSO/IPIPE0        | DSO/IPIPE0        |  |  |
|        | BKPT/DSCLK        | BKPT/DSCLK        |  |  |
| GPT    | PGP7/IC4/OC5      | DISCRETE INPUT    |  |  |
|        | PGP[6:3]/OC[4:1]  | DISCRETE INPUT    |  |  |
|        | PGP[2:0]/IC[3:1]  | DISCRETE INPUT    |  |  |
|        | PAI               | DISCRETE INPUT    |  |  |
|        | PCLK              | DISCRETE INPUT    |  |  |
|        | PWMA, PWMB        | DISCRETE OUTPUT   |  |  |
| QSM    | PQS7/TXD          | DISCRETE INPUT    |  |  |
|        | PQS[6:4]/PCS[3:1] | DISCRETE INPUT    |  |  |
|        | PQS3/PCS0/SS      | DISCRETE INPUT    |  |  |
|        | PQS2/SCK          | DISCRETE INPUT    |  |  |
|        | PQS1/MOSI         | DISCRETE INPUT    |  |  |
|        | PQS0/MISO         | DISCRETE INPUT    |  |  |
|        | RXD               | RXD               |  |  |

Table 4-17. Module Pin Functions

#### 4.5.5 Pin State During Reset

It is important to keep the distinction between pin function and pin electrical state clear. Although control register values and mode select inputs determine pin function, a pin driver can be active, inactive or in high-impedance state while reset occurs. During power-up reset, pin state is subject to the constraints discussed in **4.5.7 Power-On Reset**.

#### NOTE

Pins that are not used should either be configured as outputs, or (if configured as inputs) pulled to the appropriate inactive state. This decreases additional  $I_{DD}$  caused by digital inputs floating near mid-supply level.

## 4.5.5.1 Reset States of SIM Pins

Generally, while RESET is asserted, SIM pins either go to an inactive highimpedance state or are driven to their inactive states. After RESET is released, mode selection occurs, and reset exception processing begins. Pins configured as inputs during reset become active high-impedance loads after RESET is released. Inputs must be driven to the desired active state — pull-up or pulldown circuitry may be necessary. Pins configured as outputs begin to function after RESET is released. Table 4–18 is a summary of SIM pin states during reset.

|                             | Pin State While   | Pin State After     | RESET Released        |  |
|-----------------------------|-------------------|---------------------|-----------------------|--|
| Mnemonic                    | RESET<br>Asserted | Default<br>Function | Alternate<br>Function |  |
| ADDR23/CS10                 | 1                 | 1                   | ADDR23                |  |
| ADDR[22:19]/CS[9:6]/PC[6:3] | 1                 | 1                   | ADDR[22:19]           |  |
| ADDR[18:0]                  | INACTIVE          | ADDR[18:0]          | ADDR[18:0]            |  |
| AS/PE5                      | INACTIVE          | OUTPUT              | INPUT                 |  |
| AVEC/PE2                    | INACTIVE          | INPUT               | INPUT                 |  |
| BERR                        | INACTIVE          | INPUT               | INPUT                 |  |
| BG/CS1                      | 1                 | 1                   | 1                     |  |
| BGACK/CS2                   | 1                 | 1                   | INPUT                 |  |
| BR/CS0                      | 1                 | 1                   | INPUT                 |  |
| CLKOUT                      | OUTPUT            | OUTPUT              | OUTPUT                |  |
| CSBOOT                      | INACTIVE          | 0                   | 0                     |  |
| DATA[15:0]                  | MODE SELECT       | INPUTS              | INPUTS                |  |
| DS/PE4                      | INACTIVE          | OUTPUT              | INPUT                 |  |
| DSACK0/PE0                  | INACTIVE          | INPUT               | INPUT                 |  |
| DSACK1/PE1                  | INACTIVE          | INPUT               | INPUT                 |  |
| FC[2:0]/CS[5:3]/PC[2:0]     | 1                 | 1                   | FC[2:0]               |  |
| HALT                        | INACTIVE          | INPUT               | INPUT                 |  |
| IRQ[7:1]/PF[7:1]            | INACTIVE          | INPUT               | INPUT                 |  |
| MODCLK/PF0                  | MODE SELECT       | INPUT               | INPUT                 |  |
| R/W                         | INACTIVE          | OUTPUT              | R∕₩                   |  |
| RESET                       | ASSERTED          | INPUT               | INPUT                 |  |
| SIZ[1:0]/PE[7:6]            | INACTIVE          | SIZ[1:0]            | INPUT                 |  |
| TSC                         | MODE SELECT       | INPUT               | INPUT                 |  |

## Table 4-18. SIM Pin Reset States

## 4.5.5.2 Reset States of Pins Assigned to Other MCU Modules

As a rule, module pins that are assigned to general-purpose I/O ports go to active high-impedance state following reset. However, during power-up reset, module port pins may be in an indeterminate state for a short period. Refer to **4.5.7 Power-On Reset** for more information. Table 4–19 is a summary of module pin states.

| Module | Pin Mnemonic      | State           |
|--------|-------------------|-----------------|
| ADC    | PADA[7:0]/AN[7:0] | INPUT           |
|        | VRH               | APPLIED VOLTAGE |
|        | V <sub>RL</sub>   | APPLIED VOLTAGE |
| CPU    | DSI/IPIPE1        | IPIPE1 SIGNAL   |
|        | DSO/IPIPE0        | IPIPE0 SIGNAL   |
|        | BKPT/DSCLK        | BKPT SIGNAL     |
| GPT    | PGP7/IC4/OC5      | INPUT           |
|        | PGP[6:3]/OC[4:1]  | INPUT           |
|        | PGP[2:0]/IC[3:1]  | INPUT           |
|        | PAI               | INPUT           |
|        | PCLK              | INPUT           |
|        | PWMA, PWMB        | INPUT           |
| QSM    | PQS7/TXD          | INPUT           |
|        | PQS[6:4]/PCS[3:1] | INPUT           |
|        | PQS3/PCS0/SS      | INPUT           |
|        | PQS2/SCK          | INPUT           |
|        | PQS1/MOSI         | INPUT           |
|        | PQS0/MISO         | INPUT           |
|        | RXD               | RXD SIGNAL      |

## 4.5.6 Reset Timing

The RESET input must be asserted for a specified minimum period in order for reset to occur (See APPENDIX A ELECTRICAL CHARACTERISTICS, Table A–5). External RESET assertion can be delayed internally for a period equal to the longest bus cycle time (or the bus monitor timeout period) in order to protect write cycles from being aborted by reset. While RESET is asserted, SIM pins are either in an inactive, high-impedance state or are driven to their inactive states.

When an external device asserts  $\overline{\text{RESET}}$  for the proper period, reset control logic clocks the signal into an internal latch. The control logic drives the  $\overline{\text{RESET}}$  pin low for an additional 512 CLKOUT cycles after it detects that the  $\overline{\text{RESET}}$  signal is no longer being externally driven, to guarantee this length of reset to the entire system.

If an internal source asserts a reset signal, the reset control logic asserts RESET for a minimum of 512 cycles. If the reset signal is still asserted at the end of 512 cycles, the control logic continues to assert RESET until the internal reset signal is negated.

MOTOROLA 4–68 After 512 cycles have elapsed, the RESET pin goes to an inactive, highimpedance state for 10 cycles. At the end of this 10-cycle period, pin state is tested. When pin state is logic level one, reset exception processing begins. If, however, pin state is logic level zero, reset control logic drives the pin low for another 512 cycles. At the end of this period, the pin again goes to highimpedance state for 10 cycles, and then is tested again. The process repeats until RESET goes high.

## 4.5.7 Power-On Reset

When the SIM clock synthesizer is used to generate system clocks, power-on reset involves special circumstances related to application of system and clock synthesizer power. Regardless of clock source, voltage must be applied to clock synthesizer power input pin V<sub>DDSYN</sub> in order for the MCU to operate. The following discussion assumes that V<sub>DDSYN</sub> is applied before and during reset — this minimizes crystal start-up time. When V<sub>DDSYN</sub> is applied at power-on, start-up time is affected by specific crystal parameters and by oscillator circuit design. V<sub>DD</sub> ramp-up time also affects pin state during reset. Refer to **APPENDIX A ELECTRICAL CHARACTERISTICS** for voltage and timing specifications.

During power-on reset, an internal circuit in the SIM drives the IMB internal (MSTRST) and external (EXTRST) reset lines. The circuit releases MSTRST as  $V_{DD}$  ramps up to the minimum specified value, and SIM pins are initialized as shown in Table 4-18. As  $V_{DD}$  reaches specified minimum value, the clock synthesizer VCO begins operation and clock frequency ramps up to specified limp mode frequency. The external RESET line remains asserted until the clock synthesizer PLL locks and 512 CLKOUT cycles elapse.

The SIM clock synthesizer provides clock signals to the other MCU modules. After the clock is running and MSTRST is asserted for at least four clock cycles, these modules reset.  $V_{DD}$  ramp time and VCO frequency ramp time determine how long the four cycles take. Worst case is approximately 15 milliseconds. During this period, module port pins may be in an indeterminate state. While input-only pins can be put in a known state by means of external pull-up resistors, external logic on input/output or output-only pins during this time must condition the lines. Active drivers require high-impedance buffers or isolation resistors to prevent conflict.

Figure 4–29 is a timing diagram of power-up reset. It shows the relationships between  $\overrightarrow{\text{RESET}}$ , V<sub>DD</sub>, and bus signals.



#### Figure 4–29. Power-On Reset Timing

#### 4.5.7.1 Use of Three-State Control Pin

Asserting the three-state control (TSC) input causes the MCU to put all output drivers in an inactive, high-impedance state. TSC must remain asserted for 10 clock cycles in order for drivers to change state. There are certain constraints on use of TSC during power-up reset:

When the internal clock synthesizer is used (MODCLK held high during reset), synthesizer ramp-up time affects how long the 10 cycles take. Worst case is approximately 20 milliseconds from TSC assertion.

When an external clock signal is applied (MODCLK held low during reset), pins go to high-impedance state as soon after TSC assertion as 10 clock pulses have been applied to the EXTAL pin.

#### NOTE

When TSC assertion takes effect, internal signals are forced to values that can cause inadvertent mode selection. Once the output drivers change state, the MCU must be powered down and restarted before normal operation can resume.

MOTOROLA 4–70

4

SYSTEM INTEGRATION MODULE

MC68HC16Z1 USER'S MANUAL

## 4.5.8 Reset Processing Summary

In order to prevent write cycles in progress from being corrupted, a reset is recognized at the end of a bus cycle, and not at an instruction boundary. Any processing in progress at the time a reset occurs is aborted. After SIM reset control logic has synchronized an internal or external reset request, it asserts the MSTRST signal.

The following events take place when MSTRST is asserted.

- A. Instruction execution is aborted.
- B. The condition code register is initialized.
  - 1. The IP field is set to \$7, disabling all interrupts below priority 7.
  - 2. The S bit is set, disabling LPSTOP mode.
  - 3. The SM bit is cleared, disabling MAC saturation mode.
- C. The K register is cleared.

It is important to be aware that all CCR bits that are not initialized are not affected by reset. However, out of power-on reset, these bits will be indeterminate.

The following events take place when MSTRST is negated after assertion.

- A. The CPU16 samples the BKPT input.
- B. The CPU16 fetches RESET vectors in the following order:
  - 1. Initial ZK, SK, and PK extension field values.
  - 2. Initial PC.
  - 3. Initial SP.
  - 4. Initial IZ value.

Vectors can be fetched from internal RAM or from external ROM enabled by the CSBOOT signal.

C. The CPU16 begins fetching instructions pointed to by the initial PK : PC.

#### 4.5.9 Reset Status Register

The reset status register (RSR) contains a bit for each reset source in the MCU. When a reset occurs, a bit corresponding to the reset type is set. When multiple causes of reset occur at the same time, more than one bit in RSR may be set. The reset status register is updated by the reset control logic when the RESET signal is released. Refer to **APPENDIX D REGISTER SUMMARY**.

#### 4.6 Interrupts

Interrupt recognition and servicing involve complex interaction between the system integration module, the central processing unit, and a device or module requesting interrupt service. This discussion provides an overview of the entire interrupt process. Chip-select logic can also be used to respond to interrupt requests. Refer to **4.7 Chip Selects** for more information.

#### 4.6.1 Interrupt Exception Processing

The CPU16 handles interrupts as a type of asynchronous exception. An exception is an event that preempts normal processing. Exception processing makes the transition from normal instruction execution to execution of a routine that deals with an exception. Each exception has an assigned vector that points to an associated handler routine. These vectors are stored in a vector table located in the first 512 bytes of address bank 0. The CPU16 uses vector numbers to calculate displacement into the table. Refer to **SECTION 5 CENTRAL PROCESSING UNIT** for more information concerning exceptions.

#### 4.6.2 Interrupt Priority and Recognition

The CPU16 provides for eight levels of interrupt priority (0–7), seven automatic interrupt vectors, and 200 assignable interrupt vectors. All interrupts with priorities less than 7 can be masked by the interrupt priority (IP) field in the condition code register.

Interrupt recognition is based on the states of interrupt request signals IRQ[7:1] and the IP mask value. Each of the signals corresponds to an interrupt priority. IRQ1 has the lowest priority, and IRQ7 has the highest priority.

The IP field consists of three bits (CCR[7:5]). Binary values %000 to %111 provide eight priority masks. Masks prevent an interrupt request of a priority less than or equal to the mask value (except for IRQ7) from being recognized and processed. When IP contains %000, no interrupt is masked. During exception processing, the IP field is set to the priority of the interrupt being serviced.

Interrupt request signals can be asserted by external devices or by microcontroller modules. Request lines are connected internally by means of a wired-NOR — simultaneous requests of differing priority can be made. Internal assertion of an interrupt request signal does not affect the logic state of the corresponding MCU pin.

External interrupt requests are routed to the CPU16 via the external bus interface and SIM interrupt control logic — the CPU treats external interrupt requests as though they come from the SIM.

SYSTEM INTEGRATION MODULE

External  $\overline{\text{IRQ}[6:1]}$  are active-low level-sensitive inputs. External  $\overline{\text{IRQ7}}$  is an active-low transition-sensitive input — it requires both an edge and a voltage level for validity.

IRQ[6:1] are maskable. IRQ7 is nonmaskable. The IRQ7 input is transitionsensitive in order to prevent redundant servicing and stack overflow. A nonmaskable interrupt is generated each time IRQ7 is asserted, and each time the priority mask changes from %111 to a lower number while IRQ7 is asserted.

Interrupt request signals are sampled on consecutive falling edges of the system clock. Interrupt request input circuitry has hysteresis — to be valid, a request signal must be asserted for at least two consecutive clock periods. Valid requests do not cause immediate exception processing, but are left pending. Pending requests are processed at instruction boundaries or when exception processing of higher-priority exceptions is complete.

The CPU16 does not latch the priority of a pending interrupt request. If an interrupt source of higher priority makes a service request while a lower priority request is pending, the higher priority request is serviced. If an interrupt request of equal or lower priority than the current IP mask value is made, the CPU does not recognize the occurrence of the request in any way.

## 4.6.3 Interrupt Acknowledge and Arbitration

Interrupt acknowledge bus cycles are generated during exception processing. When the CPU16 detects one or more interrupt requests of a priority higher than the interrupt priority mask value, it performs a CPU space read from address \$FFFFF : [IP] : 1. (Refer to **4.3.1.7 Function Codes** and **4.4.4 CPU Space Cycles** for more information.)

The CPU space read cycle performs two functions: it places a mask value corresponding to the highest priority interrupt request on the address bus, and it acquires an exception vector number from the interrupt source. The mask value also serves two purposes: it is decoded by modules that have requested interrupt service to determine whether the current interrupt acknowledge cycle pertains to them, and it is latched into the CCR IP field in order to mask lower-priority interrupts during exception processing.

Modules that have requested interrupt service decode the IP value placed on the address bus at the beginning of the interrupt acknowledge cycle, and if their requests are at the specified IP level, respond to the cycle. Arbitration between simultaneous requests of the same priority is performed by means of serial contention between module interrupt arbitration (IARB) field bit values. 4

Each module that can make an interrupt service request, including the SIM, has an IARB field in its configuration register. An IARB field can be assigned a value from %0001 (lowest priority) to %1111 (highest priority). A value of %0000 in an IARB field causes the CPU16 to process a spurious interrupt exception when an interrupt from that module is recognized.

Because the EBI manages external interrupt requests, the SIM IARB value is used for arbitration between internal and external interrupt requests. The reset value of IARB for the SIM is %1111, and the reset IARB value for all other modules is %0000. Initialization software must assign different IARB values in order to implement an arbitration scheme.

#### NOTE

Do not assign the same arbitration priority to more than one module. When two or more IARB fields have the same nonzero value, the CPU16 interprets multiple vector numbers simultaneously, with unpredictable consequences.

Arbitration must always take place, even when a single source is requesting service. This point is important for two reasons: the EBI does not transfer the CPU interrupt acknowledge cycle to the external bus unless the SIM wins contention, and failure to contend causes the interrupt acknowledge bus cycle to be terminated early, by a bus error.

When arbitration is complete, the dominant module must place an interrupt vector number on the data bus and terminate the bus cycle or assert the autovector (AVEC) signal. In the case of an external interrupt request, because the interrupt acknowledge cycle is transferred to the external bus, an external device must decode the mask value and respond with a vector number, then generate data and size acknowledge (DSACK) cycle termination signals. If the device does not respond in time, the EBI bus monitor asserts the bus error signal (BERR), and a spurious interrupt exception is taken.

The periodic interrupt timer (PIT) in the SIM can generate internal interrupt requests of specific priority at predetermined intervals. By hardware convention, PIT interrupts are serviced before external interrupt service requests of the same priority. Refer to **4.1.11 Periodic Interrupt Timer** for more information.

## 4.6.4 Interrupt Processing Summary

A summary of the entire interrupt processing sequence follows. When the sequence begins, a valid interrupt service request has been detected and is pending.

- A. The CPU finishes higher priority exception processing or reaches an instruction boundary.
- B. Processor state is stacked, then the CCR PK extension field is cleared.
- C. The interrupt acknowledge cycle begins:
  - 1. FC[2:0] are driven to %111 (CPU space) encoding.
  - The address bus is driven as follows. ADDR[23:20] = %1111; ADDR[19:16] = %1111, which indicates that the cycle is an interrupt acknowledge CPU space cycle; ADDR[15:4] = %11111111111; ADDR[3:1] = the priority of the interrupt request being acknowledged; and ADDR0 = %1.
  - 3. Request priority is latched into the CCR IP field from the address bus.
- D. Modules or external peripherals that have requested interrupt service decode the priority value in ADDR[3:1]. If request priority is the same as the priority value in the address, IARB contention takes place. When there is no contention, the spurious interrupt monitor asserts BERR, and a spurious interrupt exception is processed.
- E. After arbitration, the interrupt acknowledge cycle can be completed in one of three ways:
  - 1. The dominant interrupt source supplies a vector number and DSACK signals appropriate to the access. The CPU16 acquires the vector number.
  - 2. The AVEC signal is asserted (the signal can be asserted by the dominant interrupt source or the pin can be tied low), and the CPU16 generates an autovector number corresponding to interrupt priority.
  - 3. The bus monitor asserts BERR and the CPU16 generates the spurious interrupt vector number.
- F. The vector number is converted to a vector address.
- G. The content of the vector address is loaded into the PC, and the processor transfers control to the exception handler routine.

SYSTEM INTEGRATION MODULE

## 4.6.5 Interrupt Acknowledge Bus Cycles

Interrupt acknowledge bus cycles are CPU space cycles that are generated during exception processing. The following paragraphs describe the various kinds of interrupt acknowledge bus cycles that can be executed as part of interrupt exception processing.

# 4.6.5.1 External Bus Cycle Terminated by Data and Size Acknowledge Signals

The MCU acknowledges an external interrupt request by performing an external read cycle to obtain the interrupt vector number. The following paragraphs describe the interrupt acknowledge cycle for devices that supply a vector number and appropriate bus cycle termination signals.

Other interrupt sources use the autovector cycle described in **4.6.5.2 External Bus Cycle Terminated by External Autovector Signal**. The interrupt acknowledge cycle is a CPU space read cycle. It differs from the read cycle described in **4.4.2.1 Read Cycle** in the following ways:

- A. FC[2:0] are set to %111, the CPU space encoding.
- B. ADDR[19:16] (the CPU space type field) are set to %1111, the interrupt acknowledge encoding.
- C. ADDR[3:1] are set to the interrupt request level and ADDR0 is set to one.
- D. All remaining address bits are set.
- E. SIZ[1:0] and  $R/\overline{W}$  are driven to indicate a single-byte read cycle.

Interrupting devices must decode ADDR[3:1] to determine which device puts the interrupt vector number on the bus. The responding device must also decode SIZ[1:0] for dynamic bus allocation. Because ADDR0 = 1 during an interrupt acknowledge cycle, transfer case is either an odd byte-to-byte transfer or an odd byte-to-word transfer. The vector number is placed on DATA[15:8] if the device is an 8-bit port, or on DATA[7:0] if it is a 16-bit port. To terminate the cycle, the device must assert an appropriate combination of DSACK[1:0] signals.

Chip-select logic can be programmed to decode this bus cycle and generate an interrupt acknowledge signal. Refer to **4.7.3 Using Chip-Select Signals** for Interrupt Acknowledge for more information.

Figure 4–30 is a flowchart of the cycle. Figure 4–31 shows cycle timing.



#### Figure 4-30. Interrupt Acknowledge Cycle Flowchart



Figure 4-31. Interrupt Acknowledge Cycle Timing

SYSTEM INTEGRATION MODULE

MC68HC16Z1 USER'S MANUAL

## 4.6.5.2 External Bus Cycle Terminated by External Autovector Signal

An interrupting device requests an automatically generated vector, or autovector, by asserting the AVEC signal to terminate an interrupt acknowledge cycle. DSACK signals must not be asserted during an interrupt acknowledge cycle terminated by AVEC. If the AVEC pin is wired low, the CPU generates an autovector whenever an interrupt (of any priority, from any source) is acknowledged.

When  $\overline{AVEC}$  is asserted, the CPU ignores the state of the data bus and generates a vector number. The autovector number corresponds to the priority level of the interrupt request. Seven autovectors are available, one for each of the seven interrupt request signals. Figure 4–32 shows the timing for an autovector operation.

Chip-select logic can be programmed to decode this bus cycle and generate an internal  $\overline{AVEC}$  response when an external interrupt request is made. The interrupting device does not have to respond in this case. Chip-select logic is typically used to generate an internal autovector signal when the corresponding chip-select pin is used for an alternate function or for general-purpose I/O. Refer to **4.7.2 Chip-Select Operation** for more information.

#### 4.6.5.3 Spurious Interrupt Cycle

When an interrupt request is made, but no IARB field value is asserted in response to the interrupt acknowledge cycle, the spurious interrupt monitor asserts the BERR signal internally to prevent vector acquisition. When a responding device does not terminate an interrupt acknowledge cycle with AVEC or DSACK, the bus monitor asserts BERR internally. The CPU16 automatically generates the spurious interrupt vector number (\$F) in both cases. If the halt signal (HALT) is asserted while internal BERR is asserted, the MCU responds as though BERR alone is asserted.



Figure 4-32. Autovector Operation Timing

## 4.7 Chip Selects

Typical microcontrollers require additional hardware to provide external chipselect signals. The MC68HC16Z1 includes 12 programmable chip-select circuits that can provide two to thirteen cycle access to external memory and

MOTOROLA 4-80 SYSTEM INTEGRATION MODULE

MC68HC16Z1 USER'S MANUAL peripherals. Address block sizes of 2 Kbytes to 1 Mbyte can be selected. However, because ADDR[23:20] follow the state of ADDR19, 512-Kbyte blocks are the largest usable size. Figure 4–33 is a diagram of a basic system that uses chip selects.



1. CAN BE DECODED TO PROVIDE ADDITIONAL ADDRESS SPACE. 2. VARIES DEPENDING UPON PERIPHERAL MEMORY SIZE.



Chip-select assertion can be synchronized with bus control signals to provide output enable, read/write strobe, or interrupt acknowledge signals. Logic can also generate DSACK and AVEC signals internally. A single DSACK generator is shared by all chip-select circuits — multiple chip selects assigned to the same address must have the same number of wait states. Each signal can also be synchronized with the ECLK signal available on ADDR23.

When a memory access occurs, chip-select logic compares address space type, address, type of access, transfer size, and interrupt priority (in the case of interrupt acknowledge) to parameters stored in chip-select registers. If all parameters match, the appropriate chip-select signal is asserted. Select signals are active low. If a chip-select function is given the same address as a microcontroller module or an internal memory array, an access to that address goes to the module or array, and the chip-select signal is not asserted. The external address and data buses do not reflect the internal access.

All chip-select circuits are configured for operation out of reset. However, chipselect signals 10 through 0 are disabled, and cannot be asserted until a transfer size is chosen. The boot ROM select signal is automatically asserted out of reset. Alternate functions for chip-select pins are enabled if appropriate data bus pins are held low at the release of the reset signal (refer to **4.5.3.1 Data Bus Mode Selection** for more information). Figure 4–34 is a functional diagram of a single chip-select circuit.



Figure 4-34. Chip-Select Circuit Block Diagram

#### 4.7.1 Chip-Select Registers

Each chip-select pin can have one or more functions. Chip-select pin assignment registers (CSPAR[1:0]) determine functions of the pins. Pin assignment registers also determine port size (8- or 16-bit) for dynamic bus allocation. A pin data register (CSPDR) latches data for chip-select pins that are used for discrete output.

MOTOROLA 4–82 Blocks of addresses are assigned to each chip-select function. Block sizes of 2 Kbytes to 1 Mbyte can be selected by writing values to the appropriate base address register (CSBAR[10:0], CSBARBT). However, because the logic state of ADDR20 is always the same as the state of ADDR19 in the MC68HC16Z1, the largest usable block size is 512 Kbytes. Address blocks for separate chip-select functions can overlap.

Chip select option registers (CSOR[10:0], CSORBT) determine timing of and conditions for assertion of chip-select signals. Eight parameters, including operating mode, access size, synchronization, and wait state insertion can be specified.

Initialization software usually resides in a peripheral memory device controlled by the chip-select circuits. A set of special chip-select functions and registers (CSORBT, CSBARBT) is provided to support bootstrap operation.

Comprehensive address maps and register diagrams are provided in **APPENDIX D REGISTER SUMMARY**.

#### 4.7.1.1 Chip-Select Pin Assignment Registers

The pin assignment registers contain 12 2-bit fields ( $\overline{CS[10:0]}$ , and  $\overline{CSBOOT}$ ) that determine the functions of the chip-select pins. Each pin has two or three possible functions, as shown in Table 4–20.

| 16-Bit<br>Chip Select | 8-Bit<br>Chip Select | Alternate<br>Function | Discrete<br>Output |
|-----------------------|----------------------|-----------------------|--------------------|
| CSBOOT                | CSBOOT               | CSBOOT                |                    |
| CS0                   | CS0                  | BR                    |                    |
| CS1                   | CS1                  | BG                    | —                  |
| CS2                   | CS2                  | BGACK                 | _                  |
| CS3                   | CS3                  | FC0                   | PC0                |
| CS4                   | CS4                  | FC1                   | PC1                |
| CS5                   | CS5                  | FC2                   | PC2                |
| CS6                   | CS6                  | ADDR19                | PC3                |
| CS7                   | CS7                  | ADDR20                | PC4                |
| CS8                   | CS8                  | ADDR21                | PC5                |
| CS9                   | CS9                  | ADDR22                | PC6                |
| CS10                  | CS10                 | ADDR23                | ECLK               |

## Table 4-20.Chip-Select Pin Functions

Table 4–21 shows pin assignment field encoding. Pins that have no discrete output function do not use the %00 encoding.

| Bit Field | Description               |
|-----------|---------------------------|
| 00        | Discrete Output           |
| 01        | Alternate Function        |
| 10        | Chip Select (8-Bit Port)  |
| 11        | Chip Select (16-Bit Port) |

Table 4-21.Pin Assignment Field Encoding

Port size determines the wa

Port size determines the way in which bus transfers to an external address are allocated. Port size of 8-bits or 16-bits can be selected when a pin is assigned as a chip select. Port size and transfer size affect how the chip-select signal is asserted. Refer to **4.7.1.3 Option Registers** for more information.

Out of reset, chip-select pin function is determined by the logic level on a corresponding data bus pin. These pins have weak internal pull-up drivers, but can be held low by external devices. (Refer to **4.5.3.1 Data Bus Mode Selection** for more information.) Either 16-bit chip-select function (%11) or alternate function (%01) can be selected during reset. All pins except the boot ROM select pin (CSBOOT) are disabled out of reset. There are 12 chip-select functions and only 8 associated data bus pins — there is not a one-to-one correspondence. Refer to **4.7.4 Chip-Select Reset Operation** for more detailed information.

The CSBOOT signal is normally asserted out of reset. The state of the DATA0 line during reset determines what port width CSBOOT uses. If DATA0 is held high (either by the weak internal pull-up driver or by an external pull-up device), 16-bit width is selected. If DATA0 is held low, 8-bit port size is selected.

A pin programmed as a discrete output drives an external signal to the value specified in the pin data register. No discrete output function is available on pins CSBOOT, BR, BG, or BGACK. ADDR23 provides ECLK output rather than a discrete output signal.

When a pin is programmed for discrete output or alternate function, internal chip-select logic still functions and can be used to generate DSACK or AVEC internally on an address and control signal match.

SYSTEM INTEGRATION MODULE

## 4.7.1.2 Chip-Select Base Address Registers

Each chip select has an associated base address register. A base address is the lowest address in the block of addresses enabled by a chip select.

Block size is the extent of the address block above the base address. Block size is determined by the value contained in a BLKSZ field. Block addresses for different chip selects can overlap.

The BLKSZ field determines which bits in the base address field are compared to corresponding bits on the address bus during an access. Provided other constraints determined by option register fields are also satisfied, when a match occurs, the associated chip-select signal is asserted. Table 4–22 shows BLKSZ encoding.

| BLKSZ[2:0] | Block Size | Address Lines Compared |
|------------|------------|------------------------|
| 000        | 2 K        | ADDR[23:11]            |
| 001        | 8 K        | ADDR[23:13]            |
| 010        | 16 K       | ADDR[23:14]            |
| 011        | 64 K       | ADDR[23:16]            |
| 100        | 128 K      | ADDR[23:17]            |
| 101        | 256 K      | ADDR[23:18]            |
| 110        | 512 K      | ADDR[23:19]            |
| 111        | 512 K      | ADDR[23:20]            |

ADDR[23:20] = ADDR19 during normal operation.

The chip-select address compare logic uses only the most significant bits to match an address within a block — the value of the base address must be a multiple of block size. Base address register diagrams show how base register bits correspond to address lines.

Because the logic state of ADDR[23:20] follows that of ADDR19 in the CPU16, maximum block size is 512 Kbytes. Because ADDR[23:20] follow the logic state of ADDR19, addresses from \$080000 to \$F7FFFF are inaccessible.

After reset, the MCU fetches initialization values from word addresses \$0000 to \$0006 in bank 0 of program space. To support bootstrap operation from reset, the base address field in chip-select base address register boot (CSBARBT) has a reset value of all zeros. A memory device containing vectors located at these addresses can be automatically enabled by CSBOOT after a reset. The block size field in CSBARBT has a reset value of 512 Kbyte. Refer to **4.7.4 Chip-Select Reset Operation** for more information.

| MC68HC16Z1    |  |
|---------------|--|
| USER'S MANUAL |  |

SYSTEM INTEGRATION MODULE

## 4.7.1.3 Chip-Select Option Registers

Option register fields determine timing of and conditions for assertion of chipselect signals. Other constraints set by fields in the option register and in the base address register must also be satisfied in order to assert a chip-select signal, and to provide DSACK or autovector support. Table 4–23 is a summary of option register functions.

| MODE       | BYTE         | R/W        | STRB                | DSACK           | SPACE        | IPL              | AVEC     |
|------------|--------------|------------|---------------------|-----------------|--------------|------------------|----------|
| 0 = ASYNC* | 00 = Disable | 00 = Rsvd  | $0 = \overline{AS}$ | 0000 = 0 WAIT   | 00 = CPU SP  | 000 = All*       | 0 = Off* |
| 1 = SYNC   | 01 = Lower   | 01 = Read  | $1 = \overline{DS}$ | 0001 = 1 WAIT   | 01 = User SP | 001 = Priority 1 | 1 = On   |
|            | 10 = Upper   | 10 = Write |                     | 0010 = 2 WAIT   | 10 = Supv SP | 010 = Priority 2 |          |
|            | *11 = Both   | 11 = Both  |                     | 0011 = 3 WAIT   | 11 = S/U SP* | 011 = Priority 3 |          |
|            |              |            |                     | 0100 = 4 WAIT   |              | 100 = Priority 4 |          |
|            |              |            |                     | 0101 = 5 WAIT   |              | 101 = Priority 5 |          |
|            |              |            |                     | 0110 = 6 WAIT   |              | 110 = Priority 6 |          |
|            |              |            |                     | 0111 = 7 WAIT   |              | 111 = Priority 7 |          |
|            |              |            |                     | 1000 = 8 WAIT   |              |                  |          |
|            |              |            |                     | 1001 = 9 WAIT   |              |                  |          |
|            |              |            |                     | 1010 = 10 WAIT  |              |                  |          |
|            |              |            |                     | 1011 = 11 WAIT  |              |                  |          |
|            |              |            |                     | 1100 = 12 WAIT  |              |                  |          |
|            |              |            |                     | 1101 = 13 WAIT  |              |                  |          |
|            |              |            |                     | 1110 = F term   |              |                  |          |
|            |              |            |                     | 1111 = External |              |                  |          |

| Table 4–23. Option Register Function | Summary |  |
|--------------------------------------|---------|--|
|--------------------------------------|---------|--|

\*Use this value when function is not required for chip-select operation.

The **MODE** bit determines whether chip-select assertion is asynchronous or synchronized to the M6800-type bus clock signal (ECLK) available on ADDR23 (refer to **4.2 System Clock** for more information on ECLK).

Asynchronous chip-select operation corresponds to asynchronous external bus operation. In asynchronous mode, chip-select signal assertion occurs at the same time as AS or DS assertion, depending on the value in the STRB field. R/W determines whether the chip-select signal is asserted for a read only, for a write only, or for both read and write. An asynchronous chip-select cycle must be terminated by a data and size acknowledge (DSACK) signal or by an autovector (AVEC) signal. The DSACK field determines the source of the data and size acknowledge signal and controls wait-state insertion in asynchronous mode. The AVEC bit controls the internally-generated autovector signal. DSACK field encoding %1110 is used to enable fast-termination bus cycles (refer to **4.4.3 Fast Termination Cycles** for more information).

In synchronous mode, chip-select assertion is synchronized to the MCU ECLK output. When a match condition occurs, the chip-select circuit signals the EBI that an ECLK cycle is pending. When the EBI determines that bus timing constraints are satisfied, the chip-select signal is asserted. Transfers of word and long-word data to an 8-bit port are performed consecutively, without insertion of additional ECLK cycles. During synchronous operation, bus monitor timeout period must be longer than the number of clock cycles required for two ECLK cycles (refer to **4.1.7 Bus Monitor** for more information). Because synchronous cycles are not terminated by data and size acknowledge signals, the DSACK field has no effect in synchronous mode. The AVEC bit must not be used in synchronous mode — autovector response timing can vary due to ECLK synchronization.

The **BYTE** field controls bus allocation for chip-select transfers. Port size, set when a chip-select is enabled by a pin assignment register, affects signal assertion. When an 8-bit port is assigned, any BYTE field value other than %00 enables the chip select signal. When a 16-bit port is assigned, however, BYTE field value determines when the chip select is enabled. The BYTE fields for  $\overline{CS[10:0]}$  are cleared during reset. However, both bits in the boot ROM option register (CSORBT) BYTE field are set (%11) when the reset signal is released.

The disable option prevents chip-select signal assertion, even when all other constraints are satisfied. The associated pin is driven high, and associated signals, such as DSACK or AVEC, cannot be asserted internally by chip-select logic.

The upper and lower byte options are used to generate chip-select signals for single-byte transfers to 16-bit ports. For example, two chip-select lines can be used to select 8-bit banks in a 16-bit memory. To do this, program two chip-select base address registers with the same base address, then set up the individual lines for byte access. Program both option registers identically except for the BYTE fields — use the upper byte option for one line and the lower byte option for the other.

The both-bytes option is used to generate a single chip-select signal for word transfers to a 16-bit port.

The  $\mathbf{R}/\mathbf{W}$  field causes a chip-select signal to be asserted only for a read, only for a write, or for both read and write. Use this field in conjunction with the STRB bit to generate asynchronous control signals for external devices.

The **STRB** bit controls the timing of a chip-select assertion in asynchronous mode. Selecting address strobe causes a chip-select signal to be asserted synchronized with the address strobe. Selecting data strobe causes a chip-select signal to be asserted synchronized with the data strobe. This bit has no effect in synchronous mode.

The **DSACK** field specifies the source of data strobe acknowledge signals used in asynchronous mode. It also allows the user to optimize bus speed in a particular application by controlling the number of wait states that are inserted.

If an internally generated acknowledge option is selected, bus timing can be adjusted by inserting up to 13 wait states before DSACK assertion. A wait state has a duration of one clock cycle. The wait states are inserted beginning with S3 of the external bus cycle. A no-wait-state encoding corresponds to a three-cycle bus.

Fast termination encoding corresponds to a two-cycle bus access. MCU modules typically respond at this rate, but fast termination can also be used to access fast external devices. If an external device is fast enough, the bus cycle can be terminated at S3. (Refer to **4.4.3 Fast Termination Cycles**.)

Cycles are terminated by the first DSACK that occurs — if an external DSACK occurs during internal wait state generation, the bus cycle terminates immediately. If the externally generated acknowledge option is selected, the MCU waits indefinitely for external DSACK assertion.

If multiple chip selects are to be used to provide control signals to a single device and match conditions can occur simultaneously, all but one of the associated DSACK fields should be programmed either for external DSACK or for the same number of wait states. The remaining DSACK field should be programmed for the fast termination option. This prevents a conflict on the internal bus when the wait states are loaded into the DSACK counter shared by all chip selects.

The **SPACE** field determines the address space in which a chip select is asserted. An access must have the space type represented by SPACE encoding in order for a chip-select signal to be asserted.

A chip select set up for CPU space access should not be used to select an external device for reading or writing — I/O occurs in supervisor space, but interrupt acknowledge cycles occur in CPU space. A separate chip select is needed to access the external device. The chip select used for the  $\overline{AVEC}$  can, however, still be used for discrete I/O.

The **STRB** bit controls the timing of a chip-select assertion in asynchronous mode. Selecting address strobe causes a chip-select signal to be asserted synchronized with the address strobe. Selecting data strobe causes a chip-select signal to be asserted synchronized with the data strobe. This bit has no effect in synchronous mode.

The **DSACK** field specifies the source of data strobe acknowledge signals used in asynchronous mode. It also allows the user to optimize bus speed in a particular application by controlling the number of wait states that are inserted.

If an internally generated acknowledge option is selected, bus timing can be adjusted by inserting up to 13 wait states before DSACK assertion. A wait state has a duration of one clock cycle. The wait states are inserted beginning with S3 of the external bus cycle. A no-wait-state encoding corresponds to a three-cycle bus.

Fast termination encoding corresponds to a two-cycle bus access. MCU modules typically respond at this rate, but fast termination can also be used to access fast external devices. If an external device is fast enough, the bus cycle can be terminated at S3. (Refer to **4.4.3 Fast Termination Cycles**.)

Cycles are terminated by the first DSACK that occurs — if an external DSACK occurs during internal wait state generation, the bus cycle terminates immediately. If the externally generated acknowledge option is selected, the MCU waits indefinitely for external DSACK assertion.

If multiple chip selects are to be used to provide control signals to a single device and match conditions can occur simultaneously, all but one of the associated DSACK fields should be programmed either for external DSACK or for the same number of wait states. The remaining DSACK field should be programmed for the fast termination option. This prevents a conflict on the internal bus when the wait states are loaded into the DSACK counter shared by all chip selects.

The **SPACE** field determines the address space in which a chip select is asserted. An access must have the space type represented by SPACE encoding in order for a chip-select signal to be asserted.

A chip select set up for CPU space access should not be used to select an external device for reading or writing — I/O occurs in supervisor space, but interrupt acknowledge cycles occur in CPU space. A separate chip select is needed to access the external device. The chip select used for the AVEC can, however, still be used for discrete I/O.

## 4.7.2 Chip-Select Operation

When the MCU makes an access, enabled chip-select circuits compare the following items:

- 1. Function codes to SPACE fields.
- 2. Appropriate ADDR bits to base address fields.
- 3. Read/write status to  $R/\overline{W}$  fields.
- 4. ADDR0 and/or SIZ bits to the BYTE field (16-bit ports only).
- 5. Priority of the interrupt being acknowledged (ADDR[3:1]) to IPL fields (when the access is an interrupt acknowledge cycle).

When a match occurs, the chip-select signal is asserted. Assertion occurs at the same time as  $\overline{AS}$  or  $\overline{DS}$  assertion in asynchronous mode. Assertion is synchronized with ECLK in synchronous mode. In asynchronous mode, the value of the DSACK field determines whether  $\overline{DSACK}$  is generated internally —  $\overline{DSACK}$  also determines the number of wait states inserted before internal  $\overline{DSACK}$  assertion.

The speed of an external device determines whether internal wait states are needed. Normally, wait states are inserted into the bus cycle during S3 until a peripheral asserts DSACK (refer to **4.4.2.1 Read Cycle** and **4.4.2.2 Write Cycle** for more information on wait-state timing). If a peripheral does not generate DSACK, internal DSACK generation must be selected and a predetermined number of wait states may be programmed into the chip-select option register.

Refer to **4.6.5 Interrupt Acknowlege Bus Cycles** for additional information. Figure 4–35 is a flow diagram for the assertion of chip select.



Figure 4-35. Flow Diagram for Chip Select (Sheet 1 of 3)

MC68HC16Z1 USER'S MANUAL SYSTEM INTEGRATION MODULE

MOTOROLA 4–91 4



Figure 4-35. Flow Diagram for Chip Select (Sheet 2 of 3)

MOTOROLA 4–92 SYSTEM INTEGRATION MODULE

MC68HC16Z1 USER'S MANUAL





MC68HC16Z1 USER'S MANUAL SYSTEM INTEGRATION MODULE

MOTOROLA 4–93 4

## 4.7.3 Using Chip-Select Signals for Interrupt Acknowledge

Ordinary I/O bus cycles use supervisor space access, but interrupt acknowledge bus cycles use CPU space access (refer to **4.4.4 CPU Space Cycles** and **4.6 Interrupts** for more information). There are no differences in flow for chip selects in each type of space, but base and option registers must be properly programmed for each type of external bus cycle.

During a CPU space cycle, bits [15:3] of the appropriate base register must be configured to match ADDR[23:11], since the address is compared to an address generated by the CPU. In the MC68HC16Z1, ADDR[23:20] follow the state of ADDR19 — the states of base register bits [15:12] must match that of bit 11.

Figure 4–36 shows CPU space encoding for an interrupt acknowledge cycle. FC[2:0] are set to %111, designating CPU space access. ADDR[3:1] indicate interrupt priority, and the space type field (ADDR[19:16]) is set to %1111, the interrupt acknowledge code. The rest of the address lines are set to one.



## Figure 4-36. CPU Space Encoding for Interrupt Acknowledge

Perform the following operations before using a chip select to generate an interrupt acknowledge signal.

- 1. Program the base address field to all ones.
- Program block size to no more than 64 Kbytes. Use of CPU space automatically drives ADDR[19:16] to logic level one and ADDR[23:20] follow the state of ADDR19, so the address comparator can use only the lower 16 address lines.
- 3. Set the R/W field to read only an interrupt acknowledge cycle is performed as a read cycle.

MOTOROLA 4–94 4. Set the BYTE field to lower byte when using a 16-bit port, since the external vector for a 16-bit port is fetched from the lower byte. Set the BYTE field to upper byte when using an 8-bit port.

If an interrupting device does not provide a vector number, an autovector acknowledge must be generated — the bus cycle is terminated by asserting  $\overline{AVEC}$ . This can be done either by asserting the  $\overline{AVEC}$  pin or by generating  $\overline{AVEC}$  internally, using the chip-select option register.

## 4.7.4 Chip-Select Reset Operation

The least significant bits of each of the 2-bit CS[10:0] pin assignment fields in CSPAR0 and CSPAR1 each have a reset value of one. The reset values of the most significant bits of each field are determined by the states of DATA[7:1] during reset. There are weak internal pull-up drivers for each of the data lines, but these drivers can be overcome by bus loading effects.

The CSBOOT assignment field in CSPAR0 is configured differently. The MSB, bit 1 of CSPAR0, has a reset value of one. This enables the CSBOOT signal to select a boot ROM containing initialization firmware. The LSB value, determined by the logic level of DATA0 during reset, selects boot ROM port size. When DATA0 is held low, port size is 8 bits — when DATA0 is held high, port size is 16 bits.

After reset, the MCU fetches initialization values from word addresses \$0000 to \$0006 in bank 0 of program space. To support bootstrap operation from reset, the base address field in chip-select base address register boot (CSBARBT) has a reset value of all zeros. A ROM device containing vectors located at these addresses can be enabled by  $\overline{CSBOOT}$  after a reset. The block size field in CSBARBT has a reset value of 512 Kbyte.

The byte field in option register CSORBT has a reset value of both bytes, but CSOR[10:0] have a reset value of disable, since they should not select external devices until an initial program sets up the base and option registers. Table 4–24 shows the reset values in the base and option registers for CSBOOT.

| Fields           | Reset Values                |
|------------------|-----------------------------|
| Base Address     | \$0000 0000                 |
| Block Size       | 512 Kbyte                   |
| Async/Sync Mode  | Asynchronous Mode           |
| Upper/Lower Byte | Both Bytes (CSORBT)         |
| Byte             | Disable (CSOR10-CSOR0)      |
| Read/Write       | Read/Write                  |
| AS/DS            | ĀS                          |
| DSACK            | 13 Wait States              |
| Address Space    | Supervisor/User Space       |
| IPL              | Any Level                   |
| Autovector       | Interrupt Vector Externally |

# Table 4–24.CSBOOTBase and Option RegisterResetValues

## 4.8 Parallel Input/Output Ports

Sixteen of the SIM pins can be configured for general-purpose discrete input and output. Although these pins are organized into two ports, port E and port F, function assignment is by individual pin. PE3 is not connected to a pin. PE3 returns zero when read — writes have no effect. Pin assignment registers, data direction registers, and data registers are used to implement discrete I/O.

## 4.8.1 Pin Assignment Registers

Bits in the Port E and Port F pin assignment registers (PEPAR and PFPAR) control the functions of the pins in each port. Any bit set to one defines the corresponding pin to be a bus control signal. Any bit cleared to zero defines the corresponding pin to be an I/O pin. PEPA3 returns one when read — writes have no effect.

## 4.8.2 Data Direction Registers

Bits in the Port E and Port F data direction registers (DDRE and DDRF) control the direction of the pin drivers when the pins are configured as I/O. Any bit in a register set to one configures the corresponding pin as an output. Any bit in a register cleared to zero configures the corresponding pin as an input. These registers can be read or written at any time. DDE3 returns zero when read; writes have no effect.

## 4.8.3 Data Registers

A write to the Port E and Port F data registers (PORTE and PORTF) is stored in an internal data latch, and if any pin in the corresponding port is configured as an output, the value stored for that bit is driven out on the pin. A read of a data register returns the value at the pin only if the pin is configured as a discrete input. Otherwise, the value read is the value stored in the register. Both data registers can be accessed in two locations. Registers can be read or written at any time.

## 4.9 Factory Test

The test submodule supports scan-based testing of the various MCU modules. It is integrated into the SIM to support production test. Test submodule registers are intended for Motorola use. Register names and addresses are provided in **APPENDIX D REGISTER SUMMARY** to show the user that these addresses are occupied. The TSTME and QUOT pins are also used for factory test. 4

MOTOROLA 4–98 SYSTEM INTEGRATION MODULE

MC68HC16Z1 USER'S MANUAL

## SECTION 5 CENTRAL PROCESSING UNIT

The central processing unit (CPU16) was designed to provide compatibility with the MC68HC11 and to provide additional capabilities associated with 16- and 32-bit data sizes, 20-bit addressing, and digital signal processing. CPU16 registers are an integral part of the CPU and are not addressed as memory locations. The CPU16 register model contains all the resources of the MC68HC11, plus additional resources.

The CPU16 treats all peripheral, I/O, and memory locations as parts of a pseudolinear 1 Megabyte address space. There are no special instructions for I/O that are separate from instructions for addressing memory. Address space is made up of 16 64-Kbyte banks. Specialized bank addressing techniques and support registers provide transparent access across bank boundaries.

The CPU16 interacts with external devices and with other modules within the microcontroller via a standardized bus and bus interface. There are bus protocols for memory and peripheral accesses, as well as for managing an hierarchy of interrupt priorities.

This section is intended to provide an overview of and ready reference to CPU16 function. For detailed information concerning CPU operation, refer to the *CPU16 Reference Manual* (CPU16RM/AD).

## 5.1 Register Model

Figure 5–1 shows the CPU16 register model. Registers are discussed in detail in the following paragraphs.



Figure 5-1. CPU16 Register Model

CENTRAL PROCESSING UNIT

5

## 5.1.1 Accumulators

The CPU16 has two 8-bit accumulators (A and B) and one 16-bit accumulator (E). In addition, accumulators A and B can be concatenated into a second 16-bit double accumulator (D).

Accumulators A, B, and D are general-purpose registers used to hold operands and results during mathematic and data manipulation operations.

Accumulator E can be used in the same way as accumulator D, and also extends CPU16 capabilities. It allows more data to be held within the CPU16 during operations, simplifies 32-bit arithmetic and digital signal processing, and provides a practical 16-bit accumulator offset indexed addressing mode.

#### 5.1.2 Index Registers

The CPU16 has three 16-bit index registers (IX, IY, and IZ). Each index register has an associated 4-bit extension field (XK, YK, and ZK).

Concatenated registers and extension fields provide 20-bit indexed addressing and support data structure functions anywhere in the CPU16 address space.

IX and IY can perform the same operations as MC68HC11 registers of the same names, but the CPU16 instruction set provides additional indexed operations.

IZ can perform the same operations as IX and IY, and also provides an additional indexed addressing capability that replaces MC68HC11 direct addressing mode. Initial IZ and ZK extension field values are included in the RESET exception vector, so that ZK : IZ can be used as a direct page pointer out of reset.

## 5.1.3 Stack Pointer

The CPU16 stack pointer (SP) is 16 bits wide. An associated 4-bit extension field (SK) provides 20-bit stack addressing.

Stack implementation in the CPU16 is from high to low memory. The stack grows downward as it is filled. SK : SP are decremented each time data is pushed on the stack, and incremented each time data is pulled from the stack.

SK : SP point to the next available stack address, rather than to the address of the latest stack entry. Although the stack pointer is normally incremented or decremented by word address, it is possible to push and pull byte-sized data. Setting the stack pointer to an odd value causes misalignment, which affects performance.

#### 5.1.4 Program Counter

The CPU16 program counter (PC) is 16 bits wide. An associated 4-bit extension field (PK) provides 20-bit program addressing.

CPU16 instructions are fetched from even word boundaries. PC0 always has a value of 0, to assure that instruction fetches are made from word-aligned addresses.

## 5.1.5 Condition Code Register

The 16-bit condition code register can be divided into two functional blocks. The 8 MSB, which correspond to the CCR in the MC68HC11, contain the lowpower stop control bit and processor status flags. The 8 LSB contain the interrupt priority field, the DSP saturation mode control bit, and the program counter address extension field.

Figure 5–2 shows the condition code register. Detailed descriptions of each status indicator and field in the register follow the figure.

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6  | 5 | 4  | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|----|---|----|---|---|---|---|
| S  | MV | Н  | EV | Ν  | Z  | V | С |   | IP |   | SM |   | Р | К |   |

## Figure 5-2. Condition Code Register

- S STOP Enable
  - 0 = Stop clock when LPSTOP instruction is executed.
  - 1 = Perform NOP when LPSTOP instruction is executed.
- MV Accumulator M overflow flag Set when overflow into AM35 has occurred.
- H Half Carry Flag

Set when a carry from A3 or B3 occurs during BCD addition.

EV — Extension Bit Overflow Flag Set when an overflow into AM31 has occurred.

## N — Negative Flag

Set when the MSB of a result register is set.

Z — Zero Flag

Set when all bits of a result register are zero.

## V — Overflow Flag

Set when twos complement overflow occurs as the result of an operation.

## C — Carry Flag

Set when carry or borrow occurs during arithmetic operation. Also used during shift and rotate to facilitate multiple word operations.

## IP[2:0] — Interrupt Priority Field

The priority value in this field (0 to 7) is used to mask interrupts.

## SM — Saturate Mode Bit

When SM is set, if either EV or MV is set, data read from AM using TMER or TMET will be given maximum positive or negative value, depending on the state of the AM sign bit before overflow.

## PK[3:0] — Program Counter Address Extension Field

This field is concatenated with the program counter to form a 20-bit address.

## 5.1.6 Address Extension Register and Address Extension Fields

There are six 4-bit address extension fields. EK, XK, YK, and ZK are contained by the address extension register, PK is part of the CCR, and SK stands alone.

Extension fields are the bank portions of 20-bit concatenated bank : byte addresses used in the CPU16 pseudolinear memory management scheme.

All extension fields except EK correspond directly to a register. XK, YK, and ZK extend registers IX, IY, and IZ; PK extends the PC; and SK extends the SP. EK holds the 4 MSB of the 20-bit address used by extended addressing mode.

## 5.1.7 Multiply and Accumulate Registers

The multiply and accumulate (MAC) registers are part of a CPU submodule that performs repetitive signed fractional multiplication and stores the cumulative result. These operations are part of control-oriented digital signal processing.

There are four MAC registers. Register H contains the 16-bit signed fractional multiplier. Register I contains the 16-bit signed fractional multiplicand. Accumulator M is a specialized 36-bit product accumulation register. XMSK and YMSK contain 8-bit mask values used in modulo addressing.

The CPU16 has a special subset of signal processing instructions that manipulate the MAC registers and perform signal processing calculation.

#### 5.2 Memory Management

The CPU16 uses bank switching to provide a 1 Megabyte address space. There are 16 banks within the address space. Each bank is made up of 64 Kbytes addressed from \$0000 to \$FFFF. Banks are selected by means of address extension fields associated with individual CPU16 registers.

In addition, address space can be split into discrete 1 Megabyte program and data spaces by externally decoding the SIM function code outputs. When this technique is used, instruction fetches and reset vector fetches access program space, while exception vector fetches (other than for reset), data accesses, and stack accesses are made in data space.

## 5.2.1 Address Extension

All CPU16 resources that are used to generate addresses are effectively 20 bits wide. These resources include extended index registers, program counter, and stack pointer. All addressing modes use 20-bit addresses.

20-bit addresses are formed from a 16-bit byte address generated by an individual CPU16 register and a 4-bit bank address contained in an associated extension field. The byte address corresponds to ADDR[15:0] and the bank address corresponds to ADDR[19:16].

#### 5.2.2 Extension Fields

The six address extension fields are each used in a different type of access. All but EK are associated with particular CPU16 registers. There are a number of ways to manipulate extension fields and the address map. Refer to the *CPU16 Reference Manual* (CPU16RM/AD) for detailed information.

#### 5.3 Data Types

The CPU16 uses the following types of data:

- Bits
- 4-bit signed integers
- 8-bit (byte) signed and unsigned integers
- 8-bit, 2-digit binary coded decimal numbers
- 16-bit (word) signed and unsigned integers
- 32-bit (long word) signed and unsigned integers
- 16-bit signed fractions
- 32-bit signed fractions
- 36-bit signed fixed-point numbers
- 20-bit effective address consisting of 16-bit byte address and 4-bit extension

MOTOROLA 5–6 There are 8 bits in a byte, 16 bits in a word. Bit set and clear instructions use both byte and word operands. Bit test instructions use byte operands.

Negative integers are represented in twos-complement form. Four-bit signed integers, packed two to a byte, are used only as X and Y offsets in MAC and RMAC operations. Thirty-two-bit integers are used only by extended multiply and divide instructions, and by the associated LDED and STED instructions.

Binary coded decimal numbers are packed, two digits per byte. BCD operations use byte operands.

16-bit fractions are used in both fractional multiplication and division, and as multiplicand and multiplier operands in the MAC unit. Bit 15 is the sign bit. There is an implied radix point between bits 15 and 14. There are 15 bits of magnitude — the range of values is -1 (\$8000) to  $1 - 2^{-15}$  (\$7FFF).

Signed 32-bit fractions are used only by fractional multiplication and division instructions. Bit 31 is the sign bit. An implied radix point lies between bits 31 and 30. There are 31 bits of magnitude — the range of values is -1 (\$8000000) to  $1 - 2^{-31}$  (\$7FFFFFF).

Signed 36-bit fixed-point numbers are used only by the MAC unit. Bit 35 is the sign bit. Bits [34:31] are sign extension bits. There is an implied radix point between bits 31 and 30. There are 31 bits of magnitude, but use of the extension bits allows representation of numbers in the range -16 (\$80000000) to 15.999969482 (\$7FFFFFFF).

20-bit addresses are formed by combining a 16-bit byte address with a 4-bit address extension.

#### 5.4 Memory Organization

Both program and data memory are divided into sixteen 64-Kbyte banks. Addressing is pseudolinear — a 20-bit extended address can access any byte location in the appropriate address space.

A word is composed of two consecutive bytes. A word address is normally an even byte address. Byte 0 of a word has a lower 16-bit address than Byte 1. Long words and 32-bit signed fractions consist of two consecutive words, and are normally accessed at the address of Byte 0 in Word 0.

Instruction fetches always access word addresses. Word operands are normally accessed at even byte addresses, but may be accessed at odd byte addresses, with a substantial performance penalty. To be compatible with the MC68HC11, misaligned word transfers and misaligned stack accesses are allowed. Transferring a misaligned word requires two successive byte transfer operations.

Figure 5–3 shows how each CPU16 data type is organized in memory. Consecutive even addresses show size and alignment.

| Address |           |                                                |           |           |           |           |          | Ту       | pe       | , mar 1997 |          |          |          |          |          |          |
|---------|-----------|------------------------------------------------|-----------|-----------|-----------|-----------|----------|----------|----------|------------|----------|----------|----------|----------|----------|----------|
| \$0000  | BIT<br>15 | BIT<br>14                                      | BIT<br>13 | BIT<br>12 | BIT<br>11 | BIT<br>10 | BIT<br>9 | BIT<br>8 | BIT<br>7 | BIT<br>6   | BIT<br>5 | BIT<br>4 | BIT<br>3 | BIT<br>2 | BIT<br>1 | BIT<br>0 |
| \$0002  |           |                                                |           | BY        | TE0       |           |          |          |          |            |          | BY       | TE1      |          |          |          |
| \$0004  | ±         | X                                              | OFFS      | ET        | ±         | Y         | OFFS     | ET       | ±        | Х          | OFFS     | ET       | ±        | Y        | OFFS     | ET       |
| \$0006  |           | BC                                             | D1        |           |           | BC        | D0       |          |          | BC         | :D1      |          | BCD0     |          |          |          |
| \$0008  |           |                                                |           |           |           |           |          | WO       | RD 0     |            |          |          |          |          |          |          |
| \$000A  |           | WORD1                                          |           |           |           |           |          |          |          |            |          |          |          |          |          |          |
| \$000C  |           | MSW LONG WORD 0                                |           |           |           |           |          |          |          |            |          |          |          |          |          |          |
| \$000E  |           | LSW LONG WORD 0                                |           |           |           |           |          |          |          |            |          |          |          |          |          |          |
| \$0010  |           |                                                |           |           |           |           | MSV      | V LON    | G WO     | RD 1       |          |          | •        |          |          |          |
| \$0012  |           |                                                |           |           | . 1       |           | LSW      | /LON     | G WO     | RD 1       |          | •        | •        |          |          |          |
| \$0014  | ±         | ⇐ (Ra                                          | adix Po   | oint)     | 1         | 16-       | BITSI    | GNED     | FRAG     | CTION      | 0        |          | ,        | •        |          |          |
| \$0016  | ±         | ± ⇐ (Radix Point) 16-BIT SIGNED FRACTION 1     |           |           |           |           |          |          |          |            |          |          |          |          |          |          |
| \$0018  | ±         | ± ⇐ (Radix Point) MSW 32-BIT SIGNED FRACTION 0 |           |           |           |           |          |          |          |            |          |          |          |          |          |          |
| \$001A  |           | LSW 32-BIT SIGNED FRACTION 0 0                 |           |           |           |           | 0        |          |          |            |          |          |          |          |          |          |
| \$001C  | ±         | ± (Radix Point) MSW 32-BIT SIGNED FRACTION 1   |           |           |           |           |          |          |          |            |          |          |          |          |          |          |
| \$001E  |           |                                                |           |           |           | LS        | N 32-E   | SIT SIG  | NED I    | RAC        | FION 1   |          |          |          |          | 0        |

#### MAC Data Types

| 35 |    |   | 32 | 31 |                            |                               | 16 |
|----|----|---|----|----|----------------------------|-------------------------------|----|
| ±  | ×  | « | ×  | «  | ⇐ (Radix Point)            | MSW 32-BIT SIGNED FRACTION    |    |
|    | 15 |   | 0  |    |                            |                               |    |
|    |    |   |    |    | LSW 32-BIT SIGNED FRACTION |                               |    |
|    |    |   |    | ±  | ⇐ (Radix Point)            | <b>16-BIT SIGNED FRACTION</b> |    |

#### Address Data Type

| 19 16           | 15 0           |  |
|-----------------|----------------|--|
| 4-Bit Extension | 16-Bit Address |  |

## Figure 5–3. Data Types and Memory Organization

CENTRAL PROCESSING UNIT

## 5.5 Addressing Modes

The CPU16 uses 10 basic types of addressing. There are one or more addressing modes within each type. Table 5–1 shows the addressing modes.

| Mode                | Mnemonic | Description                                                                   |
|---------------------|----------|-------------------------------------------------------------------------------|
| Accumulator Offset  | E,X      | Index Register X with Accumulator E offset                                    |
|                     | E,Y      | Index Register Y with Accumulator E offset                                    |
|                     | E,Z      | Index Register Z with Accumulator E offset                                    |
| Extended            | EXT      | Extended                                                                      |
|                     | EXT20    | 20-bit Extended                                                               |
| Immediate           | IMM8     | 8-bit Immediate                                                               |
|                     | IMM16    | 16-bit Immediate                                                              |
| Indexed 8-Bit       | IND8, X  | Index Register X with unsigned 8-bit offset                                   |
|                     | IND8, Y  | Index Register Y with unsigned 8-bit offset                                   |
|                     | IND8, Z  | Index Register Z with unsigned 8-bit offset                                   |
| Indexed 16-Bit      | IND16, X | Index Register X with signed 16-bit offset                                    |
|                     | IND16, Y | Index Register Y with signed 16-bit offset                                    |
|                     | IND16, Z | Index Register Z with signed 16-bit offset                                    |
| Indexed 20-Bit      | IND20, X | Index Register X with signed 20-bit offset                                    |
|                     | IND20, Y | Index Register Y with signed 20-bit offset                                    |
|                     | IND20, Z | Index Register Z with signed 20-bit offset                                    |
| Inherent            | INH      | Inherent                                                                      |
| Post-Modified Index | IXP      | Signed 8-bit offset added to Index Register X after effective address is used |
| Relative            | REL8     | 8-bit relative                                                                |
|                     | REL16    | 16-bit relative                                                               |

Table 5-1. Addressing Modes

All modes generate ADDR[15:0]. This address is combined with ADDR[19:16] from an operand or an extension field to form a 20-bit effective address.

#### NOTE

Bank switching is transparent to most instructions. ADDR[19:16] of the effective address are changed to make an access across a bank boundary. However, extension field values do not change as a result of effective address computation.

## 5.5.1 Immediate Addressing Modes

In the immediate modes, an argument is contained in a byte or word immediately following the instruction. For IMM8 and IMM16 modes, the effective address is the address of the argument.

There are three specialized forms of IMM8 addressing.

The AIS, AIX/Y/Z, ADDD and ADDE instructions decrease execution time by sign-extending the 8-bit immediate operand to 16 bits, then adding it to an appropriate register.

The MAC and RMAC instructions use an 8-bit immediate operand to specify two signed 4-bit index register offsets.

The PSHM and PULM instructions use an 8-bit immediate mask operand to indicate which registers must be pushed to or pulled from the stack.

## 5.5.2 Extended Addressing Modes

Regular extended mode instructions contain ADDR[15:0] in the word following the opcode. The effective address is formed by concatenating the EK field and the 16-bit byte address. EXT20 mode is used only by the JMP and JSR instructions. These instructions contain a 20-bit effective address that is zero-extended to 24 bits to give the instruction an even number of bytes.

## 5.5.3 Indexed Addressing Modes

In the indexed modes, registers IX, IY, and IZ, together with their associated extension fields, are used to calculate the effective address.

For 8-bit indexed modes an 8-bit unsigned offset contained in the instruction is added to the value contained in an index register and its extension field.

For 16-bit modes, a 16-bit signed offset contained in the instruction is added to the value contained in an index register and its extension field.

For 20-bit modes, a 20-bit signed offset (zero-extended to 24 bits) is added to the value contained in an index register. These modes are used for JMP and JSR instructions only.

## 5.5.4 Inherent Addressing Mode

Inherent mode instructions use information directly available to the processor to determine the effective address. Operands (if any) are system resources and are thus not fetched from memory.

## 5.5.5 Accumulator Offset Addressing Mode

Accumulator offset modes form an effective address by sign-extending the content of accumulator E to 20 bits, then adding the result to an index register and its associated extension field. This mode allows use of an index register and an accumulator within a loop without corrupting accumulator D.

## 5.5.6 Relative Addressing Modes

Relative modes are used for branch and long branch instructions. If a branch condition is satisfied, a byte or word signed twos-complement offset is added to the concatenated PK field and program counter. The new PK : PC value is the effective address.

## 5.5.7 Post-Modified Index Addressing Mode

Post-modified index mode is used by the MOVB and MOVW instructions. A signed 8-bit offset is added to index register X after the effective address formed by XK : IX is used.

## 5.5.8 Use of HC16 Indexed Mode to Replace HC11 Direct Mode

In MC68HC11 systems, the direct addressing mode can be used to perform rapid accesses to RAM or I/O mapped into bank 0 (\$0000 to \$00FF), but the CPU16 uses the first 512 bytes of bank 0 for exception vectors. To provide an enhanced replacement for direct mode, the ZK field and index register Z have been assigned reset initialization vectors — by resetting the ZK field to a chosen page, and using indexed mode addressing, a programmer can access useful data structures anywhere in the address map.

#### 5.6 Instruction Set

The instruction set is based upon that of the MC68HC11, but the opcode map has been rearranged to maximize performance with a 16-bit data bus. Much MC68HC11 code can run on the CPU16 following reassembly. The user must take into account changed instruction times, the interrupt mask, and the new interrupt stack frame.

#### 5.6.1 Data Movement Instructions

The CPU16 has a complete set of 8 and 16-bit data movement instructions, as well as instructions to support 32-bit intermodule bus (IMB) operations. General-purpose load, store, transfer and move instructions facilitate movement of data to and from memory and peripherals. Special purpose instructions enhance indexing, extended addressing, stacking, and digital signal processing.

## 5.6.1.1 Load Instructions

Load instructions copy memory content into an accumulator or register. Memory content is not changed by the operation.

There are specialized load instructions for stacking, indexing, extended addressing, and digital signal processing. Refer to the appropriate summary for more information.

| Mnemonic | Function                  | Operation                                         |  |  |
|----------|---------------------------|---------------------------------------------------|--|--|
| LDAA     | Load A                    | $(M) \Rightarrow A$                               |  |  |
| LDAB     | Load B                    | (M) ⇒ B                                           |  |  |
| LDD      | Load D                    | (M : M + 1) ⇒ D                                   |  |  |
| LDE      | Load E                    | (M∶M+1) ⇒E                                        |  |  |
| LDED     | Load Concatenated E and D | $(M:M+1) \Rightarrow E$ $(M+2:M+3) \Rightarrow D$ |  |  |

Table 5-2. Load Summary

## 5.6.1.2 Move Instructions

These instructions move data bytes or words from one location to another in memory.

Table 5–3. Move Summary

| Mnemonic | Function  | Operation                           |  |  |
|----------|-----------|-------------------------------------|--|--|
| MOVB     | Move Byte | $(M_1) \Rightarrow M_2$             |  |  |
| MOVW     | Move Word | $(M:M+1_1) \Longrightarrow M:M+1_2$ |  |  |

## 5.6.1.3 Store Instructions

Store instructions copy the content of an accumulator or register to memory. Register/accumulator content is not changed by the operation.

There are specialized store instructions for indexing, extended addressing, and CCR manipulation. Refer to the appropriate summary for more information.

| Mnemonic | Function                   | Operation                                                   |
|----------|----------------------------|-------------------------------------------------------------|
| STAA     | Store A                    | (A) ⇒ M                                                     |
| STAB     | Store B                    | (B) ⇒ M                                                     |
| STD      | Store D                    | $(D) \Longrightarrow M : M + 1$                             |
| STE      | Store E                    | $(E) \Longrightarrow M : M + 1$                             |
| STED     | Store Concatenated D and E | $(E) \Rightarrow M : M + 1$ $(D) \Rightarrow M + 2 : M + 3$ |

Table 5-4. Store Summary

## 5.6.1.4 Transfer Instructions

These instructions transfer the content of a register or accumulator to another register or accumulator. Content of the source is not changed by the operation.

There are specialized transfer instructions for stacking, indexing, extended addressing, CCR manipulation, and digital signal processing. Refer to the appropriate summary for more information.

| Mnemonic | Function        | Operation           |
|----------|-----------------|---------------------|
| ТАВ      | Transfer A to B | $(A) \Rightarrow B$ |
| ТВА      | Transfer B to A | $(B) \Rightarrow A$ |
| TDE      | Transfer D to E | (D) ⇒ E             |
| TED      | Transfer E to D | $(E) \Rightarrow D$ |

| Ta | able | 55. | Transfer | Summary |
|----|------|-----|----------|---------|
|----|------|-----|----------|---------|

## 5.6.1.5 Exchange Instructions

These instructions exchange the contents of pairs of registers or accumulators. There are specialized exchange instructions for indexing.

| Mnemonic | Function          | Operation |  |
|----------|-------------------|-----------|--|
| XGAB     | Exchange A with B | (A) ⇔ (B) |  |
| XGDE     | Exchange D with E | (D) ⇔ (E) |  |

Table 5-6. Exchange Summary

## 5.6.2 Mathematic Instructions

The CPU16 has a full set of 8- and 16-bit mathematic instructions. There are instructions for signed and unsigned arithmetic, division and multiplication, as well as a complete set of Boolean operators.

Special arithmetic and logic instructions aid stacking operations, indexing, extended addressing, BCD calculation, and condition code register manipulation. There are also dedicated multiply and accumulate instructions.

#### 5.6.2.1 Addition and Subtraction Instructions

Signed and unsigned 8- and 16-bit arithmetic instructions can be performed between registers or between registers and memory. Instructions that add or subtract the value of the CCR carry bit facilitate multiple precision computation.

| Mnemonic | Function            | Operation                                 |
|----------|---------------------|-------------------------------------------|
| ABA      | Add B to A          | $(A) + (B) \Rightarrow A$                 |
| ADCA     | Add with Carry to A | $(A) + (M) + C \Longrightarrow A$         |
| ADCB     | Add with Carry to B | $(B) + (M) + C \Longrightarrow B$         |
| ADCD     | Add with Carry to D | $(D) + (M : M + 1) + C \Longrightarrow D$ |
| ADCE     | Add with Carry to E | (E) + (M : M + 1) + C ⇒ E                 |
| ADDA     | Add to A            | $(A) + (M) \Longrightarrow A$             |
| ADDB     | Add to B            | $(B) + (M) \Longrightarrow B$             |
| ADDD     | Add to D            | $(D) + (M : M + 1) \Longrightarrow D$     |
| ADDE     | Add to E            | $(E) + (M : M + 1) \Longrightarrow E$     |
| ADE      | Add D to E          | (E) + (D) ⇒ E                             |

Table 5–7. Addition Summary

CENTRAL PROCESSING UNIT

| SBA  | Subtract B from A          | $(A)-(B) \Longrightarrow A$               |
|------|----------------------------|-------------------------------------------|
| SBCA | Subtract with Carry from A | $(A) - (M) - C \Longrightarrow A$         |
| SBCB | Subtract with Carry from B | $(B) - (M) - C \Longrightarrow B$         |
| SBCD | Subtract with Carry from D | $(D) - (M : M + 1) - C \Longrightarrow D$ |
| SBCE | Subtract with Carry from E | $(E) - (M : M + 1) - C \Longrightarrow E$ |
| SDE  | Subtract D from E          | (E) – (D)⇒ E                              |
| SUBA | Subtract from A            | $(A) - (M) \Longrightarrow A$             |
| SUBB | Subtract from B            | $(B) - (M) \Longrightarrow B$             |
| SUBD | Subtract from D            | $(D) - (M : M + 1) \Longrightarrow D$     |
| SUBE | Subtract from E            | $(E) - (M : M + 1) \Longrightarrow E$     |

Table 5-8. Subtraction Summary

## 5.6.2.2 Binary Coded Decimal Instructions

To add binary coded decimal operands, use addition instructions that set the half-carry bit in the CCR, then adjust the result with the DAA instruction.

| ABA  | Add B to A           | $(A) + (B) \Longrightarrow A$                  |
|------|----------------------|------------------------------------------------|
| ADCA | Add with Carry to A  | $(A) + (M) + C \Rightarrow A$                  |
| ADCB | Add with Carry to B  | $(B) + (M) + C \Rightarrow B$                  |
| ADDA | Add to A             | $(A) + (M) \Longrightarrow A$                  |
| ADDB | Add to B             | $(B) + (M) \Longrightarrow B$                  |
| DAA  | Decimal Adjust A     | (A)10                                          |
| SXT  | Sign Extend B into A | If B7 == 1<br>then A == \$FF<br>else A == \$00 |

Table 5-9. BCD Summary

## 5.6.2.3 Compare and Test Instructions

Compare and test instructions perform subtraction between a pair of registers or between a register and memory. The result is not stored, but condition codes are set by the operation. These instructions are generally used to establish conditions for branch instructions.

| CBA  | Compare A to B              | (A) – (B)            |
|------|-----------------------------|----------------------|
| CMPA | Compare A to Memory         | (A) – (M)            |
| СМРВ | Compare B to Memory         | (B) – (M)            |
| CPD  | Compare D to Memory         | (D) – (M : M + 1)    |
| CPE  | Compare E to Memory         | (E) – (M : M + 1)    |
| TST  | Test for Zero or Minus      | (M) — \$00           |
| TSTA | Test A for Zero or Minus    | (A) — \$00           |
| TSTB | Test B for Zero or Minus    | (B) <b>–</b> \$00    |
| TSTD | Test D for Zero or Minus    | (D) - \$0000         |
| TSTE | Test E for Zero or Minus    | (E) – \$0000         |
| TSTW | Test for Zero or Minus Word | (M : M + 1) - \$0000 |

Table 5–10. Compare and Test Summary

## 5.6.2.4 Multiplication and Division Instructions

There are instructions for signed and unsigned 8- and 16-bit multiplication, as well as for signed 16-bit fractional multiplication. Eight-bit multiplication operations have a 16-bit product. Sixteen-bit multiplication operations can have either 16- or 32-bit products.

All division operations have 16-bit divisors, but dividends can be either 16- or 32-bit numbers. Quotients and remainders of all division operations are 16-bit numbers. There are instructions for signed and unsigned division, as well as for fractional division.

Fractional multiplication uses 16-bit operands. Bit 15 is the sign bit. There is an implied radix point between bits 15 and 14. The range of values is -1 (\$8000) to 0.999969482 (\$7FFF). The MSB of the result is its sign bit, and there is an implied radix point between the sign bit and the rest of the result.

There are special 36-bit signed fractional multiply and accumulate unit instructions to support digital signal processing operations. Refer to the appropriate summary for more information.

| EDIV  | Extended Unsigned Divide   | $\begin{array}{l} (E:D) \ / \ (IX) \\ Quotient \Rightarrow IX \\ Remainder \Rightarrow D \end{array}$           |
|-------|----------------------------|-----------------------------------------------------------------------------------------------------------------|
| EDIVS | Extended Signed Divide     | $\begin{array}{l} (E:D) / (IX) \\ \text{Quotient} \Rightarrow IX \\ \text{Remainder} \Rightarrow D \end{array}$ |
| EMUL  | Extended Unsigned Multiply | $(E)*(D)\RightarrowE:D$                                                                                         |
| EMULS | Extended Signed Multiply   | $(E)\ast(D)\RightarrowE:D$                                                                                      |
| FDIV  | Fractional Divide          | $\begin{array}{l} (D) \ / \ (IX) \Rightarrow IX \\ Remainder \Rightarrow D \end{array}$                         |
| FMULS | Fractional Signed Multiply | $(E)*(D)\RightarrowE:D$                                                                                         |
| IDIV  | Integer Divide             | (D) / (IX) $\Rightarrow$ IX;<br>Remainder $\Rightarrow$ D                                                       |
| MUL   | Multiply                   | $(A)*(B) \Rightarrow D$                                                                                         |

 Table 5–11. Multiplication and Division Summary

## 5.6.2.5 Decrement and Increment Instructions

These instructions are optimized 8- and 16-bit addition and subtraction operations. Because they do not affect the carry bit in the CCR, they are particularly well suited for loop counters in multiple-precision computation routines.

 Table 5–12. Decrement and Increment Summary

| DEC  | Decrement Memory      | (M) – \$01 ⇒ M                         |
|------|-----------------------|----------------------------------------|
| DECA | Decrement A           | (A) – \$01 ⇒ A                         |
| DECB | Decrement B           | (B) – \$01 ⇒ B                         |
| DECW | Decrement Memory Word | $(M:M+1)-\$0001 \Longrightarrow M:M+1$ |
| INC  | Increment Memory      | (M) + \$01 ⇒ M                         |
| INCA | Increment A           | (A) + \$01 ⇒ A                         |
| INCB | Increment B           | (B) + \$01 ⇒ B                         |
| INCW | Increment Memory Word | $(M:M+1)+\$0001 \implies M:M+1$        |

## 5.6.2.6 Clear, Complement and Negate Instructions

Each of these instructions performs a specific binary operation on a value in an accumulator or in memory. Clear operations set the value to 0, complement operations replace the value with its ones complement, and negate operations replace the value with its twos complement.

| Clear Memory         | \$00 ⇒ M                                                                                                                                                                                                                                                                                         |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Clear A              | \$00 ⇒ A                                                                                                                                                                                                                                                                                         |
| Clear B              | \$00 ⇒ B                                                                                                                                                                                                                                                                                         |
| Clear D              | \$0000 ⇒ D                                                                                                                                                                                                                                                                                       |
| Clear E              | \$0000 ⇒ E                                                                                                                                                                                                                                                                                       |
| Clear Memory Word    | \$0000 ⇒ M : M + 1                                                                                                                                                                                                                                                                               |
| Ones Complement Byte | \$FF – (M) ⇒ M                                                                                                                                                                                                                                                                                   |
| Ones Complement A    | $FF - (A) \Rightarrow A$                                                                                                                                                                                                                                                                         |
| Ones Complement B    | $FF - (B) \Rightarrow B$                                                                                                                                                                                                                                                                         |
| Ones Complement D    | \$FFFF – (D) ⇒ D                                                                                                                                                                                                                                                                                 |
| Ones Complement E    | \$FFFF – (E) ⇒ E                                                                                                                                                                                                                                                                                 |
| Ones Complement Word | $FFFF - M : M + 1 \Longrightarrow M : M + 1$                                                                                                                                                                                                                                                     |
| Twos Complement Byte | \$00 – (M) ⇒ M                                                                                                                                                                                                                                                                                   |
| Twos Complement A    | $00 - (A) \Rightarrow A$                                                                                                                                                                                                                                                                         |
| Twos Complement B    | \$00 – (B) ⇒ B                                                                                                                                                                                                                                                                                   |
| Twos Complement D    | \$0000 – (D) ⇒ D                                                                                                                                                                                                                                                                                 |
| Twos Complement E    | \$0000 – (E) ⇒ E                                                                                                                                                                                                                                                                                 |
| Twos Complement Word | $\$0000 - (M:M+1) \Longrightarrow M:M+1$                                                                                                                                                                                                                                                         |
|                      | Clear A<br>Clear B<br>Clear D<br>Clear D<br>Clear E<br>Clear Memory Word<br>Ones Complement Byte<br>Ones Complement A<br>Ones Complement B<br>Ones Complement E<br>Ones Complement E<br>Ones Complement Byte<br>Twos Complement A<br>Twos Complement B<br>Twos Complement D<br>Twos Complement D |

Table 5-13. Clear, Complement and Negate Summary

## 5.6.2.7 Boolean Logic Instructions

Each of these instructions performs the Boolean logic operation represented by the mnemonic. There are 8- and 16-bit versions of each instruction.

There are special forms of logic instructions for stack pointer, program counter, index register, and address extension field manipulation. Refer to the appropriate summary for more information.

| Mnemonic | Function       | Operation                                   |
|----------|----------------|---------------------------------------------|
| ANDA     | AND A          | $(A) \bullet (M) \Rightarrow A$             |
| ANDB     | AND B          | $(B) \bullet (M) \Rightarrow B$             |
| ANDD     | AND D          | $(D) \bullet (M : M + 1) \Longrightarrow D$ |
| ANDE     | AND E          | $(E) \bullet (M : M + 1) \Longrightarrow E$ |
| EORA     | Exclusive OR A | $(A) \oplus (M) \Rightarrow A$              |
| EORB     | Exclusive OR B | $(B) \oplus (M) \Rightarrow B$              |
| EORD     | Exclusive OR D | $(D) \oplus (M : M + 1) \Longrightarrow D$  |
| EORE     | Exclusive OR E | $(E) \oplus (M:M+1) \Longrightarrow E$      |
| ORAA     | OR A           | $(A) + (M) \Rightarrow A$                   |
| ORAB     | OR B           | $(B) + (M) \Rightarrow B$                   |
| ORD      | OR D           | $(D) + (M : M + 1) \Rightarrow D$           |
| ORE      | ORE            | $(E) + (M : M + 1) \Rightarrow E$           |

Table 5–14. Boolean Logic Summary

## 5.6.3 Bit Test and Manipulation Instructions

These operations use a mask value to test or change the value of individual bits in an accumulator or in memory. BITA and BITB provide a convenient means of setting condition codes without altering the value of either operand.

Table 5-15. Bit Test and Manipulation Summary

| Mnemonic | Function          | Operation                                                 |
|----------|-------------------|-----------------------------------------------------------|
| BITA     | Bit Test A        | (A) • (M)                                                 |
| BITB     | Bit Test B        | (B) • (M)                                                 |
| BCLR     | Clear Bit(s)      | $(M) \bullet (\overline{Mask}) \Longrightarrow M$         |
| BCLRW    | Clear Bit(s) Word | $(M:M+1) \bullet (\overline{Mask}) \Longrightarrow M:M+1$ |
| BSET     | Set Bit(s)        | $(M) + (Mask) \Rightarrow M$                              |
| BSETW    | Set Bit(s) Word   | $(M:M+1) + (Mask) \Longrightarrow M:M+1$                  |

## 5.6.4 Shift and Rotate Instructions

There are shift and rotate commands for all accumulators, for memory bytes and for memory words. All shift and rotate operations pass the shifted-out bit through the carry bit in the CCR in order to facilitate multiple-byte and multiple-word operations. There are no separate logical left shift operations — use ASL instead. Motorola assemblers assemble LSL mnemonics as ASL operations.

| 105  |                        |        |
|------|------------------------|--------|
| LSR  | Logic Shift Right      |        |
|      |                        |        |
|      |                        | b7 b0  |
| LSRA | Logic Shift Right A    |        |
|      |                        | 0      |
|      |                        | b7 b0  |
| LSRB | Logic Shift Right B    |        |
|      |                        |        |
|      |                        | b7 b0  |
| LSRD | Logic Shift Right D    |        |
|      |                        |        |
|      |                        | b15 b0 |
| LSRE | Logic Shift Right E    |        |
|      |                        |        |
|      |                        | b15 b0 |
| LSRW | Logic Shift Right Word |        |
|      |                        |        |
|      |                        |        |
| LL   |                        |        |

Table 5-16. Logic Shift Summary

| Mnemonic       | Function                    | Operation |
|----------------|-----------------------------|-----------|
| ASL<br>(LSL)   | Arithmetic Shift Left       |           |
| ASLA<br>(LSLA) | Arithmetic Shift Left A     |           |
| ASLB<br>(LSLB) | Arithmetic Shift Left B     |           |
| ASLD<br>(LSLD) | Arithmetic Shift Left D     |           |
| ASLE<br>(LSLE) | Arithmetic Shift Left E     |           |
| ASLW<br>(LSLW) | Arithmetic Shift Left Word  |           |
| ASR            | Arithmetic Shift Right      |           |
| ASRA           | Arithmetic Shift Right A    |           |
| ASRB           | Arithmetic Shift Right B    |           |
| ASRD           | Arithmetic Shift Right D    |           |
| ASRE           | Arithmetic Shift Right E    |           |
| ASRW           | Arithmetic Shift Right Word |           |

Table 5-17. Arithmetic Shift Summary

|      |                   | • |
|------|-------------------|---|
| ROL  | Rotate Left       |   |
| ROLA | Rotate Left A     |   |
| ROLB | Rotate Left B     |   |
| ROLD | Rotate Left D     |   |
| ROLE | Rotate Left E     |   |
| ROLW | Rotate Left Word  |   |
| ROR  | Rotate Right      |   |
| RORA | Rotate Right A    |   |
| RORB | Rotate Right B    |   |
| RORD | Rotate Right D    |   |
| RORE | Rotate Right E    |   |
| RORW | Rotate Right Word |   |

MC68HC16Z1 USER'S MANUAL

## 5.6.5 Program Control Instructions

Program control instructions affect the sequence of instruction execution.

Branch instructions cause sequence to change when specific conditions exist. The CPU16 has short, long, and bit-condition branches.

Jump instructions cause immediate changes in sequence. The CPU16 has a true 20-bit address jump instruction.

Subroutine instructions optimize the process of temporarily transferring control to a segment of code that performs a particular task. The CPU16 can branch or jump to subroutines.

Interrupt instructions handle immediate transfer of control to a routine that performs a critical task. Software interrupts are a type of exception.

#### 5.6.5.1 Short Branch Instructions

Short branch instructions operate as follows. When a specified condition is met, a signed 8-bit offset is added to the value in the program counter. If addition causes the value in the PC to be greater than \$FFFF or less than \$0000, the PK extension field is incremented or decremented. Program execution continues at the new extended address.

Short branch instructions can be classified by the type of condition that must be satisfied in order for a branch to be taken. Some instructions belong to more than one classification.

Unary branch instructions always execute.

Simple branches are taken when a specific bit in the condition code register is in a specific state as a result of a previous operation.

Unsigned conditional branches are taken when comparison or test of unsigned quantities results in a specific combination of condition code register bits.

Signed branches are taken when comparison or test of signed quantities results in a specific combination of condition code register bits.

|          | Unary    | Branches        |           |
|----------|----------|-----------------|-----------|
| Mnemonic | Opcode   | Equation        | Condition |
| BRA      | BO       | 1 = 1           | True      |
| BRN      | B1       | 1 = 0           | False     |
|          | Simple   | Branches        |           |
| Mnemonic | Opcode   | Equation        | Condition |
| BCC      | B4       | C = 0           | Equation  |
| BCS      | B5       | C=1             | Equation  |
| BEQ      | B7       | Z=1             | Equation  |
| BMI      | BB       | N = 1           | Equation  |
| BNE      | B6       | Z=0             | Equation  |
| BPL      | BA       | N = 0           | Equation  |
| BVC      | B8       | V = 0           | Equation  |
| BVS      | B9       | V = 1           | Equation  |
|          | Unsigned | Branches        |           |
| Mnemonic | Opcode   | Equation        | Condition |
| BCC      | B4       | C = 0           | (X) ≥ (M) |
| BCS      | B5       | C = 1           | (X) < (M) |
| BEQ      | B7       | Z=1             | (X) = (M) |
| BHI      | B2       | C+Z=0           | (X) > (M) |
| BLS      | B3       | C+Z=1           | (X) ≤ (M) |
| BNE      | B6       | Z=0             | (X) ≠ (M) |
|          | Signed   | Branches        |           |
| Mnemonic | Opcode   | Equation        | Condition |
| BEQ      | B7       | Z=1             | (X) = (M) |
| BGE      | BC       | N ⊕ V = 0       | (X) ≥ (M) |
| BGT      | BE       | Z + (N ⊕ V) = 0 | (X) > (M) |
| BLE      | BF       | Z + (N ⊕ V) = 1 | (X) ≤ (M) |
| BLT      | BD       | N ⊕ V = 1       | (X) < (M) |
| BNE      | B6       | Z=0             | (X) ≠ (M) |

The numeric range of short branch offset values is \$80 (-128) to \$7F (127), but actual displacement from the instruction differs from the range for two reasons. First, PC values are automatically aligned to word boundaries. Only even offsets are valid — an odd offset value is rounded down. Maximum positive offset is \$7E. Second, instruction pipelining affects the value in the PC at the time an instruction executes. The value to which the offset is added is the address of the instruction plus \$0006. At maximum positive offset (\$7E), displacement from the branch instruction is 132. At maximum negative offset (\$80), displacement is -122.

## 5.6.5.2 Long Branch Instructions

Long branch instructions operate as follows. When a specified condition is met, a signed 16-bit offset is added to the value in the program counter. If addition causes the value in the PC to be greater than \$FFFF or less than \$0000, the PK extension field is incremented or decremented. Program execution continues at the new extended address.

Long branch instructions can be classified by the type of condition that must be satisfied in order for a branch to be taken. Some instructions belong to more than one classification.

Unary branch instructions always execute.

Simple branches are taken when a specific bit in the condition code register is in a specific state as a result of a previous operation.

Unsigned branches are taken when comparison or test of unsigned quantities results in a specific combination of condition code register bits.

Signed branches are taken when comparison or test of signed quantities results in a specific combination of condition code register bits.

|          | Unary E  | Branches               |           |
|----------|----------|------------------------|-----------|
| Mnemonic | Opcode   | Equation               | Condition |
| LBRA     | 3780     | 1 = 1                  | True      |
| LBRN     | 3781     | 1 = 0                  | False     |
|          |          | Branches               |           |
| Mnemonic | Opcode   | Equation               | Condition |
| LBCC     | 3784     | C=0                    | Equation  |
| LBCS     | 3785     | C=1                    | Equation  |
| LBEQ     | 3787     | Z=1                    | Equation  |
| LBEV     | 3791     | EV = 1                 | Equation  |
| LBMI     | 378B     | N = 1                  | Equation  |
| LBMV     | 3790     | MV = 1                 | Equation  |
| LBNE     | 3786     | Z=0                    | Equation  |
| LBPL     | 378A     | N = 0                  | Equation  |
| LBVC     | 3788     | V = 0                  | Equation  |
| LBVS     | 3789     | V = 1                  | Equation  |
|          | Unsigned | Branches               |           |
| Mnemonic | Opcode   | Equation               | Condition |
| LBCC     | 3784     | C = 0                  | (X) ≥ (M) |
| LBCS     | 3785     | C=1                    | (X) < (M) |
| LBEQ     | 3787     | Z=1                    | (X) = (M) |
| LBHI     | 3782     | C+Z=0                  | (X) > (M) |
| LBLS     | 3783     | C+Z=1                  | (X) ≤ (M) |
| LBNE     | 3786     | Z=0                    | (X) ≠ (M) |
|          | Signed   | Branches               |           |
| Mnemonic | Opcode   | Equation               | Condition |
| LBEQ     | 3787     | Z=1                    | (X) = (M) |
| LBGE     | 378C     | N⊕V=0                  | (X) ≥ (M) |
| LBGT     | 378E     | $Z + (N \oplus V) = 0$ | (X) > (M) |
| LBLE     | 378F     | Z + (N ⊕ V) = 1        | (X) ≤ (M) |
| LBLT     | 378D     | N ⊕ V = 1              | (X) < (M) |
| LBNE     | 3786     | Z=0                    | (X) ≠ (M) |

The numeric range of long branch offset values is \$8000 (-32768) to \$7FFF (32767), but actual displacement from the instruction differs from the range for two reasons. First, PC values are automatically aligned to word boundaries. Only even offsets are valid — an odd offset value will be rounded down. Maximum positive offset is \$7FFE. Second, instruction pipelining affects the value in the PC at the time an instruction executes. The value to which the offset is added is the address of the instruction plus \$0006. At maximum positive offset (\$7FFE), displacement from the instruction is 32772. At maximum negative offset (\$8000), displacement is -32762.

MOTOROLA 5–26

## 5.6.5.3 Bit Condition Branch Instructions

Bit condition branches are taken when specific bits in a memory byte are in a specific state. A mask operand is used to test a memory location pointed to by a 20-bit indexed or extended effective address. If the bits in memory match the mask, an 8- or 16-bit signed relative offset is added to the current value of the program counter. If addition causes the value in the PC to be greater than \$FFFF or less than \$0000, the PK extension field is incremented or decremented. Program execution continues at the new extended address.

| Mnemonic | Addressing Mode | Opcode     | Equation         |
|----------|-----------------|------------|------------------|
| BRCLR    | IND8, X         | СВ         | (M) • (Mask) = 0 |
|          | IND8, Y         | DB         |                  |
|          | IND8, Z         | EB         |                  |
|          | IND16, X        | ٥A         |                  |
|          | IND16, Y        | 1 <b>A</b> |                  |
|          | IND16, Z        | 2A         |                  |
|          | EXT             | ЗА         |                  |
| BRSET    | IND8, X         | 8B         | (M) • (Mask) = 0 |
|          | IND8, Y         | 9B         |                  |
|          | IND8, Z         | AB         |                  |
|          | IND16, X        | oВ         |                  |
|          | IND16, Y        | 1B         |                  |
|          | IND16, Z        | 2B         |                  |
|          | EXT             | 3B         |                  |

Table 5–21. Bit Condition Branch Summary

The numeric range of 8-bit offset values is \$80 (-128) to \$7F (127), and the numeric range of 16-bit offset values is \$8000 (-32768) to \$7FFF (32767), but actual displacement from the branch instruction differs from the range for two reasons. First, PC values are automatically aligned to word boundaries. Only even offsets are valid — an odd offset value is rounded down. Maximum positive 8-bit offset is \$7E; maximum positive 16-bit offset is \$7FFE. Second, instruction pipelining affects the value in the PC at the time an instruction executes. The value to which the offset is added is the address of the instruction plus \$0006. Maximum positive (\$7E) and negative (\$80) 8-bit offsets correspond to displacements of 132 and -122 from the branch instruction. Maximum positive (\$7FFE) and negative (\$8000) 16-bit offsets correspond to displacements of 32772 and -32762.

#### 5.6.5.4 Jump Instruction

The CPU16 JMP instruction uses 20-bit addressing, so that control can be passed to any address in the memory map. It should be noted that BRA and LBRA execute in fewer cycles than the indexed forms of JMP.

Table 5–22. Jump Summary

| Mnemonic | Function | Operation                            |
|----------|----------|--------------------------------------|
| JMP      | Jump     | 20-bit Address $\Rightarrow$ PK : PC |

#### 5.6.5.5 Subroutine Instructions

Subroutines can be called by short (BSR) or long (LBSR) branches, or by a jump (JSR). A single instruction, RTS, returns control to the calling routine.

All three types of calling instructions stack return PC and CCR values prior to transferring control to a subroutine. Stacking the CCR also saves the PK extension field. Other resources can be saved by means of the PSHM instruction, if necessary.

| Mnemonic | Function                  | Operation                                                                                                                                                                     |
|----------|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BSR      | Branch to Subroutine      | $(PK : PC) - 2 \Rightarrow PK : PC$ $Push (PC)$ $(SK : SP) - 2 \Rightarrow SK : SP$ $Push (CCR)$ $(SK : SP) - 2 \Rightarrow SK : SP$ $(PK : PC) + Offset \Rightarrow PK : PC$ |
| JSR      | Jump to Subroutine        | Push (PC)<br>(SK : SP) – 2 $\Rightarrow$ SK : SP<br>Push (CCR)<br>(SK : SP) – 2 $\Rightarrow$ SK : SP<br>20-bit Address $\Rightarrow$ PK : PC                                 |
| LBSR     | Long Branch to Subroutine | Push (PC)<br>(SK : SP) – 2 $\Rightarrow$ SK : SP<br>Push (CCR)<br>(SK : SP) – 2 $\Rightarrow$ SK : SP<br>(PK : PC) + Offset $\Rightarrow$ PK : PC                             |
| RTS      | Return from Subroutine    | $(SK : SP) + 2 \Rightarrow SK : SP$ Pull PK $(SK : SP) + 2 \Rightarrow SK : SP$ Pull PC $(PK : PC) - 2 \Rightarrow PK : PC$                                                   |

#### Table 5–23. Subroutine Summary

MOTOROLA 5–28 CENTRAL PROCESSING UNIT

Instruction pipelining affects the operation of BSR. When a subroutine is called, PK : PC contain the address of the calling instruction plus \$0006. LBSR and JSR stack this value, but BSR must adjust it prior to stacking. LBSR and JSR are 4-byte instructions. For program execution to resume at the instruction immediately following them, RTS must subtract \$0002 from the stacked PK : PC value. BSR is a 2-byte instruction. BSR subtracts \$0002 from the stacked value prior to stacking so that RTS will work correctly.

#### 5.6.5.6 Interrupt Instructions

The SWI instruction initiates synchronous exception processing. First, return PC and CCR values are stacked (stacking the CCR saves the PK extension field). After return values are stacked, the PK field is cleared, and the PC is loaded with exception vector 6 (content of address \$000C).

The RTI instruction is used to terminate all exception handlers, including interrupt service routines. It causes normal execution to resume with the instruction following the last instruction that executed prior to interrupt.

| Mnemonic | Function              | Operation                                                                                                                                                                             |
|----------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RTI      | Return from Interrupt | $(SK : SP) + 2 \Rightarrow SK : SP$ Pull CCR $(SK : SP) + 2 \Rightarrow SK : SP$ Pull PC $(PK : PC) - 6 \Rightarrow PK : PC$                                                          |
| SWI      | Software Interrupt    | $(PK : PC) + 2 \Rightarrow PK : PC$ $Push (PC)$ $(SK : SP) - 2 \Rightarrow SK : SP$ $Push (CCR)$ $(SK : SP) - 2 \Rightarrow SK : SP$ $\$0 \Rightarrow PK$ $SWI Vector \Rightarrow PC$ |

| Table | 5-24. | Interrupt | Summary |
|-------|-------|-----------|---------|
|-------|-------|-----------|---------|

Instruction pipelining affects the operation of SWI. When an interrupt occurs, PK : PC contain the address of the interrupted instruction plus \$0006. This value is stacked during asynchronous exception processing, but synchronous exceptions, such as SWI, must adjust the stacked value so that RTI can work correctly. For program execution to resume with the interrupted instruction following an asynchronous interrupt, RTI must subtract \$0006 from the stacked PK : PC value. Synchronous interrupts allow an interrupted instruction to finish execution before exception processing begins. The SWI instruction must add \$0002 prior to stacking in order for execution to resume correctly.

MC68HC16Z1 USER'S MANUAL CENTRAL PROCESSING UNIT

## 5.6.6 Indexing and Address Extension Instructions

The CPU16 has a complete set of instructions that enable a user to take full advantage of 20-bit pseudolinear addressing. These instructions use specialized forms of mathematic and data transfer instructions to perform index register manipulation and extension field manipulation.

## 5.6.6.1 Indexing Instructions

Indexing instructions perform 8- and 16-bit operations on the three index registers and accumulators, other registers, or memory. Index addition and transfer instructions also affect the associated extension field.

| Addition Instructions |                           |                                             |  |
|-----------------------|---------------------------|---------------------------------------------|--|
| Mnemonic              | Function                  | Operation                                   |  |
| ABX                   | Add B to IX               | $(XK : IX) + (000 : B) \Rightarrow XK : IX$ |  |
| ABY                   | Add B to IY               | $(YK : IY) + (000 : B) \Rightarrow YK : IY$ |  |
| ABZ                   | Add B to IZ               | (ZK : Z) + (000 : B) ⇒ ZK : IZ              |  |
| ADX                   | Add D to IX               | $(XK : IX) + ( * D) \Rightarrow XK : IX$    |  |
| ADY                   | Add D to IY               | $(YK : IY) + ( * D) \Rightarrow YK : IY$    |  |
| ADZ                   | Add D to IZ               | $(ZK:IZ) + (*D) \Rightarrow ZK:IZ$          |  |
| AEX                   | Add E to IX               | $(XK : IX) + (*D) \Rightarrow XK : IX$      |  |
| AEY                   | Add E to IY               | $(YK : IY) + ( * E) \Rightarrow YK : IY$    |  |
| AEZ                   | Add E to IZ               | $(ZK:IZ) + (*E) \Rightarrow ZK:IZ$          |  |
| AIX                   | Add Immediate Value to IX | XK : IX + ( « IMM8/16) ⇒ XK : IX            |  |
| AIY                   | Add Immediate Value to IY | YK : IY + ( « IMM8/16) ⇒ YK : IY            |  |
| AIZ                   | Add Immediate Value to IZ | ZK : IZ + ( « IMM8/16) ⇒ ZK : IZ            |  |
|                       | Compare Instruct          | lons                                        |  |
| Mnemonic              | Function                  | Operation                                   |  |
| CPX                   | Compare IX to Memory      | (IX) - (M : M + 1)                          |  |
| CPY                   | Compare IY to Memory      | (IY) – (M : M + 1)                          |  |
| CPZ                   | Compare IZ to Memory      | (IZ) – (M : M + 1)                          |  |
|                       | Load Instruction          | ns                                          |  |
| Mnemonic              | Function                  | Operation                                   |  |
| LDX                   | Load IX                   | $(M:M+1)\RightarrowIX$                      |  |
| LDY                   | Load IY                   | $(M:M+1)\RightarrowIY$                      |  |
| LDZ                   | Load IZ                   | $(M:M+1)\RightarrowIZ$                      |  |

Table 5-25. Indexing Summary

| Store Instructions |                    |                                     |  |
|--------------------|--------------------|-------------------------------------|--|
| Mnemonic           | Function           | Operation                           |  |
| STX                | Store IX           | $(IX) \Rightarrow M : M + 1$        |  |
| STY                | Store IY           | (IY) ⇒ M : M + 1                    |  |
| STZ                | Store IZ           | (IZ) ⇒ M : M + 1                    |  |
|                    | Transfer Instruct  | lons                                |  |
| Mnemonic           | Function           | Operation                           |  |
| TSX                | Transfer SP to IX  | $(SK : SP) + 2 \Rightarrow XK : IX$ |  |
| TSY                | Transfer SP to IY  | (SK : SP) + 2 ⇒ YK : IY             |  |
| TSZ                | Transfer SP to IZ  | $(SK : SP) + 2 \Rightarrow ZK : IZ$ |  |
| TXS                | Transfer IX to SP  | $(XK : IX) - 2 \Rightarrow SK : SP$ |  |
| TXY                | Transfer IX to IY  | $(XK:IX)\RightarrowYK:IY$           |  |
| TXZ                | Transfer IX to IZ  | $(XK : IX) \Rightarrow ZK : IZ$     |  |
| TYS                | Transfer IY to SP  | (YK : IY) – 2 ⇒ SK : SP             |  |
| TYX                | Transfer IY to IX  | $(YK : IY) \Rightarrow XK : IX$     |  |
| TYZ                | Transfer IY to IZ  | $(YK : IY) \Rightarrow ZK : IZ$     |  |
| TZS                | Transfer IZ to SP  | $(ZK : IZ) - 2 \Rightarrow SK : SP$ |  |
| TZX                | Transfer IZ to IX  | $(ZK : IZ) \Rightarrow XK : IX$     |  |
| TZY                | Transfer IZ to IY  | $(ZK : IZ) \Rightarrow ZK : IY$     |  |
|                    | Exchange Instruc   | tions                               |  |
| Mnemonic           | Function           | Operation                           |  |
| XGDX               | Exchange D with IX | $(D) \Leftrightarrow (IX)$          |  |
| XGDY               | Exchange D with IY | (D) ⇔ (IY)                          |  |
| XGDZ               | Exchange D with IZ | (D) ⇔ (IZ)                          |  |
| XGEX               | Exchange E with IX | (E) ⇔ (IX)                          |  |
| XGEY               | Exchange E with IY | (E) ⇔ (IY)                          |  |
| XGEZ               | Exchange E with IZ | (E) ⇔ (IZ)                          |  |

# Table 5-25. Indexing Summary (Continued)

### 5.6.6.2 Address Extension Instructions

Address extension instructions transfer extension field contents to or from accumulator B. Other types of operations can be performed on the extension field value while it is in the accumulator.

| Mnemonic | Function         | Operation                                          |
|----------|------------------|----------------------------------------------------|
| TBEK     | Transfer B to EK | (B) ⇒ EK                                           |
| TBSK     | Transfer B to SK | (B) ⇒ SK                                           |
| ТВХК     | Transfer B to XK | (B) ⇒ XK                                           |
| ТВҮК     | Transfer B to YK | (B) ⇒ YK                                           |
| TBZK     | Transfer B to ZK | (B) ⇒ ZK                                           |
| ТЕКВ     | Transfer EK to B | \$0 ⇒ B[7:4]<br>(EK) ⇒ B[3:0]                      |
| TSKB     | Transfer SK to B | (SK) ⇒ B[3:0]<br>\$0 ⇒ B[7:4]                      |
| ТХКВ     | Transfer XK to B | $  0 \Rightarrow B[7:4]  (XK) \Rightarrow B[3:0] $ |
| ТҮКВ     | Transfer YK to B | \$0 ⇒ B[7:4]<br>(YK) ⇒ B[3:0]                      |
| ТΖКВ     | Transfer ZK to B | \$0 ⇒ B[7:4]<br>(ZK) ⇒ B[3:0]                      |

## Table 5–26. Address Extension Summary

## 5.6.7 Stacking Instructions

There are two types of stacking instructions. Stack pointer instructions use specialized forms of mathematic and data transfer instructions to perform stack pointer manipulation. Stack operation instructions save information on and retrieve information from the system stack.

|          | Stack Pointer Instru                                                                                                  | ictions                                                                                |
|----------|-----------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|
| Mnemonic | Function                                                                                                              | Operation                                                                              |
| AIS      | Add Immediate Data to SP                                                                                              | SK : SP + ( « IMM16) ⇒ SK : SP                                                         |
| CPS      | Compare SP to Memory                                                                                                  | (SP) – (M : M + 1)                                                                     |
| LDS      | Load SP                                                                                                               | $(M: M+1) \Rightarrow SP$                                                              |
| STS      | Store SP                                                                                                              | $(SP) \Rightarrow M : M + 1$                                                           |
| TSX      | Transfer SP to IX                                                                                                     | $(SK : SP) + 2 \Rightarrow XK : IX$                                                    |
| TSY      | Transfer SP to IY                                                                                                     | $(SK : SP) + 2 \Rightarrow YK : IY$                                                    |
| TSZ      | Transfer SP to IZ                                                                                                     | $(SK : SP) + 2 \Rightarrow ZK : IZ$                                                    |
| TXS      | Transfer IX to SP                                                                                                     | $(XK : IX) - 2 \Rightarrow SK : SP$                                                    |
| TYS      | Transfer IY to SP                                                                                                     | $(YK : IY) - 2 \Rightarrow SK : SP$                                                    |
| TZS      | Transfer IZ to SP                                                                                                     | $(ZK : IZ) - 2 \Rightarrow SK : SP$                                                    |
|          | Stack Operation Instr                                                                                                 | uctions                                                                                |
| Mnemonic | Function                                                                                                              | Operation                                                                              |
| PSHA     | Push A                                                                                                                | $(SK : SP) + 1 \Rightarrow SK : SP$<br>Push (A)<br>$(SK : SP) - 2 \Rightarrow SK : SP$ |
| PSHB     | Push B                                                                                                                | (SK : SP) + 1 ⇒ SK : SP<br>Push (B)<br>(SK : SP) – 2 ⇒ SK : SP                         |
| PSHM     | Push Multiple Registers<br>Mask bits:<br>0 = D 1 = E<br>2 = IX 3 = IY<br>4 = IZ 5 = K<br>6 = CCR 7 = (reserved)       | For mask bits 0 to 6 :<br>If mask bit set<br>Push register<br>(SK:SP) – 2 ⇒ SK : SP    |
| PULA     |                                                                                                                       | (SK : SP) + 2 ⇒ SK : SP<br>Pull (A)<br>(SK : SP) – 1 ⇒ SK : SP                         |
| PULB     | Pull B                                                                                                                | (SK : SP) + 2 ⇒ SK : SP<br>Pull (B)<br>(SK : SP) – 1 ⇒ SK : SP                         |
| PULM     | Pull Multiple RegistersMask bits: $0 = CCR[15:4]$ $1 = K$ $2 = IZ$ $3 = IY$ $4 = IX$ $5 = E$ $6 = D$ $7 = (reserved)$ | For mask bits 0 to 7:<br>If mask bit set<br>(SK:SP) + 2 ⇒ SK : SP<br>Pull register     |

# Table 5–27. Stacking Summary

### 5.6.8 Condition Code Instructions

Condition code instructions use specialized forms of mathematic and data transfer instructions to perform condition code register manipulation. Interrupts are not acknowledged until the instruction following ANDP, ORP, TAP, and TDP has executed. Refer to **5.6.10 Stop and Wait Instructions** for more information.

| Mnemonic | Function              | Operation                                 |
|----------|-----------------------|-------------------------------------------|
| ANDP     | AND CCR               | $(CCR) \cdot IMM16 \Rightarrow CCR[15:4]$ |
| ORP      | ORCCR                 | $(CCR) + IMM16 \Rightarrow CCR[15:4]$     |
| ТАР      | Transfer A to CCR     | (A[7:0]) ⇒ CCR[15:8]                      |
| TDP      | Transfer D to CCR     | (D) ⇒ CCR[15:4]                           |
| TPA      | Transfer CCR MSB to A | (CCR[15:8]) ⇒ A                           |
| TPD      | Transfer CCR to D     | (CCR) ⇒D                                  |

 Table 5–28. Condition Code Summary

## 5.6.9 Digital Signal Processing Instructions

DSP instructions use the CPU16 multiply and accumulate unit to implement digital filters and other signal processing functions. Other instructions, notably those that operate on concatenated E and D accumulators, are also used for signal processing.

| Mnemonic | Function                       | Operation                                                                                                                     |
|----------|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| ACE      | Add E to AM[31:15]             | (AM[31:15]) + (E) ⇒ AM                                                                                                        |
| ACED     | Add concatenated E and D to AM | $(E:D)+(AM)\RightarrowAM$                                                                                                     |
| ASLM     | Arithmetic Shift Left AM       |                                                                                                                               |
| ASRM     | Arithmetic Shift Right AM      |                                                                                                                               |
| CLRM     | Clear AM                       | \$00000000 ⇒ AM[35:0]                                                                                                         |
| LDHI     | Initialize HR and IR           | $(\mathbf{M}:\mathbf{M}+1)_{\mathbf{X}}\Rightarrow\mathbf{HR}$ $(\mathbf{M}:\mathbf{M}+1)_{\mathbf{Y}}\Rightarrow\mathbf{IR}$ |

 Table 5–29.
 DSP
 Summary

| MAC    | Multiply and Accumulate<br>Signed 16-Bit Fractions              | $(HR) * (IR) \Rightarrow E : D$ $(AM) + (E : D) \Rightarrow AM$ Qualified (IX) $\Rightarrow$ IX<br>Qualified (IY) $\Rightarrow$ IY<br>$(HR) \Rightarrow IZ$ $(M : M + 1)\chi \Rightarrow HR$ $(M : M + 1)\gamma \Rightarrow IR$ |
|--------|-----------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PSHMAC | Push MAC State                                                  | MAC Registers ⇒ Stack                                                                                                                                                                                                           |
| PULMAC | Pull MAC State                                                  | Stack $\Rightarrow$ MAC Registers                                                                                                                                                                                               |
| RMAC   | Repeating<br>Multiply and Accumulate<br>Signed 16-Bit Fractions | Repeat until (E) < 0<br>(AM) + (H) * (I) $\Rightarrow$ AM<br>Qualified (IX) $\Rightarrow$ IX;<br>Qualified (IY) $\Rightarrow$ IY;<br>(M : M + 1)X $\Rightarrow$ H;<br>(M : M + 1)Y $\Rightarrow$ I<br>(E) - 1 $\Rightarrow$ E   |
| TDMSK  | Transfer D to XMSK : YMSK                                       | (D[15:8]) ⇒ XMSK<br>(D[7:0]) ⇒ YMSK                                                                                                                                                                                             |
| TEDM   | Transfer E and D to AM[31:0]<br>Sign Extend AM                  | (D) ⇒ AM[15:0]<br>(E) ⇒ AM[31:16]<br>AM[32:35] = AM31                                                                                                                                                                           |
| TEM    | Transfer E to AM[31:16]<br>Sign Extend AM<br>Clear AM LSB       | (E) ⇒ AM[31:16]<br>\$00 ⇒ AM[15:0]<br>AM[32:35] = AM31                                                                                                                                                                          |
| TMER   | Transfer AM to E Rounded                                        | Rounded (AM) $\Rightarrow$ Temp<br>If (SM • (EV + MV))<br>then Saturation $\Rightarrow$ E<br>else Temp[31:16] $\Rightarrow$ E                                                                                                   |
| TMET   | Transfer AM to E Truncated                                      | If (SM • (EV + MV))<br>then Saturation ⇒ E<br>else AM[31:16] ⇒ E                                                                                                                                                                |
| TMXED  | Transfer AM to IX : E : D                                       | $\begin{array}{c} AM[35:32] \Rightarrow IX[3:0]\\ AM35 \Rightarrow IX[15:4]\\ AM[31:16] \Rightarrow E\\ AM[15:0] \Rightarrow D \end{array}$                                                                                     |

### 5.6.10 Stop and Wait Instructions

There are two instructions that put the CPU16 in an inactive state. Both require that either an interrupt or a reset exception occurs before normal execution of instructions resumes. However, each operates differently.

LPSTOP minimizes microcontroller power consumption. The CPU16 initiates a stop, but it and other controller modules are deactivated by the MCU system integration module (SIM). Reactivation is also handled by the SIM. The interrupt priority field from the CPU16 condition code register is copied into SIM control logic, then the system clock to the processor is stopped. When a reset or an interrupt of higher priority than the IP value occurs, the SIM activates the CPU16, and the appropriate exception processing sequence begins (refer to **SECTION 4 SYSTEM INTEGRATION MODULE** for more information).

WAI idles the CPU16, but does not affect operation of other MCU modules. The IP field is not copied to the SIM. System clocks continue to run. The processor waits until a reset or an interrupt of higher priority than the IP value occurs, then begins the appropriate exception processing sequence.

Because the system integration module does not restart the CPU16, interrupts are acknowledged more quickly following WAI than following LPSTOP.

To make certain that conditions for termination of LPSTOP and WAI are correct, interrupts are not recognized until after the instruction following ANDP, ORP, TAP, and TDP executes. This prevents interrupt exception processing during the period after the mask changes but before the following instruction executes. Refer to **5.12 Exceptions** and **SECTION 4 SYSTEM INTEGRATION MODULE** for more information concerning exceptions and interrupt exception processing.

|          | •                  | •                             |
|----------|--------------------|-------------------------------|
| Mnemonic | Function           | Operation                     |
| LPSTOP   | Low Power Stop     | If S<br>then STOP<br>else NOP |
| WAI      | Wait for Interrupt | WAIT                          |

| Table | 5–30. | Stop | and | Wait | Summary |
|-------|-------|------|-----|------|---------|
|-------|-------|------|-----|------|---------|

## 5.6.11 Background Mode and Null Operations

Background debugging mode (BDM) is a special CPU16 operating mode that is used for system development. Executing BGND when BDM is enabled puts the CPU16 in this mode. The logic state of certain SIM pins during system reset affects BDM operation. Refer to **SECTION 4 SYSTEM INTEGRATION MODULE** for more information.

Null operations are often used to replace other instructions during software debugging. Replacing conditional branch instructions with BRN, for instance, permits testing a decision-making routine without actually taking the branches.

| BGND | Enter Background Debug Mode | If BDM enabled<br>enter BDM;<br>else, illegal instruction |
|------|-----------------------------|-----------------------------------------------------------|
| BRN  | Branch Never                | If $1 = 0$ , branch                                       |
| LBRN | Long Branch Never           | If 1 = 0, branch                                          |
| NOP  | Null operation              | _                                                         |

## Table 5-31. Background Mode and Null Operations

### 5.6.12 Instruction Set Summary

The following summary is a quick reference to the entire CPU16 instruction set. Refer to the *CPU16 Reference Manual* (CPU16RM/AD) for detailed information on each instruction, assembler syntax, and condition code evaluation. A key to table nomenclature is provided on the last page of the table.

|          | Instruction Set Summary           |                                                |                                                                                                   |                                                                                        |                                                     |                                                     | Condition Codes |   |     |     |       |   |   |   |   |  |
|----------|-----------------------------------|------------------------------------------------|---------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|-----------------------------------------------------|-----------------------------------------------------|-----------------|---|-----|-----|-------|---|---|---|---|--|
| Mnemonic | Operation                         | Description                                    | Address                                                                                           |                                                                                        | Instruction                                         |                                                     |                 |   |     |     |       |   |   |   | - |  |
|          |                                   |                                                | Mode                                                                                              | Opcode                                                                                 | Operand                                             | Cycles                                              | S               | M | V H | E   | V     | N | Z | ۷ | C |  |
| ABA      | Add B to A                        | $(A) + (B) \Rightarrow A$                      | INH                                                                                               | 370B                                                                                   | -                                                   | 2                                                   | -               |   | - 4 | _   | -     | Δ | Δ | Δ | Δ |  |
| ABX      | Add B to X                        | (XK : IX) + (000 : B) ⇒ XK :<br>IX             | INH                                                                                               | 374F                                                                                   | -                                                   | 2                                                   | -               |   |     |     | -   - | _ |   |   | - |  |
| ABY      | Add B to Y                        | (YK : IY) + (000 : B) ⇒ YK :<br>IY             | INH                                                                                               | 375F                                                                                   | -                                                   | 2                                                   | =               |   |     |     |       |   |   |   | - |  |
| ABZ      | Add B to Z                        | $(ZK : IZ) + (000 : B) \Rightarrow ZK :$<br>IZ | INH                                                                                               | 376F                                                                                   | -                                                   | 2                                                   | -               |   |     |     |       | - |   | - | - |  |
| ACE      | Add E to AM[31:15]                | (AM[31:15]) + (E) ⇒ AM                         | INH                                                                                               | 3722                                                                                   |                                                     | 2                                                   | -               | Δ |     | - 4 | - 1   |   |   | — |   |  |
| ACED     | Add concatenated<br>E and D to AM | $(E:D) + (AM) \Rightarrow AM$                  | INH                                                                                               | 3723                                                                                   | -                                                   | 4                                                   | -               | Δ |     | - 4 | •   - |   |   | - |   |  |
| ADCA     | Add with Carry to A               | (A) + (M) + C ⇒ A                              | IND8, X<br>IND8, Y<br>IND8, Z<br>IMM8<br>IND16, X<br>IND16, Y<br>IND16, Z<br>E, X<br>E, Y<br>E, Z | 43<br>53<br>63<br>1743<br>1753<br>1763<br>1763<br>1773<br>2743<br>2753<br>2763         | ff<br>ff<br>9999<br>9999<br>9999<br>hh li<br>—      | 6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6 | -               |   | - Δ |     | -     | Δ | Δ | Δ | Δ |  |
| ADCB     | Add with Carry to B               | (B) + (M) + C ⇒ B                              | IND8, X<br>IND8, Y<br>IND8, Z<br>IMM8<br>E, X<br>E, Y<br>E, Z<br>IND16, X<br>IND16, Z<br>EXT      | C3<br>D3<br>E3<br>F3<br>27C3<br>27D3<br>27E3<br>17C3<br>17D3<br>17E3<br>17F3           | ff<br>ff<br>ii<br><br>9999<br>9999<br>hh ll         | 6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6      |                 |   | - Δ |     | -     | Δ | Δ | Δ | Δ |  |
| ADCD     | Add with Carry to D               | (D) + (M : M + 1) + C ⇒ D                      | IND8, X<br>IND8, Y<br>IND8, Z<br>E, Y<br>E, Z<br>IMM16<br>IND16, X<br>IND16, Z<br>EXT             | 83<br>93<br>A3<br>2783<br>2793<br>27A3<br>37B3<br>37C3<br>37C3<br>37C3<br>37C3<br>37F3 | ff<br>ff<br>jj kk<br>9999<br>9999<br>hh ll          | 6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6           |                 |   |     |     | -     | Δ | Δ | Δ | Δ |  |
| ADCE     | Add with Carry to E               | (E) + (M : M + 1) + C ⇒ E                      | IMM16<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                                                  | 3733<br>3743<br>3753<br>3763<br>3773                                                   | jj kk<br>9999<br>9999<br>9999<br>9999<br>hh ll      | 4<br>6<br>6<br>6                                    | -               |   | •   |     | -     | Δ | Δ | Δ | Δ |  |
| ADDA     | Add to A                          | (A) + (M) ⇒ A                                  | IND8, X<br>IND8, Y<br>IND8, Z<br>IMM8<br>E, X<br>E, Y<br>E, Z<br>IND16, X<br>IND16, Z<br>EXT      | 41<br>51<br>61<br>2741<br>2751<br>2761<br>1741<br>1751<br>1761<br>1771                 | ff<br>ff<br>ii<br><br>9999<br>9999<br>9999<br>hh ll | 6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6      |                 |   | - Δ |     | -     | Δ | Δ | Δ | Δ |  |

Instruction Set Summary

|          | <b>.</b>                    |                                                                             |                      | Summary (Continued) |               |             |   | Condition Codes |   |    |   |   |   |   |  |
|----------|-----------------------------|-----------------------------------------------------------------------------|----------------------|---------------------|---------------|-------------|---|-----------------|---|----|---|---|---|---|--|
| Mnemonic | Operation                   | Description                                                                 | Address              | <u> </u>            | Instruction   |             |   |                 | _ |    | _ |   |   | _ |  |
| 1000     |                             |                                                                             | Mode                 | Opcode              | Operand       | Cycles      | S | M               | _ | EV | N | Z | V | C |  |
| ADDB     | Add to B                    | $(B) + (M) \Rightarrow B$                                                   | IND8, X<br>IND8, Y   | C1<br>D1            | ii<br>ff      | 6<br>6      |   | _               | Δ | _  | Δ | Δ | Δ | Δ |  |
|          |                             |                                                                             | IND8, Z              | Ē1<br>F1            | ff            | 6           |   |                 |   |    |   |   |   |   |  |
|          |                             |                                                                             |                      | 27C1                | ff            | 2           |   |                 |   |    |   |   |   |   |  |
|          |                             |                                                                             | E, X<br>E, Y         | 27D1                | _             | 6           |   |                 |   |    |   |   |   |   |  |
|          |                             |                                                                             | E, Z                 | 27E1<br>17C1        | _             | 6           |   |                 |   |    |   |   |   |   |  |
|          |                             |                                                                             | IND16, X<br>IND16, Y | 17D1                | 9999<br>9999  | 6<br>6      |   |                 |   |    |   |   |   |   |  |
|          |                             |                                                                             | IND16, Z             | 17E1                | 9999<br>hh li | 6           |   |                 |   |    |   |   |   |   |  |
| ADDD     | Add to D                    |                                                                             | EXT                  | 17F1                |               | 6           |   |                 |   |    |   |   |   |   |  |
| ADDD     | Add to D                    | $(D) + (M : M + 1) \Longrightarrow D$                                       | IND8, X<br>IND8, Y   | 81<br>91            | jjkk<br>ff    | 6<br>6      | _ |                 |   |    | Δ | Δ | Δ | Δ |  |
|          |                             |                                                                             | IND8, Z              | A1<br>FC            | ff            | 6           |   |                 |   |    |   |   |   |   |  |
|          |                             |                                                                             | IMM8<br>FX           | 2781                | ff            | 2<br>6      |   |                 |   |    |   |   |   |   |  |
|          |                             |                                                                             | E, X<br>E, Y<br>E, Z | 2791                | _             | ő           |   |                 |   |    |   |   |   |   |  |
|          |                             |                                                                             | E,Z<br>IMM16         | 27A1<br>37B1        | ii -          | 6<br>6<br>4 |   |                 |   |    |   |   |   |   |  |
|          |                             |                                                                             | IND16. X             | 37C1                | 9999          | 6           |   |                 |   |    |   |   |   |   |  |
|          |                             |                                                                             | IND16, X<br>IND16, Y | 37D1                | 9999          | 6           |   |                 |   |    |   |   |   |   |  |
|          |                             |                                                                             | IND16, Z<br>EXT      | 37E1<br>37F1        | 9999<br>hh ii | 6<br>6      |   |                 |   |    |   |   |   |   |  |
| ADDE     | Add to E                    | (E) + (M : M + 1) ⇒ E                                                       | IMM8                 | 7C                  | ii.           | 2           |   | -               |   |    | Δ | Δ | Δ | Δ |  |
|          |                             |                                                                             | IMM16                | 3731<br>3741        | jj kk<br>9999 | 4<br>6      |   |                 |   |    |   |   |   |   |  |
|          |                             |                                                                             | IND16, X<br>IND16, Y | 3751                | 9999          | 6<br>6      |   |                 |   |    |   |   |   |   |  |
|          |                             |                                                                             | IND16, Z<br>EXT      | 3761<br>3771        | 9999<br>hh li | 6<br>6      |   |                 |   |    |   |   |   |   |  |
| ADE      | Add D to E                  | (E) + (D) ⇒ E                                                               | INH                  | 2778                |               | 2           | _ |                 |   |    | Δ | Δ | Δ | Δ |  |
| ADX      | Add D to X                  | $(XK : IX) + (*D) \Rightarrow XK : IX$                                      | INH                  | 37CD                | -             | 2           |   | _               |   | _  | - | _ |   | - |  |
| ADY      | Add D to Y                  | $(YK : IY) + (*D) \Rightarrow YK : IY$                                      | INH                  | 37DD                | -             | 2           | - | _               | _ | -  | - |   | - | - |  |
| ADZ      | Add D to Z                  | (ZK : IZ) + («D) ⇒ ZK : IZ                                                  | INH                  | 37ED                | -             | 2           | 1 |                 |   |    | - | - | - |   |  |
| AEX      | Add E to X                  | $(XK : IX) + (*E) \Rightarrow XK : IX$                                      | INH                  | 374D                |               | 2           |   |                 |   | _  |   |   |   |   |  |
| AEY      | Add E to Y                  | $(YK : IY) + (*E) \Rightarrow YK : IY$                                      | INH                  | 375D                |               | 2           | _ |                 |   |    | - |   | - |   |  |
| AEZ      | Add E to Z                  | $(ZK : IZ) + (*E) \Rightarrow ZK : IZ$<br>SK : SP + *IMM $\Rightarrow$ SK : | INH                  | 376D<br>3F          | <br>ii        | 2           | - |                 |   |    |   | - |   | _ |  |
|          | Add Immediate Data<br>to SP | SP                                                                          | IMM8<br>IMM16        | 373F                | jj kk         | 4           | _ |                 |   |    | _ | _ | _ |   |  |
| AIX      | Add Immediate<br>Value to X | XK : IX + «IMM ⇒ XK : IX                                                    | IMM8<br>IMM16        | 3C<br>373C          | ii<br>jjkk    | 2<br>4      | - | _               | - | _  | - | Δ |   |   |  |
| AIY      | Add Immediate<br>Value to Y | YK : IY + «IMM ⇒ YK : IY                                                    | IMM8<br>IMM16        | 3D<br>373D          | ii<br>jjkk    | 2<br>4      | - | -               | _ | _  | - | Δ | - | ~ |  |
| AIZ      | Add Immediate<br>Value to Z | ZK : IZ + «IMM ⇒ ZK : IZ                                                    | IMM8<br>IMM16        | 3E<br>373E          | ii<br>jjkk    | 2<br>4      |   |                 |   | -  | - | Δ |   | - |  |
| ANDA     | AND A                       | (A) • (M) ⇒ A                                                               | IND8, X<br>IND8, Y   | 46                  | ff<br>#       | 6           | - | _               | _ |    | Δ | Δ | 0 |   |  |
|          |                             |                                                                             | IND8, Y<br>IND8, Z   | 56<br>66            | ff<br>ff      | 6<br>6      |   |                 |   |    |   |   |   |   |  |
|          |                             |                                                                             | IMM8                 | 76                  | ü             | 2           |   |                 |   |    |   |   |   |   |  |
|          |                             |                                                                             | IND16, X<br>IND16, Y | 1746<br>1756        | 9999          | 6<br>6      |   |                 |   |    |   |   |   |   |  |
|          |                             |                                                                             | IND16.Z              | 1766                | 9999<br>9999  | 6           |   |                 |   |    |   |   |   |   |  |
|          |                             |                                                                             | EXT                  | 1776                | 9999<br>hh il | 6           |   |                 |   |    |   |   |   |   |  |
|          |                             |                                                                             | E, X<br>E, Y         | 2746<br>2756        | =             | 6<br>6      |   |                 |   |    |   |   |   |   |  |
|          |                             |                                                                             | E, Z                 | 2766                | _             | 6           |   |                 |   |    |   |   |   |   |  |
| ANDB     | AND B                       | (B) • (M) ⇒ B                                                               | IND8, X<br>IND8, Y   | C6<br>D6            | ff<br>ff      | 6<br>6      | - | _               | _ |    | Δ | Δ | 0 | - |  |
|          |                             |                                                                             | IND8. Z              | E6                  | ff            |             |   |                 |   |    |   |   |   |   |  |
|          |                             |                                                                             | IMM8                 | F6                  | ii I          | 6<br>2<br>6 |   |                 |   |    |   |   |   |   |  |
|          |                             |                                                                             | IND16, X<br>IND16, Y | 17C6<br>17D6        | 9999<br>9999  | 6<br>6      |   |                 |   |    |   |   |   |   |  |
|          |                             |                                                                             | IND16, Z             | 17E6                | 9999<br>hh ii | 6           |   |                 |   |    |   |   |   |   |  |
|          |                             |                                                                             | EXT                  | 17F6<br>27C6        | hh ll         | 6<br>6      |   |                 |   |    |   |   |   |   |  |
|          |                             |                                                                             | E, X<br>E, Y         | 27D6                | =             | 6           |   |                 |   |    |   |   |   |   |  |
|          |                             |                                                                             | Ē, Ż                 | 27E6                | -             | 6           |   |                 |   |    |   |   |   |   |  |

|                   |                                | Instruction Se             |                                                                                       | ary (Co                                                                                          |                                                                         |                                                                    | <b></b> |    |   |              |      |   |   |   |
|-------------------|--------------------------------|----------------------------|---------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|--------------------------------------------------------------------|---------|----|---|--------------|------|---|---|---|
| Mnemonic          | Operation                      | Description                | Address<br>Mode                                                                       | Oncede                                                                                           | Instruction<br>Operand                                                  |                                                                    | S       | MV |   | ditio        | N Co |   | V | С |
| ANDD              | AND D                          | (D) • (M : M + 1) ⇒ D      | IND8, X<br>IND8, Y<br>IND8, Z<br>E, X<br>E, Z<br>IMM16<br>IND16, X<br>IND16, Z<br>EXT | Opcode<br>86<br>96<br>46<br>2786<br>2786<br>2786<br>3786<br>3786<br>37C6<br>37D6<br>37F6<br>37F6 | 09999<br>ff<br>ff<br><br>jj kk<br>9999<br>9999<br>9999<br>9999<br>hh ll | Cycles<br>6<br>6<br>6<br>6<br>6<br>6<br>4<br>6<br>6<br>6<br>6<br>6 | -       |    |   |              | Δ    | Δ | 0 |   |
| ANDE              | AND E                          | (E) • (M : M + 1) ⇒ E      | IMM16<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                                      | 3736<br>3746<br>3756<br>3766<br>3776                                                             | jj kk<br>9999<br>9999<br>9999<br>9999<br>hh ll                          | 4<br>6<br>6<br>6                                                   | -       | _  |   |              | Δ    | Δ | 0 | - |
| ANDP <sup>1</sup> | AND CCR                        | (CCR) • IMM16⇒ CCR         | IMM16                                                                                 | 373A                                                                                             | jj kk                                                                   | 4                                                                  | Δ       | Δ  | Δ | Δ            | Δ    | Δ | Δ | L |
| ASL               | Arithmetic Shift Left          | €+                         | IND8, X<br>IND8, Y<br>IND8, Z<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT              | 04<br>14<br>24<br>1704<br>1714<br>1724<br>1734                                                   | ff<br>ff<br>9999<br>9999<br>9999<br>6999<br>hh II                       | 8<br>8<br>8<br>8<br>8<br>8<br>8                                    |         |    | _ |              | Δ    | Δ | Δ | 2 |
| ASLA              | Arithmetic Shift Left<br>A     |                            | INH                                                                                   | 3704                                                                                             |                                                                         | 2                                                                  | -       |    |   | <del>-</del> | Δ    | Δ | Δ | 2 |
| ASLB              | Arithmetic Shift Left<br>B     |                            | INH                                                                                   | 3714                                                                                             | -                                                                       | 2                                                                  | -       |    |   |              | Δ    | Δ | Δ | 1 |
| ASLD              | Arithmetic Shift Left<br>D     |                            | INH                                                                                   | 27F4                                                                                             | -                                                                       | 2                                                                  |         |    | _ | -            | Δ    | Δ | Δ |   |
| ASLE              | Arithmetic Shift Left<br>E     |                            | INH                                                                                   | 2774                                                                                             | -                                                                       | 2                                                                  | _       |    |   | -            | Δ    | Δ | Δ |   |
| ASLM              | Arithmetic Shift Left<br>AM    | ©+ <u>;;</u> <u>-</u> ;,-• | INH                                                                                   | 2786                                                                                             |                                                                         | 4                                                                  | -       | Δ  | - | Δ            | Δ    |   |   |   |
| ASLW              | Arithmetic Shift Left<br>Word  |                            | IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                                               | 2704<br>2714<br>2724<br>2734                                                                     | 9999<br>9999<br>9999<br>hh ll                                           | 8<br>8<br>8<br>8                                                   | -       | _  | - | _            | Δ    | Δ | Δ |   |
| ASR               | Arithmetic Shift Right         | G                          | IND8, X<br>IND8, Y<br>IND8, Z<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT              | 0D<br>1D<br>2D<br>170D<br>171D<br>172D<br>173D                                                   | ff<br>ff<br>9999<br>9999<br>9999<br>9999<br>hh ll                       | 8<br>8<br>8<br>8<br>8<br>8<br>8                                    | -       |    | _ | -            | Δ    | Δ | Δ |   |
| ASRA              | Arithmetic Shift Right<br>A    | Ginning a                  | INH                                                                                   | 370D                                                                                             | -                                                                       | 2                                                                  | -       | _  |   | -            | Δ    | Δ | Δ |   |
| ASRB              | Arithmetic Shift Right<br>B    | Ginning a                  | INH                                                                                   | 371D                                                                                             | -                                                                       | 2                                                                  | -       |    |   |              | Δ    | Δ | Δ |   |
| ASRD              | Arithmetic Shift Right<br>D    | G <u>;</u> ;;;;;;;;;;;,≠C  | INH                                                                                   | 27FD                                                                                             | -                                                                       | 2                                                                  |         |    | _ |              | Δ    | Δ | Δ |   |
| ASRE              | Arithmetic Shift Right<br>E    | <u>ынтр</u> ю              | INH                                                                                   | 277D                                                                                             | -                                                                       | 2                                                                  | -       |    | - | —            | Δ    | Δ | Δ |   |
| ASRM              | Arithmetic Shift Right<br>AM   | ₲штҵ҄ҹҩ                    | INH                                                                                   | 27BA                                                                                             | -                                                                       | 2                                                                  | -       | _  | - | Δ            | Δ    | — |   |   |
| ASRW              | Arithmetic Shift Right<br>Word |                            | IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                                               | 270D<br>271D<br>272D<br>273D                                                                     | 9999<br>9999<br>9999<br>hh li                                           | 8<br>8<br>8<br>8                                                   | -       | _  | _ |              | Δ    | Δ | Δ |   |
| BCC               | Branch if Carry Clear          | If C = 0, branch           | REL8                                                                                  | B4                                                                                               | r                                                                       | 6, 2                                                               | -       | -  |   |              |      |   |   |   |

MOTOROLA 5–40

| Mnemonic     | Operation                                                     |                                                           |                                                                                                                         |                                                                              | Instruction                                                 |                                                     |           |       |
|--------------|---------------------------------------------------------------|-----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|-------------------------------------------------------------|-----------------------------------------------------|-----------|-------|
|              |                                                               | Description                                               | Address<br>Mode                                                                                                         | Opcode                                                                       | Operand                                                     | Cycles                                              | S MV H EV | N Z V |
| BCLR         | Clear Bit(s)                                                  | (M) • (Mask) ⇒ M                                          | IND16, X<br>IND16, Y<br>IND16, Z<br>EXT<br>IND8, X<br>IND8, Y<br>IND8, Z                                                | 08<br>18<br>28<br>38<br>1708<br>1718<br>1728                                 | mm gggg<br>mm gggg<br>mm gggg<br>mm hh li<br>mm ff<br>mm ff | 8<br>8<br>8<br>8<br>8<br>8<br>8<br>8<br>8           |           |       |
| BCLRW        | Clear Bit(s) Word                                             | (M : M + 1) • (Mask) ⇒<br>M : M + 1                       | IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                                                                                 | 2708<br>2718<br>2728<br>2738                                                 | mmmm<br>9999<br>mmmm<br>9999<br>mmmm<br>9999<br>mmmm        | 10<br>10<br>10<br>10                                |           | ΔΔΟ   |
|              |                                                               |                                                           |                                                                                                                         |                                                                              | hh ll                                                       |                                                     |           | L     |
| BCS<br>BEQ   | Branch if Carry Set                                           | If C = 1, branch                                          | REL8                                                                                                                    | B5                                                                           | π                                                           | 6, 2                                                |           |       |
| BGE          | Branch if Equal<br>Branch if Greater<br>Than or Equal to Zero | If $Z = 1$ , branch<br>If $N \oplus V = 0$ , branch       | REL8<br>REL8                                                                                                            | B7<br>BC                                                                     | rr<br>rr                                                    | 6, 2<br>6, 2                                        |           |       |
| BGND         | Enter Background<br>Debug Mode                                | If BDM enabled<br>enter BDM;<br>else, illegal instruction | INH                                                                                                                     | 37A6                                                                         | -                                                           | _                                                   |           |       |
| BGT          | Branch if Greater<br>Than Zero                                | If $Z + (N \oplus V) = 0$ , branch                        | REL8                                                                                                                    | BE                                                                           | 'n                                                          | 6, 2                                                |           |       |
| BHI          | Branch if Higher                                              | If $C + Z = 0$ , branch                                   | REL8                                                                                                                    | B2                                                                           | ۳                                                           | 6, 2                                                |           |       |
| BITA         | Bit Test A                                                    | (A) • (M)                                                 | IND8, X<br>IND8, Y<br>IND8, Z<br>IND8, Z<br>IND16, X<br>IND16, X<br>IND16, Z<br>E, X<br>E, X<br>E, Z                    | 49<br>59<br>69<br>1749<br>1759<br>1769<br>1779<br>2749<br>2759<br>2769       | ff<br>ff<br>ii<br>9999<br>9999<br>hh II<br>                 | 6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6 |           | ΔΔΟ   |
| BITB         | Bit Test B                                                    | (B) • (M)                                                 | IND8, X<br>IND8, Y<br>IND8, Z<br>IND8, Z<br>IND8, Z<br>IND16, X<br>IND16, Y<br>IND16, Z<br>E, X<br>E, X<br>E, Y<br>E, Z | C9<br>D9<br>E9<br>F9<br>17C9<br>17D9<br>17E9<br>17F9<br>27C9<br>27D9<br>27E9 | ff<br>ff<br>9999<br>9999<br>9999<br>hh II<br>—              | 6<br>6<br>2<br>6<br>6<br>6<br>6<br>6<br>6<br>6      |           | ΔΔΟ   |
| BLE          | Branch if Less Than<br>or Equal to Zero                       | If $Z + (N \oplus V) = 1$ , branch                        | REL8                                                                                                                    | BF                                                                           | rr                                                          | 6, 2                                                |           |       |
| BLS          | Branch if Lower or<br>Same                                    | If $C + Z = 1$ , branch                                   | REL8                                                                                                                    | B3                                                                           | r                                                           | 6, 2                                                |           |       |
| BLT          | Branch if Less Than<br>Zero                                   | If $N \oplus V = 1$ , branch                              | REL8                                                                                                                    | BD                                                                           | r                                                           | 6, 2                                                |           |       |
| BMI          | Branch if Minus                                               | If N = 1, branch                                          | REL8                                                                                                                    | BB                                                                           | ŕr                                                          | 6, 2                                                |           |       |
| BNE          | Branch if Not Equal                                           | If Z = 0, branch                                          | REL8                                                                                                                    | B6                                                                           | rr                                                          | 6, 2                                                |           |       |
| BPL          | Branch if Plus                                                | If N = 0, branch                                          | REL8                                                                                                                    | BA                                                                           | r                                                           | 6, 2                                                |           |       |
| BRA<br>BRCLR | Branch Always<br>Branch if Bit(s) Clear                       | If 1 = 1, branch<br>If (M) • (Mask) = 0, branch           | REL8<br>IND8, X<br>IND8, Y<br>IND8, Z<br>IND16, X                                                                       | BO<br>CB<br>DB<br>EB<br>0A                                                   | r<br>mm ff rr<br>mm ff rr<br>mm ff rr<br>mm g999<br>mr      | 6<br>12, 10<br>12, 10<br>12, 10<br>14, 10           |           |       |
|              |                                                               |                                                           | IND16, Y                                                                                                                | 1A                                                                           | mm gggg                                                     | 14, 10                                              |           |       |
|              |                                                               |                                                           | IND16, Z                                                                                                                | 2A                                                                           | mm gggg<br>mr                                               | 14, 10                                              |           |       |
|              |                                                               |                                                           | EXT                                                                                                                     | ЗA                                                                           | mm hhli<br>mm                                               | 14, 10                                              |           |       |

#### CENTRAL PROCESSING UNIT

| Maamaa'- | Onenation                   | Instruction Se                                                                                                                       |                                                                                                              | ary (Co                                                                |                                                                      |                                                |          |     | an alles          |   |   |     |
|----------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|----------------------------------------------------------------------|------------------------------------------------|----------|-----|-------------------|---|---|-----|
| Mnemonic | Operation                   | Description                                                                                                                          | Address<br>Mode                                                                                              | Opcode                                                                 | Instruction<br>Operand                                               | Cycles                                         | SI       |     | onditi<br>H   E V |   | Z | VI  |
| BRSET    | Branch if Bit(s) Set        | lf (M) • (Mask) = 0, branch                                                                                                          | IND8, X<br>IND8, Y<br>IND8, Z<br>IND16, X                                                                    | 8B<br>9B<br>AB<br>0B                                                   | mm ffrr<br>mm ffrr<br>mm ffrr<br>mm 99999                            | 12, 10<br>12, 10<br>12, 10<br>12, 10<br>14, 10 | <b>-</b> |     |                   | - | - |     |
|          |                             |                                                                                                                                      | IND16, Y                                                                                                     | 1 <b>B</b>                                                             | mm 99999<br>mm                                                       | 14, 10                                         |          |     |                   |   |   |     |
|          |                             |                                                                                                                                      | IND16, Z                                                                                                     | 2B                                                                     | mm 9999                                                              | 14, 10                                         |          |     |                   |   |   |     |
|          |                             |                                                                                                                                      | EXT                                                                                                          | 3B                                                                     | mm hhli<br>mr                                                        | 14, 10                                         |          |     |                   |   |   |     |
| BSET     | Set Bit(s)                  | (M) • (Mask) ⇒ M                                                                                                                     | IND16, X<br>IND16, Y<br>IND16, Z<br>EXT<br>IND8, X<br>IND8, Y<br>IND8, Z                                     | 09<br>19<br>29<br>39<br>1709<br>1719<br>1729                           | mm 9999<br>mm 9999<br>mm 9990<br>mm hh li<br>mm ff<br>mm ff<br>mm ff | 8<br>8<br>8<br>8<br>8<br>8                     |          |     |                   | Δ | Δ | 0 - |
| BSETW    | Set Bit(s) in Word          | (M:M+1) • (Mask)<br>⇒ M:M+1                                                                                                          | IND16, X                                                                                                     | 2709                                                                   | mmmm<br>9999                                                         | 10                                             | 1        |     |                   | Δ | Δ | 0 - |
|          |                             |                                                                                                                                      | IND16, Y                                                                                                     | 2719                                                                   | mmmm<br>9999                                                         | 10                                             |          |     |                   |   |   |     |
|          |                             |                                                                                                                                      | IND16, Z                                                                                                     | 2729                                                                   | mmmm<br>9999                                                         | 10                                             |          |     |                   |   |   |     |
|          |                             |                                                                                                                                      | EXT                                                                                                          | 2739                                                                   | mmmm<br>hh li                                                        | 10                                             |          |     |                   |   |   |     |
| BSR      | Branch to Subroutine        | (PK : PC) - 2 ⇒ PK : PC<br>Push (PC)<br>(SK : SP) - 2 ⇒ SK : SP<br>Push (CCR)<br>(SK : SP) - 2 ⇒ SK : SP<br>(PK:PC) + Offset ⇒ PK:PC | REL8                                                                                                         | 36                                                                     | ſŕ                                                                   | 10                                             | -        |     |                   | - |   |     |
| BVC      | Branch if Overflow<br>Clear | If V = 0, branch                                                                                                                     | REL8                                                                                                         | <b>B8</b>                                                              | ſſ                                                                   | 6, 2                                           |          |     |                   | - |   |     |
| BVS      | Branch if Overflow<br>Set   | If $V = 1$ , branch                                                                                                                  | REL8                                                                                                         | B9                                                                     | r                                                                    | 6, 2                                           | -        |     |                   | - | - |     |
| CBA      | Compare A to B              | (A) – (B)                                                                                                                            | INH                                                                                                          | 371B                                                                   | -                                                                    | 6, 2                                           | -        |     |                   | Δ | Δ | Δ   |
| CLR      | Clear Memory                | \$00 ⇒ M                                                                                                                             | IND8, X<br>IND8, Y<br>IND8, Z<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                                     | 05<br>15<br>25<br>1705<br>1715<br>1725<br>1735                         | ff<br>ff<br>9999<br>9999<br>9999<br>9999<br>hh ll                    | 4<br>4<br>6<br>6<br>6                          | -        |     |                   | 0 | 1 | 0 ( |
| CLRA     | Clear A                     | \$00 ⇒ A                                                                                                                             | INH                                                                                                          | 3705                                                                   | -                                                                    | 2                                              | -        |     | <u> </u>          | 0 | 1 | 0 ( |
| CLRB     | Clear B                     | \$00 ⇒ B                                                                                                                             | INH                                                                                                          | 3715                                                                   | -                                                                    | 2                                              |          |     |                   | 0 | 1 | 0 ( |
| CLRD     | Clear D                     | \$0000 ⇒ D                                                                                                                           | INH                                                                                                          | 27F5                                                                   | -                                                                    | 2                                              | -        |     |                   | 0 | 1 | 0 ( |
| CLRE     | Clear E                     | \$0000 ⇒ E                                                                                                                           | INH                                                                                                          | 2775                                                                   |                                                                      | 2                                              | _        |     |                   | 0 | 1 | 0 ( |
| CLRM     | Clear AM                    | \$00000000 ⇒ AM[32:0]                                                                                                                | INH                                                                                                          | 2787                                                                   |                                                                      | 2                                              | -        | 0 . | - 0               | - |   |     |
| CLRW     | Clear Memory Word           | \$0000 ⇒ M : M + 1                                                                                                                   | IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                                                                      | 2705<br>2715<br>2725<br>2735                                           | 9999<br>9999<br>9999<br>hh li                                        | 6<br>6<br>6                                    | -        |     |                   | 0 | 1 | 0 ( |
| СМРА     | Compare A to<br>Memory      | (A) – (M)                                                                                                                            | IND8, X<br>IND8, Y<br>IND8, Z<br>IMD8, Z<br>IMD16, Z<br>IND16, X<br>IND16, Z<br>E, X<br>E, X<br>E, X<br>E, Z | 48<br>58<br>68<br>1748<br>1758<br>1768<br>1778<br>2748<br>2758<br>2768 | ff<br>ff<br>9999<br>9999<br>5999<br>hh<br>                           | 6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6      | -        |     |                   | Δ | Δ | Δ.  |

MC68HC16Z1 USER'S MANUAL

|          | •••••••••••••••••••••••••••••••••••••• | Instruction Se                                                  |                                                                                                   | ary (Co                                                                                |                                                            |                                                          |       |        |            |        |        |        |
|----------|----------------------------------------|-----------------------------------------------------------------|---------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|------------------------------------------------------------|----------------------------------------------------------|-------|--------|------------|--------|--------|--------|
| Mnemonic | Operation                              | Description                                                     | Address                                                                                           | 0                                                                                      | Instruction                                                |                                                          | 0.140 | Condit |            |        | V      | -      |
| СМРВ     | Compare B to                           | (B) – (M)                                                       | Mode<br>IND8, X<br>IND8, Y                                                                        | Opcode<br>C8                                                                           | Operand<br>ff                                              | Cycles<br>6                                              | S M   | HE     | / N        | Z<br>∆ | ν<br>Δ | C<br>A |
|          | Memory                                 |                                                                 | IND8, Y<br>IND8, Z<br>IMM8<br>IND16, X<br>IND16, Y<br>IND16, Z<br>E, X<br>E, X<br>E, Y<br>E, Z    | D8<br>E8<br>F8<br>17C8<br>17D8<br>17E8<br>17F8<br>27C8<br>27D8<br>27E8                 | ff<br>ii<br>9999<br>9999<br>9999<br>hh II<br>—             | 6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6 | -     |        |            |        |        |        |
| СОМ      | Ones Complement                        | \$FF – (M) ⇒ M                                                  | IND8, X<br>IND8, Y<br>IND8, Z<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                          | 00<br>10<br>20<br>1700<br>1710<br>1720<br>1730                                         | ff<br>ff<br>9999<br>9999<br>9999<br>9999<br>hh ll          | 8<br>8<br>8<br>8<br>8<br>8<br>8                          |       |        | Δ          | Δ      | 0      | 1      |
| COMA     | Ones Complement A                      | \$FF – (A) ⇒ A                                                  | INH                                                                                               | 3700                                                                                   |                                                            | 2                                                        |       |        | Δ          | Δ      | 0      | 1      |
| COMB     | Ones Complement B                      | $FF - (B) \Rightarrow B$                                        | INH                                                                                               | 3710                                                                                   |                                                            | 2                                                        |       |        | · <b>Δ</b> | Δ      | 0      | 1      |
| COMD     | Ones Complement D<br>Ones Complement E | $\frac{\$FFFF - (D) \Rightarrow D}{\$FFFF - (E) \Rightarrow E}$ | INH<br>INH                                                                                        | 27F0<br>2770                                                                           |                                                            | 2                                                        |       |        | - <u>Δ</u> | Δ<br>Δ | 0      | 1      |
| COMW     | Ones Complement E<br>Word              | \$FFFF - M : M + 1 ⇒<br>M : M + 1                               | IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                                                           | 2770<br>2700<br>2710<br>2720<br>2730                                                   | 9999<br>9999<br>9999<br>hh li                              | 8<br>8<br>8<br>8                                         |       | ·      | Δ          | Δ      | 0      | 1      |
| CPD      | Compare D to<br>Memory                 | (D) – (M : M + 1)                                               | IND8, X<br>IND8, Y<br>IND8, Z<br>E, X<br>E, Z<br>IMM16<br>IND16, X<br>IND16, Z<br>IND16, Z<br>EXT | 88<br>98<br>A8<br>2788<br>2798<br>2798<br>3788<br>37B8<br>37C8<br>37D8<br>37E8<br>37F8 | ff<br>ff<br>jj kk<br>9999<br>9999<br>9999<br>9999<br>509   | 6<br>6<br>6<br>6<br>6<br>4<br>6<br>6<br>6<br>6           |       |        | - Δ        | Δ      | Δ      | Δ      |
| CPE      | Compare E to<br>Memory                 | (E) – (M : M + 1)                                               | IMM16<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                                                  | 3738<br>3748<br>3758<br>3768<br>3768<br>3778                                           | hh II<br>9999<br>9999<br>9999<br>jj kk                     | 6<br>6<br>6<br>6                                         |       |        | - Δ        | Δ      | Δ      | Δ      |
| CPS      | Compare SP to<br>Memory                | (SP) – (M∶M + 1)                                                | IND8, X<br>IND8, Y<br>IND8, Z<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT<br>IMM16                 | 4F<br>5F<br>6F<br>174F<br>175F<br>176F<br>177F<br>377F                                 | ff<br>ff<br>9999<br>9999<br>9099<br>hh ll<br>jj kk         | 6<br>6<br>6<br>6<br>6<br>4                               |       |        | - Δ        | Δ      | Δ      | Δ      |
| СРХ      | Compare IX to<br>Memory                | (IX) – (M : M + 1)                                              | IND8, X<br>IND8, Y<br>IND8, Z<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT<br>IMM16                 | 4C<br>5C<br>6C<br>174C<br>175C<br>176C<br>177C<br>377C                                 | ff<br>ff<br>9999<br>9999<br>9999<br>5099<br>hh II<br>jj kk | 6<br>6<br>6<br>6<br>6<br>4                               |       |        | Δ          | Δ      | Δ      | Δ      |
| СРҮ      | Compare IY to<br>Memory                | (IY) – (M : M + 1)                                              | IND8, X<br>IND8, Y<br>IND8, Z<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT<br>IMM16                 | 4D<br>5D<br>6D<br>174D<br>175D<br>176D<br>177D<br>377D                                 | ff<br>ff<br>9999<br>9999<br>9099<br>5099<br>hh II<br>jj kk | 6<br>6<br>6<br>6<br>6<br>6<br>4                          |       |        | Δ          | Δ      | Δ      | Δ      |

| Marrie   |                               | Instruction Se                                      |                                                                                                                          | ary (Co                                                                        |                                                        | )                                                        | <b>A *</b> **          |                    |
|----------|-------------------------------|-----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|--------------------------------------------------------|----------------------------------------------------------|------------------------|--------------------|
| Mnemonic | Operation                     | Description                                         | Address<br>Mode                                                                                                          | Opcode                                                                         | Instruction<br>Operand                                 | Cycles                                                   | Condition<br>S MV H EV | n Codes<br>N Z V C |
| CPZ      | Compare IZ to<br>Memory       | (IZ) – (M : M + 1)                                  | IND8, X<br>IND8, Y<br>IND8, Z<br>IND16, X<br>IND16, X<br>IND16, Z<br>EXT<br>IMM16                                        | 4E<br>5E<br>6E<br>174E<br>175E<br>176E<br>177E<br>377E                         | 9999<br>9999<br>9999<br>9999<br>hh li<br>jj kk         | 6<br>6<br>6<br>6<br>6<br>6<br>6<br>4                     | <u> </u>               |                    |
| DAA      | Decimal Adjust A              | (A) <sub>10</sub>                                   | INH                                                                                                                      | 3721                                                                           | 1                                                      | 2                                                        |                        | ΔΔΔΔ               |
| DEC      | Decrement Memory              | (M) – \$01 ⇒ M                                      | IND8, X<br>IND8, Y<br>IND8, Z<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                                                 | 01<br>11<br>21<br>1701<br>1711<br>1721<br>1731                                 | ff<br>ff<br>9999<br>9999<br>9999<br>hh li              | 8<br>8<br>8<br>8<br>8<br>8<br>8                          |                        |                    |
| DECA     | Decrement A                   | (A) – \$01 ⇒ A                                      | INH                                                                                                                      | 3701                                                                           | —                                                      | 2                                                        |                        | ΔΔΔ                |
| DECB     | Decrement B                   | (B) – \$01 ⇒ B                                      | INH                                                                                                                      | 3711                                                                           | -                                                      | 2                                                        |                        | ΔΔΔ —              |
| DECW     | Decrement Memory<br>Word      | (M : M + 1) – \$0001<br>⇒ M : M + 1                 | IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                                                                                  | 2701<br>2711<br>2721<br>2731                                                   | 9999<br>9999<br>9999<br>hh ii                          | 8<br>8<br>8<br>8                                         |                        | ΔΔΔ                |
| EDIV     | Extended Unsigned<br>Divide   | (E : D) / (IX)<br>Quotient ⇒ IX<br>Remainder ⇒ D    | INH                                                                                                                      | 3728                                                                           | -                                                      | 24                                                       |                        | ΔΔΔΔ               |
| EDIVS    | Extended Signed<br>Divide     | (E : D) / (IX)<br>Quotient ⇒ IX<br>Remainder ⇒ ACCD | INH                                                                                                                      | 3729                                                                           | -                                                      | 38                                                       |                        | ΔΔΔΔ               |
| EMUL     | Extended Unsigned<br>Multiply | (E) * (D) ⇒ E : D                                   | INH                                                                                                                      | 3725                                                                           | -                                                      | 10                                                       |                        | ΔΔ — Δ             |
| EMULS    | Extended Signed<br>Multiply   | (E) * (D) ⇒ E : D                                   | INH                                                                                                                      | 3726                                                                           | -                                                      | 8                                                        |                        | Δ Δ — Δ            |
| EORA     | Exclusive OR A                | (A) ⊕ (M) ⇒ A                                       | IND8, X<br>IND8, Y<br>IND8, Z<br>IND8, Z<br>IND16, X<br>IND16, X<br>IND16, Y<br>IND16, Z<br>E, X<br>E, X<br>E, Y<br>E, Z | 44<br>54<br>64<br>74<br>1744<br>1754<br>1764<br>1774<br>2744<br>2754<br>2764   | ff<br>ff<br>9999<br>9999<br>hh li<br>—<br>—            | 6<br>6<br>2<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6 |                        | ΔΔ0                |
| EORB     | Exclusive OR B                | (B) ⊕ (M) ⇒ B                                       | IND8, X<br>IND8, Y<br>IND8, Z<br>IND8, Z<br>IND16, X<br>IND16, X<br>IND16, X<br>IND16, Z<br>E, X<br>E, X<br>E, Y<br>E, Z | C4<br>D4<br>E4<br>17C4<br>17C4<br>17E4<br>17F4<br>27C4<br>27C4<br>27E4         | ff<br>ff<br>9999<br>9999<br>9999<br>9999<br>hh II<br>— | 6<br>6<br>6<br>2<br>6<br>6<br>6<br>6<br>6                |                        | ΔΔ0 —              |
| EORD     | Exclusive OR D                | (D)                                                 | IND8, X<br>IND8, Y<br>IND8, Z<br>E, X<br>E, Y<br>E, Z<br>IMM16<br>IND16, X<br>IND16, Z<br>EXT                            | 84<br>94<br>A4<br>2784<br>2794<br>27A4<br>37B4<br>37C4<br>37C4<br>37C4<br>37F4 | ff<br>ff<br>                                           | 6<br>6<br>6<br>6<br>4<br>6<br>6<br>6<br>6                |                        | ΔΔΟ                |
| EORE     | Exclusive OR E                | (E) ⊕ (M : M + 1) ⇒ E                               | IMM16<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                                                                         | 3734<br>3744<br>3754<br>3764<br>3774                                           | hh II<br>9999<br>9999<br>9999<br>jj kk                 | 4<br>6<br>6<br>6                                         |                        | ΔΔΟ —              |

|          |                                                    | Instruction Se                                                                                                                      |                                                                          | ary (Co                                        |                                                      |                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |     |
|----------|----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|------------------------------------------------|------------------------------------------------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-----|
| Mnemonic | Operation                                          | Description                                                                                                                         | Address                                                                  |                                                | Instruction                                          |                      | and a second sec | on Codes |     |
|          |                                                    |                                                                                                                                     | Mode                                                                     | Opcode                                         | Operand                                              | Cycles               | SMVHEV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | NZ       | V C |
| FDIV     | Fractional Divide                                  | $\begin{array}{l} (D) \ / \ (IX) \Rightarrow IX \\ Remainder \Rightarrow \ D \end{array}$                                           | INH                                                                      | 372B                                           | -                                                    | 22                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | - A      | ΔΔ  |
| FMULS    | Fractional Signed<br>Multiply                      | $\begin{array}{c} (E)*(D)\RightarrowE:D[31:1]\\ 0\RightarrowD[0] \end{array}$                                                       | INH                                                                      | 3727                                           | -                                                    | 8                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ΔΔ       | ΔΔ  |
| IDIV     | Integer Divide                                     | (D) / (IX) $\Rightarrow$ IX;<br>Remainder $\Rightarrow$ D                                                                           | INH                                                                      | 372A                                           |                                                      | 22                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | - Δ      | 0 Δ |
| INC      | Increment Memory                                   | (M) + \$01 ⇒ M                                                                                                                      | IND8, X<br>IND8, Y<br>IND8, Z<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT | 03<br>13<br>23<br>1703<br>1713<br>1723<br>1733 | ff<br>ff<br>9999<br>9999<br>9999<br>hh ll            | 2222222              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ΔΔ       | Δ — |
| INCA     | Increment A                                        | (A) + \$01 ⇒ A                                                                                                                      | INH                                                                      | 3703                                           | -                                                    | 2                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ΔΔ       | Δ — |
| INCB     | Increment B                                        | (B) + \$01 ⇒ B                                                                                                                      | INH                                                                      | 3713                                           |                                                      | 2                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ΔΔ       | Δ   |
| INCW     | Increment Memory<br>Word                           | (M : M + 1) + \$0001<br>⇒ M : M + 1                                                                                                 | IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                                  | 2703<br>2713<br>2723<br>2733                   | 9999<br>9999<br>9999<br>hh li                        | 8<br>8<br>8<br>8     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ΔΔ       | Δ — |
| JMP      | Jump                                               | (ea) ⇒ PK : PC                                                                                                                      | IND20, X<br>IND20, Y<br>IND20, Z<br>EXT20                                | 4B<br>5B<br>6B<br>7A                           | zg 9999<br>zg 9999<br>zg 9999<br>zg 9999<br>zb hh li | 8<br>8<br>8<br>6     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |     |
| JSR      | Jump to Subroutine                                 | Push (PC)<br>(SK : SP) $- 2 \Rightarrow$ SK : SP<br>Push (CCR)<br>(SK : SP) $- 2 \Rightarrow$ SK : SP<br>(ea) $\Rightarrow$ PK : PC | IND20, X<br>IND20, Y<br>IND20, Z<br>EXT                                  | 89<br>99<br>A9<br>FA                           | 29 9999<br>29 9999<br>29 9999<br>29 9999<br>20 hh li | 12<br>12<br>12<br>10 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |     |
| LBCC     | Long Branch if Carry<br>Clear                      | If $C = 0$ , branch                                                                                                                 | REL16                                                                    | 3784                                           | m                                                    | 6, 4                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |     |
| LBCS     | Long Branch if Carry<br>Set                        | If C = 1, branch                                                                                                                    | REL16                                                                    | 3785                                           | m                                                    | 6, 4                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |     |
| LBEQ     | Long Branch if Equal                               | If $Z = 1$ , branch                                                                                                                 | REL16                                                                    | 3787                                           | m                                                    | 6, 4                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |     |
| LBEV     | Long Branch if EV<br>Set                           | If EV = 1, branch                                                                                                                   | REL16                                                                    | 3791                                           | m                                                    | 6, 4                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |     |
| LBGE     | Long Branch if<br>Greater Than or<br>Equal to Zero | if N ⊕ V = 0, branch                                                                                                                | REL16                                                                    | 378C                                           | m                                                    | 6, 4                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |     |
| LBGT     | Long Branch if<br>Greater Than Zero                | If $Z + (N \oplus V) = 0$ , branch                                                                                                  | REL16                                                                    | 378E                                           | m                                                    | 6, 4                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |     |
| LBHI     | Long Branch if<br>Higher                           | If $C + Z = 0$ , branch                                                                                                             | REL16                                                                    | 3782                                           | m                                                    | 6, 4                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |     |
| LBLE     | Long Branch if Less<br>Than or Equal to Zero       | If $Z + (N \oplus V) = 1$ , branch                                                                                                  | REL16                                                                    | 378F                                           | m                                                    | 6, 4                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |     |
| LBLS     | Long Branch if Lower<br>or Same                    | If $C + Z = 1$ , branch                                                                                                             | REL16                                                                    | 3783                                           | m                                                    | 6, 4                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |     |
| LBLT     | Long Branch if Less<br>Than Zero                   | If N ⊕ V = 1, branch                                                                                                                | REL16                                                                    | 378D                                           | m                                                    | 6, 4                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |     |
| LBMI     | Long Branch if Minus                               | If N = 1, branch                                                                                                                    | REL16                                                                    | 378B                                           | mr                                                   | 6, 4                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |     |
| LBMV     | Long Branch if MV<br>Set                           | If MV = 1, branch                                                                                                                   | REL16                                                                    | 3790                                           | m                                                    | 6, 4                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |     |
| LBNE     | Long Branch if Not<br>Equal                        | If Z = 0, branch                                                                                                                    | REL16                                                                    | 3786                                           | m                                                    | 6, 4                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |     |
| LBPL     | Long Branch if Plus                                | If N = 0, branch                                                                                                                    | REL16                                                                    | 378A                                           | m                                                    | 6, 4                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |     |
| LBRA     | Long Branch Always                                 | If 1 = 1, branch                                                                                                                    | REL16                                                                    | 3780                                           | m                                                    | 6                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |     |
| LBRN     | Long Branch Never                                  | If 1 = 0, branch                                                                                                                    | REL16                                                                    | 3781                                           | mr                                                   | 6                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |     |
| LBSR     | Long Branch to<br>Subroutine                       | Push (PC)<br>(SK : SP) - 2 ⇒ SK : SP<br>Push (CCR)<br>(SK : SP) - 2 ⇒ SK : SP<br>(PK : PC) + Offset ⇒<br>PK : PC                    | REL16                                                                    | 27F9                                           | m                                                    | 10                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |     |
| LBVC     | Long Branch if<br>Overflow Clear                   | If $V = 0$ , branch                                                                                                                 | REL16                                                                    | 3788                                           | m                                                    | 6, 4                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |     |
| LBVS     | Long Branch if<br>Overflow Set                     | If V = 1, branch                                                                                                                    | REL16                                                                    | 3789                                           | m                                                    | 6, 4                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |     |

| Mnemonic | Operation                    | Instruction Se<br>Description                                                                                                                                 | Address                                                                                                   | ary (00                                                                                        | Instruction                                                          |                                                               | Condition | n Codes |   |
|----------|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|---------------------------------------------------------------|-----------|---------|---|
|          | operation                    | Description                                                                                                                                                   | Mode                                                                                                      | Opcode                                                                                         | Operand                                                              | Cycles                                                        | SMVHEV    | NZV     | C |
| LDAA     | Load A                       | (M) ⇒ A                                                                                                                                                       | IND8, X<br>IND8, Y<br>IND8, Z<br>IMM8<br>IND16, X<br>IND16, Y<br>IND16, Z<br>E, X<br>E, X<br>E, Y<br>E, Z | 45<br>55<br>65<br>75<br>1745<br>1755<br>1765<br>1775<br>2745<br>2755<br>2765                   | 9999<br>9999<br>9999<br>9999<br>9999<br>9999<br>9999<br>9999<br>9999 | 6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6           |           |         |   |
| LDAB     | Load B                       | (M) ⇒ B                                                                                                                                                       | IND8, X<br>IND8, Y<br>IND8, Z<br>IMM8<br>IND16, X<br>IND16, Y<br>IND16, Z<br>E, T<br>E, X<br>E, Y<br>E, Z | C5<br>D5<br>E5<br>17C5<br>17D5<br>17F5<br>27C5<br>27D5<br>27E5                                 | ff<br>ff<br>9999<br>9999<br>9999<br>5099<br>hh II<br>—               | 6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6 |           | ΔΔΟ     |   |
| LDD      | Load D                       | (M : M + 1) ⇒ D                                                                                                                                               | IND8, X<br>IND8, Y<br>IND8, Z<br>E, X<br>E, Y<br>E, Z<br>IMM16<br>IND16, X<br>IND16, Z<br>EXT             | 85<br>95<br>A5<br>2785<br>2785<br>2785<br>3785<br>3785<br>3705<br>3705<br>3775<br>3775<br>3775 | ff<br>ff<br><br>9999<br>9999<br>9999<br>9999<br>9999<br>9            | 6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6                |           | ΔΔΟ     |   |
| LDE      | Load E                       | (M : M + 1) ⇒ E                                                                                                                                               | IMM16<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                                                          | 3735<br>3745<br>3755<br>3765<br>3775                                                           | jj kk<br>9999<br>9999<br>9999<br>9999<br>hh li                       | 4<br>6<br>6<br>6                                              |           | ΔΔΟ     |   |
| LDED     | Load Concatenated<br>E and D | $(M: M + 1) \Rightarrow E$<br>$(M + 2: M + 3) \Rightarrow D$                                                                                                  | EXT                                                                                                       | 2771                                                                                           | hh II                                                                | 8                                                             |           |         |   |
| LDHI     | Initialize H and I           | $(\mathbf{M}: \mathbf{M} + 1)\mathbf{\chi} \Rightarrow \mathbf{H} \mathbf{R}$ $(\mathbf{M}: \mathbf{M} + 1)\mathbf{\gamma} \Rightarrow \mathbf{I} \mathbf{R}$ | INH                                                                                                       | 27B0                                                                                           | -                                                                    | 8                                                             |           |         |   |
| LDS      | Load SP                      | (M : M + 1) ⇒ SP                                                                                                                                              | IND8, X<br>IND8, Y<br>IND8, Z<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT<br>IMM16                         | CF<br>DF<br>EF<br>17CF<br>17DF<br>17EF<br>17FF<br>37BF                                         | ff<br>ff<br>9999<br>9999<br>9999<br>hh ll<br>jj kk                   | 6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>4                     |           | ΔΔ0     |   |
| LDX      | Load IX                      | (M : M + 1) ⇒ IX                                                                                                                                              | IND8, X<br>IND8, Y<br>IND8, Z<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT<br>IMM16                         | CC<br>DC<br>EC<br>17CC<br>17DC<br>17EC<br>17FC<br>37BC                                         | ff<br>ff<br>9999<br>9999<br>9999<br>9999<br>hh II<br>jj kk           | 6<br>6<br>6<br>6<br>6<br>6<br>4                               |           | ΔΔΟ     | - |
| LDY      | Load IY                      | (M : M + 1) ⇒ IY                                                                                                                                              | IND8, X<br>IND8, Y<br>IND8, Z<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT<br>IMM16                         | CD<br>DD<br>ED<br>17CD<br>17DD<br>17ED<br>17FD<br>37BD                                         | ff<br>ff<br>9999<br>9999<br>9999<br>0999<br>hh II<br>jj kk           | 6<br>6<br>6<br>6<br>6<br>6<br>4                               |           | ΔΔΟ     | - |
| LDZ      | Load IZ                      | (M : M + 1) ⇒ IZ                                                                                                                                              | IND8, X<br>IND8, Y<br>IND8, Z<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT<br>IMM16                         | CE<br>DE<br>EE<br>17CE<br>17DE<br>17EE<br>17FE<br>37BE                                         | ff<br>ff<br>9999<br>9999<br>9999<br>hh ll<br>jj kk                   | 6<br>6<br>6<br>6<br>6<br>6<br>4                               |           | ΔΔΟ     |   |

MOTOROLA 5–46 CENTRAL PROCESSING UNIT

MC68HC16Z1 USER'S MANUAL

|          |                                                          | Instruction Se                                                                                                                                                                                                                     |                                                                                                   | ary (Co                                                                |                                                                 |                                           |       |       |   |   |   | _ |
|----------|----------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|-----------------------------------------------------------------|-------------------------------------------|-------|-------|---|---|---|---|
| Mnemonic | Operation                                                | Description                                                                                                                                                                                                                        | Address                                                                                           |                                                                        | Instruction                                                     |                                           |       | ditio |   |   |   |   |
|          |                                                          |                                                                                                                                                                                                                                    | Mode                                                                                              | Opcode                                                                 | Operand                                                         | Cycles                                    | SMVH  | EV    | N | Z | V | C |
| LPSTOP   | Low Power Stop                                           | If S<br>then STOP<br>else NOP                                                                                                                                                                                                      | INH                                                                                               | 27F1                                                                   | -                                                               | 4, 20                                     |       | _     | _ | _ |   |   |
| LSR      | Logical Shift Right                                      | ⊶ <u>p</u> pr@                                                                                                                                                                                                                     | IND8, X<br>IND8, Y<br>IND8, Z<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                          | 0F<br>1F<br>2F<br>170F<br>171F<br>172F<br>173F                         | ff<br>ff<br>9999<br>9999<br>9999<br>5098<br>hh II               | 8<br>8<br>8<br>8<br>8<br>8                |       |       | 0 | Δ | Δ | Δ |
| LSRA     | Logical Shift Right A                                    | ⊶ឰ¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯                                                                                                                                                                                            | INH                                                                                               | 370F                                                                   | -                                                               | 2                                         |       | -     | 0 | Δ | Δ | Δ |
| LSRB     | Logical Shift Right B                                    | ⊶ਗ਼ੑੑੑੑੑੑੑੑੑੑੑੑੑੑੑੑੑੑੑੑੑੑੑੑੑੑੑੑੑ                                                                                                                                                                                                   | INH                                                                                               | 371F                                                                   | -                                                               | 2                                         |       | -     | 0 | Δ | Δ | Δ |
| LSRD     | Logical Shift Right D                                    | •••                                                                                                                                                                                                                                | INH                                                                                               | 27FF                                                                   | -                                                               | 2                                         |       | =     | 0 | Δ | Δ | 2 |
| LSRE     | Logical Shift Right E                                    | ⊶∏⊥⊥₩₩©                                                                                                                                                                                                                            | INH                                                                                               | 277F                                                                   | -                                                               | 2                                         |       | -     | 0 | Δ | Δ | 2 |
| LSRW     | Logical Shift Right<br>Word                              |                                                                                                                                                                                                                                    | IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                                                           | 270F<br>271F<br>272F<br>273F                                           | 9999<br>9999<br>9999<br>hh li                                   | 8<br>8<br>8<br>8                          |       | -     | 0 | Δ | Δ | 2 |
| MAC      | Multiply and<br>Accumulate<br>Signed 16-Bit<br>Fractions | $\begin{array}{l} (HR)*(IR)\Rightarrow \bar{E}:D\\ (AM)+(E:D)\Rightarrow AM\\ Qualified (IX)\Rightarrow IX\\ Qualified (IY)\Rightarrow IY\\ (HR)\Rightarrow IZ\\ (M:M+1)\chi\Rightarrow HR\\ (M:M+1)Y\Rightarrow IR\\ \end{array}$ | IMM8                                                                                              | 7B                                                                     | хоуо                                                            | 12                                        | — A — | Δ     |   |   | Δ | - |
| MOVB     | Move Byte                                                | $(M_1) \Rightarrow M_2$                                                                                                                                                                                                            | IXP to EXT<br>EXT to IXP<br>EXT to<br>EXT to<br>EXT                                               | 30<br>32<br>37FE                                                       | ff hhii<br>hhii ff<br>hhii hhii                                 | 8<br>8<br>10                              |       | -     | Δ | Δ | 0 | - |
| MOVW     | Move Word                                                | $(M:M+1_1)\RightarrowM:M+1_2$                                                                                                                                                                                                      | IXP to EXT<br>EXT to IXP<br>EXT to<br>EXT                                                         | 31<br>33<br>37FF                                                       | ff hh   <br>hh    ff<br>hh    hh                                | 8<br>8<br>10                              |       | -     | Δ | Δ | 0 | - |
| MUL      | Multiply                                                 | (A) * (B) ⇒ D                                                                                                                                                                                                                      | INH                                                                                               | 3724                                                                   |                                                                 | 10                                        |       |       |   |   |   | 1 |
| NEG      | Negate Memory                                            | \$00 – (M) ⇒ M                                                                                                                                                                                                                     | IND8, X<br>IND8, Y<br>IND8, Z<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                          | 02<br>12<br>22<br>1702<br>1712<br>1722<br>1732                         | ff<br>ff<br>9995<br>9995<br>9995<br>9995<br>hh ll               | 8<br>8<br>8<br>8<br>8<br>8                |       | -     | Δ | Δ | Δ | 4 |
| NEGA     | Negate A                                                 | \$00 – (A) ⇒ A                                                                                                                                                                                                                     | INH                                                                                               | 3702                                                                   | -                                                               | 2                                         |       |       | Δ | Δ | Δ | 4 |
| NEGB     | Negate B                                                 | \$00 – (B) ⇒ B                                                                                                                                                                                                                     | INH                                                                                               | 3712                                                                   | -                                                               | 2                                         |       | -     | Δ | Δ | Δ |   |
| NEGD     | Negate D                                                 | \$0000 – (D) ⇒ D                                                                                                                                                                                                                   | INH                                                                                               | 27F2                                                                   | -                                                               | 2                                         |       | -     | Δ | Δ | Δ |   |
| NEGE     | Negate E                                                 | \$0000 – (E) ⇒ E                                                                                                                                                                                                                   | INH                                                                                               | 2772                                                                   | -                                                               | 2                                         |       | -     | Δ | Δ | Δ |   |
| NEGW     | Negate Memory<br>Word                                    | \$0000 (M : M + 1)<br>⇒ M : M + 1                                                                                                                                                                                                  | IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                                                           | 2702<br>2712<br>2722<br>2732                                           | 9999<br>9999<br>9999<br>hh li                                   | 8<br>8<br>8                               |       |       | Δ | Δ | Δ |   |
| NOP      | Null Operation                                           |                                                                                                                                                                                                                                    | INH                                                                                               | 274C                                                                   | -                                                               | 2                                         |       | -1    |   | - |   |   |
| ORAA     | OR A                                                     | (A) + (M) ⇒ A                                                                                                                                                                                                                      | IND8, X<br>IND8, Y<br>IND8, Z<br>IMM8<br>IND16, X<br>IND16, Y<br>IND16, Z<br>E, X<br>E, Y<br>E, Z | 47<br>57<br>67<br>1747<br>1757<br>1767<br>1767<br>2747<br>2757<br>2767 | ff<br>ff<br>9999<br>9999<br>9999<br>0999<br>0099<br>0099<br>009 | 6<br>6<br>2<br>6<br>6<br>6<br>6<br>6<br>6 |       | -     | Δ | Δ | 0 | - |

| Mnemonic          | Operation                                                                                                                            | Instruction Se<br>Description                                                                                                                                                                                                 | Address                                                                                           |                                                                                        | Instruction                                           |                                                     |   |    | Con | ditic | n Co | des |   |   |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|-------------------------------------------------------|-----------------------------------------------------|---|----|-----|-------|------|-----|---|---|
|                   |                                                                                                                                      |                                                                                                                                                                                                                               | Mode                                                                                              | Opcode                                                                                 | Operand                                               | Cycles                                              | S | ΜV | H   | E۷    | N    | Z   | V | C |
| ORAB              | OR B                                                                                                                                 | (B) + (M) ⇒ B                                                                                                                                                                                                                 | IND8, X<br>IND8, Y<br>IND8, Z<br>IMM8<br>IND16, X<br>IND16, Y<br>IND16, Z<br>E, X<br>E, X<br>E, Z | C7<br>D7<br>E7<br>F7<br>17C7<br>17D7<br>17E7<br>27C7<br>27D7<br>27E7                   | ff<br>ff<br>9999<br>9999<br>9099<br>5099<br>hh II<br> | 6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6 | - |    |     |       | Δ    | Δ   | 0 | - |
| ORD               | OR D                                                                                                                                 | (D) + (M : M + 1) ⇒ D                                                                                                                                                                                                         | IND8, X<br>IND8, Y<br>IND8, Z<br>E, X<br>E, Z<br>IMM16, X<br>IND16, X<br>IND16, Z<br>EXT          | 87<br>97<br>A7<br>2787<br>2787<br>2747<br>37B7<br>37C7<br>37C7<br>37C7<br>37C7<br>37F7 | ff<br>ff<br>hh II<br>9999<br>9999<br>9999<br>jj kk    | 6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6 |   |    |     |       | Δ    | Δ   | 0 | - |
| ORE               | OR E                                                                                                                                 | (E) + (M : M + 1) ⇒ E                                                                                                                                                                                                         | IMM16<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                                                  | 3737<br>3747<br>3757<br>3767<br>3777                                                   | hh II<br>9999<br>9999<br>9999<br>jj kk                | 4<br>6<br>6<br>6                                    | - |    |     | -     | Δ    | Δ   | 0 |   |
| ORP <sup>1</sup>  | OR Condition Code<br>Register                                                                                                        | $(CCR) + IMM16 \Rightarrow CCR$                                                                                                                                                                                               | IMM16                                                                                             | 373B                                                                                   | jj kk                                                 | 4                                                   | Δ | Δ  | Δ   | Δ     | Δ    | Δ   | Δ | ۵ |
| PSHA              | Push A                                                                                                                               | (SK : SP) + 1 ⇒ SK : SP<br>Push (A)<br>(SK : SP) – 2 ⇒ SK : SP                                                                                                                                                                | INH                                                                                               | 3708                                                                                   |                                                       | 4                                                   | - |    |     | -     |      |     |   |   |
| PSHB              | Push B                                                                                                                               | (SK : SP) + 1 ⇒ SK : SP<br>Push (B)<br>(SK : SP) – 2 ⇒ SK : SP                                                                                                                                                                | INH                                                                                               | 3718                                                                                   | -                                                     | 4                                                   |   |    |     | -     | -    |     |   | - |
| PSHM              | Push Multiple<br>Registers<br>0 = D<br>1 = E<br>2 = IX<br>3 = IY<br>4 = IZ<br>5 = K<br>6 = CCR<br>7 = (reserved)                     | For mask bits 0 to 7:<br>If mask bit set<br>Push register<br>(SK : SP) – 2 ⇒ SK : SP                                                                                                                                          | IMM8                                                                                              | 34                                                                                     | II                                                    | 4 + 2N<br>N =<br>number of<br>iterations            | - | -  |     |       | -    | -   |   | - |
| PSHMAC            | Push MAC State                                                                                                                       | MAC Registers ⇒ Stack                                                                                                                                                                                                         | INH                                                                                               | 27B8                                                                                   | -                                                     | 14                                                  | - | -  |     | -     | -    |     | _ | - |
| PULA              | Pull A                                                                                                                               | (SK : SP) + 2 ⇒ SK : SP<br>Pull (A)<br>(SK : SP) – 1 ⇒ SK : SP                                                                                                                                                                | INH                                                                                               | 3709                                                                                   | _                                                     | 6                                                   |   | -  | -   |       |      |     | - | - |
| PULB              | Pull B                                                                                                                               | (SK : SP) + 2 ⇒ SK : SP<br>Pull (B)<br>(SK : SP) – 1 ⇒ SK : SP                                                                                                                                                                | INH                                                                                               | 3719                                                                                   | -                                                     | 6                                                   | - |    |     | _     |      | -   | - | • |
| PULM <sup>1</sup> | Pull Multiple<br>Registers<br>Mask bits:<br>0 = CCR[15:4]<br>1 = K<br>2 = IZ<br>3 = IY<br>4 = IX<br>5 = E<br>6 = D<br>7 = (reserved) | For mask bits 0 to 7:<br>If mask bit set<br>(SK : SP) + 2 ⇒ SK : SP<br>Pull register                                                                                                                                          | IMM8                                                                                              | 35                                                                                     | ii                                                    | 2+2(N+1)<br>N =<br>number of<br>iterations          | Δ | Δ  | Δ   | Δ     | Δ    | Δ   | Δ |   |
| PULMAC            | Pull MAC State                                                                                                                       | Stack ⇒ MAC Registers                                                                                                                                                                                                         | INH                                                                                               | 27B9                                                                                   |                                                       | 16                                                  | — |    | _   | -     | _    |     | - | _ |
| RMAC              | Repeating<br>Multiply and<br>Accumulate<br>Signed 16-Bit<br>Fractions                                                                | Repeat until (E) < 0<br>(AM) + (H) + (I) $\Rightarrow$ AM<br>Qualified (IX) $\Rightarrow$ IX;<br>Qualified (IY) $\Rightarrow$ IY;<br>(M : M + 1)X $\Rightarrow$ H;<br>(M : M + 1)Y $\Rightarrow$ I<br>(E) - 1 $\Rightarrow$ E | IMM8                                                                                              | FB                                                                                     | хоуо                                                  | 6 +<br>12 per<br>iteration                          |   | Δ  | _   | Δ     |      | _   |   | - |

| Mnemonic         | Operation                     | Instruction Se<br>Description                                                                        | Address                                                                                                                              | ary (CC                                                                | Instruction                                              |                                                          | r |   | <u></u> | ditio | m Co | dae |   |   |
|------------------|-------------------------------|------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|----------------------------------------------------------|----------------------------------------------------------|---|---|---------|-------|------|-----|---|---|
| MNemonic         | Operation                     | Description                                                                                          | Mode                                                                                                                                 | Opcode                                                                 | Operand                                                  | Cycles                                                   | S |   |         | EV    |      | Z   | V | С |
| ROL              | Rotate Left                   | ر <mark>۳۰۰۰۰۰۵۰</mark> ۰۵۹                                                                          | IND8, X<br>IND8, Y<br>IND8, Z<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                                                             | 0C<br>1C<br>2C<br>170C<br>171C<br>172C<br>173C                         | 69999<br>ff<br>99999<br>99999<br>99999<br>99999<br>hh ll | 8<br>8<br>8<br>8<br>8<br>8<br>8<br>8                     | - | _ |         |       | Δ    | Δ   | Δ | Δ |
| ROLA             | Rotate Left A                 |                                                                                                      | INH                                                                                                                                  | 370C                                                                   | -                                                        | 2                                                        | - | - | _       | —     | Δ    | Δ   | Δ | Δ |
| ROLB             | Rotate Left B                 |                                                                                                      | INH                                                                                                                                  | 371C                                                                   | -                                                        | 2                                                        | - |   |         |       | Δ    | Δ   | Δ | Δ |
| ROLD             | Rotate Left D                 |                                                                                                      | INH                                                                                                                                  | 27FC                                                                   | -                                                        | 2                                                        | - | - | -       | -     | Δ    | Δ   | Δ | Δ |
| ROLE             | Rotate Left E                 |                                                                                                      | INH                                                                                                                                  | 277C                                                                   | -                                                        | 2                                                        | - |   |         |       | Δ    | Δ   | Δ | ۵ |
| ROLW             | Rotate Left Word              |                                                                                                      | IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                                                                                              | 270C<br>271C<br>272C<br>273C                                           | 9999<br>9999<br>9999<br>hh li                            | 8<br>8<br>8<br>8                                         | - | - |         |       | Δ    | Δ   | Δ | 1 |
| ROR              | Rotate Right                  | Gardin 1111                                                                                          | IND8, X<br>IND8, Y<br>IND8, Z<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                                                             | 0E<br>1E<br>2E<br>170E<br>171E<br>172E<br>173E                         | ff<br>ff<br>9999<br>9999<br>9999<br>9999<br>hh il        | 8<br>8<br>8<br>8<br>8<br>8<br>8                          | — |   | _       |       | Δ    | Δ   | Δ | 2 |
| RORA             | Rotate Right A                |                                                                                                      | INH                                                                                                                                  | 370E                                                                   | -                                                        | 2                                                        |   | _ |         |       | Δ    | Δ   | Δ | 1 |
| RORB             | Rotate Right B                | تېرىتىتىي.<br>مەر                                                                                    | INH                                                                                                                                  | 371E                                                                   | -                                                        | 2                                                        | - |   | -       |       | Δ    | Δ   | Δ | 1 |
| RORD             | Rotate Right D                |                                                                                                      | INH                                                                                                                                  | 27FE                                                                   | -                                                        | 2                                                        | - | - |         |       | Δ    | Δ   | Δ |   |
| RORE             | Rotate Right E                |                                                                                                      | INH                                                                                                                                  | 277E                                                                   | -                                                        | 2                                                        | - |   | —       |       | Δ    | Δ   | Δ |   |
| RORW             | Rotate Right Word             |                                                                                                      | IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                                                                                              | 270E<br>271E<br>272E<br>273E                                           | 9999<br>9999<br>9999<br>hh li                            | 8<br>8<br>8<br>8                                         | - |   |         |       | Δ    | Δ   | Δ |   |
| RTI <sup>2</sup> | Return from Interrupt         | (SK : SP) + 2 ⇒ SK : SP<br>Pull CCR<br>(SK : SP) + 2 ⇒ SK : SP<br>Pull PC<br>(PK : PC) – 6 ⇒ PK : PC | INH                                                                                                                                  | 2777                                                                   | _                                                        | 12                                                       | Δ | Δ | Δ       | Δ     | Δ    | Δ   | Δ |   |
| RTS <sup>3</sup> | Return from<br>Subroutine     | (SK : SP) + 2 ⇒ SK : SP<br>Pull PK<br>(SK : SP) + 2 ⇒ SK : SP<br>Pull PC<br>(PK : PC) - 2 ⇒ PK : PC  | INH                                                                                                                                  | 27F7                                                                   | -                                                        | 12                                                       |   | - | _       |       | -    |     | - |   |
| SBA              | Subtract B from A             | $(A) - (B) \Rightarrow A$                                                                            | INH                                                                                                                                  | 370A                                                                   | —                                                        | 2                                                        | - |   | _       |       | Δ    | Δ   | Δ |   |
| SBCA             | Subtract with Carry<br>from A | (A) – (M) – C ⇒ A                                                                                    | IND8, X<br>IND8, Y<br>IND8, Z<br>IND16, X<br>IND16, X<br>IND16, Z<br>EXTX<br>EXTX<br>EXTX<br>EXTX<br>EXX<br>EXX<br>EXX<br>EXX<br>EXX | 42<br>52<br>62<br>1742<br>1752<br>1752<br>1762<br>2742<br>2752<br>2752 | ff<br>ff<br>9999<br>9099<br>hh<br>                       | 6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6 |   | _ |         | _     | Δ    | Δ   | Δ |   |

|          |                               | Instruction Se                                              | t Summ                                                                                                       | ary (Co                                                                                        | ontinued                                               | )                                                   |          |   |     |     |
|----------|-------------------------------|-------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|--------------------------------------------------------|-----------------------------------------------------|----------|---|-----|-----|
| Mnemonic | Operation                     | Description                                                 | Address                                                                                                      |                                                                                                | Instruction                                            |                                                     | Conditio |   |     |     |
| 0000     | Outransit Oraci               |                                                             | Mode                                                                                                         | Opcode                                                                                         | Operand                                                | Cycles                                              | SMVHEV   |   |     | / c |
| SBCB     | Subtract with Carry<br>from B | (B) – (M) – C ⇒ B                                           | IND8, X<br>IND8, Z<br>IND8, Z<br>IND8, Z<br>IND16, X<br>IND16, X<br>IND16, Z<br>E, X<br>E, X<br>E, Y<br>E, Z | C2<br>D2<br>E2<br>F2<br>17C2<br>17D2<br>17E2<br>27C2<br>27C2<br>27D2<br>27E2                   | ff<br>ff<br>9999<br>9999<br>9999<br>9090<br>hh li<br>— | 6662666666                                          |          | Δ | Δ.  | ΔΔ  |
| SBCD     | Subtract with Carry<br>from D | (D) – (M : M + 1) – C ⇒ D                                   | IND8, X<br>IND8, Y<br>IND8, Z<br>E, X<br>E, Y<br>E, Z<br>IMM16<br>IND16, X<br>IND16, Z<br>EXT                | 82<br>92<br>A2<br>2782<br>2792<br>27A2<br>37B2<br>37C2<br>37C2<br>37C2<br>37C2<br>37F2<br>37F2 | ff<br>ff<br>                                           | 6<br>6<br>6<br>6<br>4<br>6<br>6<br>6<br>6           |          |   |     | ΔΔ  |
| SBCE     | Subtract with Carry<br>from E | (E) – (M : M + 1) – C ⇒ E                                   | IMM16<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                                                             | 3732<br>3742<br>3752<br>3762<br>3772                                                           | hh II<br>9999<br>9999<br>9999<br>jj Kk                 | 4<br>6<br>6<br>6                                    |          | Δ | Δ   | ΔΔ  |
| SDE      | Subtract D from E             | (E) – (D)⇒ E                                                | INH                                                                                                          | 2779                                                                                           | -                                                      | 2                                                   |          | Δ | Δ . | ΔΔ  |
| STAA     | Store A                       | (A) ⇒ M                                                     | IND8, X<br>IND8, Y<br>IND8, Z<br>IND16, X<br>IND16, Z<br>IND16, Z<br>EXT<br>E, X<br>E, X<br>E, Z             | 4A<br>5A<br>6A<br>174A<br>175A<br>176A<br>274A<br>275A<br>276A                                 | ff<br>ff<br>9999<br>9999<br>5098<br>hh<br>—<br>—       | 4<br>4<br>6<br>6<br>6<br>6<br>4<br>4<br>4           |          | Δ | Δ   | 0 — |
| STAB     | Store B                       | (B) ⇒ M                                                     | IND8, X<br>IND8, Y<br>IND8, Z<br>IND16, X<br>IND16, X<br>IND16, Z<br>EXT<br>E, X<br>E, X<br>E, Z             | CA<br>DA<br>EA<br>17CA<br>17DA<br>17FA<br>27CA<br>27CA<br>27DA<br>27EA                         | ff<br>ff<br>9999<br>9999<br>9999<br>9999<br>hh li<br>— | 4<br>4<br>6<br>6<br>6<br>6<br>4<br>4<br>4           |          | Δ | Δ   | 0 — |
| STD      | Store D                       | (D) ⇒ M : M + 1                                             | IND8, X<br>IND8, Y<br>IND8, Z<br>E, X<br>E, Y<br>E, Z<br>IND16, X<br>IND16, Z<br>EXT                         | 8A<br>9A<br>278A<br>279A<br>27AA<br>37CA<br>37DA<br>37EA<br>37FA                               | ff<br>ff<br>                                           | 4<br>4<br>6<br>6<br>6<br>6<br>4<br>4<br>4<br>4<br>4 |          | Δ | Δ   | 0   |
| STE      | Store E                       | (E) ⇒ M : M + 1                                             | IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                                                                      | 3742<br>3752<br>3762<br>3772                                                                   | 9999<br>9999<br>9999<br>jj kk                          | 6<br>6<br>6<br>6                                    |          | Δ | Δ   | 0   |
| STED     | Store Concatenated<br>D and E | $(E) \Rightarrow M : M + 1$ $(D) \Rightarrow M + 2 : M + 3$ | EXT                                                                                                          | 2773                                                                                           | hh II                                                  | 8                                                   |          | - |     |     |
| STS      | Store SP                      | (SP) ⇒ M : M + 1                                            | IND8, X<br>IND8, Y<br>IND8, Z<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                                     | 8F<br>9F<br>AF<br>178F<br>179F<br>17AF<br>17BF                                                 | ff<br>ff<br>9999<br>9999<br>9999<br>9999<br>hh li      | 4<br>4<br>6<br>6<br>6                               |          | Δ | Δ   | 0 — |

|          | T                    | Instruction Se                                                                                                                                                                                           |                                                                                                           | ary (Co                                                                        |                                                                     | )                                                   |   |      |            |    |               |          |   |   |
|----------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|---------------------------------------------------------------------|-----------------------------------------------------|---|------|------------|----|---------------|----------|---|---|
| Mnemonic | Operation            | Description                                                                                                                                                                                              | Address                                                                                                   | 0                                                                              | Instruction                                                         | Quales                                              | - | Taas |            |    | on Co         |          |   | _ |
| STX      | Store IX             | (IX) ⇒ M : M + 1                                                                                                                                                                                         | Mode<br>IND8, X<br>IND8, Y<br>IND8, Z<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                          | Opcode<br>8C<br>9C<br>AC<br>178C<br>179C<br>17AC<br>17BC                       | <b>Operand</b><br>ff<br>ff<br>9999<br>9999<br>9999<br>9999<br>hh ll | Cycles<br>4<br>4<br>6<br>6<br>6<br>6<br>6           | - |      |            | EV | <b>N</b><br>△ | <b>Ζ</b> | 0 |   |
| STY      | Store IY             | (IY) ⇒ M : M + 1                                                                                                                                                                                         | IND8, X<br>IND8, Y<br>IND8, Z<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                                  | 8D<br>9D<br>AD<br>178D<br>179D<br>17AD<br>17BD                                 | ff<br>ff<br>9999<br>9999<br>9999<br>9999<br>hh li                   | 4<br>4<br>6<br>6<br>6<br>6                          | - |      | ·          |    | Δ             | Δ        | 0 |   |
| STZ      | Store Z              | (IZ) ⇒ M : M + 1                                                                                                                                                                                         | IND8, X<br>IND8, Y<br>IND8, Z<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                                  | 8E<br>9E<br>178E<br>179E<br>179E<br>17AE<br>17BE                               | ff<br>ff<br>9999<br>9999<br>9999<br>5999<br>hh ll                   | 4<br>4<br>6<br>6<br>6                               | - |      | ·          | _  | Δ             | Δ        | 0 |   |
| SUBA     | Subtract from A      | (A) – (M) ⇒ A                                                                                                                                                                                            | IND8, X<br>IND8, Y<br>IND8, Z<br>IND16, Z<br>IND16, Y<br>IND16, Z<br>EXT<br>E, X<br>E, Y<br>E, Z          | 40<br>50<br>60<br>1740<br>1750<br>1760<br>1770<br>2740<br>2750<br>2760         | ff<br>ff<br>9999<br>9999<br>9999<br>hh li<br>—                      | 6<br>6<br>2<br>6<br>6<br>6<br>6<br>6<br>6<br>6      |   |      | . <u> </u> |    | Δ             | Δ        | Δ | Δ |
| SUBB     | Subtract from B      | (B) – (M) ⇒ B                                                                                                                                                                                            | IND8, X<br>IND8, Y<br>IND8, Z<br>IMM8<br>IND16, X<br>IND16, Y<br>IND16, Z<br>E, X<br>E, X<br>E, Y<br>E, Z | C0<br>D0<br>E0<br>17C0<br>17D0<br>17E0<br>17F0<br>27C0<br>27D0<br>27E0         | ff<br>ff<br>9999<br>9999<br>0099<br>hh li<br>—                      | 6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6 | - |      |            | _  | Δ             | Δ        | Δ | Δ |
| SUBD     | Subtract from D      | (D) – (M : M + 1) ⇒ D                                                                                                                                                                                    | IND8, X<br>IND8, Y<br>IND8, Z<br>E, X<br>E, Y<br>IND16, X<br>IND16, X<br>IND16, Z<br>EXT                  | 80<br>90<br>A0<br>2780<br>2790<br>27A0<br>37B0<br>37C0<br>37D0<br>37E0<br>37F0 | ff<br>ff<br>                                                        | 6<br>6<br>6<br>6<br>6<br>4<br>6<br>6<br>6<br>6      |   |      |            |    | Δ             | Δ        | Δ | Δ |
| SUBE     | Subtract from E      | (E) – (M : M + 1) ⇒ E                                                                                                                                                                                    | IMM16<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                                                          | 3730<br>3740<br>3750<br>3760<br>3770                                           | hh II<br>9999<br>9999<br>9999<br>jj kk                              | 4<br>6<br>6<br>6                                    | - |      |            | -  | Δ             | Δ        | Δ | Δ |
| SWI      | Software Interrupt   | $\begin{array}{l} (PK:PC)+2 \Rightarrow PK:PC\\ Push(PC)\\ (SK:SP)-2 \Rightarrow SK:SP\\ Push(CCR)\\ (SK:SP)-2 \Rightarrow SK:SP\\ \mathfrak{SO}\Rightarrow PK\\ SWI \ Vector\Rightarrow PC \end{array}$ | INH                                                                                                       | 3720                                                                           |                                                                     | 16                                                  | _ |      |            | -  | _             |          |   |   |
| SXT      | Sign Extend B into A | If B7 = 1<br>then A = \$FF<br>else A = \$00                                                                                                                                                              | INH                                                                                                       | 27F8                                                                           | -                                                                   | 2                                                   | _ |      |            |    | Δ             | Δ        | _ |   |
| TAB      | Transfer A to B      | (A) ⇒ B                                                                                                                                                                                                  | INH                                                                                                       | 3717                                                                           | -                                                                   | 2                                                   | — |      |            |    | Δ             | Δ        | 0 |   |
| TAP      | Transfer A to CCR    | (A[7:0]) ⇒ CCR[15:8]                                                                                                                                                                                     | INH                                                                                                       | 37FD                                                                           |                                                                     | 4                                                   | Δ | Δ    | Δ          | Δ  | Δ             | Δ        | Δ | Δ |
| TBA      | Transfer B to A      | (B) ⇒ A                                                                                                                                                                                                  | INH                                                                                                       | 3707                                                                           | -                                                                   | 2                                                   | _ |      |            | -  | Δ             | Δ        | 0 |   |
| TBEK     | Transfer B to EK     | (B) ⇒ EK                                                                                                                                                                                                 | INH                                                                                                       | 27FA                                                                           | -                                                                   | 2                                                   | - | _    | _          | -  | —             |          |   | _ |

5

|                  |                                                              | instruction Se                                                                                                                | t Summ                                                                   | ary (Co                                        | ntinued                                           | )                          |                              |
|------------------|--------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|------------------------------------------------|---------------------------------------------------|----------------------------|------------------------------|
| Mnemonic         | Operation                                                    | Description                                                                                                                   | Address                                                                  |                                                | Instruction                                       |                            | Condition Codes              |
|                  |                                                              |                                                                                                                               | Mode                                                                     | Opcode                                         | Operand                                           | Cycles                     | S MV H EV N Z V C            |
| TBSK             | Transfer B to SK                                             | (B) ⇒ SK                                                                                                                      | INH                                                                      | 379F                                           | -                                                 | 2                          |                              |
| ТВХК             | Transfer B to XK                                             | (B) ⇒ XK                                                                                                                      | INH                                                                      | 379C                                           | -                                                 | 2                          |                              |
| ТВҮК             | Transfer B to YK                                             | (B) ⇒ YK                                                                                                                      | INH                                                                      | 379D                                           | -                                                 | 2                          |                              |
| TBZK             | Transfer B to ZK                                             | (B) ⇒ ZK                                                                                                                      | INH                                                                      | 379E                                           | -                                                 | 2                          |                              |
| TDE              | Transfer D to E                                              | (D) ⇒ E                                                                                                                       | INH                                                                      | 277B                                           | -                                                 | 2                          | <u>^ ^ ^ -</u>               |
| TDMSK            | Transfer D to<br>XMSK : YMSK                                 | (D[15:8]) ⇒ X MASK<br>(D[7:0]) ⇒ Y MASK                                                                                       | INH                                                                      | 372F                                           | -                                                 | 2                          |                              |
| TDP <sup>1</sup> | Transfer D to CCR                                            | (D) ⇒ CCR[15:4]                                                                                                               | INH                                                                      | 372D                                           | —                                                 | 4                          | ΔΔΔΔΔΔΔ                      |
| TED              | Transfer E to D                                              | (E) ⇒ D                                                                                                                       | INH                                                                      | 27FB                                           | -                                                 | 2                          | <u> </u>                     |
| TEDM             | Transfer E and D to<br>AM[31:0]<br>Sign Extend AM            | (D) ⇒ AM[15:0]<br>(E) ⇒ AM[31:16]<br>AM[32:35] = AM31                                                                         | INH                                                                      | 27B1                                           | _                                                 | 4                          | - 0 - 0                      |
| ТЕКВ             | Transfer EK to B                                             | \$0 ⇒ B[7:4]<br>(EK) ⇒ B[3:0]                                                                                                 | INH                                                                      | 27BB                                           | —                                                 | 2                          |                              |
| ТЕМ              | Transfer E to<br>AM[31:16]<br>Sign Extend AM<br>Clear AM LSB | (E) ⇒ AM[31:16]<br>\$00 ⇒ AM[15:0]<br>AM[32:35] = AM31                                                                        | INH                                                                      | 2782                                           | -                                                 | 4                          | - 0 - 0                      |
| TMER             | Transfer AM to E<br>Rounded                                  | Rounded (AM) $\Rightarrow$ Temp<br>If (SM • (EV + MV))<br>then Saturation $\Rightarrow$ E<br>else Temp[31:16] $\Rightarrow$ E | INH                                                                      | 27B4                                           | -                                                 | 6                          | — Δ — Δ Δ Δ — —              |
| TMET             | Transfer AM to E<br>Truncated                                | If $(SM \bullet (EV + MV))$<br>then Saturation $\Rightarrow E$<br>else AM[31:16] $\Rightarrow E$                              | INH                                                                      | 27B5                                           | -                                                 | 2                          | Δ Δ                          |
| TMXED            | Transfer AM to<br>IX : E : D                                 | AM[35:32] ⇒ IX[3:0]<br>AM35 ⇒ IX[15:4]<br>AM[31:16] ⇒ E<br>AM[15:0] ⇒ D                                                       | INH                                                                      | 27B3                                           | -                                                 | 6                          |                              |
| ТРА              | Transfer CCR MSB to<br>A                                     | (CCR[15:8]) ⇒ A                                                                                                               | INH                                                                      | 37FC                                           | -                                                 | 2                          |                              |
| TPD              | Transfer CCR to D                                            | $(CCR) \Rightarrow D$                                                                                                         | INH                                                                      | 372C                                           |                                                   | 2                          |                              |
| TSKB             | Transfer SK to B                                             | (SK) ⇒ B[3:0]<br>\$0 ⇒ B[7:4]                                                                                                 | INH                                                                      | 37AF                                           | -                                                 | 2                          |                              |
| TST              | Test for Zero or<br>Minus                                    | (M) - \$00                                                                                                                    | IND8, X<br>IND8, Y<br>IND8, Z<br>IND16, X<br>IND16, Y<br>IND16, Z<br>EXT | 06<br>16<br>26<br>1706<br>1716<br>1726<br>1736 | ff<br>ff<br>9999<br>9999<br>9999<br>9999<br>hh ll | 6<br>6<br>6<br>6<br>6<br>6 | <u> </u>                     |
| TSTA             | Test A for<br>Zero or Minus                                  | (A) – \$00                                                                                                                    | INH                                                                      | 3706                                           | -                                                 | 2                          | <u>\ \ \ 0 0</u>             |
| TSTB             | Test B for<br>Zero or Minus                                  | (B) <b>-</b> \$00                                                                                                             | INH                                                                      | 3716                                           | -                                                 | 2                          | <u>^</u> <u>^</u> <u>0</u> 0 |
| TSTD             | Test D for<br>Zero or Minus                                  | (D) – \$0000                                                                                                                  | INH                                                                      | 27F6                                           | -                                                 | 2                          | <u>\ \ \ 0 0</u>             |
| TSTE             | Test E for<br>Zero or Minus                                  | (E) – \$0000                                                                                                                  | INH                                                                      | 2776                                           | —                                                 | 2                          | <u>\ \ \ 0 0</u>             |
| TSTW             | Test for<br>Zero or Minus Word                               | (M : M + 1) – \$0000                                                                                                          | IND16, X<br>IND16, Y<br>IND16, Z<br>EXT                                  | 2706<br>2716<br>2726<br>2736                   | 9999<br>9999<br>9999<br>hh li                     | 6<br>6<br>6                | <u> </u>                     |
| TSX              | Transfer SP to X                                             | (SK : SP) + 2 ⇒ XK : IX                                                                                                       | INH                                                                      | 274F                                           |                                                   | 2                          |                              |
| TSY              | Transfer SP to Y                                             | (SK : SP) + 2 ⇒ YK : IY                                                                                                       | INH                                                                      | 275F                                           |                                                   | 2                          |                              |
| TSZ              | Transfer SP to Z                                             | (SK : SP) + 2 ⇒ ZK : IZ                                                                                                       | INH                                                                      | 276F                                           |                                                   | 2                          |                              |
| ТХКВ             | Transfer XK to B                                             | $\begin{array}{c} \$0 \Rightarrow B[7:4] \\ (XK) \Rightarrow B[3:0] \end{array}$                                              | INH                                                                      | 37AC                                           | -                                                 | 2                          |                              |
| TXS              | Transfer X to SP                                             | (XK : IX) – 2 ⇒ SK : SP                                                                                                       | INH                                                                      | 374E                                           |                                                   | 2                          |                              |
| TXY              | Transfer X to Y                                              | (XK : IX) ⇒ YK : IY                                                                                                           | INH                                                                      | 275C                                           | —                                                 | 2                          |                              |
| TXZ              | Transfer X to Z                                              | (XK : IX) ⇒ ZK : IZ                                                                                                           | INH                                                                      | 276C                                           | -                                                 | 2                          |                              |
| түкв             | Transfer YK to B                                             | \$0 ⇒ B[7:4]<br>(YK) ⇒ B[3:0]                                                                                                 | INH                                                                      | 37AD                                           | -                                                 | 2                          |                              |
| TYS              | Transfer Y to SP                                             | (YK : IY) – 2 ⇒ SK : SP                                                                                                       | INH                                                                      | 375E                                           | -                                                 | 2                          |                              |
| TYX              | Transfer Y to X                                              | $(YK : IY) \Rightarrow XK : IX$                                                                                               | INH                                                                      | 274D                                           |                                                   | 2                          |                              |

MOTOROLA 5–52

#### CENTRAL PROCESSING UNIT

MC68HC16Z1 USER'S MANUAL

#### Instruction Set Summary (Concluded)

| Mnemonic | Operation          | Description                   | Address | Instruction |         |        |   | Condition Codes |    |    |     |   |   |   |
|----------|--------------------|-------------------------------|---------|-------------|---------|--------|---|-----------------|----|----|-----|---|---|---|
|          |                    |                               | Mode    | Opcode      | Operand | Cycles | S | M               | VF | EV | N   | Z | V | С |
| TYZ      | Transfer Y to Z    | (YK : IY) ⇒ ZK : IZ           | INH     | 276D        | _       | 2      | - |                 |    |    |     |   |   | _ |
| ТΖКВ     | Transfer ZK to B   | \$0 ⇒ B[7:4]<br>(ZK) ⇒ B[3:0] | INH     | 37AE        | -       | 2      | - |                 |    |    | -   |   |   | - |
| TZS      | Transfer Z to SP   | (ZK : IZ) – 2 ⇒ SK : SP       | INH     | 376E        | -       | 2      | - |                 |    |    | -   |   |   |   |
| TZX      | Transfer Z to X    | (ZK : IZ) ⇒ XK : IX           | INH     | 274E        |         | 2      | - |                 |    |    |     |   |   | - |
| TZY      | Transfer Z to Y    | (ZK : IZ) ⇒ ZK : IY           | INH     | 275E        | -       | 2      | - |                 |    |    |     |   |   |   |
| WAI      | Wait for Interrupt | WAIT                          | INH     | 27F3        | -       | 8      | - |                 |    |    | -   |   |   | _ |
| XGAB     | Exchange A with B  | (A) ⇔(B)                      | INH     | 371A        | -       | 2      | - |                 |    |    | - 1 |   |   |   |
| XGDE     | Exchange D with E  | (D) ⇔(E)                      | INH     | 277A        |         | 2      | - |                 |    |    |     |   |   |   |
| XGDX     | Exchange D with X  | (D) ⇔ (IX)                    | INH     | 37CC        |         | 2      | - |                 |    |    | -   |   | _ | _ |
| XGDY     | Exchange D with Y  | (D) ⇔ (IY)                    | INH     | 37DC        |         | 2      | - |                 |    |    |     |   | _ | _ |
| XGDZ     | Exchange D with Z  | (D) ⇔(IZ)                     | INH     | 37EC        |         | 2      | - |                 |    |    | -   |   | _ | - |
| XGEX     | Exchange E with X  | (E) ⇔ (IX)                    | INH     | 374C        |         | 2      | - |                 |    |    | -   | _ |   | _ |
| XGEY     | Exchange E with Y  | (E) ⇔(IY)                     | INH     | 375C        |         | 2      | - |                 |    |    | -   |   | _ | - |
| XGEZ     | Exchange E with Z  | (E) ⇔(IZ)                     | INH     | 376C        |         | 2      | - |                 |    |    |     |   |   | _ |

NOTES:

CCR[15:4] change according to results of operation — PK field is not affected.
 CCR[15:0] change according to copy of CCR pulled from stack.

3. PK field changes according to state pulled from stack --- the rest of the CCR is not affected.

## Instruction Set Abbreviations and Symbols

|        |   | Instruction Set A                        | obreviations | an | la Symbols                            |
|--------|---|------------------------------------------|--------------|----|---------------------------------------|
| Α      |   | Accumulator A                            | Х            | —  | Register used in operation            |
| AM     | _ | Accumulator M                            | м            |    | Address of one memory byte            |
| в      |   | Accumulator B                            | M +1         |    | Address of byte at M + \$0001         |
| CCR    |   | Condition code register                  | M:M+1        |    | Address of one memory word            |
| D      |   | Accumulator D                            | ()X          | -  | Contents of address pointed to by IX  |
| E      |   | Accumulator E                            | ()Y          |    | Contents of address pointed to by IY  |
| EK     |   | Extended addressing extension field      | ()Z          |    | Contents of address pointed to by IZ  |
| IR     |   | MAC multiplicand register                | E,X          |    | IX with E offset                      |
| HR     |   | MAC multiplier register                  | E, Y         |    | IY with E offset                      |
| X      |   | Index register X                         | E, Z         |    | IZ with E offset                      |
| ĨŶ     |   | Index register Y                         | EXT          | _  | Extended                              |
| IZ     |   | Index register Z                         | EXT20        |    | 20-bit extended                       |
| ĸ      |   | Address extension register               | IMM8         |    | 8-bit immediate                       |
| PC     |   | Program counter                          | IMM16        |    | 16-bit immediate                      |
| PK     | _ | Program counter extension field          | IND8, X      |    | IX with unsigned 8-bit offset         |
| SK     |   | Stack pointer extension field            | IND8, Y      |    | IY with unsigned 8-bit offset         |
| SL.    |   | Multiply and accumulate sign latch       | IND8, Z      |    | IZ with unsigned 8-bit offset         |
| SP     |   | Stack pointer                            | IND16, X     |    | IX with signed 16-bit offset          |
| хĸ     |   | Index register X extension field         | IND16, Y     |    | IY with signed 16-bit offset          |
| YK     | _ | Index register Y extension field         | IND16, Z     |    | IZ with signed 16-bit offset          |
| ZK     |   | Index register Z extension field         | IND20, X     |    | IX with signed 20-bit offset          |
| XMSK   |   | Modulo addressing index register X mask  | IND20, Y     |    | IY with signed 20-bit offset          |
| YMSK   |   | Modulo addressing index register Y mask  | IND20, Z     |    | IZ with signed 20-bit offset          |
| S      |   | Stop disable control bit                 | INH          |    | Inherent                              |
| мv     |   | AM overflow indicator                    | IXP          |    | Post-modified indexed                 |
| н      |   | Half carry indicator                     | REL8         |    | 8-bit relative                        |
| EV     |   | AM extended overflow indicator           | REL16        |    | 16-bit relative                       |
| N      |   | Negative indicator                       | b            |    | 4-bit address extension               |
| z      |   | Zero indicator                           | ff           |    | 8-bit unsigned offset                 |
| v      |   | Twos complement overflow indicator       | 9999         |    | 16-bit signed offset                  |
| ċ      | _ | Carry/borrow indicator                   | hh           |    | High byte of 16-bit extended address  |
| IP     |   | Interrupt priority field                 | ü            |    | 8-bit immediate data                  |
| SM     |   | Saturation mode control bit              | <br>jj       |    | High byte of 16-bit immediate data    |
| PK     |   | Program counter extension field          | ,,,<br>kk    |    | Low byte of 16-bit immediate data     |
|        |   | Bit not affected                         |              |    | Low byte of 16-bit extended address   |
| Δ      |   | Bit changes as specified                 | <br>mm       |    | 8-bit mask                            |
| ō      |   | Bit cleared                              | mmmm         |    | 16-bit mask                           |
| 1      |   | Bit set                                  | rr           |    | 8-bit unsigned relative offset        |
| м      |   | Memory location used in operation        | rrrr         | _  | 16-bit signed relative offset         |
| R      | _ | Result of operation                      | xo           |    | MAC index register X offset           |
| s      |   | Source data                              | yo           |    | MAC index register Y offset           |
| Ŭ      |   |                                          | je<br>z      |    | 4-bit zero extension                  |
|        |   |                                          | -            |    |                                       |
| +      |   | Addition                                 | •            |    | AND                                   |
| т<br>• |   | Subtraction or negation (2's complement) | +            |    | Inclusive OR (OR)                     |
|        | _ | Multiplication                           | ⊕            |    | Exclusive OR (EOR)                    |
| *      |   | •                                        |              |    | • •                                   |
| /      |   | Division                                 | NOT          |    | Complementation                       |
| >      |   | Greater                                  | :            | —  | Concatenation                         |
| <      |   | Less                                     | ⇒            |    | Transferred                           |
| =      |   | Equal                                    | ⇔            | _  | Exchanged                             |
| 2      |   | Equal or greater                         | ±            |    | Sign bit; also used to show tolerance |
| ≤      |   | Equal or less                            | ×            |    | Sign extension                        |
| ¥      | — | Not equal                                | %            | —  | Binary value                          |
|        |   |                                          | \$           |    | Hexadecimal value                     |
|        |   |                                          |              |    |                                       |

## 5.7 Comparison of CPU16 and MC68HC11 Instruction Sets

Most HC11 instructions are a source-code compatible subset of the CPU16 instruction set. However, certain HC11 instructions have been replaced by functionally equivalent HC16 instructions, and some CPU16 instructions with the same mnemonics as HC11 instructions operate differently.

Table 5–32 shows HC11 instructions that have either been replaced by CPU16 instructions or that operate differently in the CPU16. Replacement instructions are not identical to HC11 instructions — HC11 code must be altered to establish proper preconditions.

All CPU16 instruction execution times differ from those of the HC11. Refer to the *CPU16 Reference Manual* (CPU16RM/AD) for details.

| HC11 Instruction | HC16 Implementation                                                                        |
|------------------|--------------------------------------------------------------------------------------------|
| BHS              | BCC Only                                                                                   |
| BLO              | BCS Only                                                                                   |
| BSR              | Generates a different stack frame                                                          |
| CLC              | Replaced by ANDP                                                                           |
| CLI              | Replaced by ANDP                                                                           |
| CLV              | Replaced by ANDP                                                                           |
| DES              | Replaced by AIS                                                                            |
| DEX              | Replaced by AIX                                                                            |
| DEY              | Replaced by AIY                                                                            |
| INS              | Replaced by AIS                                                                            |
| INX              | Replaced by AIX                                                                            |
| INY              | Replaced by AIY                                                                            |
| JMP              | IND8 addressing modes replaced by IND20 and EXT modes                                      |
| JSR              | IND8 addressing modes replaced by IND20 and EXT modes<br>Generates a different stack frame |
| LSL, LSLD        | Use ASL instructions*                                                                      |
| PSHX             | Replaced by PSHM                                                                           |
| PSHY             | Replaced by PSHM                                                                           |
| PULX             | Replaced by PULM                                                                           |
| PULY             | Replaced by PULM                                                                           |
| RTI              | Reloads PC and CCR only                                                                    |
| RTS              | Uses two-word stack frame                                                                  |
| SEC              | Replaced by ORP                                                                            |
| SEI              | Replaced by ORP                                                                            |
| SEV              | Replaced by ORP                                                                            |
| STOP             | Replaced by LPSTOP                                                                         |
| ТАР              | CPU16 CCR bits differ from HC11<br>CPU16 interrupt priority scheme differs from HC11       |
| ТРА              | CPU16 CCR bits differ from HC11<br>CPU16 interrupt priority scheme differs from HC11       |
| TSX              | Adds 2 to SK : SP before transfer to XK : IX                                               |
| TSY              | Adds 2 to SK : SP before transfer to YK : IY                                               |
| TXS              | Subtracts 2 from XK : IX before transfer to SK : SP                                        |
| TXY              | Transfers XK field to YK field                                                             |
| TYS              | Subtracts 2 from YK : IY before transfer to SK : SP                                        |
| TYX              | Transfers YK field to XK field                                                             |
| WAI              | Waits indefinitely for interrupt or reset<br>Generates a different stack frame             |

## Table 5–32. HC16 Implementation of HC11 Instructions

\*Motorola assemblers automatically translate ASL mnemonics

### 5.8 Instruction Format

CPU16 instructions consist of an 8-bit opcode, which may be preceded by an 8-bit prebyte and followed by one or more operands.

Opcodes are mapped in four 256-instruction pages. Page 0 opcodes stand alone, but Page 1, 2, and 3 opcodes are pointed to by a prebyte code on Page 0. The prebytes are \$17 (Page 1), \$27 (Page 2), and \$37 (Page 3).

Operands can be 4 bits, 8 bits or 16 bits in length. However, because the CPU16 fetches 16-bit instruction words from even byte boundaries, each instruction must contain an even number of bytes.

Operands are organized as bytes, words, or a combination of bytes and words. Operands of 4-bits are either zero-extended to 8 bits, or packed two to a byte. The largest instructions are six bytes in length. Size, order, and function of operands are evaluated when an instruction is decoded.

A Page 0 opcode and an 8-bit operand can be fetched simultaneously. Instructions that use 8-bit indexed, immediate, and relative addressing modes have this form — code written with these instructions is very compact.

Table 5–33 shows basic CPU16 instruction formats.

### Table 5–33. Basic Instruction Formats

|    |    |    |     |       | 8-Bi   | t Opcod  | e witi | h 8-Bit    | Ор        | erand             |       |       |        |           |   |
|----|----|----|-----|-------|--------|----------|--------|------------|-----------|-------------------|-------|-------|--------|-----------|---|
| 15 | 14 | 13 | 12  | 11    | 10     | 9        | 8      | 7          | 6         | 5                 | 4     | 3     | 2      | 1         | 0 |
|    |    |    | Ор  | code  |        |          |        |            |           |                   | Оре   | rand  |        |           |   |
|    |    |    |     | 8-B   | lit Op | code wi  | th 4-8 | Bit Inde   | ex l      | Extensio          | ns    |       |        |           |   |
| 15 | 14 | 13 | 12  | 11    | 10     | 9        | 8      | 7          | 6         | 5                 | 4     | 3     | 2      | 1         | 0 |
|    |    |    | Ор  | code  |        |          |        | )          | (Ex       | tension           |       |       | Y Exte | ension    |   |
| 45 |    | 10 | 12  | 11    |        | -Bit Ope |        | Argun<br>7 | nent<br>6 | t <b>(s)</b><br>5 | 4     | 3     | 2      |           | • |
| 15 | 14 | 13 |     |       | 10     | 9        | 8      | /          | 0         | 5                 |       |       | 2      | 1         | 0 |
|    |    |    | Up  | code  |        |          |        |            |           |                   | Ope   | orand |        |           |   |
|    |    |    |     |       |        |          | Opera  |            |           |                   |       |       |        |           |   |
| a  |    |    |     |       |        |          | Opera  | na(s)      |           |                   |       |       |        |           |   |
|    |    |    |     | 8-Rit | Onco   | de with  | 8-Bit  | Prehvt     | . 1       | lo Arau           | ment  |       |        |           |   |
| 15 | 14 | 13 | 12  | 11    | 10     | 9        | 8      | 7          | •, •<br>6 | 5                 | 4     | 3     | 2      | 1         | 0 |
|    |    |    |     | byte  |        |          | Ť      |            |           |                   |       | code  |        | · · · · · |   |
|    |    |    |     |       |        |          | I.     |            |           |                   |       |       |        |           |   |
|    |    |    |     | 8-Bit | Орсо   | de with  | 8-Bit  | Preby      | te,       | Argume            | nt(s) |       |        |           |   |
| 15 | 14 | 13 | 12  | 11    | 10     | 9        | 8      | 7          | 6         | 5                 | 4     | 3     | 2      | 1         | 0 |
|    |    |    | Pre | byte  |        |          |        |            |           |                   | Ор    | code  |        |           |   |
|    |    |    |     |       |        | 1        | Opera  | nd(s)      |           |                   |       |       |        |           |   |
|    |    |    |     |       |        |          | Opera  | nd(s)      |           |                   |       |       |        |           |   |
|    |    |    |     |       |        |          |        |            |           |                   |       |       |        |           |   |
|    |    |    |     |       |        | Opcode   |        |            |           | -                 |       |       |        |           |   |
| 15 | 14 | 13 | 12  | 11    | 10     | 9        | 8      | 7          | 6         | 5                 |       | 3     | 2      | 1         | 0 |
|    |    |    | Ор  | code  |        |          |        |            |           | \$0               |       |       | Exte   | nsion     |   |
|    | 1  |    |     |       |        |          | Opera  | and        |           |                   |       |       |        |           |   |

### 5.9 Execution Model

This description builds up a conceptual model of the mechanism the CPU16 uses to fetch and execute instructions. The functional divisions in the model do not necessarily correspond to physical subunits of the microprocessor.

As shown in Figure 5–4, there are three functional blocks involved in fetching, decoding, and executing instructions. These are the microsequencer, the instruction pipeline, and the execution unit. These elements function concurrently — at any given time, all three may be active.

CENTRAL PROCESSING UNIT



Figure 5-4. Instruction Execution Model

### 5.9.1 Microsequencer

The microsequencer controls the order in which instructions are fetched, advanced through the pipeline, and executed. It increments the program counter and generates multiplexed external tracking signals IPIPE0 and IPIPE1 from internal signals that control execution sequence.

## 5.9.2 Instruction Pipeline

The pipeline is a three stage FIFO that holds instructions while they are decoded and executed. Depending upon instruction size, as many as three instructions can be in the pipeline at one time (single-word instructions, one held in Stage C, one being executed in Stage B, and one latched in Stage A).

## 5.9.3 Execution Unit

The execution unit evaluates opcodes, interfaces with the microsequencer to advance instructions through the pipeline, and performs instruction operations.

#### 5.10 Execution Process

Fetched opcodes are latched into Stage A, then advanced to Stage B. Opcodes are evaluated in Stage B. The execution unit can access operands in either Stage A or Stage B (Stage B accesses are limited to 8-bit operands). When execution is complete, opcodes are moved from Stage B to Stage C, where they remain until the next instruction is complete.

A prefetch mechanism in the microsequencer reads instruction words from memory and increments the program counter. When instruction execution begins, the program counter points to an address six bytes after the address of the first word of the instruction being executed.

The number of machine cycles necessary to complete an execution sequence varies according to the complexity of the instruction. Refer to the *CPU16 Reference Manual* (CPU16RM/AD) for details.

### 5.10.1 Changes in Program Flow

5

When program flow changes, instructions are fetched from a new address. Before execution can begin at the new address, instructions and operands from the previous instruction stream must be removed from the pipeline. If a change in flow is temporary, a return address must be stored, so that execution of the original instruction stream can resume after the change in flow.

At the time an instruction that causes a change in program flow executes, PK : PC point to the address of the first word of the instruction + \$0006. During execution of the instruction, PK : PC is loaded with the address of the first instruction word in the new instruction stream. However, Stages A and B still contain words from the old instruction stream. Extra processing steps must be performed prior to execution from the new instruction stream.

#### 5.11 Instruction Timing

CPU16 instruction execution time has three components:

Bus cycles required to prefetch the next instruction Bus cycles required for operand accesses Time required for internal operations

A bus cycle requires a minimum of two system clock periods. If the access time of a memory device is greater than two clock periods, bus cycles will be longer. However, all bus cycles must be an integer number of clock periods. CPU16 internal operations are always an integer multiple of two clock periods.

CENTRAL PROCESSING UNIT

Dynamic bus sizing affects bus cycle time. The system integration module manages all accesses. Refer to **SECTION 4 SYSTEM INTEGRATION MODULE** for more information.

The CPU16 does not execute more than one instruction at a time. The total time required to execute a particular instruction stream can be calculated by summing the individual execution times of each instruction in the stream.

Total execution time is calculated using the expression

$$(CL_T) = (CL_P) + (CL_O) + (CL_I)$$

Where:

 $(CL_T)$  = Total clock periods per instruction  $(CL_I)$  = Clock periods used for internal operation  $(CL_P)$  = Clock periods used for program access  $(CL_O)$  = Clock periods used for operand access

A detailed discussion of instruction timing parameters is beyond the scope of this manual. Refer to the *CPU16 Reference Manual* (CPU16RM/AD) for more information on this topic.

### 5.12 Exceptions

An exception is an event that preempts normal instruction process. Exception processing makes the transition from normal instruction execution to execution of a routine that deals with an exception.

Each exception has an assigned vector that points to an associated handler routine. Exception processing includes all operations required to transfer control to a handler routine, but does not include execution of the handler routine itself. Keep the distinction between exception processing and execution of an exception handler in mind while reading this section.

## 5.12.1 Exception Vectors

An exception vector is the address of a routine that handles an exception. Exception vectors are contained in a data structure called the exception vector table, which is located in the first 512 bytes of Bank 0.

All vectors except the reset vector consist of one word and reside in data space. The reset vector consists of four words that reside in program space. (Refer to **SECTION 4 SYSTEM INTEGRATION MODULE** for information concerning address space types and the function code outputs.) There are 52 predefined or reserved vectors, and 200 user-defined vectors. Each vector is assigned an 8-bit number. Vector numbers for some exceptions are generated by external devices; others are supplied by the processor. There is a direct mapping of vector number to vector table address. The processor left shifts the vector number one place (multiplies by two) to convert it to an address.

| Vector<br>Number | Vector<br>Address | Address<br>Space | Type of<br>Exception             |  |
|------------------|-------------------|------------------|----------------------------------|--|
| 0                | 0000              | Р                | RESET — Initial ZK, SK, and PK   |  |
|                  | 0002              | Р                | RESET — Initial PC               |  |
|                  | 0004              | Р                | RESET — Initial SP               |  |
|                  | 0006              | Р                | RESET — Initial IZ (Direct Page) |  |
| 4                | 0008              | D                | BKPT (Breakpoint)                |  |
| 5                | 000A              | D                | BERR (Bus Error)                 |  |
| 6                | 000C              | D                | SWI (Software Interrupt)         |  |
| 7                | 000E              | D                | Illegal Instruction              |  |
| 8                | 0010              | D                | Division by Zero                 |  |
| 9-E              | 0012-001C         | D                | Unassigned, Reserved             |  |
| F                | 001E              | D                | Uninitialized Interrupt          |  |
| 10               | 0020              | D                | Unassigned, Reserved             |  |
| 11               | 0022              | D                | Level 1 Interrupt Autovector     |  |
| 12               | 0024              | D                | Level 2 Interrupt Autovector     |  |
| 13               | 0026              | D                | Level 3 Interrupt Autovector     |  |
| 14               | 0028              | D                | Level 4 Interrupt Autovector     |  |
| 15               | 002A              | D                | Level 5 Interrupt Autovector     |  |
| 16               | 002C              | D                | Level 6 Interrupt Autovector     |  |
| 17               | 002E              | D                | Level 7 Interrupt Autovector     |  |
| 18               | 0030              | D                | Spurious Interrupt               |  |
| 19-37            | 0032 - 006E       | D                | Unassigned, Reserved             |  |
| 38 – FF          | 0070 - 01FE       | D                | User-Defined Interrupts          |  |

 Table 5-34. Exception Vector Table

### 5.12.2 Exception Stack Frame

During exception processing, the contents of the program counter and condition code register are stacked at a location pointed to by SK : SP. Unless it is altered during exception processing, the stacked PK : PC value is the address of the next instruction in the current instruction stream, plus \$0006. Figure 5–5 shows the exception stack frame.



⇐ SP After Exception Stacking

High Address

⇐ SP Before Exception Stacking

### Figure 5–5. Exception Stack Frame Format

Condition Code Register Program Counter

### 5.12.3 Exception Processing Sequence

Exception processing is performed in four distinct phases.

- A. Priority of all pending exceptions is evaluated, and the highest priority exception is processed first.
- B. Processor state is stacked, then the CCR PK extension field is cleared.
- C. An exception vector number is acquired and converted to a vector address.
- D. The content of the vector address is loaded into the PC, and the processor jumps to the exception handler routine.

There are variations within each phase for differing types of exceptions. However, all vectors but the reset vectors contain 16-bit addresses, and the PK field is cleared. Exception handlers must be located within Bank 0 or vectors must point to a jump table.

#### 5.12.4 Types of Exceptions

Exceptions can be either internally or externally generated. External exceptions, which are defined as asynchronous, include interrupts, bus errors (BERR), breakpoints (BKPT), and resets (RESET). Internal exceptions, which are defined as synchronous, include the software interrupt (SWI) instruction, the background (BGND) instruction, illegal instruction exceptions, and the divide-by-zero exception.

#### 5.12.4.1 Asynchronous Exceptions

Asynchronous exceptions occur without reference to CPU16 or IMB clocks, but exception processing is synchronized. For all asynchronous exceptions but RESET, exception processing begins at the first instruction boundary following recognition of an exception. Refer to **SECTION 4 SYSTEM INTEGRATION MODULE** for more information concerning asynchronous exceptions.

Because of pipelining, the stacked return PK : PC value for all asynchronous exceptions, other than RESET, is equal to the address of the next instruction in the current instruction stream plus \$0006. The RTI instruction, which must terminate all exception handler routines, subtracts \$0006 from the stacked value in order to resume execution of the interrupted instruction stream.

#### 5.12.4.2 Synchronous Exceptions

Synchronous exception processing is part of an instruction definition. Exception processing for synchronous exceptions will always be completed, and the first instruction of the handler routine will always be executed, before interrupts are detected.

Because of pipelining, the value of PK : PC at the time a synchronous exception executes is equal to the address of the instruction that causes the exception plus \$0006. Since RTI always subtracts \$0006 upon return, the stacked PK : PC must be adjusted by the instruction that caused the exception so that execution will resume with the following instruction. For this reason \$0002 is added to the PK : PC value before it is stacked.

#### 5.12.5 Multiple Exceptions

Each exception has a hardware priority based upon its relative importance to system operation. Asynchronous exceptions have higher priorities than synchronous exceptions. Exception processing for multiple exceptions is done by priority, from lowest to highest. Priority governs the order in which exception processing occurs, not the order in which exception handlers are executed.

Unless BERR, BKPT, or RESET occur during exception processing, the first instruction of all exception handler routines is guaranteed to execute before another exception is processed. Since interrupt exceptions have higher priority than synchronous exceptions, this means that the first instruction in an interrupt handler will be executed before other interrupts are sensed.

RESET, BERR, and BKPT exceptions that occur during exception processing of a previous exception will be processed before the first instruction of that exception's handler routine. The converse is not true — if an interrupt occurs during BERR exception processing, for example, the first instruction of the BERR handler will be executed before interrupts are sensed. This permits the exception handler to mask interrupts during execution.

Refer to **SECTION 4 SYSTEM INTEGRATION MODULE** for detailed information concerning interrupts and system reset. Refer to the *CPU16 Reference Manual* (CPU16RM/AD) for information concerning processing of specific exceptions.

### 5.12.6 RTI Instruction

The return-from-interrupt instruction (RTI) must be the last instruction in all exception handlers except the RESET handler. RTI pulls the exception stack frame that was pushed onto the system stack during exception processing, and restores processor state. Normal program flow resumes at the address of the instruction that follows the last instruction executed before exception processing began.

RTI is not used in the RESET handler because RESET initializes the stack pointer and does not create a stack frame.

### 5.13 Development Support

The CPU16 incorporates powerful tools for tracking program execution and for system debugging. These tools are deterministic opcode tracking, breakpoint exceptions, and background debugging mode. Judicious use of CPU16 capabilities permits in-circuit emulation and system debugging using a bus state analyzer, a simple serial interface, and a terminal.

### 5.13.1 Deterministic Opcode Tracking

The CPU16 has two multiplexed outputs, IPIPE0 and IPIPE1, that enable external hardware to monitor the instruction pipeline during normal program execution. The signals IPIPE0 and IPIPE1 can be demultiplexed into six pipeline state signals that allow a state analyzer to synchronize with instruction stream activity.

### 5.13.1.1 IPIPE0/IPIPE1 Multiplexing

Six types of information are required to track pipeline activity. To generate the six state signals, eight pipeline states are encoded and multiplexed into IPIPE0 and IPIPE1. The multiplexed signals have two phases. State signals are active low. Table 5–35 shows the encoding scheme.

| Phase | IPIPE1 State | IPIPE0 State | State Signal Name |
|-------|--------------|--------------|-------------------|
| 1     | 0            | 0            | START & FETCH     |
|       | 0            | 1            | FETCH             |
|       | 1            | 0            | START             |
|       | 1            | 1            | NULL              |
| 2     | 0            | 0            | INVALID           |
|       | 0            | 1            | ADVANCE           |
|       | 1            | 0            | EXCEPTION         |
|       | 1            | 1            | NULL              |

#### Table 5-35. IPIPE0/IPIPE1 Encoding

MC68HC16Z1 USER'S MANUAL IPIPE0 and IPIPE1 are timed so that a logic analyzer can capture all six pipeline state signals and address, data, or control bus state in any single bus cycle. Refer to **APPENDIX A ELECTRICAL CHARACTERISTICS** for specifications.

State signals can be latched asynchronously on the falling and rising edges of either address strobe  $(\overline{AS})$  or data strobe  $(\overline{DS})$ . They can also be latched synchronously using the microcontroller CLKOUT signal. Refer to the *CPU16 Reference Manual* (CPU16RM/AD) for detailed information concerning state signals and state signal demux logic.

### 5.13.1.2 Combining Opcode Tracking with Other Capabilities

Pipeline state signals are useful during normal instruction execution and execution of exception handlers. The signals provide a complete model of the pipeline up to the point a breakpoint is acknowledged.

Breakpoints are acknowledged after an instruction has executed, when it is in pipeline Stage C. A breakpoint can initiate either exception processing or background debugging mode. IPIPE0/IPIPE1 are not usable when the CPU16 is in background debugging mode.

### 5.13.2 Breakpoints

Breakpoints are set by internal assertion of the IMB  $\overline{\text{BKPT}}$  signal or by external assertion of the microcontroller  $\overline{\text{BKPT}}$  pin. In the MC68HC16Z1, no internal module can assert the IMB  $\overline{\text{BKPT}}$  signal. The CPU16 supports breakpoints on any memory access. Acknowledged breakpoints can initiate either exception processing or background debugging mode. After BDM has been enabled, the CPU16 will enter BDM when either  $\overline{\text{BKPT}}$  input is asserted.

If BKPT assertion is synchronized with an instruction prefetch, the instruction is tagged with the breakpoint when it enters the pipeline, and the breakpoint occurs after the instruction executes.

If  $\overline{\text{BKPT}}$  assertion is synchronized with an operand fetch, breakpoint processing occurs at the end of the instruction during which  $\overline{\text{BKPT}}$  is latched.

Breakpoints on instructions that are flushed from the pipeline before execution are not acknowledged, but operand breakpoints are always acknowledged. There is no breakpoint acknowledge bus cycle when BDM is entered. Refer to **SECTION 4 SYSTEM INTEGRATION MODULE** for more information concerning breakpoints.

## 5.13.3 Opcode Tracking and Breakpoints

Breakpoints are acknowledged after a tagged instruction has executed, when it is copied from pipeline Stage B to Stage C. Stage C contains the opcode of the previous instruction when execution of the current instruction begins.

When an instruction is tagged, IPIPE0/IPIPE1 reflect the start of execution and the appropriate number of pipeline advances and operand fetches before the breakpoint is acknowledged. If background debugging mode is enabled, these signals model the pipeline before BDM is entered.

## 5.13.4 Background Debugging Mode

Microprocessor debugging programs are generally implemented in external software. CPU16 BDM provides a debugger implemented in CPU microcode.

BDM incorporates a full set of debug options — registers can be viewed and altered, memory can be read or written, and test features can be invoked.

BDM is an alternate CPU16 operating mode. While the CPU16 is in BDM, normal instruction execution is suspended, and special microcode performs debugging functions under external control. While in BDM, the CPU16 ceases to fetch instructions via the parallel bus and communicates with the development system via a dedicated serial interface.

#### 5.13.4.1 Enabling BDM

The CPU16 samples the internal and external  $\overrightarrow{BKPT}$  signals during reset to determine whether to enable BDM. If either  $\overrightarrow{BKPT}$  input is at logic level zero when sampled, an internal BDM enabled flag is set.

BDM operation is enabled when  $\overrightarrow{\text{BKPT}}$  is asserted at the rising edge of the  $\overrightarrow{\text{RESET}}$  signal. BDM remains enabled until the next system reset. If  $\overrightarrow{\text{BKPT}}$  is at logic level one on the trailing edge of  $\overrightarrow{\text{RESET}}$ , BDM is disabled.  $\overrightarrow{\text{BKPT}}$  is relatched on each rising transition of  $\overrightarrow{\text{RESET}}$ .  $\overrightarrow{\text{BKPT}}$  is synchronized internally, and must be asserted for at least two clock cycles prior to negation of  $\overrightarrow{\text{RESET}}$ .

### 5.13.4.2 BDM Sources

When BDM is enabled, external breakpoint hardware, internal IMB module breakpoints, and the BGND instruction can cause the CPU16 to enter BDM. If BDM is not enabled when a breakpoint occurs, a breakpoint exception is processed.

#### 5.13.4.2.1 BKPT Signal

If enabled, BDM is initiated when assertion of BKPT is acknowledged. There is no breakpoint acknowledge bus cycle when BDM is entered. Refer to SECTION 4 SYSTEM INTEGRATION MODULE for more information concerning breakpoint acknowledge cycles. For timing specifications refer to APPENDIX A ELECTRICAL CHARACTERISTICS.

#### 5.13.4.2.2 BGND Instruction

If BDM has been enabled, executing BGND will cause the CPU16 to suspend normal operation and enter BDM. If BDM has not been correctly enabled, an illegal instruction exception is generated.

#### 5.13.4.3 Entering BDM

When the processor detects a breakpoint or decodes a BGND instruction, it suspends instruction execution and asserts the FREEZE signal. Once FREEZE has been asserted, the CPU enables the serial communication hardware and awaits a command.

Assertion of FREEZE causes opcode tracking signals IPIPE0 and IPIPE1 to change definition and become serial communication signals DSO and DSI. FREEZE is asserted at the next instruction boundary after BKPT is asserted. IPIPE0 and IPIPE1 change function before an EXCEPTION signal can be generated. The development system must use FREEZE assertion as an indication that BDM has been entered. When BDM is exited, FREEZE is negated prior to initiation of normal bus cycles — IPIPE0 and IPIPE1 will be valid when normal instruction prefetch begins.

#### 5.13.4.4 BDM Commands

Commands consist of one 16-bit operation word and can include one or more 16-bit extension words. Each incoming word is read as it is assembled by the serial interface. The microcode routine corresponding to a command is executed as soon as the command is complete. Result operands are loaded into the output shift register to be shifted out as the next command is read. This process is repeated for each command until the CPU returns to normal operating mode. The BDM command set is summarized in Table 5–36. Refer to the *CPU16 Reference Manual* (CPU16RM/AD) for a BDM command glossary.

| Command                         | Mnemonic | Description                                                                                  |
|---------------------------------|----------|----------------------------------------------------------------------------------------------|
| Read Registers<br>from Mask     | RREGM    | Read contents of registers specified by<br>command word register mask                        |
| Write Registers<br>from Mask    | WREGM    | Write to registers specified by<br>command word register mask                                |
| Read MAC Registers              | RDMAC    | Read contents of entire<br>Multiply and Accumulate register set                              |
| Write MAC Registers             | WRMAC    | Write to entire Multiply and Accumulate register set                                         |
| Read PC and SP                  | RPCSP    | Read contents of program counter and stack pointer                                           |
| Write PC and SP                 | WPCSP    | Write to program counter and stack pointer                                                   |
| Read Data Memory                | RDMEM    | Read byte from specified 20-bit address<br>in data space                                     |
| Write Data Memory               | WDMEM    | Write byte to specified 20-bit address<br>in data space                                      |
| Read Program Memory             | RPMEM    | Read word from specified 20-bit address<br>in program space                                  |
| Write Program Memory            | WPMEM    | Write word to specified 20-bit address<br>in program space                                   |
| Execute from current<br>PK : PC | GO       | Instruction pipeline flushed and refilled;<br>instructions executed from current PC – \$0006 |
| Null Operation                  | NOP      | Null command — performs no operation                                                         |

Table 5–36. Command Summary

## 5.13.4.5 Returning from BDM

BDM is terminated when a resume execution (GO) command is received. GO refills the instruction pipeline from address (PK : PC - \$0006). FREEZE is negated prior to the first prefetch. Upon negation of FREEZE, the serial subsystem is disabled, and the DSO/DSI signals revert to IPIPE0/IPIPE1 functionality.

#### 5.13.4.6 BDM Serial Interface

The serial interface uses a synchronous protocol similar to that of the Motorola Serial Peripheral Interface (SPI). Figure 5-6 is a development system serial logic diagram.

The development system serves as the master of the serial link, and is responsible for the generation of serial interface clock signal DSCLK.

Serial clock frequency range is from DC to one-half the CPU16 clock frequency. If DSCLK is derived from the CPU16 system clock, development system serial logic can be synchronized with the target processor.

The serial interface operates in full-duplex mode. Data transfers occur on the falling edge of DSCLK and are stable by the following rising edge of DSCLK. Data is transmitted MSB first, and is latched on the rising edge of DSCLK.

The serial data word is 17 bits wide — 16 data bits and a status/control bit. Bit 16 indicates status of CPU-generated messages.

Command and data transfers initiated by the development system must clear bit 16. All commands that return a result return 16 bits of data plus one status bit.



Figure 5-6. BDM Serial I/O Block Diagram

CENTRAL PROCESSING UNIT

# 5.14 Digital Signal Processing

The CPU16 performs low-frequency digital signal processing algorithms in real time. The most common DSP operation in embedded control applications is filtering, but the CPU16 can perform several other useful DSP functions. These include autocorrelation (detecting a periodic signal in the presence of noise), cross-correlation (determining the presence of a defined periodic signal), and closed-loop control routines (selective filtration in a feedback path).

Although derivation of DSP algorithms is often a complex mathematic task, the algorithms themselves typically consist of a series of multiply and accumulate (MAC) operations. The CPU16 contains a dedicated set of registers that are used to perform MAC operations. These are collectively called the MAC unit.

DSP operations generally require a large number of MAC iterations. The CPU16 instruction set includes instructions that perform MAC setup and repetitive MAC operations. Other instructions, such as 32-bit load and store instructions, can also be used in DSP routines.

Many DSP algorithms require extensive data address manipulation. To increase throughput, the CPU16 performs effective address calculations and data prefetches during MAC operations. In addition, the MAC unit provides modulo addressing to efficiently implement circular DSP buffers.

Refer to the *CPU16 Reference Manual* (CPU16RM/AD) for detailed information concerning the MAC unit and execution of DSP instructions.

5

## SECTION 6 ANALOG-TO-DIGITAL CONVERTER

The analog-to-digital converter module (ADC) is a unipolar, successiveapproximation converter with eight modes of operation. It has selectable 8- or 10-bit resolution. Monotonicity is guaranteed in both modes. Refer to **APPENDIX A ELECTRICAL CHARACTERISTICS** for ADC timing and electrical specifications. This section is an overview of ADC function. Refer to the *ADC Reference Manual* (ADCRM/AD) for a comprehensive discussion of ADC capabilities.

#### 6.1 Overview

A bus interface unit (ABIU) handles communication between the ADC and other microcontroller modules, and supplies IMB timing signals to the ADC. Special operating modes and test functions are controlled by a module configuration register (ADCMCR) and a factory test register (ADCTST).

ADC module conversion functions can be grouped into three basic subsystems: an analog front end, a digital control section, and result storage. Figure 6–1 is a functional block diagram of the ADC module.

In addition to use as multiplexer inputs, the eight analog inputs can be used as a general-purpose digital input port (Port AD), provided signals are within logic level specification. A port data register (PADR) is used to access input data.

#### 6.2 External Connections

The ADC uses 12 pins on the MC68HC16Z1 package. Eight pins are analog inputs (which can also be used as digital inputs), two pins are analog reference connections, and two pins are analog supply connections.



Figure 6-1. ADC Block Diagram

## 6.2.1 Analog Input Pins

Each of the eight analog input pins (AN[7:0]) is connected to a multiplexer in the ADC. The multiplexer selects an analog input for conversion to digital data.

Analog input pins can also be read as digital inputs, provided the applied voltage meet  $V_{IH}$  and  $V_{IL}$  specification. When used as digital inputs, the pins are organized into an 8-bit port (Port ADA), and referred to as ADA[7:0]. Digital input data is accessed via a port data register (PADR). There is no data direction register because port pins are used only for input.

## 6.2.2 Analog Reference Pins

Separate high ( $V_{RH}$ ) and low ( $V_{RL}$ ) analog reference voltages are connected to the analog reference pins. The pins permit connection of regulated and filtered supplies that allow the ADC to achieve its highest degree of accuracy.

## 6.2.3 Analog Supply Pins

Pins  $V_{DDA}$  and  $V_{SSA}$  supply power to analog circuitry associated with the RC DAC. Other circuitry in the ADC is powered from the digital power bus (pins  $V_{DDI}$  and  $V_{SSI}$ ). Dedicated analog power supplies are necessary to isolate sensitive ADC circuitry from noise on the digital power bus.

## 6.3 Programmer's Model

The ADC module is mapped into 32 words of address space (refer to Table 6–1). Five words are control/status registers, one word is digital port data, and 24 words provide access to the results of AD conversion (eight addresses for each type of converted data). Two words are reserved for expansion.

The ADC module base address is determined by the value of the MM bit in the system integration module configuration register (SIMCR). The base address is normally \$FFF700 in the MC68HC16Z1.

Internally, the ADC has both a differential data bus and a buffered IMB data bus. Registers not directly associated with conversion functions, such as the module configuration register, the module test register, and the port data register, reside on the buffered bus, while conversion registers and result registers reside on the differential bus.

Registers that reside on the buffered bus are updated immediately when written. However, writes to ADC control registers abort any conversion in progress.

#### 6.4 ADC Bus Interface Unit

The ADC is designed to act as a slave device on the intermodule bus. The bus interface unit (ABIU) provides IMB bus cycle termination and synchronizes internal ADC signals with IMB signals. The ABIU also manages data bus routing to accommodate the three conversion data formats, and controls the interface to the module differential data bus.

#### 6.5 Special Operating Modes

Low-power stop mode and freeze mode are ADC operating modes associated with assertion of IMB signals by other microcontroller modules or by external sources. These modes are controlled by the values of bits in the ADC module configuration register (ADCMCR).

#### 6.5.1 Low-Power Stop Mode

When the STOP bit in ADCMCR is set, the IMB clock signal to the ADC is disabled. This places the module in an idle state, and power consumption is minimized. The bus interface unit does not shut down and ADC registers are still accessible. If a conversion is in progress when STOP is set, it is aborted.

STOP is set during system reset, and must be cleared before the ADC can be used. Because analog circuit bias currents are turned off during low-power stop, the ADC requires recovery time after STOP is cleared.

Execution of the CPU16 LPSTOP command places the entire modular microcontroller in low-power stop mode. Refer to SECTION 4 SYSTEM INTEGRATION MODULE and SECTION 5 CENTRAL PROCESSING UNIT for more information regarding low-power stop operation.

## 6.5.2 Freeze Mode

When the CPU16 in the modular microcontroller enters background debugging mode, the FREEZE signal is asserted. The ADC can respond to internal assertion of FREEZE in one of three different ways — it can ignore FREEZE assertion, finish the current conversion and then freeze, or freeze immediately.

Type of response is determined by the value of the FRZ[1:0] field in the module configuration register (refer to Table 6–2).

| Table 6–1.<br>FRZ Field Selection |                                |  |  |  |  |
|-----------------------------------|--------------------------------|--|--|--|--|
| FRZ Response                      |                                |  |  |  |  |
| 00                                | Ignore FREEZE                  |  |  |  |  |
| 01                                | Reserved                       |  |  |  |  |
| 10                                | Finish conversion, then freeze |  |  |  |  |
| 11                                | Freeze immediately             |  |  |  |  |

When the ADC freezes, the ADC clock stops and all sequential activity ceases. Contents of control and status registers remain valid while frozen. When the FREEZE signal is negated, ADC activity resumes.

If the ADC freezes during a conversion, activity resumes with the next step in the conversion sequence. However, capacitors in the analog conversion circuitry discharge while the ADC is frozen — the conversion will be inaccurate.

Refer to **SECTION 5 CENTRAL PROCESSING UNIT** for more information on background debugging mode.

#### 6.6 Analog Subsystem

The analog subsystem consists of a multiplexer, sample capacitors, a buffer amplifier, an RC DAC array, and a high-gain comparator. Comparator output is used to sequence the successive approximation register (SAR). The interface between the comparator and the SAR is the boundary between ADC analog and digital subsystems.

## 6.6.1 Multiplexer

The multiplexer selects one of 16 sources for conversion. Eight sources are internal and eight are external. Multiplexer operation is controlled by channel selection field CD:CA in register ADCTL1 (refer to Table 6–3). The multiplexer contains positive and negative stress protection circuitry. This circuitry prevents voltages on other input channels from affecting the current conversion.

| [CD:CA] Value | Input Source                             |  |  |
|---------------|------------------------------------------|--|--|
| %0000         | ANO                                      |  |  |
| %0001         | AN1                                      |  |  |
| %0010         | AN2                                      |  |  |
| %0011         | AN3                                      |  |  |
| %0100         | AN4                                      |  |  |
| %0101         | AN5                                      |  |  |
| %0110         | AN6                                      |  |  |
| %0111         | AN7                                      |  |  |
| %1000         | RESERVED                                 |  |  |
| %1001         | RESERVED                                 |  |  |
| %1010         | RESERVED                                 |  |  |
| %1011         | RESERVED                                 |  |  |
| %1100         | V <sub>RH</sub>                          |  |  |
| %1101         | V <sub>RL</sub>                          |  |  |
| %1110         | (V <sub>RH –</sub> V <sub>RL</sub> ) / 2 |  |  |
| %1111         | TEST/RESERVED                            |  |  |

## Table 6–2. Multiplexer Channels

# 6.6.2 Sample Capacitors and Buffer Amplifier

Each of the input channels has its own sample capacitor. All channels share a single buffer amplifier. After a channel is selected, for the first two ADC clock cycles of a sampling period, multiplexer output is connected to the input of the sample buffer amplifier via the sample capacitor. The sample amplifier buffers the input channel from the relatively large capacitance of the RC DAC array.

During the second two clock cycles of a sampling period, the sample capacitor is disconnected from the multiplexer, and the sample buffer amplifier charges the RC DAC array with the value stored in the sample capacitor.

During the third portion of a sampling period, both sample capacitor and buffer amplifier are bypassed, and multiplexer input charges the DAC array directly. The length of this third portion of a sampling period is determined by the value of the STS field in ADCTL0.

## 6.6.3 RC DAC Array

The RC DAC array consists of binary-weighted capacitors and a resistor-divider chain. The array performs two functions: it acts as a sample hold circuit during conversion, and it provides each successive digital-to-analog comparison voltage to the comparator. Conversion begins with MSB comparison and ends with LSB comparison. Array switching is controlled by the digital subsystem.

## 6.6.4 Comparator

The comparator indicates whether each approximation output from the RC DAC array during resolution is higher or lower than the sampled input voltage. Comparator output is fed to the digital control logic, which sets or clears each bit in the successive approximation register in sequence, MSB first.

## 6.7 Digital Control Subsystem

The digital control subsystem includes control and status registers, clock and prescaler control logic, channel and reference select logic, conversion sequence control logic, and the successive approximation register.

The subsystem controls the multiplexer and the output of the RC array during sample and conversion periods, stores the results of comparison in the successive-approximation register, then transfers results to the result registers.

## 6.7.1 Control/Status Registers

There are two control registers (ADCTL0, ADCTL1) and one status register (ADSTAT). ADCTL0 controls conversion resolution, sample time, and clock/prescaler value. ADCTL1 controls analog input selection, conversion mode, and initiation of conversion. A write to ADCTL0 aborts the current conversion sequence and halts the ADC. Conversion must be restarted by writing to ADCTL1. A write to ADCTL1 aborts the current conversion sequence with parameters altered by the write. ADSTAT shows conversion sequence status, conversion channel status, and conversion completion status.

The following paragraphs are a general discussion of control function. **APPENDIX D REGISTER SUMMARY** shows the ADC address map and discusses register bits and fields.

#### 6.7.2 Clock and Prescaler Control

The ADC clock is derived from the system clock by a programmable prescaler. ADC clock period is determined by the value of the PRS field in ADCTL0.

The prescaler has two stages. The first stage is a 5-bit modulus counter. It divides the system clock by any value from 2 to 32 (PRS[4:0] = %00001 to %11111). The second stage is a divide-by-two circuit. Table 6–4 shows prescaler output values.

| PRS[4:0] | ADC Clk    |  |  |
|----------|------------|--|--|
| %00000   | RESERVED   |  |  |
| %00001   | Sys Clk/4  |  |  |
| %00010   | Sys Clk/6  |  |  |
|          |            |  |  |
| %11101   | Sys Clk/60 |  |  |
| %11110   | Sys Clk/62 |  |  |
| %11111   | Sys Clk/64 |  |  |

# Table 6–3.Prescaler Output

ADC clock speed must be between 0.5 MHz and 2.1 MHz. The reset value of the PRS field is %00011, which divides a nominal 16.78-MHz system clock by eight, yielding maximum ADC clock frequency. There are a minimum of four IMB clock cycles for each ADC clock cycle.

#### 6.7.3 Sample Time

The first two portions of all sample periods require four ADC clock cycles. During the third portion of a sample period, the selected channel is connected directly to the RC DAC array for a specified number of clock cycles. The value of the STS field in ADCTL0 determines the number of cycles (refer to Table 6– 5). The number of clock cycles required for a sample period is the value specified by STS plus four. Sample time is determined by PRS value.

| STS[1:0] | Sample Time          |  |  |
|----------|----------------------|--|--|
| 00       | 4 A/D Clock Periods  |  |  |
| 01       | 8 A/D Clock Periods  |  |  |
| 10       | 16 A/D Clock Periods |  |  |
| 11       | 32 A/D Clock Periods |  |  |

Table 6-4.STS Field Selection

## 6.7.4 Resolution

ADC resolution can be either eight or ten bits. Resolution is determined by the state of the RES10 bit in ADCTL0. Both 8-bit and 10-bit conversion results are automatically aligned in the result registers.

## 6.7.5 Conversion Control Logic

Analog-to-digital conversions are performed in sequences. Sequences are initiated by any write to ADCTL1. If a conversion sequence is already in progress, a write to either control register will abort it and reset the SCF and CCF flags in the A/D status register. There are eight conversion modes. Conversion mode is determined by ADCTL1 control bits. Each conversion mode affects the bits in status register ADSTAT differently. Result storage differs from mode to mode.

#### 6.7.5.1 Conversion Parameters

The following conversion parameters are controlled by bits in ADCTL1.

- Conversion channel the value of the channel selection field ([CA:CD]) in ADCTL1 determines which multiplexer inputs are used in a conversion sequence. There are 16 possible inputs. Eight inputs are external pins (AN[7:0]), and eight are internal.
- Length of sequence A conversion sequence consists of either four or eight conversions. The number of conversions in a sequence is determined by the state of the S8CM bit in ADCTL1.
- Single or continuous conversion Conversion can be limited to a single sequence or a sequence can be performed continuously. The state of the SCAN bit in ADCTL1 determines whether single or continuous conversion is performed.
- Single or multiple channel conversion Conversion sequence(s) can be run on a single channel or on a block of four or eight channels. Channel conversion is controlled by the state of the MULT bit in ADCTL1.

#### 6.7.5.2 Conversion Modes

Conversion modes are defined by the state of the SCAN, MULT, and S8CM bits in ADCTL1. Table 6–6 shows mode numbering.

| SCAN | MULT | S8CM | Mode |
|------|------|------|------|
| 0    | 0    | 0    | 0    |
| 0    | 0    | 1    | 1    |
| 0    | 1    | 0    | 2    |
| 0    | 1    | 1    | 3    |
| 1    | 0    | 0    | 4    |
| 1    | 0    | 1    | 5    |
| 1    | 1    | 0    | 6    |
| 1    | 1    | 1    | 7    |

# Table 6–5.ADC Conversion Modes

- Mode 0 A single 4-conversion sequence is performed on a single input channel specified by the value in CD:CA. Each result is stored in a separate result register (RSLT0 to RSLT3). The appropriate CCF bit in ADSTAT is set as each register is filled. The SCF bit in ADSTAT is set when the conversion sequence is complete.
- Mode 1 A single 8-conversion sequence is performed on a single input channel specified by the value in CD:CA. Each result is stored in a separate result register (RSLT0 to RSLT7). The appropriate CCF bit in ADSTAT is set as each register is filled. The SCF bit in ADSTAT is set when the conversion sequence is complete.
- Mode 2 A single conversion is performed on each of four sequential input channels, starting with the channel specified by the value in CD:CA. Each result is stored in a separate result register (RSLT0 to RSLT3). The appropriate CCF bit in ADSTAT is set as each register is filled. The SCF bit in ADSTAT is set when the last conversion is complete.
- Mode 3 A single conversion is performed on each of eight sequential input channels, starting with the channel specified by the value in CD:CA. Each result is stored in a separate result register (RSLT0 to RSLT7). The appropriate CCF bit in ADSTAT is set as each register is filled. The SCF bit in ADSTAT is set when the last conversion is complete.

- Mode 4 Continuous 4-conversion sequences are performed on a single input channel specified by the value in CD:CA. Each result is stored in a separate result register (RSLT0 to RSLT3). Previous results are overwritten when a sequence repeats. The appropriate CCF bit in ADSTAT is set as each register is filled. The SCF bit in ADSTAT is set when the first 4-conversion sequence is complete.
- Mode 5 Continuous 8-conversion sequences are performed on a single input channel specified by the value in CD:CA. Each result is stored in a separate result register (RSLT0 to RSLT7). Previous results are overwritten when a sequence repeats. The appropriate CCF bit in ADSTAT is set as each register is filled. The SCF bit in ADSTAT is set when the first 8-conversion sequence is complete.
- Mode 6 Continuous conversions are performed on each of four sequential input channels, starting with the channel specified by the value in CD:CA. Each result is stored in a separate result register (RSLT0 to RSLT3). The appropriate CCF bit in ADSTAT is set as each register is filled. The SCF bit in ADSTAT is set when the first 4-conversion sequence is complete.
- Mode 7 Continuous conversions are performed on each of eight sequential input channels, starting with the channel specified by the value in CD:CA. Each result is stored in a separate result register (RSLT0 to RSLT7). The appropriate CCF bit in ADSTAT is set as each register is filled. The SCF bit in ADSTAT is set when the first 8-conversion sequence is complete.

Table 6–7 summarizes ADC operation when MULT is cleared (single channel modes). Table 6–8 summarizes ADC operation when MULT is set (multi-channel modes). Number of conversions per channel is determined by SCAN. Channel numbers are given in order of conversion.

| S8CM | CD | cc | СВ | CA | Input                                    | Result Register |
|------|----|----|----|----|------------------------------------------|-----------------|
| 0    | 0  | 0  | 0  | 0  | ANO                                      | RSLT[0:3]       |
| 0    | 0  | 0  | 0  | 1  | AN1                                      | RSLT[0:3]       |
| 0    | 0  | 0  | 1  | 0  | AN2                                      | RSLT[0:3]       |
| 0    | 0  | 0  | 1  | 1  | AN3                                      | RSLT[0:3]       |
| 0    | 0  | 1  | 0  | 0  | AN4                                      | RSLT[0:3]       |
| 0    | 0  | 1  | 0  | 1  | AN5                                      | RSLT[0:3]       |
| 0    | 0  | 1  | 1  | 0  | AN6                                      | RSLT[0:3]       |
| 0    | 0  | 1  | 1  | 1  | AN7                                      | RSLT[0:3]       |
| 0    | 1  | 0  | 0  | 0  | RESERVED                                 | RSLT[0:3]       |
| 0    | 1  | 0  | 0  | 1  | RESERVED                                 | RSLT[0:3]       |
| 0    | 1  | 0  | 1  | 0  | RESERVED                                 | RSLT[0:3]       |
| 0    | 1  | 0  | 1  | 1  | RESERVED                                 | RSLT[0:3]       |
| 0    | 1  | 1  | 0  | 0  | V <sub>RH</sub>                          | RSLT[0:3]       |
| 0    | 1  | 1  | 0  | 1  | V <sub>RL</sub>                          | RSLT[0:3]       |
| 0    | 1  | 1  | 1  | 0  | (V <sub>RH –</sub> V <sub>RL</sub> ) / 2 | RSLT[0:3]       |
| 0    | 1  | 1  | 1  | 1  | TEST/RESERVED                            | RSLT[0:3]       |
| 1    | 0  | 0  | 0  | 0  | ANO                                      | RSLT[0:7]       |
| 1    | 0  | 0  | 0  | 1  | AN1                                      | RSLT[0:7]       |
| 1    | 0  | 0  | 1  | 0  | AN2                                      | RSLT[0:7]       |
| 1    | 0  | 0  | 1  | 1  | AN3                                      | RSLT[0:7]       |
| 1    | 0  | 1  | 0  | 0  | AN4                                      | RSLT[0:7]       |
| 1    | 0  | 1  | 0  | 1  | AN5                                      | RSLT[0:7]       |
| 1    | 0  | 1  | 1  | 0  | AN6                                      | RSLT[0:7]       |
| 1    | 0  | 1  | 1  | 1  | AN7                                      | RSLT[0:7]       |
| 1    | 1  | 0  | 0  | 0  | RESERVED                                 | RSLT[0:7]       |
| 1    | 1  | 0  | 0  | 1  | RESERVED                                 | RSLT[0:7]       |
| 1    | 1  | 0  | 1  | 0  | RESERVED                                 | RSLT[0:7]       |
| 1    | 1  | 0  | 1  | 1  | RESERVED                                 | RSLT[0:7]       |
| 1    | 1  | 1  | 0  | 0  | V <sub>RH</sub>                          | RSLT[0:7]       |
| 1    | 1  | 1  | 0  | 1  | V <sub>RL</sub>                          | RSLT[0:7]       |
| 1    | 1  | 1  | 1  | 0  | (V <sub>RH –</sub> V <sub>RL</sub> ) / 2 | RSLT[0:7]       |
| 1 .  | 1  | 1  | 1  | 1  | TEST/RESERVED                            | RSLT[0:7]       |

# Table 6-6. Single-Channel Conversions

| S8CM | CD | cc | СВ | CA | Input                                    | Result Register |
|------|----|----|----|----|------------------------------------------|-----------------|
| 0    | 0  | 0  | Х  | Х  | ANO                                      | RSLT0           |
|      |    |    |    |    | AN1                                      | RSLT1           |
|      |    |    |    |    | AN2                                      | RSLT2           |
|      |    |    |    |    | AN3                                      | RSLT3           |
| 0    | 0  | 1  | Х  | Х  | AN4                                      | RSLTO           |
|      |    |    |    |    | AN5                                      | RSLT1           |
|      |    |    |    |    | AN6                                      | RSLT2           |
|      |    |    |    |    | AN7                                      | RSLT3           |
| 0    | 1  | 0  | Х  | Х  | RESERVED                                 | RSLT0           |
|      |    |    |    |    | RESERVED                                 | RSLT1           |
|      |    |    |    |    | RESERVED                                 | RSLT2           |
|      |    |    |    |    | RESERVED                                 | RSLT3           |
| 0    | 1  | 1  | Х  | Х  | V <sub>RH</sub>                          | RSLTO           |
|      |    |    |    |    | V <sub>RL</sub>                          | RSLT1           |
|      |    |    |    |    | (V <sub>RH –</sub> V <sub>RL</sub> ) / 2 | RSLT2           |
|      |    |    |    |    | TEST/RESERVED                            | RSLT3           |
| 1    | 0  | Х  | Х  | Х  | ANO                                      | RSLTO           |
|      |    |    |    |    | AN1                                      | RSLT1           |
|      |    |    |    |    | AN2                                      | RSLT2           |
|      |    |    |    |    | AN3                                      | RSLT3           |
|      |    |    |    |    | AN4                                      | RSLT4           |
|      |    |    |    |    | AN5                                      | RSLT5           |
|      |    |    |    |    | AN6                                      | RSLT6           |
|      |    |    |    |    | AN7                                      | RSLT7           |
| 1    | 1  | Х  | Х  | Х  | RESERVED                                 | RSLT0           |
|      |    |    |    |    | RESERVED                                 | RSLT1           |
|      |    |    |    |    | RESERVED                                 | RSLT2           |
|      |    |    |    |    | RESERVED                                 | RSLT3           |
|      |    |    |    |    | V <sub>RH</sub>                          | RSLT4           |
|      |    |    |    |    | V <sub>RL</sub>                          | RSLT5           |
|      |    |    |    |    | (V <sub>RH –</sub> V <sub>RL</sub> ) / 2 | RSLT6           |
|      |    |    |    |    | TEST/RESERVED                            | RSLT7           |

Table 6-7. Multiple-Channel Conversions

## 6.7.6 Conversion Timing

Total conversion time is made up of initial sample time, transfer time, final sample time, and resolution time. Initial sample time is the time during which a selected input channel is connected to the sample buffer amplifier via a sample capacitor. During transfer time, the sample capacitor is disconnected from the multiplexer, and the RC DAC array is driven by the sample buffer amp. During final sampling time, the sample capacitor and amplifier are bypassed, and the multiplexer input charges the RC DAC array directly. During resolution time, the voltage in the RC DAC array is converted to a digital value, and the value is stored in the SAR.

Initial sample time and transfer time are fixed at 2 ADC clock cycles each. Final sample time can be 2, 4, 8, or 16 ADC clock cycles, depending on the value of the STS field in ADCTL0. Resolution time is 10 cycles for 8-bit conversion and 12 cycles for 10-bit conversion.

Transfer and resolution require a minimum of 16 ADC clocks (8  $\mu$ s with a 2.1-MHz ADC clock) for 8-bit resolution or 18 ADC clocks (9  $\mu$ s with a 2.1-MHz ADC clock) for 10-bit resolution. If maximum final sample time (16 ADC clocks) is used, total conversion time is 15  $\mu$ s for an 8-bit conversion or 16  $\mu$ s for a 10-bit conversion (with a 2.1-MHz ADC clock).

Figures 6–2 and 6–3 illustrate the timing for 8- and 10-bit conversions, respectively. These diagrams assume a final sampling period of two ADC clocks.



Figure 6-2. 8-Bit Conversion Timing



Figure 6-3. 10-Bit Conversion Timing

## 6.7.7 Successive Approximation Register

The successive approximation register accumulates the result of each conversion one bit at a time, starting with the most significant bit.

At the start of the resolution period, the MSB of the SAR is set, and all less significant bits are cleared. Depending on the result of the first comparison, the MSB is either left set or cleared. Each successive bit is set or left cleared in descending order until all eight or ten bits have been resolved.

When conversion is complete, the content of the SAR is transferred to the appropriate result register. Refer to **APPENDIX D REGISTER SUMMARY** for register mapping and configuration.

## 6.7.8 Result Registers

Result registers are used to store data after conversion is complete. The registers can be accessed from the IMB under ABIU control. Each register can be read from three different addresses in the ADC memory map. The format of the result data depends on the address from which it is read.

- Unsigned Right-Justified Format Conversion result is unsigned rightjustified data. Bits [9:0] are used for 10-bit resolution, bits [7:0] are used for 8-bit conversion (bits [9:8] are zero). Bits [15:10] always return zero when read.
- Signed Left-Justified Format Conversion result is signed left-justified data. Bits [15:6] are used for 10-bit resolution, bits [15:8] are used for 8-bit conversion (bits [7:6] are zero). Although the ADC is unipolar, it is assumed that the zero point is  $(V_{RH} - V_{RL}) / 2$  when this format is used. The value read from the register is an offset twos-complement number for positive input, bit 15 = 0, for negative input, bit 15 = 1. Bits [5:0] always return zero when read.
- Unsigned Left-Justified Format Conversion result is unsigned left-justified data. Bits [15:6] are used for 10-bit resolution, bits [15:8] are used for 8-bit conversion (bits [7:6] are zero). Bits [5:0] always return zero when read.

Refer to **APPENDIX D REGISTER SUMMARY** for register mapping and configuration.

6

MOTOROLA 6–18 ANALOG-TO-DIGITAL CONVERTER

MC68HC16Z1 USER'S MANUAL

## SECTION 7 QUEUED SERIAL MODULE

This section is an overview of MC68HC16Z1 queued serial module (QSM) function. Complete information on the QSM can be found in the *Queued Serial Module Reference Manual* (QSMRM/AD).

#### 7.1 General

The QSM contains two serial interfaces, the queued serial peripheral interface (QSPI) and the serial communication interface (SCI). Figure 7–1 is a block diagram of the QSM.



Figure 7-1. QSM Block Diagram

The QSPI provides easy peripheral expansion or interprocessor communication via a full-duplex, synchronous, three-line bus. Four programmable peripheral chip-selects can select up to 16 peripheral devices. A self-contained RAM queue allows up to 16 serial transfers of 8 to 16 bits each or transmission of a 256-bit data stream without CPU intervention. A special wraparound mode supports continuous sampling of a serial peripheral, with automatic QSPI RAM updating, for efficient interfacing to A/D converters.

The SCI provides a standard nonreturn to zero (NRZ) mark/space format. It will operate in either full- or half-duplex mode — there are separate transmitter and receiver enable bits and dual data buffers. A modulus-type baud rate generator provides rates from 64 to 524 kbaud (with a 16.78-MHz system clock). Word length of either 8 or 9 bits is software selectable. Optional parity generation and detection provide either even or odd parity check capability. Advanced error detection circuitry catches glitches of up to 1/16 of a bit time in duration. Wakeup functions allow the CPU to run uninterrupted until meaningful data is available.

## 7.2 QSM Registers and Address Map

There are four types of QSM registers. These are QSM global registers, QSM pin control registers, QSPI registers, and SCI registers. Global registers and pin control registers are discussed in **7.2.1 QSM Global Registers** and **7.2.2 QSM Pin Control Registers**. QSPI and SCI registers are discussed in **7.3 Queued Serial Peripheral Interface** and **7.4 Serial Communications Interface**. Writes to unimplemented register bits have no meaning or effect, and reads from unimplemented bits always return a logic zero value.

The QSM address map includes the QSM registers and the QSPI RAM. The modmap (MM) bit in the system integration module configuration register (SIMCR) defines the most significant bit (ADDR23) of the IMB address for each module in the MC68HC16Z1. Because the CPU16 in the MC68HC16Z1 drives only ADDR[19:0] and ADDR[23:20] follow the logic state of ADDR19, MM must equal 1.

Refer to **APPENDIX D REGISTER SUMMARY** for a QSM address map and register bit/field definition. **SECTION 4 SYSTEM INTEGRATION MODULE** contains more information about how the state of MM affects the system.

## 7.2.1 QSM Global Registers

The QSM configuration register (QSMCR) contains parameters for interfacing to the CPU16 and the intermodule bus. The QSM test register (QTEST) is used during factory test of the QSM. The QSM interrupt level register (QILR) determines the priority of interrupts requested by the QSM and the vector used when an interrupt is acknowledged. The QSM interrupt vector register (QIVR) contains the interrupt vector for both QSM submodules. QILR and QIVR are 8-bit registers located at the same word address. Refer to **APPENDIX D REGISTER SUMMARY** for register bit and field definitions.

## 7.2.1.1 Low-power Stop Operation

When the STOP bit in QSMCR is set, the system clock input to the QSM is disabled and the module enters a low-power operating state. QSMCR is the only register guaranteed to be readable while STOP is asserted. The QSPI RAM is not readable, but writes to RAM or any register are guaranteed valid while STOP is asserted. STOP may be set by the CPU and by reset.

System software must stop the QSPI and SCI before asserting STOP in order to prevent data corruption and simplify restart. Disable both SCI receiver and transmitter after transfers in progress are complete. Halt the QSPI by setting the HALT bit in SPCR3 and then setting STOP after the HALTA flag is set. Refer to **SECTION 4 SYSTEM INTEGRATION MODULE** for more information concerning low-power operation.

#### 7.2.1.2 Freeze Operation

The freeze (FRZ[1:0]) bits in QSMCR are used to determine what action is taken by the QSM when the IMB FREEZE signal is asserted. FREEZE is asserted when the CPU enters background debugging mode. At the present time, FRZ0 has no effect; setting FRZ1 causes the QSPI to halt on the first transfer boundary following FREEZE assertion. See **SECTION 5 CENTRAL PROCESSING UNIT** for more information on background debugging mode.

#### 7.2.1.3 QSM Interrupts

Both the QSPI and SCI can make interrupt requests on the IMB. Each has a separate interrupt request priority register, but a single vector register is used to generate exception vector numbers.

The values of the ILQSPI and ILSCI fields in QILR determine the priority of QSPI and SCI interrupt requests. The values in these fields correspond to internal interrupt request signals IRQ[7:1]. A value of %111 causes IRQ7 to be asserted when a QSM interrupt request is made; lower field values cause corresponding lower-numbered interrupt request signals to be asserted. Setting field value to %000 disables interrupts. If ILQSPI and ILSCI have the same nonzero value, and the QSPI and SCI make simultaneous interrupt requests, the QSPI has priority.

When the CPU16 acknowledges an interrupt request, it places the value in the condition code register interrupt priority (IP) mask on the address bus. The QSM compares IP mask value to request priority to determine whether it should contend for arbitration priority. Arbitration priority is determined by the value of the IARB field in QSMCR. Each module that generates interrupts must have a nonzero IARB value. Arbitration is performed by means of serial assertion of IARB field bit values.

When the QSM wins interrupt arbitration, it responds to the CPU interrupt acknowledge cycle by placing an interrupt vector number on the data bus. The vector number is used to calculate displacement into the CPU16 exception vector table. SCI and QSPI vector numbers are generated from the value in the QIVR INTV field. The values of bits INTV[7:1] are the same for QSPI and SCI, but the value of INTV0 is supplied by the QSM when an interrupt request is made. INTV0 = 0 for SCI interrupt requests; INTV0 = 1 for QSPI requests.

At reset, INTV is initialized to \$0F, the uninitialized interrupt vector number. To enable interrupt-driven serial communication, a user-defined vector number (\$40–\$FF) must be written to QIVR, and interrupt handler routines must be located at the addresses pointed to by the corresponding vector. CPU writes to INTV0 have no meaning or effect. Reads of INTV0 return a value of one.

Refer to SECTION 5 CENTRAL PROCESSING UNIT and SECTION 4 SYSTEM INTEGRATION MODULE for more information about exceptions and interrupts.

## 7.2.2 QSM Pin Control Registers

The QSM uses nine pins. Eight of the pins can be used for serial communication or for parallel I/O. Clearing a bit in the Port QS pin assignment register (PQSPAR) assigns the corresponding pin to general-purpose I/O; setting a bit assigns the pin to the QSPI. PQSPAR does not affect operation of the SCI.

The Port QS data direction register (DDRQS) determines whether pins are inputs or outputs. Clearing a bit makes the corresponding pin an input; setting a bit makes the pin an output. DDRQS affects both QSPI function and I/O function. DDRQS1 determines the direction of the TXD pin only when the SCI transmitter is disabled. When the SCI transmitter is enabled, the TXD pin is an output.

The Port QS data register (PORTQS) latches I/O data. PORTQS writes drive pins defined as outputs. PORTQS reads return data present on the pins. To avoid driving undefined data, first write a byte to PORTQS, then configure DDRQS.

PQSPAR and DDRQS are 8-bit registers located at the same word address. Table 7–1 is a summary of QSM pin functions.

|           | Pin      | Mode     | DDRQS Bit | Pin Function                   |
|-----------|----------|----------|-----------|--------------------------------|
| QSPI Pins | MISO     | Master   | 0         | Serial Data Input to QSPI      |
|           |          |          | 1         | General-Purpose Digital Output |
|           |          | Slave    | 0         | General-Purpose Digital Input  |
|           |          |          | 1         | Serial Data Output from QSPI   |
|           | MOSI     | Master   | 0         | General-Purpose Digital Input  |
|           |          |          | 1         | Serial Data Output from QSPI   |
|           |          | Slave    | 0         | Serial Data Input to QSPI      |
|           |          |          | 1         | General-Purpose Digital Output |
|           | SCK      | Master   | 0         | General-Purpose Digital Input  |
|           |          |          | 1         | Clock Output from QSPI         |
|           |          |          | 0         | Clock Input to QSPI            |
|           |          |          | 1         | General-Purpose Digital Output |
|           | PCS0/SS  | Master   | 0         | Mode Fault Input               |
| 1         |          |          | 1         | Chip-Select Output             |
|           |          | Slave    | 0         | QSPI Slave Select Input        |
| [         |          |          | 1         | General-Purpose Digital Output |
|           | PCS[3:1] | Master   | 0         | General-Purpose Digital Input  |
|           |          |          | 1         | Chip-Select Output             |
|           |          | Slave    | 0         | General-Purpose Digital Input  |
|           |          |          | 1         | General-Purpose Digital Output |
| SCI Pins  | TXD      | Transmit | X         | Serial Data Output from SCI    |
| ſ         | RXD      | Receive  | NA        | Serial Data Input to SCI       |
| [         |          |          | NA        |                                |

Table 7–1. QSM Pin Functions

X = DDRQS bit ignored, data is output when TE = 1

## 7.3 Queued Serial Peripheral Interface

The queued serial peripheral interface (QSPI) communicates with external devices via a synchronous serial bus. The QSPI is fully compatible with SPI systems found on other Motorola products, but has enhanced capabilities. The QSPI can perform full duplex three-wire or half duplex two-wire transfers. A variety of transfer rate, clocking, and interrupt-driven communication options is available.

Serial transfer of any number of bits from 8 to 16 can be specified. Programmable transfer length simplifies interfacing to a number of devices that require different data lengths.

An inter-transfer delay of 1 to 500  $\mu$ s (using a 16.78-MHz system clock) may be specified (default is 1  $\mu$ s). Programmable delay simplifies interfacing to a number of devices that require different delays between transfers.

A dedicated 80-byte RAM is used to store received data, data to be transmitted, and a queue of commands. The CPU can access these locations directly — serial peripherals can be treated like memory-mapped parallel devices.

The command queue allows the QSPI to perform up to 16 serial transfers without CPU intervention. Each queue entry contains all the information needed by the QSPI to independently complete one serial transfer.

A pointer identifies the queue location containing the command for the next serial transfer. Normally, the pointer address is incremented after each serial transfer, but the CPU can change the pointer value at any time. Multiple-task support can be provided by segmenting the queue.

The QSPI has four peripheral chip-select pins. Chip-select signals simplify interfacing by reducing CPU intervention. If chip-select signals are externally decoded, 16 independent select signals can be generated. Each chip-select pin can drive up to four independent peripherals, depending on loading.

Wraparound operating mode allows continuous execution of queued commands. In wraparound mode, newly received data replaces previously received data in receive RAM. Wraparound can simplify interfacing with A/D converters by continuously updating conversion values stored in the RAM.

Continuous transfer mode allows simultaneous transfer of an uninterrupted bit stream. Any number of bits in the range 8 to 256 may be transferred without CPU intervention. Longer transfers are possible, but minimal CPU intervention is required to prevent loss of data. A 1- $\mu$ s pause (16.78-MHz system clock) is inserted between each queue entry transfer.



Figure 7-2. QSPI Block Diagram

## 7.3.1 QSPI Registers

The programmer's model for the QSPI consists of the QSM global and pin control registers, four QSPI control registers (SPCR[0:3]), a status register (SPCR), and the 80-byte QSPI RAM.

Registers and RAM can be read and written by the CPU. Refer to **APPENDIX D REGISTER SUMMARY** register bit and field definitions.

7

## 7.3.1.1 Control Registers

Control registers contain parameters for configuring the QSPI and enabling various modes of operation. The CPU has read and write access to all control registers, but the QSM has read access only to all bits except the SPE bit in SPCR1. Control registers must be initialized before the QSPI is enabled to insure defined operation. SPCR1 must be written last because it contains the QSPI enable bit (SPE).

Writing a new value to any control register except SPCR2 while the QSPI is enabled disrupts operation. SPCR2 is buffered — new SPCR2 values become effective after completion of the current serial transfer. Rewriting NEWQP in SPCR2 causes execution to restart at the designated location. Reads of SPCR2 return the current value of the register, not of the buffer.

Writing the same value into any control register except SPCR2 while the QSPI is enabled has no effect on QSPI operation.

## 7.3.1.2 Status Register

SPSR contains information concerning the current serial transmission. Only the QSPI can set the bits in this register. The CPU reads SPSR to obtain QSPI status information and writes it to clear status flags.

## 7.3.2 QSPI RAM

The QSPI contains an 80-byte block of dual-access static RAM that can be accessed by both the QSPI and the CPU. The RAM is divided into three segments: receive data RAM, transmit data RAM, and command control data RAM. Receive data is information received from a serial device external to the MCU. Transmit data is information stored by the CPU for transmission to an external device. Command control data is used to perform transfers. Figure 7–3 shows RAM organization.

#### 7.3.2.1 Receive Data RAM

Data received by the QSPI is stored in this segment. The CPU reads this segment to retrieve data from the QSPI. Data stored in receive RAM is right-justified. Unused bits in a receive queue entry are set to zero by the QSPI upon completion of the individual queue entry. The CPU can access the data using byte, word, or long-word addressing.

The CPTQP value in SPSR shows which queue entries have been executed. The CPU uses this information to determine which locations in receive RAM contain valid data before reading them.



Figure 7-3. QSPI RAM

#### 7.3.2.2 Transmit Data RAM

Data that is to be transmitted by the QSPI is stored in this segment. The CPU normally writes one word of data into this segment for each queue command to be executed.

Information to be transmitted must be written to transmit data RAM in a rightjustified format. The QSPI cannot modify information in the transmit data RAM. The QSPI copies the information to its data serializer for transmission. Information remains in transmit RAM until overwritten.

#### 7.3.2.3 Command RAM

Command RAM is used by the QSPI when in master mode. The CPU writes one byte of control information to this segment for each QSPI command to be executed. The QSPI cannot modify information in command RAM.

Command RAM consists of 16 bytes. Each byte is divided into two fields. The peripheral chip-select field enables peripherals for transfer. The command control field provides transfer options.

A maximum of 16 commands can be in the queue. Queue execution by the QSPI proceeds from the address in NEWQP through the address in ENDQP (both of these fields are in SPCR2).

## 7.3.3 QSPI Pins

The QSPI uses seven MC68HC16Z1 pins. These pins may be configured for general-purpose I/O when not needed for QSPI application.

Table 7-2 shows QSPI input and output pins and their functions.

| Pin Names               | Mnemonics | Mode            | Function                                                  |  |
|-------------------------|-----------|-----------------|-----------------------------------------------------------|--|
| Master In Slave Out     | MISO      | Master<br>Slave | Serial Data Input to QSPI<br>Serial Data Output from QSPI |  |
| Master Out Slave In     | MOSI      | Master<br>Slave | Serial Data Output from QSPI<br>Serial Data Input to QSPI |  |
| Serial Clock            | SCK       | Master<br>Slave | Clock Output from QSPI<br>Clock Input to QSPI             |  |
| Peripheral Chip Selects | PCS[3:0]  | Master          | Select Peripherals                                        |  |
| Slave Select            | SS        | Master<br>Slave | Causes mode fault<br>Initiates serial transfer            |  |

Table 7–2. QSPI Pin Function

## 7.3.4 QSPI Operation

The QSPI uses a dedicated 80-byte block of static RAM accessible by both the QSPI and the CPU to perform queued operations. The RAM is divided into three segments. There are 16 command control bytes, 16 transmit data words, and 16 receive data words. QSPI RAM is organized so that one byte of command control data, one word of transmit data, and one word of receive data correspond to one queue entry, \$0-\$F.

The CPU initiates QSPI operation by setting up a queue of QSPI commands in command RAM, writing transmit data into transmit RAM, then enabling the QSPI. The QSPI executes the queued commands, sets a completion flag (SPIF), and then either interrupts the CPU or waits for CPU intervention.

There are four queue pointers. The CPU16 can access three of them through fields in QSPI registers. The new queue pointer (NEWQP), contained in SPCR2, points to the first command in the queue. An internal queue pointer points to the command currently being executed. The completed queue pointer (CPTQP), contained in SPSR, points to the last command executed. The end queue pointer (ENDQP), contained in SPCR2, points to the final command in the queue.

The internal pointer is initialized to the same value as NEWQP. During normal operation, the command pointed to by the internal pointer is executed, the value in the internal pointer is copied into CPTQP, the internal pointer is incremented, and then the sequence repeats. Execution continues at the internal pointer address unless the NEWQP value is changed. After each command is

QUEUED SERIAL MODULE

executed, ENDQP and CPTQP are compared. When a match occurs, the SPIF flag is set and the QSPI stops unless wraparound mode is enabled.

At reset, NEWQP is initialized to \$0. When the QSPI is enabled, execution begins at queue address \$0 unless another value has been written into NEWQP. ENDQP is initialized to \$0 at reset, but should be changed to show the last queue entry before the QSPI is enabled. NEWQP and ENDQP can be written at any time. When the NEWQP value changes, the internal pointer value also changes. However, if NEWQP is written while a transfer is in progress, the transfer is completed normally. Leaving NEWQP and ENDQP set to \$0 causes a single transfer to occur when the QSPI is enabled.

## 7.3.5 QSPI Operating Modes

The QSPI operates in either master or slave mode. Master mode is used when the MCU originates data transfers. Slave mode is used when an external device initiates serial transfers to the MCU via the QSPI. Switching between the modes is controlled by MSTR in SPCR0. Prior to entering either mode, appropriate QSM and QSPI registers must be properly initialized.

In master mode, the QSPI executes a queue of commands defined by control bits in each command RAM queue entry. Chip-select pins are activated, data is transmitted from transmit RAM and received into receive RAM.

In slave mode, operation proceeds in response to SS pin activation by an external bus master. Operation is similar to master mode, but no peripheral chip selects are generated, and the number of bits transferred is controlled in a different manner. When the QSPI is selected, it automatically executes the next queue transfer to correctly exchange data with the external device.

Although the QSPI inherently supports multimaster operation, no special arbitration mechanism is provided. A mode fault flag (MODF) indicates a request for SPI master arbitration — system software must provide arbitration. Note that unlike previous SPI systems, MSTR is not cleared by a mode fault being set nor are the QSPI pin output drivers disabled. The QSPI and associated output drivers must be disabled by clearing SPE in SPCR1.

Figure 7–4 shows QSPI initialization; Figures 7–5 and 7–6 show QSPI master and slave operation. The CPU must initialize the QSM global and pin registers and the QSPI control registers before enabling the QSPI for either mode of operation (refer to **7.6 QSM Initialization**). The command queue must be written before the QSPI is enabled for master mode operation. Any data to be transmitted should be written into transmit RAM before the QSPI is enabled. During wraparound operation, data for subsequent transmissions may be written at any time.



Figure 7-4. Flowchart of QSPI Initialization Operation

MOTOROLA 7–12 QUEUED SERIAL MODULE

MC68HC16Z1 USER'S MANUAL



Figure 7-5. Flowchart of QSPI Master Operation (Part 1)

MC68HC16Z1 USER'S MANUAL QUEUED SERIAL MODULE



Figure 7–5. Flowchart of QSPI Master Operation (Part 2)

MOTOROLA 7–14 QUEUED SERIAL MODULE

MC68HC16Z1 USER'S MANUAL



MC68HC16Z1 USER'S MANUAL QUEUED SERIAL MODULE

MOTOROLA 7–15 7



Figure 7-6. Flowchart of QSPI Slave Operation (Part 1)

MOTOROLA 7–16

QUEUED SERIAL MODULE

MC68HC16Z1 USER'S MANUAL



Figure 7-6. Flowchart of QSPI Slave Operation (Part 2)

MC68HC16Z1 USER'S MANUAL QUEUED SERIAL MODULE

Normally, the SPI bus performs synchronous bidirectional transfers. The serial clock on the SPI bus master supplies the clock signal (SCK) to time the transfer of data. Four possible combinations of clock phase and polarity may be specified by means of the CPHA and CPOL bits in SPCR0.

Data is transferred with the most significant bit first. The number of bits transferred per command defaults to eight, but may be set to any value from 8 to 16 bits by writing a value into the BITSE field in command RAM.

Typically, SPI bus outputs are not open-drain unless multiple SPI masters are in the system. If needed, the WOMQ bit in SPCR0 can be set to provide wired-OR, open-drain outputs. An external pullup resistor should be used on each output line. WOMQ affects all QSPI pins regardless of whether they are assigned to the QSPI or used as general-purpose I/O.

### 7.3.5.1 Master Mode

Setting the MSTR bit in SPCR0 selects master mode operation. In master mode, the QSPI can initiate serial transfers, but cannot respond to externally initiated transfers. When the slave select input of a device configured for master mode is asserted, a mode fault occurs.

Before QSPI operation is initiated, QSM register PQSPAR must be written to assign necessary pins to the QSPI. The pins necessary for master mode operation are MISO and MOSI, SCK, and one or more of the chip-select pins. MISO is used for serial data input in master mode, and MOSI is used for serial data output. Either or both may be necessary, depending on the particular application. SCK is the serial clock output in master mode.

Before master mode operation is initiated, QSM register DDRQS must be written to direct the data flow on the QSPI pins used. Configure the SCK, MOSI and appropriate chip-select pins PCS[3:0]/SS as outputs. The MISO pin must be configured as an input.

After pins are assigned and configured, write appropriate data to the command queue. If data is to be transmitted, write the data to transmit RAM. Initialize the queue pointers as appropriate.

Data transfer is synchronized with the internally-generated serial clock (SCK). Control bits, CPHA and CPOL, in SPCR0, control clock phase and polarity. Combinations of CPHA and CPOL determine upon which SCK edge to drive outgoing data from the MOSI pin and to latch incoming data from the MISO pin.

QUEUED SERIAL MODULE

Baud rate is selected by writing a value from 2 to 255 into the SPBR field in SPCR0. The QSPI uses a modulus counter to derive SCK baud rate from the MCU system clock. The following expressions apply to SCK baud rate:

```
SCK Baud Rate = System Clock/(2SPBR)
```

or

SPBR = System Clock/(2SCK)(Baud Rate Desired)

Giving SPBR a value of zero or one disables the baud rate generator. SCK is disabled and assumes its inactive state value.

The DSCK field in command RAM determines the delay period from chip-select assertion until the leading edge of the serial clock. The DSCKL field in SPCR1 determines the period of delay before the assertion of SCK. The following expression determines the actual delay before SCK:

PCS to SCK Delay = [DSCKL/System Clock Frequency]

where DSCKL equals {1,2,3, ..., 127}.

When DSCK equals zero, DSCKL is not used. Instead, the PCS valid-to-SCK transition is one-half the DSCK period.

There are two transfer length options. The user can choose a default value of 8 bits, or a programmed value of 8 to 16 bits, inclusive. The programmed value must be written into the BITS field in SPCR0. The BITSE field in command RAM determines whether the default value (BITSE = 0) or the BITS value (BITSE = 1) is used. Table 7–3 shows BITS field encoding.

# Table 7–3. BITS Encoding

| BITS | Bits per Transfer |  |
|------|-------------------|--|
| 0000 | 16                |  |
| 0001 | Reserved          |  |
| 0010 | Reserved          |  |
| 0011 | Reserved          |  |
| 0100 | Reserved          |  |
| 0101 | Reserved          |  |
| 0110 | Reserved          |  |
| 0111 | Reserved          |  |
| 1000 | 8                 |  |
| 1001 | 9                 |  |
| 1010 | 10                |  |
| 1011 | 11                |  |
| 1100 | 12                |  |
| 1101 | 13                |  |
| 1110 | 14                |  |
| 1111 | 15                |  |

Delay after transfer can be used to provide a peripheral deselect interval. A delay can also be inserted between consecutive transfers to allow serial A/D converters to complete conversion. There are two transfer delay options. The user can choose to delay a standard period (1  $\mu$ s with a 16.78-MHz system clock) after serial transfer is complete or can specify a delay period. Writing a value to the DTL field in SPCR1 specifies a delay period. The DT bit in command RAM determines whether the standard delay period (DT = 0) or the specified delay period (DT = 1) is used. The following expression is used to calculate the delay:

Delay after Transfer = [(32DTL)/System Clock Frequency]

where DTL equals {1, 2, 3, ..., 255}.

A zero value for DTL causes a delay-after-transfer value of 8192/system clock.

Standard Delay after Transfer = [17/System Clock]

Adequate delay between transfers must be specified for long data streams. The QSPI requires time, approximately 1  $\mu$ s at 16.78-MHz system clock, to load a transmit RAM entry for transfer. Receiving devices need at least 1  $\mu$ s of delay between successive transfers. If the system clock is operating at a slower rate, the delay between transfers must be increased proportionately.

Operation is initiated by setting the SPE bit in SPCR1. Shortly after SPE is set, the QSPI executes the command at the command RAM address pointed to by NEWQP. Data at the pointer address in transmit RAM is loaded into the data serializer and transmitted — data that is simultaneously received is stored at the pointer address in receive RAM.

When the proper number of bits have been transferred, the QSPI stores the working queue pointer value in CPTQP, increments the working queue pointer, and loads the next data for transfer from transmit RAM. The command pointed to by the incremented working queue pointer will be executed next unless a new value has been written to NEWQP. If a new queue pointer value is written while a transfer is in progress, that transfer will be completed normally.

When the CONT bit in command RAM is set, PCS pins are continuously driven in specified states during and between transfers. If the chip-select pattern changes during or between transfers, the original pattern is driven until execution of the following transfer begins. When CONT is cleared, the data in register QPDR is driven between transfers.

When the QSPI reaches the end of the queue, it sets the SPIF flag. If the SPIFIE bit in SPCR2 is set, an interrupt request is generated when SPIF is asserted. At this point, the QSPI clears SPE and stops unless wraparound mode is enabled.

## 7.3.5.2 Master Wraparound Mode

Wraparound mode is enabled by setting the WREN bit in SPCR2. The queue can wrap to pointer address \$0 or to the address pointed to by NEWQP, depending on the state of the WRTO bit in SPCR2.

In wraparound mode, the QSPI cycles through the queue continuously, even while the QSPI is requesting interrupt service. SPE is not cleared when the last command in the queue is executed. New receive data overwrites previously received data in receive RAM. Each time the end of the queue is reached, the SPIF flag is set. SPIF is not automatically reset. If interrupt-driven SPI service is used, the service routine must clear the SPIF bit to abort the current request. Additional interrupt requests during servicing can be prevented by clearing SPIFIE, but SPIFIE is buffered — clearing it will not abort a current request.

There are two recommended methods of exiting wraparound mode. The WREN bit can be cleared, or the HALT bit in SPCR3 can be set. Exiting wraparound mode by clearing SPE is not recommended — clearing SPE may abort a serial transfer in progress. The QSPI sets SPIF, clears SPE, and stops the first time it reaches the end of the queue after WREN is cleared. After HALT is set, the QSPI finishes the current transfer, then stops executing commands. After the QSPI stops, SPE can be cleared.

## 7.3.5.3 Slave Mode

Clearing the MSTR bit in SPCR0 selects slave mode operation. In slave mode, the QSPI is unable to initiate serial transfers. Transfers are initiated by an external bus master. Slave mode is typically used on a multi-master SPI bus. Only one device can be bus master (operate in master mode) at any given time.

Before QSPI operation is initiated, QSM register PQSPAR must be written to assign necessary pins to the QSPI. The pins necessary for slave mode operation are MISO and MOSI, SCK, and PCS0/SS. MISO is used for serial data output in slave mode, and MOSI is used for serial data input. Either or both may be necessary, depending on the particular application. SCK is the serial clock input in slave mode. Assertion of the active-low slave select signal (SS) initiates slave mode operation.

Before slave mode operation is initiated, DDRQS must be written to direct data flow on the QSPI pins used. Configure the MOSI, SCK and PCS0/SS pins as inputs. The MISO pin must be configured as an output.

After pins are assigned and configured, write data to be transmitted into transmit RAM. Command RAM is not used in slave mode and does not need to be initialized. Unused portions of QSPI RAM can be used by the CPU as general-purpose RAM. Initialize the queue pointers as appropriate.

When SPE is set and MSTR is clear, a low state on the slave select (PCS0/SS) pin commences slave mode operation at the address indicated by NEWQP. Data that is received is stored at the pointer address in receive RAM — data is simultaneously loaded into the data serializer from the pointer address in transmit RAM and transmitted. Transfer is synchronized with the externally generated SCK. The CPHA and CPOL bits determine upon which SCK edge to latch incoming data from the MISO pin and to drive outgoing data from the MOSI pin.

Because the command control segment is not used, the command control bits and peripheral chip-select codes have no effect in slave mode operation. The PCS0/SS pin is used only as an input.

The SPBR, DT and DSCK bits are not used in slave mode. The QSPI drives neither the clock nor the chip-select pins and thus cannot control clock rate or transfer delay.

Because the BITSE option is not available in slave mode, the BITS field specifies the number of bits to be transferred for all transfers in the queue. When the number of bits designated by BITS has been transferred, the QSPI stores the working queue pointer value in CPTQP, increments the working queue pointer, and loads new transmit data from transmit RAM into the data serializer. The working queue pointer address is used the next time PCS0/SS is asserted, unless the CPU writes to NEWQP first.

The QSPI shifts one bit for each pulse of SCK until the slave select input goes high. If  $\overline{SS}$  goes high before the number of bits specified by the BITS field is transferred, the QSPI resumes operation at the same pointer address the next time  $\overline{SS}$  is asserted. The maximum value that the BITS field can have is 16. If more than 16 bits are transmitted before  $\overline{SS}$  is negated, pointers are incremented and operation continues. The QSPI transmits as many bits as it receives at each queue address, until the BITS value is reached or  $\overline{SS}$  is negated.  $\overline{SS}$  need not go high between transfers — the QSPI will transfer data until reaching the end of the queue whether  $\overline{SS}$  remains low or is toggled between transfers.

When the QSPI reaches the end of the queue, it sets the SPIF flag. If the SPIFIE bit in SPCR2 is set, an interrupt request is generated when SPIF is asserted. At this point, the QSPI clears SPE and stops unless wraparound mode is enabled.

### 7.3.5.4 Slave Wraparound Mode

Slave wraparound mode is enabled by setting the WREN bit in SPCR2. The queue can wrap to pointer address \$0 or to the address pointed to by NEWQP, depending on the state of the WRTO bit in SPCR2. Slave wraparound operation is identical to master wraparound operation.

### 7.3.6 Peripheral Chip Selects

Peripheral chip-select signals are used to select an external device for serial data transfer. Chip-select signals are asserted when a command in the queue is executed. Signals are asserted at a logic level corresponding to the value of the PCS bits in the command. More than one chip-select signal can be asserted at a time, and more than one external device can be connected to each PCS pin, provided proper fanout is observed. PCS0 shares a pin with the slave select SS signal, which initiates slave mode serial transfer. If SS is taken low when the QSPI is in master mode, a mode fault occurs.

To set up a chip-select function, set the appropriate bit in PQSPAR, then configure the chip-select pin as an output by setting the appropriate bit in DDRQS. The value of the bit in PORTQS that corresponds to the chip-select pin determines the base state of the chip-select signal — if base state is zero, chip-select assertion must be active high (PCS bit in command RAM must be set); if base state is one, assertion must be active low (PCS bit in command RAM must be cleared). PORTQS bits are cleared during reset — if no new data is written to PORTQS before pin assignment and configuration as an output, base state of

QUEUED SERIAL MODULE

chip-select signals is zero and chip-select pins are configured for active-high operation.

### 7.4 Serial Communication Interface

The serial communication interface (SCI) communicates with external devices via an asynchronous serial bus. The SCI uses a standard nonreturn to zero (NRZ) transmission format. The SCI is fully compatible with other Motorola SCI systems, such as those in M68HC11 and M68HC05 devices. Figure 7–7 is a block diagram of the SCI transmitter; Figure 7–8 is a block diagram of the SCI receiver.

### 7.4.1 SCI Registers

The SCI programming model includes the QSM global and pin control registers, and four SCI registers. There are two SCI control registers (SCCR0 and SCCR1), one status register (SCSR), and one data register (SCDR). Refer to **APPENDIX D REGISTER SUMMARY** for register bit and field definition.

### 7.4.1.1 Control Registers

SCCR0 contains the baud rate selection field. Baud rate must be set before the SCI is enabled. The CPU can read and write this register at any time.

SCCR1 contains a number of SCI configuration parameters, including transmitter and receiver enable bits, interrupt enable bits, and operating mode enable bits. The CPU can read and write this register at any time. The SCI can modify the RWU bit under certain circumstances.

Changing the value of SCI control bits during a transfer operation may disrupt operation. Before changing register values, allow the SCI to complete the current transfer, then disable the receiver and transmitter.



Figure 7-7. SCI Transmitter Block Diagram

MC68HC16Z1 USER'S MANUAL QUEUED SERIAL MODULE



Figure 7-8. SCI Receiver Block Diagram

MOTOROLA 7–26 QUEUED SERIAL MODULE

MC68HC16Z1 USER'S MANUAL

# 7.4.1.2 Status Register

SCSR contains flags that show SCI operating conditions. These flags are cleared either by SCI hardware or by a read/write sequence. In general, flags are cleared by reading SCSR, then reading (receiver status bits) or writing (transmitter status bits) SCDR. A long-word read can consecutively access both SCSR and SCDR. This action clears receive status flag bits that were set at the time of the read, but does not clear TDRE or TC flags.

If an internal SCI signal for setting a status bit comes after the CPU has read the asserted status bits, but before the CPU has written or read register SCDR, the newly set status bit is not cleared — SCSR must be read again with the bit set, and SCDR must be written or read before the status bit is cleared.

Reading either byte of SCSR causes all 16 bits to be accessed, and any status bit already set in either byte will be cleared on a subsequent read or write of register SCDR.

# 7.4.1.3 Data Register

SCDR contains two data registers at the same address. RDR is a read-only register that contains data received by the SCI serial interface. The data comes into the receive serial shifter and is transferred to RDR. TDR is a write-only register that contains data to be transmitted. The data is first written to TDR, then transferred to the transmit serial shifter, where additional format bits are added before transmission. R[7:0]/T[7:0] contain either the first eight data bits received when SCDR is read, or the first eight data bits to be transmitted when SCDR is written. R8/T8 are used when the SCI is configured for 9-bit operation. When it is configured for 8-bit operation, they have no meaning or effect.

# 7.4.2 SCI Pins

Two unidirectional pins, TXD (transmit data) and RXD (receive data), are associated with the SCI. TXD can be used by the SCI or for general-purpose I/O — function is assigned by the Port QS pin assignment register (PQSPAR). The receive data (RXD) pin is dedicated to the SCI. Table 7–4 shows SCI pin function.

|   | Pin Names           | Mnemonics | Mode Function                            |                             |
|---|---------------------|-----------|------------------------------------------|-----------------------------|
| I | <b>Receive Data</b> | RXD       | Receiver Disabled Not Used               |                             |
|   |                     |           | Receiver Enabled Serial Data Input to    |                             |
| Ī | Transmit Data       | TXD       | Transmitter Disabled General-Purpose I/O |                             |
|   |                     |           | Transmitter Enabled                      | Serial Data Output from SCI |

| Table 7–4. SCI Pin Function | Table | 7-4. | SCI | Pin | Function |
|-----------------------------|-------|------|-----|-----|----------|
|-----------------------------|-------|------|-----|-----|----------|

### 7.4.3 SCI Operation

SCI operation can be polled by means of status flags in SPSR, or interruptdriven operation can be employed by means of the interrupt enable bits in SCCR1.

### 7.4.3.1 Definition of Terms

- Bit-Time The time required to transmit or receive one bit of data; one cycle of the baud frequency.
- Start Bit One bit-time of logic zero that indicates the beginning of a data frame. A start bit must begin with a one-to-zero transition and be preceded by at least three receive time (RT) samples of logic one.
- Stop Bit One bit-time of logic one that indicates the end of a data frame.
- Frame A complete unit of serial information. The SCI can use 10-bit or 11-bit frames.
- Data Frame A start bit, a specified number of data or information bits, and at least one stop bit.
- Idle Frame A frame that consists of consecutive ones. An idle frame has no start bit.
- Break Frame A frame that consists of consecutive zeros. A break frame has no stop bits.

### 7.4.3.2 Serial Formats

All data frames must have a start bit and at least one stop bit. Receiving and transmitting devices must use the same data frame format. The SCI provides hardware support for both 10-bit and 11-bit frames. The serial mode (M) bit in SCI control register one (SCCR1) specifies the number of bits per frame.

The most common data frame format for NRZ serial interface is one start bit, eight data bits (LSB first), and one stop bit; a total of 10 bits. The most common 11-bit data frame contains one start bit, eight data bits, a parity or control bit, and one stop bit. 10-bit and 11-bit frames are shown in Table 7–5.

MOTOROLA 7–28 QUEUED SERIAL MODULE

|       | 10-B | it Frames      |      |
|-------|------|----------------|------|
| Start | Data | Parity/Control | Stop |
| 1     | 7    | _              | 2    |
| 1     | 7    | 1              | 1    |
| 1     | 8    | _              | 1    |
|       | 11-B | it Frames      |      |
| Start | Data | Parity/Control | Stop |
| 1     | 7    | 1              | 2    |
| 1     | 8    | 1              | 1    |

# Table 7–5. Serial Frame Formats

# 7.4.3.3 Baud Clock

The SCI baud clock is programmed by writing a 13-bit value to the baud rate (SCBR) field in SCI control register zero (SCCR0). Baud clock is derived from the MCU system clock by a modulus counter. Writing a value of zero to SCBR disables the baud rate generator. Baud clock rate is calculated as follows:

SCI Baud Clock Rate = System Clock/(32SCBR)

where SCBR is in the range {1, 2, 3, ..., 8191}.

The SCI receiver operates asynchronously. An internal clock is necessary to synchronize with an incoming data stream. The SCI baud clock generator produces a receive time (RT) sampling clock with a frequency 16 times that of the SCI baud clock. The SCI determines the position of bit boundaries from transitions within the received waveform, and adjusts sampling points to the proper positions within the bit period.

# 7.4.3.4 Parity Checking

The parity type (PT) bit in SCCR1 selects either even (PT = 0) or odd (PT = 1) parity. PT affects received and transmitted data. The parity enable (PE) bit in SCCR1 determines whether parity checking is enabled (PE = 1) or disabled (PE = 0). When PE is set, the MSB of the data in a frame is used for the parity function. For transmitted data, a parity bit is generated; for received data, the parity bit is checked. When parity checking is enabled, the parity flag (PF) in the SCI status register (SCSR) is set if a parity error is detected.

Enabling parity affects the number of data bits in a frame, which can in turn affect frame size. Table 7–6 shows possible data and parity formats.

# Table 7–6. Effect of Parity Checking on Data Size

| М | PE | Result                    |  |  |
|---|----|---------------------------|--|--|
| 0 | 0  | 8 Data Bits               |  |  |
| 0 | 1  | 7 Data Bits, 1 Parity Bit |  |  |
| 1 | 0  | 9 Data Bits               |  |  |
| 1 | 1  | 8 Data Bits, 1 Parity Bit |  |  |

# 7.4.3.5 Transmitter Operation

The transmitter consists of a serial shifter and a parallel data register (TDR) located in the SCI data register (SCDR). The serial shifter cannot be directly accessed by the CPU. The transmitter is double-buffered — data can be loaded into the TDR while other data is shifted out. The transmitter enable (TE) bit in SCCR1 enables (TE = 1) and disables (TE = 0) the transmitter.

Shifter output is connected to the TXD pin while the transmitter is operating (TE = 1, or TE = 0 and transmission in progress). Wired-OR operation should be specified when more than one transmitter is used on the same SCI bus. The wired-OR mode select bit (WOMS) in SCCR1 determines whether TXD is an open-drain (wired-OR) output or a normal CMOS output. An external pull-up resistor on the TXD pin is necessary for wired-OR operation. WOMS controls TXD function whether the pin is used for SCI transmissions (TE = 1) or as a general-purpose I/O pin.

Data to be transmitted is written to TDR, then transferred to the serial shifter. The transmit data register empty (TDRE) flag in SCSR shows the status of TDR. When TDRE = 0, TDR contains data that has not been transferred to the shifter — writing to TDR again will overwrite the data. TDRE is set when the data in TDR is transferred to the shifter. Before new data can be written to TDR, however, the processor must clear TDRE by writing to SCSR. If new data is written to TDR without first clearing TDRE, the data will not be transmitted.

The transmission complete (TC) flag in SCSR shows transmitter shifter state. When TC = 0, the shifter is busy. TC is set when all shifting operations are completed. TC is not automatically cleared — the processor must clear it by first reading SCSR while TC is set, then writing new data to TDR.

The state of the serial shifter is checked when the TE bit is set. If TC = 1, an idle frame is transmitted as a preamble to the following data frame. If TC = 0, the current operation continues until the final bit in the frame is sent, then the preamble is transmitted. The TC bit is set at the end of preamble transmission.

The send break (SBK) bit in SCCR1 is used to insert break frames in a transmission. A nonzero integer number of break frames is transmitted while SBK is set. Break transmission begins when SBK is set, and ends with the transmission in progress at the time either SBK or TE are cleared. If SBK is set while a transmission is in progress, that transmission finishes normally before the break begins. To assure the minimum break time, toggle SBK quickly to one and back to zero. The TC bit is set at the end of break transmission. After break transmission, at least one bit-time of logic level one (mark idle) is transmitted to ensure that a subsequent start bit can be detected.

If TE remains set, after all pending idle, data and break frames are shifted out, TDRE and TC are set and TXD is held at logic level one (mark).

When TE is cleared, the transmitter is disabled after all pending idle, data and break frames are transmitted. The TC flag is set, and the TXD pin reverts to control by PQSPAR and DDRQS. Buffered data is not transmitted after TE is cleared. To avoid losing data in the buffer, do not clear TE until TDRE is set.

Some serial communication systems require a mark on the TXD pin even when the transmitter is disabled. Configure the TXD pin as an output (DDRQS), then write a one to PORTQS7. When the transmitter releases control of the TXD pin, it reverts to driving a logic one output.

To insert a delimiter between two messages, to place nonlistening receivers in wakeup mode between transmissions, or to signal a retransmission by forcing an idle line, clear and then set TE before data in the serial shifter has shifted out. The transmitter finishes the transmission, then sends a preamble. After the preamble is transmitted, if TDRE is set, the transmitter will mark idle. Otherwise, normal transmission of the next sequence will begin.

Both TDRE and TC have associated interrupts. The interrupts are enabled by the transmit interrupt enable (TIE) and transmission complete interrupt enable (TCIE) bits in SCCR1. Service routines can load the last byte of data in a sequence into the TDR, then terminate the transmission when a TDRE interrupt occurs.

### 7.4.3.6 Receiver Operation

The receiver enable (RE) bit in SCCR1 enables (RE = 1) and disables (RE = 0) the transmitter. The receiver contains a receive serial shifter and a parallel receive data register (RDR) located in the SCI data register (SCDR). The serial shifter cannot be directly accessed by the CPU. The receiver is double-buffered — data can be held in RDR while other data is shifted in.

Receiver bit processor logic drives a state machine that determines the logic level for each bit-time. This state machine controls when the bit processor logic

| MC68HC16Z1    |  |
|---------------|--|
| USER'S MANUAL |  |

QUEUED SERIAL MODULE

is to sample the RXD pin and also controls when data is to be passed to the receive serial shifter. A receive time (RT) clock is used to control sampling and synchronization. Data is shifted into the receive serial shifter according to the most recent synchronization of the RT clock with the incoming data stream. From this point on, data movement is synchronized with the MCU system clock. Operation of the receiver state machine is detailed in the *QSM Reference Manual* (QSMRM/AD).

The number of bits shifted in by the receiver depends on the serial format. However, all frames must end with at least one stop bit. When the stop bit is received, the frame is considered to be complete, and the received data in the serial shifter is transferred to RDR. The receiver data register flag (RDRF) is set when the data is transferred.

Noise errors, parity errors, and framing errors can be detected while a data stream is being received. Although error conditions are detected as bits are received, the noise flag (NF), the parity flag (PF), and the framing error (FE) flag in SCSR are not set until data is transferred from the serial shifter to RDR.

RDRF must be cleared before the next transfer from the shifter can take place. If RDRF is set when the shifter is full, transfers are inhibited and the overrun error (OR) flag in SCSR is set. OR indicates that the CPU needs to service RDR faster. When OR is set, the data in RDR is preserved, but the data in the serial shifter is lost. Since framing, noise, and parity errors are detected while data is in the serial shifter, FE, NF, and PF cannot occur at the same time as OR.

When the CPU16 reads SCSR and SCDR in sequence, it acquires status and data, and also clears the status flags. Reading SCSR acquires status and arms the clearing mechanism. Reading SCDR acquires data and clears SCSR.

When RIE in SCCR1 is set, an interrupt request is generated whenever RDRF is set. Because receiver status flags are set at the same time as RDRF, they do not have separate interrupt enables.

### 7.4.3.7 Idle-Line Detection

During a typical serial transmission, frames are transmitted isochronously — no idle time occurs between frames. Even when all the data bits in a frame are logic ones, the start bit provides one logic zero bit-time during the frame. An idle line is a sequence of contiguous ones equal to the current frame size. Frame size is determined by the state of the M bit in SCCR1.

The SCI receiver has both short and long idle-line detection capability. Idle-line detection is always enabled. The idle line type (ILT) bit in SCCR1 determines which type of detection is used. When an idle line condition is detected, the IDLE flag in SCSR is set.

For short idle-line detection, the receiver bit processor counts contiguous logic one bit-times whenever they occur. Short detection provides the earliest possible recognition of an idle line condition, because the stop bit and contiguous logic ones before and after it are counted. For long idle-line detection, the receiver counts logic ones after the stop bit is received. Only a complete idle frame will cause the IDLE flag to be set.

In some applications, CPU overhead can cause a bit-time of logic level one to occur between frames. This bit-time does not affect content, but if it occurs after a frame of ones when short detection is enabled, the receiver flags an idle line.

When the idle line interrupt enable (ILIE) bit in SCCR1 is set, an interrupt request is generated when the IDLE flag is set. The flag is cleared by reading SCSR and SCDR in sequence. IDLE is not set again until after at least one frame has been received (RDRF = 1). This prevents an extended idle interval from causing more than one interrupt.

### 7.4.3.8 Receiver Wakeup

The receiver wakeup function allows a transmitting device to direct a transmission to a single receiver or to a group of receivers by sending an address frame at the start of a message. Hardware activates each receiver in a system under certain conditions. Resident software must process address information and enable or disable receiver operation.

A receiver is placed in wakeup mode by setting the receiver wake up (RWU) bit in SCCR1. While RWU is set, receiver status flags and interrupts are disabled. Although the CPU can clear RWU, it is normally cleared by hardware during wakeup.

The WAKE bit in SCCR1 determines which type of wakeup is used. When WAKE = 0, idle-line wakeup is selected. When WAKE = 1, address-mark wakeup is selected. Both types require a software-based device addressing and recognition scheme.

Idle-line wakeup allows a receiver to sleep until an idle line is detected. When an idle-line is detected, the receiver clears RWU and wakes up. The receiver waits for the first frame of the next transmission. The byte is received normally, transferred to register RDR, and the RDRF flag is set. If software does not recognize the address, it can set RWU and put the receiver back to sleep. For idle-line wakeup to work, there must be a minimum of one frame of idle line between transmissions — there must be no idle time between frames within a transmission.

Address-mark wakeup uses a special frame format to wake up the receiver. When the MSB of an address-mark frame is set, that frame contains address

QUEUED SERIAL MODULE

information. The first frame of each transmission must be an address frame. When the MSB of a frame is set, the receiver clears RWU and wakes up. The byte is received normally, transferred to register RDR, and the RDRF flag is set. If software does not recognize the address, it can set RWU and put the receiver back to sleep. Address-mark wakeup allows idle time between frames and eliminates idle time between transmissions. However, there is a loss of efficiency due to an additional bit-time per frame.

## 7.4.3.9 Internal Loop

The LOOPS bit in SCCR1 controls a feedback path on the data serial shifter. When LOOPS is set, SCI transmitter output is fed back into the receive serial shifter. TXD is asserted (idle line). Both transmitter and receiver must be enabled prior to entering loop mode.

# 7.5 QSM Initialization

After reset, the QSM remains in an idle state until initialized. A general sequence guide for initialization follows.

### A. Global

- 1. Configuration register (QSMCR)
  - a. Write an interrupt arbitration priority value into the IARB field.
  - b. Clear the FREEZE and/or STOP bits for normal operation.
- 2. Interrupt vector and interrupt level registers (QIVR and QILR)
  - a. Write QSPI/SCI interrupt vector into QIVR.
  - b. Write QSPI (ILSPI) and SCI (ILSCI) interrupt priorities into QILR.
- 3. Port data and data direction registers (PORTQS and DDRQS)
  - a. Write a data word to PORTQS.
  - b. Establish direction of QSM pins used for I/O by writing to DDRQS.
- 4. Assign pin functions by writing to the pin assignment register (PQSPAR)
- B. Queued Serial Peripheral Interface
  - 1. Write appropriate values to QSPI COMMAND RAM.
  - 2. QSPI control register zero (SPCR0)
    - a. Write a transfer rate value into the BR field.
    - b. Determine clock phase (CPHA), and clock polarity (CPOL).
    - c. Determine number of bits to be transferred in a serial operation (BIT).
    - d. Select master or slave operating mode (MSTR).
    - e. Enable or disable wired-OR operation (WOMQ).
  - 3. QSPI control register one (SPCR1)
    - a. Establish a delay following serial transfer by writing to the DTL field.
    - b. Establish a delay before serial transfer by writing to the DSCKL field.

- 4. QSPI control register two (SPCR2)
  - a. Write an initial queue pointer value into the NEWQP field.
  - b. Write a final queue pointer value into the ENDQP field.
  - c. Enable or disable queue wraparound (WREN).
  - d. Write wraparound address into the WRTO field.
  - e. Enable or disable QSPI flag interrupt (SPIFIE).
- 5. QSPI control register three (SPCR3)
  - a. Enable or disable halt at end of queue (HALT).
  - b. Enable or disable halt and mode fault interrupts (HMIE).
  - c. Enable or disable loopback (LOOPQ).
- 6. To enable the QSPI, set the SPE bit in SPCR1.
- C. Serial Communication Interface (SCI)
  - 1. SCI control register zero (SCCR0)
  - a. Write a transfer rate (baud) value into the BR field.
  - 2. SCI control register one (SCCR1)
    - a. Select serial mode (M)
    - b. Enable use (PE) and type (PT) of parity check.
    - c. Select use (RWU) and type (WAKE) of receiver wakeup.
    - d. Enable idle-line detection (ILT) and interrupt (ILIE).
    - e. Enable or disable wired-OR operation (WOMS).
    - f. Enable or disable break transmission (BK).
  - 3. To receive, set the receiver (RE) and receiver interrupt (RIE) bits in SCCR1.
  - 4. To transmit
    - a. Set transmitter (TE) and transmitter interrupt (TIE).
    - b. Clear the transmitter data register empty (TDRE) and transmit complete (TC) indicators by reading the serial communication interface status register (SCSR).
    - c. Write transmit data to the serial communication data register (SCDR).

7

7

MOTOROLA 7–36 QUEUED SERIAL MODULE

MC68HC16Z1 USER'S MANUAL

# SECTION 8 GENERAL-PURPOSE TIMER

The general-purpose timer (GPT) is an 11-channel timer for use in systems where a moderate level of CPU control is required. This section is an overview of GPT function. Refer to the *GPT Reference Manual* (GPTRM/AD) for complete information on the GPT module.

### 8.1 General

The GPT consists of a capture/compare unit, a pulse accumulator, and two pulse-width modulators. A bus interface unit connects the GPT to the intermodule bus (IMB).

The capture/compare unit features three input capture channels, four output compare channels, and one channel that can be selected as an input capture or output compare channel. These channels share a 16-bit free-running counter (TCNT) which derives its clock from a nine-stage prescaler or from the external clock input signal, PCLK.

Pulse accumulator channel logic includes an 8-bit counter; the pulse accumulator can operate in either event counting mode or gated time accumulation mode.

Pulse-width modulator outputs are periodic waveforms whose duty cycles can be independently selected and modified by user software. The PWM circuits share a 16-bit free-running counter that can be clocked by the same nine-stage prescaler used by the capture/compare unit or by the PCLK input.

All GPT pins can also be used for general-purpose input/output. The input capture and output compare pins form a bidirectional 8-bit parallel port (Port GP). PWM pins are outputs only. PAI and PCLK pins are inputs only.



Figure 8–1. GPT Block Diagram

### 8.2 GPT Registers and Address Map

The GPT programming model consists of a configuration register (GPTMCR), parallel I/O registers (DDRGP, PORTGP), capture/compare registers (TCNT, TCTL1, TCTL2, TIC[1:3], TOC[1:4], TI4/O5, CFORC), pulse accumulator registers (PACNT, PACTL), pulse-width modulation registers (PWMA, PWMB, PWMC, PWMCNT, PWMBUFA, PWMBUFB), status registers (TFLG1, TFLG2) and interrupt control registers (TMSK1, TMSK2). Functions of the module configuration register are discussed in **8.3 Special Modes of Operation** and **8.4 Polled and Interrupt-Driven Operation**. Other register functions are discussed in the appropriate sections.

All registers can be accessed using byte or word operations. Certain capture/compare registers and pulse-width modulation registers must be accessed by word operations to ensure coherency. If byte accesses are used to read a register such as the timer counter register (TCNT), there is a possibility that data in the byte not being accessed will change while the other byte is read. Both bytes must be accessed at the same time.

GENERAL-PURPOSE TIMER

The modmap (MM) bit in the system integration module configuration register (SIMCR) defines the most significant bit (ADDR23) of the IMB address for each register in the MCU. Because the CPU16 drives only ADDR[19:0] and ADDR[23:20] follow the logic state of ADDR19, MM must equal one.

Refer to **APPENDIX D REGISTER SUMMARY** for a GPT address map and register bit/field descriptions. **SECTION 4 SYSTEM INTEGRATION MODULE** contains more information about how the state of MM affects the system.

## 8.3 Special Modes of Operation

The GPT module configuration register (GPTMCR) is used to control special GPT operating modes. These include low-power stop mode, freeze mode, single-step mode, and test mode. Normal GPT operation can be polled or interrupt-driven. Refer to **8.4 Polled and Interrupt-Driven Operation** for more information.

### 8.3.1 Low-power Stop Mode

Low-power stop operation is initiated by setting the STOP bit in GPTMCR. In stop mode the system clock to the module is turned off. The clock remains off until STOP is negated or a reset occurs. All counters and prescalers within the timer stop counting while the STOP bit is set. Only the module configuration register (GPTMCR) and the interrupt configuration register (ICR) should be accessed while in the stop mode. Accesses to other GPT registers cause unpredictable behavior. Low-power stop can also be used to disable module operation during debugging.

### 8.3.2 Freeze Mode

The freeze (FRZ[1:0]) bits in GPTMCR are used to determine what action is taken by the GPT when the IMB FREEZE signal is asserted. FREEZE is asserted when the CPU enters background debugging mode. At the present time, FRZ1 has no effect; setting FRZ0 causes the GPT to enter freeze mode. Refer to **SECTION 5 CENTRAL PROCESSING UNIT** for more information on background debugging mode.

Freeze mode freezes the current state of the timer. The prescaler and the pulse accumulator do not increment and changes to the pins are ignored (input pin synchronizers are not clocked). All of the other timer functions that are controlled by the CPU will operate normally; for example, registers can be written to change pin directions, force output compares, and read or write I/O pins.

While the FREEZE signal is asserted, the CPU has write access to registers and bits that are normally read-only, or write-once. The write-once bits can be written to as often as needed. The prescaler and the pulse accumulator remain stopped and the input pins are ignored until the FREEZE signal is negated (the CPU is no longer in BDM), the FRZO bit is cleared, or the MCU is reset.

Activities that are in progress prior to FREEZE assertion are completed. For example, if an input edge on an input capture pin is detected just as the FREEZE signal is asserted, the capture occurs and the corresponding interrupt flag is set.

### 8.3.3 Single-Step Mode

Two bits in GPTMCR support GPT debugging without using BDM. When the STOPP bit is asserted, the prescaler and the pulse accumulator stop counting and changes at input pins are ignored. Reads of the GPT pins will return the state of the pin when STOPP was set. After STOPP is set, the INCP bit can be set to increment the prescaler and clock the input synchronizers once. The INCP bit is self-negating after the prescaler is incremented. INCP can be set repeatedly. The INCP bit has no effect when the STOPP bit is not set.

### 8.3.4 Test Mode

Test mode is used during Motorola factory testing. The GPT has no dedicated test-mode control register; all GPT testing in the MC68HC16Z1 is done under control of the system integration module.

### 8.4 Polled and Interrupt-Driven Operation

Normal GPT function can be polled or interrupt-driven. All GPT functions have an associated status flag and an associated interrupt. The timer interrupt flag registers (TFLG1 and TFLG2) contain status flags used for polled and interruptdriven operation. The timer mask registers (TMSK1 and TMSK2) contain interrupt control bits. Control routines can monitor GPT operation by polling the status registers. When an event occurs, the control routine transfers control to a service routine that handles that event. If interrupts are enabled for an event, the GPT requests interrupt service when the event occurs. Using interrupts does not require continuously polling the status flags to see if an event has taken place. However, status flags must be cleared after an interrupt is serviced, in order to disable the interrupt request.

## 8.4.1 Polled Operation

When an event occurs in the GPT, that event sets a status flag in TFLG1 or TFLG2. The GPT sets the flags; they cannot be set by the CPU. TFLG1 and TFLG2 are 8-bit registers that can be accessed individually or as one 16-bit register. The registers are initialized to zero at reset. Table 8–1 shows status flag assignment.

| Flag Register<br>Mnemonic Assignment     |  | Source                           |  |
|------------------------------------------|--|----------------------------------|--|
| IC1F TFLG1                               |  | Input Capture 1                  |  |
| IC2F TFLG1                               |  | Input Capture 2                  |  |
| IC3F TFLG1                               |  | Input Capture 3                  |  |
| OC1F TFLG1                               |  | Output Compare 1                 |  |
| OC2FTFLG1OC3FTFLG1OC4FTFLG1IC4/OC5FTFLG1 |  | FLG1 Output Compare 2            |  |
|                                          |  | Output Compare 3                 |  |
|                                          |  | Output Compare 4                 |  |
|                                          |  | Input Capture 4/Output Compare 5 |  |
| TOF TFLG2                                |  | Timer Overflow                   |  |
| PAOVF TFLG2                              |  | Pulse Accumulator Overflow       |  |
| PAIF TFLG2                               |  | Pulse Accumulator Input          |  |

Table 8–1. GPT Status Flags

For each bit in TFLG1 and TFLG2 there is a corresponding bit in TMSK1 and TMSK2 in the same bit position. If a mask bit is set and an associated event occurs, a hardware interrupt request is generated.

In order to re-enable a status flag after an event occurs, the status flags must be cleared. Status registers are cleared in a particular sequence. The register must first be read for set flags, then zeros must be written to the flags that are to be cleared. If a new event occurs between the time that the register is read and the time that it is written, the associated flag is not cleared.

### 8.4.2 GPT Interrupts

The GPT has 11 internal sources that can cause it to request interrupt service (refer to Table 8–2). Setting bits in TMSK1 and TMSK2 enables specific interrupt sources. TMSK1 and TMSK2 are 8-bit registers that can be addressed individually or as one 16-bit register. The registers are initialized to zero at reset. For each bit in TMSK1 and TMSK2 there is a corresponding bit in TFLG1 and TFLG2 in the same bit position. TMSK2 also controls the operation of the timer prescaler. Refer to **8.7 Prescaler** for more information.

| MC68HC16Z1           |  |  |  |  |
|----------------------|--|--|--|--|
| <b>USER'S MANUAL</b> |  |  |  |  |

The value of the interrupt level (IRL) field in the interrupt control register (ICR) determines the priority of GPT interrupt requests. IRL values correspond to MCU interrupt request signals IRQ[7:1]. IRQ7 is the highest priority interrupt request signal; IRQ1 is the lowest-priority signal. A value of %111 causes IRQ7 to be asserted when a GPT interrupt request is made; lower field values cause corresponding lower-priority interrupt request signals to be asserted. Setting field value to %000 disables interrupts.

| Name    | Source<br>Number | Source                           | Vector<br>Number |
|---------|------------------|----------------------------------|------------------|
|         | 0000             | Adjusted Channel                 | IVBA : 0000      |
| IC1     | 0001             | Input Capture 1                  | IVBA : 0001      |
| IC2     | 0010             | Input Capture 2                  | IVBA : 0010      |
| IC3     | 0011             | Input Capture 3                  | IVBA : 0011      |
| OC1     | 0100             | Output Compare 1                 | IVBA : 0100      |
| OC2     | 0101             | Output Compare 2                 | IVBA : 0101      |
| OC3     | 0110             | Output Compare 3                 | IVBA : 0110      |
| OC4     | 0111             | Output Compare 4                 | IVBA : 0111      |
| IC4/OC5 | 1000             | Input Capture 4/Output Compare 5 | IVBA : 1000      |
| то      | 1001             | Timer Overflow                   | IVBA : 1001      |
| PAOV    | 1010             | Pulse Accumulator Overflow       | IVBA : 1010      |
| PAI     | 1011             | Pulse Accumulator Input          | IVBA : 1011      |

 Table 8–2. GPT Interrupt Sources

The CPU16 recognizes only interrupt request signals of a priority greater than the condition code register interrupt priority (IP) mask value. When the CPU acknowledges an interrupt request, the priority of the acknowledged request is written to the IP mask and driven out on the IMB address lines.

When the IP mask value driven out on the address lines is the same as the IRL value, the GPT contends for arbitration priority. GPT arbitration priority is determined by the value of the IARB field in GPTMCR. Each MCU module that can make interrupt requests must be assigned a nonzero IARB value in order to implement an arbitration scheme. Arbitration is performed by means of serial assertion of IARB field bit values.

When the GPT wins interrupt arbitration, it responds to the CPU interrupt acknowledge cycle by placing an interrupt vector number on the data bus. The vector number is used to calculate displacement into the CPU16 exception vector table. Vector numbers are formed by concatenating the value in the ICR IVBA field with a 4-bit value supplied by the GPT when an interrupt request is made.

Hardware prevents the vector number from changing while it is being driven out on the IMB. Vector number assignment is shown in Table 8–2.

At reset, IVBA is initialized to \$0. To enable interrupt-driven timer operation, the upper nibble of a user-defined vector number (\$40–\$FF) must be written to IVBA, and interrupt handler routines must be located at the addresses pointed to by the corresponding vector. Note that IVBA must be written before GPT interrupts are enabled, or the GPT could supply a vector number (\$00 to \$0F) that corresponds to an assigned or reserved exception vector.

The internal GPT interrupt priority hierarchy is shown in Table 8–2. The lower the interrupt source number, the higher the priority. A single GPT interrupt source can be given priority over all other GPT interrupt sources by assigning the priority adjust field (PAB) in the ICR a value equal to its source number.

Interrupt requests are asserted until associated status flags are cleared. Status flags must be cleared in a particular sequence. The status register must first be read for set flags, then zeros must be written to the flags that are to be cleared. If a new event occurs between the time that the register is read and the time that it is written, the associated flag is not cleared.

Refer to SECTION 5 CENTRAL PROCESSING UNIT and SECTION 4 SYSTEM INTEGRATION MODULE for more information about exceptions and interrupts.

### 8.5 Pin Descriptions

The GPT uses twelve of the MC68HC16Z1 pins. Each pin can perform more than one function. Descriptions of GPT pins divided into functional groups follow.

### 8.5.1 Input Capture Pins (IC[1:3])

Each of these pins is associated with a single GPT input capture function. Each pin has hysteresis — any pulse longer than two system clocks is guaranteed to be valid and any pulse shorter than one system clock is ignored. Each pin has an associated 16-bit capture register that holds the captured counter value. These pins can also be used for general-purpose I/O. Refer to **8.8.2 Input Capture Functions** for more information.

### 8.5.2 Input Capture/Output Compare Pin (IC4/OC5)

This pin can be configured for use by either an input capture or an output compare function. It has an associated 16-bit register that is used for holding either the input capture value or the output match value. When used for input capture the pin has the same hysteresis as other input capture pins. The pin can be used for general-purpose I/O. Refer to **8.8.2 Input Capture Functions** and **8.8.3 Output Compare Functions** for more information.

GENERAL-PURPOSE TIMER

## 8.5.3 Output Compare Pins (OC[1:4])

These pins are used for GPT output compare functions. Each pin has an associated 16-bit compare register and a 16-bit comparator. Pins OC2, OC3, and OC4 are associated with a specific output compare function. The OC1 function can affect the output of all compare pins. If the OC1 pin is not needed for an output compare function it can be used to output the clock selected for the timer counter register. Any of these pins can also be used for general-purpose I/O. Refer to **8.8.3 Output Compare Functions** for more information.

## 8.5.4 Pulse Accumulator Input Pin (PAI)

The PAI pin connects a discrete signal to the pulse accumulator for timed or gated pulse accumulation. PAI has hysteresis — any pulse longer than two system clocks is guaranteed to be valid and any pulse shorter than one system clock is ignored. It can be used as a general-purpose input pin. Refer to **8.10 Pulse Accumulator** for more information.

## 8.5.5 Pulse-Width Modulation (PWMA, PWMB)

PWMA and PWMB pins carry pulse-width modulator outputs. The modulators can be programmed to generate a periodic waveform of variable frequency and duty cycle. PWMA can be used to output the clock selected as the input to the PWM counter. These pins can also be used for general-purpose output. Refer to **8.11 Pulse-Width Modulation (PWM) Unit** for more information.

# 8.5.6 Auxiliary Timer Clock Input (PCLK)

PCLK connects an external clock to the GPT. The external clock can be used as the clock source for the capture/compare unit or the PWM unit in place of one of the prescaler outputs. PCLK has hysteresis — any pulse longer than two system clocks is guaranteed to be valid and any pulse shorter than one system clock is ignored. This pin can also be used as a general-purpose input pin. Refer to 8.7 Prescaler for more information.

### 8.6 General-Purpose I/O

Any GPT pin can be used for general-purpose I/O when it is not used for another purpose. Capture/compare pins are bidirectional, others can be used only for output or input. I/O direction is controlled by a data direction bit in the Port GP data direction register (DDRGP).

Parallel data is read from and written to the Port GP data register (PORTGP). Pin data can be read even when pins are configured for a timer function. Data read from PORTGP always reflects the state of the external pin, while data written to PORTGP may not always affect the external pin. Data written to PORTGP does not immediately affect pins used for output compare functions, but the data is latched. When an output compare function is disabled, the last data written to PORTGP is driven out on the associated pin if it is configured as an output. Data written to PORTGP can cause input captures if the corresponding pin is configured for input capture function.

The pulse accumulator input (PAI) and the external clock input (PCLK) pins provide general-purpose input. The state of these pins can be read by accessing the PAIS and PCLKS bits in the pulse accumulator control register (PACTL).

Pulse-width modulation A and B (PWMA/PWMB) output pins can serve as general-purpose outputs. The force PWM value (FPWMx) and the force logic one (F1x) bits in the compare force (CFORC) and PWM control (PWMC) registers, respectively, control their operation.

### 8.7 Prescaler

Capture/compare and PWM units have independent 16-bit free-running counters as a main timing component. These counters derive their clocks from the prescaler or from the PCLK input. Figure 8–2 is a prescaler block diagram.

In the prescaler, the system clock is divided by a nine-stage divider chain. Prescaler outputs equal to system clock divided by 2, 4, 8, 16, 32, 64, 128, 256 and 512 are provided. Connected to these outputs are 2 multiplexers, one for the capture/compare unit, the other for the PWM unit.

Multiplexers can each select one of seven prescaler taps or an external input from the PCLK pin. Multiplexer output for the timer counter (TCNT) is selected by bits CPR[2:0] in timer interrupt mask register 2 (TMSK2). Multiplexer output for the PWM counter (PWMCNT) is selected by bits PPR[2:0] in the PWM control register C (PWMC).

After reset, the GPT is configured to use system clock divided by 4 for TCNT and system clock divided by 2 for PWMCNT. Initialization software can change the division factor — the PPR bits can be written at any time but the CPR bits can only be written once after reset unless the GPT is in test or freeze mode.

The prescaler can be read at any time. In freeze mode the prescaler can also be written. Word accesses must be used to ensure coherency. If coherency is not needed byte accesses may be used. The prescaler value is contained in bits [8:0] while bits [15:9] are unimplemented and will be read as zeros.



Figure 8–2. Prescaler Block Diagram

Multiplexer outputs (including the PCLK signal) can be connected to external pins. The CPROUT bit in the TMSK2 register configures the OC1 pin to output the TCNT clock and the PPROUT bit in the PWMC register configures the PWMA pin to output the PWMC clock. CPROUT and PPROUT can be written at any time. Clock signals on OC1 and PWMA do not have a 50% duty cycle. They have the period of the selected clock but are high for only one system clock time.

GENERAL-PURPOSE TIMER

The prescaler also supplies three clock signals to the pulse accumulator clock select mux. These are the system clock divided by 512, the external clock signal from the PCLK pin and the capture/compare clock signal.

### 8.8 Capture/Compare Unit

The capture/compare unit contains the timer counter (TCNT), the input capture (IC) functions and the output compare (OC) functions. Figure 8–3 is a block diagram of the capture/compare unit.

### 8.8.1 Timer Counter

The timer counter (TCNT) is the key timing component in the capture/compare unit. The timer counter is a 16-bit free-running counter that starts counting after the processor comes out of reset. The counter cannot be stopped during normal operation. After reset, the GPT is configured to use the system clock divided by four as the input to the counter. The prescaler divides the system clock and provides selectable input frequencies. User software can configure the system to use one of seven prescaler outputs or an external clock.

The counter can be read any time without affecting its value. Because the GPT is interfaced to the IMB and the IMB supports a 16-bit bus, a word read gives a coherent value. If coherency is not needed, byte accesses can be made. The counter is set to \$0000 during reset and is normally a read-only register. In test mode and freeze mode, any value can be written to the timer counter.

When the counter rolls over from \$FFFF to \$0000, the timer overflow flag (TOF) in timer interrupt flag register 2 (TFLG2) is set. An interrupt can be enabled by setting the corresponding interrupt enable bit (TOI) in timer interrupt mask register 2 (TMSK2). Refer to **8.4.2 GPT Interrupts** for more information.

### 8.8.2 Input Capture Functions

All GPT input capture functions use the same 16-bit timer counter (TCNT). Each input capture pin has a dedicated 16-bit latch and input edge-detection/selection logic. Each input capture function has an associated status flag, and can cause the GPT to make an interrupt service request.

When a selected edge transition occurs on an input capture pin, the associated 16-bit latch captures the content of TCNT and sets the appropriate status flag. An interrupt request can be generated when the transition is detected.



Figure 8–3. Capture/Compare Block Unit Diagram

MOTOROLA

8-12

Edge-detection logic consists of control bits that enable edge detection and select a transition to detect. The EDGExA and EDGExB bits in timer control register 2 (TCTL2) determine whether the input capture functions detect rising edges only, falling edges only, or both rising and falling edges. Clearing both bits disables the input capture function. Input capture functions operate independently of each other and can capture the same TCNT value if individual input edges are detected within the same timer count cycle.

Input capture interrupt logic includes a status flag, which indicates that an edge has been detected, and an interrupt enable bit. An input capture event sets the ICxF bit in the timer interrupt flag register 1 (TFLG1) and causes the GPT to make an interrupt request if the corresponding ICxI bit is set in the timer interrupt mask register 1 (TMSK1). If the ICxI bit cleared, software must poll the status flag to determine that an event has occurred. Refer to **8.4 Polled and Interrupt-Driven Operation** for more information.

Input capture events are generally asynchronous to the timer counter. Because of this, input capture signals are conditioned by a synchronizer and digital filter. Events are synchronized with the system clock so that latching of TCNT content and counter incrementation occur on opposite half-cycles of the system clock. Inputs have hysteresis — capture of any transition longer than two system clocks is guaranteed; any transition shorter than one system clock has no effect.

Figure 8–4 shows the relationship of system clock to synchronizer output. The value latched into the capture register is the value of the counter several system clock cycles after the transition that triggers the edge detection logic. There can be up to one clock cycle of uncertainty in latching of the input transition. Maximum time is determined by the system clock frequency.

The input capture register is a 16-bit register — a word access is required to ensure coherency. If coherency is not required, byte accesses can be used to read the register. Input capture registers can be read at any time without affecting their values.



Figure 8–4. Input Capture Timing Example

An input capture occurs every time a selected edge is detected, even when the input capture status flag is set. This means that the value read from the input capture register corresponds to the most recent edge detected, which may not be the edge that caused the status flag to be set.

## 8.8.3 Output Compare Functions

Each GPT output compare pin has an associated 16-bit compare register and a 16-bit comparator. Each output compare function has an associated status flag, and can cause the GPT to make an interrupt service request. Output compare logic is designed to prevent false compares during data transition times.

When the programmed content of an output compare register matches the value in TCNT, an output compare status flag (OCxF) bit in TFLG1 is set. If the appropriate interrupt enable bit (OCxI) in TMSK1 is set, an interrupt request is made when a match occurs. Refer to **8.4.2 GPT Interrupts** for more information.

Operation of output compare 1 differs from that of the other output compare functions. OC1 control logic can be programmed to make state changes on other OC pins when an OC1 match occurs. Control bits in the timer compare force register (CFORC) allow for early forced compares.

## 8.8.3.1 Output Compare 1

Output compare 1 can affect any or all of OC[1:5] when an output match occurs. In addition to allowing generation of multiple control signals from a single comparison operation, this function makes it possible for two or more output compare functions to control the state of a single OC pin. Output pulses as short as one timer count can be generated in this way.

The OC1 action mask register (OC1M) and the OC1 action data register (OC1D) control OC1 function. Setting a bit in OC1M selects a corresponding bit in the GPT parallel data port. Bits in OC1D determine whether selected bits are to be set or cleared when an OC1 match occurs. Pins must be configured as outputs in order for the data in the register to be driven out on the corresponding pin. If an OC1 match and another output match occur at the same time and both attempt to alter the same pin, the OC1 function controls the state of the pin.

## 8.8.3.2 Forced Output Compare

Timer compare force register (CFORC) is used to make forced compares. The action taken as a result of a forced compare is the same as when an output compare match occurs, except that status flags are not set. Forced channels take programmed actions immediately after the write to CFORC.

The CFORC register is implemented as the upper byte of a 16-bit register which also contains the PWM control register C (PWMC). It can be accessed as 8 bits or a word access can be used. Reads of force compare bits (FOC) have no meaning and always return zeros. These bits are self-negating.

## 8.9 Input Capture 4/Output Compare 5

The IC4/OC5 pin can be used for input capture, output compare, or generalpurpose I/O. A function enable bit (I4/O5) in the pulse accumulator control register (PACTL) configures the pin for input capture (IC4) or output compare function (OC5). Both bits are cleared during reset, configuring the pin as an input, but also enabling the OC5 function. IC4/OC5 I/O functions are controlled by the DDRGPI4/O5 bit in the Port GP data direction register (DDRGP).

The 16-bit register (TI4/O5) used with the IC4/OC5 function acts as an input capture register or as an output compare register depending on which function is selected. When used as the input capture 4 register, it cannot be written to except in test or freeze mode.

## 8.10 Pulse Accumulator

The pulse accumulator counter (PACNT) is an 8-bit read/write up-counter. PACNT can operate in external event counting or gated time accumulation modes. Figure 8–5 is a block diagram of the pulse accumulator.

In event counting mode, the counter increments each time a selected transition of the pulse accumulator input (PAI) pin is detected. The maximum clocking rate is the system clock divided by four.

In gated time accumulation mode a clock increments PACNT while the PAI pin is in the active state. There are four possible clock sources.

Two bits in the TFLG2 register show pulse accumulator status. The pulse accumulator flag (PAIF) indicates that a selected edge has been detected at the PAI pin. The pulse accumulator overflow flag (PAOVF) indicates that the pulse accumulator count has rolled over from \$FF to \$00. This can be used to extend the range of the counter beyond 8 bits.

An interrupt request can be made when each of the status flags is set. However, operation of the PAI interrupt depends on operating mode. In event counting mode, an interrupt is requested when the edge being counted is detected. In gated mode, the request is made when the PAI input changes from active to inactive state. Interrupt requests are enabled by the PAOVI and PAII bits in the TMSK2 register.

Bits in the pulse accumulator control register (PACTL) control the operation of PACNT. The PAMOD bit selects event counting or gated operation. In event counting mode, the PEDGE control bit determines whether a rising or falling edge is detected; in gated mode, PEDGE specifies the active state of the gate signal. Bits PACLK[1:0] select the clock source used in gated mode.

PACTL and PACNT are implemented as one 16-bit register, but may be accessed with byte or word access cycles. Both registers are cleared at reset, but the PAIS and PCLKS bits show the state of the PAI and PCLK pins.

The PAI pin can also be used for general-purpose input. The logic state of the PAIS bit in PACTL shows the state of the pin.



Figure 8–5. Pulse Accumulator Block Diagram

## 8.11 Pulse-Width Modulation Unit

The pulse-width modulation (PWM) unit has two output channels, PWMA and PWMB. A single clock output from the prescaler multiplexer drives a 16-bit counter that is used to control both channels. Figure 8–6 is a block diagram of the pulse-width modulation unit.

The PWM unit has two operational modes. Fast mode uses a clocking rate equal to 1/256 of the prescaler output rate; slow mode uses a rate equal to 1/32768 of the prescaler output rate. The duty cycle ratios of the two PWM channels can be individually controlled by software. The PWMA pin can also output the clock that drives the PWM counter. PWM pins can also be used as output pins.





**GENERAL-PURPOSE TIMER** 

MC68HC16Z1 USER'S MANUAL

## 8.11.1 PWM Counter

The 16-bit counter in the PWM unit is similar to the timer counter in the capture/compare unit. During reset, the GPT is configured to use the system clock divided by two to drive the counter. Initialization software can reconfigure the counter to use one of seven prescaler outputs or an external clock input from the PCLK pin.

The PWM count register (PWMCNT can be read at any time without affecting its value. A read must be a word access to ensure coherence, but byte accesses can be made if coherence is not needed. The counter is cleared to \$0000 during reset and is a read-only register except in freeze or test mode.

Fifteen of the sixteen counter bits are output to multiplexers A and B. The multiplexers provide the fast and slow modes of the PWM unit. Mode for PWMA is selected by the SFA bit in the PWM control register C (PWMC). Mode for PWMB is selected by the SFB bit in the same register.

PWMA, PWMB, and PPR[2:0] bits in PWMC control PWM output frequency. In fast mode, bits [7:0] of PWMCNT are used to clock the PWM logic; in slow mode, bits [14:7] are used. The period of a PWM output in slow mode is 128 times longer than the fast mode period. Table 8–3 shows a range of PWM output frequencies using a 16.78 MHz system clock.

| PPR[2:0] | Prescaler Tap     | Fast Mode | Slow Mode  |
|----------|-------------------|-----------|------------|
| 000      | Div 2 = 8.39 MHz  | 32.8 kHz  | 256 Hz     |
| 001      | Div 4 = 4.19 MHz  | 16.4 kHz  | 128 Hz     |
| 010      | Div 8 = 2.10 MHz  | 8.19 kHz  | 64.0 Hz    |
| 011      | Div 16 = 1.05 MHz | 4.09 kHz  | 32.0 Hz    |
| 100      | Div 32 = 524 kHz  | 2.05 kHz  | 16.0 Hz    |
| 101      | Div 64 = 262 kHz  | 1.02 kHz  | 8.0 Hz     |
| 110      | Div 128 = 131 kHz | 512 Hz    | 4.0 Hz     |
| 111      | PCLK              | PCLK/256  | PCLK/32768 |

### Table 8–3. PWM Frequency Range Using 16.78 MHz System Clock

### 8.11.2 PWM Function

The pulse width values of the PWM outputs are determined by control registers PWMA and PWMB. PWMA and PWMB are 8-bit registers that are implemented as two bytes of a 16-bit register. PWMA and PWMB can be accessed as separate bytes or as one 16-bit register. A value of \$00 loaded into either register causes the corresponding output pin to output a continuous logic level zero signal. A value of \$80 causes the corresponding output signal to have a 50% duty cycle, and so on, to the maximum value of \$FF, which corresponds to an output which is at logic level one for 255/256 of the cycle.

Setting the F1A (for PWMA) or F1B (for PWMB) bits in the CFORC register causes the corresponding pin to output a continuous logic level one signal. The logic level of the associated pin does not change until the end of the current cycle. F1A and F1B are the lower two bits of CFORC, but can be accessed at the same word address as PWMC.

Data written to PWMA and PWMB is not used until the end of a complete cycle. This prevents supurious short or long pulses when register values are changed. The current duty cycle value is stored in the appropriate PWM buffer register (PWMBUFA or PWMBUFB). The new value is transferred from the PWM register to the buffer register at the end of the current cycle.

Registers PWMA, PWMB, and PWMC, are reset to \$00 during reset. These registers may be written or read at any time. PWMC is implemented as the lower byte of a 16-bit register. The upper byte is the CFORC register. The buffer registers, PWMBUFA and PWMBUFB, are read-only at all times and may be accessed as separate bytes or as one 16-bit register.

Pins PWMA and PWMB can also be used for general-purpose output. The values of the F1A and F1B bits in PWMC are driven out on the corresponding PWM pins when normal PWM operation is disabled. When read, the F1A and F1B bits reflect the states of the PWMA and PWMB pins.

## SECTION 9 STANDBY RAM MODULE

The standby RAM (SRAM) module consists of a control register block and a 1-Kbyte array of fast (two bus cycle) static RAM. The SRAM is especially useful for system stacks and variable storage. SRAM can be mapped to any 1 Kbyte boundary in the address map, but must not overlap the module control registers (overlap makes the registers inaccessible). Data can be read/written in bytes, words or long words. SRAM is powered by  $V_{DD}$  in normal operation. During power-down, SRAM contents can be maintained by power from the  $V_{STBY}$  input. Power switching between sources is automatic.

## 9.1 SRAM Register Block

There are four SRAM control registers: the RAM module configuration register (RAMMCR), the RAM test register (RAMTST), and the RAM array base address registers (RAMBAH/RAMBAL).

The modmap (MM) bit in the system integration module configuration register (SIMCR) defines the most significant bit (ADDR23) of the IMB address for each module in the MC68HC16Z1. Because the CPU16 in the MC68HC16Z1 drives only ADDR[19:0] and ADDR[23:20] follow the logic state of ADDR19, MM must equal one. **SECTION 4 SYSTEM INTEGRATION MODULE** contains more information about how the state of MM affects the system.

There is an 8-byte minimum control register block size for the SRAM module. Unimplemented register addresses are read as zeros, and writes have no effect. Refer to **APPENDIX D REGISTER SUMMARY** for the register block address map and register bit/field definitions.

### 9.2 SRAM Array Address Mapping

Base address registers RAMBAH and RAMBAL are used to specify the SRAM array base address in the MC68HC16Z1 memory map. RAMBAH and RAMBAL can only be written while the SRAM is in low-power mode (RAMMCR STOP = 1) and the base address lock (RAMMCR RLCK = 0) is disabled. RLCK can be written once only to a value of one. This prevents accidental remapping of the array.

In the MC68HC16Z1, ADDR[23:20] follow the logic state of ADDR19 unless externally driven. The SRAM array must not be mapped to addresses \$7FF000-\$7FFFFF, which are inaccessible to the CPU16. If mapped to these addresses, the array remains inaccessible until a reset occurs.

### 9.3 SRAM Array Address Space Type

The RASP field in RAMMCR determines SRAM array address space type. The SRAM module can respond to both program and data space accesses or to program space accesses only. This allows code to be executed from RAM, and permits use of program counter relative addressing mode for operand fetches from the array. Refer to SECTION 4 SYSTEM INTEGRATION MODULE and SECTION 5 CENTRAL PROCESSING UNIT for more information concerning address space types and program/data space access.

### 9.4 Normal Access

The array can be accessed by byte, word, or long word. A byte or aligned word access takes one bus cycle or two system clocks. A long word or misaligned word access requires two bus cycles. Refer to **SECTION 4 SYSTEM INTEGRATION MODULE** for more information concerning access times.

## 9.5 Standby and Low-Power Stop Operation

Standby and low-power modes should not be confused. Standby mode maintains the RAM array when the MCU main power supply is turned off. Low-power mode minimizes MCU power consumption.

Relative voltage levels of the MCU  $V_{DD}$  and  $V_{STBY}$  pins determine whether the SRAM is in standby mode. SRAM circuitry senses when the difference between the two supply voltages is greater than a specified limit, and switches to the higher-voltage power source. If specified levels are maintained, there is no loss of memory when switching occurs. Access to the array is not guaranteed while the SRAM module is powered from  $V_{STBY}$ . If standby operation is not desired, connect the  $V_{STBY}$  pin to the  $V_{SS}$  pin.

Setting the STOP bit in RAMMCR switches the SRAM module to low-power mode. In low-power mode, the array retains its contents, but cannot be read or written by the CPU. If  $V_{DD}$  falls below  $V_{SB}$  while the SRAM is in low-power mode, internal circuitry switches to  $V_{STBY}$ , as in standby mode. Because the CPU16 always operates in supervisor mode, STOP can be read or written at any time. STOP is set during reset. Stop mode is exited by clearing STOP.

STANDBY RAM MODULE

Refer to **APPENDIX A ELECTRICAL CHARACTERISTICS** for standby switching and power consumption specifications.

### 9.6 Reset

Reset places the SRAM in low-power mode, enables program space access, and clears the base address registers and the register lock bit. These actions make it possible to write a new base address into the registers.

When a synchronous reset occurs while a byte or word SRAM access is in progress, the access is completed. If reset occurs during the first word access of a long-word operation, only the first word access is completed. If reset occurs during the second word access of a long-word operation, the entire access is completed. Data being read from or written to the RAM may be corrupted by asynchronous reset. Refer to **SECTION 4 SYSTEM INTEGRATION MODULE** for more information concerning resets.

#### STANDBY RAM MODULE

MC68HC16Z1 USER'S MANUAL

## APPENDIX A ELECTRICAL CHARACTERISTICS

This appendix contains electrical specification tables and reference timing diagrams. Each timing diagram has an associated key table made up of parameters abstracted from the specification tables. Pertinent notes have been included in the key tables.

| Rating                                                                                                                 | Symbol           | Value                                          | Unit |
|------------------------------------------------------------------------------------------------------------------------|------------------|------------------------------------------------|------|
| Supply Voltage <sup>1,2,6</sup>                                                                                        | V <sub>DD</sub>  | -0.3 to + 6.5                                  | v    |
| Input Voltage1,2,3,4,6                                                                                                 | V <sub>in</sub>  | -0.3 to +6.5                                   | V    |
| Instantaneous Maximum Current                                                                                          |                  |                                                | mA   |
| Single pin limit (applies to all pins) <sup>1,4,5,6</sup>                                                              | I <sub>D</sub>   | 25                                             |      |
| Operating Maximum Current                                                                                              |                  |                                                | μA   |
| Digital input disruptive current <sup>4,5,6,7</sup><br>V <sub>SS</sub> − 0.3 ≤ V <sub>IN</sub> ≤ V <sub>DD</sub> + 0.3 | liD              | – 500 to 500                                   |      |
| Operating Temperature Range<br>MC68HC16Z1 "C" Suffix<br>MC68HC16Z1 "V" Suffix<br>MC68HC16Z1 "M" Suffix                 | T <sub>A</sub>   | TL to TH<br>40 to 85<br>40 to 105<br>40 to 125 | °C   |
| Storage Temperature Range                                                                                              | T <sub>stg</sub> | -55 to 150                                     | °C   |

### Table A–1. Maximum Ratings

NOTES:

- Permanent damage can occur if maximum ratings are exceeded. Exposure to voltages or currents in excess of recommended values affects device reliability. Device modules may not operate normally while being exposed to electrical extremes.
- 2. Although sections of the device contain circuitry to protect against damage from high static voltages or electrical fields, take normal precautions to avoid exposure to voltages higher than maximum-rated voltages.
- 3. All pins except TSTME/TSC.
- 4. All functional non-supply pins are internally clamped to  $V_{SS}.$  All functional pins except EXTAL,  $\overline{\text{TSTME}}/\text{TSC}$ , and XFC are internally clamped to  $V_{DD}.$
- 5. Power supply must maintain regulation within operating  $V_{DD}$  range during instantaneous and operating maximum current condition.
- 6. This parameter is periodically sampled rather than 100% tested.
- Total input current for all digital input-only and all digital input/output pins must not exceed 10 mA. Exceeding this limit can cause disruption of normal operation.

Α

### Table A–2. Thermal Characteristics

| Characteristic                                                                       | Symbol          | Value | Unit |
|--------------------------------------------------------------------------------------|-----------------|-------|------|
| Thermal Resistance<br>Plastic 132-Pin Surface Mount<br>Plastic 144-Pin Surface Mount | Θ <sub>JA</sub> | 38    | °C/W |

The average chip-junction temperature (T<sub>J</sub>) in C can be obtained from:

 $T_{J} = T_{A} + (P_{D} \Theta_{JA}) \quad (1)$ 

where

TA

= Ambient Temperature, °C

Θ<sub>JA</sub> = Package Thermal Resistance, Junction-to-Ambient, °C/W

 $P_D = P_{INT} + P_{I/O}$ 

PINT = I<sub>DD</sub> × V<sub>DD</sub>, Watts — Chip Internal Power

 $P_{VO}$  = Power Dissipation on Input and Output Pins — User Determined

For most applications  $P_{I/O}$  <  $P_{INT}$  and can be neglected. An approximate relationship between  $P_D$  and  $T_J$  (if  $P_{I/O}$  is neglected) is:

 $P_D = K + (T_J + 273^{\circ}C)$  (2)

Solving equations 1 and 2 for K gives:

$$K = P_D + (T_A + 273^{\circ}C) + \Theta_{JA} \times P_D^2$$
 (3)

where K is a constant pertaining to the particular part. K can be determined from equation (3) by measuring  $P_D$  (at equilibrium) for a known  $T_A$ . Using this value of K, the values of  $P_D$  and  $T_J$  can be obtained by solving equations (1) and (2) iteratively for any value of  $T_A$ .

### Table A–3. Clock Control Timing

 $(V_{DD} \text{ and } V_{DDSYN} = 5.0 \text{ Vdc} \pm 10\%, V_{SS} = 0 \text{ Vdc}, T_A = T_L \text{ to } T_H.$ 

| Characteristic                                                               | Symbol            | Min          | Max                                             | Unit |
|------------------------------------------------------------------------------|-------------------|--------------|-------------------------------------------------|------|
| PLL Reference Frequency Range                                                | fref              | 25           | 50                                              | kHz  |
| System Frequency <sup>1</sup>                                                |                   | dc           | 16.78                                           |      |
| On-Chip PLL Frequency                                                        | f <sub>sys</sub>  | 0.131        | 16.78                                           | MHz  |
| External Clock Operation                                                     |                   | dc           | 16                                              |      |
| PLL Lock Time <sup>2</sup>                                                   | tipli             | -            | 20                                              | ms   |
| Limp Mode Clock Frequency <sup>3</sup><br>SYNCR X bit = 0<br>SYNCR X bit = 1 | flimp             | _            | f <sub>sys</sub> max /2<br>f <sub>sys</sub> max | MHz  |
| CLKOUT Stability <sup>4,5</sup><br>Short term<br>Long term                   | C <sub>stab</sub> | -1.0<br>-0.5 | 1.0<br>0.5                                      | %    |

32.768 kHz reference)

NOTES:

- 1. All internal registers retain data at 0 Hz.
- 2. Assumes that stable  $V_{DDSYN}$  is applied, that an external filter capacitor with a value of 0.1  $\mu$ F is attached to the XFC pin, and that the crystal oscillator is stable. Lock time is measured from power-up to RESET release. This specification also applies to the period required for PLL lock after changing the W and Y frequency control bits in the synthesizer control register (SYNCR) while the PLL is running, and to the period required for the clock to lock after LPSTOP.
- 3. Determined by the initial control voltage applied to the on-chip VCO. The X bit in SYNCR controls a divide by two scaler on the system clock output.
- 4. Short-term CLKOUT stability is the average deviation from programmed frequency measured over a 2 μs interval at maximum f<sub>Sys</sub>. Long-term CLKOUT stability is the average deviation from programmed frequency measured over a 1 ms interval at maximum f<sub>Sys</sub>. Stability is measured with a stable external clock applied variation in crystal oscillator frequency is additive to this figure.
- 5. This parameter is periodically sampled rather than 100% tested.

MOTOROLA A–4 APPENDIX A ELECTRICAL CHARACTERISTICS MC68HC16Z1 USER'S MANUAL

## Table A-4. DC Characteristics

| Characteristic                                                                                                                                                                                                                                            | Symbol                                                  | Min                    | Max                    | Unit                   |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|------------------------|------------------------|------------------------|
| Input High Voltage                                                                                                                                                                                                                                        | VIH                                                     | 0.7 (V <sub>DD</sub> ) | V <sub>DD</sub> + 0.3  | V                      |
| Input Low Voltage                                                                                                                                                                                                                                         | VIL                                                     | V <sub>SS</sub> - 0.3  | 0.2 (V <sub>DD</sub> ) | V                      |
| Input Hysteresis <sup>1,9</sup>                                                                                                                                                                                                                           | V <sub>HYS</sub>                                        | 0.5                    |                        | ۷                      |
| Input Leakage Current <sup>2</sup><br>V <sub>in</sub> =V <sub>DD</sub> or V <sub>SS</sub> All input-only pins except ADC pins                                                                                                                             | l <sub>in</sub>                                         | -2.5                   | 2.5                    | μA                     |
| High Impedance (Off-State) Leakage Current <sup>2</sup><br>V <sub>in</sub> =V <sub>DD</sub> or V <sub>SS</sub> All input/output and output pins                                                                                                           | loz                                                     | -2.5                   | 2.5                    | μA                     |
| CMOS Output High Voltage <sup>2,3</sup><br>$I_{OH} = -10.0 \ \mu A$ Group 1,2,4 input/output and all output pins                                                                                                                                          | V <sub>OH</sub>                                         | V <sub>DD</sub> – 0.2  |                        | v                      |
| CMOS Output Low Voltage <sup>2</sup><br>$I_{OL} = 10.0 \ \mu A$ Group 1,2,4 input/output and all output pins                                                                                                                                              | V <sub>OL</sub>                                         | —                      | 0.2                    | v                      |
| Output High Voltage <sup>2,3</sup><br>I <sub>OH =</sub> -0.8 mA Group 1,2,4 input/output and all output pins                                                                                                                                              | V <sub>OH</sub>                                         | V <sub>DD</sub> – 0.8  |                        | v                      |
| Output Low Voltage <sup>2</sup><br>IOL = 1.6 mA Group 1 I/O Pins, CLKOUT, FREEZE/QUOT, IPIPE0<br>IOL = 5.3 mA Group 2 and Group 4 I/O Pins, CSBOOT, BG/CS<br>IOL = 12 mA Group 3                                                                          | VOL                                                     |                        | 0.4<br>0.4<br>0.4      | v                      |
| Three State Control Input High Voltage                                                                                                                                                                                                                    | VIHTSC                                                  | 1.6 (V <sub>DD</sub> ) | 9.1                    | V                      |
| $ \begin{array}{llllllllllllllllllllllllllllllllllll$                                                                                                                                                                                                     | IMSP                                                    |                        | -120                   | μA                     |
| V <sub>DD</sub> Supply Current <sup>6</sup><br>RUN <sup>4</sup><br>LPSTOP, 32.768 kHz crystal, VCO Off (STSIM = 0)<br>LPSTOP (External clock input frequency = maximum f <sub>sys</sub> )                                                                 | I <sub>DD</sub><br>S <sub>IDD</sub><br>S <sub>IDD</sub> |                        | 110<br>350<br>5        | mΑ<br>μΑ<br>mΑ         |
| Clock Synthesizer Operating Voltage                                                                                                                                                                                                                       | VDDSYN                                                  | 4.5                    | 5.5                    | ۷                      |
| V <sub>DDSYN</sub> Supply Current <sup>6</sup><br>32.768 kHz crystal, VCO on, maximum f <sub>sys</sub><br>External Clock, maximum f <sub>sys</sub><br>LPSTOP, 32.768 kHz crystal, VCO off (STSIM = 0)<br>32.768 kHz crystal, V <sub>DD</sub> powered down | Iddsyn<br>Iddsyn<br>S <sub>iddsyn</sub><br>Iddsyn       |                        | 1<br>5<br>150<br>100   | m Α<br>m Α<br>μΑ<br>μΑ |
| RAM Standby Voltage <sup>7</sup><br>Specified V <sub>DD</sub> applied<br>V <sub>DD</sub> = V <sub>SS</sub>                                                                                                                                                | V <sub>SB</sub>                                         | 0.0<br>3.0             | 5.5<br>5.5             | v                      |
| RAM Standby Current <sup>7</sup><br>Specified V <sub>DD</sub> applied<br>V <sub>DD</sub> = V <sub>SS</sub>                                                                                                                                                | I <sub>SB</sub><br>I <sub>SB</sub>                      | -2.5                   | 2.5<br>50              | μΑ<br>μΑ               |
| Power Dissipation <sup>8</sup>                                                                                                                                                                                                                            | PD                                                      | -                      | 605                    | mΨ                     |

(V<sub>DD</sub> and V<sub>DDSYN</sub> = 5.0 Vdc  $\pm$  10%, V<sub>SS</sub> = 0 Vdc, T<sub>A</sub> = T<sub>L</sub> to T<sub>H</sub>)

## Table A-4. DC Characteristics (Continued)

|                                  | Characteristic                                                                                                  | Symbol          | Min | Max                     | Unit |
|----------------------------------|-----------------------------------------------------------------------------------------------------------------|-----------------|-----|-------------------------|------|
| Input Capacitance <sup>2,9</sup> | All input-only pins except ADC pins<br>All input/output pins                                                    | C <sub>in</sub> | _   | 10<br>20                | pF   |
|                                  | s and CLKOUT, FREEZE/QUOT, IPIPE0<br>Group 2 I/O Pins and CSBOOT, BG/CS<br>Group 3 I/O pins<br>Group 4 I/O pins | CL              |     | 90<br>100<br>130<br>200 | pF   |

 $(V_{DD} \text{ and } V_{DDSYN} = 5.0 \text{ Vdc} \pm 10\%, V_{SS} = 0 \text{ Vdc}, T_A = T_L \text{ to } T_H)$ 

#### NOTES:

- 1. Applies to:
  - Port ADA [7:0] AN[7:0] Port ADA [7:0] AN[7:0] Port E [7:4] <u>SIZ[1:0]</u>, AS, DS Port F [7:0] IRQ[7:1], MODCLK Port GP [7:0] IC4/OC5/OC1, IC[3:1], OC[4:1]/OC1 Port QS [7:0] TXD, PCS[3:1], PCS0/SS, SCK, MOSI, MISO BKPT/DSCLK, DSI/IPIPE1, PAI, PCLK, RESET, RXD, TSTME/TSC
- 2. Input-Only Pins: TSTME/TSC, BKPT/DSCLK, PAI, PCLK, RXD Output-Only Pins: CSBOOT, BG/CS1, CLKOUT, FREEZE/QUOT, DS0/IPIPE0, PWMA, PWMB Input/Output Pins:
  - Group 1: Port GP [7:0] - IC4/OC5/OC1, IC[3:1], OC[4:1]/OC1 DATA[15:0], DSI/IPIPE1
  - Port C [6:0] ADDR[22:19]/<u>CS[9:6]</u>, FC[2:0]/<u>CS[5:3]</u> Port E [7:0] <u>SIZ[1:0]</u>, AS, DS, AVEC, DSACK[1:0] Port F [7:0] IRQ[7:1], MODCLK Group 2: Port QS [7:3] - TXD, PCS[3:1], PCS0/SS ADDR23/CS10/ECLK, ADDR[18:0], R/W, BERR, BR/CS0, BGACK/CS2
  - Group 3: HALT, RESET
  - Group 4: MISO, MOSI, SCK
- 3. Does not apply to HALT and RESET because they are open drain pins. Does not apply to Port QS [7:0] (TXD, PCS[3:1], PCS0/SS, SCK, MOSI, MISO) in wired-OR mode.
- 4. Current measured with system clock frequency of 16.78 MHz, all modules active.
- 5. Use of an active pulldown device is recommended.
- Total operating current is the sum of the appropriate V<sub>DD</sub> supply and V<sub>DDSYN</sub> supply currents.
- 7. The SRAM module will not switch into standby mode as long as VSB does not exceed VDD by more than 0.5 Volt. The SRAM array cannot be accessed while the module is in standby mode.
- Power dissipation measured with system clock frequency of 16.78 MHz, all modules active. Power 8. dissipation is calculated using the following expression:

 $P_D = Maximum V_{DD} (I_{DDSYN} + I_{DD})$ 

9. This parameter is periodically sampled rather than 100% tested.

| Num                 | Characteristic                                                                                  | Symbol             | Min  | Max   | Unit |
|---------------------|-------------------------------------------------------------------------------------------------|--------------------|------|-------|------|
| F1 <sup>2</sup>     | Frequency of Operation (32.768 kHz crystal)                                                     | f                  | 0.13 | 16.78 | MHz  |
| 1                   | Clock Period                                                                                    | t <sub>cyc</sub>   | 59.6 | -     | ns   |
| 1A                  | ECLK Period                                                                                     | t <sub>Ecyc</sub>  | 476  | _     | ns   |
| 1B <sup>3</sup>     | External Clock Input Period                                                                     | tXcyc              | 64   |       | ns   |
| 2, 3                | Clock Pulse Width                                                                               | tcw                | 24   |       | ns   |
| 2A, 3A              | ECLK Pulse Width                                                                                | tECW               | 236  | —     | ns   |
| 2B, 3B <sup>3</sup> | External Clock Input High/Low Time                                                              | <sup>t</sup> XCHL  | 32   |       | ns   |
| 4, 5                | CLKOUT Rise and Fall Time                                                                       | tCrf               |      | 5     | ns   |
| 4A, 5A              | Rise and Fall Time (All Outputs except CLKOUT)                                                  | t <sub>rf</sub>    |      | 8     | ns   |
| 4B, 5B              | External Clock Input Rise and Fall Time                                                         | tXCrf              |      | 5     | ns   |
| 6                   | Clock High to ADDR, FC, SIZE Valid                                                              | <sup>t</sup> CHAV  | 0    | 29    | ns   |
| 7                   | Clock High to ADDR, Data, FC, SIZE, High Impedance                                              | <sup>t</sup> CHAZx | 0    | 59    | ns   |
| 8                   | Clock High to ADDR, FC, SIZE, Invalid                                                           | <sup>t</sup> CHAZn | 0    | -     | ns   |
| 9                   | Clock Low to AS, DS, CS Asserted                                                                | tCLSA              | 2    | 25    | ns   |
| 9A4                 | AS to DS or CS Asserted (Read)                                                                  | <sup>t</sup> STSA  | -15  | 15    | ns   |
| 11                  | ADDR, FC, SIZE Valid to $\overline{AS}$ , $\overline{CS}$ , (and $\overline{DS}$ Read) Asserted | tavsa              | 15   | —     | ns   |
| 12                  | Clock Low to AS, DS, CS Negated                                                                 | <sup>t</sup> CLSN  | 2    | 29    | ns   |
| 13                  | AS, DS, CS Negated to ADDR, FC, SIZE Invalid (Address Hold)                                     | tSNAI              | 15   | —     | ns   |
| 14                  | AS, CS (and DS Read) Width Asserted                                                             | tswa               | 100  | —     | ns   |
| 14A                 | DS, DS Width Asserted (Write)                                                                   | tswaw              | 45   | -     | ns   |
| 14B                 | AS, CS (and DS Read) Width Asserted (Fast Cycle)                                                | tswdw              | 40   | -     | ns   |
| 155                 | AS, DS, CS Width Negated                                                                        | tSN                | 40   | -     | ns   |
| 16                  | Clock High to AS, DS, R/W High Impedance                                                        | tCHSZ              |      | 59    | ns   |
| 17                  | AS, DS, CS Negated to R/W High                                                                  | tSNRN              | 15   | -     | ns   |
| 18                  | Clock High to R/W High                                                                          | tCHRH              | 0    | 29    | ns   |
| 20                  | Clock High to R/W Low                                                                           | tCHRL              | 0    | 29    | ns   |
| 21                  | R/W High to AS, CS Asserted                                                                     | <sup>t</sup> RAAA  | 15   |       | ns   |

# Table A–5. AC Timing

(V<sub>DD</sub> and V<sub>DDSYN</sub> = 5.0 Vdc  $\pm$  10%, V<sub>SS</sub> = 0 Vdc, T<sub>A</sub> = T<sub>L</sub> to T<sub>H</sub>)

A

| Num                 | Characteristic                                                           | Symbol             | Min | Max | Unit             |
|---------------------|--------------------------------------------------------------------------|--------------------|-----|-----|------------------|
| 22                  | R/W Low to DS, CS Asserted (Write)                                       | <sup>t</sup> RASA  | 70  |     | ns               |
| 23                  | Clock High to Data Out Valid                                             | tCHDO              |     | 29  | ns               |
| 24                  | Data Out Valid to Negating Edge of AS, CS (Fast Write Cycle)             | <sup>t</sup> DVASN | 15  | -   | ns               |
| 25                  | DS, CS Negated to Data Out Invalid (Data Out Hold)                       | tSNDOI             | 15  |     | ns               |
| 26                  | Data Out Valid to DS, CS Asserted (Write)                                | t <sub>DVSA</sub>  | 15  |     | ns               |
| 27                  | Data In Valid to Clock Low (Data Setup)                                  | <sup>t</sup> DICL  | 5   |     | ns               |
| 27A                 | Late BERR, HALT Asserted to Clock Low (Setup Time)                       | tBELCL             | 20  |     | ns               |
| 28                  | AS, DS Negated to DSACK[1:0], BERR, HALT, AVEC Negated                   | tSNDN              | 0   | 80  | ns               |
| 29 <sup>6</sup>     | DS, CS Negated to Data In Invalid (Data In Hold)                         | tSNDI              | 0   |     | ns               |
| 29A <sup>6, 7</sup> | DS, CS Negated to Data In High Impedance                                 | tshdi              |     | 55  | ns               |
| 30 <sup>6</sup>     | CLKOUT Low to Data In Invalid (Fast Cycle Hold)                          | tCLDI              | 15  |     | ns               |
| 30A <sup>6</sup>    | CLKOUT Low to Data In High Impedance                                     | tCLDH              |     | 90  | ns               |
| 318                 | DSACK[1:0] Asserted to Data In Valid                                     | tDADI              |     | 50  | ns               |
| 33                  | Clock Low to BG Asserted/Negated                                         | <sup>t</sup> CLBAN |     | 29  | ns               |
| 35 <sup>9</sup>     | BR Asserted to BG Asserted                                               | t <b>BRAGA</b>     | 1   |     | t <sub>cyc</sub> |
| 37                  | BGACK Asserted to BG Negated                                             | <sup>t</sup> GAGN  | 1   | 2   | t <sub>cyc</sub> |
| 39                  | BG Width Negated                                                         | t <sub>GH</sub>    | 2   |     | t <sub>cyc</sub> |
| 39 <b>A</b>         | BG Width Asserted                                                        | tGA                | 1   |     | t <sub>cyc</sub> |
| 46                  | R/W Width Asserted (Write or Read)                                       | tRWA               | 150 |     | ns               |
| 46 <b>A</b>         | R/W Width Asserted (Fast Write or Read Cycle)                            | <sup>t</sup> RWAS  | 90  |     | ns               |
| 47A                 | Asynchronous Input Setup Time<br>BR, BGACK, DSACK[1:0], BERR, AVEC, HALT | <sup>t</sup> AIST  | 5   |     | ns               |
| 47B                 | Asynchronous Input Hold Time                                             | t <sub>AIHT</sub>  | 15  |     | ns               |
| 48 <sup>10</sup>    | DSACK[1:0] Asserted to BERR, HALT Asserted                               | t <sub>DABA</sub>  | —   | 30  | ns               |
| 53                  | Data Out Hold from Clock High                                            | tDOCH              | 0   | -   | ns               |
| 54                  | Clock High to Data Out High Impedance                                    | tснрн              |     | 28  | ns               |
| 55                  | R/W Asserted to Data Bus Impedance Change                                | tRADC              | 40  | -   | ns               |
| 70                  | Clock Low to Data Bus Driven (Show Cycle)                                | tSCLDD             | 0   | 29  | ns               |
| 71                  | Data Setup Time to Clock Low (Show Cycle)                                | tSCLDS             | 15  |     | ns               |
| 72                  | Data Hold from Clock Low (Show Cycle)                                    | tSCLDH             | 10  |     | ns               |
| 73                  | BKPT Input Setup Time                                                    | tBKST              | 15  |     | ns               |
| 74                  | BKPT Input Hold Time                                                     | <sup>t</sup> вкнт  | 10  |     | ns               |

## Table A–5. AC Timing (Continued) ( $V_{DD}$ and $V_{DDSYN} = 5.0 \text{ Vdc} \pm 10\%$ , $V_{SS} = 0 \text{ Vdc}$ , $T_A = T_L$ to $T_H$ )

## Table A-5. AC Timing (Continued)

| Num | Characteristic                                    | Symbol             | Min | Max | Unit             |
|-----|---------------------------------------------------|--------------------|-----|-----|------------------|
| 75  | Mode Select Setup Time                            | t <sub>MSS</sub>   | 20  |     | t <sub>cyc</sub> |
| 76  | Mode Select Hold Time                             | tMSH               | 0   | -   | ns               |
| 77  | RESET Assertion Time <sup>11</sup>                | <sup>t</sup> RSTA  | 4   | -   | t <sub>cyc</sub> |
| 78  | RESET Rise Time <sup>12</sup>                     | <sup>t</sup> RSTR  | —   | 10  | t <sub>cyc</sub> |
| 100 | CLKOUT High to Phase 1 Asserted <sup>13</sup>     | tCHP1A             | 3   | 40  | ns               |
| 101 | CLKOUT High to Phase 2 Asserted <sup>13</sup>     | tCHP2A             | 3   | 40  | ns               |
| 102 | Phase 1 Valid to AS or DS Asserted <sup>13</sup>  | tp1VSA             | 10  |     | ns               |
| 103 | Phase 2 Valid to AS or DS Negated <sup>13</sup>   | tP2VSN             | 10  |     | ns               |
| 104 | AS or DS Valid to Phase 1 Negated <sup>13</sup>   | tSAP1N             | 10  |     | ns               |
| 105 | AS or DS Negated to Phase 2 Negated <sup>13</sup> | t <sub>SNP2N</sub> | 10  | _   | ns               |

(V<sub>DD</sub> and V<sub>DDSYN</sub> = 5.0 Vdc  $\pm$  10%, V<sub>SS</sub> = 0 Vdc, T<sub>A</sub> = T<sub>L</sub> to T<sub>H</sub>)

NOTES:

1. All AC timing is shown with respect to 20% V<sub>DD</sub> and 70% V<sub>DD</sub> levels unless otherwise noted.

- 2. Minimum system clock frequency is four times the crystal frequency, subject to specified limits.
- Minimum external clock high and low times are based on a 50% duty cycle. The minimum allowable t<sub>Xcyc</sub> period will be reduced when the duty cycle of the external clock signal varies. The relationship between external clock input duty cycle and minimum t<sub>Xcyc</sub> is expressed:

Minimum t<sub>Xcvc</sub> period = minimum t<sub>XCHL</sub> / (50% - external clock input duty cycle tolerance).

To achieve maximum operating frequency (f<sub>sys</sub>) while using an external clock input, adjust clock input duty cycle to obtain a 50% duty cycle on CLKOUT.

- 4. Specification 9A is the worst-case skew between  $\overline{AS}$  and  $\overline{DS}$  or  $\overline{CS}$ . The amount of skew depends on the relative loading of these signals. When loads are kept within specified limits, skew will not cause  $\overline{AS}$  and  $\overline{DS}$  to fall outside the limits shown in specification 9.
- 5. If multiple chip selects are used, CS width negated (specification 15) applies to the time from the negation of a heavily loaded chip select to the assertion of a lightly loaded chip select. The CS width negated specification between multiple chip selects does not apply to chip selects being used for synchronous ECLK cycles.
- 6. Hold times are specified with respect to DS or CS on asynchronous reads and with respect to CLKOUT on fast cycle reads. The user is free to use either hold time.
- 7. Maximum value is equal to  $(t_{cyc}/2) + 25$  ns.
- If the asynchronous setup time (<u>specification</u> 47A) requirements are satisfied, the DSACK[1:0] low to data setup time (specification 31) and DSACK[1:0] low to BERR low setup time (specification 48) can be ignored. The data must only satisfy the data-in to clock low setup time (specification 27) for the following clock cycle. BERR must satisfy only the late BERR low to clock low setup time (specification 27A) for the following clock cycle.
- 9. To ensure coherency during every operand transfer, BG is not asserted in response to BR until after all cycles of the current operand transfer are complete.
- 10. In the absence of DSACK[1:0], BERR is an asynchronous input using the asynchronous setup time (specification 47A).
- 11. After external RESET negation is detected, a short transition period (approximately 2 t<sub>cyc</sub>) elapses, then the SIM drives RESET low for 512 t<sub>cyc</sub>
- 12. External logic must pull RESET high during this period in order for normal MCU operation to begin.
- 13. Eight pipeline states are multiplexed into IPIPE[1:0]. The multiplexed signals have two phases.

 Address access time = (2.5 + WS) t<sub>Cyc</sub> - t<sub>CLAV</sub> - t<sub>DICL</sub> Chip select access time = (2 + WS) t<sub>Cyc</sub> - t<sub>CLSA</sub> - t<sub>DICL</sub> Where: WS = number of wait states. When fast termination is used (2 clock bus) WS = -1.

MC68HC16Z1 APPENDIX A USER'S MANUAL ELECTRICAL CHARACTERISTICS MOTOROLA A–9

### Table A-6. Background Debugging Mode Timing

| Num        | Characteristic                         | Symbol             | Min | Max | Unit             |
|------------|----------------------------------------|--------------------|-----|-----|------------------|
| B0         | DSI Input Setup Time                   | tDSISU             | 15  | _   | ns               |
| <b>B</b> 1 | DSI Input Hold Time                    | tDSIH              | 10  |     | ns               |
| B2         | DSCLK Setup Time                       | tDSCSU             | 15  | _   | ns               |
| B3         | DSCLK Hold Time                        | tDSCH              | 10  |     | ns               |
| B4         | DSO Delay Time                         | tDSOD              |     | 25  | ns               |
| B5         | DSCLK Cycle Time                       | tDSCCYC            | 2   | _   | t <sub>cyc</sub> |
| B6         | CLKOUT High to FREEZE Asserted/Negated | <sup>t</sup> FRZAN | ·   | 50  | ns               |
| B7         | CLKOUT High to IPIPE1 High Impedance   | tIFZ               | ·   | 50  | ns               |
| B8         | CLKOUT High to IPIPE1 Valid            | tiF                |     | 50  | ns               |
| B9         | DSCLK Low Time                         | tDSCLO             | 1   | _   | t <sub>cyc</sub> |

 $(V_{DD} = 5.0 \text{ Vdc} \pm 10\%, V_{SS} = 0 \text{ Vdc}, T_A = T_L \text{ to } T_H)$ 

NOTES:

1. All AC timing is shown with respect to 20% V<sub>DD</sub> and 70% V<sub>DD</sub> levels unless otherwise noted.

## Table A-7. ECLK Bus Timing

(V<sub>DD</sub> = 5.0 Vdc  $\pm$  10%, V<sub>SS</sub> = 0 Vdc, T<sub>A</sub> = T<sub>L</sub> to T<sub>H</sub>)

| Num              | Characteristic                    | Symbol            | Min | Max | Unit             |
|------------------|-----------------------------------|-------------------|-----|-----|------------------|
| E1 <sup>2</sup>  | ECLK Low to Address Valid         | <sup>t</sup> EAD  |     | 60  | ns               |
| E2               | ECLK Low to Address Hold          | <sup>t</sup> EAH  | 10  |     | ns               |
| E3               | ECLK Low to CS Valid (CS delay)   | tECSD             | -   | 150 | ns               |
| E4               | ECLK Low to CS Hold               | tECSH             | 15  | —   | ns               |
| E5               | CS Negated Width                  | tECSN             | 30  |     | ns               |
| E6               | Read Data Setup Time              | tEDSR             | 30  | -   | ns               |
| E7               | Read Data Hold Time               | <sup>t</sup> EDHR | 15  | —   | ns               |
| E8               | ECLK Low to Data High Impedance   | tEDHZ             | —   | 60  | ns               |
| E9               | CS Negated to Data Hold (Read)    | tECDH             | 0   | —   | ns               |
| E10              | CS Negated to Data High Impedance | tECDZ             | —   | 1   | t <sub>cyc</sub> |
| E11              | ECLK Low to Data Valid (Write)    | tEDDW             |     | 2   | t <sub>cyc</sub> |
| E12              | ECLK Low to Data Hold (Write)     | tedhw             | 5   | —   | ns               |
| E13              | CS Negated to Data Hold (Write)   | tECHW             | 0   |     | ns               |
| E14 <sup>3</sup> | Address Access Time (Read)        | <sup>t</sup> EACC | 386 |     | ns               |
| E15 <sup>4</sup> | Chip Select Access Time (Read)    | tEACS             | 296 |     | ns               |
| E16              | Address Setup Time                | t <sub>EAS</sub>  |     | 1/2 | t <sub>cyc</sub> |

NOTES:

- 1. All AC timing is shown with respect to 20%  $V_{\mbox{DD}}$  and 70%  $V_{\mbox{DD}}$  levels unless otherwise noted.
- 2. When previous bus cycle is not an ECLK cycle, the address may be valid before ECLK goes low.
- 3. Address access time =  $t_{Ecyc} t_{EAD} t_{EDSR}$
- 4. Chip select access time = t<sub>Ecyc</sub> t<sub>ECSD</sub> t<sub>EDSR</sub>

## Table A-8. QSPI Timing

| $(V_{DD} = 5.0 \text{ Vdc} \pm 10\%, V_{SS} = 0 \text{ Vdc}, T_A = T_L \text{ to } T_{H_1} 200 \text{ pF} \text{ load on all C}$ | QSPI pins) |
|----------------------------------------------------------------------------------------------------------------------------------|------------|
|----------------------------------------------------------------------------------------------------------------------------------|------------|

| Num | Function                                                                 | Symbol                             | Min                      | Max                  | Unit                                             |
|-----|--------------------------------------------------------------------------|------------------------------------|--------------------------|----------------------|--------------------------------------------------|
|     | Operating Frequency<br>Master<br>Slave                                   | fop                                | DC<br>DC                 | 1/4<br>1/4           | System Clock Frequency<br>System Clock Frequency |
| 1   | Cycle Time<br>Master<br>Slave                                            | t <sub>qcyc</sub>                  | 4 4                      | 510<br>—             | tcyc<br>tcyc                                     |
| 2   | Enable Lead Time<br>Master<br>Slave                                      | tlead                              | 2<br>2                   | 128                  | tcyc<br>tcyc                                     |
| 3   | Enable Lag Time<br>Master<br>Slave                                       | tlag                               | 2                        | 1/2                  | SCK<br>tcyc                                      |
| 4   | Clock (SCK) High or Low Time<br>Master<br>Slave <sup>2</sup>             | t <sub>sw</sub>                    | 2 tcyc –60<br>2 tcyc – n | 255 t <sub>cyc</sub> | ns<br>ns                                         |
| 5   | Sequential Transfer Delay<br>Master<br>Slave (Does Not Require Deselect) | t <sub>td</sub>                    | 17<br>13                 | 8192<br>—            | tcyc<br>tcyc                                     |
| 6   | Data Setup Time (Inputs)<br>Master<br>Slave                              | t <sub>su</sub>                    | 30<br>20                 |                      | ns<br>ns                                         |
| 7   | Data Hold Time (Inputs)<br>Master<br>Slave                               | t <sub>hi</sub>                    | 0<br>20                  | _                    | ns<br>ns                                         |
| 8   | Slave Access Time                                                        | ta                                 |                          | 1                    | tcyc                                             |
| 9   | Slave MISO Disable Time                                                  | <sup>t</sup> dis                   |                          | 2                    | tcyc                                             |
| 10  | Data Valid (after SCK Edge)<br>Master<br>Slave                           | t <sub>v</sub>                     | _                        | 50<br>50             | ns<br>ns                                         |
| 11  | Data Hold Time (Outputs)<br>Master<br>Slave                              | tho                                | 0                        |                      | ns<br>ns                                         |
| 12  | Rise Time<br>Input<br>Output                                             | t <sub>ri</sub><br>t <sub>ro</sub> | _                        | 2<br>30              | μs<br>ns                                         |
| 13  | Fall Time<br>Input<br>Output                                             | t <sub>fi</sub><br>t <sub>fo</sub> | =                        | 2<br>30              | μs<br>ns                                         |

NOTES:

1. All AC timing is shown with respect to 20%  $V_{\text{DD}}$  and 70%  $V_{\text{DD}}$  levels unless otherwise noted.

2. In formula, n = External SCK rise + External SCK fall time

| Num | Parameter                                                                                                          | Symbol                              | Min   | Max | Unit |
|-----|--------------------------------------------------------------------------------------------------------------------|-------------------------------------|-------|-----|------|
| 1   | Analog Supply                                                                                                      | V <sub>DDA</sub>                    | - 0.3 | 6.5 | V    |
| 2   | Internal Digital Supply                                                                                            | V <sub>DDI</sub>                    | - 0.3 | 6.5 | v    |
| 3   | Reference Supply                                                                                                   | V <sub>RH</sub> , V <sub>RL</sub>   | - 0.3 | 6.5 | v    |
| 4   | V <sub>SS</sub> Differential Voltage                                                                               | V <sub>SSI –</sub> V <sub>SSA</sub> | - 0.1 | 0.1 | v    |
| 5   | V <sub>DD</sub> Differential Voltage                                                                               | V <sub>DDI –</sub> V <sub>DDA</sub> | - 6.5 | 6.5 | V    |
| 6   | V <sub>REF</sub> Differential Voltage                                                                              | V <sub>RH –</sub> V <sub>RL</sub>   | - 6.5 | 6.5 | v    |
| 7   | V <sub>REF</sub> to V <sub>DDA</sub> Differential Voltage                                                          | V <sub>RH –</sub> V <sub>DDA</sub>  | - 6.5 | 6.5 | v    |
| 8   | Disruptive Input Current <sup>1</sup> , 2, 4, 5<br>V <sub>SSA</sub> −0.3 ≤ V <sub>INA</sub> ≤ V <sub>DDA</sub> + 2 | INA                                 | - 15  | 15  | μA   |
| 9   | Maximum Input Current <sup>3, 4</sup><br>V <sub>SSA</sub> -1 ≤ V <sub>INA</sub> ≤ V <sub>DDA</sub> + 3.5           | I <sub>MA</sub>                     | - 500 | 500 | μΑ   |

### Table A-9. ADC Maximum Ratings

NOTES:

- 1. Below disruptive current conditions, the channel being stressed will have conversion values of \$3FF for analog inputs greater than  $V_{RH}$  and \$000 for values less than  $V_{RL}$ . This assumes that  $V_{RH} \le V_{DDA}$  and  $V_{RL} \ge V_{SSA}$  due to the presence of the sample amplifier. Other channels are not affected by non-disruptive conditions.
- 2. Input signals with large slew rates or high frequency noise components cannot be converted accurately. These signals also interfere with conversion of other channels.
- 3. Exceeding limit may cause conversion error on stressed channels and on unstressed channels. Transitions within the limit do not affect device reliability or cause permanent damage.
- 4. This parameter is periodically sampled rather than 100% tested.
- 5. Applies to single pin only.



## Table A-10. ADC DC Electrical Characteristics (Operating)

| Num | Parameter                                          | Symbol                              | Min                     | Max                     | Unit |
|-----|----------------------------------------------------|-------------------------------------|-------------------------|-------------------------|------|
| 1   | Analog Supply <sup>1</sup>                         | V <sub>DDA</sub>                    | 4.5                     | 5.5                     | v    |
| 2   | Internal Digital Supply <sup>1</sup>               | V <sub>DDI</sub>                    | 4.5                     | 5.5                     | v    |
| 3   | V <sub>SS</sub> Differential Voltage               | V <sub>SSI –</sub> V <sub>SSA</sub> | - 1.0                   | 1.0                     | mV   |
| 4   | V <sub>DD</sub> Differential Voltage               | V <sub>DDI –</sub> V <sub>DDA</sub> | - 1.0                   | 1.0                     | v    |
| 5   | Reference Voltage Low <sup>2, 5</sup>              | V <sub>RL</sub>                     | V <sub>SSA</sub>        | V <sub>DDA</sub> / 2    | v    |
| 6   | Reference Voltage High <sup>2, 5</sup>             | V <sub>RH</sub>                     | V <sub>DDA</sub> /2     | V <sub>DDA</sub>        | v    |
| 7   | V <sub>REF</sub> Differential Voltage <sup>5</sup> | V <sub>RH</sub> _V <sub>RL</sub>    | 4.5                     | 5.5                     | v    |
| 8   | Input Voltage <sup>2</sup>                         | VINDC                               | V <sub>SSA</sub>        | V <sub>DDA</sub>        | v    |
| 9   | Input High, Port ADA                               | V <sub>IH</sub>                     | 0.7 (V <sub>DDA</sub> ) | V <sub>DDA</sub> + 0.3  | V    |
| 10  | Input Low, Port ADA                                | VIL                                 | V <sub>SSA</sub> - 0.3  | 0.2 (V <sub>DDA</sub> ) | v    |
| 15  | Analog Supply Current <sup>3</sup>                 | I <sub>DDA</sub>                    | —                       | 1.0                     | mA   |
| 16  | Analog Supply Current, LPSTOP                      | S <sub>DDA</sub>                    |                         | TBD                     | μA   |
| 17  | Reference Supply Current                           | I <sub>REF</sub>                    |                         | 250                     | μA   |
| 18  | Input Current, Off Channel <sup>4</sup>            | lOFF                                | -                       | 250                     | nA   |
| 19  | Total Input Capacitance, Not Sampling              | C <sub>INN</sub>                    |                         | 10                      | pF   |
| 20  | Total Input Capacitance, Sampling                  | C <sub>INS</sub>                    | —                       | 15                      | рF   |

(V<sub>SS</sub> = 0 Vdc, ADCLK = 2.1 MHz, T<sub>A</sub> within operating temperature range)

NOTES:

1. Refers to operation over full temperature and frequency range.

2. To obtain full-scale, full-range results, V<sub>SSA</sub> ≤ V<sub>RL</sub> ≤ V<sub>INDC</sub> ≤ V<sub>RH</sub> ≤ V<sub>DDA</sub>.

3. Current measured at maximum system clock frequency with ADC active.

4. Maximum leakage occurs at maximum operating temperature. Current decreases by approximately one-half for each 10° C decrease from maximum temperature.

5. Accuracy tested and guaranteed at  $V_{BH} - V_{BL} \le 5.0 \text{ V} \pm 10\%$ .

A

## Table A–11. ADC AC Characteristics (Operating)

| Num | Parameter                                              | Symbol            | Min  | Max   | Unit |
|-----|--------------------------------------------------------|-------------------|------|-------|------|
| 1   | IMB Clock Frequency                                    | FICLK             | 2.0  | 16.78 | MHz  |
| 2   | ADC Clock Frequency                                    | FADCLK            | 0.5  | 2.1   | MHz  |
| 3   | 8-bit Conversion Time (16 ADC Clocks) <sup>1</sup>     | TCONV             | 7.62 |       | μs   |
| 4   | 10-bit Conversion Time (18 ADC<br>Clocks) <sup>1</sup> | T <sub>CONV</sub> | 8.58 |       | μs   |
| 5   | Stop Recovery Time                                     | T <sub>SR</sub>   |      | 10    | μs   |

(V<sub>DD</sub> and V<sub>DDA</sub> = 5.0 Vdc  $\pm$  10%, V<sub>SS</sub> = 0 Vdc, T<sub>A</sub> within operating temperature range)

NOTES:

1. Assumes 2.1 MHz ADC clock and selection of minimum sample time (2 ADC clocks).

### Table A–12. ADC Conversion Characteristics (Operating)

 $(V_{DD} \text{ and } V_{DDA} = 5.0 \text{ Vdc} \pm 10\%, V_{SS} = 0 \text{ Vdc}, T_A = T_L \text{ to } T_H, \text{ ADCLK} = 2.1 \text{ MHz})$ 

| Num | Parameter                                     | Symbol         | Min  | Тур | Max        | Unit   |
|-----|-----------------------------------------------|----------------|------|-----|------------|--------|
| 1   | 8-bit Resolution <sup>1</sup>                 | 1 Count        |      | 20  |            | m V    |
| 2   | 8-bit Differential Nonlinearity <sup>2</sup>  | DNL            | 5    | _   | .5         | Counts |
| 3   | 8-bit Integral Nonlinearity <sup>2</sup>      | INL            | -1   |     | 1          | Counts |
| 4   | 8-bit Absolute Error <sup>2,3</sup>           | AE             | -1   |     | 1          | Counts |
| 5   | 10-bit Resolution <sup>1</sup>                | 1 Count        |      | 5   |            | m V    |
| 6   | 10-bit Differential Nonlinearity <sup>2</sup> | DNL            | -1   |     | 1          | Counts |
| 7   | 10-bit Integral Nonlinearity <sup>2</sup>     | INL            | -2   |     | 2          | Counts |
| 8   | 10-bit Absolute Error <sup>2,4</sup>          | AE             | -2.5 | _   | 2.5        | Counts |
| 9   | Source Impedance at Input <sup>5</sup>        | R <sub>S</sub> |      | 20  | See Note 5 | kΩ     |

NOTES:

1.  $V_{RH} - V_{RL} \ge 5.12$  V;  $V_{DDA} - V_{SSA} = 5.12$  V

- 2. At V<sub>RFF</sub> = 5.12 V, one 10-bit count = 5 mV and one 8-bit count = 20 mV.
- 3. 8-bit absolute error of 1 count (20 mV) includes 1/2 count (10 mV) inherent guantization error and 1/2 count (10 mV) circuit (differential, integral, and offset) error.
- 4. 10-bit absolute error of 2.5 counts (12.5 mV) includes 1/2 count (2.5 mV) inherent quantization error and 2 counts (10 mV) circuit (differential, integral, and offset) error.
- Maximum source impedance is application-dependent. Error resulting from pin leakage depends on junction 5. leakage into the pin and on leakage due to charge sharing with internal capacitance. In the following expressions, expected error in result value due to leakage is expressed in voltage (Verrx).

Error from junction leakage is a function of external source impedance and input leakage current:

where IOFF is a function of operating temperature. (See Table A-10, note 4).

Charge-sharing leakage is a function of ADC clock speed, number of channels scanned, and source impedance:

- For 10-bit conversion, Verr10 = .25 pF × VDDA × RS × ADCLK + (9 × number of channels)
  - For 8-bit conversion, Verr8 = .25 pF × VDDA × RS × ADCLK + (8 × number of channels)

Timing Diagrams



NOTE: Timing shown with respect to 20% and 70% V<sub>DD</sub>.

## Figure A-1. CLKOUT Output Timing Diagram



NOTE: Timing shown with respect to 20% and 70%  $V_{DD}.\,$  Pulse width shown with respect to 50%  $V_{DD}.\,$ 





NOTE: Timing shown with respect to 20% and 70% V<sub>DD</sub>.

Figure A–3. ECLK Output Timing Diagram APPENDIX A ELECTRICAL CHARACTERISTICS

MC68HC16Z1 USER'S MANUAL

MOTOROLA A-16

### Key to Figures A-1, A-2, A-3 (Abstracted from Table A-5; see table for complete notes)

| Num                | Characteristic                                 | Symbol           | Min  | Max | Units |
|--------------------|------------------------------------------------|------------------|------|-----|-------|
| 1                  | Clock Period                                   | t <sub>cyc</sub> | 59.6 | -   | ns    |
| 1A                 | ECLK Period                                    | tEcyc            | 476  | —   | ns    |
| 1B <sup>3</sup>    | External Clock Input Period                    | tXcyc            | 64   | -   | ns    |
| 2, 3               | Clock Pulse Width                              | tcw              | 24   | -   | ns    |
| 2A, 3A             | ECLK Pulse Width                               | tECW             | 236  |     | ns    |
| 2B,3B <sup>3</sup> | External Clock Input High/Low Time             | txchl            | 32   | -   | ns    |
| 4, 5               | CLOCKOUT Rise and Fall Time                    | tCrf             |      | 5   | ns    |
| 4A, 5A             | Rise and Fall Time (All outputs except CLKOUT) | t <sub>rf</sub>  |      | 8   | ns    |
| 4B, 5B             | External Clock Rise and Fall Time              | txCrf            |      | 5   | ns    |

NOTES:

1. All AC timing is shown with respect to 20% V<sub>DD</sub> and 70% V<sub>DD</sub> levels unless otherwise noted.

3. Minimum external clock high and low times are based on a 50% duty cycle. The minimum allowable t<sub>XCYC</sub> period will be reduced when the duty cycle of the external clock signal varies. The relationship between external clock input duty cycle and minimum t<sub>XCYC</sub> is expressed:

Minimum t<sub>XCYC</sub> period = minimum t<sub>XCHL</sub> / (50% - external clock input duty cycle tolerance).

To achieve maximum operating frequency ( $f_{sys}$ ) while using an external clock input, adjust clock input duty cycle to obtain a 50% duty cycle on CLKOUT.



Figure A-4. Read Cycle Timing Diagram

APPENDIX A ELECTRICAL CHARACTERISTICS MC68HC16Z1 USER'S MANUAL

Key to Figure A-4 (Abstracted from Table A-5; see table for complete notes)

| Num                | Characteristic                                                        | Symbol             | Min | Max | Units |
|--------------------|-----------------------------------------------------------------------|--------------------|-----|-----|-------|
| 6                  | Clock High to ADDR, FC, SIZE Valid                                    | t <sub>CHAV</sub>  | 0   | 29  | ns    |
| 8                  | Clock High to ADDR, FC, SIZE Invalid                                  | tCHAZn             | 0   | —   | ns    |
| 9                  | Clock Low to AS, DS, CS Asserted                                      | <sup>t</sup> CLSA  | 2   | 25  | ns    |
| 9A <sup>4</sup>    | AS to DS or CS Asserted (Read)                                        | <sup>t</sup> STSA  | -15 | 15  | ns    |
| 11                 | ADDR, FC, SIZE Valid to AS, CS (and DS Read) Asserted                 | t <sub>AVSA</sub>  | 15  | -   | ns    |
| 12                 | Clock Low to AS, DS, CS Negated                                       | <sup>t</sup> CLSN  | 2   | 29  | ns    |
| 13                 | AS, DS, CS Negated to ADDR, FC, SIZE Invalid (Address Hold)           | tSNAI              | 15  |     | ns    |
| 14                 | AS, CS (and DS Read) Width Asserted                                   | tswa               | 100 | -   | ns    |
| 155                | AS, DS, CS Width Negated                                              | tsn                | 40  | -   | ns    |
| 18                 | Clock High to R/W High                                                | <sup>t</sup> CHRH  | 0   | 29  | ns    |
| 20                 | Clock High to R/W Low                                                 | tCHRL              | 0   | 29  | ns    |
| 21                 | R/W High to AS, CS Asserted                                           | traaa              | -15 | -   | ns    |
| 27                 | Data In Valid to Clock Low (Data Setup)                               | tDICL              | 5   | —   | ns    |
| 27A                | Late BERR, HALT Asserted to Clock Low (Setup Time)                    | <sup>t</sup> BELCL | 20  | —   | ns    |
| 28                 | AS, DS Negated to DSACK[1:0], BERR, HALT, AVEC Negated                | tSNDN              | 0   | 80  | ns    |
| 29 <sup>6</sup>    | DS, CS Negated to Data In Invalid (Data In Hold)                      | tSNDI              | 0   |     | ns    |
| 29A <sup>6,7</sup> | DS, CS Negated to Data In High-Impedance                              | tshdi              |     | 55  | ns    |
| 318                | DSACK[1:0] Asserted to Data In Valid                                  | t <sub>DADI</sub>  | -   | 50  | ns    |
| 46                 | R/W Width Asserted (Write or Read)                                    | tRWA               | 150 |     | ns    |
| 47A                | Asynchronous Input Setup Time<br>BR, BG, DSACK[1:0], BERR, AVEC, HALT | tAIST              | 5   |     | ns    |
| 47B                | Asynchronous Input Hold Time                                          | <sup>t</sup> AIHT  | 15  | —   | ns    |
| 48 <sup>10</sup>   | DSACK[1:0] Asserted to BERR, HALT Asserted                            | <sup>t</sup> DABA  | —   | 30  | ns    |
| 73                 | BKPT Input Setup Time                                                 | tBKST              | 15  |     | ns    |
| 74                 | BKPT Input Hold Time                                                  | tвкнт              | 10  | -   | ns    |
| 100                | CLKOUT High to Phase 1 Asserted <sup>12</sup>                         | tCHP1A             | 3   | 40  | ns    |
| 101                | CLKOUT High to Phase 2 Asserted <sup>12</sup>                         | tCHP2A             | 3   | 40  | ns    |
| 102                | Phase 1 Valid to AS or DS Asserted <sup>13</sup>                      | tP1VSA             | 10  | _   | ns    |
| 103                | Phase 2 Valid to AS or DS Negated <sup>13</sup>                       | tP2VSN             | 10  | -   | ns    |
| 104                | AS or DS Valid to Phase 1 Negated <sup>13</sup>                       | tSAP1N             | 10  |     | ns    |
| 105                | AS or DS Negated to Phase 2 Negated <sup>13</sup>                     | tSNP2N             | 10  | -   | ns    |

NOTES:

1. All AC timing is shown with respect to 20% V<sub>DD</sub> and 70% V<sub>DD</sub> levels unless otherwise noted.

- 4. Specification 9A is the worst-case skew between AS and DS or CS. The amount of skew depends on the relative loading of these signals. When loads are kept within specified limits, skew will not cause AS and DS to fall outside the limits shown in specification 9.
- 5. If multiple chip selects are used, CS width negated (specification 15) applies to the time from the negation of a heavily loaded chip select to the assertion of a lightly loaded chip select. The CS width negated specification between multiple chip selects does not apply to chip selects synchronized to ECLK.
- Hold times are specified with respect to DS or CS on asynchronous reads and with respect to CLKOUT on fast reads. The user is free to use either hold time.
- 7. Maximum value is equal to  $(t_{cyc} / 2) + 25$  ns.
- 8. If the asynchronous setup time (specification 47A) requirements are satisfied, the DSACK[1:0] low to data setup time (specification 31) and DSACK[1:0] low to BERR low setup time (specification 48) can be ignored. The data must only satisfy the data-in to clock low setup time (specification 27) for the following clock cycle. BERR must satisfy only the late BERR low to clock low setup time (specification 27A) for the following clock cycle.
- 10. In the absence of DSACK[1:0], BERR is an asynchronous input use specification 47A.
- 13. Eight pipeline states are multiplexed into IPIPE[1:0]. The multiplexed signals have two phases.

| MC68HC16Z1    | APPENDIX A                 |
|---------------|----------------------------|
| USER'S MANUAL | ELECTRICAL CHARACTERISTICS |

MOTOROLA

A-19



Figure A-5. Write Cycle Timing Diagram

APPENDIX A ELECTRICAL CHARACTERISTICS MC68HC16Z1 USER'S MANUAL

A

| Num              | Characteristic                                                                                                      | Symbol             | Min | Max | Units |
|------------------|---------------------------------------------------------------------------------------------------------------------|--------------------|-----|-----|-------|
| 6                | Clock High to ADDR, FC, SIZE Valid                                                                                  | tCHAV              | 0   | 29  | ns    |
| 8                | Clock High to ADDR, FC, SIZE Invalid                                                                                | <sup>t</sup> CHAZn | 0   |     | ns    |
| 9                | Clock Low to AS, DS, CS Asserted                                                                                    | t <sub>CLSA</sub>  | 2   | 25  | ns    |
| 11               | ADDR, FC, SIZE, Valid to $\overline{AS}$ , $\overline{CS}$ (and $\overline{DS}$ Read) Asserted                      | <sup>t</sup> avsa  | 15  | —   | ns    |
| 12               | Clock Low to AS, DS, CS Negated                                                                                     | t <sub>CLSN</sub>  | 2   | 29  | ns    |
| 13               | $\overline{\text{AS}}, \overline{\text{DS}}, \overline{\text{CS}}$ Negated to ADDR, FC, SIZE Invalid (Address Hold) | tSNAI              | 15  | -   | ns    |
| 14               | AS, CS (and DS Read) Width Asserted                                                                                 | tswa               | 100 |     | ns    |
| 14 <b>A</b>      | DS, CS Width Asserted Write                                                                                         | tswaw              | 45  | —   | ns    |
| 155              | AS, DS, CS Width Negated                                                                                            | t <sub>SN</sub>    | 40  | -   | ns    |
| 17               | AS, DS, CS Negated to R/W High                                                                                      | t <sub>SNRN</sub>  | 15  | -   | ns    |
| 20               | Clock High to R/W Low                                                                                               | <sup>t</sup> CHRL  | 0   | 29  | ns    |
| 22               | $R\overline{W}$ Low to $\overline{DS}$ , $\overline{CS}$ Asserted (Write)                                           | trasa              | 70  | —   | ns    |
| 23               | Clock High to Data Out Valid                                                                                        | tCHDO              |     | 29  | ns    |
| 25               | DS, CS Negated to Data Out Invalid (Data Out Hold)                                                                  | tSNDOI             | 15  | _   | ns    |
| 26               | Data Out Valid to DS, CS Asserted (Write)                                                                           | t <sub>DVSA</sub>  | 15  |     | ns    |
| 27A              | Late BERR, HALT Asserted to Clock Low (Setup Time)                                                                  | <sup>t</sup> BELCL | 20  | — . | ns    |
| 28               | AS, DS Negated to DSACK[1:0], BERR, HALT, AVEC<br>Negated                                                           | tSNDN              | 0   | 80  | ns    |
| 46               | R/W Width Asserted (Write or Read)                                                                                  | tRWA               | 150 | _   | ns    |
| 47 <b>A</b>      | Asynchronous Input Setup Time<br>BR, BG, DSACK[1:0], BERR, AVEC, HALT                                               | tAIST              | 5   | _   | ns    |
| 48 <sup>10</sup> | DSACK[1:0] Asserted to BERR, HALT Asserted                                                                          | t <sub>DABA</sub>  |     | 30  | ns    |
| 53               | Data Out Hold from Clock High                                                                                       | tDOCH              | 0   | _   | ns    |
| 54               | Clock High to Data Out High-Impedance                                                                               | tCHDH              |     | 28  | ns    |
| 73               | BKPT Input Setup Time                                                                                               | <sup>t</sup> BKST  | 15  | —   | ns    |
| 74               | BKPT Input Hold Time                                                                                                | tвкнт              | 10  |     | ns    |
| 100              | CLKOUT High to Phase 1 Asserted <sup>12</sup>                                                                       | tCHP1A             | 3   | 40  | ns    |
| 101              | CLKOUT High to Phase 2 Asserted <sup>12</sup>                                                                       | tCHP2A             | 3   | 40  | ns    |
| 102              | Phase 1 Valid to $\overline{\text{AS}}$ or $\overline{\text{DS}}$ Asserted <sup>13</sup>                            | <sup>t</sup> P1VSA | 10  |     | ns    |
| 103              | Phase 2 Valid to AS or DS Negated <sup>13</sup>                                                                     | <sup>t</sup> P2VSN | 10  |     | ns    |
| 104              | AS or DS Valid to Phase 1 Negated <sup>13</sup>                                                                     | tSAP1N             | 10  | _   | ns    |
| 105              | AS or DS Negated to Phase 2 Negated <sup>13</sup>                                                                   | tSNP2N             | 10  |     | ns    |

### Key to Figure A–5 (Abstracted from Table A–5; see table for complete notes)

NOTES:

1. All AC timing is shown with respect to 20% V<sub>DD</sub> and 70% V<sub>DD</sub> levels unless otherwise noted.

5. If multiple chip selects are used, CS width negated (specification 15) applies to the time from the negation of a heavily loaded chip select to the assertion of a lightly loaded chip select. The CS width negated specification between multiple chip selects does not apply to chip selects sychronized to ECLK.

10. In the absence of DSACK[1:0], BERR is an asynchronous input - use specification 47A.

13. Eight pipeline states are multiplexed into IPIPE[1:0]. The multiplexed signals have two phases.

A



Figure A-6. Show Cycle Timing Diagram

| Num | Characteristic                                                            | Symbol             | Min | Max | Units |
|-----|---------------------------------------------------------------------------|--------------------|-----|-----|-------|
| 6   | Clock High to ADDR, FC, SIZE Valid                                        | tCHAV              | 0   | 29  | ns    |
| 8   | Clock High to ADDR, FC, SIZE Invalid                                      | t <sub>CHAZn</sub> | 0   | _   | ns    |
| 9   | Clock Low to AS, DS, CS Asserted                                          | t <sub>CLSA</sub>  | 2   | 25  | ns    |
| 12  | Clock Low to AS, DS, CS Negated                                           | t <sub>CLSN</sub>  | 2   | 29  | ns    |
| 155 | AS, DS, CS Width Negated                                                  | tsn                | 40  |     | ns    |
| 18  | Clock High to R/W High                                                    | tCHRH              | 0   | 29  | ns    |
| 20  | Clock High to R/W Low                                                     | tCHRL              | 0   | 29  | ns    |
| 70  | Clock Low to Data Bus Driven (Show)                                       | <sup>t</sup> SCLDD | 0   | 29  | ns    |
| 71  | Data Setup Time to Clock Low (Show)                                       | tSCLDS             | 15  |     | ns    |
| 72  | Data Hold from Clock Low (Show)                                           | <sup>t</sup> SCLDH | 10  |     | ns    |
| 73  | BKPT Input Setup Time                                                     | t <sub>BKST</sub>  | 15  | _   | ns    |
| 74  | BKPT Input Hold Time                                                      | <sup>t</sup> вкнт  | 10  |     | ns    |
| 100 | CLKOUT High to Phase 1 Asserted <sup>12</sup>                             | tCHP1A             | 3   | 40  | ns    |
| 101 | CLKOUT High to Phase 2 Asserted <sup>12</sup>                             | <sup>t</sup> CHP2A | 3   | 40  | ns    |
| 102 | Phase 1 Valid to AS or DS Asserted <sup>13</sup>                          | <sup>t</sup> P1VSA | 10  | -   | ns    |
| 103 | Phase 2 Valid to $\overline{AS}$ or $\overline{DS}$ Negated <sup>13</sup> | <sup>t</sup> P2VSN | 10  | _   | ns    |
| 104 | AS or DS Valid to Phase 1 Negated <sup>13</sup>                           | <sup>t</sup> SAP1N | 10  |     | ns    |
| 105 | AS or DS Negated to Phase 2 Negated <sup>13</sup>                         | t <sub>SNP2N</sub> | 10  |     | ns    |

# Key to Figure A–6

(Abstracted from Table A-5; see table for complete notes)

NOTES:

1. All AC timing is shown with respect to 20%  $V_{\text{DD}}$  and 70%  $V_{\text{DD}}$  levels unless otherwise noted.

5. If multiple chip selects are used, CS width negated (specification 15) applies to the time from the negation of a heavily loaded chip select to the assertion of a lightly loaded chip select. The CS width negated specification between multiple chip selects does not apply to chip selects synchronized to ECLK.

13. Eight pipeline states are multiplexed into IPIPE[1:0]. The multiplexed signals have two phases.





MOTOROLA A-24 APPENDIX A ELECTRICAL CHARACTERISTICS MC68HC16Z1 USER'S MANUAL

#### Key to Figure A-7

#### (Abstracted from Table A-5; see table for complete notes)

| Num | Characteristic                     | Symbol            | Min | Max | Units            |
|-----|------------------------------------|-------------------|-----|-----|------------------|
| 75  | Mode Select Setup Time             | tMSS              | 20  |     | t <sub>cyc</sub> |
| 76  | Mode Select Hold Time              | tMSH              | 0   | -   | ns               |
| 77  | RESET Assertion Time <sup>11</sup> | <sup>t</sup> RSTA | 4   | -   | <sup>t</sup> cyc |
| 78  | RESET Rise Time <sup>12</sup>      | tRSTR             |     | 10  | t <sub>cyc</sub> |

NOTES:

1. All AC timing is shown with respect to 20%  $V_{\text{DD}}$  and 70%  $V_{\text{DD}}$  levels unless otherwise noted.

11. After external RESET negation is detected, a short transition period (approximately 2 t<sub>cyc</sub>) elapses, then the SIM drives RESET low for 512 t<sub>cyc</sub>

12. External logic must pull RESET high during this period in order for normal MCU operation to begin.





| Key                    | to       | Figure    | A-8                     |    |
|------------------------|----------|-----------|-------------------------|----|
| (Abstracted from Table | <b>A</b> | 5; see ta | able for complete notes | 5) |

| Num             | Characteristic                                                        | Symbol             | Min | Max | Units            |
|-----------------|-----------------------------------------------------------------------|--------------------|-----|-----|------------------|
| 7               | Clock High to ADDR, Data, FC, SIZE High Impedance                     | tCHAZx             | 0   | 59  | ns               |
| 16              | Clock High to AS, DS, R/W High Impedance                              | tCHSZ              |     | 59  | ns               |
| 33              | Clock Low to BG Asserted/Negated                                      | <sup>t</sup> CLBAN |     | 29  | ns               |
| 35 <sup>9</sup> | BR Asserted to BG Asserted                                            | t <b>BRAGA</b>     | 1   |     | t <sub>cyc</sub> |
| 37              | BGACK Asserted to BG Negated                                          | <sup>t</sup> GAGN  | 1   | 2   | t <sub>cyc</sub> |
| 39A             | BG Width Asserted                                                     | tGA                | 1   | -   | t <sub>cyc</sub> |
| 47A             | Asynchronous Input Setup Time<br>BR, BG, DSACK[1:0], BERR, AVEC, HALT | <sup>t</sup> AIST  | 5   | _   | ns               |

NOTES:

1. All AC timing is shown with respect to 20%  $V_{\mbox{DD}}$  and 70%  $V_{\mbox{DD}}$  levels unless otherwise noted.

9. To ensure coherency during every operand transfer, BG will not be asserted in response to BR until after all cycles of the current operand transfer are complete.

13. Eight pipeline states are multiplexed into IPIPE[1:0]. The multiplexed signals have two phases.





| Key | to | Figure | A9 |
|-----|----|--------|----|
|-----|----|--------|----|

(Abstracted from Table A-5; see table for complete notes)

| Num                                                                        | Characteristic                   | Symbol | Min | Max | Units            |
|----------------------------------------------------------------------------|----------------------------------|--------|-----|-----|------------------|
| 33                                                                         | Clock Low to BG Asserted/Negated |        | -   | 29  | ns               |
| 35 <sup>9</sup>                                                            | BR Asserted to BG Asserted       |        | 1   | —   | t <sub>cyc</sub> |
| 37                                                                         | BGACK Asserted to BG Negated     | tGAGN  | 1   | 2   | t <sub>cyc</sub> |
| 47A Asynchronous Input Setup Time<br>BR, BG, DSACK[1:0]x, BERR, AVEC, HALT |                                  | tAIST  | 5   |     | ns               |

NOTES:

1. All AC timing is shown with respect to 20%  $V_{\text{DD}}$  and 70%  $V_{\text{DD}}$  levels unless otherwise noted.

9. To ensure coherency during every operand transfer, BG will not be asserted in response to BR until after all cycles of the current operand transfer are complete.

13. Eight pipeline states are multiplexed into IPIPE[1:0]. The multiplexed signals have two phases.

Α



Figure A-10. Fast Termination Read Cycle Timing Diagram

| Num                 | Characteristic                                                            | Symbol             | Min | Max | Units |
|---------------------|---------------------------------------------------------------------------|--------------------|-----|-----|-------|
| 6                   | Clock High to ADDR, FC, SIZE Valid                                        | tCHAV              | 0   | 29  | ns    |
| 8                   | Clock High to ADDR, FC, SIZE Invalid                                      | <sup>t</sup> CHAZn | 0   | _   | ns    |
| 9                   | Clock Low to AS, DS, CS Asserted                                          | <sup>t</sup> CLSA  | 2   | 25  | ns    |
| 12                  | Clock Low to AS, DS, CS Negated                                           | <sup>t</sup> CLSN  | 2   | 29  | ns    |
| 14B                 | AS, CS (and DS Read) Width Asserted (Fast Cycle)                          | tswDw              | 40  |     | ns    |
| 18                  | Clock High to R/W High                                                    | <sup>t</sup> CHRH  | 0   | 29  | ns    |
| 20                  | Clock High to R/W Low                                                     | <sup>t</sup> CHRL  | 0   | 29  | ns    |
| 27                  | Data In Valid to Clock Low (Data Setup)                                   | <sup>t</sup> DICL  | 5   | -   | ns    |
| 29 <sup>6</sup>     | DS, CS Negated to Data In Invalid (Data In Hold)                          | tSNDI              | 0   | -   | ns    |
| 29A <sup>6, 7</sup> | DS, CS Negated to Data In High Impedance                                  | tSHDI              |     | 55  | ns    |
| 306                 | CLKOUT Low to Data In Invalid (Fast Hold)                                 | tCLDI              | 15  | -   | ns    |
| 30A <sup>6</sup>    | CLKOUT Low to Data In High-Impedance                                      | <sup>t</sup> CLDH  | -   | 90  | ns    |
| 46A                 | R/W Width Asserted (Fast Write or Read)                                   | <sup>t</sup> RWAS  | 90  | -   | ns    |
| 73                  | BKPT Input Setup Time                                                     | <sup>t</sup> BKST  | 15  | -   | ns    |
| 74                  | BKPT Input Hold Time                                                      | <sup>t</sup> вкнт  | 10  | -   | ns    |
| 100                 | CLKOUT High to Phase 1 Asserted <sup>12</sup>                             | tCHP1A             | 3   | 40  | ns    |
| 101                 | CLKOUT High to Phase 2 Asserted <sup>12</sup>                             | tCHP2A             | 3   | 40  | ns    |
| 102                 | Phase 1 Valid to AS or DS Asserted <sup>13</sup>                          | <sup>t</sup> P1VSA | 10  |     | ns    |
| 103                 | Phase 2 Valid to $\overline{AS}$ or $\overline{DS}$ Negated <sup>13</sup> | tp2VSN             | 10  |     | ns    |
| 104                 | AS or DS Valid to Phase 1 Negated <sup>13</sup>                           | tSAP1N             | 10  | -   | ns    |
| 105                 | AS or DS Negated to Phase 2 Negated <sup>13</sup>                         | tSNP2N             | 10  |     | ns    |

#### Key to Figure A-10

(Abstracted from Table A–5; see table for complete notes)

NOTES:

1. All AC timing is shown with respect to 20%  $V_{DD}$  and 70%  $V_{DD}$  levels unless otherwise noted.

 Hold times are specified with respect to DS or CS on asynchronous reads and with respect to CLKOUT on fast reads. The user is free to use either hold time.

7. Maximum value is equal to  $(t_{cyc} / 2) + 25$  ns.

13. Eight pipeline states are multiplexed into IPIPE[1:0]. The multiplexed signals have two phases.



Figure A-11. Fast Termination Write Cycle Timing Diagram

| Num | Characteristic                                         | Symbol             | Min | Max | Units |
|-----|--------------------------------------------------------|--------------------|-----|-----|-------|
| 6   | Clock High to ADDR, FC, SIZE Valid                     | <sup>t</sup> CHAV  | 0   | 29  | ns    |
| 8   | Clock High to ADDR, FC, SIZE Invalid                   | tCHAZn             | 0   | _   | ns    |
| 9   | Clock Low to AS, DS, CS Asserted                       | <sup>t</sup> CLSA  | 2   | 25  | ns    |
| 12  | Clock Low to AS, DS, CS Negated                        | <sup>t</sup> CLSN  | 2   | 29  | ns    |
| 14B | AS, CS (and DS Read) Width Asserted (Fast Cycle)       | tswDw              | 40  |     | ns    |
| 18  | Clock High to R/W High                                 | t <sub>CHRH</sub>  | 0   | 29  | ns    |
| 20  | Clock High to R/W Low                                  | <sup>t</sup> CHRL  | 0   | 29  | ns    |
| 23  | Clock High to Data Out Valid                           | tCHDO              |     | 29  | ns    |
| 24  | Data Out Valid to Negating Edge of AS, CS (Fast Write) | t DVASN            | 15  |     | ns    |
| 25  | DS, CS Negated to Data Out Invalid (Data Out Hold)     | tSNDOI             | 15  | -   | ns    |
| 46A | R/W Width Asserted (Fast Write or Read)                | tRWAS              | 90  |     | ns    |
| 73  | BKPT Input Setup Time                                  | <sup>t</sup> BKST  | 15  |     | ns    |
| 74  | BKPT Input Hold Time                                   | tвкнт              | 10  |     | ns    |
| 100 | CLKOUT High to Phase 1 Asserted <sup>12</sup>          | tCHP1A             | 3   | 40  | ns    |
| 101 | CLKOUT High to Phase 2 Asserted <sup>12</sup>          | tCHP2A             | 3   | 40  | ns    |
| 102 | Phase 1 Valid to AS or DS Asserted <sup>13</sup>       | <sup>t</sup> P1VSA | 10  |     | ns    |
| 103 | Phase 2 Valid to AS or DS Negated <sup>13</sup>        | <sup>t</sup> P2VSN | 10  |     | ns    |
| 104 | AS or DS Valid to Phase 1 Negated <sup>13</sup>        | tSAP1N             | 10  | —   | ns    |
| 105 | AS or DS Negated to Phase 2 Negated <sup>13</sup>      | tSNP2N             | 10  | _   | ns    |

#### Key to Figure A-11 (Abstracted from Table A-5; see table for complete notes)

NOTES:

1. All AC timing is shown with respect to 20%  $V_{\text{DD}}$  and 70%  $V_{\text{DD}}$  levels unless otherwise noted.

13. Eight pipeline states are multiplexed into IPIPE[1:0]. The multiplexed signals have two phases.

MOTOROLA A-33





Figure A-12. ECLK Timing Diagram

| Num              | Characteristic                                                                           | Symbol             | Min | Max | Units            |
|------------------|------------------------------------------------------------------------------------------|--------------------|-----|-----|------------------|
| 1A               | ECLK Period                                                                              | tEcyc              | 476 |     | ns               |
| 2A, 3A           | ECLK Pulse Width                                                                         | tECW               | 236 | -   | ns               |
| 4A, 5A           | Rise and Fall Time                                                                       | t <sub>rf</sub>    |     | 8   | ns               |
| E1 <sup>2</sup>  | ECLK Low to ADDR and R/W Valid                                                           | t <sub>EAD</sub>   | —   | 60  | ns               |
| E2               | ECLK Low to ADDR and R/W Hold                                                            | tEAH               | 10  | —   | ns               |
| E3               | ECLK Low to CS Valid (CS delay)                                                          | tECSD              | _   | 150 | ns               |
| E4               | ECLK Low to CS Hold                                                                      | t <sub>ECSH</sub>  | 15  | _   | ns               |
| E5               | CS Negated Width                                                                         | <b>tECSN</b>       | 30  | —   | ns               |
| E6               | Read Data Setup Time                                                                     | t <sub>EDSR</sub>  | 30  | —   | ns               |
| E7               | Read Data Hold Time                                                                      | tEDHR              | 15  | -   | ns               |
| E8               | ECLK Low to Data High Impedance                                                          | <sup>t</sup> EDHZ  | —   | 60  | ns               |
| E9               | CS Negated to Data Hold (Read)                                                           | tECDH              | 0   | _   | ns               |
| E10              | CS Negated to Data High Impedance                                                        | tECDZ              | -   | 1   | t <sub>cyc</sub> |
| E11              | ECLK Low to Data Valid (Write)                                                           | tEDDW              | -   | 2   | t <sub>cyc</sub> |
| E12              | ECLK Low to Data Hold (Write)                                                            | <sup>t</sup> EDHW  | 5   | _   | ns               |
| E13              | CS Negated to Data Hold (Write)                                                          | tECHW              | 0   | -   | ns               |
| E14 <sup>3</sup> | Address Access Time (Read)                                                               | <sup>t</sup> EACC  | 386 |     | ns               |
| E15 <sup>4</sup> | Chip Select Access Time (Read)                                                           | <sup>t</sup> EACS  | 296 |     | ns               |
| E16              | Address Setup Time                                                                       | t <sub>EAS</sub>   | -   | 1/2 | t <sub>cyc</sub> |
| 100              | CLKOUT High to Phase 1 Asserted <sup>12</sup>                                            | tCHP1A             | 3   | 40  | ns               |
| 101              | CLKOUT High to Phase 2 Asserted <sup>12</sup>                                            | <sup>t</sup> CHP2A | 3   | 40  | ns               |
| 102              | Phase 1 Valid to $\overline{\text{AS}}$ or $\overline{\text{DS}}$ Asserted <sup>13</sup> | tP1VSA             | 10  |     | ns               |
| 103              | Phase 2 Valid to AS or DS Negated <sup>13</sup>                                          | tP2VSN             | 10  |     | ns               |
| 104              | AS or DS Valid to Phase 1 Negated <sup>13</sup>                                          | tSAP1N             | 10  | _   | ns               |
| 105              | AS or DS Negated to Phase 2 Negated <sup>13</sup>                                        | tSNP2N             | 10  | _   | ns               |

#### Key to Figure A-12 (Abstracted from Table A-7; see table for complete notes)

NOTES:

1. All AC timing is shown with respect to 20% V<sub>DD</sub> and 70% V<sub>DD</sub> levels unless otherwise noted.

 When the previous bus cycle is not a synchronous ECLK bus cycle, the address may be valid before ECLK goes low.

- 3. Address access time =  $t_{Ecyc} t_{EAD} t_{EDSR}$
- 4. Chip select access time =  $t_{Ecyc} t_{ECSD} t_{EDSR}$
- 13. Eight pipeline states are multiplexed into IPIPE[1:0]. The multiplexed signals have two phases.

MC68HC16Z1 USER'S MANUAL

# APPENDIX A ELECTRICAL CHARACTERISTICS



NOTE:  $\overline{\text{AS}}$  and  $\overline{\text{DS}}$  timing shown for reference only.



| Num                | Characteristic                                                 | Symbol            | Min | Max | Units |
|--------------------|----------------------------------------------------------------|-------------------|-----|-----|-------|
| 6                  | Clock High to ADDR, FC, SIZE Valid                             | tCHAV             | 0   | 29  | ns    |
| 8                  | Clock High to ADDR, FC, SIZE Invalid                           | tCHAZn            | 0   | -   | ns    |
| 9                  | Clock Low to AS, DS, CS Asserted                               | <sup>t</sup> CLSA | 2   | 25  | ns    |
| 11                 | ADDR, FC, SIZE Valid to AS, CS (and DS Read)<br>Asserted       | <sup>t</sup> AVSA | 15  | -   | ns    |
| 12                 | Clock Low to AS, DS, CS Negated                                | tCLSN             | 2   | 29  | ns    |
| 13                 | AS, DS, CS Negated to ADDR, FC, SIZE Invalid<br>(Address Hold) | <sup>t</sup> SNAI | 15  | -   | ns    |
| 14                 | AS, CS (and DS Read) Width Asserted                            | tswa              | 100 | -   | ns    |
| 14A                | DS, CS Width Asserted Write                                    | tswaw             | 45  | -   | ns    |
| 15 <sup>5</sup>    | AS, DS, CS Width Negated                                       | tSN               | 40  | -   | ns    |
| 18                 | Clock High to R/W High                                         | tCHRH             | 0   | 29  | ns    |
| 20                 | Clock High to R/W Low                                          | tCHRL             | 0   | 29  | ns    |
| 23                 | Clock High to Data Out Valid                                   | tCHDO             |     | 29  | ns    |
| 25                 | DS, CS Negated to Data Out Invalid (Data Out Hold)             | tSNDOI            | 15  | -   | ns    |
| 296                | DS, CS Negated to Data In Invalid (Data In Hold)               | tSNDI             | 0   | -   | ns    |
| 29A <sup>6,7</sup> | DS, CS Negated to Data In High Impedance                       | tSHDI             |     | 55  | ns    |
| 46                 | R/W Width Asserted (Write or Read)                             | tRWA              | 150 |     | ns    |
| 53                 | Data Out Hold from Clock High                                  | tDOCH             | 0   | -   | ns    |
| 54                 | Clock High to Data Out High Impedance                          | tснрн             |     | 28  | ns    |
| 55                 | R/W Asserted to Data Bus Impedance Change                      | tRADC             | 40  | -   | ns    |

#### Key to Figure A-13

#### (Abstracted from Table A-5; see table for complete notes)

NOTES:

- 1. All AC timing is shown with respect to 20% V<sub>DD</sub> and 70% V<sub>DD</sub> levels unless otherwise noted.
- 5. If multiple chip selects are used,  $\overline{CS}$  width negated (specification 15) applies to the time from the negation of a heavily loaded chip select to the assertion of a lightly loaded chip select. The  $\overline{CS}$  width negated specification between multiple chip selects does not apply to chip selects synchronized to ECLK.
- 6. Hold times are specified with respect to DS or CS on asynchronous reads and with respect to CLKOUT on fast reads. The user is free to use either hold time.
- 7. Maximum value is equal to  $(t_{cyc} / 2) + 25$  ns.



Figure A-14. Background Debugging Mode Timing Diagram — Serial Communication



# Figure A–15. Background Debugging Mode Timing Diagram — Freeze Assertion

#### Key to Figures A-14 and A-15

(Abstracted from Table A-6; see table for complete notes)

| Num | Characteristic                        | Symbol             | Min | Max | Unit             |
|-----|---------------------------------------|--------------------|-----|-----|------------------|
| BO  | DSI Input Setup Time                  | tDSISU             | 15  |     | ns               |
| B1  | DSI Input Hold Time                   | tDSIH              | 10  | -   | ns               |
| B2  | DSCLK Setup Time                      | tDSCSU             | 15  | -   | ns               |
| B3  | DSCLK Hold Time                       | tDSCH              | 10  |     | ns               |
| B4  | DSO Delay Time                        | tDSOD              |     | 25  | ns               |
| B5  | DSCLK Cycle Time                      | tDSCCYC            | 2   | -   | t <sub>cyc</sub> |
| B6  | CLKOUT Low to FREEZE Asserted/Negated | <sup>t</sup> FRZAN |     | 50  | ns               |
| B7  | CLKOUT High to IPIPE1 High Impedance  | tIFZ               |     | TBD | ns               |
| B8  | CLKOUT High to IPIPE1 Valid           | tIF                |     | TBD | ns               |
| B9  | DSCLK Low Time                        | <sup>t</sup> DSCLO | 1   | - 1 | t <sub>cyc</sub> |

NOTES:

1. All AC timing is shown with respect to 20%  $V_{\text{DD}}$  and 70%  $V_{\text{DD}}$  levels unless otherwise noted.







Figure A-17. QSPI Timing Master, CPHA = 1 APPENDIX A ELECTRICAL CHARACTERISTICS

MC68HC16Z1 USER'S MANUAL

MOTOROLA A-40

| Key to | Figures    | A-16   | and    | A-17 |
|--------|------------|--------|--------|------|
| (Abst  | racted fro | om Tab | ole A- | -8)  |

| Num | Function                            | Symbol                             | Min       | Max                  | Unit     |
|-----|-------------------------------------|------------------------------------|-----------|----------------------|----------|
| 1   | Master Cycle Time                   | t <sub>qcyc</sub>                  | 4         | 510                  | tcyc     |
| 2   | Master Enable Lead Time             | tlead                              | 2         | 128                  | tcyc     |
| 3   | Master Enable Lag Time              | tlag                               |           | 1/2                  | SCK      |
| 4   | Master Clock (SCK) High or Low Time | t <sub>sw</sub>                    | 2 tcyc-60 | 255 t <sub>cyc</sub> | ns       |
| 5   | Master Sequential Transfer Delay    | <sup>t</sup> td                    | 17        | 8192                 | tcyc     |
| 6   | Master Data Setup Time (Inputs)     | t <sub>su</sub>                    | 30        |                      | ns       |
| 7   | Master Data Hold Time (Inputs)      | t <sub>hi</sub>                    | 0         |                      | ns       |
| 10  | Master Data Valid (after SCK Edge)  | t <sub>v</sub>                     |           | 50                   | ns       |
| 11  | Master Data Hold Time (Outputs)     | t <sub>ho</sub>                    | 0         |                      | ns       |
| 12  | Rise Time<br>Input<br>Output        | t <sub>ri</sub><br>t <sub>ro</sub> |           | 2<br>30              | μs<br>ns |
| 13  | Fall Time<br>Input<br>Output        | t <sub>fi</sub><br>t <sub>fo</sub> | =         | 2<br>30              | μs<br>ns |

NOTES:

1. All AC timing is shown with respect to 20%  $V_{\mbox{DD}}$  and 70%  $V_{\mbox{DD}}$  levels unless otherwise noted.



Figure A-18. QSPI Timing Slave, CPHA = 0



Figure A-19. QSPI Timing Slave, CPHA = 1 APPENDIX A ELECTRICAL CHARACTERISTICS

MC68HC16Z1 USER'S MANUAL

MOTOROLA A–42

# Key to Figures A-18 and A-19

| Num | Function                                                       | Symbol                             | Min                    | Max     | Unit     |
|-----|----------------------------------------------------------------|------------------------------------|------------------------|---------|----------|
| 1   | Slave Cycle Time                                               | t <sub>qcyc</sub>                  | 4                      |         | tcyc     |
| 2   | Slave Enable Lead Time                                         | tlead                              | 2                      | _       | tcyc     |
| 3   | Slave Enable Lag Time                                          | tlag                               | 2                      | —       | tcyc     |
| 4   | Slave Clock (SCK) High or Low Time <sup>2</sup>                | t <sub>sw</sub>                    | 2 t <sub>cyc</sub> – n |         | ns       |
| 5   | Slave Sequential Transfer Delay<br>(Does Not Require Deselect) | <sup>t</sup> td                    | 13                     |         | tcyc     |
| 6   | Slave Data Setup Time (Inputs)                                 | t <sub>su</sub>                    | 20                     | -       | ns       |
| 7   | Slave Data Hold Time (Inputs)                                  | t <sub>hi</sub>                    | 20                     | _       | ns       |
| 8   | Slave Access Time                                              | ta                                 |                        | 1       | tcyc     |
| 9   | Slave MISO Disable Time                                        | <sup>t</sup> dis                   |                        | 2       | tcyc     |
| 10  | Slave Data Valid (after SCK Edge)                              | tv                                 |                        | 50      | ns       |
| 11  | Slave Data Hold Time (Outputs)                                 | t <sub>ho</sub>                    | 0                      |         | ns       |
| 12  | Rise Time<br>Input<br>Output                                   | t <sub>ri</sub><br>t <sub>ro</sub> | _                      | 2<br>30 | μs<br>ns |
| 13  | Fall Time<br>Input<br>Output                                   | t <sub>fi</sub><br>t <sub>fo</sub> | _                      | 2<br>30 | μs<br>ns |

# (Abstracted from Table A-8)

NOTES:

1. All AC timing is shown with respect to 20%  $V_{\text{DD}}$  and 70%  $V_{\text{DD}}$  levels unless otherwise noted.

2. In formula, n = External SCK rise + External SCK fall time

MOTOROLA A-44

# APPENDIX A ELECTRICAL CHARACTERISTICS

# APPENDIX B MECHANICAL DATA AND ORDERING INFORMATION

The MC68HC16Z1 is available in a 132-pin plastic surface mount package and a 144-pin plastic surface mount package. Both packages can be ordered in molded carrier rings. This appendix provides package pin assignment drawings, dimensional drawings, and ordering information.



Figure B–1. 132-Pin Plastic Surface Mount Package Pin Assignments



SCALE 1:1



#### CASE 831A-01

#### Figure B-2. 132-Pin Package Dimensions





Figure B–3. 132-Pin Molded Carrier Ring Assembly (Part 1)

APPENDIX B MECHANICAL DATA AND ORDERING INFORMATION









#### NOTES:

- OTES: 1. ALL DIMENSIONS AND TOLERANCES CONFORM TO ANSI Y14.5M, 1992. 2. CONTROLING DIMENSION: MILLIMETER. 3. A, AD, AE, AF AND AH DIMENSIONS DO NOT INCLUDE MOLD PROTRUSION. ALLOWABLE MOLD PROTRUSION IS 0.20 (0.009) PER SIDE. DO D FOTFUSION IS 0.20 (0.009) PER SIDE.
- FOR AE DIMENSION IS 0.18 (0.007). 4. A, S1 AND AH DIMENSIONS INCLUDE MOLD MISMATCH, AND ARE MEASURED AT THE
- MISMAICH, AND AHE MEASURED AT THE PARTING LINE. 5. UNLESS OTHERWISE SPECIFIED DIMENSIONS ARE SYMMETRICAL ABOUT CENTERLINES. 6. B AND C DATUM HOLES ARE TO BE USED FOR TRIM, FORM AND EXCISE OF THE MICIDED PACKAGE ONLY HOLES OF AND Q2 ARE TO BE USED FOR ELECTRICAL TESTING ONLY.
- 7. NON-DATUM HOLES ONLY.
- 8. APPLIES TO RING AND PACKAGE FEATURES.

|           | MILLIN | ETERS | INC         | HES        |  |  |
|-----------|--------|-------|-------------|------------|--|--|
| DIM       | MIN    | MAX   | MIN         | MAX        |  |  |
| A         | 45.87  | 46.13 | 46.13 1.806 |            |  |  |
| A1        | 45.70  | BSC   | 1.799       | BSC        |  |  |
| A2        | 41.37  | 41.63 | 1.629       | 1.639      |  |  |
| C         | 4.70   | 4.90  | 0.185       | 0.193      |  |  |
| D         | 0.40   | 0.50  | 0.016       | 0.020      |  |  |
| D1        | 0.21   | 0.30  | 0.008       | 0.012      |  |  |
| D2        | 0.31   | 0.40  | 0.012 0.075 | 0.016      |  |  |
| E         | 1.90   | 2.10  |             | 0.083      |  |  |
| F         | 0.19   | 0.27  | 0.007       | 0.011      |  |  |
| G         | 0.65   | BSC   | 0.026 BSC   |            |  |  |
| G1        | 0.635  | BSC   | 0.025       | BSC        |  |  |
| н         | 1.70   | 1.90  | 0.067       | 0.075      |  |  |
| J         | 0.16   | 0.20  | 0.006       | 0.008      |  |  |
| L         | 32.20  | BSC   | 1.268       | BSC        |  |  |
| L1        | 35.20  | BSC   | 1.386       | BSC        |  |  |
| M         | 1.30   | 2.30  | 0.051       | 0.091      |  |  |
| <b>M2</b> | 6°     | 8°    | 6°          | <b>8</b> ° |  |  |
| N         | 0.145  | 0.16  | 0.0057      | 0.0063     |  |  |
| P         | 1.77   | 2.03  | 0.070       | 0.080      |  |  |

|     | MILLIN | IETERS | INC   | HES   |  |  |
|-----|--------|--------|-------|-------|--|--|
| DIM | MIN    | MAX    | MIN   | MAX   |  |  |
| Ř   | 0.40   | 0.60   | 0.016 | 0.024 |  |  |
| R1  | 3.50   | 4.50   | 0.138 | 0.177 |  |  |
| R2  | 2.00   | 3.00   | 0.079 | 0.118 |  |  |
| S   | 37.87  | 38.13  | 1.491 | 1.501 |  |  |
| ٧   | 21.21  | 21.31  | 0.835 | 0.839 |  |  |
| W   | 1.45   | 1.55   | 0.057 | 0.061 |  |  |
| AA  | 0.45   | 0.85   | 0.018 | 0.033 |  |  |
| AB  | 0.30   | 0.60   | 0.012 |       |  |  |
| AC  | 1.37   | 1.63   | 0.054 | 0.064 |  |  |
| AD  | 27.88  | 28.01  | 1.098 | 1.103 |  |  |
| AE  | 25.79  | 25.93  | 1.015 | 1.021 |  |  |
| AF  | 23.91  | 24.05  | 0.941 | 0.947 |  |  |
| AG  | 21.52  | 21.66  | 0.847 | 0.853 |  |  |
| AH  | 24.06  | 24.20  | 0.947 | 0.953 |  |  |
| AJ  | 3.46   | 3.66   | 0.136 | 0.144 |  |  |
| AL  | 14.00  | 14.10  | 0.551 | 0.555 |  |  |

В

# Figure B-3. 132-Pin Molded Carrier Ring Assembly (Part 2)



Figure B-4. 144-Pin Plastic Surface Mount Package Pin Assignments

APPENDIX B MECHANICAL DATA AND ORDERING INFORMATION







NOTES:

- 1. DIMENSIONING AND TOLERANCING PER ANSI Y14.5M, 1982. 2. CONTROLLING DIMENSION: MILLIMETER.
- 2. CONTROLLING DIMENSION: MILLIMETER. 3. DATUM PLANE -H- IS LOCATED AT BOTTOM OF
- LEAD AND IS COINCIDENT WITH THE LEAD WHERE THE LEAD EXISTS THE PLASTIC BODY AT THE BOTTOM OF THE PARTING LINE.
- AT THE BOTTOM OF THE PARTING LINE. 4. DATUMS -A-, -B- AND -D- TO BE DETERMINED AT DATUM PLANE -H-.
- DIMENSIONS S AND V TO BE DETERMINED AT SEATING PLANE -C-.
- SEATING PLANE -C-6. DIMENSIONS A AND B DO NOT INCLUDE MOLD PROTRUSION. ALLOWABLE PROTRUSION IS 0.25(0.010) PER SIDE. DIMENSIONS A AND B DO INCLUDE MOLD MISMATCH AND ARE DETERDINED AT DATING IA ANE H
- DETERMINED AT DATUM PLANE -H-. 7. DIMENSION D DOES NOT INCLUDE DAMBAR BROTRUSION ALLOWARE DAMBAR
- DIRICISION OF DESING INCLUDE DAMBAR PROTRUSION. ALLOWABLE DAMBAR PROTRUSION SHALL BE 0.08(0.003) TOTAL IN EXCESS OF THE D DIMENSION AT MAXIMUM MATERIAL CONDITION.

|     | MILLIN | ETERS | INC          | HES        |  |
|-----|--------|-------|--------------|------------|--|
| DIM | MIN    | MAX   | MIN          | MAX        |  |
| A   | 19.90  | 20.10 | 0.784        | 0.791      |  |
| В   | 19.90  | 20.10 | 0.784        | 0.791      |  |
| C   | 2.80   | 3.00  | 0.111        | 0.118      |  |
| D   | 0.18   | 0.28  | 0.007        | 0.011      |  |
| E   | 2.50   | 2.70  | 0.099        | 0.106      |  |
| F   | 0.18   | 0.24  | 0.007        | 0.009      |  |
| G   | 0.50   | BASIC | 0.0197       | BASIC      |  |
| н   | 0.25   | 0.35  | 0.10         | 0.013      |  |
| J   | 0.11   | 0.18  | 0.005        | 0.007      |  |
| K   | 0.65   | 0.95  | 0.026        | 0.037      |  |
| L   | 17.5   | D REF | 0.689 BASIC  |            |  |
| M   | 5°     | 9°    | 5°           | <b>9</b> ° |  |
| N   | 0.11   | 0.14  | 0.005        | 0.005      |  |
| P   | 0.25   | BASIC | 0.0098 BASIC |            |  |
| Q   | 0°     | 7°    | 0°           | 7°         |  |
| R   | 0.13   | 0.30  | 0.005        | 0.012      |  |
| S   | 23.00  | 23.40 | 0.906        | 0.921      |  |
| T   | 0.13   | -     | 0.006        | -          |  |
| U   | 0°     | _     | 0°           | -          |  |
| V   | 23.00  | 23.40 | 0.906        | 0.921      |  |
| W   | 0.40   | -     | 0.016        | -          |  |
| X   | 1.60   | REF   | 0.063 REF    |            |  |

В



CASE 863C-01





SCALE 1:1





NOTES:

- 1. ALL DIMENSIONS AND TOLERANCES CONFORM
- 1. ALL DIMENSIONS AND TOLERANCES CONFORM TO ANSI Y145M, 1982.
   2. CONTROLLING DIMENSION: MILLIMETER.
   3. A DIMENSION DOES NOT INCLUDE MOLD PROTRUSION, ALLOWABLE MOLD PROTRUSION IS 0.20 (0.006) PER SIDE
- 4. A AND S DIMENSIONS INCLUDE MOLD MISMATCH, AND ARE MEASURED AT THE PARTING LINE.
- 5. UNLESS OTHEWISE SPECIFIED DIMENSIONS ARE SYMMETRICAL ABOUT CENTERLINES. 6. B AND C DATUM HOLES ARE TO BE USED FOR
- TRIM, FORM AND EXCISE OF THE MOLDED PACKAGE ONLY. HOLES Q1 AND Q2 ARE TO BE USED FOR ELECTRICAL TESTING ONLY.
- USED FOR ELECTRICAL TESTING ONLY. 7. NON-DATUM HOLES ONLY. 8. APPLIES TO RING AND PACKAGE FEATURES. 9. DIMENSION DI DOES NOT INCLUDE DAMBAR PROTRUSION. ALLUG DAG (0.003) TOTAL IN EXCESS OF THE DIMENSION AT MAXIMUM MATERIAL CONDITION.

|     | MILLIM | ETERS                | INC         | HES    |  |  |
|-----|--------|----------------------|-------------|--------|--|--|
| DIM | MIN    | MAX                  | MIN         | MAX    |  |  |
| A   | 35.870 | 36.130               | 1.412       | 1.422  |  |  |
| A1  | 35.70  | 0 BSC                | 1.406 BSC   |        |  |  |
| A2  | 35.180 | 35.430               | 1.385       | 1.395  |  |  |
| B   | 11.00  | D BSC                | 0.433 BSC   |        |  |  |
| C   | 4.700  | 4.900                | 0.185       | 0.193  |  |  |
| D   | 0.410  | 0.500                | 0.016       | 0.020  |  |  |
| D1  | 0.150  | 0.304                | 0.006       | 0.012  |  |  |
| D2  | 0.400  | MAX                  | 0.016       | 6 MAX  |  |  |
| E   | 1.910  | 2.109                | 0.075       | 0.083  |  |  |
| F   | 0.150  | 0.260                | 0.006       | 0.010  |  |  |
| G   | 0.650  | BSC                  | 0.020       | 5 BSC  |  |  |
| G1  | 0.500  | BSC                  | 0.020       | BSC    |  |  |
| H   | 1.700  | 1.90                 | 0.067       | 0.075  |  |  |
| J   | 0.130  | 0.23                 | 0.006       | 0.009  |  |  |
| L   | 22.00  | 0 BSC                | 0.866 BSC   |        |  |  |
| L1  | 25.20  | 0 BSC                | 0.992 BSC   |        |  |  |
| M   | 1.600  | 2.000                | 0.063       | 0.078  |  |  |
| M2  |        | MAX                  | 8° MAX      |        |  |  |
| N   | 0.130  | 0.170                | 0.005       | 0.007  |  |  |
| Ρ.  | 1.770  | 2.030                | 0.070       | 0.080  |  |  |
| R   | 0.400  | 0.600                | 0.016       | 0.024  |  |  |
| R1  | 3.500  | 4.500                | 0.138       | 0.177  |  |  |
| R2  | 2.000  | 3.000                | 0.079       | 0.118  |  |  |
| S   | 27.870 | 28.130               | 1.097       | 1.107  |  |  |
| T   |        | 0 BSC                |             | BSC    |  |  |
| V   | 14.550 | 14.750               | 0.573       | 0.580  |  |  |
| V1  | 14.550 | 14.750               | 0.573       | 0.580  |  |  |
| W   | 1.450  | 1.550                | 0.057       | 0.061  |  |  |
| AA  | 0.450  | 0.850                | 0.018       | 0.033  |  |  |
| AB  | 0.300  | 0.600                | 0.012       | 0.024  |  |  |
| AC  | 1.370  | 1.630                | 0.054       | 0.064  |  |  |
| AD  | 1.370  | 1.630                | 0.054 0.064 |        |  |  |
| AH  | 19.900 | 00 20.100 0.7835 0.7 |             |        |  |  |
| AH1 | 19.900 | 20.100               | 0.7835      | 0.7913 |  |  |
| AJ  | 2.530  | 2.670                | 0.0996      | 0.1051 |  |  |

CASE 922-01

# Figure B–6. 144-Pin Molded Carrier Ring Assembly (Part 1)





| Device<br>Package | Temperature<br>Range (°C) | Reference<br>Frequency | Shipping<br>Method | Order<br>Number |
|-------------------|---------------------------|------------------------|--------------------|-----------------|
| 132-PIN           | -40 to 85                 | 16.78 MHz              | 36 PER TRAY        | XC16Z1CFC16     |
| PLASTIC           |                           |                        | 2 PER TRAY         | SPAKXC16Z1CFC16 |
| SURFACE           |                           | 20 MHz                 | 36 PER TRAY        | XC16Z1CFC20     |
| MOUNT             |                           |                        | 2 PER TRAY         | SPAKXC16Z1CFC20 |
|                   |                           | 25 MHz                 | 36 PER TRAY        | XC16Z1CFC25     |
|                   |                           |                        | 2 PER TRAY         | SPAKXC16Z1CFC25 |
|                   | -40 to 105                | 16.78 MHz              | 36 PER TRAY        | XC16Z1VFC16     |
|                   |                           |                        | 2 PER TRAY         | SPAKXC16Z1VFC16 |
|                   |                           | 20 MHz                 | 36 PER TRAY        | XC16Z1VFC20     |
|                   |                           |                        | 2 PER TRAY         | SPAKXC16Z1VFC20 |
|                   |                           | 25 MHz                 | 36 PER TRAY        | XC16Z1VFC25     |
|                   |                           |                        | 2 PER TRAY         | SPAKXC16Z1VFC25 |
|                   | -40 to 125                | 16.78 MHz              | 36 PER TRAY        | XC16Z1MFC16     |
|                   |                           |                        | 2 PER TRAY         | SPAKXC16Z1MFC16 |
|                   |                           | 20 MHz                 | 36 PER TRAY        | XC16Z1MFC20     |
|                   |                           |                        | 2 PER TRAY         | SPAKXC16Z1MFC20 |
|                   |                           | 25 MHz                 | 36 PER TRAY        | XC16Z1MFC25     |
|                   |                           |                        | 2 PER TRAY         | SPAKXC16Z1MFC25 |
| 132-PIN           | -40 to 85                 | 16.78 MHz              | 10 PER TUBE        | XC16Z1CFD16     |
| MOLDED            |                           | 20 MHz                 | 10 PER TUBE        | XC16Z1CFD20     |
| CARRIER           |                           | 25 MHz                 | 10 PER TUBE        | XC16Z1CFD25     |
| RING              | -40 to 105                | 16.78 MHz              | 10 PER TUBE        | XC16Z1VFD16     |
|                   |                           | 20 MHz                 | 10 PER TUBE        | XC16Z1VFD20     |
|                   |                           | 25 MHz                 | 10 PER TUBE        | XC16Z1VFD25     |
|                   | -40 to 125                | 16.78 MHz              | 10 PER TUBE        | XC16Z1MFD16     |
|                   |                           | 20 MHz                 | 10 PER TUBE        | XC16Z1MFD20     |
|                   |                           | 25 MHz                 | 10 PER TUBE        | XC16Z1MFD25     |
| 144-PIN           | -40 to 85                 | 16.78 MHz              | 44 PER TRAY        | XC16Z1CFV16     |
| PLASTIC           |                           |                        | 2 PER TRAY         | SPAKXC16Z1CFV16 |
| SURFACE           |                           | 20 MHz                 | 44 PER TRAY        | XC16Z1CFV20     |
| MOUNT             |                           |                        | 2 PER TRAY         | SPAKXC16Z1CFV20 |
|                   |                           | 25 MHz                 | 44 PER TRAY        | XC16Z1CFV25     |
|                   |                           |                        | 2 PER TRAY         | SPAKXC16Z1CFV25 |
|                   | -40 to 105                | 16.78 MHz              | 44 PER TRAY        | XC16Z1VFV16     |
|                   |                           |                        | 2 PER TRAY         | SPAKXC16Z1VFV16 |
|                   |                           | 20 MHz                 | 44 PER TRAY        | XC16Z1VFV20     |
|                   |                           |                        | 2 PER TRAY         | SPAKXC16Z1VFV20 |
|                   |                           | 25 MHz                 | 44 PER TRAY        | XC16Z1VFV25     |
|                   |                           |                        | 2 PER TRAY         | SPAKXC16Z1VFV25 |
|                   | -40 to 125                | 16.78 MHz              | 44 PER TRAY        | XC16Z1MFV16     |
|                   |                           |                        | 2 PER TRAY         | SPAKXC16Z1MFV16 |
|                   |                           | 20 MHz                 | 44 PER TRAY        | XC16Z1MFV20     |
|                   |                           |                        | 2 PER TRAY         | SPAKXC16Z1MFV20 |
|                   |                           | 25 MHz                 | 44 PER TRAY        | XC16Z1MFV25     |
|                   |                           |                        | 2 PER TRAY         | SPAKXC16Z1MFV25 |
| 144-PIN           | -40 to 85                 | 16.78 MHz              | 13 PER TUBE        | XC16Z1CFM16     |
| MOLDED            |                           | 20 MHz                 | 13 PER TUBE        | XC16Z1CFM20     |
| CARRIER           |                           | 25 MHz                 | 13 PER TUBE        | XC16Z1CFM25     |
| RING              | -40 to 105                | 16.78 MHz              | 13 PER TUBE        | XC16Z1VFM16     |
|                   |                           | 20 MHz                 | 13 PER TUBE        | XC16Z1VFM20     |
|                   |                           | 25 MHz                 | 13 PER TUBE        | XC16Z1VFM25     |
|                   | -40 to 125                | 16.78 MHz              | 13 PER TUBE        | XC16Z1MFM16     |
|                   |                           | 20 MHz                 | 13 PER TUBE        | XC16Z1MFM20     |
|                   | 1                         | 25 MHz                 | 13 PER TUBE        | XC16Z1MFM25     |

# Table B-1. MC68HC16Z1 Ordering Information

# APPENDIX C DEVELOPMENT SUPPORT

This section is a brief reference to Motorola development tools for the MC68HC16Z1 microcontroller. Information provided is complete at the time of publication, but new systems and software are continually being developed. In addition, there are a growing number of third-party tools available. The Motorola *MCU Tool Box* (MCUTLBX/D Rev. B) provides an up-to-date list of development tools. Contact your Motorola representative for further information.

Table C-1. MC68HC16Z1 Development Tools

| Microcontroller | Evaluation   | Evaluation | Evaluation    | Programmer |
|-----------------|--------------|------------|---------------|------------|
| Part Number     | Board        | Modules*   | Systems*/Kits | Boards     |
| MC68HC16Z1      | M68HC16Z1EVB | -          |               |            |

\*EVS and EVM include an Integrated Development Environment (IDE) which contains an editor, assembler, hardware debugger and simulator.

# C.1 M68HC16EVB Evaluation Board

The evaluation board is a low-cost tool for debugging and evaluating MC68HC16Z1-based target systems. Features of the M68HC16EVB include:

- Operation in either debugging or evaluation mode.
- Operation from a personal computer platform without an on-board monitor using CPU16 background debugging mode.
- An integrated assembly/editing/emulation environment.
- · As many as seven software breakpoints.
- Memory map of target system.
- On-board RS-232C port.
- Logic analyzer pod connectors.

Refer to the *M68HC16EVB Evaluation Board User's Manual*, (M68HC16Z1EVB/D) for more information.

# APPENDIX D REGISTER SUMMARY

This appendix contains address maps, register diagrams, and bit/field definitions for the MC68HC16Z1. This appendix is intended to be a ready reference. In-depth information about register function is provided in the appropriate sections of the manual.

Except for central processing unit resources, information is presented in the intermodule bus address order shown in Table D-1.

| Module | Size<br>(Bytes) | 23   | Base<br>Address |      |      |      |      |          |          |
|--------|-----------------|------|-----------------|------|------|------|------|----------|----------|
| ADC    | 64              | M111 | 1111            | 1111 | 0111 | 00XX | XXXX | \$YFF700 |          |
| GPT    | 64              | M111 | 1111            | 1111 | 1001 | 00XX | XXXX | \$YFF900 |          |
| SIM    | 128             | 128  | M111            | 1111 | 1111 | 1010 | 0XXX | XXXX     | \$YFFA00 |
| SRAM   | 8               | M111 | 1111            | 1111 | 1011 | 0000 | OXXX | \$YFFB00 |          |
| QSM    | 512             | M111 | 1111            | 1111 | 110X | XXXX | XXXX | \$YFFC00 |          |

Table D-1. MC68HC16Z1 Module Address Map

Control registers for all the modules in the microcontroller are mapped into a 4 Kbyte block. The state of the module mapping (MM) bit in the SIM module configuration register (SIMCR) determines where the control registers block is located in the system memory map. When MM = 0, register addresses range from \$7FF000 to \$7FFFFF; when MM = 1, register addresses range from \$FFF000 to \$FFFFFF.

In the MC68HC16Z1, ADDR[23:20] follow the logic state of ADDR19 unless externally driven. MM corresponds to IMB ADDR23 — if it is cleared, the SIM maps IMB modules into address space \$7FF000-\$7FFFFF, which is inaccessible to the CPU16. Modules remain inaccessible until reset occurs. The reset state of MM is one, but the bit is one-time writable — initialization software should make certain it remains set.

# **D.1 Central Processing Unit**

CPU16 registers are not part of the module address map. The following diagram is a functional representation of CPU resources.

# D.1.1 CPU16 Register Model

| 20 16 | 15 8     | 7        | 0   | <b>BIT POSITION</b>                                       |
|-------|----------|----------|-----|-----------------------------------------------------------|
|       | A        | D        | B   | ACCUMULATORS A AND B<br>ACCUMULATOR D (A : B)             |
|       |          | E        |     | ACCUMULATOR E                                             |
| ХК    |          | IX       |     | INDEX REGISTER X                                          |
| YK    |          | IY       |     | INDEX REGISTER Y                                          |
| ZK    |          | IZ       |     | INDEX REGISTER Z                                          |
| SK    | 5        | SP       |     | STACK POINTER                                             |
| PK    | F        | ×        |     | PROGRAM COUNTER                                           |
|       | CCR      |          | РК  | CONDITION CODE REGISTER/<br>PC EXTENSION REGISTER         |
|       | ЕК ХК    | YK       | ZK  | ADDRESS EXTENSION REGISTER                                |
|       |          |          | SK  | STACK EXTENSION REGISTER                                  |
|       | ŀ        | HR.      |     | MAC MULTIPLIER REGISTER                                   |
|       |          | IR       |     | MAC MULTIPLICAND REGISTER                                 |
|       | <i>µ</i> | AA<br>AM | 1   | MAC ACCUMULATOR MSB [35:16]<br>MAC ACCUMULATOR LSB [15:0] |
|       | XMSK     | YM       | ISK | MAC XY MASK REGISTER                                      |

| D.1.2 | CCR · | - Condition | Code | Register |
|-------|-------|-------------|------|----------|
|-------|-------|-------------|------|----------|

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6  | 5 | 4  | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|----|---|----|---|---|---|---|
| S  | MV | Н  | EV | N  | Z  | V | c |   | IP |   | SM |   | Р | к |   |

The CCR contains processor status flags, the interrupt priority field, and the program counter address extension field. The CPU16 has a special set of instructions that manipulate the CCR.

# S — STOP Enable

- 0 = Stop clock when LPSTOP instruction is executed.
- 1 = Perform NOP when LPSTOP instruction is executed.
- MV Accumulator M overflow flag

Set when overflow into AM35 has occurred.

H — Half Carry Flag

Set when a carry from A3 or B3 occurs during BCD addition.

- EV Extension Bit Overflow Flag Set when an overflow into AM31 has occurred.
- N Negative Flag

Set when the MSB of a result register is set.

Z — Zero Flag

Set when all bits of a result register are zero.

V — Overflow Flag

Set when twos complement overflow occurs as the result of an operation.

# C — Carry Flag

Set when carry or borrow occurs during arithmetic operation. Also used during shift and rotate to facilitate multiple word operations.

# IP[2:0] — Interrupt Priority Field

The priority value in this field (0 to 7) is used to mask interrupts.

# SM — Saturate Mode Bit

When SM is set, if either EV or MV is set, data read from AM using TMER or TMET will be given maximum positive or negative value, depending on the state of the AM sign bit before overflow.

PK[3:0] — Program Counter Address Extension Field

This field is concatenated with the program counter to form a 20-bit address.

| Address  | 15 8 7                                     | 0 |
|----------|--------------------------------------------|---|
| \$YFF700 | MODULE CONFIGURATION (ADCMCR)              |   |
| \$YFF702 | FACTORY TEST (ADTEST)                      |   |
| \$YFF704 | (RESERVED)                                 |   |
| \$YFF706 | PORT ADA DATA (PORTADA)                    |   |
| \$YFF708 | (RESERVED)                                 |   |
| \$YFF70A | ADC CONTROL 0 (ADCTL0)                     |   |
| \$YFF70C | ADC CONTROL 1 (ADCTL1)                     |   |
| \$YFF70E | ADC STATUS (ADSTAT)                        |   |
| \$YFF710 | RIGHT-JUSTIFIED UNSIGNED RESULT 0 (RJURR0) |   |
| \$YFF712 | RIGHT-JUSTIFIED UNSIGNED RESULT 1 (RJURR1) |   |
| \$YFF714 | RIGHT-JUSTIFIED UNSIGNED RESULT 2 (RJURR2) |   |
| \$YFF716 | RIGHT-JUSTIFIED UNSIGNED RESULT 3 (RJURR3) |   |
| \$YFF718 | RIGHT-JUSTIFIED UNSIGNED RESULT 4 (RJURR4) |   |
| \$YFF71A | RIGHT-JUSTIFIED UNSIGNED RESULT 5 (RJURR5) |   |
| \$YFF71C | RIGHT-JUSTIFIED UNSIGNED RESULT 6 (RJURR6) |   |
| \$YFF71E | RIGHT-JUSTIFIED UNSIGNED RESULT 7 (RJURR7) |   |
| \$YFF720 | LEFT-JUSTIFIED SIGNED RESULT 0 (LJSRR0)    |   |
| \$YFF722 | LEFT-JUSTIFIED SIGNED RESULT 1 (LJSRR1)    |   |
| \$YFF724 | LEFT-JUSTIFIED SIGNED RESULT 2 (LJSRR2)    |   |
| \$YFF726 | LEFT-JUSTIFIED SIGNED RESULT 3 (LJSRR3)    |   |
| \$YFF728 | LEFT-JUSTIFIED SIGNED RESULT 4 (LJSRR4)    |   |
| \$YFF72A | LEFT-JUSTIFIED SIGNED RESULT 5 (LJSRR5)    |   |
| \$YFF72C | LEFT-JUSTIFIED SIGNED RESULT 6 (LJSRR6)    |   |
| \$YFF72E | LEFT-JUSTIFIED SIGNED RESULT 7 (LJSRR7)    |   |
| \$YFF730 | LEFT-JUSTIFIED UNSIGNED RESULT 0 (LJURRO)  |   |
| \$YFF732 | LEFT-JUSTIFIED UNSIGNED RESULT 1 (LJURR1)  |   |
| \$YFF734 | LEFT-JUSTIFIED UNSIGNED RESULT 2 (LJURR2)  |   |
| \$YFF736 | LEFT-JUSTIFIED UNSIGNED RESULT 3 (LJURR3)  |   |
| \$YFF738 | LEFT-JUSTIFIED UNSIGNED RESULT 4 (LJURR4)  |   |
| \$YFF73A | LEFT-JUSTIFIED UNSIGNED RESULT 5 (LJURR5)  |   |
| \$YFF73C | LEFT-JUSTIFIED UNSIGNED RESULT 6 (LJURR6)  |   |
| \$YFF73E | LEFT-JUSTIFIED UNSIGNED RESULT 7 (LJURR7)  |   |

Table D-2. ADC Module Address Map

| D.2.1  | A | DCI | MCR |    | ADC | Module   | Conf | igu | ration | Register |          | \$YFF700 |
|--------|---|-----|-----|----|-----|----------|------|-----|--------|----------|----------|----------|
| 15     | 1 | 4   | 13  | 12 |     |          |      | 8   | 7      | 6        |          | 0        |
| STOP   |   | FRZ |     |    |     | NOT USED |      |     | SUPV   |          | NOT USED |          |
| RESET: |   |     |     |    |     |          |      |     |        |          |          |          |
| 1      | ( | )   | 0   |    |     |          |      |     | 0      |          |          |          |

ADCMCR controls ADC operation during low-power stop and freeze modes.

# STOP — STOP Mode

- 0 = Normal operation
- 1 = Low-power operation

STOP places the ADC in low-power state. Setting STOP aborts any conversion in progress. STOP is set during reset and must be cleared before ADC operation can begin — because analog circuitry bias current has been turned off, there must be a period of recovery after STOP is cleared before conversion begins.

# FRZ[1:0] — Freeze

The FRZ field determines ADC response to assertion of the FREEZE signal.

| Freeze Encouning |                                |  |  |  |  |  |
|------------------|--------------------------------|--|--|--|--|--|
| FRZ[1:0]         | Response                       |  |  |  |  |  |
| 00               | Ignore IFREEZE                 |  |  |  |  |  |
| 01               | Reserved                       |  |  |  |  |  |
| 10               | Finish conversion, then freeze |  |  |  |  |  |
| 11               | Freeze immediately             |  |  |  |  |  |

#### Freeze Encoding

#### SUPV — Supervisor/Unrestricted

Because the CPU16 in the MC68HC16Z1 operates only in supervisor mode, this bit has no effect.

# D.2.2 ADTEST — ADC Test Register

# \$YFF702

ADTEST is used with the SIM test register for factory test of the ADC.

| D.2.3 PORTADA — Port ADA Data Register |          |   |   |   |   |   |   |   |            | <b>\$YFF706</b> |
|----------------------------------------|----------|---|---|---|---|---|---|---|------------|-----------------|
| 15                                     |          |   |   |   |   |   | 8 | 7 |            | 0               |
|                                        | NOT USED |   |   |   |   |   |   |   | PADA       |                 |
| RESET:<br>0                            | 0        | 0 | 0 | 0 | 0 | 0 | 0 |   | INPUT DATA |                 |

A read of PADA[7:0] returns the logic levels of port ADA pins. If an input is outside specified logic levels, an indeterminate value is read. Use as a digital input does not preclude use as an analog input.

| D.2.4  | D.2.4 ADCTL0 — A/D Control Register 0 \$YFF70A |   |     |      |   |   |   |       |   |    |   |   |     |   |   |
|--------|------------------------------------------------|---|-----|------|---|---|---|-------|---|----|---|---|-----|---|---|
| 15     |                                                |   |     |      |   |   | 8 | 7     | 6 | 5  | 4 | 3 | 2   | 1 | 0 |
|        |                                                |   | NOT | USED |   |   |   | RES10 | S | TS |   |   | PRS |   |   |
| RESET: |                                                |   |     |      |   |   |   |       |   |    |   |   |     |   |   |
| 0      | 0                                              | 0 | 0   | 0    | 0 | 0 | 0 | 0     | 0 | 0  | 0 | 0 | 0   | 1 | 1 |

ADCTL0 is used to select resolution, sample time, and clock/prescaler value. Writing ADCTL0 aborts any conversion in progress — ADC activity halts until ADCTL1 is written.

RES10 — 10-Bit Resolution

0 = 8-bit conversion

1 = 10-bit conversion

### STS[1:0] — Sample Time Selection

The STS field selects one of four sample times.

| Sample   | This Selection       |
|----------|----------------------|
| STS[1:0] | Sample Time          |
| 00       | 4 A/D Clock Periods  |
| 01       | 8 A/D Clock Periods  |
| 10       | 16 A/D Clock Periods |
| 11       | 32 A/D Clock Periods |

### Sample Time Selection

PRS[4:0] — Prescaler Rate Selection

ADC clock is generated from system clock using a modulus counter and a divideby-two circuit. PRS contains the counter modulus.

| ADC CIOCK | Selection  |
|-----------|------------|
| PRS[4:0]  | ADCCLK     |
| %00000    | RESERVED   |
| %00001    | Sys Clk/4  |
| %00010    | Sys Clk/6  |
|           |            |
| %11101    | Sys Clk/60 |
| %11110    | Sys Clk/62 |
| %11111    | Sys Clk/64 |
|           |            |

### ADC Clock Selection

| D.2.5 ADCTL1 — A/D Control Register | 1 |      |      |      |    |    | \$YF | F70C |
|-------------------------------------|---|------|------|------|----|----|------|------|
| 15                                  | 7 | 6    | 5    | 4    | 3  | 2  | 1    | 0    |
| NOT USED                            |   | SCAN | MULT | S8CM | CD | 00 | CB   | CA   |

| RESET: |   |   |   |   | AUT.V. (193 | · · · · · · · · · · · · · · · · · · · | 6 |   |   |   |   |   |   | L |   |  |
|--------|---|---|---|---|-------------|---------------------------------------|---|---|---|---|---|---|---|---|---|--|
| 0      | 0 | 0 | 0 | 0 | 0           | 0                                     | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |

ADCTL1 selects conversion mode and the analog channel or channels. Writing ADCTL1 aborts any conversion in progress and initiates a new conversion sequence.

- SCAN Scan Mode Selection
  - 0 =Single conversion sequence
  - 1 = Continuous conversion
- MULT Multichannel Conversion
  - 0 = Conversion sequence(s) run on a single channel selected by [CD:CA].
  - 1 = Sequential conversion of four or eight channels selected by [CD:CA].
- S8CM Select Eight-Conversion Sequence Mode
  - 0 = Four-conversion sequence
  - 1 = Eight-conversion sequence

### **ADC Conversion Modes**

| SCAN | MULT | S8CM | MODE                                           |
|------|------|------|------------------------------------------------|
| 0    | 0    | 0    | SINGLE 4-CONVERSION SINGLE-CHANNEL SEQUENCE    |
| 0    | 0    | 1    | SINGLE 8-CONVERSION SINGLE-CHANNEL SEQUENCE    |
| 0    | 1    | 0    | SINGLE 4-CONVERSION MULTICHANNEL SEQUENCE      |
| 0    | 1    | 1    | SINGLE 8-CONVERSION MULTICHANNEL SEQUENCE      |
| 1    | 0    | 0    | MULTIPLE 4-CONVERSION SINGLE-CHANNEL SEQUENCES |
| 1    | 0    | 1    | MULTIPLE 8-CONVERSION SINGLE-CHANNEL SEQUENCES |
| 1    | 1    | 0    | MULTIPLE 4-CONVERSION MULTICHANNEL SEQUENCES   |
| 1    | 1    | 1    | MULTIPLE 8-CONVERSION MULTICHANNEL SEQUENCES   |

[CD:CA] — Channel Selection

Bits in this field select input channel or channels for analog-to-digital conversion.

Conversion mode determines which channel or channels are selected for conversion and which result registers are used to store conversion results. The following tables summarize the effects of ADCTL1 bits and fields.

### Single-Channel Conversions

| S8CM | CD | cc | СВ | CA | Input                                    | Result Register |
|------|----|----|----|----|------------------------------------------|-----------------|
| 0    | 0  | 0  | 0  | 0  | ANO                                      | RSLT[0:3]       |
| 0    | 0  | 0  | 0  | 1  | AN1                                      | RSLT[0:3]       |
| 0    | 0  | 0  | 1  | 0  | AN2                                      | RSLT[0:3]       |
| 0    | 0  | 0  | 1  | 1  | AN3                                      | RSLT[0:3]       |
| 0    | 0  | 1  | 0  | 0  | AN4                                      | RSLT[0:3]       |
| 0    | 0  | 1  | 0  | 1  | AN5                                      | RSLT[0:3]       |
| 0    | 0  | 1  | 1  | 0  | AN6                                      | RSLT[0:3]       |
| 0    | 0  | 1  | 1  | 1  | AN7                                      | RSLT[0:3]       |
| 0    | 1  | 0  | 0  | 0  | RESERVED                                 | RSLT[0:3]       |
| 0    | 1  | 0  | 0  | 1  | RESERVED                                 | RSLT[0:3]       |
| 0    | 1  | 0  | 1  | 0  | RESERVED                                 | RSLT[0:3]       |
| 0    | 1  | 0  | 1  | 1  | RESERVED                                 | RSLT[0:3]       |
| 0    | 1  | 1  | 0  | 0  | V <sub>RH</sub>                          | RSLT[0:3]       |
| 0    | 1  | 1  | 0  | 1  | V <sub>RL</sub>                          | RSLT[0:3]       |
| 0    | 1  | 1  | 1  | 0  | (V <sub>RH –</sub> V <sub>RL</sub> ) / 2 | RSLT[0:3]       |
| 0    | 1  | 1  | 1  | 1  | TEST/RESERVED                            | RSLT[0:3]       |
| 1    | 0  | 0  | 0  | 0  | ANO                                      | RSLT[0:7]       |
| 1    | 0  | 0  | 0  | 1  | AN1                                      | RSLT[0:7]       |
| 1    | 0  | 0  | 1  | 0  | AN2                                      | RSLT[0:7]       |
| 1    | 0  | 0  | 1  | 1  | AN3                                      | RSLT[0:7]       |
| 1    | 0  | 1  | 0  | 0  | AN4                                      | RSLT[0:7]       |
| 1    | 0  | 1  | 0  | 1  | AN5                                      | RSLT[0:7]       |
| 1    | 0  | 1  | 1  | 0  | AN6                                      | RSLT[0:7]       |
| 1    | 0  | 1  | 1  | 1  | AN7                                      | RSLT[0:7]       |
| 1    | 1  | 0  | 0  | 0  | RESERVED                                 | RSLT[0:7]       |
| 1    | 1  | 0  | 0  | 1  | RESERVED                                 | RSLT[0:7]       |
| 1    | 1  | 0  | 1  | 0  | RESERVED                                 | RSLT[0:7]       |
| 1    | 1  | 0  | 1  | 1  | RESERVED                                 | RSLT[0:7]       |
| 1    | 1  | 1  | 0  | 0  | V <sub>RH</sub>                          | RSLT[0:7]       |
| 1    | 1  | 1  | 0  | 1  | V <sub>RL</sub>                          | RSLT[0:7]       |
| 1    | 1  | 1  | 1  | 0  | (V <sub>RH -</sub> V <sub>RL</sub> ) / 2 | RSLT[0:7]       |
| 1    | 1  | 1  | 1  | 1  | TEST/RESERVED                            | RSLT[0:7]       |

| Multichannel Conversions |    |    |    |    |                                          |                 |  |  |  |  |  |
|--------------------------|----|----|----|----|------------------------------------------|-----------------|--|--|--|--|--|
| S8CM                     | CD | CC | СВ | CA | Input                                    | Result Register |  |  |  |  |  |
| 0                        | 0  | 0  | Х  | X  | AN[0:3]                                  | RSLT[0:3]       |  |  |  |  |  |
| 0                        | 0  | 1  | Х  | Х  | AN[4:7]                                  | RSLT[0:3]       |  |  |  |  |  |
| 0                        | 1  | 0  | Х  | Х  | RESERVED                                 | RSLT[0:3]       |  |  |  |  |  |
| 0                        | 1  | 1  | Х  | Х  | V <sub>RH</sub>                          | RSLT0           |  |  |  |  |  |
|                          |    |    |    |    | V <sub>RL</sub>                          | RSLT1           |  |  |  |  |  |
|                          |    |    |    |    | (V <sub>RH –</sub> V <sub>RL</sub> ) / 2 | RSLT2           |  |  |  |  |  |
|                          |    |    |    |    | TEST/RESERVED                            | RSLT3           |  |  |  |  |  |
| 1                        | 0  | Х  | Х  | Х  | AN[0:7]                                  | RSLT[0:7]       |  |  |  |  |  |
| 1                        | 1  | Х  | Х  | Х  | RESERVED                                 | RSLT0           |  |  |  |  |  |
|                          |    |    |    |    | RESERVED                                 | RSLT1           |  |  |  |  |  |
|                          |    |    |    |    | RESERVED                                 | RSLT2           |  |  |  |  |  |
|                          |    |    |    |    | RESERVED                                 | RSLT3           |  |  |  |  |  |
|                          |    |    |    |    | V <sub>RH</sub>                          | RSLT4           |  |  |  |  |  |
|                          |    |    |    |    | V <sub>RL</sub>                          | RSLT5           |  |  |  |  |  |
|                          |    |    |    |    | (V <sub>RH –</sub> V <sub>RL</sub> ) / 2 | RSLT6           |  |  |  |  |  |
|                          |    |    |    |    | TEST/RESERVED                            | RSLT7           |  |  |  |  |  |

### Multichannel Conversions

| D.2.6  | D.2.6 ADSTAT — ADC Status Register |     |      |    |    |      |   |   |     |   |   |   | \$YF | F70E |   |
|--------|------------------------------------|-----|------|----|----|------|---|---|-----|---|---|---|------|------|---|
| 15     | 14                                 |     |      | 11 | 10 |      | 8 | 7 |     |   |   |   |      |      | 0 |
| SCF    |                                    | NOT | USED |    |    | CCTR |   |   | COF |   |   |   |      |      |   |
| RESET: |                                    |     |      |    |    |      |   |   |     |   |   |   |      |      |   |
| 0      | 0                                  | 0   | 0    | 0  | 0  | 0    | 0 | 0 | 0   | 0 | 0 | 0 | 0    | 0    | 0 |

ADSTAT is a read-only register that contains the sequence complete flag, the conversion counter, and a channel-converted flag for each of the input channels.

### SCF — Sequence Complete Flag

0 = Sequence not complete

1 = Sequence complete

When SCAN = 0, SCF is set at the end of a conversion sequence. When SCAN = 1, SCF is set at the end of the first conversion sequence. SCF is cleared when converter activity is halted or restarted by a write to ADCTL0.

### CCTR[2:0] — Conversion Counter

This field shows the content of the conversion counter pointer during a conversion sequence. The value is the number of the next result register to be written.

### CCF[7:0] — Conversion Complete Flags

Each bit in this field corresponds to an A/D result register. A bit is set when conversion of the corresponding input is complete. It remains set until the result register is read. It is cleared when the register is read.

| MC68HC | C16Z1  |
|--------|--------|
| USER'S | MANUAL |

### **D.2.7 RSLT[0:7]** — ADC Result Registers

### **\$YFF710-\$YFF73E**

Result registers contain conversion results. Data format depends on the address from which it is read. The notation 10 in a diagram indicates that a bit is used only for 10-bit resolution and is cleared during 8-bit conversion. The notation 8/10 indicates a bit is used for both 8-bit and 10-bit resolution. Unused bits return zeros when read.

| C | .2.7.1 | <b>RJURR</b> — Unsigned | Rig | ght-Ju | istifie | d Res | sult R | legiste | ers \$ | YFF  | 710- | \$YFI | F71F |
|---|--------|-------------------------|-----|--------|---------|-------|--------|---------|--------|------|------|-------|------|
|   | 15     |                         | 10  | 9      | 8       | 7     | 6      | 5       | 4      | 3    | 2    | 1     | 0    |
| [ |        | NOT USED                |     | 10     | 10      | 8/10  | 8/10   | 8/10    | 8/10   | 8/10 | 8/10 | 8/10  | 8/10 |
|   |        |                         |     |        |         |       |        |         |        |      |      |       |      |

| ۵ | ).2.7. | 2 LJS | SRR - | — Sig | gned | Left-J | ustifie | ed Re | esult | Regis | sters | <b>\$YFF720-\$YFF72F</b> |
|---|--------|-------|-------|-------|------|--------|---------|-------|-------|-------|-------|--------------------------|
|   | 15     | 14    | 13    | 12    | 11   | 10     | 9       | 8     | 7     | 6     | 5     | 0                        |
|   | 8/10   | 8/10  | 8/10  | 8/10  | 8/10 | 8/10   | 8/10    | 8/10  | 10    | 10    |       | NOT USED                 |

This data format assumes that the zero reference point is  $(V_{BH} - V_{BL}) / 2$ . Bit 15 thus indicates the sign of the result. When bit 15 = 1, the result is positive; when bit 15 = 0, the result is negative. Bits [5:0] return zeros when read.

| C | ).2.7.: | 3 LJL | JRR - | — Un | signe | d Lei | it-Jusi | tified | Resu | lt Re | gisters | \$YFF730-\$YFF73F |
|---|---------|-------|-------|------|-------|-------|---------|--------|------|-------|---------|-------------------|
|   | 15      | 14    | 13    | 12   | 11    | 10    | 9       | 8      | 7    | 6     | 5       | 0                 |
| [ | 8/10    | 8/10  | 8/10  | 8/10 | 8/10  | 8/10  | 8/10    | 8/10   | 10   | 10    |         | NOT USED          |

| Address              | 15 8                       | 7 0                     |
|----------------------|----------------------------|-------------------------|
| \$YFF900             | GPT MODULE CONFI           | GURATION (GPTMCR)       |
| \$YFF902             | (RESERVED                  | ) FOR TEST)             |
| \$YFF904             | INTERRUPT CON              | FIGURATION (ICR)        |
| \$YFFE06             | PGP DATA DIRECTION (DDRGP) | PGP DATA (PORTGP)       |
| \$YFF908             | OC1 ACTION MASK (OC1M)     | OC1 ACTION DATA (OC1D)  |
| \$YFF90A             | TIMER COUI                 | NTER (TCNT)             |
| \$YFF90C             | PA CONTROL (PACTL)         | PA COUNTER (PACNT)      |
| \$YFF90E             | INPUT CAPT                 | URE 1 (TIC1)            |
| \$YFF910             | INPUT CAPT                 | URE 2 (TIC2)            |
| \$YFF912             | INPUT CAPT                 | URE 3 (TIC3)            |
| \$YFF914             | OUTPUT COM                 | PARE 1 (TOC1)           |
| \$YFF916             | OUTPUT COM                 | PARE 2 (TOC2)           |
| \$YFF918             | OUTPUT COM                 | PARE 3 (TOC3)           |
| \$YFF91A             | OUTPUT COM                 | PARE 4 (TOC4)           |
| \$YFF91C             | INPUT CAPTURE 4/OUTF       | PUT COMPARE 5 (TI4/O5)  |
| \$YFF91E             | TIMER CONTROL 1 (TCTL1)    | TIMER CONTROL 2 (TCTL2) |
| \$YFF920             | TIMER MASK 1 (TMSK1)       | TIMER MASK 2 (TMSK2)    |
| \$YFF922             | TIMER FLAG 1 (TFLG1)       | TIMER FLAG 2 (TFLG2)    |
| \$YFF924             | FORCE COMPARE (CFORC)      | PWM CONTROL C (PWMC)    |
| \$YFF926             | PWM CONTROL A (PWMA)       | PWM CONTROL B (PWMB)    |
| \$YFF928             | PWM COUN                   | T (PWMCNT)              |
| \$YFF92A             | PWMA BUFFER (PWMBUFA)      | PWMB BUFFER (PWMBUFB)   |
| \$YFF92C             | GPT PRESCA                 | LER (PRESCL)            |
| \$YFF92E<br>\$YFF93F | RESE                       | RVED                    |

Table D-3. GPT Address Map

| I | D.3.1 ( | GPTM | CR — | GPT   | Modul | e Co | onfig | urat | ion Re | giste | эr |   |       |       | \$YFF | -900  |
|---|---------|------|------|-------|-------|------|-------|------|--------|-------|----|---|-------|-------|-------|-------|
|   | 15      | 14   | 13   | 12    | 11    | 10   | 9     | 8    | 7      | 6     | 5  | 4 | 3     | 2     | 1     | 0     |
|   | STOP    | FRZ1 | FRZ0 | STOPP | INCP  | 0    | 0     | 0    | SUPV   | 0     | 0  | 0 | IARB3 | IARB2 | IARB1 | IARB0 |
|   | RESET:  |      |      |       |       |      |       |      |        |       |    |   |       |       |       |       |
|   | 0       | 0    | 0    | 0     | 0     | 0    | 0     | 0    | 1      | 0     | 0  | 0 | 0     | 0     | 0     | 0     |

GPTMCR bits control freeze, low-power stop, and single-step modes.

STOP - Stop Clocks

0 = Internal clocks not shut down

1 = Internal clocks shut down

### FRZ[1:0] — FREEZE Response

- FRZ1 is not used; FRZ0 encoding determines response to the IMB FREEZE signal.
  - 0 = Ignore IMB FREEZE signal
  - 1 = FREEZE the current state of the GPT
- STOPP Stop Prescaler
  - 0 = Normal operation
  - 1 = Stop prescaler and pulse accumulator from incrementing. Ignore changes to input pins.
- INCP Increment Prescaler
  - 0 = Has no meaning
  - 1 = If STOPP is asserted, increment prescaler once and clock input synchronizers once.
- SUPV Supervisor/Unrestricted Data Space

Because the CPU16 in the MC68HC16Z1 operates in supervisor mode only, this bit has no effect.

### IARB[3:0] — Interrupt Arbitration

Each module that generates interrupts must have an IARB value. IARB values are used to arbitrate between interrupt requests of the same priority.

### **D.3.2 GPTMTR** — GPT Module Test Register (Reserved)

**\$YFF902** 

This address is currently unused and returns zeros when read. It is reserved for GPT factory test.

| D.3.3  | ICR — | - GPT | Intern | rupt C | onfigu | ration | Regis | ter |     |    |   |   | \$ | SYF | F904 |
|--------|-------|-------|--------|--------|--------|--------|-------|-----|-----|----|---|---|----|-----|------|
| 15     | 14    | 13    | 12     | 11     | 10     | 9      | 8     | 7   | 6   | 5  | 4 | 3 | 2  | 1   | 0    |
|        | IF    | PA A  |        | 0      |        | IRL    |       |     | IVI | BA |   | 0 | 0  | 0   | 0    |
| RESET: | 0     | ^     | ^      |        | ^      | ^      | •     | 0   | 0   | •  | • | 0 | •  |     |      |

ICR fields determine internal and external interrupt priority, and provide the upper nibble of the interrupt vector number supplied to the CPU when an interrupt is acknowledged.

IPA — Interrupt Priority Adjust

Specifies which of the 11 internal GPT interrupt sources is assigned highest priority.

IPL — Interrupt Priority Level

Specifies the priority level of GPT interrupt requests.

IVBA — Interrupt Vector Base Address

Contains the most significant nibble of interrupt vector numbers supplied by the GPT.

| D.3.4       | DDF | RGP - | — Po         | rt GP | Data  | Dire  | ction  | Regis | ter |   |     |     |   | \$YF | F906 |
|-------------|-----|-------|--------------|-------|-------|-------|--------|-------|-----|---|-----|-----|---|------|------|
|             | POI | RTGF  | <b>)</b> — P | ort G | P Dat | a Reg | gister |       |     |   |     |     |   | \$YF | F907 |
| 15          |     |       |              |       |       |       | 8      | 7     |     |   |     |     |   |      | 0    |
|             |     |       | DD           | RGP   |       |       |        |       |     |   | POR | TGP |   |      |      |
| RESET:<br>0 | 0   | 0     | 0            | 0     | 0     | 0     | 0      | 0     | 0   | 0 | 0   | 0   | 0 | 0    | 0    |

When GPT pins are used as an 8-bit port, DDRGP determines whether pins are input or output and PORTGP holds the 8-bit data.

DDRGP[7:0] — Parallel Data Direction Register

0 = Input only

1 = Output

PORTGP[7:0] — Parallel Data Register

| D.3.5      | OC1 | м — (        | DC1 | Actio | n Ma  | sk Re | egiste | r |   |      |   |   |   | \$YF | F908 |
|------------|-----|--------------|-----|-------|-------|-------|--------|---|---|------|---|---|---|------|------|
|            | OC1 | <b>D</b> — ( | DC1 | Actio | n Dat | a Reg | gister |   |   |      |   |   |   | \$YF | F909 |
| 15         | 14  | 13           | 12  | 11    | 10    | 9     | 8      | 7 | 6 | 5    | 4 | з | 2 | 1    | 0    |
|            |     | 0C1M         |     |       | 0     | 0     | 0      |   |   | 0C1D |   |   | 0 | 0    | 0    |
| RESET<br>0 | 0   | 0            | 0   | 0     | 0     | 0     | 0      | 0 | 0 | 0    | 0 | 0 | 0 | 0    | 0    |

All OC outputs can be controlled by the action of OC1. OC1M contains a mask that determines which pins are affected, and OC1D determines what the outputs are.

### OC1M[5:1] - OC1 Mask

0 = Corresponding output compare pin is not affected by OC1 compare.

1 = Corresponding output compare pin is affected by OC1 compare.

OC1M[5:1] correspond to OC[5:1].

### OC1D[5:1] - OC1 Data

0 = If OC1 mask bit is set, clear corresponding output compare pin on OC1 match.

1 = If OC1 mask bit is set, set corresponding output compare pin on OC1 match. OC1D[5:1] correspond to OC[5:1].

D.3.6 TCNT — Timer Counter Register

# TCNT is the 16-bit free-running counter associated with the input capture, output compare, and pulse accumulator functions of the GPT module.

\$YFF90A

| D.3.7  | PACT | "L F  | Pulse | Accur  | nulato  | r Cont | rol Reg | giste | r |        |       |       | \$`    | YFF | 90C |
|--------|------|-------|-------|--------|---------|--------|---------|-------|---|--------|-------|-------|--------|-----|-----|
|        | PAC  | NT —  | Pulse | e Accu | umulate | or Cou | unter   |       |   |        |       |       | \$`    | YFF | 90D |
| 15     | 14   | 13    | 12    | 11     | 10      | 9      | 8       | 7     | 6 | 5      | 4     | 3     | 2      | 1   | 0   |
| PAIS   | PAEN | PAMOD | PEDGE | PCLKS  | 14/05   | PA     | CLK     |       | P | ULSE A | CCUMU | LATOR | COUNTE | R   |     |
| RESET: |      |       |       |        |         |        |         |       |   |        |       |       |        |     |     |
| U      | 0    | 0     | 0     | U      | 0       | 0      | 0       | 0     | 0 | 0      | 0     | 0     | 0      | 0   | 0   |

PACTL enables the pulse accumulator and selects either event counting or gated mode. In event counting mode, PACNT is incremented each time an event occurs. In gated mode, it is incremented by an internal clock.

PAIS - PAI Pin State (Read Only)

- PAEN Pulse Accumulator Enable
  - 0 = Pulse accumulator disabled
  - 1 = Pulse accumulator enabled

PAMOD — Pulse Accumulator Mode

- 0 = External event counting
- 1 = Gated time accumulation
- PEDGE Pulse Accumulator Edge Control

The effects of PEDGE and PAMOD are shown in the following table.

| PAMOD | PEDGE | Effect                              |
|-------|-------|-------------------------------------|
| 0     | 0     | PAI Falling Edge Increments Counter |
| 0     | 1     | PAI Rising Edge Increments Counter  |
| 1     | 0     | Zero on PAI Inhibits Counting       |
| 1     | 1     | One on PAI Inhibits Counting        |

- PCLKS PCLK Pin State (Read Only)
- 14/O5 Input Capture 4/Output Compare 5
  - 0 = Output compare 5 enabled
  - 1 = Input capture 4 enabled
- PACLK[1:0] Pulse Accumulator Clock Select (Gated Mode)

| PACLK[1:0] | Puise Accumulator Clock Selected  |
|------------|-----------------------------------|
| 00         | System Clock Divided by 512       |
| 01         | Same Clock Used to Increment TCNT |
| 10         | TOF Flag from TCNT                |
| 11         | External Clock, PCLK              |

PACNT — Pulse Accumulator Counter

Eight-bit read/write counter used for external event counting or gated time accumulation.

MOTOROLA D–14 APPENDIX D Register Summary MC68HC16Z1 USER'S MANUAL

# D.3.8 TIC[1:3] — Input Capture Registers 1-3

The input capture registers are 16-bit read-only registers which are used to latch the value of TCNT when a specified transition is detected on the corresponding input capture pin. They are reset to \$FFFF.

### **D.3.9 TOC[1:4]** — Output Compare Registers 1–4 \$YFF914-\$YFF91A

The output compare registers are 16-bit read/write registers which can be used as output waveform controls or as elapsed time indicators. For output compare functions, they are written to a desired match value and compared against TCNT to control specified pin actions. They are reset to \$FFFF.

### **D.3.10 TI4/O5** — Input Capture 4/Output Compare 5 Register \$YFF91C

This register serves either as input capture register 4 or output compare register 5, depending on the state of I4/O5 in PACTL.

| D.3.1  | 1 TC | :TL1/ | TCTL | .2 — | Time | r Cor | ntrol F | Regist | ers 1 | and | 2   |    |     | \$YF | F91E |
|--------|------|-------|------|------|------|-------|---------|--------|-------|-----|-----|----|-----|------|------|
| 15     | 14   | 13    | 12   | 11   | 10   | 9     | 8       | 7      | 6     | 5   | 4   | 3  | 2   | 1    | 0    |
| OM5    | OL5  | OM4   | OL4  | OMB  | OL3  | OM2   | OL2     | ED     | GE4   | ED  | GE3 | ED | GE2 | ED   | GE1  |
| RESET: |      |       |      |      |      |       |         |        |       |     |     |    |     |      |      |
| 0      | 0    | 0     | 0    | 0    | 0    | 0     | 0       | 0      | 0     | 0   | 0   | 0  | 0   | 0    | 0    |

TCTL1 determines output compare mode and output logic level. TCTL2 determines the type of input capture to be performed.

OM/OL[5:2] — Output Compare Mode Bits and Output Compare Level Bits Each pair of bits specifies an action to be taken when output comparison is successful.

| OM/OL[5:2] | Action Taken                         |
|------------|--------------------------------------|
| 00         | Timer Disconnected from Output Logic |
| 01         | Toggle OCx Output Line               |
| 10         | Clear OCx Output Line to 0           |
| 11         | Set OCx Output Line to 1             |

EDGE[4:1] — Input Capture Edge Control

Each pair of bits configures input sensing logic for the corresponding input capture.

| EDGE[4:1] | Configuration                           |
|-----------|-----------------------------------------|
| 00        | Capture Disabled                        |
| 01        | Capture on Rising Edge Only             |
| 10        | Capture on Falling Edge Only            |
| 11        | Capture on Any (Rising or Falling) Edge |

**\$YFF90E-\$YFF912** 

| D.3.12      | 2 TM     | ISK1/T             | MSł    | <2 —    | Tim    | er Int | errupt  | Mas     | k F  | legist | ers 1  | and 2    |        | \$YFI | F920  |
|-------------|----------|--------------------|--------|---------|--------|--------|---------|---------|------|--------|--------|----------|--------|-------|-------|
| 15          | 14       |                    |        | 11      | 10     |        | 8       | 7       | 6    | 5      | 4      | 3        | 2      |       | 0     |
| 4/051       |          | OCI                |        |         |        | ICI    |         | TOI     | 0    | PAOV   | I PAII | CPROUT   |        | CPR   |       |
| RESET:<br>0 | 0        | 0                  | 0      | 0       | 0      | 0      | 0       | 0       | 0    | 0      | 0      | 0        | 0      | 0     | 0     |
|             |          | SK1 er<br>rrupts a |        |         |        |        |         | upts.   | Т    | MSK2   | con    | trols pu | ilse a | accum | ulato |
| 14/051      | i — Ir   | nput Ca            | aptui  | re 4/C  | Outpu  | t Com  | npare   | 5 Inte  | erru | pt En  | able   |          |        |       |       |
|             |          | IC4/00             | •      |         |        |        | •       |         |      |        |        |          |        |       |       |
|             | 1 =      |                    | C5 in  | terrup  | ot req | ueste  | d whe   | en 14/  | O5F  | flag   | in TF  | LG1 is s | et     |       |       |
|             | :11      | - Outpu            | it Co  | mnai    | e Inte | ernuot | Fnat    | le      |      |        |        |          |        |       |       |
|             |          | OC inte            |        |         |        |        |         |         |      |        |        |          |        |       |       |
|             | 1 =      | OC inte            | errup  | ot req  | ueste  | d who  | en OC   | ; flag  | set  |        |        |          |        |       |       |
| 00          | CI[4:1   | ] corre            | spor   | nd to   | OC[4   | :1].   |         |         |      |        |        |          |        |       |       |
|             | 11       | Input C            | Capti  | ure In  | terru  | ot Ena | able    |         |      |        |        |          |        |       |       |
|             |          | IC inte            |        |         |        |        |         |         |      |        |        |          |        |       |       |
|             |          | IC inte            | •      | •       |        |        | n IC fl | ag se   | ət   |        |        |          |        |       |       |
| IC          | l[3:1]   | corres             | pono   | d to IC | 2[3:1] | •      |         |         |      |        |        |          |        |       |       |
| TOI         | – Tim    | er Ove             | orflov | v Inte  | rrupt  | Enab   | le      |         |      |        |        |          |        |       |       |
|             |          | Timer              |        |         |        |        |         | k       |      |        |        |          |        |       |       |
|             | 1 =      | Interru            | pt re  | quest   | ed w   | hen T  | OF fla  | ag is : | set  |        |        |          |        |       |       |
|             | <u> </u> | Pulse A            | Accu   | mulat   | or O   | verflo | w Inte  | rrupt   | Ena  | able   |        |          |        |       |       |
|             |          | Pulse              |        |         |        |        |         | •       |      |        |        |          |        |       |       |
|             | 1 =      | Interru            | pt re  | quest   | ed w   | hen P  | AOV     | flag    | is s | et     |        |          |        |       |       |
| PAII        | _ Pul    | lse Acc            | m      | lator   | Innut  | Intor  | runt F  | nahl    | 2    |        |        |          |        |       |       |
|             |          | Pulse a            |        |         | •      |        | •       |         | •    |        |        |          |        |       |       |
|             |          | Interru            |        |         |        |        |         |         | set  |        |        |          |        |       |       |
|             | דוור     | C                  |        | /Car    | tura   | Init C |         | າມະຈະ   | .+ ⊏ | nahla  |        |          |        |       |       |
| ULUC        |          | – Corr<br>Norma    | •      | •       |        |        |         | Juipi   | πE   | nable  |        |          |        |       |       |
|             |          | TCNT               |        |         |        |        |         |         |      |        |        |          |        |       |       |
|             |          |                    |        |         |        |        | •       |         |      |        |        |          |        |       |       |

### CPR[2:0] — Timer Prescaler/PCLK Select Field

This field selects one of seven prescaler taps or PCLK to be TCNT input.

| CPR[2:0] | System Clock<br>Divide-by Factor |
|----------|----------------------------------|
| 000      | 4                                |
| 001      | 8                                |
| 010      | 16                               |
| 011      | 32                               |
| 100      | 64                               |
| 101      | 128                              |
| 110      | 256                              |
| 111      | PCLK                             |

| D.3.13 | TFLG1/TFLG2 — Timer Interrupt Flag Registers 1 and 2 |    |         |    |    |     |   |     |   |       |      |   |   |   | <b>\$YFF922</b> |  |  |
|--------|------------------------------------------------------|----|---------|----|----|-----|---|-----|---|-------|------|---|---|---|-----------------|--|--|
| 15     | 14                                                   |    |         | 11 | 10 |     | 8 | 7   | 6 | 5     | 4    | 3 | 2 | 1 | 0               |  |  |
| 14/05F |                                                      | 00 | <u></u> |    |    | ICF |   | TOF | 0 | PAOVF | PAIF | 0 | 0 | 0 | 0               |  |  |
| RESET: |                                                      |    |         |    |    |     |   |     |   |       |      |   |   |   |                 |  |  |
| 0      | 0                                                    | 0  | 0       | 0  | 0  | 0   | 0 | 0   | 0 | 0     | 0    | 0 | 0 | 0 | 0               |  |  |

These registers show condition flags that correspond to various GPT events. If the corresponding interrupt enable bit in TMSK1/TMSK2 is set, an interrupt will occur.

14/O5F — Input Capture 4/Output Compare 5 Flag

When I4/O5 in PACTL is zero, this flag is set each time TCNT matches the value in TOC5. When I4/O5 in PACTL is one, the flag is set each time a selected edge is detected at the I4/O5 pin.

OCF[4:1] — Output Compare Flags

An output compare flag is set each time TCNT matches the corresponding TOC register. OCF[4:1] correspond to OC[4:1].

ICF[3:1] — Input Capture Flags

A flag is set each time a selected edge is detected at the corresponding input capture pin. ICF[3:1] correspond to IC[3:1].

TOF — Timer Overflow Flag

This flag is set each time TCNT advances from a value of \$FFFF to \$0000.

PAOVF — Pulse Accumulator Overflow Flag

This flag is set each time the pulse accumulator counter advances from a value of \$FF to \$00.

PAIF — Pulse Accumulator Flag

In event counting mode, this flag is set when an active edge is detected on the PAI pin. In gated time accumulation mode, it is set at the end of the timed period.

MC68HC16Z1 USER'S MANUAL

| D.3.14 | .3.14 CFORC — Compare Force Register |     |   |    |    |       |       |        |   |     |   |     |     |     | <b>\$YFF</b> 924 |  |  |
|--------|--------------------------------------|-----|---|----|----|-------|-------|--------|---|-----|---|-----|-----|-----|------------------|--|--|
|        | P                                    | WMC |   |    | \$ | YFF   | 925   |        |   |     |   |     |     |     |                  |  |  |
| 15     |                                      |     |   | 11 | 10 | 9     | 8     | 7      | 6 |     | 4 | 3   | 2   | 1   | 0                |  |  |
|        |                                      | FOC |   |    | 0  | FPWMA | FPWMB | PPROUT |   | PPR |   | SFA | SFB | F1A | F1B              |  |  |
| RESET: | 0                                    | 0   | 0 | 0  | 0  | 0     | 0     | 0      | 0 | 0   | 0 | 0   | 0   | 0   | 0                |  |  |

Setting a bit in CFORC will cause a specific output on OC or PWM pins. PWMC sets PWM operating conditions.

FOC[5:1] — Force Output Compare

0 = Has no meaning

1 = Causes pin action programmed for corresponding OC pin, but the OC flag is not set.

FOC[5:1] correspond to OC[5:1].

- FPWMA Force PWMA Value
  - 0 = Normal PWMA operation
  - 1 = The value of F1A is driven out on the PWMA pin, regardless of the state of PPROUT.

FPWMB — Force PWMB Value

- 0 = Normal PWMB operation
- 1 = The value of F1B is driven out on the PWMB pin.

PPROUT — PWM Clock Output Enable

- 0 = Normal PWM operation on PMWA
- 1 = TCNT clock driven out PWMA pin.

PPR[2:0] — PWM Prescaler/PCLK Select

This field selects one of seven prescaler taps or PCLK to be PWMCNT input.

| PPR[2:0] | System Clock<br>Divide-by Factor |
|----------|----------------------------------|
| 000      | 2                                |
| 001      | 4                                |
| 010      | 8                                |
| 011      | 16                               |
| 100      | 32                               |
| 101      | 64                               |
| 110      | 128                              |
| 111      | PCLK                             |

SFA --- PWMA Slow/Fast Select

0 = PWMA period is 256 PWMCNT increments long.

1 = PWMA period is 32768 PWMCNT increments long.

SFB — PWMB Slow/Fast Select

0 = PWMB period is 256 PWMCNT increments long.

1 = PWMB period is 32768 PWMCNT increments long.

The following table shows the effects of SF settings on PWM frequency (16.78-MHz system clock).

| PPR[2:0] | Prescaler Tap     | SFA/B = 0 | SFA/B = 1  |
|----------|-------------------|-----------|------------|
| 000      | Div 2 = 8.39 MHz  | 32.8 kHz  | 256 Hz     |
| 001      | Div 4 = 4.19 MHz  | 16.4 kHz  | 128 Hz     |
| 010      | Div 8 = 2.10 MHz  | 8.19 kHz  | 64.0 Hz    |
| 011      | Div 16 = 1.05 MHz | 4.09 kHz  | 32.0 Hz    |
| 100      | Div 32 = 524 kHz  | 2.05 kHz  | 16.0 Hz    |
| 101      | Div 64 = 262 kHz  | 1.02 kHz  | 8.0 Hz     |
| 110      | Div 128 = 131 kHz | 512 Hz    | 4.0 Hz     |
| 111      | PCLK              | PCLK/256  | PCLK/32768 |

### F1A — Force Logic Level One on PWMA

0 = Force logic level zero output on PWMA pin.

1 = Force logic level one output on PWMA pin.

### F1B — Force Logic Level One on PWMB

0 = Force logic level zero output on PWMB pin.

1 = Force logic level one output on PWMB pin.

### D.3.15 PWMA/PWMB — PWM Registers A/B

# The value in these registers determines pulse-width of the corresponding PWM output. A value of \$00 corresponds to continuously low output; a value of \$80 to 50% duty cycle. Maximum value (\$FF) selects an output which is high for 255/256 of the period. Writes to these registers are buffered by PWMBUFA and PWMBUFB.

### D.3.16 PWMCNT — PWM Count Register

### PWMCNT is the 16-bit free-running counter used for GPT PWM functions.

### D.3.17 PWMBUFA — PWM Buffer Register A

### **PWMBUFB** — PWM Buffer Register B

In order to prevent glitches when PWM duty cycle is changed, the contents of PWMA and PWMB are transferred to these read-only registers at the end of each duty cycle. Reset state is \$0000.

### D.3.18 PRESCL — GPT Prescaler

The 9-bit prescaler value can be read from bits [8:0] at this address. Bits [15:9] always read as zeros. Reset state is \$0000.

### **\$YFF926, \$YFF927**

# **\$**YFF928

### \$YFF92A \$YFF92B

## \$YFF92C

D

| Address       | 15 8                                | 7 0                                  |  |  |  |  |  |  |  |
|---------------|-------------------------------------|--------------------------------------|--|--|--|--|--|--|--|
| YFFA00        | MODULE CONFIG                       | URATION (SIMCR)                      |  |  |  |  |  |  |  |
| YFFA02        | FACTORY T                           | EST (SIMTR)                          |  |  |  |  |  |  |  |
| YFFA04        | CLOCK SYNTHESIZE                    | R CONTROL (SYNCR)                    |  |  |  |  |  |  |  |
| YFFA06        | NOT USED                            | RESET STATUS (RSR)                   |  |  |  |  |  |  |  |
| YFFA08        | MODULE TES                          | ST E (SIMTRE)                        |  |  |  |  |  |  |  |
| YFFA0A        | NOT USED                            | NOT USED                             |  |  |  |  |  |  |  |
| YFFA0C        | NOT USED                            | NOT USED                             |  |  |  |  |  |  |  |
| YFFA0E        | NOT USED                            | NOT USED                             |  |  |  |  |  |  |  |
| YFFA10        | NOT USED                            | PORTE DATA (PORTE0)                  |  |  |  |  |  |  |  |
| YFFA12        | NOT USED PORTE DATA (PORTE)         |                                      |  |  |  |  |  |  |  |
| YFFA14        | NOT USED PORTE DATA DIRECTION (DDRE |                                      |  |  |  |  |  |  |  |
| YFFA16        | NOT USED                            | PORTE PIN ASSIGNMENT (PEPAR)         |  |  |  |  |  |  |  |
| YFFA18        | NOT USED                            | PORTF DATA (PORTF0)                  |  |  |  |  |  |  |  |
| YFFA1A        | NOT USED                            | PORTF DATA (PORTF1)                  |  |  |  |  |  |  |  |
| YFFA1C        | NOT USED                            | PORTF DATA DIRECTION (DDRF)          |  |  |  |  |  |  |  |
| YFFA1E        | NOT USED PORTF PIN ASSIGNMENT (PFP/ |                                      |  |  |  |  |  |  |  |
| YFFA20        | NOT USED                            | SYSTEM PROTECTION CONTROL<br>(SYPCR) |  |  |  |  |  |  |  |
| YFFA22        | PERIODIC INTERRU                    | PT CONTROL (PICR)                    |  |  |  |  |  |  |  |
| YFFA24        | PERIODIC INTERR                     | UPT TIMING (PITR)                    |  |  |  |  |  |  |  |
| YFFA26        | NOT USED                            | SOFTWARE SERVICE (SWSR)              |  |  |  |  |  |  |  |
| YFFA28        | NOT USED                            | NOT USED                             |  |  |  |  |  |  |  |
| YFFA2A        | NOT USED                            | NOT USED                             |  |  |  |  |  |  |  |
| YFFA2C        | NOT USED                            | NOT USED                             |  |  |  |  |  |  |  |
| YFFA2E        | NOT USED                            | NOT USED                             |  |  |  |  |  |  |  |
| YFFA30        | TEST MODULE MASTE                   | ER SHIFT A (TSTMSRA)                 |  |  |  |  |  |  |  |
| YFFA32        | TEST MODULE MASTE                   | ER SHIFT B (TSTMSRB)                 |  |  |  |  |  |  |  |
| YFFA34        | TEST MODULE SH                      | FT COUNT (TSTSC)                     |  |  |  |  |  |  |  |
| YFFA36        | TEST MODULE REPETIT                 | TION COUNTER (TSTRC)                 |  |  |  |  |  |  |  |
| YFFA38        | TEST MODULE C                       | XONTROL (CREG)                       |  |  |  |  |  |  |  |
| <b>YFFA3A</b> | TEST MODULE DISTRIBUTED (DREG)      |                                      |  |  |  |  |  |  |  |
| YFFA3C        | NOT USED                            | NOT USED                             |  |  |  |  |  |  |  |
| YFFA3E        | NOT USED                            | NOT USED                             |  |  |  |  |  |  |  |
| YFFA40        | NOT USED                            | PORT C DATA (PORTC)                  |  |  |  |  |  |  |  |
| YFFA42        | NOT USED NOT USED                   |                                      |  |  |  |  |  |  |  |

Table D-4. SIM Address Map

|      | Table | D-4. | SIM    | Address      | Мар   | (Continued)  |  |
|------|-------|------|--------|--------------|-------|--------------|--|
| ress | 15    |      |        | 8            | 7     |              |  |
| A44  |       |      | CHIP-S | ELECT PIN AS | SIGNM | ENT (CSPAR0) |  |
|      |       |      |        |              |       |              |  |

| Table | D-4. | SIM | Address | Мар | (Continued) |
|-------|------|-----|---------|-----|-------------|
|-------|------|-----|---------|-----|-------------|

| Address | 15 8                         | 7 0               |  |  |  |  |  |  |  |
|---------|------------------------------|-------------------|--|--|--|--|--|--|--|
| YFFA44  | CHIP-SELECT PIN AS           | SIGNMENT (CSPAR0) |  |  |  |  |  |  |  |
| YFFA46  | CHIP-SELECT PIN AS           | SIGNMENT (CSPAR1) |  |  |  |  |  |  |  |
| YFFA48  | CHIP-SELECT BAS              | E BOOT (CSBARBT)  |  |  |  |  |  |  |  |
| YFFA4A  | CHIP-SELECT OPTI             | ON BOOT (CSORBT)  |  |  |  |  |  |  |  |
| YFFA4C  | CHIP-SELECT B                | ASE 0 (CSBAR0)    |  |  |  |  |  |  |  |
| YFFA4E  | CHIP-SELECT OPTION 0 (CSOR0) |                   |  |  |  |  |  |  |  |
| YFFA50  | CHIP-SELECT BASE 1 (CSBAR1)  |                   |  |  |  |  |  |  |  |
| YFFA52  | CHIP-SELECT O                | PTION 1 (CSOR1)   |  |  |  |  |  |  |  |
| YFFA54  | CHIP-SELECT B                | ASE 2 (CSBAR2)    |  |  |  |  |  |  |  |
| YFFA56  | CHIP-SELECT O                | PTION 2 (CSOR2)   |  |  |  |  |  |  |  |
| YFFA58  | CHIP-SELECT B                | ASE 3 (CSBAR3)    |  |  |  |  |  |  |  |
| YFFA5A  | CHIP-SELECT O                | PTION 3 (CSOR3)   |  |  |  |  |  |  |  |
| YFFA5C  | CHIP-SELECT B                | ASE 4 (CSBAR4)    |  |  |  |  |  |  |  |
| YFFA5E  | CHIP-SELECT O                | PTION 4 (CSOR4)   |  |  |  |  |  |  |  |
| YFFA60  | CHIP-SELECT B                | ASE 5 (CSBAR5)    |  |  |  |  |  |  |  |
| YFFA62  | CHIP-SELECT O                | PTION 5 (CSOR5)   |  |  |  |  |  |  |  |
| YFFA64  | CHIP-SELECT B                | ASE 6 (CSBAR6)    |  |  |  |  |  |  |  |
| YFFA66  | CHIP-SELECT O                | PTION 6 (CSOR6)   |  |  |  |  |  |  |  |
| YFFA68  | CHIP-SELECT B                | ASE 7 (CSBAR7)    |  |  |  |  |  |  |  |
| YFFA6A  | CHIP-SELECT O                | PTION 7 (CSOR7)   |  |  |  |  |  |  |  |
| YFFA6C  | CHIP-SELECT B                | ASE 8 (CSBAR8)    |  |  |  |  |  |  |  |
| YFFA6E  | CHIP-SELECT OI               | PTION 8 (CSOR8)   |  |  |  |  |  |  |  |
| YFFA70  | CHIP-SELECT B                | ASE 9 (CSBAR9)    |  |  |  |  |  |  |  |
| YFFA72  | CHIP-SELECT OI               | PTION 9 (CSOR9)   |  |  |  |  |  |  |  |
| YFFA74  | CHIP-SELECT BA               | SE 10 (CSBAR10)   |  |  |  |  |  |  |  |
| YFFA76  |                              | TION 10 (CSOR10)  |  |  |  |  |  |  |  |
| YFFA78  | NOT USED NOT USED            |                   |  |  |  |  |  |  |  |
| YFFA7A  | NOT USED NOT USED            |                   |  |  |  |  |  |  |  |
| YFFA7C  | NOT USED                     | NOT USED          |  |  |  |  |  |  |  |
| YFFA7E  | NOT USED                     | NOT USED          |  |  |  |  |  |  |  |

| D.4.1  | D.4.1 SIMCR — Module Configuration Register |       |    |            |    |    |    |      |   |   |   |   |     |    |   |
|--------|---------------------------------------------|-------|----|------------|----|----|----|------|---|---|---|---|-----|----|---|
| 15     | 14                                          | 13    | 12 | 11         | 10 | 9  | 8  | 7    | 6 | 5 | 4 | 3 |     |    | 0 |
| EXOFF  | FRZSW                                       | FRZBM | 0  | SLVEN      | 0  | SH | EN | SUPV | M | 0 | 0 |   | IAF | RB |   |
| RESET: |                                             |       |    |            |    |    |    |      |   |   |   |   |     |    |   |
| 0      | 0                                           | 0     | 0  | DATA<br>11 | 0  | 0  | 0  | 1    | 1 | 0 | 0 | 1 | 1   | 1  | 1 |

SIMCR controls system configuration. Can be read or written at any time, except for the module mapping (MM) bit, which can be written once, and must remain set.

- EXOFF External Clock Off
  - 0 = The CLKOUT pin is driven from an internal clock source.
  - 1 = The CLKOUT pin is placed in a high-impedance state.
- FRZSW Freeze Software Enable
  - 0 = When FREEZE is asserted, the software watchdog and periodic interrupt timer counters continue to run.
  - 1 = When FREEZE is asserted, the software watchdog and periodic interrupt timer counters are disabled, preventing interrupts during software debug.
- FRZBM Freeze Bus Monitor Enable
  - 0 = When FREEZE is asserted, the bus monitor continues to operate.
  - 1 = When FREEZE is asserted, the bus monitor is disabled.

### SLVEN — Factory Test Mode Enabled

0 = IMB is not available to an external master.

1 = An external bus master has direct access to the IMB.

### SHEN[1:0] — Show Cycle Enable

This field determines what the EBI does with the external bus during internal transfer operations.

### SUPV — Supervisor/User Data Space

The MC68HC16Z1 operates only in supervisory mode — SUPV has no effect.

MM — Module Mapping

Because ADDR[23:20] follow the state of ADDR19 in the CPU16, MM must remain set.

- 0 = Internal modules are addressed from \$7FF000 \$7FFFFF.
- 1 = Internal modules are addressed from \$FFF000 \$FFFFFF.

### IARB[3:0] — Interrupt Arbitration Field

Determines SIM interrupt arbitration priority. The reset value is \$F (highest priority), to prevent SIM interrupts from being discarded during initialization.



### D.4.2 SIMTR — System Integration Test Register

SIMTR is used for factory test only.

| D.4.3  | SYN | CR – | - Clo | r  |    |   |   | \$YF | FA04 |   |       |       |       |       |       |
|--------|-----|------|-------|----|----|---|---|------|------|---|-------|-------|-------|-------|-------|
| 15     | 14  | 13   | 12    | 11 | 10 | 9 | 8 | 7    | 6    | 5 | 4     | 3     | 2     | 1     | 0     |
| W      | Х   |      |       |    | Y  |   |   | EDIV | 0    | 0 | SLIMP | SLOCK | RSTEN | STSIM | STEXT |
| RESET: |     |      |       |    |    |   |   |      |      |   |       |       |       |       |       |
| 0      | 0   | 1    | 1     | 1  | 1  | 1 | 1 | 0    | 0    | 0 | U     | U     | 0     | 0     | 0     |

SYNCR determines system clock operating frequency and mode of operation. Clock frequency is determined by SYNCR bit settings as follows:

 $F_{SYSTEM} = F_{REFERENCE} [4(Y + 1)(2^{2W + X})]$ 

W — Frequency Control (VCO)

0 = Base VCO frequency.

1 = VCO frequency multiplied by four.

X — Frequency Control Bit (Prescale)

0 = Base system clock frequency

1 = System clock frequency multiplied by two.

Y[5:0] — Frequency Control (Counter)

The Y field is the initial value for the modulus 64 down counter in the synthesizer feedback loop. Values range from 0 to 63.

### EDIV — ECLK Divide Rate

0 = ECLK is system clock divided by 8.

1 = ECLK is system clock divided by 16.

### SLIMP — Limp Mode

0 = External crystal is VCO reference.

1 = Loss of crystal reference.

### SLOCK — Synthesizer Lock

0 = VCO is enabled, but has not locked.

1 = VCO has locked on the desired frequency or system clock is external.

### RSTEN — Reset Enable

0 = Loss of reference causes the MCU to operate in limp mode.

1 = Loss of reference causes system reset.

### STSIM — Stop Mode System Integration Clock

0 = SIM clock driven by an external source and VCO off during low-power stop.

1 = SIM clock driven by VCO during low-power stop.

STEXT — Stop Mode External Clock

- 0 = CLKOUT held low during low-power stop.
- 1 = CLKOUT driven from SIM clock during low-power stop.

| D.4.4 | 4 RSI | <b>२</b> — । | Reset | State | us Re | giste | r |     |     |    |     |   |     | \$YF | FA07 |  |
|-------|-------|--------------|-------|-------|-------|-------|---|-----|-----|----|-----|---|-----|------|------|--|
| 15    | 14    | 13           | 12    | 11    | 10    | 9     | 8 | 7   | 6   | 5  | 4   | 3 | 2   | 1    | 0    |  |
|       |       |              | NOT   | USED  |       |       |   | EXT | POW | SW | HLT | 0 | LOC | SYS  | TST  |  |

RSR contains a status bit for each reset source in the MCU. RSR is updated when the MCU comes out of reset. A set bit indicates what type of reset occurred. If multiple sources assert reset signals at the same time, more than one bit in RSR may be set. This register can be read at any time; a write has no effect.

### EXT — External Reset

Reset caused by an external signal.

POW — Power-Up Reset

Reset caused by the power-up reset circuit.

- SW Software Watchdog Reset Reset caused by the software watchdog circuit.
- HLT Halt Monitor Reset Reset caused by the halt monitor.

### LOC — Loss of Clock Reset

Reset caused by loss of clock frequency reference.

### SYS — System Reset

Reset caused by a CPU RESET instruction. Not used by MC68HC16Z1. The CPU16 has no reset instruction.

### TST — Test Submodule Reset

Reset caused by the test submodule. Used during system test only.

D.4.5 SIMTRE — System Integration Test Register (ECLK) \$YFFA08 Register is used for factory test only.

| D.4.0 | 6 PO | RTEC | POR | TE1  | — P | ort E | Data | Regi | ster |     | :   | \$YFF | A11, | \$YF | FA13 |
|-------|------|------|-----|------|-----|-------|------|------|------|-----|-----|-------|------|------|------|
| 15    | 14   | 13   | 12  | 11   | 10  | 9     | 8    | 7    | 6    | 5   | 4   | з     | 2    | 1    | 0    |
|       |      |      | NOT | USED |     |       |      | PE7  | PE6  | PE5 | PE4 | PE3   | PE2  | PE1  | PEO  |
| RES   | SET: |      |     |      |     |       |      |      |      |     |     |       |      |      |      |
|       |      |      |     |      |     |       |      | U    | U    | U   | U   | U     | U    | U    | U    |

PORTE is an internal data latch that can be accessed at two locations — it can be read or written at any time. If a pin in I/O port E is configured as an output, the corresponding bit value is driven out on the pin. When a pin is configured for output, a read of PORTE returns the latched bit value; when a pin is configured for input, a read returns the pin logic level. Reads of PE3 always return one.

| D.4.7 | 7 DD | RE — | - Port | E Da | ata Di | rectic | on Re | gister | •    |      |      |      |      | \$YF | FA15 |
|-------|------|------|--------|------|--------|--------|-------|--------|------|------|------|------|------|------|------|
| 15    | 14   | 13   | 12     | 11   | 10     | 9      | 8     | 7      | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|       |      |      | NOT    | JSED |        |        |       | DDE7   | DDE6 | DDE5 | DDE4 | DDE3 | DDE2 | DDE1 | DDE0 |
| RES   | ET:  |      |        |      |        |        |       | 0      | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

Bits in this register control the direction of the port E pin drivers when pins are configured for I/O. Setting a bit configures the corresponding pin as an output; clearing a bit configures the corresponding pin as an input. This register can be read or written at any time.

| D.4.8 | 8 PEF                                                                                   | PAR · | — Po | rt E F | Pin As | ssignr | nent | Regis | ster |   |   |   |   | \$YF | FA17 |
|-------|-----------------------------------------------------------------------------------------|-------|------|--------|--------|--------|------|-------|------|---|---|---|---|------|------|
| 15    | 14                                                                                      | 13    | 12   | 11     | 10     | 9      | 8    | 7     | 6    | 5 | 4 | 3 | 2 | 1    | 0    |
|       | NOT USED PE7 PE6 PE5 PE4 PE3 PE2 PE1 PE0<br>(SIZ1) (SIZ0) (AS) (DS) (AVEC) DSACK1DSACK0 |       |      |        |        |        |      |       |      |   |   |   |   |      |      |
| RES   | SET:                                                                                    |       |      |        |        |        |      |       |      |   |   |   |   |      |      |

DATAS DATAS DATAS DATAS DATAS DATAS DATAS DATAS

Bits in this register determine the function of port E pins. Setting a bit assigns the corresponding pin to a bus control signal; clearing a bit assigns the pin to I/O port E. PE3 is not connected to a pin. DDE3, PE3, and PEPAR3 can be read and written, but have no function.

|   | D.4.9 | 9 PO | RTFC | /POF | TF1- | – Po | rt F I | Data | Regis | ter |   | ę | \$YFF | A19, | \$YF | FA1B |
|---|-------|------|------|------|------|------|--------|------|-------|-----|---|---|-------|------|------|------|
|   | 15    | 14   | 13   | 12   | 11   | 4    | 3      | 2    | 1     | 0   |   |   |       |      |      |      |
| [ |       |      |      | NOT  | USED | PF4  | PF3    | PF2  | PF1   | PF0 |   |   |       |      |      |      |
|   | RES   | SET: |      |      |      |      |        |      |       |     |   |   |       |      |      |      |
|   |       |      |      |      |      |      |        |      | U     | U   | U | U | U     | U    | U    | U    |

PORTF is an internal data latch that can be accessed at two locations. It can be read or written at any time. If a pin in I/O port F is configured as an output, the corresponding bit value is driven out on the pin. When a pin is configured for output, a read of PORTF returns the latched bit value; when a pin is configured for input, a read returns the pin logic level.

| D.4. | 10                                                 | DD | RF - | — Por | tFC | Data | Direct | ion R | legiste | er |   |   |   |   | \$YF | FA1D |
|------|----------------------------------------------------|----|------|-------|-----|------|--------|-------|---------|----|---|---|---|---|------|------|
| 15   |                                                    |    |      |       |     |      |        |       |         |    |   |   |   |   |      | 0    |
|      | NOT USED   DDF7   DDF6   DDF5   DDF4   DDF3   DDF2 |    |      |       |     |      |        |       |         |    |   |   |   |   |      | DDF0 |
| RE   | SET:                                               |    |      |       |     |      |        |       |         |    |   |   |   |   |      |      |
|      |                                                    |    |      |       |     |      |        |       | 0       | 0  | 0 | 0 | 0 | 0 | 0    | 0    |

Bits in this register control the direction of the port F pin drivers when pins are configured for I/O. Setting a bit configures the corresponding pin as an output; clearing a bit configures the corresponding pin as an input. This register can be read or written at any time.

| [ | <b>).4.1</b> | 1 PF | PAR | — P | ort F | Pin A | Assign | men | t Reg         | ister         |               |               |   |   | \$YF          | FA1F            |
|---|--------------|------|-----|-----|-------|-------|--------|-----|---------------|---------------|---------------|---------------|---|---|---------------|-----------------|
|   | 15           | 14   | 13  | 12  | 11    | 10    | 9      | 8   | 7             | 6             | 5             | 4             | з | 2 | 1             | 0               |
|   |              |      |     | NOT | USED  |       |        |     | PF7<br>(IRQ7) | PF6<br>(IRQ6) | PF5<br>(IRQ5) | PF4<br>(IRQ4) |   |   | PF1<br>(IRQ1) | PF0<br>(MODCLK) |
|   | RES          | ET:  |     |     |       |       |        |     |               |               |               |               |   |   |               |                 |

DATA9 DATA9 DATA9 DATA9 DATA9 DATA9 DATA9

Bits in this register determine the function of port F pins. Setting a bit assigns the corresponding pin to a bus control signal; clearing a bit assigns the pin to I/O port F.

| D.4 | .12  | SY | PCR | — s | ystem | Pro | tection | Сс | ontrol | Regis  | ter |    |     |     | \$YF | FA21 |
|-----|------|----|-----|-----|-------|-----|---------|----|--------|--------|-----|----|-----|-----|------|------|
| 15  |      | 14 | 13  | 12  | 11    | 10  | 9       | 8  | 7      | 6      | 5   | 4  | 3   | 2   | 1    | 0    |
|     |      |    |     | NOT | JSED  |     |         |    | SWE    | SWP    | SV  | VT | HME | BME | В    | MT   |
| RE  | ESET | :  |     |     |       |     |         |    |        |        |     |    |     |     |      |      |
|     |      |    |     |     |       |     |         |    | 1      | MODCLK | 0   | 0  | 0   | 0   | 0    | 0    |

SYPCR controls system monitor functions, software watchdog clock prescaling, and bus monitor timing. This register can be written once following power-on or reset.

- SWE Software Watchdog Enable
  - 0 = Software watchdog disabled
  - 1 = Software watchdog enabled
- SWP Software Watchdog Prescale
  - 0 = Software watchdog clock not prescaled
  - 1 = Software watchdog clock prescaled by 512
- SWT[1:0] Software Watchdog Timing

This field selects software watchdog timeout period.

| Softwa | re Watchdog | Ratio                                                 |
|--------|-------------|-------------------------------------------------------|
| SWP    | SWT         | Ratio                                                 |
| 0      | 00          | 2 <sup>9</sup>                                        |
| 0      | 01          | 211                                                   |
| 0      | 10          | 2 <sup>13</sup>                                       |
| 0      | 11          | 2 <sup>15</sup>                                       |
| 1      | 00          | 2 <sup>18</sup>                                       |
| 1      | 01          | 220                                                   |
| 1      | 10          | 2 <sup>20</sup><br>2 <sup>22</sup><br>2 <sup>24</sup> |
| 1      | 11          | 2 <sup>24</sup>                                       |

| Software | Watchdog | Ratio |
|----------|----------|-------|
|          |          |       |

### HME — Halt Monitor Enable

0 = Disable halt monitor function

1 = Enable halt monitor function

### BME — Bus Monitor External Enable

0 = Disable bus monitor function for an internal to external bus cycle.

1 = Enable bus monitor function for an internal to external bus cycle.

### BMT[1:0] — Bus Monitor Timing

This field selects bus monitor timeout period.

|     | <b>Bus Monitor Period</b>         |
|-----|-----------------------------------|
| BMT | <b>Bus Monitor Timeout Period</b> |
| 00  | 64 System Clocks                  |
| 01  | 32 System Clocks                  |
| 10  | 16 System Clocks                  |
| 11  | 8 System Clocks                   |

### D.4.13 PICR — Periodic Interrupt Control Register

### **\$YFFA22**

| 15     | 14 | 13 | 12 | 11 | 10 | 9     | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|--------|----|----|----|----|----|-------|---|---|---|---|---|---|---|---|---|
| 0      | 0  | 0  | 0  | 0  |    | PIRQL |   |   |   |   | P | V |   |   |   |
| RESET: |    |    |    |    |    |       |   |   |   |   |   |   |   |   |   |
| 0      | 0  | 0  | 0  | 0  | 0  | 0     | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |

Contains information concerning periodic interrupt priority and vectoring. PICR[10:0] can be read or written at any time. PICR[15:11] are unimplemented and always return zero.

### PIRQL[2:0] — Periodic Interrupt Request Level

This field determines the priority of periodic interrupt requests.

### PIV[7:0] — Periodic Interrupt Vector

The bits of this field contain the periodic interrupt vector number supplied by the SIM when the CPU acknowledges an interrupt request.

| ľ | ).4.14 | PIT | R  | Perio | dic In | terrup | ot Ti | mer Re | giste | er |   |    |    |   | \$YF | FA24 |
|---|--------|-----|----|-------|--------|--------|-------|--------|-------|----|---|----|----|---|------|------|
|   | 15     | 14  | 13 | 12    | 11     | 10     | 9     | 8      | 7     | 6  | 5 | 4  | 3  | 2 | 1    | 0    |
|   | 0      | 0   | 0  | 0     | 0      | 0      | 0     | PTP    |       |    |   | Pľ | ТМ |   |      |      |
|   | RESET: |     |    |       |        |        |       |        |       |    |   |    |    |   |      |      |
|   | 0      | 0   | 0  | 0     | 0      | 0      | 0     | MODCLK | 0     | 0  | 0 | 0  | 0  | 0 | 0    | 0    |

Contains the count value for the periodic timer. This register can be read or written at any time.

PTP — Periodic Timer Prescaler Control

- 1 = Periodic timer clock prescaled by a value of 512
- 0 = Periodic timer clock not prescaled

PITM[7:0] — Periodic Interrupt Timing Modulus

This is the 8-bit timing modulus used to determine periodic interrupt rate. Use the following expression to calculate timer period.

PIT Period = [(PIT Modulus)(Prescaler value)(4)]/EXTAL Frequency

| D.4. | 15 S\ | NSR | — Sc | oftwar | e Se | rvice | Reg | ister |   |   |   |   |   | \$YF | FA27 |
|------|-------|-----|------|--------|------|-------|-----|-------|---|---|---|---|---|------|------|
| 15   | 14    | 13  | 12   | 11     | 10   | 9     | 8   | 7     | 6 | 5 | 4 | 3 | 2 | 1    | 0    |
|      |       |     | NOT  | USED   |      |       |     | 0     | 0 | 0 | 0 | 0 | 0 | 0    | 0    |
| RE   | SET   |     |      |        |      |       |     |       |   |   |   |   |   |      |      |
|      |       |     |      |        |      |       |     | 0     | 0 | 0 | 0 | 0 | 0 | 0    | 0    |

When the software watchdog is enabled, a service sequence must be written to this register within a specific interval. When read, SWSR always returns \$00. Register shown with read value.

| D.4.16 TSTMSRA — Master Shift Register A                                       | \$YFFA30       |
|--------------------------------------------------------------------------------|----------------|
| Register is used for factory test only.                                        |                |
| D.4.17 TSTMSRB — Master Shift Register B                                       | \$YFFA32       |
| Register is used for factory test only.                                        |                |
| D.4.18 TSTSC — Test Module Shift Count                                         | \$YFFA34       |
| Register is used for factory test only.                                        |                |
| D.4.19 TSTRC — Test Module Repetition Count                                    | \$YFFA36       |
| Register is used for factory test only.                                        | <b>JILLAJO</b> |
| register is used for raciory test only.                                        |                |
| D.4.20 CREG — Test Submodule Control Register                                  | \$YFFA38       |
| Register is used for factory test only.                                        |                |
| D.4.21 DREG — Distributed Register                                             | \$YFFA3A       |
| Register is used for factory test only.                                        |                |
| D.4.22 PORTC — Port C Data Register                                            | \$YFFA41       |
| 15 14 13 12 11 10 9 8 7 6 5 4 3 2                                              | 1 0            |
| NOT USED         0         DO6         DO5         DO4         DO3         DO2 | DO1 DO0        |
| RESET                                                                          |                |

PORTC latches data for chip-select pins that are used for discrete output.

0

1

1

1

1

1

1

1

| D.4.: | <b>).4.23 CSPAR0</b> — Ch |           |    |           | Selec | t Pin /   | Pin Assignment Register 0 |       |   |           |   |           | \$YFFA44 |    |      |  |  |  |
|-------|---------------------------|-----------|----|-----------|-------|-----------|---------------------------|-------|---|-----------|---|-----------|----------|----|------|--|--|--|
| 15    | 14                        | 13        | 12 | 11        | 10    | 9         | 8                         | 7     | 6 | 5         | 4 | 3         | 2        | 1  | 0    |  |  |  |
| 0     | 0                         | CS<br>(FC |    | CS<br>(FC | -     | CS<br>(FC |                           | (BGA  |   | CS<br>(BC |   | CS<br>(BI | 30<br>R) | CS | BOOT |  |  |  |
| RE    | SET:                      |           |    |           |       |           |                           |       |   |           |   |           |          |    |      |  |  |  |
| 0     | 0                         | DATA2     | 1  | DATA2     | 1     | DATA2     | 1                         | DATA1 | 1 | DATA1     | 1 | DATA1     | 1        | 1  | DATA |  |  |  |

Contains seven 2-bit fields (CS[5:0] and CSBOOT) that determine the functions of corresponding chip-select pins. CSPAR0[15:14] are not used. These bits always read zero; write has no effect. CSPAR0 bit 1 always reads one; writes to CSPAR0 bit 1 have no effect. Mnemonics in parentheses show alternate functions that can be enabled by data bus mode selection during reset.

| D.4.2  | 24 CS | SPAR | 1 — ( | Chip S | Selec | t Pin /     | Assi | gnment       | Re | gister 1   |   |            |   | \$YFF/     | 46 |
|--------|-------|------|-------|--------|-------|-------------|------|--------------|----|------------|---|------------|---|------------|----|
| 15     | 14    | 13   | 12    | 11     | 10    | 9           | 8    | 7            | 6  | 5          | 4 | 3          | 2 | 1          | 0  |
| 0      | 0     | 0    | 0     | 0      | 0     | CS1<br>(ADD | -    | CSS<br>(ADD) |    | CS<br>(ADD |   | CS<br>(ADD |   | CS<br>(ADD |    |
| RESET: | 0     | 0    | 0     | 0      | 0     | DATA7       | 1    | DATA6        | 1  | DATA5      | 1 | DATA4      | 1 | DATA3      | 1  |

Contains five 2-bit fields ( $\overline{CS[10:6]}$ ) that determine the functions of corresponding chip-select pins. CSPAR1[15:10] are not used. These bits always read zero; write has no effect. Mnemonics in parentheses show alternate functions that can be enabled by data bus mode selection during reset.

| Pin Assignment Field Encoding                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                           |  |  |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|--|--|--|--|--|--|
| Bit Field                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Description               |  |  |  |  |  |  |
| 00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Discrete Output*          |  |  |  |  |  |  |
| 01                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Alternate Function*       |  |  |  |  |  |  |
| 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Chip Select (8-Bit Port)  |  |  |  |  |  |  |
| 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Chip Select (16-Bit Port) |  |  |  |  |  |  |
| and the second se |                           |  |  |  |  |  |  |

\*Does not apply to the CSBOOT field

### D.4.25 CSBARBT — Chip Select Base Address Register Boot ROM SYFFA48 6 5 15 14 13 12 11 10 9 8 7 4 3 2 1 ADDR BLKSZ 23 22 21 20 19 18 17 16 15 14 13 12 11 RESET: 0 0 0 0 0 0 0 ٥ 0 ٥ 0 0 1 1 ٥ 1

D.4.26 CSBAR[0:10] — Chip Select Base Address Registers \$YFFA4C-\$YFFA74

| 15         | 14         | 13         | 12         | 11         | 10         | 9          | 8          | 7          | 6          | 5          | 4          | 3          | 2 | 1     | 0 |
|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|---|-------|---|
| ADDR<br>23 | ADDR<br>22 | ADDR<br>21 | ADDR<br>20 | ADDR<br>19 | ADDR<br>18 | ADDR<br>17 | ADDR<br>16 | ADDR<br>15 | ADDR<br>14 | ADDR<br>13 | ADDR<br>12 | ADDR<br>11 |   | BLKSZ |   |
| RESET:     |            |            |            |            |            |            |            |            |            |            |            |            |   |       |   |
| 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0 | 0     | 0 |

MC68HC16Z1 **USER'S MANUAL**  Each chip-select pin has an associated base address register. A base address is the lowest address in the block of addresses enabled by a chip select. ADDR[23:20] are at the same logic level as ADDR19 during normal operation. CSBARBT contains the base address for selection of a bootstrap peripheral memory device. Bit and field definition for CSBARBT and CSBAR[0:10] are the same, but reset block sizes differ.

### ADDR[15:3] — Base Address

This field sets the starting address of a particular address space.

### BLKSZ — Block Size

This field determines the size of the block above the base address that is enabled by the chip select.

| BIOCK SIZE | Encoding                                                                                                                            |
|------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Block Size | Address Lines Compared                                                                                                              |
| 2 K        | ADDR23-ADDR11                                                                                                                       |
| 8 K        | ADDR23-ADDR13                                                                                                                       |
| 16 K       | ADDR23-ADDR14                                                                                                                       |
| 64 K       | ADDR23-ADDR16                                                                                                                       |
| 128 K      | ADDR23-ADDR17                                                                                                                       |
| 256 K      | ADDR23-ADDR18                                                                                                                       |
| 512 K      | ADDR23-ADDR19                                                                                                                       |
| 512 K      | ADDR23-ADDR20                                                                                                                       |
|            | Block         Size           2 K         8 K           16 K         64 K           128 K         256 K           512 K         12 K |

### Block Size Encoding

| D.4.27 | CSC | ORBI        | r — C  | hip S | Select | Opti | on Re  | giste | r Boo  | t RO | M   |     | :   | \$YF | FA4A |
|--------|-----|-------------|--------|-------|--------|------|--------|-------|--------|------|-----|-----|-----|------|------|
| 15     | 14  | 13          | 12     | 11    | 10     | 9    | 8      | 7     | 6      | 5    | 4   | 3   | 2   | 1    | 0    |
| MODE   | BY  | TE          | R/     | Ŵ     | STRB   |      | DSA    | CK    |        | SP/  | ACE |     | IPL |      | AVEC |
| RESET: |     |             |        |       |        |      |        |       |        |      |     |     |     |      |      |
| 0      | 1   | 1           | 1      | 1     | 0 -    | 1    | 1      | 0     | 1      | 1    | 1   | 0   | 0   | 0    | 0    |
| D.4.28 | CS  | <b>OR[0</b> | :10] - | – Cr  | nip Se | lect | Optior | n Reg | gister | S    | \$  | YFF | 44E | \$YF | FA76 |
| 15     | 14  | 13          | 12     | 11    | 10     | 9    | 8      | 7     | 6      | 5    | 4   | 3   | 2   | 1    | 0    |
| MODE   | BY  | TE          | R/     | W     | STRB   |      | DSA    | CK    |        | SP   | ACE |     | IPL |      | AVEC |
| RESET: |     |             |        |       |        |      |        |       |        |      |     |     |     |      |      |
| 0      | 0   | 0           | 0      | 0     | 0      | 0    | 0      | 0     | 0      | 0    | 0   | 0   | 0   | 0    | 0    |

Contain parameters that support bootstrap operations from peripheral memory devices. Bit and field definitions for CSORBT and CSOR[0:10] are the same.

### MODE — Asynchronous/Synchronous Mode

Synchronous mode cannot be used with internally-generated autovectors.

- 0 = Asynchronous mode selected
- 1 = Synchronous mode selected

### BYTE — Upper/Lower Byte Option

The value in this field determines whether a select signal can be asserted.

| MOTOROLA | APPENDIX D       | MC68HC16Z1    |
|----------|------------------|---------------|
| D-30     | REGISTER SUMMARY | USER'S MANUAL |

D

### R/W --- Read/Write

This field causes a chip select to be asserted only for a read, only for a write, or for both read and write.

### STRB — Address Strobe/Data Strobe

1 = Data strobe

0 = Address strobe

### DSACK — Data Strobe Acknowledge

This field specifies the source of DSACK in asynchronous mode and controls wait state insertion.

### SPACE — Address Space Select

This field selects an address space to be used by the chip-select logic.

### IPL — Interrupt Priority Level

This field determines interrupt priority level when a chip-select is used for interrupt acknowledge. It does not affect CPU interrupt recognition.

### AVEC — Autovector Enable

Do not enable autovector support when in synchronous mode.

1 = Autovector enabled

0 = External interrupt vector enabled

| MODE      | BYTE         | R/W        | STRB                | DSACK           | SPACE        | IPL              | AVEC    |
|-----------|--------------|------------|---------------------|-----------------|--------------|------------------|---------|
| 0 = ASYNC | 00 = Disable | 00 = Rsvd  | $0 = \overline{AS}$ | 0000 = 0 WAIT   | 00 = CPU SP  | 000 = All        | 0 = Off |
| 1 = SYNC  | 01 = Lower   | 01 = Read  | 1 = DS              | 0001 = 1 WAIT   | 01 = User SP | 001 = Priority 1 | 1 = On  |
|           | 10 = Upper   | 10 = Write |                     | 0010 = 2 WAIT   | 10 = Supv SP | 010 = Priority 2 |         |
|           | 11 = Both    | 11 = Both  |                     | 0011 = 3 WAIT   | 11 = S/U SP  | 011 = Priority 3 |         |
|           |              |            |                     | 0100 = 4 WAIT   |              | 100 = Priority 4 |         |
|           |              |            |                     | 0101 = 5 WAIT   |              | 101 = Priority 5 |         |
|           |              |            |                     | 0110 = 6 WAIT   |              | 110 = Priority 6 |         |
|           |              |            |                     | 0111 = 7 WAIT   |              | 111 = Priority 7 |         |
|           |              |            |                     | 1000 = 8 WAIT   |              |                  |         |
|           |              |            |                     | 1001 = 9 WAIT   |              |                  |         |
|           |              |            |                     | 1010 = 10 WAIT  |              |                  |         |
|           |              |            |                     | 1011 = 11 WAIT  |              |                  |         |
|           |              |            |                     | 1100 = 12 WAIT  |              |                  |         |
|           |              |            |                     | 1101 = 13 WAIT  |              |                  |         |
|           |              |            |                     | 1110 = F term   |              |                  |         |
|           |              |            |                     | 1111 = External |              |                  |         |

### **Option Register Function Summary**

| Address  | 15 | 8 7                       | 0                    |
|----------|----|---------------------------|----------------------|
| \$YFFB00 |    | RAM MODULE CONFIGURATIO   | N REGISTER (RAMMCR)  |
| \$YFFB02 |    | RAM TEST REGISTE          | R (RAMTST)           |
| \$YFFB04 |    | RAM ARRAY BASE ADDRESS RE | GISTER HIGH (RAMBAH) |
| \$YFFB06 |    | RAM ARRAY BASE ADDRESS R  | EGISTER LOW (RAMBAL) |

| Table D-5. SRAM Addres |
|------------------------|
|------------------------|

| ł | D.5.1  | RAN | IMCR | — F | RAM N | lodule | e Co | nfigur     | ation | Regi |   | \$YFFB00 |      |   |   |   |  |
|---|--------|-----|------|-----|-------|--------|------|------------|-------|------|---|----------|------|---|---|---|--|
|   | 15     |     |      |     | 11    |        | 9    | 8          | 7     | 6    | 5 | 4        | з    | 2 | 1 | 0 |  |
|   | STOP   | 0   | 0    | 0   | RLCK  | 0      | RA   | <b>ISP</b> |       |      |   | NOT      | USED |   |   |   |  |
|   | RESET: |     |      |     |       |        |      |            |       |      |   |          |      |   |   |   |  |
|   | 1      | 0   | 0    | 0   | 0     | 0      | 1    | 1          |       |      |   |          |      |   |   |   |  |

RAMMCR is used to determine whether the RAM is in STOP mode or normal mode. It is also used to determine in which space the array resides, and controls access to the base array registers. Reads of unimplemented bits always return zeros. Writes do not affect unimplemented bits.

### STOP — Stop Control

0 = RAM array operates normally.

1 = RAM array enters low-power stop mode.

This bit determines whether the RAM array is in low-power stop mode. Reset state is one, leaving the array configured for low-power stop operation. In stop mode, the array retains its contents, but cannot be read or written by the CPU. This bit can be read or written at any time.

### RLCK — RAM Base Address Lock

- 0 = SRAM base address registers can be written from IMB
- 1 = SRAM base address registers are locked

RLCK defaults to zero on reset; it can be written once to one.

### RASP[1:0] — RAM Array Space

RASP limits access to the SRAM array in microcontrollers that support separate user and supervisor operating modes. Because the CPU16 operates in supervisor mode only, RASP1 has no effect.

| RASP | Space            |
|------|------------------|
| ХО   | Program and Data |
| X1   | Program          |

D

### D.5.2 RAMTST - RAM Test Register

RAMTST is used for factory test only. Reads of this register return zeros, and writes have no effect.

| D.5.3        | RAM        | BAH              | — A  | rray E | Base . | Addre      | ess R | egiste                           | er Hig     | h          |                |                |            | \$YFI           | FB04         |
|--------------|------------|------------------|------|--------|--------|------------|-------|----------------------------------|------------|------------|----------------|----------------|------------|-----------------|--------------|
| 15           | 14         | 13               | 12   | 11     | 10     | 9          | 8     | 7                                | 6          | 5          | 4              | 3              | 2          | 1               | 0            |
|              |            |                  | NOT  | USED   |        |            |       | ADDR<br>23                       | ADDR<br>22 | ADDR<br>21 | ADDR<br>20     | ADDR<br>19     | ADDR<br>18 | ADDR<br>17      | ADDR<br>16   |
| RESET:       |            |                  |      |        |        |            |       |                                  |            |            |                |                |            |                 |              |
| 0            | 0          | 0                | 0    | 0      | 0      | 0          | 0     | 0                                | 0          | 0          | 0              | 0              | 0          | 0               | 0            |
|              |            |                  |      |        |        |            |       |                                  |            |            |                |                |            |                 |              |
| D.5.4        | RAM        |                  |      | ray E  |        |            |       | egiste                           |            |            |                |                |            | \$YFI           | FB06         |
| <b>D.5.4</b> | <b>RAM</b> | <b>BAL</b><br>13 | — Ar | ray E  | ase /  | Addre<br>9 | ss Re | egiste                           | r Low<br>6 | /<br>5     | 4              | 3              | 2          | <b>\$ Y F I</b> | F <b>B06</b> |
|              |            |                  |      | •      |        |            |       | 9 <b>giste</b><br>7<br>ADDR<br>7 |            |            | 4<br>ADDR<br>4 | 3<br>ADDR<br>3 |            | 1<br>ADDR<br>1  |              |

RAMBAH and RAMBAL are used to specify an SRAM array base address. RAMBAH and RAMBAL can only be written while the SRAM is in low-power mode (RAMMCR STOP = 1) and the base address lock (RAMMCR RLCK = 0) is disabled. This prevents accidental remapping of the array.

| Address               | 15 8                        | 7 0                         |
|-----------------------|-----------------------------|-----------------------------|
| \$YFFC00              | QSM MODULE CONF             | GURATION (QSMCR)            |
| \$YFFC02              | QSM TES                     | T (QTEST)                   |
| \$YFFC04              | QSM INTERRUPT LEVEL (QUILR) | QSM INTERRUPT VECTOR (QIVR) |
| \$YFFC06              | RESE                        | RVED                        |
| \$YFFC08              | SCI CONTRO                  | DL 0 (SCCR0)                |
| \$YFFC0A              | SCI CONTRO                  | DL 1 (SCCR1)                |
| \$YFFC0C              | SCI STATI                   | US (SCSR)                   |
| \$YFFC0E              | SCI DAT.                    | A (SCDR)                    |
| \$YFFC10              | RESE                        | RVED                        |
| \$YFFC12              | RESE                        | RVED                        |
| \$YFFC14              | RESERVED                    | PQS DATA (PORTQS)           |
| \$YFFC16              | PQS PIN ASSIGNMENT (PQSPAR) | PQS DATA DIRECTION (DDRQS)  |
| \$YFFC18              | SPI CONTRO                  | DL 0 (SPCR0)                |
| \$YFFC1A              | SPI CONTRO                  | DL 1 (SPCR1)                |
| \$YFFC1C              | SPI CONTRO                  | DL 2 (SPCR2)                |
| \$YFFC1E              | SPI CONTROL 3 (SPCR3)       | SPI STATUS (SPSR)           |
| \$YFFC20<br>\$YFFCFF  | RESE                        | RVED                        |
| \$YFFD00<br>\$YFFD1F  | RECEIVE R                   | AM (RR[0:F])                |
| \$YFFD20<br>\$YFFD3F  | TRANSMIT F                  | 3AM (TR[0:F])               |
| \$YFFD40-<br>\$YFFD4F | COMMAND F                   | RAM (CR[0:F])               |

Table D-6. QSM Address Map

| D.6.1 QMCR — QSM Configuration Register \$ |                                   |      |   |   |   |   |   |      |   |   |   |  |    | \$YF | FC00 |
|--------------------------------------------|-----------------------------------|------|---|---|---|---|---|------|---|---|---|--|----|------|------|
| 15                                         | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 |      |   |   |   |   |   |      |   |   |   |  |    |      | 0    |
| STOP                                       | FRZ1                              | FRZ0 | 0 | 0 | 0 | 0 | 0 | SUPV | 0 | 0 | 0 |  | IA | RB   |      |
| RESET:                                     |                                   |      |   |   |   |   |   |      |   |   |   |  |    |      |      |
| 0                                          | 0 0 0 0 0 0 0 1 0 0 0 0           |      |   |   |   |   |   |      |   |   |   |  |    |      | 0    |

QMCR bits enable stop and freeze modes, and determine the arbitration priority of QSM interrupt requests.

STOP — Stop Enable

0 = Normal QSM clock operation

1 = QSM clock operation stopped

When STOP is set, the QSM enters low-power stop mode. System clock input to the module is disabled. While STOP is asserted, only QMCR reads are guaranteed to be valid, but writes to QSPI RAM or any register are guaranteed valid. STOP is

| MOTOROLA |  |
|----------|--|
| D-34     |  |

### APPENDIX D REGISTER SUMMARY

MC68HC16Z1 USER'S MANUAL set during reset. The SCI receiver and transmitter must be disabled before STOP is set. To stop the QSPI, set the HALT bit in SPCR3, wait until the HALTA flag is set, then set STOP.

FRZ[1:0] — Freeze Control

0 = Ignore the FREEZE signal on the IMB

1 = Halt the QSPI (on a transfer boundary)

FRZ1 determines what action is taken by the QSPI when the FREEZE signal of the IMB is asserted. FREEZE is asserted whenever the CPU enters background mode. FRZ0 is reserved for future use.

Bits [12:8] — Not Implemented

### SUPV — Supervisor/Unrestricted

Because the CPU16 in the MC68HC16Z1 operates only in supervisor mode, this bit has no effect.

Bits [6:4] — Not Implemented

### IARB — Interrupt Arbitration

Each module that generates interrupts must have an IARB value. IARB values are used to arbitrate between interrupt requests of the same priority.

D.6.2 QTEST — QSM Test Register

Used for factory test only.

### **D.6.3 QILR** — QSM Interrupt Level Register

QIVR — QSM Interrupt Vector Register

| 15     | 14 | 13 | 12     | 11 | 10 | 9     | 8 | 7 | 6 | 5 | 4  | 3  | 2 | 1 | 0 |
|--------|----|----|--------|----|----|-------|---|---|---|---|----|----|---|---|---|
| 0      | 0  |    | ILQSPI |    |    | ILSCI |   |   |   |   | IN | τv |   |   |   |
| RESET: |    |    |        |    |    |       |   |   |   |   |    |    |   |   |   |
| 0      | 0  | 0  | 0      | 0  | 0  | 0     | 0 | 0 | 0 | 0 | 0  | 1  | 1 | 1 | 1 |

The values of the ILQSPI and ILSCI fields in QILR determine the priority of QSPI and SCI interrupt requests. QIVR determines the value of the interrupt vector number the QSM supplies when it responds to an interrupt acknowledge cycle. At reset, QIVR is initialized to vector number \$0F, the uninitialized interrupt vector number. To use interrupt-driven serial communication, a user-defined vector number must be written to QIVR.

\$YFFC02

\$YFFC04

\$YFFC05

### ILQSPI — Interrupt Level for QSPI

When an interrupt request is made, ILQSPI value determines which of the interrupt request signals is asserted; when a request is acknowledged, the QSM compares this value to a mask value supplied by the CPU16 to determine whether to respond. ILQSPI must have a value in the range \$0 (lowest priority) to \$7 (highest priority).

### ILSCI — Interrupt Level for SCI

When an interrupt request is made, ILSCI value determines which of the interrupt request signals is asserted. When a request is acknowledged, the QSM compares this value to a mask value supplied by the CPU16 to determine whether to respond. The field must have a value in the range \$0 (lowest priority) to \$7 (highest priority).

If ILQSPI and ILSCI have the same nonzero value, and both submodules simultaneously request interrupt service, the QSPI has priority.

### INTV[7:0] — Interrupt Vector Number

The values of INTV[7:1] are the same for both QSPI and SCI interrupt requests; the value of INTV0 used during an interrupt acknowledge cycle is supplied by the QSM. INTV0 is at logic level zero during an SCI interrupt and at logic level one during a QSPI interrupt. A write to INTV0 has no effect. Reads of INTV0 return a value of one.

| D.e | .4 PORTQS - Port QS Data Registe | r     |      |      |      |      |      | \$YF | FC15 |
|-----|----------------------------------|-------|------|------|------|------|------|------|------|
| 1   | 5 8                              | 7     | 6    | 5    | 4    | з    | 2    | 1    | 0    |
|     | RESERVED                         | PQS7  | PQS6 | PQS5 | PQS4 | PQS3 | PQS2 | PQS1 | PQS0 |
|     |                                  | RESET | Γ:   |      |      |      |      |      |      |
|     |                                  | 0     | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

PORTQS latches I/O data. Writes drive pins defined as outputs. Reads return data present on the pins. To avoid driving undefined data, first write a byte to PORTQS, then configure DDRQS.

| D.6.5 | D.6.5 PQSPAR — Pin Assignment Register |    |     |      |    |   |   |   |   |   |     |     |   |   |   |
|-------|----------------------------------------|----|-----|------|----|---|---|---|---|---|-----|-----|---|---|---|
|       | DDRQS — Data Direction Register \$1    |    |     |      |    |   |   |   |   |   |     |     |   |   |   |
| 15    | 14                                     | 13 | 12  | 11   | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3   | 2 | 1 | 0 |
|       |                                        |    | PQS | SPAR |    |   |   |   |   |   | DDI | RQS |   |   |   |
| RESET | :                                      | 0  | 0   | 0    | 0  | 0 | 0 | 0 | 0 | 0 | 0   | 0   | 0 | 0 | 0 |

Clearing a bit in PQSPAR assigns the corresponding pin to general-purpose I/O; setting a bit assigns the pin to the QSPI. PQSPAR does not affect operation of the SCI. DDRQS determines whether pins are inputs or outputs. Clearing a bit makes the corresponding pin an input; setting a bit makes the pin an output.

DDRQS affects both QSPI function and I/O function. DDRQS determines the direction of the TXD pin only when the SCI transmitter is disabled. When the SCI transmitter is enabled, the TXD pin is an output.

| D.6.6 SPCR0 — QSPI Control Register 0 \$Y |                                   |      |   |    |    |   |      |      |   |   |   |   |   |   | \$YFI | FC18 |
|-------------------------------------------|-----------------------------------|------|---|----|----|---|------|------|---|---|---|---|---|---|-------|------|
|                                           | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 |      |   |    |    |   |      |      |   |   |   |   |   |   |       | 0    |
| Ν                                         | ISTR                              | WOMQ |   | Bľ | TS |   | CPOL | CPHA |   |   |   | В | R |   |       |      |
| R                                         | ESET:                             |      |   |    |    |   |      |      |   |   |   |   |   |   |       |      |
|                                           | 0                                 | 0    | 0 | 0  | 0  | 0 | 0    | 1    | 0 | 0 | 0 | 0 | 0 | 1 | 0     | 0    |

SPCR0 contains parameters for configuring the QSPI and enabling various modes of operation. The CPU has read/write access to SPCR0, but the QSM has read access only. SPCR0 must be initialized before QSPI operation begins. Writing a new value to SPCR0 while the QSPI is enabled disrupts operation.

### MSTR — Master/Slave Mode Select

0 = QSPI is a slave device.

1 = QSPI is system master.

### WOMQ — Wired-OR Mode for QSPI Pins

- 0 = Outputs have normal MOS drivers.
- 1 = Pins designated for output by DDRQS have open-drain drivers.
- BITS Bits Per Transfer

The BITS field determines the number of serial data bits transferred.

- CPOL Clock Polarity
  - 0 = The inactive state value of SCK is logic level zero.
  - 1 = The inactive state value of SCK is logic level one.

### CPHA — Clock Phase

- 0 = Data captured on the leading edge of SCK and changed on the following edge of SCK.
- 1 = Data is changed on the leading edge of SCK and captured on the following edge of SCK.

### SPBR — Serial Clock Baud Rate

QSPI Baud rate is selected by writing a value from 2 to 255 into SPBR. Giving BR a value of zero or one disables SCK (disable state determined by CPOL). At reset, BAUD is initialized to a 2.1-MHz SCK frequency.

| D.6.7  | D.6.7 SPCR1 — QSPI Control Register 1 \$ |  |  |       |  |  |  |  |  |  |   |    |  |  |   |
|--------|------------------------------------------|--|--|-------|--|--|--|--|--|--|---|----|--|--|---|
| 15     | 14 13 12 11 10 9 8 7 6 5 4 3 2           |  |  |       |  |  |  |  |  |  |   |    |  |  | 0 |
| SPE    |                                          |  |  | DSCKL |  |  |  |  |  |  | D | ΓL |  |  |   |
| RESET: | ET:                                      |  |  |       |  |  |  |  |  |  |   |    |  |  |   |
| 0      | 0 0 0 0 1 0 0 0 0 0 1                    |  |  |       |  |  |  |  |  |  |   |    |  |  | 0 |

SPCR1 enables the QSPI and specified transfer delays. The CPU has read/write access to SPCR1, but the QSM has read access only to all bits but enable bit SPE. SPCR1 must be written last during initialization because it contains SPE. Writing a new value to SPCR1 while the QSPI is enabled disrupts operation.

### SPE — QSPI Enable

- 0 = QSPI is disabled. QSPI pins can be used for general-purpose I/O.
- 1 = QSPI is enabled. Pins allocated by PQSPAR are controlled by the QSPI.

### DSCKL — Delay before SCK

When the DSCK bit in command RAM is set, this field determines the length of delay from PCS valid to SCK transition. PCS may be any of the four peripheral chip-select pins.

### DTL --- Length of Delay after Transfer

When the DT bit in command RAM is set, this field determines the length of delay after serial transfer.

| D.6.8  | D.6.8 SPCR2 — QSPI Control Register 2 \$YFFC1C |      |    |    |    |     |   |   |   |   |   |   | C1C |     |   |
|--------|------------------------------------------------|------|----|----|----|-----|---|---|---|---|---|---|-----|-----|---|
| 15     | 14                                             | 13   | 12 | 11 | 10 | 9   | 8 | 7 | 6 | 5 | 4 | 3 | 2   | 1   | 0 |
| SPIFIE | WREN                                           | WRTO | 0  |    | EN | DQP |   | 0 | 0 | 0 | 0 |   | NEV | VQP |   |
| RESET  | •                                              |      |    |    |    |     |   |   |   |   |   |   |     |     |   |
| 0      | 0                                              | 0    | 0  | 0  | 0  | 0   | 0 | 0 | 0 | 0 | 0 | 0 | 0   | 0   | 0 |

SPCR2 contains QSPI queue pointers, wraparound mode control bits, and an interrupt enable bit. The CPU has read/write access to SPCR2, but the QSM has read access only. SPCR2 is buffered — new SPCR2 values become effective only after completion of the current serial transfer. Rewriting NEWQP in SPCR2 causes execution to restart at the designated location. SPCR2 reads return the value of the register, not the buffer.

### SPIFIE — SPI Finished Interrupt Enable

- 0 = QSPI interrupts disabled
- 1 = QSPI interrupts enabled

### WREN — Wrap Enable

- 0 = Wraparound mode disabled
- 1 = Wraparound mode enabled

### WRTO - Wrap To

- 0 = Wrap to pointer address \$0
- 1 = Wrap to address in NEWQP
- Bit 12 Not Implemented

ENDQP — Ending Queue Pointer

This field contains the last QSPI queue address.

### Bits [7:4] - Not Implemented

NEWQP — New Queue Pointer Value

This field contains the first QSPI queue address.

# D.6.9 SPCR3 — QSPI Control Register 3

### \$YFFC1E

|        | SPS | 5R — | QSP | I Sta | tus Re | egiste | er   |      |      |       |   |   |    | \$YFI | FC1F |  |
|--------|-----|------|-----|-------|--------|--------|------|------|------|-------|---|---|----|-------|------|--|
| 15     | 14  | 13   | 12  | 11    | 10     | 9      | 8    | 7    | 6    | 5     | 4 | 3 | 2  | 1     | 0    |  |
| 0      | 0   | 0    | 0   | 0     | LOOPQ  | HMIE   | HALT | SPIF | MODF | HALTA | 0 |   | CP | TQP   |      |  |
| RESET: |     |      |     |       |        |        |      |      |      |       |   |   |    |       |      |  |
| 0      | 0   | 0    | 0   | 0     | 0      | 0      | 0    | 0    | 0    | 0     | 0 | 0 | 0  | 0     | 0    |  |

SPCR3 contains the loop mode enable bit, halt and mode fault interrupt enables, and the halt control bit. The CPU has read/write access to SPCR3, but the QSM has read access only. SPCR3 must be initialized before QSPI operation begins. Writing a new value to SPCR3 while the QSPI is enabled disrupts operation. SPSR contains information concerning the current serial transmission. Only the QSPI can set bits in SPSR. The CPU reads SPSR to obtain QSPI status information and writes it to clear status flags.

Bits [15:11] - Not Implemented

LOOPQ - QSPI Loop Mode

- 0 = Feedback path disabled
- 1 = Feedback path enabled

### HMIE — HALTA and MODF Interrupt Enable

- 0 = HALTA and MODF interrupts disabled
- 1 = HALTA and MODF interrupts enabled
- HALT Halt
  - 0 = Halt not enabled
  - 1 = Halt enabled

MC68HC16Z1 USER'S MANUAL SPIF — QSPI Finished Flag

0 = QSPI not finished

1 = QSPI finished

MODF — Mode Fault Flag

0 = Normal operation

- 1 = Another SPI node requested to become the network SPI master while the QSPI was enabled in master mode ( $\overline{SS}$  input taken low).
- HALTA Halt Acknowledge Flag
  - 0 = QSPI not halted

1 = QSPI halted

- Bit 4 Not Implemented
- CPTQP Completed Queue Pointer

CPTQP points to the last command executed. It is updated when the current command is complete. When the first command in a queue is executing, CPTQP contains either the reset value (\$0) or a pointer to the last command completed in the previous queue.

### D.6.10 RR[0:F] — Receive Data Ram

### \$YFFD00-\$YFFD0E

Data received by the QSPI is stored in this segment. The CPU reads this segment to retrieve data from the QSPI. Data stored in receive RAM is right-justified. Unused bits in a receive queue entry are set to zero by the QSPI upon completion of the individual queue entry. The CPU can access the data using byte, word, or long-word addressing.

### D.6.11 TR[0:F] — Transmit Data Ram

### \$YFFD20-\$YFFD3E

Data that is to be transmitted by the QSPI is stored in this segment. The CPU normally writes one word of data into this segment for each queue command to be executed.

Information to be transmitted must be written to transmit data RAM in a rightjustified format. The QSPI cannot modify information in the transmit data RAM. The QSPI copies the information to its data serializer for transmission. Information remains in transmit RAM until overwritten.

D

| D.6.12 CF | R[0:F] — C | ommand  | \$YFFD40-\$YFFD4F |      |            |             |       |
|-----------|------------|---------|-------------------|------|------------|-------------|-------|
| 7         | 6          | 5       | 4                 | 3    | 2          | 1           | 0     |
| CONT      | BITSE      | DT      | DSCK              | PCS3 | PCS2       | PCS1        | PCS0* |
| _         |            | _       | _                 |      |            |             |       |
| CONT      | BITSE      | DT      | DSCK              | PCS3 | PCS2       | PCS1        | PCS0* |
|           | COMMANE    | CONTROL |                   |      | PERIPHERAL | CHIP SELECT |       |

\*The PCS0 bit represents the dual-function PCS0/SS.

Command RAM is used by the QSPI when in master mode. The CPU writes one byte of control information to this segment for each QSPI command to be executed. The QSPI cannot modify information in command RAM.

Command RAM consists of 16 bytes. Each byte is divided into two fields. The peripheral chip-select field enables peripherals for transfer. The command control field provides transfer options.

A maximum of 16 commands can be in the queue. Queue execution proceeds from the address in NEWQP through the address in ENDQP (both of these fields are in SPCR2).

### PCS[3:0] — Peripheral Chip Select

Peripheral chip-select bits are used to select an external device for serial data transfer. More than one peripheral chip select may be activated at a time, and more than one peripheral chip may be connected to each PCS pin, provided proper fanout is observed. PCS0 shares a pin with the slave select SS signal, which initiates slave mode serial transfer. If SS is taken low when the QSPI is in master mode, a mode fault occurs.

### CONT - Continue

- 0 = Control of chip selects returned to QPDR after transfer is complete.
- 1 = Peripheral chip selects remain asserted after transfer is complete.

### BITSE — Bits per Transfer Enable

0 = 8 bits

1 = Number of bits set in BITS field of SPCR0

### DT — Delay after Transfer

The QSPI provides a variable delay at the end of serial transfer to facilitate interfacing with peripherals that have a latency requirement. The delay between transfers is determined by the SPCR1 DTL field.

DSCK — PCS to SCK Delay

0 = PCS valid to SCK transition is one-half SCK.

1 = SPCR1 DSCKL field specifies delay from PCS valid to SCK.

| D.6.1  | 3 SC | CR0 | — so | CI Co | ontrol | Regis | ster 0 |   |      |   |   |   |   | <b>\$YFFC08</b><br>2 1 0 |   |
|--------|------|-----|------|-------|--------|-------|--------|---|------|---|---|---|---|--------------------------|---|
| 15     | 14   | 13  | 12   | 11    | 10     | 9     | 8      | 7 | 6    | 5 | 4 | 3 | 2 | 1                        | 0 |
| 0      | 0    | 0   |      |       |        |       |        |   | SCBR |   |   |   |   |                          |   |
| RESET: |      |     |      |       |        |       |        |   |      |   |   |   |   |                          |   |
| 0      | 0    | 0   | 0    | 0     | 0      | 0     | 0      | 0 | 0    | 0 | 0 | 0 | 1 | 0                        | 0 |

SCCR0 contains the SCI baud rate selection field. Baud rate must be set before the SCI is enabled. The CPU can read and write SCCR0 at any time. Changing the value of SCCR0 bits during a transfer operation can disrupt operation.

Bits [15:13] — Not Implemented

SCBR — SCI Baud Rate

SCI baud rate is programmed by writing a 13-bit value to this field. Writing a value of zero to SCBR disables the baud rate generator. Baud clock rate is calculated as follows:

# SCI Baud Clock Rate = System Clock/(32SCBR)

| ٢ | D.6.14 | 4 SCO | CR1 - | — so | CI Co | ntrol | Regi | ster 1 |     |      |     |      |    |    | \$YFF | COA |
|---|--------|-------|-------|------|-------|-------|------|--------|-----|------|-----|------|----|----|-------|-----|
|   | 15     | 14    | 13    | 12   | 11    | 10    | 9    | 8      | 7   | 6    | 5   | 4    | 3  | 2  | 1     | 0   |
|   | 0      | LOOPS | WOMS  | ILT  | PT    | PE    | м    | WAKE   | TIE | TCIE | RIE | ILIE | TE | FE | RWU   | SBK |
|   | RESET: |       |       |      |       |       |      |        |     |      |     |      |    |    |       |     |
|   | 0      | 0     | 0     | 0    | 0     | 0     | 0    | 0      | 0   | 0    | 0   | 0    | 0  | 0  | 0     | 0   |

SCCR1 contains SCI configuration parameters, including transmitter and receiver enable bits, interrupt enable bits, and operating mode enable bits. The CPU can read and write SCCR0 at any time. The SCI can modify the RWU bit under certain circumstances. Changing the value of SCCR1 bits during a transfer operation can disrupt operation.

- Bit 15 Not Implemented
- LOOPS Loop Mode
  - 0 = Normal SCI operation, no looping, feedback path disabled
  - 1 = Test SCI operation, looping, feedback path enabled
- WOMS Wired-OR Mode for SCI Pins
  - 0 = If configured as an output, TXD is a normal CMOS output.
  - 1 = If configured as an output, TXD is an open-drain output.
- ILT Idle-Line Detect Type
  - 0 = Short idle-line detect (start count on first one)
  - 1 = Long idle-line detect (start count on first one after stop bit(s))

- PT --- Parity Type
  - 0 = Even parity
  - 1 = Odd parity
- PE Parity Enable
  - 0 = SCI parity disabled
  - 1 = SCI parity enabled
- M Mode Select
  - 0 = 10-bit SCI frame
  - 1 = 11-bit SCI frame
- WAKE Wakeup by Address Mark
  - 0 = SCI receiver awakened by idle-line detection
  - 1 = SCI receiver awakened by address mark (last bit set)
- TIE Transmit Interrupt Enable
  - 0 = SCI TDRE interrupts inhibited
  - 1 = SCI TDRE interrupts enabled
- TCIE Transmit Complete Interrupt Enable
  - 0 = SCI TC interrupts inhibited
  - 1 = SCI TC interrupts enabled
- RIE Receiver Interrupt Enable
  - 0 = SCI RDRF and OR interrupts inhibited
  - 1 = SCI RDRF and OR interrupts enabled
- ILIE Idle-Line Interrupt Enable
  - 0 = SCI IDLE interrupts inhibited
  - 1 = SCI IDLE interrupts enabled
- TE Transmitter Enable
  - 0 = SCI transmitter disabled (TXD pin may be used as I/O)
  - 1 = SCI transmitter enabled (TXD pin dedicated to SCI transmitter)
- RE Receiver Enable
  - 0 = SCI receiver disabled (status bits inhibited)
  - 1 = SCI receiver enabled
- RWU Receiver Wakeup
  - 0 = Normal receiver operation (received data recognized)
  - 1 = Wakeup mode enabled (received data ignored until awakened)
- SBK Send Break
  - 0 = Normal operation
  - 1 = Break frame(s) transmitted after completion of current frame

MC68HC16Z1 USER'S MANUAL APPENDIX D REGISTER SUMMARY

| D.6.15 | SC | SR — | - SCI    | Stat | us Re | egist | er   |    |      |     |      |    | ;  | \$YFF | -COC |
|--------|----|------|----------|------|-------|-------|------|----|------|-----|------|----|----|-------|------|
| 15     | 14 | 13   | 12       | 11   | 10    | 9     | 8    | 7  | 6    | 5   | 4    | 3  | 2  | 1     | 0    |
|        |    | 1    | NOT USED | )    |       |       | TDRE | TC | RDRF | RAF | IDLE | OR | NF | FE    | PF   |
| RESET: |    |      |          |      |       |       |      |    |      |     |      |    |    |       |      |
| 0      | 0  | 0    | 0        | 0    | 0     | 0     | 1    | 1  | 0    | 0   | 0    | 0  | 0  | 0     | 0    |

SCSR contains flags that show SCI operating conditions. These flags are cleared either by SCI hardware or by a CPU read/write sequence. The sequence consists of reading SCSR, then reading or writing SCDR.

If an internal SCI signal for setting a status bit comes after the CPU has read the asserted status bits, but before the CPU has written or read SCDR, the newly set status bit is not cleared — SCSR must be read again with the bit set, and SCDR must be written or read before the status bit is cleared.

A long-word read can consecutively access both SCSR and SCDR. This action clears receive status flag bits that were set at the time of the read, but does not clear TDRE or TC flags. Reading either byte of SCSR causes all 16 bits to be accessed, and any status bit already set in either byte will be cleared on a subsequent read or write of register SCDR.

- TDRE Transmit Data Register Empty
  - 0 = Register TDR still contains data to be sent to the transmit serial shifter.
  - 1 = A new character may now be written to register TDR.
- TC Transmit Complete
  - 0 = SCI transmitter is busy.
  - 1 = SCI transmitter is idle.
- RDRF Receive Data Register Full
  - 0 = Register RDR is empty or contains previously read data.
  - 1 = Register RDR contains new data.
- **RAF** Receiver Active
  - 0 = SCI receiver is idle.
  - 1 = SCI receiver is busy.
- IDLE Idle-Line Detected
  - 0 = SCI receiver did not detect an idle-line condition.
  - 1 = SCI receiver detected an idle-line condition.
- OR Overrun Error
  - 0 = RDRF is cleared before new data arrives.
  - 1 = RDRF is not cleared before new data arrives.

# NF - Noise Error

0 = No noise detected on the received data.

1 = Noise occurred on the received data.

# FE --- Framing Error

1 = Framing error or break occurred on the received data.

0 = No framing error on the received data.

# PF — Parity Error

1 = Parity error occurred on the received data.

0 = No parity error on the received data.

| l | D.6.16 | SC | DR — SCI Data Register \$YFFC0E |    |    |    |   |       |       |       |       | C0E   |       |       |       |       |
|---|--------|----|---------------------------------|----|----|----|---|-------|-------|-------|-------|-------|-------|-------|-------|-------|
|   | 15     | 14 | 13                              | 12 | 11 | 10 | 9 | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|   | 0      | 0  | 0                               | 0  | 0  | 0  | 0 | R8/T8 | R7/T7 | R6/T6 | R5/T5 | R4/T4 | R3/T3 | R2/T2 | R1/T1 | R0/T0 |
|   | RESET: |    |                                 |    |    |    |   |       |       |       |       |       |       |       |       |       |
|   | 0      | 0  | 0                               | 0  | 0  | 0  | 0 | U     | U     | U     | U     | U     | U     | U     | U     | U     |

SCDR consists of two data registers at the same address. RDR is a read-only register that contains data received by the SCI serial interface. Data comes into the receive serial shifter and is transferred to RDR. TDR is a write-only register that contains data to be transmitted. Data is first written to TDR, then transferred to the transmit serial shifter, where additional format bits are added before transmission. R[7:0]/T[7:0] contain either the first eight data bits received when SCDR is read, or the first eight data bits to be transmitted when SCDR is written. R8/T8 are used when the SCI is configured for 9-bit operation. When it is configured for 8-bit operation, they have no meaning or effect.

|          | ADC                                        |   |
|----------|--------------------------------------------|---|
| Address  | 15 8 7                                     | 0 |
| \$FFF700 | MODULE CONFIGURATION (ADCMCR)              |   |
| \$FFF702 | FACTORY TEST (ADTEST)                      |   |
| \$FFF704 | (RESERVED)                                 |   |
| \$FFF706 | PORTADA DATA (PORTADA)                     |   |
| \$FFF708 | (RESERVED)                                 |   |
| \$FFF70A | ADC CONTROL 0 (ADCTL0)                     |   |
| \$FFF70C | ADC CONTROL 1 (ADCTL1)                     |   |
| \$FFF70E | ADC STATUS (ADSTAT)                        |   |
| \$FFF710 | RIGHT-JUSTIFIED UNSIGNED RESULT 0 (RJURR0) |   |
| \$FFF712 | RIGHT-JUSTIFIED UNSIGNED RESULT 1 (RJURR1) |   |
| \$FFF714 | RIGHT-JUSTIFIED UNSIGNED RESULT 2 (RJURR2) |   |
| \$FFF716 | RIGHT-JUSTIFIED UNSIGNED RESULT 3 (RJURR3) |   |
| \$FFF718 | RIGHT-JUSTIFIED UNSIGNED RESULT 4 (RJURR4) |   |
| \$FFF71A | RIGHT-JUSTIFIED UNSIGNED RESULT 5 (RJURR5) |   |
| \$FFF71C | RIGHT-JUSTIFIED UNSIGNED RESULT 6 (RJURR6) |   |
| \$FFF71E | RIGHT-JUSTIFIED UNSIGNED RESULT 7 (RJURR7) |   |
| \$FFF720 | LEFT-JUSTIFIED SIGNED RESULT 0 (LJSRR0)    |   |
| \$FFF722 | LEFT-JUSTIFIED SIGNED RESULT 1 (LJSRR1)    |   |
| \$FFF724 | LEFT-JUSTIFIED SIGNED RESULT 2 (LJSRR2)    |   |
| \$FFF726 | LEFT-JUSTIFIED SIGNED RESULT 3 (LJSRR3)    |   |
| \$FFF728 | LEFT-JUSTIFIED SIGNED RESULT 4 (LJSRR4)    |   |
| \$FFF72A | LEFT-JUSTIFIED SIGNED RESULT 5 (LJSRR5)    |   |
| \$FFF72C | LEFT-JUSTIFIED SIGNED RESULT 6 (LJSRR6)    |   |
| \$FFF72E | LEFT-JUSTIFIED SIGNED RESULT 7 (LJSRR7)    |   |
| \$FFF730 | LEFT-JUSTIFIED UNSIGNED RESULT 0 (LJURR0)  |   |
| \$FFF732 | LEFT-JUSTIFIED UNSIGNED RESULT 1 (LJURR1)  |   |
| \$FFF734 | LEFT-JUSTIFIED UNSIGNED RESULT 2 (LJURR2)  |   |
| \$FFF736 | LEFT-JUSTIFIED UNSIGNED RESULT 3 (LJURR3)  |   |
| \$FFF738 | LEFT-JUSTIFIED UNSIGNED RESULT 4 (LJURR4)  |   |
| \$FFF73A | LEFT-JUSTIFIED UNSIGNED RESULT 5 (LJURR5)  |   |
| \$FFF73C | LEFT-JUSTIFIED UNSIGNED RESULT 6 (LJURR6)  |   |
| \$FFF73E | LEFT-JUSTIFIED UNSIGNED RESULT 7 (LJURR7)  |   |

# Table D-7. MC68HC16Z1 Module Address Map

(Assumes SIMCR MM = 1)

MOTOROLA D-46

# APPENDIX D REGISTER SUMMARY

MC68HC16Z1 USER'S MANUAL

.

|                      | GPT                        |                         |  |  |  |  |  |
|----------------------|----------------------------|-------------------------|--|--|--|--|--|
| Address              | 15 8                       | 7 0                     |  |  |  |  |  |
| \$FFF900             | GPT MODULE CONFI           | GURATION (GPTMCR)       |  |  |  |  |  |
| \$FFF902             | (RESERVEI                  | D FOR TEST)             |  |  |  |  |  |
| \$FFF904             | INTERRUPT CON              | FIGURATION (ICR)        |  |  |  |  |  |
| \$FFFE06             | PGP DATA DIRECTION (DDRGP) | PGP DATA (PORTGP)       |  |  |  |  |  |
| \$FFF908             | OC1 ACTION MASK (OC1M)     | OC1 ACTION DATA (OC1D)  |  |  |  |  |  |
| \$FFF90A             | TIMER COU                  | NTER (TCNT)             |  |  |  |  |  |
| \$FFF90C             | PA CONTROL (PACTL)         | PA COUNTER (PACNT)      |  |  |  |  |  |
| \$FFF90E             | INPUT CAPT                 | URE 1 (TIC1)            |  |  |  |  |  |
| \$FFF910             | INPUT CAPT                 | INPUT CAPTURE 2 (TIC2)  |  |  |  |  |  |
| \$FFF912             | INPUT CAPT                 | INPUT CAPTURE 3 (TIC3)  |  |  |  |  |  |
| \$FFF914             | OUTPUT COMPARE 1 (TOC1)    |                         |  |  |  |  |  |
| \$FFF916             | OUTPUT COMPARE 2 (TOC2)    |                         |  |  |  |  |  |
| \$FFF918             | OUTPUT COM                 | OUTPUT COMPARE 3 (TOC3) |  |  |  |  |  |
| \$FFF91A             | OUTPUT COM                 | PARE 4 (TOC4)           |  |  |  |  |  |
| \$FFF91C             | INPUT CAPTURE 4/OUT        | PUT COMPARE 5 (TI4/O5)  |  |  |  |  |  |
| \$FFF91E             | TIMER CONTROL 1 (TCTL1)    | TIMER CONTROL 2 (TCTL2) |  |  |  |  |  |
| \$FFF920             | TIMER MASK 1 (TMSK1)       | TIMER MASK 2 (TMSK2)    |  |  |  |  |  |
| \$FFF922             | TIMER FLAG 1 (TFLG1)       | TIMER FLAG 2 (TFLG2)    |  |  |  |  |  |
| \$FFF924             | FORCE COMPARE (CFORC)      | PWM CONTROL C (PWMC)    |  |  |  |  |  |
| \$FFF926             | PWM CONTROL A (PWMA)       | PWM CONTROL B (PWMB)    |  |  |  |  |  |
| \$FFF928             | PWM COUN                   | T (PWMCNT)              |  |  |  |  |  |
| \$FFF92A             | PWMA BUFFER (PWMBUFA)      | PWMB BUFFER (PWMBUFB)   |  |  |  |  |  |
| \$FFF92C             | GPT PRESCA                 | LER (PRESCL)            |  |  |  |  |  |
| \$FFF92E<br>\$FFF93F | RESE                       | RVED                    |  |  |  |  |  |

D

|          | SIM                        |                                      |  |  |  |  |  |
|----------|----------------------------|--------------------------------------|--|--|--|--|--|
| Address  | 15 8                       | 7 0                                  |  |  |  |  |  |
| \$FFFA00 | MODULE CONFIG              | URATION (SIMCR)                      |  |  |  |  |  |
| \$FFFA02 | FACTORY T                  | EST (SIMTR)                          |  |  |  |  |  |
| \$FFFA04 | CLOCK SYNTHESIZE           | CLOCK SYNTHESIZER CONTROL (SYNCR)    |  |  |  |  |  |
| \$FFFA06 | NOT USED                   | RESET STATUS (RSR)                   |  |  |  |  |  |
| \$FFFA08 | MODULE TES                 | ST E (SIMTRE)                        |  |  |  |  |  |
| \$FFFA0A | NOT USED                   | NOT USED                             |  |  |  |  |  |
| \$FFFA0C | NOT USED                   | NOT USED                             |  |  |  |  |  |
| \$FFFA0E | NOT USED                   | NOT USED                             |  |  |  |  |  |
| \$FFFA10 | NOT USED                   | PORTE DATA (PORTE0)                  |  |  |  |  |  |
| \$FFFA12 | NOT USED                   | PORTE DATA (PORTE1)                  |  |  |  |  |  |
| \$FFFA14 | NOT USED                   | PORTE DATA DIRECTION (DDRE)          |  |  |  |  |  |
| \$FFFA16 | NOT USED                   | PORTE PIN ASSIGNMENT (PEPAR)         |  |  |  |  |  |
| \$FFFA18 | NOT USED                   | PORTF DATA (PORTF0)                  |  |  |  |  |  |
| \$FFFA1A | NOT USED                   | PORTF DATA (PORTF1)                  |  |  |  |  |  |
| \$FFFA1C | NOT USED                   | PORTF DATA DIRECTION (DDRF)          |  |  |  |  |  |
| \$FFFA1E | NOT USED                   | PORTF PIN ASSIGNMENT (PFPAR)         |  |  |  |  |  |
| \$FFFA20 | NOT USED                   | SYSTEM PROTECTION CONTROL<br>(SYPCR) |  |  |  |  |  |
| \$FFFA22 | PERIODIC INTERRU           | PT CONTROL (PICR)                    |  |  |  |  |  |
| \$FFFA24 | PERIODIC INTERR            | UPT TIMING (PITR)                    |  |  |  |  |  |
| \$FFFA26 | NOT USED                   | SOFTWARE SERVICE (SWSR)              |  |  |  |  |  |
| \$FFFA28 | NOT USED                   | NOT USED                             |  |  |  |  |  |
| \$FFFA2A | NOT USED                   | NOT USED                             |  |  |  |  |  |
| \$FFFA2C | NOT USED                   | NOT USED                             |  |  |  |  |  |
| \$FFFA2E | NOT USED                   | NOT USED                             |  |  |  |  |  |
| \$FFFA30 | TEST MODULE MASTE          | R SHIFT A (TSTMSRA)                  |  |  |  |  |  |
| \$FFFA32 | TEST MODULE MASTE          | R SHIFT B (TSTMSRB)                  |  |  |  |  |  |
| \$FFFA34 | TEST MODULE SHI            | FT COUNT (TSTSC)                     |  |  |  |  |  |
| \$FFFA36 | TEST MODULE REPETIT        | TION COUNTER (TSTRC)                 |  |  |  |  |  |
| \$FFFA38 | TEST MODULE CONTROL (CREG) |                                      |  |  |  |  |  |
| \$FFFA3A | TEST MODULE DIS            | TRIBUTED (DREG)                      |  |  |  |  |  |
| \$FFFA3C | NOT USED                   | NOT USED                             |  |  |  |  |  |
| \$FFFA3E | NOT USED                   | NOT USED                             |  |  |  |  |  |
| \$FFFA40 | NOT USED                   | PORT C DATA (CSPDR)                  |  |  |  |  |  |
| \$FFFA42 | NOT USED                   | NOT USED                             |  |  |  |  |  |

|                                                                                                                 | SIM (CONTINU                 | JED)                                |  |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------|------------------------------|-------------------------------------|--|--|--|--|--|
| Address                                                                                                         | 15 8                         | 7 0                                 |  |  |  |  |  |
| \$FFFA44                                                                                                        | CHIP-SELECT PIN AS           | SIGNMENT (CSPAR0)                   |  |  |  |  |  |
| \$FFFA46                                                                                                        | CHIP-SELECT PIN AS           | CHIP-SELECT PIN ASSIGNMENT (CSPAR1) |  |  |  |  |  |
| \$FFFA48                                                                                                        | CHIP-SELECT BAS              | E BOOT (CSBARBT)                    |  |  |  |  |  |
| \$FFFA4A                                                                                                        | CHIP-SELECT OPTI             | ON BOOT (CSORBT)                    |  |  |  |  |  |
| \$FFFA4C                                                                                                        | CHIP-SELECT B                | ASE 0 (CSBAR0)                      |  |  |  |  |  |
| \$FFFA4E                                                                                                        | CHIP-SELECT O                | PTION 0 (CSOR0)                     |  |  |  |  |  |
| \$FFFA50                                                                                                        | CHIP-SELECT B                | ASE 1 (CSBAR1)                      |  |  |  |  |  |
| \$FFFA52                                                                                                        | CHIP-SELECT OI               | PTION 1 (CSOR1)                     |  |  |  |  |  |
| \$FFFA54                                                                                                        | CHIP-SELECT B                | ASE 2 (CSBAR2)                      |  |  |  |  |  |
| \$FFFA56                                                                                                        | CHIP-SELECT O                | PTION 2 (CSOR2)                     |  |  |  |  |  |
| \$FFFA58                                                                                                        | CHIP-SELECT B                | ASE 3 (CSBAR3)                      |  |  |  |  |  |
| \$FFFA5A                                                                                                        | CHIP-SELECT OPTION 3 (CSOR3) |                                     |  |  |  |  |  |
| \$FFFA5C                                                                                                        | CHIP-SELECT BASE 4 (CSBAR4)  |                                     |  |  |  |  |  |
| \$FFFA5E                                                                                                        | CHIP-SELECT OPTION 4 (CSOR4) |                                     |  |  |  |  |  |
| \$FFFA60                                                                                                        | CHIP-SELECT BASE 5 (CSBAR5)  |                                     |  |  |  |  |  |
| \$FFFA62                                                                                                        | CHIP-SELECT OF               | PTION 5 (CSOR5)                     |  |  |  |  |  |
| \$FFFA64                                                                                                        | CHIP-SELECT B                | ASE 6 (CSBAR6)                      |  |  |  |  |  |
| \$FFFA66                                                                                                        | CHIP-SELECT OI               | PTION 6 (CSOR6)                     |  |  |  |  |  |
| \$FFFA68                                                                                                        | CHIP-SELECT B                | ASE 7 (CSBAR7)                      |  |  |  |  |  |
| \$FFFA6A                                                                                                        | CHIP-SELECT OI               | PTION 7 (CSOR7)                     |  |  |  |  |  |
| \$FFFA6C                                                                                                        | CHIP-SELECT B                | ASE 8 (CSBAR8)                      |  |  |  |  |  |
| \$FFFA6E                                                                                                        | CHIP-SELECT OI               | PTION 8 (CSOR8)                     |  |  |  |  |  |
| \$FFFA70                                                                                                        | CHIP-SELECT B                | ASE 9 (CSBAR9)                      |  |  |  |  |  |
| \$FFFA72                                                                                                        | CHIP-SELECT O                | PTION 9 (CSOR9)                     |  |  |  |  |  |
| \$FFFA74                                                                                                        | CHIP-SELECT BA               | SE 10 (CSBAR10)                     |  |  |  |  |  |
| \$FFFA76                                                                                                        | CHIP-SELECT OP               | TION 10 (CSOR10)                    |  |  |  |  |  |
| \$FFFA78                                                                                                        | NOT USED                     | NOT USED                            |  |  |  |  |  |
| \$FFFA7A                                                                                                        | NOT USED                     | NOT USED                            |  |  |  |  |  |
| \$FFFA7C                                                                                                        | NOT USED                     | NOT USED NOT USED                   |  |  |  |  |  |
| \$FFFA7E                                                                                                        | NOT USED                     | NOT USED                            |  |  |  |  |  |
| the second se |                              |                                     |  |  |  |  |  |

D

|                      | SRAM                                                  |                             |  |  |  |  |  |  |
|----------------------|-------------------------------------------------------|-----------------------------|--|--|--|--|--|--|
| Address              | 15 8                                                  | 7 0                         |  |  |  |  |  |  |
| \$FFFB00             | RAM MODULE CONFIGURA                                  | TION REGISTER (RAMMCR)      |  |  |  |  |  |  |
| \$FFFB02             | RAM TEST REG                                          | ISTER (RAMTST)              |  |  |  |  |  |  |
| \$FFFB04             | RAM ARRAY BASE ADDRESS                                | S REGISTER HIGH (RAMBAH)    |  |  |  |  |  |  |
| \$FFFB06             | \$FFFB06 RAM ARRAY BASE ADDRESS REGISTER LOW (RAMBAL) |                             |  |  |  |  |  |  |
|                      | QSM                                                   |                             |  |  |  |  |  |  |
| Address              | 15 8                                                  | 7 0                         |  |  |  |  |  |  |
| \$FFFC00             | QSM MODULE CONF                                       | GURATION (QSMCR)            |  |  |  |  |  |  |
| \$FFFC02             | QSM TES                                               | T (QTEST)                   |  |  |  |  |  |  |
| \$FFFC04             | QSM INTERRUPT LEVEL (QUILR)                           | QSM INTERRUPT VECTOR (QIVR) |  |  |  |  |  |  |
| \$FFFC06             | RESE                                                  | RESERVED                    |  |  |  |  |  |  |
| \$FFFC08             | SCI CONTROL 0 (SCCR0)                                 |                             |  |  |  |  |  |  |
| \$FFFC0A             | SCI CONTROL 1 (SCCR1)                                 |                             |  |  |  |  |  |  |
| \$FFFC0C             | SCI STATUS (SCSR)                                     |                             |  |  |  |  |  |  |
| \$FFFC0E             | SCI DATA (SCDR)                                       |                             |  |  |  |  |  |  |
| \$FFFC10             | RESERVED                                              |                             |  |  |  |  |  |  |
| \$FFFC12             | RESE                                                  | RVED                        |  |  |  |  |  |  |
| \$FFFC14             | RESERVED                                              | PQS DATA (PORTQS)           |  |  |  |  |  |  |
| \$FFFC16             | PQS PIN ASSIGNMENT (PQSPAR)                           | PQS DATA DIRECTION (DDRQS)  |  |  |  |  |  |  |
| \$FFFC18             | SPI CONTRO                                            | DL 0 (SPCR0)                |  |  |  |  |  |  |
| \$FFFC1A             | SPI CONTRO                                            | DL 1 (SPCR1)                |  |  |  |  |  |  |
| \$FFFC1C             | SPI CONTRO                                            | DL 2 (SPCR2)                |  |  |  |  |  |  |
| \$FFFC1E             | SPI CONTROL 3 (SPCR3)                                 | SPI STATUS (SPSR)           |  |  |  |  |  |  |
| \$FFFC20<br>\$FFFCFF | RESERVED                                              |                             |  |  |  |  |  |  |
| \$FFFD00<br>\$FFFD1F | RECEIVE RA                                            | RECEIVE RAM (RR[0:F])       |  |  |  |  |  |  |
| \$FFFD20<br>\$FFFD3F | TRANSMIT F                                            | RAM (TR[0:F])               |  |  |  |  |  |  |
| \$FFFD40<br>\$FFFD4F | COMMAND F                                             | RAM (CR[0:F])               |  |  |  |  |  |  |

D

| Mnemonic   | Name                                     | Register Location    |
|------------|------------------------------------------|----------------------|
| ADDR[15:3] | Base Address                             | CSBAR[0:10], CSBARBT |
| AVEC       | Autovector Enable                        | CSOR[0:10], CSORBT   |
| BITS       | Bits Per Transfer                        | SPCR0                |
| BITSE      | Bits Per Transfer Enable                 | QSPI Command RAM     |
| BLKSZ      | Block Size                               | CSBAR[0:10], CSBARBT |
| BME        | Bus Monitor External Enable              | SYPCR                |
| BMT[1:0]   | Bus Monitor Timing                       | SYPCR                |
| BYTE       | Upper/Lower Byte Option                  | CSOR[0:10], CSORBT   |
| с          | Carry Flag                               | CCR                  |
| CCF[7:0]   | Conversion Complete Flags                | ADSTAT               |
| CCTR[2:0]  | Conversion Counter                       | ADSTAT               |
| CONT       | Continue                                 | QSPI Command RAM     |
| CPHA       | Clock Phase                              | SPCR0                |
| CPOL       | Clock Polarity                           | SPCR0                |
| CPROUT     | Compare/Capture Unit Clock Output Enable | TMSK2                |
| CPR[2:0]   | Timer Prescaler/PCLK Select Field        | TMSK2                |
| CPTQP      | Completed Queue Pointer                  | SPSR                 |
| CR[0:F]    | Command RAM                              | QSPI RAM             |
| CSOR[0:10] | Chip Select Option Registers             | CSOR[0:10], CSORBT   |
| DSACK      | Data Strobe Acknowledge                  | CSOR[0:10], CSORBT   |
| DSCK       | PCS to SCK Delay                         | QSPI Command RAM     |
| DSCKL      | Delay before SCK                         | SPCR1                |
| DT         | Delay after Transfer                     | QSPI Command RAM     |
| DTL        | Length of Delay after Transfer           | SPCR1                |
| EDGE[4:1]  | Input Capture Edge Control               | TCTL2                |
| EDIV       | ECLK Divide Rate                         | SYNCR                |
| ENDQP      | Ending Queue Pointer                     | SPCR2                |
| EV         | Extension Bit Overflow Flag              | CCR                  |
| EXOFF      | External Clock Off                       | SIMCR                |
| EXT        | External Reset                           | RSR                  |
| F1A        | Force Logic Level One on PWMA            | PWMC                 |
| F1B        | Force Logic Level One on PWMB            | PWMC                 |
| FE         | Framing Error                            | SCSR                 |
| FOC[5:1]   | Force Output Compare                     | CFORC                |
| FPWMA      | Force PWMA Value                         | CFORC                |
| FPWMB      | Force PWMB Value                         | CFORC                |

Table D-8. Register Bit and Field Mnemonics

| FRZBM           | Freeze Bus Monitor Enable             | SIMCR              |
|-----------------|---------------------------------------|--------------------|
| FRZSW           | Freeze Software Enable                | SIMCR              |
| FRZ[1:0]        | Freeze                                | ADCMCR             |
| FRZ[1:0]        | FREEZE Response                       | GPTMCR             |
| FRZ[1:0]        | Freeze Control                        | QSMCR              |
| H               | Half Carry Flag                       | CCR                |
| HALT            | Halt                                  | SPCR3              |
| HALTA           | Halt Acknowledge Flag                 | SPSR               |
| HLT             | Halt Monitor Reset                    | RSR                |
| HME             | Halt Monitor Enable                   | SYPCR              |
| HMIE            | HALTA and MODF Interrupt Enable       | SPCR3              |
| 14/05           | Input Capture 4/Output Compare 5      | PACNT              |
| 14/05<br>14/05F |                                       | TFLG1              |
| 14/05F          | Input Capture 4/Output Compare 5 Flag |                    |
|                 | 14/05 Interrupt Enable                | TMSK1              |
|                 | Interrupt Arbitration                 | QSMCR              |
| IARB[3:0]       |                                       | GPTMCR             |
| IARB[3:0]       | Interrupt Arbitration Field           | SIMCR              |
| ICF[3:1]        | Input Capture Flags                   | TFLG1              |
| ICI[3:1]        | Input Capture Interrupt Enable        | TMSK1              |
| IDLE            | Idle-Line Detected                    | SCSR               |
| ILIE            | Idle-Line Interrupt Enable            | SCCR1              |
| ILQSPI          | Interrupt Level for QSPI              | QILR               |
| ILSCI           | Interrupt Level for SCI               | QILR               |
|                 | Idle-Line Detect Type                 | SCCR1              |
| INCP            | Increment Prescaler                   | GPTMCR             |
| INTV[7:0]       | Interrupt Vector Number               | QIVR               |
| IPA             | Interrupt Priority Adjust             | ICR                |
| IPL             | Interrupt Priority Level              | CSOR[0:10], CSORBT |
| IPL             | Interrupt Priority Level              | ICR                |
| IP[2:0]         | Interrupt Priority Field              | CCR                |
| IVBA            | Interrupt Vector Base Address         | ICR                |
| LJSRR           | Signed Left-Justified Result          | RSLT[0:7]          |
| LJURR           | Unsigned Left-Justified Result        | RSLT[0:7]          |
| LOC             | Loss of Clock Reset                   | RSR                |
| LOOPQ           | QSPI Loop Mode                        | SPCR3              |
| LOOPS           | Loop Mode                             | SCCR1              |
| м               | Mode Select                           | SCCR1              |
| MISO            | Master In Slave Out                   | DDRQS              |
| MISO            | Master In Slave Out                   | PQSPAR             |
| MM              | Module Mapping                        | SIMCR              |

# Table D-8. Register Bit and Field Mnemonics (Continued)

MOTOROLA D–52 APPENDIX D REGISTER SUMMARY

| MODE       | Asynchronous/Synchronous Mode               | CSOR[0:10], CSORBT |
|------------|---------------------------------------------|--------------------|
| MODF       | Mode Fault Flag                             | SPSR               |
| MOSI       | Master Out Slave In                         | DDRQS              |
| MOSI       | Master Out Slave In                         | PQSPAR             |
| MSTR       | Master/Slave Mode Select                    | SPCR0              |
| MULT       | Multichannel Conversion                     | ADCTL1             |
| MV         | Accumulator M Overflow Flag                 | CCR                |
| N          | Negative Flag                               | CCR                |
| NEWQP      | New Queue Pointer Value                     | SPCR2              |
| NF         | Noise Error                                 | SCSR               |
| OC1D[5:1]  | OC1 Data                                    | OC1D               |
| OC1M[5:1]  | OC1 Mask                                    | OC1M               |
| OCF[4:1]   | Output Compare Flags                        | TFLG1              |
| OCI[4:1]   | Output Compare Interrupt Enable             | TMSK1              |
| OM[5:2]    | Output Compare Mode Bits                    | TCTL1              |
| OL[5:2]    | Output Compare Level Bits                   | TCTL1              |
| OR         | Overrun Error                               | SCSR               |
| PACLK[1:0] | Pulse Accumulator Clock Select (Gated Mode) | PACNT              |
| PAEN       | Pulse Accumulator Enable                    | PACNT              |
| PAIF       | Pulse Accumulator Flag                      | TFLG2              |
| PAII       | Pulse Accumulator Input Interrupt Enable    | TMSK2              |
| PAIS       | PAI Pin State (Read Only)                   | PACNT              |
| PAMOD      | Pulse Accumulator Mode                      | PACNT              |
| PAOVF      | Pulse Accumulator Overflow Flag             | TFLG2              |
| PAOVI      | Pulse Accumulator Overflow Interrupt Enable | TMSK2              |
| PCLKS      | PCLK Pin State (Read Only)                  | PACNT              |
| PCS0/SS    | Peripheral Chip Select 0/Slave Select       | PQSPAR             |
| PCS[3:0]   | Peripheral Chip Select                      | QSPI command RAM   |
| PCS[3:1]   | Peripheral Chip Selects                     | PQSPAR             |
| PE         | Parity Enable                               | SCCR1              |
| PEDGE      | Pulse Accumulator Edge Control              | PACNT              |
| PF         | Parity Error                                | SCSR               |
| PIRQL[2:0] | Periodic Interrupt Request Level            | PICR               |
| PITM[7:0]  | Periodic Interrupt Timing Modulus           | PITR               |
| PIV[7:0]   | Periodic Interrupt Vector                   | PICR               |
| PK[3:0]    | Program Counter Address Extension Field     | CCR                |
| PORTQS     | Port QS Data Register                       | QIVR               |
| POW        | Power-Up Reset                              | RSR                |
| PPROUT     | PWM Clock Output Enable                     | PWMC               |
| PPR[2:0]   | PWM Prescaler/PCLK Select                   | PWMC               |

| PRS[4:0]  | Prescaler Rate Selection              | ADCTLO             |
|-----------|---------------------------------------|--------------------|
| PT        | Parity Type                           | SCCR1              |
| PTP       | Periodic Timer Prescaler Control      | PITR               |
| R/W       | Read/Write                            | CSOR[0:10], CSORBT |
| RAF       | Receiver Active                       | SCSR               |
| RASP[1:0] | RAM Array Space                       | RAMMCR             |
| RDRF      | Receive Data Register Full            | SCSR               |
| RE        | Receiver Enable                       | SCCR1              |
| RES10     | 10-Bit Resolution                     | ADCTL0             |
| RIE       | Receiver Interrupt Enable             | SCCR1              |
| RJURR     | Unsigned Right-Justified Result       | RSLT[0:7]          |
| RLCK      | RAM Base Address Lock                 | RAMMCR             |
| RR[0:F]   | Receive Data Ram                      | QSPI RAM           |
| RSTEN     | Reset Enable                          | SYNCR              |
| RWU       | Receiver Wakeup                       | SCCR1              |
| S         | STOP Enable                           | CCR                |
| S8CM      | Select Eight-Conversion Sequence Mode | ADCTL1             |
| SBK       | Send Break                            | SCCR1              |
| SCAN      | Scan Mode Selection                   | ADCTL1             |
| SCBR      | SCI Baud Rate                         | SCCR0              |
| SCF       | Sequence Complete Flag                | ADSTAT             |
| SCK       | Serial Clock                          | DDRQS              |
| SFA       | PWMA Slow/Fast Select                 | PWMC               |
| SFB       | PWMB Slow/Fast Select                 | PWMC               |
| SHEN[1:0] | Show Cycle Enable                     | SIMCR              |
| SLIMP     | Limp Mode                             | SYNCR              |
| SLOCK     | Synthesizer Lock                      | SYNCR              |
| SLVEN     | Factory Test Mode Enabled             | SIMCR              |
| SM        | Saturate Mode Bit                     | CCR                |
| SPACE     | Address Space Select                  | CSOR[0:10], CSORBT |
| SPBR      | Serial Clock Baud Rate                | SPCR0              |
| SPE       | QSPI Enable                           | SPCR1              |
| SPIF      | QSPI Finished Flag                    | SPSR               |
| SPIFIE    | SPI Finished Interrupt Enable         | SPCR2              |
| STEXT     | Stop Mode External Clock              | SYNCR              |
| STOP      | STOP Mode                             | ADCMCR             |
| STOP      | Stop Clocks                           | GPTMCR             |
| STOP      | Stop Enable                           | QSMCR              |
| STOP      | Stop Control                          | RAMMCR             |
| STOPP     | Stop Prescaler                        | GPTMCR             |

# Table D-8. Register Bit and Field Mnemonics (Continued)

| · · · · · · · · · · · · · · · · · · · |                                    |                    |
|---------------------------------------|------------------------------------|--------------------|
| STRB                                  | Address Strobe/Data Strobe         | CSOR[0:10], CSORBT |
| STSIM                                 | Stop Mode System Integration Clock | SYNCR              |
| STS[1:0]                              | Sample Time Selection              | ADCTL0             |
| SUPV                                  | Supervisor/Unrestricted            | ADCMCR             |
| SUPV                                  | Supervisor/Unrestricted            | GPTMCR             |
| SUPV                                  | Supervisor/Unrestricted            | QSMCR              |
| SUPV                                  | Supervisor/Unrestricted            | SIMCR              |
| SW                                    | Software Watchdog Reset            | RSR                |
| SWE                                   | Software Watchdog Enable           | SYPCR              |
| SWP                                   | Software Watchdog Prescale         | SYPCR              |
| SWT[1:0]                              | Software Watchdog Timing           | SYPCR              |
| SYS                                   | System Reset                       | RSR                |
| тс                                    | Transmit Complete                  | SCSR               |
| TCIE                                  | Transmit Complete Interrupt Enable | SCCR1              |
| TDRE                                  | Transmit Data Register Empty       | SCSR               |
| TE                                    | Transmitter Enable                 | SCCR1              |
| TIE                                   | Transmit Interrupt Enable          | SCCR1              |
| TOF                                   | Timer Overflow Flag                | TFLG2              |
| TOI                                   | Timer Overflow Interrupt Enable    | TMSK2              |
| TR[0:F]                               | Transmit Data Ram                  | QSPI RAM           |
| TST                                   | Test Submodule Reset               | RSR                |
| TXD                                   | Transmit Data                      | DDRQS              |
| v                                     | Overflow Flag                      | CCR                |
| w                                     | Frequency Control (VCO)            | SYNCR              |
| WAKE                                  | Wakeup by Address Mark             | SCCR1              |
| WOMQ                                  | Wired-OR Mode for QSPI Pins        | SPCR0              |
| WOMS                                  | Wired-OR Mode for SCI Pins         | SCCR1              |
| WREN                                  | Wrap Enable                        | SPCR2              |
| WRTO                                  | Wrap To                            | SPCR2              |
| x                                     | Frequency Control Bit (Prescale)   | SYNCR              |
| Y[5:0]                                | Frequency Control (Counter)        | SYNCR              |
| Z                                     | Zero Flag                          | CCR                |
| [CD:CA]                               | Channel Selection                  | ADCTL1             |

# Table D-8. Register Bit and Field Mnemonics (Continued)

MOTOROLA D-56 APPENDIX D REGISTER SUMMARY

# INDEX

#### – A –

Abort ADC conversion sequence and halt 6-7 Abort ADC conversion sequence and start new sequence 1-7 Acceptable bus cycle terminations for asynchronous cycles 4-51 Accumulators 5-3 Accumulator A (A) 2-2, 5-3 Accumulator B (B) 2-2, 5-3 Accumulator D (D) 2-2, 5-3 Accumulator E (E) 2-2, 5-3 Accumulator M (AM) 2-2, 5-3 Accumulator M overflow flag (MV) 2-2, 5-4 Analog-to-Digital Converter Module (ADC) 6-1 Analog input signals (AN[7:0]) 2-3, 3-5, 3-7, 3-8.6-3 Analog subsystem 6-5 Buffer amplifier 6-6 Bus interface unit (ABIU) 6-4 Channels share buffer amplifier 6-6 Clock and prescaler control 6-7 Clock cycles required for sample period 6-8 Clock derived from system clock 6-7 Clock speed 6-8 Comparator 6-7 Control and status registers remain valid while frozen 6-5 Control register 0 (ADCTL0) 6-7 Control register 1 (ADCTL1) 6-8 Conversion channel 6-9 Conversion control logic 6-9 Conversion modes 6-9 Conversion parameters 6-9 Conversion time 6-14 Conversions performed in sequences 6-9 Differential and buffered data buses 6-3

Digital control subsystem 6-7 Features 3-2 Input channel sample capacitor 6-6 Low-power stop mode 6-4 Module base address 6-3 Module configuration register (ADCMCR) 6-4 Multiplexer 6-5 Port A (PADA) 2-3 Power connections (VDDA and VSSA) 2-4, 3-6, 6-3 Prescaler 6-7 RC DAC array 6-6 Reference voltage connections (VRH and VRI) 2-4.3-6.6-3 Resolution 6-8 Resolution time 6-14 Result changes while frozen 6-5 Result registers (RSLT[0:7]) 6-16 Result registers read from three addresses 6-16 Status register (ADSTAT) 6-9 Successive approximation register (SAR) 6-16 Transfer and resolution require a minimum of 16 adc clocks 6-14 Transfer time 6-14 Addition and subtraction instructions 5-14 ADDR0 indicates byte offset from base address 4-25 Address bus (ADDR[23:0]) 2-3, 3-5, 3-7, 3-8, 4-21, 4-41, 4-42, 4-45 Address bus convention 2-5 Address extension 5-6 Address extension fields 5-5 Extended addressing extension field (EK) 2-2 Index register X extension field (XK) 2-2 Index register Y extension field (YK) 2-2 Index register Z extension field (ZK) 2-2 Program counter extension field (PK) 2-2, 5-5

MC68HC16Z1 USER'S MANUAL INDEX

Stack Pointer Extension Field (SK) 2-2, 5-5 Address extension fields used in different types of access 5-6 Address extension instructions 5-30 Address extension register (K) 2-2 Address space 3-10, 4-46, 4-88, 5-1 Address space encoding 4-23, 5-3 Address strobe (AS) 2-3, 3-5, 3-7, 3-8, 4-21, 4-39, 4-41, 4-42, 4-45, 4-90 Address-mark wakeup 7-33 Addresses effectively 20 bits wide 5-6 Addressing modes 5-9 Accumulator offset addressing mode 5-11 Extended addressing modes 5-10 Immediate addressing modes 5-10 Indexed addressing modes 5-10 Inherent addressing mode 5-10 Post-modified index addressing mode 5-11 Program counter relative addressing mode 9-2 Relative addressing modes 5-11 Alianed word 4-25 Amount of data transferred by bus cycle 4-25 Analog input pins (AN[7:0]) 3-5, 3-7, 3-8, 6-3 Analog reference pins (VRH and VRL) 3-6, 6-3 Analog supply pins (VDDA and VSSA) 3-6, 6-3 Application of system and clock synthesizer power 4-69 Arbitration between interrupt requests 4-4 Arbitration between simultaneous requests of the same priority 4-73 Arbitration must always take place 4-74 Arbitration scheme 4-74 Asserted 2-5 Asserting AVEC to terminate interrupt acknowledge cycle 4-79 Assertion of BG is subject to constraints 4-57 Assignable interrupt vectors 4-72 Asynchronous bus cycles 4-21 Asynchronous exceptions 5-63 Asynchronous input hold times 4-38 Asynchronous input setup time 4-38 Automatic interrupt vectors 4-72 Autovector number corresponds to interrupt priority level 4-79

Autovector operation timing 4–80 Autovector signal (AVEC) 2–3, 3–5, 3–7, 3–8, 4–5, 4–23, 4–79 Auxiliary timer clock input signal (PCLK) 3–5, 3–7, 3–8, 8–8

## - B -

Background debugging mode (BDM) 5-37, 5-67 Commands 5-68 Serial interface 5-69 Sources 5-67 Background mode and null operations 5-37 Bank switching 5-6 Base address 3-11 Base state of QSPI peripheral chip-select signal 7-23 Basic instruction formats 5-58 Basic operand size 4-25 Basic system 4-19 Baud rate 7-19 Baud rate must be set before SCI is enabled 7-24 BCD packing 5-7 Binary coded decimal instructions 5-15 Bit cleared 2-5 Bit condition branch instructions 5-27 Bit set 2-5 Bit test and manipulation instructions 5-19 Block of addresses enabled by a chip select 4-84 Block size 4-85 Boolean 0 2-5 Boolean 1 2-5 Boolean logic instructions 5-18 Boot ROM chip-select signal (CSBOOT) 2-3, 3-5, 3-7, 3-8, 4-63, 4-95 Boot ROM port size 4-63 Boot ROM select signal automatically asserted out of reset 4-82 Bootstrap operation 4-85, 4-95 Break frame 7-28, 7-31 Breakpoint 5-66 Breakpoint acknowledge cycle 4-46, 4-47, 4-49 Breakpoint acknowledge cycle timing 4-49 Breakpoint exception processing 4-47 Breakpoint mode selection 4-64 Breakpoint number field 4-47

MOTOROLA

Breakpoint operation 4-48 Breakpoints initiate exception processing or background debugging 5-66 Breakpoints on any memory access 5-66 Breakpoints on instructions flushed from the pipeline 5-66 Breakpoint source and type 4-47 Breakpoint signal (BKPT) 2-3, 3-5, 3-7, 3-8, 4-47, 5-66 BKPT reset state affects subsequent assertions 4-61 Bus allocation for chip-select transfers 4-87 Bus arbitration 4-53, 4-56, 4-58 Bus arbitration control 4-57 Bus arbitration protocols 4-54 Bus arbitration requests 4-54 Bus clock for MC6800 devices (ECLK) 4-18 Bus cycle 4-38, 5-60 Regular bus cycles 4-38, 4-39 Required for operand accesses 5-60 Required to prefetch instruction 5-60 Not terminated 4-50 Bus error 4-52 Bus error condition 4-23 Bus error exception processing 4-52 Bus error while HALT is asserted 4-53 Bus error signal (BERR) 2-3, 3-5, 3-7, 3-8, 4-23, 4-39, 4-40, 4-50, 4-51, 4-53 BERR does not force immediate exception processing 4-52 BERR not detected until an instruction is complete 4-52 Bus exception control cycles 4-50 Bus grant 4-57 Bus grant signal (BG) 2-3, 3-5, 3-7, 3-8, 4-55, 4-57 BG asserted at end of operand transfer 4-55 BG asserted in response to BR 4-55 BG indicates bus is available 4-55 Bus grant acknowledge 4-57 Bus grant acknowledge signal (BGACK) 2-3, 3-5, 3-7, 3-8, 4-55 BGACK indicates bus mastership 4-55 Bus loading can overcome data bus pull-up drivers 4-62

Bus master 4-54, 4-56, 4-57 Bus monitor 4-5, 4-6, 4-23, 4-39 Monitor period 4-5 Bus request 4-56 Bus request signal (BR) 2-3, 3-5, 3-7, 3-8, 4-55, 4-56, 4-57 BR asserted during a bus cycle or between cycles 4-55 Bus signals 4-21 Byte 5-7

#### - C -

Carry flag (C) 2-2, 5-5 CCR bits that are not initialized are not affected by reset 4-71 Changes in program flow 5-60 Changing SCI control bits can disrupt operation 7-24 Chip selects 4-1, 4-80 Assertion 4-81 Base address register boot ROM (CSBARBT) 4-85. 4-95 Base address registers (CSBAR) 4-84 Block size 4-85 Generates internal AVEC 4-89 Logic and external interrupt acknowledge cycles 4-89 **Operation 4-90** Option register boot ROM (CSORBT) 4-95 Option register function 4-86 Option registers (CSOR) 4-86 Option registers and internal DSACK 4-43 Pin assignment registers (CSPAR) 4-83 Pin data register (CSPDR) 4-89 Pin functions 4-83 Registers 4-82 Reset operation 4-82, 4-84, 4-95 Set up for CPU space access 4-88 Signals (CS[10:0]) 2-3, 3-5, 3-7, 3-8, 4-95 Synchronized to ECLK 4-87 Clear 2-5 Clear, complement and negate instructions 5-18 Clearing GPT status flags 8-7 CLKOUT signal 2-3, 3-5, 3-7, 3-8, 4-12 Clock, system 4-10

MC68HC16Z1 USER'S MANUAL

I--3

Control 4-14, 4-19 Mode select signal (MODCLK) 2-3, 3-5, 3-7, 3-8, 4-7, 4-8, 4-9 Mode selection 4-64 Operation during low-power stop 4-18 Rate changes 4-10 Rate during operation 4-10 Reference from exiternal source 4-12 Reference signal 4-12 Signal duty cycle and period 4-12 Signal from external source 4-11 Sources 4-11 Synthesizer operation 4-12 Synthesizer power connection (VDDSYN) 2-4, 3-6. 4-12. 4-69 Coherency 4-57, 7-2 Combined program and data spaces 3-13 Combining opcode tracking with other capabilities 5-66 Command RAM 7-9 Not used in slave mode 7-22 Compare and test instructions 5-16 Comparison of CPU16 and MC68HC11 instruction sets 5-55 Compatibility with the MC68HC11 5-1 Completed queue pointer (CPTQP) 7-10, 7-21 Completed queue pointer (CPTQP) 7-10, 7-21 Completion of a bus cycle 4-24 Condition Code Register (CCR) 2-2, 5-4 Condition code instructions 5-34 Conditioning mode select signals 4-62 Conditions for external bus mastership 4-55 Connecting GPT multiplexer outputs to external pins 8-10 Content of ADC control and status registers remain valid while frozen 6-5 Content of ADC result registers changes while frozen 6-5 Continuous A/D conversion 6-9 Control logic drives RESET pin low 4-68 Control registers, location in memory map 3-11 Conventions 2-5 Conversion channel 6-9 Conversion control logic 6-9

Conversion modes 6-9 Conversion parameters 6-9 CPU can set STOP bits in module configuration registers 4-18 CPU space 4-22, 4-73 CPU space address encoding 4-46 CPU space cycles 4-46 CPU space type field 4-76 CPU treats external interrupt requests as SIM interrupts 4-72 Central Processing Unit (CPU16) 5-1 Execution model 5-58 Execution process 5-60 Execution unit 5-58, 5-59 Features 3-1 Indexed addressing mode replaces HC11 direct mode 5-11 Initiates QSPI operation 7-10 Microsequencer 5-58, 5-59 Register mnemonics 2-2 Register model 5-2 Supports one source and type of breakpoint 4-47 CSBOOT automatically asserted out of reset 4-82

## – D –

DATA mnemonic 2-5 Data and size acknowledge signals (DSACK[1:0]) 2-3, 3-5, 3-7, 3-8, 4-23, 4-5, 4-34 to 4-51, 4-74, 4-90 Effect of DSACK signals 4-24 Data bus mode selection 4-62, 4-63 Data bus signals (DATA[15:0]) 2-3, 3-5, 3-7, 3-8, 4-21, 4-43 Data frame 7-28 Data in QSPI receive RAM right-justified 7-8 Data lines have weak internal pull-up drivers 4-62 Data movement instructions 5-11 Data strobe signal (DS) 2-3, 3-5, 3-7, 3-8, 4-22, 4-39, 4-41, 4-45, 4-59, 4-90 DS assertion during fast termination read cycles 4-44 Data types 5-6 4-bit bank address 5-6 4-bit signed integers 5-6

## MOTOROLA

8-bit signed and unsigned integers 5-6 8-bit, 2-digit binary coded decimal numbers 5-6 16-bit byte address 5-6 16-bit fractions 5-6 16-bit signed fractions 5-6 20-bit addresses 5-6 20-bit effective address 5-6 32-bit signed and unsigned integers 5-6 32-bit signed fractions 5-6 36-bit signed fixed-point numbers 5-6 Decrement and increment instructions 5-17 Delay after QSPI peripheral chip-select assertion 7-19 Delay after QSPI transfer 7-20 Delay before assertion of QSPI serial clock 7-19 Delay between QSPI transfers 7-20 Deskewing signals 4-38 Deterministic opcode tracking 5-65 Development support 5-65 Development serial clock signal (DSCLK) 2-3, 3-5. 3-7. 3-8. 5-69 Development serial input signal (DSI) 2-3, 3-5, 3-7.3-8.5-69 Development serial output signal (DSO) 2-3, 3-5, 3-7.3-8.5-69 Digital signal processing 5-71 Digital signal processing instructions 5-34 Division instructions 5-16 Double bus fault 4-52 Occurs in two ways 4-52 Driver types 3-6 DSACK generator shared by chip-select circuits 4-81 DSACK, BERR, and HALT assertion results 4-51 Duty cycle of clock signals on OC1 and PWMA 8-10 Duty cycle ratios of PWM channels 8-17 Dynamic bus sizing 4-20, 4-24, 5-61

## – E –

EBI data multiplexer 4–25 ECLK frequency 4–18 Edge-detection logic 8–11, 8–13 Effect of DSACK signals 4–24 Effect of parity checking 7–30 Enabling BDM 5–67

MC68HC16Z1 USER'S MANUAL

Enabling SCI parity affects number of data bits in frame 7-29 End queue pointer (ENDQP) 7-10 Entering BDM 5-68 Event counting mode, pulse accumulator 8-16 Exception 5-61 Handler routine 5-61 Priority 5-64 Processing 4-60, 4-72, 5-61, 5-63, 5-64, 7-4, 8--6 Stack frame 5-62 Vector 3-11, 5-61, 7-4, 8-6 Vector number 4-73 Vector table 5-61, 7-4, 8-6 Vectors reside in data space 5-61 Excessively long DSACK or AVEC response times 4-5 Exchange instructions 5-14 Execution model 5-58 Execution of LPSTOP instruction 4-50 Execution process 5-60 Execution unit 5-58, 5-59 Extended addressing extension field (EK) 2-2 Extended addressing modes 5-10 Extension bit overflow flag (EV) 5-4 Extension fields 5-6 Extension words 5-68 External address spaces 4-22 External arbitration circuitry 4-55 External bus 4-1 Arbitration 4-20, 4-53, 4-54 Clock signal (ECLK) 3-5, 3-7, 3-8, 4-18 Control logic 4-39 Cycle terminated by external AVEC 4-79 Cycles 4-6 Interface (EBI) 4-1, 4-19 Monitor 4-6 External bus master 4-55 External crystal oscillator connections (EXTAL, XTAL) 2-3, 2-4, 4-9 External device asserts BERR 4-50 External device asserts **RESET** 4-68 External device must decode interrupt mask value 4-74

External exceptions 5-63 External filter capacitor pin (XFC) 2-4, 4-12 External interrupt request 4-4, 4-72, 4-74 External interrupt requests treated as SIM interrupts 4-72 External loading can overcome data bus pull-up drivers 4-62 External logic on input/output or output-only pins 4-69 External low-leakage capacitor for system clock synthesizer 4-12 External peripheral power connetions (VDDE and VSSE) 2-4 External peripheral power pins (VDDE, VSSE) 2-4 External pull-up resistor on TXD pin 7-30 External RESET line asserted until clock synthesizer PLL locks 4-69 External system clock reference signal 4-12 External system clock signal 4-12 Externally generated DSACK 4-43

#### - F -

Factory test mode 4-5 Factory test mode arbitration 4-59 Fast termination cycles 4-38, 4-43, 4-45 Encoding 4-88 Read cycle 4-45 Write cycle 4-45 First two portions of ADC sample periods require four clock cycles 6-8 Forced output compare 8-15 Format of ADC result depends on result register address 6-16 Fractional multiplication and division 5-16 Framing error 7-32 Freeze mode 4-10, 7-4, 8-3 Bus monitor 4-10 Operation 4-10, 5-67 Signal (FREEZE) 2-3, 4-10. 5-68, 6-10 Software watchdog 4-10 Function code signals (FC[2:0]) 2-3, 3-5, 3-7, 3-8, 4-22, 4-41, 4-42, 4-45, 4-46, 4-76

General-purpose I/O ports Port ADA signals (PADA[7:0]) 2-3, 3-5, 3-7, 3-8.6-1 Port C signals (PC[6:0]) 2-3, 3-5, 3-7, 3-8, 4-89 Port C data register (CSPDR) 4-89 Port C pin assignment register (CSPAR) 4-83 Port E data direction register (DDRE) 4-96 Port E data register (PORTE) 4-97 Port E pin assignment register (PEPAR) 4-96 Port E signals (PE[7:0]) 2-3, 3-5, 3-7, 3-8, 4-96 Port F data direction register (DDRF) 4-96 Port F data register (PORTF) 4-97 Port F pin assignment register (PFPAR) 4-96 Port F signals (PF[7:0]) 2-3, 3-5, 3-7, 3-8, 4-96 Port GP data direction register (DDRGP) 8-8, 8-15 Port GP data register (PORTGP) 8-8 Port GP signals (PGP[7:0]) 2-3, 3-5, 3-7, 3-8, 8-8 Port QS data direction register (DDRQS) 7-5 Port QS data direction register (DDRQS) 7-18, 7-22 Port QS data register (PORTQS) 7-5 Port QS pin assignment register (PQSPAR) 7-5, 7-18.7-22 Port QS signals (POS[7:0]) 2-3, 3-5, 3-7, 3-8, 7-5 Port QS signals (PQS[7:0]) 2-3, 3-5, 3-7, 3-8, 7-5 General-purpose timer (GPT) 8-1 Activities in progress prior to FREEZE assertion 8-4 Capture/compare functions 8-11 Counter can be read without affecting its value 8-11 Counter cannot be stopped during normal operation 8-11 Debugging without BDM 8-4 Edge-detection logic 8-11, 8-13 Features 3-2 Force compare register (CFORC) 8-15 Freeze mode 8-3

Input capture (IC) functions 8-11

MOTOROLA I–6

Input pin synchronizers 8-3 Interrupt requests asserted until status flag cleared 8-7 Interrupt arbitration priority 8-6 Interrupt configuration register (ICR) 8-6 Interrupt priority hierarchy 8-7 Interrupt sources 8-6 Interrupts 8-5 Low-power stop operation 8-3 Module configuration register (GPTMCR) 8-3 Multiplexer outputs connected to external pins 8-10 OC1 action data register (OC1D) 8-15 OC1 action mask register (OC1M) 8-15 Output compare (OC) functions 8-8, 8-11, 8-14 Pin hysteresis 8-13 Pin synchronizers 8-13 Pins used for general-purpose I/O 8-8 Polled and interrupt-driven operation 8-4 Port GP data register (PORTGP) 2-3 Prescaler 8-9 Prescaler can be read at any time 8-9 Prescaler clock signal (PCLK) 2-3, 7-1, 7-8, 7-9, 7-11, 7-16, 7-19 Prescaler driven by system clock 8-9 Pulse-width modulation (PWM) unit 8-17 Single-step mode 8-4 Slow mode 8-17, 8-19 Status flags 8-4, 8-5, 8-7, 8-13 Timer control register 2 (TCTL2) 8-13 Timer counter (TCNT) 8-1, 8-9, 8-11, 8-14 Timer interrupt flag register 1 (TFLG1) 8-4, 8-5, 8-13, 8-14 Timer interrupt flag register 2 (TFLG2) 8-4, 8-5, 8-13, 8-14 Timer interrupt mask register 1 (TMSK1) 8-4, 8-5.8-13.8-14 Timer interrupt mask register 2 (TMSK2) 8-4, 8-5, 8-9, 8-11, 8-16 Timer prescaler 8-5

– H –

Half-carry flag (H) 2–2, 5–4 Halt monitor 4–6

MC68HC16Z1 USER'S MANUAL Halt monitor reset 4–6 Halt operation 4–53 Halt signal (HALT) 2–3, 3–5, 3–7, 3–8, 4–39, 4–40, 4–51, 4–53, 4–54 HALT affects external bus cycles only 4–53 HALT asserted while internal BERR asserted 4–79 HALT assertion causes single bus cycle operation 4–51 HALT timing 4–54 Handler routine 5–61 Handshaking between MCU and external peripherals 4–38

HC11 instructions 5-55

#### - 1 -

Idle frame 7-28 Idle-line detection 7-32 Idle-line wakeup 7-33 Immediate addressing modes 5-10 Implied radix point 5-7, 5-16 Index register 5-3 Index register X (IX) 2-2, 5-3 Index register Y (IY) 2-2, 5-3 Index register Z (IZ) 2-2, 5-3 Index register X extension field (XK) 2-2 Index register Y extension field (YK) 2-2 Index register Z extension field (ZK) 2-2 Indexed addressing modes 5-10 Indexing Instructions 5-30 Individual module STOP bits 4-18 Inherent addressing mode 5-10 Initial ADC sample and transfer times fixed at 2 cycles each 6-14 Initial sample time 6-14 Initiating SCI operation 7-21 Input capture (IC) functions 8-11 Edge transition 8-11 Events asynchronous to GPT timer 8-13 Functions operate independently 8-13 Occurs every time selected edge is detected 8-14 Registers 8-7, 8-13 Signals (IC[1:3]) 2-3, 3-5, 3-7, 3-8, 8-7

INDEX

Signals are conditioned 8-13 Input capture 4/output compare 5 register (IC4/OC5) 8-15 Input capture/output compare signal (IC4/OC5) 3-5, 3-7.3-8.8-7 Instruction extension words 5-68 Instruction fetches 5-7 Instruction format 5-57 Instruction pipeline 4-47,5-24, 5-26, 5-27, 5-29, 5-58. 5-59 State signals 3-5, 3-7, 3-8, 5-65 Pipeline states 5-65 Instruction pipeline signals (IPIPE[1:0]) 2-3 Multiplexing 5-65 Not usable in BDM 5-66 Instruction set 5-11 Instruction set abbreviations and symbols 5-54 Instruction set summary 5-38 Instruction timing 5-60 Instruction types 5-58 8-Bit Opcode with 4-Bit Index Extensions 5-58 8-Bit Opcode with 8-Bit Operand 5-58 8-Bit Opcode with 8-Bit Prebyte, Argument(s) 5-58 8-Bit Opcode with 8-Bit Prebyte, No Argument 5-58 8-Bit Opcode with 20-Bit Argument 5-58 Instructions Addition and subtraction instructions 5-14 Address extension instructions 5-30 Binary coded decimal instructions 5-15 Bit condition branch instructions 5-27 Bit test and manipulation instructions 5-19 Boolean logic instructions 5-18 Clear, complement and negate instructions 5-18 Compare and test instructions 5-16 Condition code instructions 5-34 Data movement instructions 5-11 Decrement and increment instructions 5-17 Digital signal processing instructions 5-34 Exchange instructions 5-14 Indexing instructions 5-30 Interrupt instructions 5-23, 5-29 Jump instructions 5-23, 5-28

Load instructions 5-12 Long branch instructions 5-25 Mathematic instructions 5-14 Move instructions 5-12 Multiplication instructions 5-16 Program control instructions 5-23 Shift and rotate instructions 5-20 Short branch instructions 5-23 Stack operation instructions 5-32 Stack pointer instructions 5-32 Stacking instructions 5-32 Stop and wait instructions 5-36 Store instructions 5-13 Subroutine instructions 5-23, 5-28 Transfer instructions 5-13 Unary branch instructions 5-23, 5-25 Instructions from previous stream removed from pipeline 5-60 Interface signal timing constraints 4-38 Intermodule bus 3–10 Internal and external breakpoint signals 4-64 Internal cycles continue when external bus is granted away 4--59 Internal handshaking signals generated by chipselect logic 4-43 Internal loop 7-34 Internal module power connections (VDDI and VSSI) 2-4 Internal or external frequency source 4-11 Internal oscillator 4-11 Internal phase-locked loop 4-11 Internal pull-up drivers on data bus 4-62 Internal register addresses 3-12 Internal source asserts reset signal 4-68 Interrupts 4-72 Acknowledge cycle 4-46, 4-73, 4-77, 7-6 Acknowledge cycle termination signals 4-76 Acknowledge cycle timing 4-78 Acknowledge using chip-select signal 4-94 Arbitration 4-4, 4-73, 7-6 Arbitration field (IARB) 4-4, 4-73 Arbitration occurs during interrupt exception processing 4-6 Asynchronous exception 4-72

MOTOROLA

I-8

INDEX

Exception processing 4-72 Handler routines 7-4. 7-7 Instructions 5-23, 5-29 Priority (IP) mask 2-2, 4-72, 4-89, 5-5, 5-11, 7-4.7-6 Priority 4-72 Processing summary 4-75 Recognition 4-72 Request 4-4, 4-72, 4-74 Request acknowledged but no IARB contention occurs 4-50 Request circuitry has hysteresis 4-73 Request signals (IRQ[7:1]) 2-3, 3-5, 3-7, 3-8, 4-72, 7-6 Requests 4-72 Requests while halted 4-53 Stack frame 5-11 Vector number 4-74, 7-4, 8-6 Interrupt-driven GPT Operation 8-4 IRQ7 is nonmaskable 4-73 IRQ[6:1] are maskable 4-73

Jump instructions 5-23, 5-28

Least significant bit (LSB) 2-5 Least significant word (LSW) 2-5 Length of ADC conversion sequence 6-9 Load instructions 5-12 Loading can overcome data bus pull-up drivers 4-62 Lock time 4-12 Logic level one 2-5 Logic level zero 2-5 Long branch instructions 5-25 Long idle-line detection 7-33 Long word 5-7 Loop counters 5-17 Loss of clock reference signal 4-19 Low-power stop 4-50, 6-3, 7-4, 8-3, 9-2 Low-power stop broadcast cycle 4-18, 4-46, 4-50 Low-power stop used for GPT debugging 8-3 LPSTOP instruction 5-38

- 1 -

- L -

- M -

MAC multiplicand register (IR) 2-2 MAC multiplier register (HR) 2-2 MAC sign latch (SL) 2-2 Manual nomenclature 2-1 Conventions 2-5 Mnemonics 2-3 Operators 2-1 Symbols 2-1 Mapping of exception vector number to vector table 5-62 Mask operand 5-27 Mask value 4-73 Master in slave out signal (MISO) 2-3, 3-5, 3-7, 3-8, 7-18, 7-22 Master out slave in signal (MOSI) 2-3, 3-5, 3-7, 3-8, 7-18, 7-22 Mathematic instructions 5-14 Maximum allowable bus response time 4-5 Maximum monitor period 4-39 Maximum specified system clock frequency 4-13 MC68HC11 compatibility 5-1 MC68HC11 direct mode addressing 5-11 MC68HC16Z1 Features 3-1 MCU power consumption 4-18 Memory management 5-6 Memory maps 3-11 Memory organization 5-7 Methods of exiting QSPI wraparound mode 7-21 Microsequencer 5-58, 5-59 Misaligned operands 4-25 Misaligned word 5-8 Misaligned word transfers 4-26 Mnemonic 2-5 Mnemonic range 2-5 MODCLK pin used as a parallel port pin 4-64 Mode select pin 3-15, 4-62 Modes of operation 4-13 Module control registers 3-11 Module mapping 3-11, 4-4 Module pin function during reset 3-16, 4-65 Modulo addressing index register X mask (XMSK) 2-2.5-36

Modulo addressing index register Y mask (YMSK) 2–2, 5–36 Most significant bit (MSB) 2–5 Most significant word (MSW) 2–5 Move instructions 5–12 Multichannel A/D conversion 6–9, 6–13 Multimaster QSPI operation 7–11 Multiple bus errors 4–53 Multiple chip-select assertion 4–88 Multiple exceptions 5–64 Multiplication Instructions 5–16 Multiply and accumulate registers 5–5 Multiply and accumulate unit (MAC) 5–71

#### – N –

Negated 2–5 Negating and reasserting HALT 4–53 Negative flag (N) 2–2, 5–4 Negative integers 5–7 New queue pointer NEWQP) 7–10, 7–21, 7–23 No IARB assertion in response to interrupt acknowledge 4–79 Noise error 7–32 Nonmaskable interrupt 4–73 Normal bus cycles 4–5 NRZ (Nonreturn to zero) 7–28 Numeric range of 8-bit offset values 5–27 Numeric range of 16-bit offset values 5–27 Numeric range of long branch offset values 5–26 Numeric range of short branch offset values 5–24

#### - 0 -

OC1 can affect other OC pins 8–14 Opcode map 5–11 Opcode tracking and breakpoints 5–67 Opcodes 5–57 Operand 4–25, 5–57 Alignment 4–25, 4–26 Byte order 4–25 Bytes 4–25 Coherency 4–57 Operand transfers to or from 8-bit and 16-bit ports 4–24 Operand transfer cases 4-26 Byte operand to 8-bit port 4-27 Byte operand to 16-bit port, even 4-28 Byte operand to 16-bit port, odd 4-29 Long-word operand to 8-bit port, aligned 4-34 Long-word operand to 8-bit port, misaligned 4-35 Word operand to 8-bit port, aligned 4-30 Word operand to 8-bit port, misaligned 4-31 Word operand to 16-bit port, aligned 4-32 Word operand to 16-bit port, misaligned 4-33 **Operating frequency 4–13** Operators 2-1 Order in which exception handlers are executed 5-64 Order of access 4-25 Ouput compare 1 (OC1) 8-10, 8-15 Ouput compare signals (OC[4:1]) 2-3, 3-5, 3-7, 3-8, 8-8 Output compare functions 8-8, 8-11 Overrun error 7-32

#### - P -

Page 0 opcode 5-57 Parallel input/output ports, SIM 4-96 Parentheses 2-5 Parity checking 7-29 Parity error 7-32 Periodic interrupts 4-8 Modulus counter 4-8 Priority 4-9 Request level 4-9 Timer 4-8 Vector 4-9 Peripheral chip-select set up 7-23 Peripheral chip-select signals, QSPI 2-3, 3-5, 3-7, 3-8.7-18.7-22.7-23 Phase comparator 4-12 Pin and signal mnemonics 2-3, 3-5, 3-7, 3-8, Pin assignment field encoding 4-84 Pin assignment for 132-pin package 3-4 Pin assignment for 144-pin package 3-5 Pin characteristics 3-6 Pin function and pin electrical state 3-5, 3-7, 3-8, 4-66

Pin mnemonics 2-3

MOTOROLA

#### INDEX

Pin state during reset 4-66 Pin synchronizer, QSPI 8-13 Pins configured as inputs during reset 4-66 Pins configured as outputs during reset 4-66 Pins that are not used 4-66 Pipeline 4-47 Pipeline state signals (IPIPE[1:0]) 2-3, 3-5, 3-7, 3-8.5-65 Pipeline state signals available unit breakpoint acknowledged 5-66 Pipeline states 5--65 Polled GPT operation 8-5 Polling GPT status registers 8-4 Port size 4-24, 4-84 Port width 4-21, 4-23 PORTE and PORTF registers can be accessed in two locations 4-97 Positioning of bytes 4-25 Post-modified index addressing mode 5-11 Power connections 3-7 Power consumption 4-18 Power-On Reset 4-69 Prefetch mechanism 5-60 Processing aborted by reset exception 4-60 Program and data spaces 3-11, 5-6, 5-7, 9-2 Program control instructions 5-23 Program counter (PC) 2-2, 5-4 Program counter extension field (PK) 2-2, 5-5 Program counter relative addressing mode 9-2 Programmable chip-select circuits 4-80 Programmable interrupt timer clock signal (PITCLK) 4-9 Programmable serial transfer length 7-6 Programming register model 2-2 Pseudolinear address space 3-11, 5-1 Pulse accumulator 8-16 Clock signal (PCLK) 2-3, 3-5, 3-7, 3-8, 8-16 Control register (PACTL) 8-9, 8-15, 8-16 Counter (PACNT) 8-16 Counter overflow 8-16 Gated time accumulation mode 8-16 Input signal (PAI) 2-3, 3-5, 3-7, 3-8, 8-8, 8-9, 8-16 Pulse-width modulation (PWM) unit 8-17

A signal (PWMA) 2–4, 8–8, 8–9, 8–17 B signal (PWMB) 2–4, 8–8, 8–9, 8–17 Control register A (PWMA) 8–20 Control register B (PWMB) 8–20 Control register C (PWMC) 8–9, 8–15, 8–19 Count register (PWMCNT) 8–19 Counter (PWMCNT) 8–9 Fast mode 8–17, 8–19 Frequency range 8–19 Function 8–20 Operating modes 8–17

## – Q –

Queued Serial Module (QSM) 7-1 Baud clocks derived from MCU system clock 7-29 Completed queue pointer (CPTQP) 7-10, 7-21 Configuration register (QSMCR) 7-3 Control registers 7-8, 7-24 Features 3-2 Freeze operation 7-3 Global registers 7-3 Initialization sequence 7-34 Interrupt arbitration priority 7-4 Interrupt level register (QILR) 7-3 Interrupt vector register (QIVR) 7-3 Interrupts 7-4 Pin control registers 7-5 Pin functions 7-5 Port (PORTQS) 2-3 QSPI and SCI interrupt requests 7-4 Queued Serial Peripheral Interface (QSPI) 7-8 Command RAM 7-8 Command RAM not used in slave mode 7-22 Control register 0 (SPCR2) 7-10 Control register 1 (SPCR2) 7-10 Control register 2 (SPCR2) 7-10 Control register 3 (SPCR2) 7-10 Drives neither clock nor peripheral chip-select pins in slave mode 7-22 Fully compatible with other SPI systems 7-6 Initialization 7-12 Internal queue pointer 7-10 Master mode 7-11, 7-18

MC68HC16Z1 USER'S MANUAL

## INDEX

Master mode operation 7-13 Master mode wraparound 7-21 Operating modes 7-11 Operation initiated by CPU16 7-10 Peripheral chip-select 0/slave select signal (PCS0/SS) 3-5. 3-7. 3-8. 7-18. 7-22 Peripheral chip-select assertion 7-23 Peripheral chip-select set up 7-23 Peripheral chip-select signals (PCS[3:0]) 2-3. 3-5. 3-7. 3-8. 7-18. 7-22. 7-23 Phase control 7-18 Pin function 7-10 Polarity control 7-18 RAM 7-2, 7-8 RAM not readable during low-power stop 7-3 Receive data RAM 7-8 Registers 7-7 Registers must be initialized 7-8 Serial clock signal (SCK) 2-4 3-5, 3-7, 3-8, Slave mode 7-11, 7-22 Slave mode operation 7-16 Slave mode wraparound 7-23 Slave select signal (SS) 3-5, 3-7, 3-8, 7-11 Status register (SPSR) 7-7 Status register (SPSR) 7-10 Transmit data RAM 7-8 Unable to initiate transfers in slave mode 7-22 Queue entry 7-10 Queue pointers 7-10 Queued serial peripheral interface (QSPI) 7-2, 7-6 Quotient out signal (QUOT) 2-4

#### - R -

Range of mnemonics 2–5 RC DAC array 6–6 Re-enable GPT status flag 8–5 Read Cycle 4–40 Read of data register when pin is configured for input 4–97 Read/Write signal (R/W) 2–4, 3–5, 3–7, 3–8, 4–22, 4–39, 4–41, 4–42, 4–45 Receive data RAM 7–8 Receive time (RT) clock 7–29, 7–32 Receiver operation 7–31 Receiver wakeup function 7-33 Reduce MCU power consumption selectively 4-18 Reduce MCU power consumption to a minimum 4-18 Reference crystal 4-11 Register access 4-5 Regular bus cycles 4-38, 4-39 Relative addressing modes 5-11 Reset 4-60, 5-60 Control logic 4-61 Exception processing 4-60, 4-71 Gated by CLKOUT 4-61 Is asynchronous exception 4-60 Mode selection 3-15, 4-61 Occurs at the end of a bus cycle 4-60 Signal (RESET) 2-4, 3-5, 3-7, 3-8, 4-60 Source 4-61 State of MODCLK determines system clock source 4-61 States of MCU module pins 4-67 States of data bus pins determine SIM operating configuration 4-61 States of SIM pins 4-66 Status register (RSR) 4-5, 4-71 Timing 4-68, 4-70 Value of SIM IARB field 4-4 Vectors reside in program space 5-61 Vectors 3-11, 5-60 Reset and exception vectors 3-11 Reset signal (RESET) 2-4, 3-5, 3-7, 3-8, 4-60 **RESET** assertion period 4-68 RESET synchronized to system clock 4-60 Reset while SRAM access in progress 9-3 **Resolution 6-8** Responding device must terminate interrupt acknowledge cycle 4-79 Returning from BDM 5-69 Resolution time 6-14 **RTI** instruction 5-65

## - S -

Sample capacitors 6–6 Sample time 6–8, 6–14 Saturation mode control bit (SM) 2–2, 5–5 Serial Communication Interface (SCI) 7–2, 7–24, 7–27

### INDEX

MC68HC16Z1 USER'S MANUAL

I-12

Baud rate 7-29 Baud clock 7-29 Compatible with other SCI systems 7-24 Control register 0 (SCCR0) 7-24 Control register 1 (SCCR1) 7-24 Control register 1 (SCCR1) 7-28, 7-31 Data frame 7-28 Data register (SCDR) 7-24, 7-27 Framing error 7-32 Noise error 7-32 Overrun error 7-32 Parity checking 7-29 Parity error 7-32 Pin function 7-27 Receive data signal (RXD) 2-4, 3-5, 3-7, 3-8, 7-31 Receive time clock (RT) 7-29, 7-32 Receiver bit processor logic 7-31 Receiver bit time 7-28 Receiver idle-line detection 7-32 Receiver operation 7-31 Receiver wakeup 7-33 Registers 7-24 Serial frame formats 7-29 Short idle-line detection 7-33 Status register (SCSR) 7-24, 7-27 Transmit data signal (TXD) 2-4, 3-5, 3-7, 3-8, 7-31 Transmitter double-buffered 7-30 Transmitter operation 7-30 Select banks in a 16-bit memory using chip-selects 4-87 Separate program and data spaces 3-14 Serial data transferred MSB first 7-18 Serial frame formats 7-29 Set 2-5 Setting STOP bits in module configuration registers 4-50 Shift and rotate instructions 5-20 Short and long idle-line detection 7-32 Short branch instructions 5-23 short idle-line detection 7-33 Show cycles 4-4, 4-59 Signal assertion 2-5

Signal characteristics 3-8 Signal function 3-9 Signal mnemonics 2-3 Signal negation 2-5 Signed 8-bit offset 5-23 Signed 16-bit offset 5-25 Signed 32-bit fractions 5-7 Signed 36-bit fixed-point numbers 5-7 Signed branches 5-23, 5-25 Signed left-justified conversion format 6-16 Signed relative offset 5-27 System Integration Module (SIM) 4-1 Assignable interrupt vectors 4-72 Asynchronous bus cycles 4-21 Automatic interrupt vectors 4-72 Breakpoints 4-46 Bus arbitration 4-53, 4-56, 4-58 Bus cycle 4-38, 5-60 Bus error 4-52 Bus grant 4-57 Bus monitor 4-5, 4-6, 4-23, 4-39 Bus request 4-56 Bus signals 4-21 Chip selects 4-1, 4-80 Clock, system 4-10 CPU space 4-22, 4-73 Data bus mode selection 4-62, 4-63 Deskews signals 4-38 Dynamic bus sizing 4-20, 4-24, 5-61 Exception 4-60, 4-72, 5-61, 5-63, 5-64, 7-4, 8-6 External bus 4-1 Factory test mode 4-5 Features 3-1 Freeze mode 4-10, 7-4, 8-3 Halt monitor 4-6 Interrupts 4-72 Low-power operation 4-18, 4-50, 6-3, 7-4, 8-3, 9-2 MCU power consumption 4-18 Modes of operation 4-13 Operand transfer cases 4-26 Periodic interrupts 4-8 Port C (CSPDR) 2-3

Port E (PORTE) 2-3 Port F (PORTF) 2-3 Port size 4-24, 4-84 Port width 4-21, 4-23 Reset 4-60, 5-60 Show cycles 4-4, 4-59 Size signal encoding 4-22 Software watchdog 4-6 Spurious interrupts 4-6, 4-74 Standard exception processing sequence 4-52 System configuration and protection 4-2 Three-line handshaking interface 4-20 Using chip-select signals for interrupt acknowledge 4-94 Simple branches 5-23, 5-25 Single bus cycle operation 4-23 Single-channel A/D conversion 6-12 Size signal encoding 4-22 Size signals (SIZ1:0) 2-4, 3-5, 3-7, 3-8, 4-22, 4-39, 4-41, 4-42, 4-45, 4-76 Slave mode 7-11, 7-22 Slave mode wraparound 7-23 Slave select signal (SS) 2-4, 3-5, 3-7, 3-8, 7-11 Software must provide idle-line arbitration 7-11 Software must stop QSPI and SCI before low-power stop 7-3 Software watchdog 4-6 Software watchdog ratio 4-7 Software watchdog service sequence 4-6 Source of DSACK signals used in asynchronous chipselect mode 4-88 Specific mnemonic 2-5 Spurious interrupts 4-6, 4-74 Cycle 4-79 Exception 4-74 Exception vector 4-6, 4-74 Monitor 4-6, 4-50, 4-79 Vector number 4-6, 4-79 Standby RAM Module (SRAM) 9-1 Array base address registers (RAMBAH/RAMBAL) 9-1 Module configuration register (RAMMCR) 9-1, 9-2 Test register (RAMTST) 9-1

Address registers written in low-power stop mode 0\_1 Array address mapping 9-1 Array address space type 9-2 Array cannot be read or written during low-power stop 9-2 Array retains contents during low-power stop 9-2 Features 3-2 Low-power mode 9-2 Standby and low-power stop operation 9-2 SS state between transfers 7-23 Stack operation instructions 5-32 Stack pointer extension field (SK) 2-2, 5-5 Stack pointer (SP) 2-2, 5-3 Stack pointer instructions 5-32 Stacking instructions 5-32 Standard exception processing sequence 4-52 Standby determined by voltage levels on VDD and VSTBY 9-2 Standby RAM power connection (VSTBY) 2-4, 3-6, 9-2 Start bit 7-28 State of GPT timer during freeze mode 8-3 State of MODCLK pin during reset 4-11 State signals can be latched asynchronously 5-66 State-by-state description of show cycle timing 4-59 Stop and wait Instructions 5-36 Stop bit 7-28 Stop Disable Control Bit (S) 2-2 Stop Enable bit (S) 5-4 Store instructions 5-13 Subroutine instructions 5-23, 5-28 Subroutines 5-28 Supervisor access mode 4-5 Symbols 2-1 Synchronization to CLKOUT 4-38 Synchronous exceptions 5-64 System clock 4-1, 4-10 Control 4-19 Control multipliers 4-14 Frequencies 4-16 Low-pass filter 4-12 Mode select (MODCLK) signal 2-3, 3-5, 3-7, 3-8, 4-18, 4-64

MOTOROLA

1 - 14

INDEX

Mode selection 4-64 Operation during low-power stop 4-18 Rate changes 4-10 Rate during operation 4-10 Reference signal 4-12 Signal (CLKOUT) 2-3, 3-5, 3-7, 3-8, 4-10 Signal can be input from an external source 4-11 Signal duty cycle and clock signal period 4-12 Signal generated externally 4-12 Sources 4-11 States 4-38 Synthesizer operation 4-12 Synthesizer power connection (VDDSYN) 2-4, 3-6.4-10 VCO ramp time 4-69 Voltage controlled oscillator (VCO) 4-12 System configuration and protection 4-2 System debugging 5-65 System memory maps 3-11 System power connections (VDD and VSS) 2-3, 3-6, 9-2 System reset 3-15 System synchronized to CLKOUT 4-39 System test 4-1

#### – T –

Transmitter shifter state 7-30 Termination of bus error cycles 4-51 Test mode enable signal (TSTME) 2-4, 3-5, 3-7, 3-8, Three-line handshaking interface 4-20 Three-state control signal (TSC) 2-4, 3-5, 3-7, 3-8, 4-70 Time required for internal operations 5-60 Timing of BERR detection/acknowledge 4-52 Timing of chip-select assertion in asynchronous mode 4-88 Total A/D conversion time 6-14 Total execution time 5-61 Transfer delay 7-20 Transfer instructions 5-13 Transfer length options 7-19 Transfer time 6-14 Transmit data RAM 7-9 Transmitted data in receive RAM right-justified 7-9

TSC during power-up reset 4–70
Two or more external devices attempt to become bus master 4–55
Two or more IARB fields have the same nonzero value 4–74
Two sources of bus exception control cycles 4–50
Two-cycle bus access 4–88
Two-cycle external bus transfer 4–43
Twos complement overflow indicator (V) 2–2, 5–5
TXD direction when SCI transmitter disabled 7–5
Type of wakeup 7–33
Types of exceptions 5–63

#### – U –

Unary branch instructions 5–23, 5–25 Uninitialized interrupt vector 7–4 Unsigned branches 5–25 Unsigned conditional branches 5–23 Unsigned left-justified conversion format 6–16 Unsigned right-justified conversion format 6–16 User-defined interrupt vector number 7–4, 7–7 Using chip-select lines to select banks in a 16-bit memory 4–87 Using chip-select signals for interrupt acknowledge 4–94

#### - V -

VCO ramp time 4–69 V<sub>DD</sub> ramp time 4–69 V<sub>DD</sub> ramp-up time 4–69 V<sub>DDSYN</sub> applied at power-on 4–69 Vector numbers 5–62

### - W -

Wait states 4–38 Watchdog timer 4–8 When bus error exception is processed 4–52 Word 5–7 Write cycle 4–42 Write cycle in progress when RESET is asserted 4–60 Writing to GPT timer counter in freeze mode 8–11

## – Z –

Zero flag (z) 2--2, 5--4

#### - NUMERICAL -

8-bit port 4-24

16-bit port 4-24

16 banks within address space 5-6

16 sources for A/D conversion 6-5

132-pin package 3-4

144-pin package 3–5

6800 bus clock signal (ECLK) 2–3

68000 bus clock signal (CLKOUT) 2-3







## Literature Distribution Centers:

USA: Motorola Literature Distribution; P.O. Box 20912; Phoenix, Arizona 85036.

EUROPE: Motorola Ltd.; European Literature Centre; 88 Tanners Drive, Blakelands, Milton Keynes, MK14 5BP, England. JAPAN: Nippon Motorola Ltd.; 4-32-1, Nishi-Gotanda, Shinagawa-ku, Tokyo 141, Japan.

ASIA PACIFIC: Motorola Semiconductors H.K. Ltd.; Silicon Harbour Center, No. 2 Dai King Street, Tai Po Industrial Estate, Tai Po, N.T., Hong Kong.

MC68HC16Z1UM/AD