

# AX07CF192 32-Bit Embedded Flash MCU

**User's Manual** (**Preliminary**)

Aeroflex Microelectronic Solutions
4350 Centennial Blvd.
Colo. Spgs., CO 80907
www.aeroflex.com

January, 2003

#### **Aeroflex Microelectronic Solutions Sales Offices**

Main Office 4350 Centennial Blvd. Colo. Spgs., CO 80907 800-645-8862

Melbourne Sales Office 1901 S. Harbor City Blvd., Suite 802 Melbourne, FL 32901 321-951-4164 Boston Office 6 Daniel Webster Hwy, #3 Nashua, NH 03602 603-888-3975

California Sales Office 120 Columbia St., Suite 200 Aliso Viejo, CA 92656 949-362-2260 European Office 719-594-8166

ARM® is trademark of Advanced RISC Machine Ltd. ARM7TDMI is designed by ARM Ltd.

Aeroflex Microelectronic Solutions reserves the right to make changes to any products and services herein at any time without notice. Consult Aeroflex or an authorized sales representative to verify that the information in this product handbook is current before using this product. Aeroflex does not assume any responsibility or liability arising out of the application or use of any product or service described herein, except as expressly agreed to in writing by Aeroflex; nor does the purchase, lease, or use of a product or service from Aeroflex convey a license under any patent rights, copyrights, trademark rights, or any other of the intellectual rights of Aeroflex or of third parties.

COPYRIGHT 2003



### **Contents**

| Introduct  | ion                                                    | 13 |
|------------|--------------------------------------------------------|----|
| 1.1        | General Description                                    | 14 |
| 1.2        | Features                                               |    |
| 1.3        | Pin Descriptions                                       |    |
| 1.4        | Operation Mode description                             |    |
| 1.5        | Memory Map                                             |    |
|            |                                                        |    |
|            | NM 0                                                   |    |
|            | OMI Core                                               |    |
| 2.1        | General Description                                    |    |
| 2.2        | Features                                               |    |
| 2.3        | Core Block Diagram                                     |    |
| 2.4        |                                                        |    |
|            | 2.4.1 ARM Instruction Set                              |    |
|            | 2.4.2 THUMB Instruction Set                            |    |
|            | 2.4.3 The Program Status Registers                     | 36 |
|            | 2.4.3.1 The condition code flags                       | 36 |
|            | 2.4.3.2 The control bits                               | 37 |
|            | 2.4.4 ARM pseudo-instructions                          |    |
|            | 2.4.5 THUMB pseudo-instructions                        |    |
| Chapter 3  |                                                        |    |
|            | ntroller                                               |    |
| 3.1        | Overview                                               |    |
| 0.1        | 3.1.1 Features                                         |    |
|            | 3.1.2 Pin Configuration                                |    |
| 3.2        |                                                        |    |
| 3.2        | 3.2.1 Configuration Registers                          |    |
| 3.3        |                                                        |    |
| 3.3        | ·                                                      |    |
|            | 3.3.1 Area Division                                    |    |
|            | 3.3.2 Area Division                                    |    |
|            | Chip Select Signals                                    |    |
| 3.4        |                                                        |    |
|            | 3.4.1 Overview                                         |    |
|            | 3.4.2 Byte Lane Write Control                          |    |
|            | 3.4.3 Basic Bus Control Signal Timing                  | 56 |
|            | 3.4.4 Wait Control                                     |    |
|            | 3.4.5 Bus Arbiter                                      |    |
| Chapter 4  |                                                        | 65 |
| MCU Co     | ntroller                                               |    |
| 4.1        | General Description                                    | 66 |
| 4.2        | Pin Function Description                               | 66 |
| 4.3        |                                                        |    |
|            | 4.3.1 Register Memory Map                              |    |
|            | 4.3.2 PINMUX Register                                  |    |
|            | 4.3.3 MCU Device Code Register (0x0900_002C Read Only) |    |
| Chapter 5  | 4.5.5 WOO Device Gode (0x0500_0025 Nead Only)          |    |
| •          | lanagement Unit                                        |    |
| 5.1        | General Description                                    |    |
| 5.1        |                                                        |    |
| 5.2        | · ·                                                    |    |
|            | 5.2.1 Introduction                                     |    |
| <b>-</b> ^ | 5.2.2 Reset and Operation Modes                        |    |
| 5.3        | Power Management Unit Register Map                     |    |
| 5.4        | Register Description                                   | 77 |
| $\wedge$   |                                                        |    |



|           | 5.5   | Signal Timing Diagram                                  | 80  |
|-----------|-------|--------------------------------------------------------|-----|
|           |       | 5.5.1 Power on Reset                                   | 80  |
|           |       | 5.5.2 Watchdog Timer Overflow                          | 80  |
|           |       | 5.5.3 Soft Reset                                       | 81  |
| Chapter 6 | 6     |                                                        | 82  |
| The       | Inter | rrupt Controller                                       | 82  |
|           | 6.1   | About the Interrupt controller                         | 83  |
|           |       | 6.1.1 Interrupt sources                                | 84  |
|           |       | 6.1.2 Interrupt Control                                |     |
|           | 6.2   |                                                        |     |
| Chapter 7 | 7     | · · · · · · · · · · · · · · · · · · ·                  | 90  |
| Wato      | chdo  | og Timer                                               | 90  |
|           | 7.1   | General Description                                    | 91  |
|           | 7.2   |                                                        |     |
|           | 7.3   | Watchdog Timer Operation                               | 93  |
|           |       | 7.3.1 Overflow Flag Timing (setting and clearing)      | 94  |
|           | 7.4   |                                                        |     |
|           | 7.5   | Watchdog Timer Register Descriptions                   | 96  |
|           | 7.6   | · · · · · · · · · · · · · · · · · · ·                  |     |
|           |       | 7.6.1 Interval Timer Mode                              |     |
|           |       | 7.6.2 Watchdog Timer Mode with Internal Reset Disable  | 99  |
|           |       | 7.6.3 Watchdog Timer Mode with Power-on Reset          |     |
|           |       | 7.6.4 Watchdog Timer Mode with Manual Reset            |     |
| Chapter 8 | 8     |                                                        | 102 |
|           |       | neral Purpose Timer                                    |     |
|           | 8.1   | About the General Purpose Timer Unit                   |     |
|           |       | 8.1.1 General Purpose Timer Unit Introduction          |     |
|           | 8.2   | ·                                                      |     |
|           |       | 8.2.1 Register Assignment                              |     |
|           |       | 8.2.2 General Purpose Timer Unit Register Descriptions |     |
|           |       | 8.2.2.1 Timer Global Control Registers                 |     |
|           |       | 8.2.2.2 Timer Channel Control Registers                |     |
|           | 8.3   | <del>-</del>                                           |     |
|           |       | 8.3.1 Free Running Mode                                |     |
|           |       | 8.3.2 Compare Match Mode                               |     |
|           |       | 8.3.2 Input Capture Mode                               |     |
|           |       | 8.3.4 Synchronized Clear and Write Mode                |     |
|           |       | 8.3.5 PWM Mode                                         |     |
|           |       | 8.3.5.1 PWM Mode Operation                             |     |
| Chapter 9 | 9     |                                                        |     |
|           |       | Jniversal Asynchronous Receiver/Transmitter)           |     |
|           | 9.1   | General Description                                    |     |
|           | 9.2   | ·                                                      |     |
|           | 9.3   | Signal Description                                     | 123 |
|           | 9.4   |                                                        |     |
|           | 9.5   | <b>5</b>                                               |     |
|           | 9.6   |                                                        |     |
|           |       | 9.6.1 FIFO Interrupt Mode Operation                    |     |
|           |       | 9.6.2 FIFO Polled Mode Operation.                      |     |
|           | 9.7   | ·                                                      |     |
| Chapter 1 | -     |                                                        |     |
| GPIC      | ) (G  | General Purpose Input Output)                          |     |
|           | 10.1  |                                                        |     |
|           | 10.2  | ·                                                      |     |
|           | . 5.2 | 10.2.1 Register Memory Map                             |     |
|           |       | 10.3.1 Register Description                            |     |
|           | 10.3  | · ·                                                    |     |
|           |       | C . G. G              |     |



| On-Chip SI   | RAM                                            | 144 |
|--------------|------------------------------------------------|-----|
| 11.1         | General Description                            | 145 |
| 11.2         | Function Description                           | 146 |
| Chapter 12   |                                                | 146 |
| On-chip Fla  | ash Memory                                     | 147 |
| 12.1         | General Description                            |     |
| 12.2         | Features                                       |     |
| 12.3         | Block Diagram                                  |     |
| 12.4         | Flash Memory Register Description              |     |
| 12.5         | On-Board Programming Mode                      |     |
| 1            | 2.5.1 Boot Mode                                |     |
|              | 2.5.2 User Program Mode                        |     |
| 12.6         | Flash Memory Programming/Erasing               |     |
| 1            | 2.6.1 Program & Program-Verify Mode            |     |
|              | 2.6.2 Pre-program & Pre-program Verify Mode    |     |
|              | 2.6.3 Erase & Erase Verify Mode                |     |
|              | 2.6.4 Erase Algorithm                          |     |
| 12.7         |                                                |     |
| 1            | 2.7.1 PROM Mode Setting                        |     |
|              | 2.7.2 Memory Map                               |     |
|              | 2.7.3 PROM Mode Operation                      |     |
|              | 2.7.4 Timing Diagram and AC/DC Characteristics |     |
|              |                                                |     |
| •            | rter                                           |     |
| 13.1         | Overview                                       | 176 |
| 1            | 3.1.1 Features                                 | 176 |
| 1            | 3.1.2 Pin Configuration                        |     |
| 13.2         | A/D Converter Registers                        |     |
| 1            | 3.2.1 Register Descriptions                    | 178 |
| 13.3         | Operation                                      | 181 |
| 13.4         | Interrupts                                     | 182 |
| 13.5         | Usage Notes                                    | 182 |
| 13.6         | Example                                        |     |
| Chapter 14   |                                                | 186 |
| Electrical C | Characteristics                                | 186 |
| 14.1         | Absolute Maximum Ratings                       | 187 |
| 14.2         | Recommended Operating Conditions:              |     |
| 14.3         | DC Characteristics                             | 188 |
| 14.4         | AC Characteristics                             | 189 |
| 14.4         | AD Conversion characteristics (Preliminary)    |     |
| 14.5         | Operational Timing                             |     |
| 1            | 4.5.1 Clock Timing                             |     |
|              | 4.5.2 Reset Timing                             |     |
|              | 4.5.3 Rus Timing                               | 193 |



## **Figures**

| Figure 1.2                                                                                                                                                                                                       | Package Outline                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | . 14                                                                                                         |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                  | AX07CF192 Block Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | . 15                                                                                                         |
| Figure 1.3                                                                                                                                                                                                       | AX07CF192 Memory Map                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | .25                                                                                                          |
|                                                                                                                                                                                                                  | Memory Map of Mode 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                              |
|                                                                                                                                                                                                                  | Memory Map of when Mode 4 and Mode 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                              |
|                                                                                                                                                                                                                  | Memory Map of Mode 6 and Mode 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                              |
|                                                                                                                                                                                                                  | ARM7TDMI Core Block Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                              |
| Figure 2.2                                                                                                                                                                                                       | ARM instruction set formats                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | .30                                                                                                          |
|                                                                                                                                                                                                                  | Register Organization in ARM state                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                              |
|                                                                                                                                                                                                                  | THUMB instruction set formats                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                              |
|                                                                                                                                                                                                                  | Register Organization in THUMB state                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                              |
| •                                                                                                                                                                                                                | Mapping of THUMB state registers onto ARM state registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                              |
|                                                                                                                                                                                                                  | Program status register format                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                              |
|                                                                                                                                                                                                                  | Block Diagram of the Bus Controller                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                              |
|                                                                                                                                                                                                                  | Access Area Map for Each Operating Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                              |
|                                                                                                                                                                                                                  | Access Size and Data Alignment Control (8-Bit Access Area)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                              |
|                                                                                                                                                                                                                  | Access Size and Data Alignment Control (16-Bit Access Area)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                              |
|                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                              |
|                                                                                                                                                                                                                  | Bus Control Signal Write Timing for 16-Bit, 1-Wait (Word Access)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                              |
|                                                                                                                                                                                                                  | Bus Control Signal Read Timing for 16-Bit, 1-Wait (Word Access)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                              |
|                                                                                                                                                                                                                  | Bus Control Signal Write Timing for 16-Bit, 1-Wait (Half-word Access)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                              |
|                                                                                                                                                                                                                  | Bus Control Signal Read Timing for 16-Bit, 1-Wait (Half-word Access)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                              |
|                                                                                                                                                                                                                  | Bus Control Signal Write Timing for 16-Bit, 1-Wait (Byte Access)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                              |
|                                                                                                                                                                                                                  | Bus Control Signal Read Timing for 16-Bit, 1-Wait (Byte Access)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                              |
|                                                                                                                                                                                                                  | Bus Control Signal Write Timing for 16-Bit, 2-Wait (Word Access)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                              |
|                                                                                                                                                                                                                  | Bus Control Signal Read Timing for 16-Bit, 2-Wait (Word Access)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                              |
|                                                                                                                                                                                                                  | Bus Control Signal Write Timing for 16-Bit, 2-Wait (Half-Word Access)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                              |
|                                                                                                                                                                                                                  | Bus Control Signal Read Timing for 16-Bit, 2-Wait (Half-Word Access)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                              |
|                                                                                                                                                                                                                  | Bus Control Signal Write Timing for 16-Bit, 2-Wait (Byte Access)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                              |
|                                                                                                                                                                                                                  | Bus Control Signal Read Timing for 16-Bit, 2-Wait (Byte Access)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                              |
|                                                                                                                                                                                                                  | Example of Wait State Insertion Timing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                              |
|                                                                                                                                                                                                                  | Example of External Bus Master Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                              |
|                                                                                                                                                                                                                  | PMU Block Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 71                                                                                                           |
|                                                                                                                                                                                                                  | Donat and Dower Management Ctate Machine                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                              |
|                                                                                                                                                                                                                  | Reset and Power Management State Machine                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | .76                                                                                                          |
|                                                                                                                                                                                                                  | Power on Reset Timing Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | .76<br>.80                                                                                                   |
| Figure 5.4                                                                                                                                                                                                       | Power on Reset Timing Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | .76<br>.80<br>.81                                                                                            |
| Figure 5.4<br>Figure 5.5                                                                                                                                                                                         | Power on Reset Timing Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | .76<br>.80<br>.81<br>.80                                                                                     |
| Figure 5.4<br>Figure 5.5                                                                                                                                                                                         | Power on Reset Timing Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | .76<br>.80<br>.81<br>.80                                                                                     |
| Figure 5.4<br>Figure 5.5<br>Figure 5.6                                                                                                                                                                           | Power on Reset Timing Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | .76<br>.80<br>.81<br>.80<br>.81                                                                              |
| Figure 5.4<br>Figure 5.5<br>Figure 5.6<br>Figure 6.1                                                                                                                                                             | Power on Reset Timing Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | .76<br>.80<br>.81<br>.80<br>.81                                                                              |
| Figure 5.4<br>Figure 5.5<br>Figure 5.6<br>Figure 6.1<br>Figure 7.1                                                                                                                                               | Power on Reset Timing Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | .76<br>.80<br>.81<br>.80<br>.81<br>.83                                                                       |
| Figure 5.4<br>Figure 5.5<br>Figure 5.6<br>Figure 6.1<br>Figure 7.1<br>Figure 7.2                                                                                                                                 | Power on Reset Timing Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | .76<br>.80<br>.81<br>.80<br>.81<br>.83                                                                       |
| Figure 5.4<br>Figure 5.5<br>Figure 5.6<br>Figure 6.1<br>Figure 7.1<br>Figure 7.2<br>Figure 7.3                                                                                                                   | Power on Reset Timing Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | .76<br>.80<br>.81<br>.80<br>.81<br>.93<br>.94                                                                |
| Figure 5.4<br>Figure 5.5<br>Figure 5.6<br>Figure 6.1<br>Figure 7.1<br>Figure 7.2<br>Figure 7.3<br>Figure 7.4                                                                                                     | Power on Reset Timing Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | .76<br>.80<br>.81<br>.80<br>.81<br>.93<br>.94                                                                |
| Figure 5.4<br>Figure 5.5<br>Figure 5.6<br>Figure 6.1<br>Figure 7.1<br>Figure 7.2<br>Figure 7.3<br>Figure 7.4<br>Figure 7.5                                                                                       | Power on Reset Timing Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | .76<br>.80<br>.81<br>.80<br>.81<br>.93<br>.94<br>.98                                                         |
| Figure 5.4<br>Figure 5.5<br>Figure 5.6<br>Figure 6.1<br>Figure 7.1<br>Figure 7.2<br>Figure 7.3<br>Figure 7.4<br>Figure 7.5<br>Figure 7.6                                                                         | Power on Reset Timing Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | .76<br>.80<br>.81<br>.83<br>.91<br>.93<br>.94<br>.98                                                         |
| Figure 5.4 Figure 5.5 Figure 5.6 Figure 6.1 Figure 7.1 Figure 7.2 Figure 7.3 Figure 7.4 Figure 7.5 Figure 7.6 Figure 7.7                                                                                         | Power on Reset Timing Diagram Watch Dog Timer Overflow Timing Diagram Soft Reset (from WDT) Timing Diagram Soft Reset (from PMU) Timing Diagram Interrupt Control Flow Diagram Watchdog Timer Module Block Diagram Operation in the Watchdog Timer Mode Operation in the Interval Timer Mode Interrupt Clear in the Interval Timer Mode with Reset Disable Interrupt Clear in the Watchdog Timer Mode with Power-on Reset Interrupt Clear in the Watchdog Timer Mode with Manual Reset                                                                                                                                                                                                                            | .76<br>.80<br>.81<br>.80<br>.81<br>.93<br>.94<br>.98<br>.99                                                  |
| Figure 5.4<br>Figure 5.5<br>Figure 5.6<br>Figure 6.1<br>Figure 7.1<br>Figure 7.2<br>Figure 7.3<br>Figure 7.4<br>Figure 7.5<br>Figure 7.6<br>Figure 7.7<br>Figure 8.1                                             | Power on Reset Timing Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | .76<br>.80<br>.81<br>.80<br>.81<br>.93<br>.94<br>.98<br>.99<br>100<br>101                                    |
| Figure 5.4<br>Figure 5.5<br>Figure 5.6<br>Figure 6.1<br>Figure 7.1<br>Figure 7.2<br>Figure 7.3<br>Figure 7.4<br>Figure 7.5<br>Figure 7.6<br>Figure 7.7<br>Figure 8.1<br>Figure 8.2                               | Power on Reset Timing Diagram Watch Dog Timer Overflow Timing Diagram Soft Reset (from WDT) Timing Diagram Soft Reset (from PMU) Timing Diagram Interrupt Control Flow Diagram Watchdog Timer Module Block Diagram Operation in the Watchdog Timer Mode Operation in the Interval Timer Mode Interrupt Clear in the Interval Timer Mode with Reset Disable Interrupt Clear in the Watchdog Timer Mode with Power-on Reset Interrupt Clear in the Watchdog Timer Mode with Manual Reset General-purpose Timer Unit Module Block Diagram Free-Running Counter Operation                                                                                                                                             | .76<br>.80<br>.81<br>.80<br>.81<br>.93<br>.94<br>.98<br>.99<br>100<br>101<br>103<br>112                      |
| Figure 5.4<br>Figure 5.5<br>Figure 5.6<br>Figure 6.1<br>Figure 7.1<br>Figure 7.2<br>Figure 7.3<br>Figure 7.4<br>Figure 7.5<br>Figure 7.6<br>Figure 7.7<br>Figure 8.1<br>Figure 8.2<br>Figure 8.3                 | Power on Reset Timing Diagram Watch Dog Timer Overflow Timing Diagram Soft Reset (from WDT) Timing Diagram Soft Reset (from PMU) Timing Diagram Interrupt Control Flow Diagram Watchdog Timer Module Block Diagram Operation in the Watchdog Timer Mode Operation in the Interval Timer Mode Interrupt Clear in the Interval Timer Mode with Reset Disable Interrupt Clear in the Watchdog Timer Mode with Power-on Reset Interrupt Clear in the Watchdog Timer Mode with Manual Reset General-purpose Timer Unit Module Block Diagram Free-Running Counter Operation Periodic Counter Operation                                                                                                                  | .76<br>.80<br>.81<br>.80<br>.81<br>.93<br>.94<br>.98<br>.99<br>100<br>101<br>103<br>112                      |
| Figure 5.4<br>Figure 5.5<br>Figure 5.6<br>Figure 6.1<br>Figure 7.1<br>Figure 7.2<br>Figure 7.3<br>Figure 7.4<br>Figure 7.5<br>Figure 7.7<br>Figure 8.1<br>Figure 8.2<br>Figure 8.3<br>Figure 8.4                 | Power on Reset Timing Diagram Watch Dog Timer Overflow Timing Diagram Soft Reset (from WDT) Timing Diagram Soft Reset (from PMU) Timing Diagram Interrupt Control Flow Diagram Watchdog Timer Module Block Diagram Operation in the Watchdog Timer Mode Operation in the Interval Timer Mode Interrupt Clear in the Interval Timer Mode with Reset Disable Interrupt Clear in the Watchdog Timer Mode with Power-on Reset Interrupt Clear in the Watchdog Timer Mode with Manual Reset Interrupt Clear in the Watchdog Timer Mode with Manual Reset General-purpose Timer Unit Module Block Diagram Free-Running Counter Operation Periodic Counter Operation Example of 0 Output/1 Output                        | .76<br>.80<br>.81<br>.80<br>.81<br>.93<br>.94<br>.98<br>.99<br>100<br>101<br>103<br>112<br>113               |
| Figure 5.4<br>Figure 5.5<br>Figure 5.6<br>Figure 6.1<br>Figure 7.1<br>Figure 7.2<br>Figure 7.3<br>Figure 7.5<br>Figure 7.6<br>Figure 7.7<br>Figure 8.1<br>Figure 8.2<br>Figure 8.3<br>Figure 8.4<br>Figure 8.5   | Power on Reset Timing Diagram Watch Dog Timer Overflow Timing Diagram Soft Reset (from WDT) Timing Diagram Soft Reset (from PMU) Timing Diagram Interrupt Control Flow Diagram Watchdog Timer Module Block Diagram Operation in the Watchdog Timer Mode Operation in the Interval Timer Mode Interrupt Clear in the Interval Timer Mode with Reset Disable Interrupt Clear in the Watchdog Timer Mode with Power-on Reset Interrupt Clear in the Watchdog Timer Mode with Manual Reset General-purpose Timer Unit Module Block Diagram Free-Running Counter Operation Periodic Counter Operation Example of 0 Output/1 Output Example of Toggle Output                                                            | .76<br>.80<br>.81<br>.83<br>.91<br>.93<br>.94<br>.99<br>100<br>101<br>113<br>114<br>115                      |
| Figure 5.4 Figure 5.5 Figure 5.6 Figure 6.1 Figure 7.1 Figure 7.2 Figure 7.3 Figure 7.4 Figure 7.5 Figure 7.6 Figure 7.7 Figure 8.1 Figure 8.2 Figure 8.3 Figure 8.4 Figure 8.5 Figure 8.6                       | Power on Reset Timing Diagram Watch Dog Timer Overflow Timing Diagram Soft Reset (from WDT) Timing Diagram Soft Reset (from PMU) Timing Diagram Interrupt Control Flow Diagram Watchdog Timer Module Block Diagram Operation in the Watchdog Timer Mode Operation in the Interval Timer Mode Interrupt Clear in the Interval Timer Mode with Reset Disable Interrupt Clear in the Watchdog Timer Mode with Power-on Reset Interrupt Clear in the Watchdog Timer Mode with Manual Reset General-purpose Timer Unit Module Block Diagram Free-Running Counter Operation Periodic Counter Operation Example of 0 Output/1 Output Example of Toggle Output Compare Match Signal Output Timing                         | .76<br>.80<br>.81<br>.83<br>.91<br>.93<br>.94<br>.99<br>100<br>101<br>103<br>112<br>113<br>114<br>115        |
| Figure 5.4 Figure 5.5 Figure 5.6 Figure 6.1 Figure 7.1 Figure 7.2 Figure 7.3 Figure 7.4 Figure 7.5 Figure 7.7 Figure 8.1 Figure 8.2 Figure 8.3 Figure 8.4 Figure 8.5 Figure 8.6 Figure 8.7                       | Power on Reset Timing Diagram Watch Dog Timer Overflow Timing Diagram Soft Reset (from WDT) Timing Diagram Soft Reset (from PMU) Timing Diagram Interrupt Control Flow Diagram Watchdog Timer Module Block Diagram Operation in the Watchdog Timer Mode Operation in the Interval Timer Mode Interrupt Clear in the Interval Timer Mode with Reset Disable Interrupt Clear in the Watchdog Timer Mode with Power-on Reset Interrupt Clear in the Watchdog Timer Mode with Manual Reset General-purpose Timer Unit Module Block Diagram Free-Running Counter Operation Periodic Counter Operation Example of 0 Output/1 Output Example of Toggle Output Compare Match Signal Output Timing Input Capture Operation | .76<br>.80<br>.81<br>.80<br>.81<br>.93<br>.94<br>.98<br>.99<br>100<br>101<br>103<br>114<br>115<br>115        |
| Figure 5.4 Figure 5.5 Figure 5.6 Figure 6.1 Figure 7.1 Figure 7.2 Figure 7.3 Figure 7.4 Figure 7.5 Figure 7.7 Figure 8.1 Figure 8.2 Figure 8.3 Figure 8.4 Figure 8.5 Figure 8.6 Figure 8.7 Figure 8.7 Figure 8.7 | Power on Reset Timing Diagram Watch Dog Timer Overflow Timing Diagram Soft Reset (from WDT) Timing Diagram Soft Reset (from PMU) Timing Diagram Interrupt Control Flow Diagram Watchdog Timer Module Block Diagram Operation in the Watchdog Timer Mode Operation in the Interval Timer Mode Interrupt Clear in the Interval Timer Mode with Reset Disable Interrupt Clear in the Watchdog Timer Mode with Power-on Reset Interrupt Clear in the Watchdog Timer Mode with Manual Reset General-purpose Timer Unit Module Block Diagram Free-Running Counter Operation Periodic Counter Operation Example of 0 Output/1 Output Example of Toggle Output Compare Match Signal Output Timing                         | .76<br>.80<br>.81<br>.80<br>.81<br>.93<br>.94<br>.98<br>.99<br>100<br>101<br>113<br>114<br>115<br>115<br>116 |



| Figure 8.10 PWM Mode Operation Example 2                             | 119           |
|----------------------------------------------------------------------|---------------|
| Figure 8.11 Reset-Synchronized PWM Mode Operation Example            | 120           |
| Figure 9.1 TOP BLOCK Diagram                                         | 122           |
| Figure 9.2 Internal UART Diagram                                     |               |
| Figure 10.1 GPIO Block Diagram and PADS Connections(example for Port | A and Port B) |
|                                                                      | 140           |
| Figure 12.1 Flash Memory Block Diagram                               |               |
| Figure 12.2 System Configuration When Using On-Board Boot Mode       | 156           |
| Figure 12.3 Boot Mode Execution Procedure                            | 157           |
| Figure 12.4 User Mode Execution Procedure                            | 159           |
| Figure 12.5 Flash Program & Program Verify Sequence                  | 162           |
| Figure 12.6 Flash Pre-program & Pre-program Verify Sequence          | 164           |
| Figure 12.7 Flash Erase & Erase Verify Sequence                      | 166           |
| Figure 12.8 Flash Erase Algorithm                                    |               |
| Figure 12.9 Read Timing Diagram                                      | 171           |
| Figure 12.10 Pre-Program/Program Timing Diagram                      | 172           |
| Figure 12.11 Erase Timing Diagram                                    | 173           |
| Figure 12.12 Pre-Program/Program Verify Timing Diagram               | 174           |
| Figure 12.13 Erase Verify Timing Diagram                             | 174           |
| Figure 13.1 Block Diagram of A/D Converter                           | 176           |
| Figure 13.2 A/D converter Operation                                  |               |
| Figure 13.3 Example of Analog Input Circuit                          | 183           |
| Figure 13.4 A/D Converter Accuracy Definitions (1)                   | 183           |
| Figure 13.5 A/D Converter Accuracy Definitions (2)                   | 184           |
| Figure 14.1 Crystal oscillator settling time                         | 192           |
| Figure 14.2 Reset Input Timing                                       | 192           |
| Figure 14.3 Bus Controller Write Timing Diagram                      | 193           |
| Figure 14.4 Bus Controller Read Timing Diagram                       | 193           |
| Figure 14.5 Basic Bus Cycle with External Wait State                 | 194           |
| Figure 14.6 Bus Release Mode Timing                                  | 194           |



### **Tables**

|             | Pin Descriptions                                             |     |
|-------------|--------------------------------------------------------------|-----|
|             | Pin Descriptions (Continued)                                 |     |
|             | AX07CF192 Operation modes                                    |     |
| Table 1.3   | Pin assignment by mode                                       | 22  |
| Table 1.3   | Pin assignment by mode (continued)                           | 23  |
| Table 1.3   | Pin assignment by mode (continued)                           | 24  |
|             | The ARM Instruction set                                      |     |
| Table 2.2   | THUMB instruction set opcodes                                | 34  |
| Table 2.3   | Condition code summary                                       | 36  |
| Table 2.4   | PSR mode bit values                                          | 38  |
| Table 3.1   | Bus Controller Pins                                          | 49  |
| Table 3.2   | BUS Controller Register Map                                  | 50  |
|             | Byte Lane condition by XA[0]                                 |     |
|             | Pin Function Descriptions                                    |     |
|             | MCU Controller Memory map                                    |     |
|             | MCU Controller Initial values in each mode                   |     |
|             | PMU Register Map                                             |     |
|             | Interrupt Controller Default Setting Value                   |     |
|             | Interrupt Controller Memory Map                              |     |
|             | Interrupt Source Trigger Mode                                |     |
|             | Watchdog Timer APB Peripheral Memory Map                     |     |
|             | Internal Counter Clock Sources (SYSCLK = 40 MHz)             |     |
|             | Timer Global Control Register Map                            |     |
|             | Timer Channel Control Register Map                           |     |
|             | Timer Channel Starting Address                               |     |
|             | Signal Descriptions1                                         |     |
|             | UART Register Address Map (0x1500 in UART1)                  |     |
| Table 9.3   | UART Register Reset Values                                   | 25  |
|             | a Divisor Values for each Baud rate (CLK=1.8432MHz)1         |     |
|             | Divisor Values for each Baud rate (CLK=3.6864MHz)            |     |
|             | Interrupt Control Functions                                  |     |
|             | Summary of Registers                                         |     |
|             | GPIO Register Memory Map                                     |     |
|             | Operating mode                                               |     |
| Table 12.1  | Signal description of Figure 12.1(BUS Interface)             | 50  |
|             | B Flash Memory Registers                                     |     |
| Table 12.6  | Control Register                                             | 153 |
| Table 12.5  | 5 Erase Block Register                                       | 154 |
|             | Status & Power Register                                      |     |
|             | FR_SEL Value for access to internal Register                 |     |
|             | S Setting for Register read/write                            |     |
|             | Erase Block Register                                         |     |
| Table 12.3  | 0 Setting for Flash PROM read/write1                         | 70  |
|             | 1 DC Characteristics                                         |     |
|             | 2 AC Characteristics                                         |     |
|             | A/D Converter Pins                                           |     |
|             | 2 A/D Converter Register Summary                             |     |
|             |                                                              |     |
| Table 14.1  | Absolute Maximum Ratings1  Recommended Operating Conditions1 | 10/ |
|             | B DC Characteristics                                         |     |
|             |                                                              |     |
| 1 abie 14.4 | IO Circuits with pull-ups1                                   | QQ  |



| Table 14.5 | IO Circuits with pull-downs                | 188 |
|------------|--------------------------------------------|-----|
|            | Clock Timing                               |     |
|            | Control Signal Timing                      |     |
|            | Bus Timing                                 |     |
| Table 14.9 | A/D Conversion Operating Conditions        | 191 |
| Table 14 1 | 0 A/D converter Electrical Characteristics | 191 |





# AX07CF192 32-Bit Embedded Flash MCU

User's Manual (Preliminary)





# Chapter 1 Introduction



#### 1.1 General Description

This 32-bit MCU with embedded flash memory is based on the ARM7TDMI core. The AX07CF192 contains the following functions: 192Kbytes Flash memory, 4K bytes SRAM, 6 channel 16-bit Timer, Watch Dog Timer, 2-channel UART, Programmable Priority Interrupt Controller, 75 bits PIO, Bus Controller including Chip select logic. These functions are implemented using the AMBA On-Chip Modular Architecture.

Several pin count versions are offered, up to a maximum of 100 pins (AX07CF192-100, shown below). Contact the factory for further information on reduced pin count versions.



Figure 1.1 Package Outline



#### 1.2 Features

- On-Chip Modular Architecture (using AMBA)
- Utilizes the ARM7TDMI 32/16bit RISC Family
- 192Kbyte Flash memory
- 4Kbyte internal SRAM
- 8/16-bit external Data Bus
- Eight Programmable Chip Select Outputs with external wait input
- Low Power Consumption using Power Management Unit
- Fully static operation: 50MHz max.
- Programmable Priority Interrupt Controller (8 external sources)
- Six 16-bit Multi Function Timers/Counters for General Purpose Applications
- One 8-bit Watchdog Timer (WDT)
- Two UARTs (Universal Asynchronous Receiver Transmitter) compatible with 16C550 UART
- Programmable Input/Output ports (75-bits)
- 10 bit 5-channel ADC
- 100 TQFP Package



Figure 1.2 AX07CF192 Block Diagram



#### 1.3 Pin Descriptions

Table 1.1 Pin Descriptions

| PIN  | SYMBOL             | DIR | DESCRIPTION                                                                     |
|------|--------------------|-----|---------------------------------------------------------------------------------|
| 1    | VDD                | -   | Power Supply 3.3V                                                               |
|      | nCS <sub>7</sub>   | 0   | External Chip Selection Number 7                                                |
| 2    | TCIOA <sub>3</sub> | I/O | PWM output, Compare match output of Reg.A and signal capture input of Timer Ch3 |
|      | PB <sub>0</sub>    | I/O | General purpose input output of port B bit0                                     |
|      | nCS <sub>6</sub>   | 0   | External Chip Selection Number 6                                                |
| 3    | TCIOB <sub>3</sub> | I/O | PWM output, Compare match output of Reg.B and signal capture input of Timer Ch3 |
| _    | PB <sub>1</sub>    | I/O | General purpose input output of port B bit 1                                    |
|      | nCS₅               | 0   | External Chip Selection Number 5                                                |
| 4    | TIOCA <sub>4</sub> | I/O | PWM output, Compare match output of Reg.A and signal capture input of Timer Ch4 |
| _    | PB <sub>2</sub>    | I/O | General purpose input output of port B bit2                                     |
|      | nCS <sub>4</sub>   | 0   | External Chip Selection Number 4                                                |
| 5    | TIOCB <sub>4</sub> | I/O | PWM output, Compare match output of Reg.B and signal capture input of Timer Ch4 |
| _    | PB <sub>3</sub>    | I/O | General purpose input output of port B bit3                                     |
| 6 -  | TMS                | I   | JTAG Test Mode Selection                                                        |
| 0 -  | PB <sub>4</sub>    | I/O | General purpose input output of port B bit4                                     |
| 7 _  | TDO                | 0   | JTAG Test Data Output                                                           |
| ′ –  | PB₅                | I/O | General purpose input output of port B bit5                                     |
| 8 –  | TDI                | I   | JTAG Test Data Input                                                            |
| 0 -  | PB <sub>6</sub>    | I/O | General purpose input output of port B bit6                                     |
| _    | TCK                | I   | JTAG Test Clock                                                                 |
| 9 –  | PB <sub>7</sub>    | I/O | General purpose input output of port B bit7                                     |
| 10   | TVPPD              | I   | 5Vinput for the use of Programming and Erasing of the Flash Memory              |
| 11   | VSS                | -   | Power ground                                                                    |
| 12 - | TxD <sub>0</sub>   | 0   | Transmit Data of UART Ch0                                                       |
| 12 - | P9 <sub>0</sub>    | I/O | General purpose input output of port 9 bit 0                                    |
| 13 _ | RxD <sub>0</sub>   | 0   | Receive Data of UART Ch0                                                        |
| 13 - | P9 <sub>1</sub>    | I/O | General purpose input output of port 9 bit 1                                    |
| 14 - | TxD <sub>1</sub>   | 0   | Transmit Data of UART Ch1                                                       |
| 14 - | P9 <sub>2</sub>    | I/O | General purpose input output of port 9 bit 2                                    |
| 15 _ | RxD <sub>1</sub>   | 0   | Receive Data of UART Ch1                                                        |
| 10 - | P9 <sub>3</sub>    | I/O | General purpose input output of port 9 bit 3                                    |
| 16   | nIRQ <sub>4</sub>  | I   | External Interrupt Request number 4                                             |
| 16 – | P9 <sub>4</sub>    | I/O | General purpose input output of port 9 bit 4                                    |
| 17   | nIRQ <sub>5</sub>  | I   | External Interrupt Request number 5                                             |
| 17 – | P9 <sub>5</sub>    | I/O | General purpose input output of port 9 bit 5                                    |
| 10   | D <sub>0</sub>     | I/O | External Data Bus bit 0                                                         |
| 18 – | P4 <sub>0</sub>    | I/O | General purpose input output or port 4 bit 0                                    |
| 10   | D <sub>1</sub>     | I/O | External Data Bus bit 1                                                         |
| 19 – | P4 <sub>1</sub>    | I/O | General purpose input output or port 4 bit 1                                    |
| 20   | $D_2$              | I/O | External Data Bus bit 2                                                         |
| 20 - | P4 <sub>2</sub>    | I/O | General purpose input output or port 4 bit 2                                    |
| 24   | D <sub>3</sub>     | I/O | External Data Bus bit 3                                                         |
| 21 _ | P4 <sub>3</sub>    | I/O | General purpose input output or port 4 bit 3                                    |



Table 1.1 Pin Descriptions (Continued)

| PIN  | SYMBOL                             | DIR      | DESCRIPTION                                                               |
|------|------------------------------------|----------|---------------------------------------------------------------------------|
| 22   | VSS                                | -        | Power ground                                                              |
| 00   | D <sub>4</sub>                     | I/O      | External Data Bus bit 4                                                   |
| 23 – | P4 <sub>4</sub>                    | I/O      | General purpose input output or port 4 bit 4                              |
| 0.4  | D <sub>5</sub>                     | I/O      | External Data Bus bit 5                                                   |
| 24 – | P4 <sub>5</sub>                    | I/O      | General purpose input output or port 4 bit 5                              |
| 0.5  | D <sub>6</sub>                     | I/O      | External Data Bus bit 6                                                   |
| 25 – | P4 <sub>6</sub>                    | I/O      | General purpose input output or port 4 bit 6                              |
| 00   | D <sub>7</sub>                     | I/O      | External Data Bus bit 7                                                   |
| 26 _ | P4 <sub>7</sub>                    | I/O      | General purpose input output or port 4 bit 7                              |
| 07   | D <sub>8</sub>                     | I/O      | External Data Bus bit 8                                                   |
| 27 _ | P3 <sub>0</sub>                    | I/O      | General purpose input output or port 3 bit 0                              |
|      | D <sub>9</sub>                     | I/O      | External Data Bus bit 9                                                   |
| 28 _ | P3 <sub>1</sub>                    | I/O      | General purpose input output or port 3 bit 1                              |
|      | D <sub>10</sub>                    | I/O      | External Data Bus bit 10                                                  |
| 29 – | P3 <sub>2</sub>                    | I/O      | General purpose input output or port 3 bit 2                              |
|      | D <sub>11</sub>                    | I/O      | External Data Bus bit 11                                                  |
| 30 – | P3 <sub>3</sub>                    | I/O      | General purpose input output or port 3 bit 3                              |
|      | D <sub>12</sub>                    | I/O      | External Data Bus bit 12                                                  |
| 31 – | P3 <sub>4</sub>                    | I/O      | General purpose input output or port 3 bit 4                              |
|      | D <sub>13</sub>                    | I/O      | External Data Bus bit 13                                                  |
| 32 - | P3 <sub>5</sub>                    | I/O      | General purpose input output or port 3 bit 5                              |
| 33 — | D <sub>14</sub>                    | I/O      | External Data Bus bit 14                                                  |
|      | P3 <sub>6</sub>                    | I/O      | General purpose input output or port 3 bit 6                              |
| 34 _ | D <sub>15</sub>                    | I/O      | External Data Bus bit 15                                                  |
|      | P3 <sub>7</sub>                    | I/O      | General purpose input output or port 3 bit 7                              |
| 35   | VDD                                | -        | Power Supply 3.3V                                                         |
|      | A <sub>0</sub>                     | 0        | External Address Bus bit 0                                                |
| 36 - | P1 <sub>0</sub>                    | I/O      | General purpose input output or port 1 bit 0                              |
|      | A <sub>1</sub>                     | 0        | External Address Bus bit 1                                                |
| 37 _ | P1 <sub>1</sub>                    | I/O      | General purpose input output or port 1 bit 1                              |
|      | A <sub>2</sub>                     | 0        | External Address Bus bit 2                                                |
| 38 – | P1 <sub>2</sub>                    | I/O      | General purpose input output or port 1 bit 2                              |
|      | A <sub>3</sub>                     | 0        | External Address Bus bit 3                                                |
| 39 – | P1 <sub>3</sub>                    | I/O      | General purpose input output or port 1 bit 3                              |
|      | A <sub>4</sub>                     | 0        | External Address Bus bit 4                                                |
| 40 - | P1 <sub>4</sub>                    | I/O      | General purpose input output or port 1 bit 4                              |
|      | A <sub>5</sub>                     | 0        | External Address Bus bit 5                                                |
| 41 – | P1 <sub>5</sub>                    | I/O      | General purpose input output or port 1 bit 5                              |
|      | A <sub>6</sub>                     | 0        | External Address Bus bit 6                                                |
| 42 - | P1 <sub>6</sub>                    | 1/0      | General purpose input output or port 1 bit 6                              |
|      | A <sub>7</sub>                     | 0        | External Address Bus bit 7                                                |
| 43 - | P1 <sub>7</sub>                    | I/O      | General purpose input output or port 1 bit 7                              |
| 44   | VSS                                | -        | Power ground                                                              |
|      | A <sub>8</sub>                     | 0        | External Address Bus bit 8                                                |
| 45 - | P2 <sub>0</sub>                    | 1/0      | General purpose input output or port 2 bit 0                              |
|      | A <sub>9</sub>                     | 0        | External Address Bus bit 9                                                |
|      | <b>~</b> 9                         | U        | External Address Dus Dit 9                                                |
| 46 - | DO.                                | 1/0      | General purpose input output or port 2 bit 1                              |
| 46 - | P2 <sub>1</sub><br>A <sub>10</sub> | I/O<br>O | General purpose input output or port 2 bit 1  External Address Bus bit 10 |



Table 1.1 Pin Descriptions (Continued)

| PIN             | SYMBOL            | DIR | DESCRIPTION                                     |
|-----------------|-------------------|-----|-------------------------------------------------|
| 40              | A <sub>11</sub>   | 0   | External Address Bus bit 11                     |
| 48 -            | P2 <sub>3</sub>   | I/O | General purpose input output or port 2 bit 3    |
| 40              | A <sub>12</sub>   | 0   | External Address Bus bit 12                     |
| 49 –            | P2 <sub>4</sub>   | I/O | General purpose input output or port 2 bit 4    |
| 50              | A <sub>13</sub>   | 0   | External Address Bus bit 13                     |
| 50 -            | P2 <sub>5</sub>   | I/O | General purpose input output or port 2 bit 5    |
| <b>-</b> 4      | A <sub>14</sub>   | 0   | External Address Bus bit 14                     |
| 51 _            | P2 <sub>6</sub>   | I/O | General purpose input output or port 2 bit 6    |
| 50              | A <sub>15</sub>   | 0   | External Address Bus bit 15                     |
| 52 <del>-</del> | P2 <sub>7</sub>   | I/O | General purpose input output or port 2 bit 7    |
| 50              | A <sub>16</sub>   | 0   | External Address Bus bit 16                     |
| 53 -            | P5 <sub>0</sub>   | I/O | General purpose input output of port 5 bit 0    |
| <b>-</b> 4      | A <sub>17</sub>   | 0   | External Address Bus bit 17                     |
| 54 -            | P5 <sub>1</sub>   | I/O | General purpose input output of port 5 bit 1    |
|                 | A <sub>18</sub>   | I   | External Address Bus bit 18                     |
| 55 -            | P5 <sub>2</sub>   | I/O | General purpose input output of port 5 bit 2    |
| 50              | A <sub>19</sub>   | 0   | External Address Bus bit 19                     |
| 56 -            | P5 <sub>3</sub>   | I/O | General purpose input output of port 5 bit 3    |
| 57              | VSS               | -   | Power ground                                    |
| 50              | nWAIT             | I   | External BUS cycle wait signal                  |
| 58 <del>-</del> | P6 <sub>0</sub>   | I/O | General purpose input output of port 6 bit 0    |
| 50              | nBREQ             | I   | External BUS Request                            |
| 59 -            | P6 <sub>1</sub>   | I/O | General purpose input output of port 6 bit 1    |
|                 | nBACK             | I   | External BUS Acknowledge                        |
| 60 –            | P6 <sub>2</sub>   | I/O | General purpose input output of port 6 bit 2    |
| 61              | CLKO              | 0   | BUS Clock Output                                |
| 61 –            | P6 <sub>7</sub>   | I/O | General purpose input output of port 6 bit 7    |
| 62              | nSTBY             | 0   | Standby mode signal. Power Down mode indicating |
| 63              | nRES              | I   | External Reset input                            |
| C4              | nTRST             | ı   | JTAG Test Reset input                           |
| 64 -            | P9 <sub>7</sub>   | I/O | General purpose input output of port 9 bit 7    |
| 65              | VSS               | -   | Power ground                                    |
| 66              | XTALOUT           | 0   | Crystal feedback output                         |
| 67              | XTALIN            | I   | Crystal or External Oscillator input            |
| 68              | VDD               | -   | Power Supply 3.3V                               |
| <b>CO</b>       | nAS               | 0   | External Address Bus strobe                     |
| 69 -            | P6 <sub>3</sub>   | I/O | General purpose input output of port 6 bit 3    |
| 70 -            | nRD               | 0   | External Bus Read                               |
| 70 -            | P6 <sub>4</sub>   | I/O | General purpose input output of port 6 bit 4    |
| 71              | nHWR              | 0   | External upper 8 bit data bus write             |
| 71 –            | P6 <sub>5</sub>   | I/O | General purpose input output of port 6 bit 5    |
| 72              | nLWR              | 0   | External lower 8 bit data bus write             |
| 72 –            | P6 <sub>6</sub>   | I/O | General purpose input output of port 6 bit 6    |
| 73              | MODE <sub>0</sub> | I   | MODE bit 0                                      |
| 74              | MODE <sub>1</sub> | I   | MODE bit 1                                      |
| 75              | MODE <sub>2</sub> | I   | MODE bit 2                                      |
| 76              | AVDD              | -   | Analog Power Supply 3.3V                        |
| 77              | AVREF             |     | ADC Reference Voltage                           |



Table 1.1 Pin Descriptions (Continued)

| PIN  | SYMBOL             | DIR | DESCRIPTION                                                                     |
|------|--------------------|-----|---------------------------------------------------------------------------------|
| 78   | $AN_0$             | l   | ADC Channel 0 input                                                             |
| 79   | AN <sub>1</sub>    | I   | ADC Channel 1 input                                                             |
| 80   | AN <sub>2</sub>    | I   | ADC Channel 2 input                                                             |
| 81   | AN <sub>3</sub>    | I   | ADC Channel 3 input                                                             |
| 82   | AN <sub>4</sub>    | I   | ADC Channel 4 input                                                             |
| 83   | VSS                | -   | Power ground                                                                    |
|      | TIOCA₅             | I/O | PWM output, Compare match output of Reg.A and signal capture input of Timer Ch5 |
| 84   | nIRQ <sub>6</sub>  | I   | External Interrupt Request number 6                                             |
| _    | P7 <sub>6</sub>    | I/O | General purpose input output of port 7 bit 6                                    |
|      | TIOCB₅             | I/O | PWM output, Compare match output of Reg.B and signal capture input of Timer Ch5 |
| 85   | nIRQ <sub>7</sub>  | 1   | External Interrupt Request number 7                                             |
| _    | P7 <sub>7</sub>    | I/O | General purpose input output of port 7 bit 7                                    |
| 86   | P7 <sub>5</sub>    | I/O | General purpose input output of port 7 bit 5                                    |
| 87 – | nIRQ <sub>0</sub>  | I   | External Interrupt Request number 0                                             |
| 01 - | P8 <sub>0</sub>    | I/O | General purpose input output of port 8 bit 0                                    |
|      | nCS₃               | 0   | External Chip Selection Number 3                                                |
| 88   | nIRQ <sub>1</sub>  | I   | External Interrupt Request number 1                                             |
| _    | P8 <sub>1</sub>    | I/O | General purpose input output of port 8 bit 1                                    |
|      | nCS <sub>2</sub>   | 0   | External Chip Selection Number 2                                                |
| 89   | $nIRQ_2$           | 1   | External Interrupt Request number 2                                             |
| _    | P8 <sub>2</sub>    | I/O | General purpose input output of port 8 bit 2                                    |
|      | nCS <sub>1</sub>   | 0   | External Chip Selection Number 1                                                |
| 90   | nIRQ <sub>3</sub>  | I   | External Interrupt Request number 3                                             |
|      | P8 <sub>3</sub>    | I/O | General purpose input output of port 8 bit 3                                    |
| 91 - | nCS <sub>0</sub>   | 0   | External Chip Selection Number 0                                                |
| 31 - | P8 <sub>4</sub>    | I/O | General purpose input output of port 8 bit 4                                    |
| 92   | VSS                | -   | Power ground                                                                    |
| 93 - | TCLKA              | I   | External timer input clock A                                                    |
| 33   | $PA_0$             | I/O | General purpose input output of port A bit 0                                    |
| 94 - | TCLKB              | I   | External timer input clock B                                                    |
| 54   | PA <sub>1</sub>    | I/O | General purpose input output of port A bit 1                                    |
| _    | TCLKC              | I   | External timer input clock C                                                    |
| 95   | TIOCA <sub>0</sub> | I/O | PWM output, Compare match output of Reg.A and signal capture input of Timer Ch0 |
|      | $PA_2$             | I/O | General purpose input output of port A bit 2                                    |
|      | TCLKD              | I   | External timer input clock D                                                    |
| 96   | TIOCB <sub>0</sub> | I/O | PWM output, Compare match output of Reg.B and signal capture input of Timer Ch0 |
|      | PA <sub>3</sub>    | I/O | General purpose input output of port A bit 3                                    |
|      | A <sub>23</sub>    | 0   | External Address Bus bit 23                                                     |
| 97   | TIOCA₁             | I/O | PWM output, Compare match output of Reg.A and signal capture input of Timer Ch1 |
|      | PA <sub>4</sub>    | I/O | General purpose input output of port A bit 4                                    |



Table 1.1 Pin Descriptions (Continued)

| PIN | SYMBOL             | DIR | DESCRIPTION                                                                     |
|-----|--------------------|-----|---------------------------------------------------------------------------------|
|     | A <sub>22</sub>    | 0   | External Address Bus bit 22                                                     |
| 98  | TIOCB₁             | I/O | PWM output, Compare match output of Reg.B and signal capture input of Timer Ch1 |
| _   | PA <sub>5</sub>    | I/O | General purpose input output of port A bit 5                                    |
|     | A <sub>21</sub>    | 0   | External Address Bus bit 21                                                     |
| 99  | TIOCA <sub>2</sub> | I/O | PWM output, Compare match output of Reg.A and signal capture input of Timer Ch2 |
| _   | PA <sub>6</sub>    | I/O | General purpose input output of port A bit 6                                    |
|     | A <sub>20</sub>    | 0   | External Address Bus bit 20                                                     |
| 100 | TIOCB <sub>2</sub> | I/O | PWM output, Compare match output of Reg.B and signal capture input of Timer Ch2 |
| _   | PA <sub>7</sub>    | I/O | General purpose input output of port A bit 7                                    |



#### 1.4 Operation Mode description

AX07CF192 is Flash Memory-embedded ARM microcontroller. It has six operation modes as shown in *Table 1.2*. The AX07CF192's external pin functionality can be changed by setting the external MODE pin or by configuring the PIN MUX registers. The pin assignment by mode is shown in *Table 1.3*. When changing modes the memory is remapped accordingly. *Figure 1.3* shows the default memory map and the memory maps of the alternative modes are shown in *Figures 1.4*, *1.5* and *1.6*.

The various modes are summarized as follows:

Table 1.2 AX07CF192 Operation modes

| MODE | MODE DESCRIPTION                                        |  |  |  |
|------|---------------------------------------------------------|--|--|--|
| 0,1  | Reserved for Test                                       |  |  |  |
| 2    | External 8-bit data bus with 16MBytes of Address Range  |  |  |  |
| 3    | External 16-bit data bus with 16MBytes of Address Range |  |  |  |
| 4    | Flash-boot mode with 16-bit data bus                    |  |  |  |
| 5    | Flash-boot mode (micro-computer mode)                   |  |  |  |
| 6    | UART-boot mode with 16-bit data bus                     |  |  |  |
| 7    | UART-boot mode (micro-computer mode)                    |  |  |  |



22

Table 1.3 Pin assignment by mode

| PIN | MODE 2   | MODE 3    | MODE 4          | MODE 6         | MODE 5          | MODE 7         |
|-----|----------|-----------|-----------------|----------------|-----------------|----------------|
|     | External | External  | Flash boot mode | UART boot mode | Flash boot mode | UART boot mode |
|     | 8bit BUS | 16bit BUS | with 16bit BUS  | with 16bit BUS | (Micro mode)    | (Micro mode)   |
| 1   | VDD      | <b>←</b>  | <b>←</b>        | <b>←</b>       | <b>←</b>        | <b>←</b>       |
| 2   | nCS7     | <b>←</b>  | +               | <del>-</del>   | TIOCA3          | <b>←</b>       |
| 3   | nCS6     | <b>←</b>  | +               | <del>-</del>   | TIOCB3          | <b>←</b>       |
| 4   | nCS5     | +         | +               | +              | TIOCA4          | +              |
| 5   | nCS4     | +         | +               | +              | TIOCB4          | <b>←</b>       |
| 6   | TMS      | <b>←</b>  | <b>←</b>        | <b>←</b>       | <b>←</b>        | <b>←</b>       |
| 7   | TDO      | +         | +               | +              | +               | +              |
| 8   | TDI      | <b>←</b>  | <b>←</b>        | <b>←</b>       | <b>←</b>        | <b>←</b>       |
| 9   | TCK      | <b>←</b>  | <b>←</b>        | <b>←</b>       | <b>←</b>        | <b>←</b>       |
| 10  | TVPPD    | <b>←</b>  | <b>←</b>        | <b>←</b>       | <b>←</b>        | <b>←</b>       |
| 11  | VSS      | <b>←</b>  | <b>←</b>        | <b>←</b>       | <b>←</b>        | <b>←</b>       |
| 12  | TxD0     | <b>←</b>  | <b>←</b>        | <b>←</b>       | <b>←</b>        | <b>←</b>       |
| 13  | RxD0     | <b>←</b>  | <b>←</b>        | <b>←</b>       | <b>←</b>        | <b>←</b>       |
| 14  | TxD1     | +         | +               | +              | +               | +              |
| 15  | RxD1     | +         | +               | +              | +               | +              |
| 16  | nIRQ4    | <b>←</b>  | <b>←</b>        | <b>←</b>       | <b>←</b>        | <b>←</b>       |
| 17  | nIRQ5    | <b>←</b>  | <b>←</b>        | <b>←</b>       | <b>←</b>        | <b>←</b>       |
| 18  | D0       | <b>←</b>  | <b>←</b>        | <b>←</b>       | P40             | <b>←</b>       |
| 19  | D1       | <b>←</b>  | <del>(</del>    | <b>←</b>       | P41             | <del>-</del>   |
| 20  | D2       | <b>←</b>  | <del>(</del>    | <b>←</b>       | P42             | <del>-</del>   |
| 21  | D3       | <b>←</b>  | <del>←</del>    | <b>←</b>       | P43             | <b>←</b>       |
| 22  | VSS      | +         | <b>←</b>        | <b>←</b>       | <b>←</b>        | <b>←</b>       |
| 23  | D4       | <b>←</b>  | <b>←</b>        | <b>←</b>       | P44             | <b>←</b>       |
| 24  | D5       | <b>←</b>  | <b>←</b>        | <b>←</b>       | P45             | <b>←</b>       |
| 25  | D6       | <b>←</b>  | <b>←</b>        | <b>←</b>       | P46             | <b>←</b>       |
| 26  | D7       | <b>←</b>  | <b>←</b>        | <b>←</b>       | P47             | <b>←</b>       |
| 27  | P30      | D8        | <b>←</b>        | <b>←</b>       | P30             | <b>←</b>       |
| 28  | P31      | D9        | <b>←</b>        | <b>←</b>       | P31             | <b>←</b>       |
| 29  | P32      | D10       | <b>←</b>        | <b>←</b>       | P32             | <b>←</b>       |
| 30  | P33      | D11       | <b>←</b>        | <b>←</b>       | P33             | <b>←</b>       |
| 31  | P34      | D12       | <del>-</del>    | <b>←</b>       | P34             | <b>←</b>       |
| 32  | P35      | D13       | <b>←</b>        | +              | P35             | +              |
| 33  | P36      | D14       | <b>+</b>        | <b>←</b>       | P36             | +              |
| 34  | P37      | D15       | <b>←</b>        | <b>←</b>       | P37             | <b>←</b>       |
| 35  | VDD      | <b>←</b>  | <b>←</b>        | +              | <b>←</b>        | +              |
| 36  | A0       | +         | <b>←</b>        | +              | P10             | +              |
| 37  | A1       | <b>←</b>  | <b>+</b>        | <b>←</b>       | P11             | +              |
| 38  | A2       | <b>←</b>  | <b>←</b>        | +              | P12             | +              |
| 39  | A3       | <b>←</b>  | <b>←</b>        | +              | P13             | <b>←</b>       |
| 40  | A4       | <b>←</b>  | <del>(</del>    | <del>(</del>   | P14             | <del>-</del>   |



23

Table 1.3 Pin assignment by mode (continued)

| PIN | MODE2    | MODE3        | MODE4           | MODE6          | MODE5           | MODE7          |
|-----|----------|--------------|-----------------|----------------|-----------------|----------------|
| No. | External | External     | Flash boot mode | UART boot mode | Flash boot mode | UART boot mode |
|     | 8bit BUS | 16bit BUS    | with 16bit BUS  | with 16bit BUS | (MICOM mode)    | (MICOM mode)   |
| 41  | A5       | <b>←</b>     | <b>←</b>        | <b>←</b>       | P15             | <b>←</b>       |
| 42  | A6       | <b>←</b>     | <b>←</b>        | <b>←</b>       | P16             | <b>←</b>       |
| 43  | A7       | <b>←</b>     | <b>+</b>        | +              | P17             | +              |
| 44  | VSS      | +            | +               | <b>←</b>       | +               | +              |
| 45  | A8       | +            | +               | <b>←</b>       | P20             | +              |
| 46  | A9       | +            | +               | <b>←</b>       | P21             | +              |
| 47  | A10      | +            | +               | <b>←</b>       | P22             | +              |
| 48  | A11      | <b>←</b>     | <b>←</b>        | <b>←</b>       | P23             | <b>←</b>       |
| 49  | A12      | <b>←</b>     | <b>←</b>        | <b>←</b>       | P24             | <b>←</b>       |
| 50  | A13      | +            | +               | +              | P25             | +              |
| 51  | A14      | +            | +               | +              | P26             | +              |
| 52  | A15      | +            | +               | +              | P27             | +              |
| 53  | A16      | +            | +               | +              | P50             | +              |
| 54  | A17      | +            | +               | +              | P51             | +              |
| 55  | A18      | +            | +               | +              | P52             | +              |
| 56  | A19      | <b>←</b>     | <b>←</b>        | <b>←</b>       | P53             | <b>←</b>       |
| 57  | VSS      | <b>←</b>     | <b>←</b>        | <b>←</b>       | <b>←</b>        | <b>←</b>       |
| 58  | nWAIT    | +            | +               | +              | P60             | +              |
| 59  | nBREQ    | <b>←</b>     | <del>(</del>    | <b>←</b>       | P61             | <b>←</b>       |
| 60  | nBACK    | <b>←</b>     | <b>←</b>        | <b>←</b>       | P62             | <b>←</b>       |
| 61  | CLKO     | <b>←</b>     | <b>←</b>        | <b>←</b>       | P67             | <b>←</b>       |
| 62  | nSTBY    | +            | +               | +              | nSTBY           | +              |
| 63  | nRES     | <b>←</b>     | <b>←</b>        | <b>←</b>       | nRES            | <b>←</b>       |
| 64  | nTRST    | <b>←</b>     | <b>←</b>        | <b>←</b>       | nTRST           | <b>←</b>       |
| 65  | VSS      | <b>←</b>     | +               | +              | <b>←</b>        | <b>←</b>       |
| 66  | XTALOUT  | <b>←</b>     | <b>←</b>        | <b>←</b>       | <b>←</b>        | <b>←</b>       |
| 67  | XTALIN   | <b>←</b>     | <b>←</b>        | <b>←</b>       | <del>(</del>    | <b>←</b>       |
| 68  | VDD      | <b>←</b>     | <del>(</del>    | <b>←</b>       | <b>←</b>        | <b>←</b>       |
| 69  | nAS      | <b>←</b>     | <b>←</b>        | <b>←</b>       | P63             | <b>←</b>       |
| 70  | nRD      | <b>←</b>     | <del>(</del>    | <b>←</b>       | P64             | <b>←</b>       |
| 71  | nHWR     | <del>-</del> | <b>←</b>        | <b>←</b>       | P65             | <b>←</b>       |
| 72  | nLWR     | <b>←</b>     | <b>←</b>        | <b>←</b>       | P66             | <b>←</b>       |
| 73  | MODE0    | <b>←</b>     | <b>+</b>        | <b>←</b>       | <b>←</b>        | <b>←</b>       |
| 73  | MODE1    | <b>←</b>     | <del>(</del>    | <del>(</del>   | <del>(</del>    | <b>←</b>       |
| 75  | MODE2    | <b>←</b>     | <b>←</b>        | <b>←</b>       | <b>←</b>        | <b>←</b>       |
| 76  | AVDD     | <b>←</b>     | <b>←</b>        | <b>←</b>       | <b>←</b>        | <b>←</b>       |
| 77  | AVREF    | <b>←</b>     | <b>+</b>        | <b>←</b>       | <b>←</b>        | +              |
| 78  | AN0      | <b>←</b>     | <b>←</b>        | <b>←</b>       | <b>←</b>        | <b>←</b>       |
| 79  | AN1      | <b>←</b>     | <b>←</b>        | <b>←</b>       | <b>←</b>        | <b>←</b>       |
| 80  | AN2      | +            | +               | +              | +               | +              |



Table 1.3 Pin assignment by mode (continued)

| PIN | MODE2    | MODE3     | MODE4           | MODE6          | MODE5           | MODE7          |
|-----|----------|-----------|-----------------|----------------|-----------------|----------------|
| No. | External | External  | Flash boot mode | UART boot mode | Flash boot mode | UART boot mode |
|     | 8bit BUS | 16bit BUS | with 16bit BUS  | with 16bit BUS | (Micro mode)    | (Micro mode)   |
| 81  | AN3      | <b>←</b>  | <b>←</b>        | <b>←</b>       | <b>←</b>        | <b>←</b>       |
| 82  | AN4      | +         | +               | +              | +               | +              |
| 83  | VSS      | +         | +               | +              | +               | +              |
| 84  | TIOCA5   | <b>←</b>  | <b>←</b>        | <b>←</b>       | <b>←</b>        | <b>←</b>       |
| 85  | TIOCB5   | <b>←</b>  | <b>←</b>        | <b>←</b>       | <b>←</b>        | <b>←</b>       |
| 86  | P75      | +         | +               | +              | +               | +              |
| 87  | nIRQ0    | +         | +               | +              | +               | +              |
| 88  | nCS3     | +         | +               | <b>←</b>       | P81             | <b>←</b>       |
| 89  | nCS2     | +         | +               | <b>←</b>       | P82             | <b>←</b>       |
| 90  | nCS1     | +         | +               | +              | P83             | +              |
| 91  | nCS0     | +         | +               | +              | P84             | +              |
| 92  | VSS      | +         | +               | +              | +               | +              |
| 93  | TCLKA    | +         | +               | +              | +               | +              |
| 94  | TCLKB    | +         | +               | +              | +               | +              |
| 95  | TCLKC    | <b>←</b>  | <del>(</del>    | <del>(</del>   | <b>←</b>        | <del>-</del>   |
| 96  | TCLKD    | +         | +               | +              | +               | +              |
| 97  | A23      | +         | +               | TIOCA1         | +               | +              |
| 98  | A22      | <b>←</b>  | +               | TIOCB1         | +               | <b>←</b>       |
| 99  | A21      | +         | +               | TIOCA2         | +               | +              |
| 100 | A20      | <b>←</b>  | <b>←</b>        | TIOCB2         | <b>←</b>        | <b>←</b>       |



#### 1.5 Memory Map



Figure 1.3 AX07CF192 Memory Map



Figure 1.4 Mode 3 Memory Map



#### Chapter 1

26



Figure 1.5 Memory Map of Modes 4 and 5



Figure 1.6 Memory Map of Modes 6 and 7



## Chapter 2 ARM7TDMI Core



#### 2.1 General Description

The ARM7TDMI is a member of the ARM family of general-purpose 32-bit microprocessors, which offer high performance and very low power consumption. This processor employs a unique architectural strategy known as THUMB, which makes it ideally suited to high volume applications with memory restrictions or applications where code density is an issue.

The key idea behind THUMB is a super reduced instruction set. Essentially, the ARM7TDMI has two instruction sets, the standard 32-bit ARM set and the 16-bit THUMB set. The THUMB set's 16-bit instruction length allows it to approach twice the density of standard ARM code while retaining most of the ARM's performance advantage over a traditional 16-bit processor by using 16-bit registers. This is possible because THUMB code operates on the same 32-bit register set as ARM code.

See also the ARM7TDMI Datasheet (ARM DDI 0029E) for further details.

#### 2.2 Features

- 32bit RISC architecture
- Low power consumption
- ARM7TDMI core with:
- On-chip ICEbreaker debug support
- 32-bit x 8 hardware multiplier
- Thumb decompressor
- Utilizes the ARM7TDMI embedded processor
- High performance 32-bit RISC architecture
- High density 16 bit instruction set (THUMB code)
- Fully static operation: 0 ~ 80MHz
- 3-stage pipeline architecture (Fetch, decode, and execution stages)
- Enhanced ARM software toolkit

THUMB code is able to provide up to 65% of the code size of ARM, and 160% of the performance of an equivalent ARM processor connected to a 16-bit memory system.



AX07CF192

28

#### 2.3 Core Block Diagram



Figure 2.1 ARM7TDMI Core Block Diagram



#### 2.4 Instruction Set

#### 2.4.1 ARM Instructions



Figure 2.2 ARM instruction set formats



Table 2.1 The ARM Instruction set

| Mnemonic | Instruction                                    | Action                                     |  |  |
|----------|------------------------------------------------|--------------------------------------------|--|--|
| ADC      | Add with carry                                 | Rd := Rn + Op2 + Carry                     |  |  |
| ADD      | Add                                            | Rd := Rn + Op2                             |  |  |
| AND      | AND                                            | Rd := Rn AND Op2                           |  |  |
| В        | Branch                                         | R15 := address                             |  |  |
| BIC      | Bit Clear                                      | Rd := Rn AND NOT Op2                       |  |  |
| BL       | Branch with Link                               | R14 := R15, R15 := address                 |  |  |
| ВХ       | Branch and Exchange                            | R15 := Rn, T bit := Rn[0]                  |  |  |
| CDP      | Coprocessor Data Processing                    | (Coprocessor-specific)                     |  |  |
| CMN      | Compare Negative                               | CPSR flags := Rn + Op2                     |  |  |
| CMP      | Compare                                        | CPSR flags := Rn - Op2                     |  |  |
| EOR      | Exclusive OR                                   | Rd := (Rn AND NOT Op2) OR (op2 AND NOT Rn) |  |  |
| LDC      | Load coprocessor from memory                   | Coprocessor load                           |  |  |
| LDM      | Load multiple registers                        | Stack manipulation (Pop)                   |  |  |
| LDR      | Load register from memory                      | Rd := (address)                            |  |  |
| MCR      | Move CPU register to coprocessor register      | cRn := rRn { <op>cRm}</op>                 |  |  |
| MLA      | Multiply Accumulate                            | Rd := (Rm * Rs) + Rn                       |  |  |
| MOV      | Move register or constant                      | Rd:= Op2                                   |  |  |
| MRC      | Move from coprocessor register to CPU register | Rn := cRn { <op>cRm}</op>                  |  |  |
| MRS      | Move PSR status/flags to register              | Rn := PSR                                  |  |  |
| MSR      | Move register to PSR status/flags              | PSR := Rm                                  |  |  |
| MUL      | Multiply                                       | Rd := Rm * Rs                              |  |  |
| MVN      | Move negative register                         | Rd := 0XFFFFFFF EOR Op2                    |  |  |
| ORR      | OR                                             | Rd := Rn OR Op2                            |  |  |
| RSB      | Reverse Subtract                               | Rd := Op2 - Rn                             |  |  |
| RSC      | Reverse Subtract with Carry                    | Rd := Op2 - Rn - 1 + Carry                 |  |  |
| SBC      | Subtract with Carry                            | Rd := Rn - Op2 - 1 + Carry                 |  |  |
| STC      | Store coprocessor register to memory           | address := CRn                             |  |  |
| STM      | Store Multiple                                 | Stack manipulation (Push)                  |  |  |
| STR      | Store register to memory                       | <address> := Rd</address>                  |  |  |
| SUB      | SUB Subtract Rd := Rn - Op2                    |                                            |  |  |
| SWI      | Software Interrupt                             | OS call                                    |  |  |
| SWP      | Swap register with memory                      | Rd := [Rn], [Rn] := Rm                     |  |  |
| TEQ      | Test bitwise equality                          | CPSR flags := Rn EOR Op2                   |  |  |
| TST      | Test bits                                      | CPSR flags := Rn AND Op2                   |  |  |



| System & User                      | FIQ              | Supervisor    | Abort         | IRQ           | Undefined     |  |
|------------------------------------|------------------|---------------|---------------|---------------|---------------|--|
| R0                                 | R0               | R0            | R0            | R0            | R0            |  |
| R1                                 | R1               | R1            | R1            | R1            | R1            |  |
| R2                                 | R2               | R2            | R2            | R2            | R2            |  |
| R3                                 | R3               | R3            | R3            | R3            | R3            |  |
| R4                                 | R4               | R4            | R4            | R4            | R4            |  |
| R5                                 | R5               | R5            | R5            | R5            | R5            |  |
| R6                                 | R6               | R6            | R6            | R6            | R6            |  |
| R7                                 | R7               | R7            | R7            | R7            | R7            |  |
| R8                                 | R8_fiq           | R8            | R8            | R8            | R8            |  |
| R9                                 | R9_fiq           | R9            | R9            | R9            | R9            |  |
| R10                                | <b>▼ R10_fiq</b> | R10           | R10           | R10           | R10           |  |
| R11                                | <b>№</b> R11_fiq | R11           | R11           | R11           | R11           |  |
| R12                                | R12_fiq          | R12           | R12           | R12           | R12           |  |
| R13                                | <b>▼ R13_fiq</b> | R13_svc       | R13_abt       | R13_irq       | R13_und       |  |
| R14                                | R14_fiq          | R14_svc       |               | R14_irq       | R14_und       |  |
| R15 (PC)                           | R15 (PC)         | R15 (PC)      | R15 (PC)      | R15 (PC)      | R15 (PC)      |  |
| ARM state Program Status Registers |                  |               |               |               |               |  |
| CPSR                               | CPSR SPSR_fiq    | CPSR SPSR_svc | CPSR SPSR_abt | CPSR SPSR_irq | CPSR SPSR_und |  |

Figure 2.3 Register Organization in ARM state



#### 2.4.2 THUMB Instruction



Figure 2.4 THUMB instruction set formats



Table 2.2 THUMB instruction set opcodes

| Mnemonic | Instruction                 | Lo reg. oper. | Hi reg. oper | Condition code set |
|----------|-----------------------------|---------------|--------------|--------------------|
| ADC      | Add with Carry              | V             |              | V                  |
| ADD      | Add                         | V             | V            | V                  |
| AND      | AND                         | V             |              | V                  |
| ASR      | R Arithmetic Shift Right    |               |              | V                  |
| В        | Unconditional branch        | V             |              |                    |
| Вхх      | Conditional branch          | V             |              |                    |
| BIC      | Bit Clear                   | V             |              | V                  |
| BL       | Branch and Link             |               |              |                    |
| ВХ       | Branch and Exchange         | V             |              | V                  |
| CMN      | Compare Negative            | V             |              | V                  |
| СМР      | Compare                     | V             | V            | V                  |
| EOR      | EOR                         | V             |              | V                  |
| LDMIA    | Load multiple               | V             |              |                    |
| LDR      | Load word                   | V             |              |                    |
| LDRB     | Load byte                   | V             |              |                    |
| LDRH     | Load halfword               | V             |              |                    |
| LSL      | Logical Shift Left          | V             |              | V                  |
| LDSB     | Load sign-extended byte     | V             |              |                    |
| LDSH     | Load sign-extended Halfword | V             |              |                    |
| LSR      | Logical Shift Right         | V             |              | V                  |
| MOV      | Move register               | V             | V            | V                  |
| MUL      | Multiply                    | V             |              | V                  |
| MVN      | Move Negative register      | V             |              | V                  |
| NEG      | Negate                      | V             |              | V                  |
| ORR      | OR                          | V             |              | V                  |
| POP      | Pop registers               | V             |              |                    |
| PUSH     | Push registers              | V             |              |                    |
| ROR      | Rotate Right                | V             |              | V                  |
| SBC      | Subtract with Carry         | V             |              | V                  |
| STMIA    | Store Multiple              | V             |              |                    |
| STR      | Store word                  | V             |              |                    |
| STRB     | Store byte                  | V             |              |                    |
| STRH     | Store halfword              | V             |              |                    |
| SWI      | Software Interrupt          |               |              |                    |
| SUB      | Subtract                    | V             |              | V                  |
| TST      | Test bits                   | V             |              | V                  |







Figure 2.5 Register Organization in THUMB state



Figure 2.6 Mapping of THUMB state registers onto ARM state registers.



Table 2.3 Condition code summary

| Code | Suffix | Flags     | Meaning                                      |
|------|--------|-----------|----------------------------------------------|
| 0000 | EQ     | Z         | set equal                                    |
| 0001 | NE     | Z         | clear not equal                              |
| 0010 | CS     | C         | set unsigned higher or same                  |
| 0011 | CC     | С         | clear unsigned lower                         |
| 0100 | MI     | N         | set negative                                 |
| 0101 | PL     | N         | clear positive or zero                       |
| 0110 | VS     | V         | set overflow                                 |
| 0111 | VC     | V         | clear no overflow                            |
| 1000 | HI     | С         | set and Z clear unsigned higher              |
| 1001 | LS     | С         | clear or Z set unsigned lower or same        |
| 1010 | GE     | N         | equals V greater or equal                    |
| 1011 | LT     | N         | not equal to V less than                     |
| 1100 | GT     | Z         | clear AND (N equals V) greater than          |
| 1101 | LE     | Z         | set OR (N not equal to V) less than or equal |
| 1110 | AL     | (Ignored) | always                                       |

#### 2.4.3 The Program Status Registers

The ARM7TDMI contains a Current Program Status Register (CPSR), plus five Saved Program Status Registers (SPSRs) for use by exception handlers. These registers hold information about the most recently performed ALU operation, control the enabling and disabling of interrupts, and set the processor operating mode

The arrangement of bits is shown in Fig. 2.7 Program status register format.



Figure 2.7 Program status register format



#### 2.4.3.1 The condition code flags

The N,Z,C and V bits are the condition code flags. These may be changed as a result of arithmetic and logical operations, and may be tested to determine whether an instruction should be executed.

In ARM state, all instructions may be executed conditionally: see table 2.3 in chapter 2.4.2.

In THUMB state, only the Branch instruction is capable of conditional execution

#### 2.4.3.2 The control bits

The bottom 8 bits of a PSR (incorporating I,F,T and M[4:0]) are known collectively as the control bits. These will change when an exception arises. If the processor is operating in a privileged mode, they can also be manipulated by software.

The T bit This reflects the operating state. When this bit is set, the

processor is executing in THUMB state, otherwise it is

executing in ARM state.

Note that the software must never change the state of the TBIT in the CPSR. If this happens, the processor will

enter an unpredictable state.

Interrupt disable bits The I and F bits are the interrupt disable bits. When set,

these disable the IRQ and FIQ interrupts respectively.

The mode bits The M4, M3, M2, M1 and M0 bits (M[4:0]) are the mode

bits. These determine the processor's operating mode, as

shown in table 2.4.

Not all combinations of the mode bits define a valid processor mode. Only those explicitly described may be used. The user should be aware that if any illegal value is programmed into the mode bits, **M**{4:0}, then the processor

will enter an unrecoverable state. If this occurs, a reset should be applied.

Reserved bits The remaining bits in the PSRs are reserved. When

changing a PSR's flag or control bits, you must ensure that these unused bits are not altered. Also, your program should not rely on them containing specific values, since in

future processors they may read as one or zero.



38

Table 2.4 PSR mode bit values

| M[4:0] | Mode       | Visible THUMB state                            | Visible ARM state                                 |
|--------|------------|------------------------------------------------|---------------------------------------------------|
| W[4.0] | Wiode      | registers                                      | registers                                         |
| 10000  | User       | R7R0,<br>LR, SP,<br>PC, CPSR                   | R14R0,<br>PC, CPSR                                |
| 10001  | FIQ        | R7R0,<br>LR_fiq, SP_fiq,<br>PC, CPSR, SPSR_fiq | R7R0,<br>R14_fiqR8_fiq,<br>PC, CPSR, SPSR_fiq     |
| 10010  | IRQ        | R7R0,<br>LR_irq, SP_irq,<br>PC, CPSR, SPSR_irq | R12R0,<br>R14_irq, R13_irq,<br>PC, CPSR, SPSR_irq |
| 10011  | Supervisor | R7R0,<br>LR_svc, SP_svc,<br>PC, CPSR, SPSR_svc | R12R0,<br>R14_svc, R13_svc,<br>PC, CPSR, SPSR_svc |
| 10111  | Abort      | R7R0,<br>LR_abt, SP_abt,<br>PC, CPSR, SPSR_abt | R12R0,<br>R14_abt, R13_abt,<br>PC, CPSR, SPSR_abt |
| 11011  | Undefined  | R7R0,<br>LR_und, SP_und,<br>PC, CPSR, SPSR_und | R12R0,<br>R14_und, R13_und,<br>PC, CPSR           |
| 11111  | System     | R7R0,<br>LR, SP,<br>PC, CPSR                   | R14R0,<br>PC, CPSR                                |



39

## 2.4.4 ARM pseudo-instructions

**ADR** 

The ADR pseudo-instruction loads a program-relative or register-relative address into a register.

**Syntax** 

The syntax of ADR is:

ADR{ condition} register, expression

where:

register is the register to load.

expression is a program-relative or register-relative expression that evaluates to:

a non word-aligned address within 255 bytes
a word-aligned address within 1020 bytes.

The address can be either before or after the address of the instruction or the base register.

Usage

ADR always assembles to one instruction. The assembler attempts to produce a single ADD or SUB instruction to load the address. If the address cannot be constructed in a single instruction, an error is generated and the assembly fails.

Use the ADRL pseudo-instruction to assemble a wider range of effective addresses.

If the expression is program-relative, it must evaluate to an address in the same code area as the ADR

pseudo-instruction. Otherwise the address may be out of range after linking.

Example

start MOV r0,#10

ADR r4,start ; => SUB r4,pc,#0xc



**ADRL** 

The ADRL pseudo-instruction loads a program-relative or register-relative address into a register. It is similar to the ADR pseudo-instruction. ADRL can load a wider range of addresses than ADR because it generates two data processing instructions.

**Syntax** 

The syntax of ADRL is:

ADRL{ condition} register, expression

where:

register is the register to load.

expression is a register-relative or program-relative expression that evaluates to:

• a non word-aligned address within 64KB

a word-aligned address within 256KB.

The address can be either before or after the address of the instruction or the base register.

Usage

ADRL always assembles to two instructions. Even if the address can be reached in a single instruction, a second, redundant instruction is produced.

If the assembler cannot construct the address in two instructions, it generates an error message and the assembly fails. See *LDR ARM pseudo-instruction* for information on loading a wider range of addresses. See also Chapter 5 *Basic Assembly Language Programming* in the *ARM Software* 

Development Toolkit User Guide.

If the expression is program-relative, it must evaluate to an address in the same code area as the ADRL pseudo-instruction. Otherwise the address may be out of range after linking.

Note

ADRL is not available when assembling Thumb instructions. Use it only in ARM code.

Example

start MOV r0,#10

ADRL r4,start + 60000 ; → ADD r4,pc,#0xe800 ; ADD r4,r4,#0x254



AX07CF192

### **LDR**

The LDR pseudo-instruction loads a register with either:

- a 32-bit constant value
- an address.

Note

This section describes the LDR *pseud*o-instruction only. Refer to the *ARM Architectural Reference Manual* for information on the LDR *instruction*.

**Syntax** 

The syntax of LDR is:

LDR{ condition} register, =[ expression | label-expression]

where:

condition is an optional condition code. register is the register to be loaded. expression evaluates to a numeric constant:

- If the value of expression is within range of a MOV or MVN instruction, the assembler generates the appropriate instruction.
- If the value of expression is *not* within range of a MOV or MVN instruction, the assembler places the constant in a literal pool and generates a program-relative LDR instruction that reads the constant from the literal pool.

The offset from the pc to the constant must be less than 4KB. You are responsible for ensuring that there is a literal pool within range. See *LTORG directive* for more information. *label-expression* is a program-relative or external expression. The assembler places the value of label-expression in a literal pool and generates a program-relative LDR instruction that loads the value from the literal pool.

The offset from the pc to the value in the literal pool must be less than 4KB. You are responsible for ensuring that there is a literal pool within range. See *LTORG directive* for more information.

If label-expression is an external expression, or is not contained in the current area, the assembler places a linker relocation directive in the object file. The linker ensures that the correct address is generated at link time.

Usage

The LDR pseudo-instruction is used for two main purposes:

- to generate literal constants when an immediate value cannot be moved into a register because it is out of range of the MOV and MVN instructions.
- to load a program-relative or external address into a register. The address remains valid regardless of where the linker places the AOF area containing the LDR.

Refer to Chapter 5 Basic Assembly Language Programming in the ARM Software Development Toolkit User Guide for a more detailed explanation of how to use LDR, and for more information on MOV and MVN.

Example

LDR r1,=0xfff ; loads 0xfff into r1

:

LDR r2,=place; loads the address of

; place into r2



AX07CF192

**NOP** 

NOP generates the preferred ARM no-operation code. This is:

MOV r0,r0

**Syntax** 

The syntax of NOP is:

NOP

Usage

NOP cannot be used conditionally. Not executing a no-operation is the same as executing it, so conditional execution is not required. Condition codes are unaltered by NOP.



AX07CF192

### 2.4.5 THUMB pseudo-instructions

**ADR** 

The thumb ADR pseudo-instruction loads a program-relative or register-relative address into a register.

**Syntax** 

The syntax of ADR is:

ADR register, expression

where:

register is the register to load.

Expression is a register-relative or program-relative expression that evaluates to awordaligned address within the range +4 to +1020 bytes. Expression must be defined locally, it

cannot be imported

Refer to MAP directive for more information on register-relative expressions.

Usage

In Thumb state, ADR can generate word-aligned addresses only. Use the ALIGN directive to ensure

that expression is aligned.

If expression is program-relative, it must evaluate to an address in the same code area as the ADR pseudo-instruction. There is no guarantee that the address will be within range after linking if it resides

in another AOF area.

Example

ADR r4, txampl ; → ADD r4,pc,#nn

; code ALIGN

txampl DCW 0,0,0,0



AX07CF192

#### **LDR**

The thumb LDR pseudo-instruction loads a low register with either:

- a 32-bit constant value
- an address.

Note

This section describes the LDR *pseudo*-instruction only. Refer to the *ARM Architectural Reference Manual* for information on the LDR *instruction*.

**Syntax** 

The syntax of LDR is:

LDR register, =[ expression | label-expression]

where:

register is the register to be loaded. LDR can access the low registers (r0-r7) only. expression evaluates to a numeric constant:

- If the value of expression is within range of a MOV instruction, the assembler generates the instruction.
- If the value of expression is *not* within range of a MOV instruction, the assembler places the constant in a literal pool and generates a program-relative LDR instruction that reads the constant from the literal pool.

The offset from the pc to the constant must be positive and less than 1KB. You are responsible for ensuring that there is a literal pool within range. See *LTORG directive* for more information.

*label-expression* is a program-relative or external expression. The assembler places the value of label-expression in a literal pool and generates a program-relative LDR instruction that loads the value from the literal pool.

The offset from the pc to the value in the literal pool must be positive and less than 1KB. You are responsible for ensuring that there is a literal pool within range. See *LTORG directive* for more information.

If label-expression is an external expression, or is not contained in the current area, the assembler places a linker relocation directive in the object file. The linker ensures that the correct address is generated at link time.

Usage

The LDR pseudo-instruction is used for two main purposes:

- to generate literal constants when an immediate value cannot be moved into a register because it is out of range of the MOV instruction.
- to load a program-relative or external address into a register. The address remains valid regardless of where the linker places the AOF area containing the LDR.

Refer to Chapter 5 Basic Assembly Language Programming in the ARM Software Development Toolkit User Guide for a more detailed explanation of how to use LDR, and for more information on MOV.

Example

LDR r1, =0xfff ; loads 0xfff into r1

LDR r2, = labelname ; loads the address of

; labelname into r2



AX07CF192

MOV

The Thumb MOV pseudo-instruction moves the value of a low register to another low register (r0-r7).

The Thumb MOV *instruction* cannot move values from one low register to another.

Note

The ADD immediate instruction generated by the assembler has the side-effect of updating the

condition codes.

**Syntax** 

The syntax of MOV is:

MOV Rd, Rs

where:

Rd is the destination register. Rs is the source register.

Usage

The MOV pseudo-instruction uses an ADD immediate instruction with a zero immediate value.

Refer to the ARM Architectural Reference Manualfor more information on the Thumb MOV instruction.

**Example** 

MOV Rd, Rs ; generates the opcode for ADD Rd, Rs, #0



**NOP** 

NOP generates the preferred Thumb no-operation instruction. This is:  $\ensuremath{\mathsf{MOV}}$  r8,r8

**Syntax** 

The syntax for NOP is:

NOP

Usage

Condition codes are unaltered by NOP



**AX07CF192** 

# Chapter 3 **BUS Controller**



#### 3.1 Overview

The AX07CF192 has an on-chip bus controller that manages the external address space divided into eight areas, which can consist of SRAM, ROM, Flash-memory or off-chip peripheral devices. The bus specifications, such as bus width and number of access states, can be set independently for each area, enabling multiple memories to be connected easily.

#### 3.1.1 Features

- 8-bit access or 16-bit access can be selected for each area
   (In THUMB mode, only 16-bit accessing of external code memory is allowed)
- Active-low chip select signals (nCS<sub>0</sub> to nCS<sub>7</sub>) can be output for areas 0 to 7
- Bus specifications can be set independently for each area
- Support Little-Endian Memory Format
- Variable wait states (up to 16 waits)
- Bus transfers can be extended using the nWAIT signal. The nWAIT signal is active-low
- Each area is 16MB (when SM='0' in PMU), or 1MB (when SM='1' in PMU) in size and can be programmed individually.



Figure 3.1 Block Diagram of the Bus Controller



# 3.1.2 Pin Configuration

**Table 3.1** summarizes the input/output pins of the bus controller.

Table 3.1 Bus Controller Pins

| Name             | I/O | Function                                                                                                                                                  |  |  |  |  |  |  |  |  |  |  |
|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|
| nCS <sub>n</sub> | 0   | Strobe signals selecting areas 0 to 7                                                                                                                     |  |  |  |  |  |  |  |  |  |  |
| nAS              | 0   | Strobe signal indicating valid address output on the address bus                                                                                          |  |  |  |  |  |  |  |  |  |  |
| nRD              | 0   | Strobe signal indicating reading from the external address space                                                                                          |  |  |  |  |  |  |  |  |  |  |
| nHWR             | 0   | Strobe signal indicating writing to the external address space, with valid data on the upper data bus ( <b>D</b> <sub>15</sub> to <b>D</b> <sub>8</sub> ) |  |  |  |  |  |  |  |  |  |  |
| nLWR             | 0   | Strobe signal indicating writing to the external address space, with valid data on the lower data bus ( <b>D</b> <sub>7</sub> to <b>D</b> <sub>0</sub> )  |  |  |  |  |  |  |  |  |  |  |
| nWAIT            | -   | Wait request signal                                                                                                                                       |  |  |  |  |  |  |  |  |  |  |
| nBREQ            | I   | Request signal for releasing the bus to an external device                                                                                                |  |  |  |  |  |  |  |  |  |  |
| nBACK            | 0   | Acknowledge signal indicating release of the bus to an external device                                                                                    |  |  |  |  |  |  |  |  |  |  |



# 3.2 Bus Controller Registers

The base address for the Bus Controller's registers is  $0x0900\_0100$ . Each configuration register (BCR0~7) is assigned to the area selected by CS0~CS7.

Table 3.2 Bus Controller Register Map

| Reg. | I/O<br>Offset | Dir. | Description                    | Initial<br>Value |
|------|---------------|------|--------------------------------|------------------|
| BCR0 | 0x0100        | R/W  | CS0 Bus Configuration Register | 0x10F*           |
| BCR1 | 0x0104        | R/W  | CS1 Bus Configuration Register | 0x0              |
| BCR2 | 0x0108        | R/W  | CS2 Bus Configuration Register | 0x0              |
| BCR3 | 0x010C        | R/W  | CS3 Bus Configuration Register | 0x0              |
| BCR4 | 0x0110        | R/W  | CS4 Bus Configuration Register | 0x0              |
| BCR5 | 0x0114        | R/W  | CS5 Bus Configuration Register | 0x0              |
| BCR6 | 0x0118        | R/W  | CS6 Bus Configuration Register | 0x0              |
| BCR7 | 0x011C        | R/W  | CS7 Bus Configuration Register | 0x0              |

Notes: 1) In mode 2, the initial value of BCR0 is 0x010F



<sup>2)</sup> In mode 3, the initial value of BCR0 is 0x000F.

<sup>3)</sup> The initial values of the other control registers are 0x0000.

### 3.2.1 Configuration Registers

The configuration registers (BCR0~7) are 16-bit read-write registers.

#### BCR0~7 Bus Configuration Registers (0x0900\_0100 to 0x0900\_011C R/W)

|       | B15 - b9 | b8       | b7       | B6 | B5     | b4 | b3 | b2    | b1      | b0 |
|-------|----------|----------|----------|----|--------|----|----|-------|---------|----|
| BCRn  | Reserved | MemWidth | Reserved | R  | eserve | d  | ١  | Norma | al Wait | t  |
| Reset | 0000000  | 1        | 0        | 0  | 0      | 0  | 1  | 1     | 1       | 1  |

Initial value : 0x010F (BCR0 in Mode2) 0x000F (BCR0 in Mode3) 0x0000 (BCR1~7)

MemWidth Selects the size of the external bus width. When this bit is 0 the MCU will interface with a 16-bit external bus. When 1, the external bus is 8 bits wide.

NormWait Select the values of the normal access wait state

0000: 1 wait state 0001: 2 wait state 0010: 3 wait state 0011: 4 wait state 0100: 5 wait state 0101: 6 wait state 0110: 7 wait state 0111: 8 wait state 1000: 9 wait state 1001: 10 wait state 1010: 11 wait state 1011: 12 wait state 1100: 13 wait state 1101: 14 wait state 1101: 15 wait state

1111:16 wait state



## 3.3 Operation

#### 3.3.1 Area Division

The external address space is divided into areas 0 to 7. Each area has a size of 16-Mbyte or 1-Mbyte modes depending on the value of SM in the PMU register. Figure 3.2 shows a general view of the memory map.

| nCS7  | 0x07FF FFFF | Reserved | 0x07FF FF |
|-------|-------------|----------|-----------|
|       | 0x0700 0000 |          |           |
| nCS6  | 0x06FF FFFF |          |           |
|       | 0x0600 0000 |          |           |
| nCS5  | 0x05FF FFFF |          | 0x0080 00 |
|       | 0x0500 0000 | nCS7     | 0x007F FF |
|       | 0x04FF FFFF |          | 0x0070 00 |
| nCS4  | 0.04111111  | nCS6     | 0x006F FF |
|       | 0x0400 0000 |          | 0x0060 00 |
| nCS3  | 0x03FF FFFF | nCS5     | 0x005F FF |
| 11000 |             |          | 0x0050 00 |
|       | 0x0300 0000 | nCS4     | 0x004F FF |
| nCS2  | 0x02FF FFFF |          | 0x0040 00 |
| nCS2  |             | nCS3     | 0x003F FF |
|       | 0x0200 0000 |          | 0x0030 00 |
| nCS1  | 0x01FF FFFF | nCS2     | 0x002F FF |
|       |             |          | 0x0020 00 |
|       | 0x0100 0000 | nCS1     | 0x001F FF |
| nCS0  | 0x00FF FFFF |          | 0x0010 00 |
|       |             | NCS0     | 0x000F FF |
|       | 0x0000 0000 |          | 0x0000 00 |

Figure 3.2 Access Area Map for Each Operating Mode

Chip select signals ( $nCS_0$  to  $nCS_7$ ) can be output for areas 0 to 7. The bus specifications for each area are selected in **BCR0** to **BCR7**.



#### 3.3.2 Area Division

The external space bus specifications consist of two elements: (1) bus width, (2) number of wait states

The bus width and number of wait states for on-chip memory and registers are fixed, and are not affected by the bus controller.

**Bus Width:** A bus width of 8 or 16 bits can be selected with the MemWidth bit-field in BCR0 to 7. An area for which an 8-bit bus is selected functions as an 8-bit address space, and an area for which a 16-bit bus is selected functions as a 16-bit address space.

If all areas are designated for 8-bit access, the 8-bit bus mode is set; if any area is designated for 16-bit access, the 16-bit bus mode is set.

**Number of Wait States:** One to 16 wait states can be selected with the NormalWait bit-field in BCR0 to 7. The number of wait states can be extended by using the nWAID signal. If nWAIT is low at the end of the wait states inserted according to the NormalWait bit-field, additional wait states will be inserted until nWAIT is returned high (see Figure 3.17).

#### 3.3.3 Chip Select Signals

For each of areas 0 to 7, the AX07CF192 can output a chip select signal ( $nCS_0$  to  $nCS_7$ ) that goes low when the corresponding area is selected in expanded mode. *Figures 3.3* to 3.15 show the output timing of the  $nCS_{0-7}$  signals.

Output of  $nCS_0$  to  $nCS_7$ : Output of  $nCS_0$  to  $nCS_7$  is enabled or disabled in the data direction register of the corresponding port.



#### 3.4 Basic Bus Interface

#### 3.4.1 Overview

The AX07CF192 has a basic bus interface that allows direct connection of ROM, SRAM, off-chip peripheral devices and so on.

### 3.4.2 Byte Lane Write Control

The possible data widths for the CPU and other internal masters are byte (8-bit), half-word (16-bit), or word (32-bit). The bus controller has a data alignment function, and when accessing external memory space, controls whether the upper data bus ( $\mathbf{D}_{15}$  to  $\mathbf{D}_{8}$ ) or lower data bus ( $\mathbf{D}_{7}$  to  $\mathbf{D}_{0}$ ) is used, according to the bus specifications for the area being accessed (8-bit access area or 16-bit access area) and the data size.

**8-Bit Access Areas:** *Figure 3.3* shows data alignment control for 8-bit access space. With 8-bit access space, the lower data bus ( $D_7$  to  $D_0$ ) is always used for accesses. The amount of data that can be accessed at one time is one byte: a half-word access is performed as two byte accesses, and a word access, as four byte accesses.



Figure 3.3 Access Size and Data Alignment Control (8-Bit Access Area)



**16-Bit Access Areas:** *Figure 3.4* shows data alignment control for 16-bit access areas. With 16-bit access areas, both the lower data bus ( $D_7$  to  $D_0$ ) and the higher data bus ( $D_{15}$  to  $D_8$ ) are used for accesses. The amount of data that can be accessed at one time is one byte or one half-word, and a word access is executed as two half-word accesses.



Figure 3.4 Access Size and Data Alignment Control (16-Bit Access Area)

**nHWR**, **nLWR** signals are generated according to the memory transfer width, external memory width, **A0**, and the access sequencing as shown in the following table (assuming 16-bit external memory):

Table 3.3 Byte Lane condition by XA[0]

|                    |                                             | <u>, , , , , , , , , , , , , , , , , , , </u>     |                                                                |                                                                                                                                                                        |
|--------------------|---------------------------------------------|---------------------------------------------------|----------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CPU access Size    | A0                                          | nHWR                                              | nLWR                                                           | Number of<br>Accesses                                                                                                                                                  |
| Word (32bit)       | Х                                           | Low                                               | Low                                                            | 2                                                                                                                                                                      |
| Half-word (16-bit) | Х                                           | Low                                               | Low                                                            | 1                                                                                                                                                                      |
| Byte (8bit)        | 0                                           | High                                              | Low                                                            | 1                                                                                                                                                                      |
| Byte (8bit)        | 1                                           | Low                                               | High                                                           | 1                                                                                                                                                                      |
|                    | Word (32bit) Half-word (16-bit) Byte (8bit) | Word (32bit) X Half-word (16-bit) X Byte (8bit) 0 | Word (32bit) X Low Half-word (16-bit) X Low Byte (8bit) 0 High | Word (32bit)         X         Low         Low           Half-word (16-bit)         X         Low         Low           Byte (8bit)         0         High         Low |



#### 3.4.3 Basic Bus Control Signal Timing

**16-Bit 1-Wait-Access Areas:** *Figure 3.5* shows the write timing of bus control signals for a 16-Bit 1-wait-access area (32-bit word access). *Figure 3.6* shows the read timing of bus control signals for a 16-Bit 1-wait-access area (32-bit word access). In this case the NormWait value in **BCR** of this area is '0'.

Note: Sequential read access keeps the nRD signal in a LOW state.



Figure 3.5 Bus Control Signal Write Timing for 16-Bit, 1-Wait (Word Access)



Figure 3.6 Bus Control Signal Read Timing for 16-Bit, 1-Wait (Word Access)



word access). Figure 3.8 shows the read timing of bus control signals for a 16-Bit 1-wait-access area (half-word access).



Figure 3.7 Bus Control Signal Write Timing for 16-Bit, 1-Wait (Half-word Access)



Figure 3.8 Bus Control Signal Read Timing for 16-Bit, 1-Wait (Half-word Access)



**Figure 3.9** shows the write timing of bus control signals for a 16-Bit 1-wait-access area (byte access). **Figure 3.10** shows the read timing of bus control signals for a 16-Bit 1-wait-access area (byte access).



Figure 3.9 Bus Control Signal Write Timing for 16-Bit, 1-Wait (Byte Access)



Figure 3.10 Bus Control Signal Read Timing for 16-Bit, 1-Wait (Byte Access)



Figure 3.11 shows the write timing of bus control signals for a 16-Bit 2-wait-access area (word access). Figure 3.12 shows the read timing of bus control signals for a 16-Bit 2-wait-access area (word access).



Figure 3.11 Bus Control Signal Write Timing for 16-Bit, 2-Wait (Word Access)



Figure 3.12 Bus Control Signal Read Timing for 16-Bit, 2-Wait (Word Access)



**Figure 3.13** shows the write timing of bus control signals for a 16-Bit 2-wait-access area (half-word access). **Figure 3.14** shows the read timing of bus control signals for a 16-Bit 2-wait-access area (half-word access).



Figure 3.13 Bus Control Signal Write Timing for 16-Bit, 2-Wait (Half-Word Access)



Figure 3.14 Bus Control Signal Read Timing for 16-Bit, 2-Wait (Half-Word Access)



**Figure 3.15** shows the write timing of bus control signals for a 16-Bit 2-wait-access area (byte access). **Figure 3.16** shows the read timing of bus control signals for a 16-Bit 2-wait-access area (byte access).



Figure 3.15 Bus Control Signal Write Timing for 16-Bit, 2-Wait (Byte Access)



Figure 3.16 Bus Control Signal Read Timing for 16-Bit, 2-Wait (Byte Access)



AX07CF192

#### 3.4.4 Wait Control

When accessing external memory space, the AX07CF192 can extend the bus cycle by inserting wait states (Tw). There are two ways of inserting wait states: (1) program wait insertion and (2) pin wait insertion using the **nWAIT** pin.

**Program Wait Insertion:** From 1 to 16 wait states can be inserted automatically between the T2 state and T3 state on an individual basis in each access space, according to the settings of the NormWait bit fields in **BCR0~7**.

**Pin Wait Insertion:** When external space is accessed in this state, a program wait is first inserted. If the **nWAIT** pin is low at the falling edge of XIN in the last T2 or Tw state, another Tw state is inserted. If the **nWAIT** pin is held low, Tw states are inserted until it goes high.

Figure 3.17 shows an example of the timing for insertion of one program wait state in 3-wait-state space.



Figure 3.17 Example of Wait State Insertion Timing.



#### 3.4.5 Bus Arbiter

The bus controller has a built-in bus arbiter that arbitrates between different bus masters. The bus master can be either the CPU or an external bus master. When a bus master has the bus right it can carry out read and write operations. Each bus master uses a bus request signal to request the bus right. At fixed times the bus arbiter determines priority and uses a bus acknowledge signal to grant the bus to a bus master, which can then use the bus.

The bus arbiter checks whether the bus request signal from a bus master is active or inactive, and returns an acknowledge signal to the bus master. When two or more bus masters request the bus, the highest-priority bus master receives an acknowledge signal and can continue to use the bus until the acknowledge signal is deactivated.

The bus master priority order is:

(High) External bus master > ARM CPU (Low)

The bus arbiter samples the bus request signals and determines priority at all times, but it does not always grant the bus immediately, even when it receives a bus request from a bus master with higher priority than the current bus master. Each bus master has certain times at which it can release the bus to a higher-priority bus master.

**ARM CPU:** The ARM CPU is the lowest-priority bus master. If an external bus master requests the bus while the CPU has the right, the bus arbiter transfers the bus right to the bus master that requested it. The bus right is transferred at the following times:

- The bus right is transferred at the boundary of a bus cycle. If word data is accessed by two consecutive byte accesses, however, the bus right is not transferred between the two byte accesses.
- If another bus master requests the bus while the CPU is performing internal operations, such as executing a multiply or divide instruction, the bus right is transferred immediately. The CPU continues its internal operations.
- If another bus master requests the bus while the CPU is in power down mode, the bus right is transferred immediately.

**External Bus Master:** The AX07CF192 can always be released to an external bus master. The external bus master has highest priority, and requests the bus right from the bus arbiter driving the **nBREQ** signal low. Once the external bus master acquires the bus, it keeps the bus until the **nBREQ** signal goes high. While the bus is released to an external bus master, the AX07CF192 chip holds the address bus, data bus, bus control signals **(nAS, nRD, nHWR, and nLWR)**, and chip select signals **(nCS0** to **7)**, in a high impedance state, and holds the **nBACK** pin at low level.

The bus arbiter samples the **nBREQ** pin at the rise of the system clock (**XIN**). If **nBREQ** is low, the bus is released to the external bus master at the appropriate opportunity. The **nBREQ** signal should be held low until **nBACK** goes low.

When the **nBREQ** pin is high for two consecutive samples, the **nBACK** pin is driven high to end the bus-release cycle.



states from when the **nBREQ** signal goes low until the bus is released.



Figure 3.18 Example of External Bus Master Operation



**AX07CF192** 

# Chapter 4 **MCU Controller**



#### 4.1 **General Description**

The MCU Controller (MCUC) is composed of 11 multi-function pin multiplex control signal registers and a device code register.

#### 4.2 **Pin Function Description**

Table 4.1 shows the Pin function descriptions.

Table 4.1 Pin Function Descriptions

| NAME   | Port<br>No. | Multiplexed functions | NAME   | Port<br>No.    | Multiplexed functions |
|--------|-------------|-----------------------|--------|----------------|-----------------------|
| Port A | PA0         | TCLKA                 | Port 4 | P40            | D0                    |
|        | PA1         | TCLKB                 |        | P41            | D1                    |
|        | PA2         | TCLKC, TIOCA0         |        | P42            | D2                    |
|        | PA3         | TCLKD, TIOCB0         |        | P43            | D3                    |
|        | PA4         | A23, TIOCA1           |        | P44            | D4                    |
|        | PA5         | A22, TIOCB1           |        | P45            | D5                    |
|        | PA6         | A21, TIOCA2           |        | P46            | D6                    |
|        | PA7         | A20, TIOCB2           |        | P47            | D7                    |
| Port B | PB0         | nCS7, TIOCA3          | Port 5 | P50            | A16                   |
|        | PB1         | nCS6, TIOCB3          |        | P51            | A17                   |
|        | PB2         | nCS5, TUICA4          |        | P52            | A18                   |
|        | PB3         | nCS4, TIOCB4          |        | P53            | A19                   |
|        | PB4         | TMS                   | Port 6 | P60            | nWAIT                 |
|        | PB5         | TDO                   |        | P61            | nBREQ                 |
|        | PB6         | TDI                   |        | P62            | nBACK                 |
|        | PB7         | TCK                   |        | P63            | nAS                   |
| Port 1 | P10         | A0                    |        | P64            | nRD                   |
|        | P11         | A1                    |        | P65            | nHWR                  |
|        | P12         | A2                    |        | P66            | nLWR                  |
|        | P13         | A3                    |        | P67            | CLKO                  |
|        | P14         | A4                    | Port 7 | <del>P70</del> | AN0                   |
|        | P15         | A5                    |        | <del>P71</del> | AN1                   |
|        | P16         | A6                    |        | <del>P72</del> | AN2                   |
|        | P17         | A7                    |        | <del>P73</del> | AN3                   |
| Port 2 | P20         | A8                    |        | <del>P74</del> | AN4                   |
|        | P21         | A9                    |        | P75            | P75                   |
|        | P22         | A10                   |        | P76            | TIOCA5, nIRQ6         |
|        | P23         | A11                   |        | P77            | TIOCB5, nIRQ7         |
|        | P24         | A12                   | Port 8 | P80            | nIRQ0                 |
|        | P25         | A13                   |        | P81            | nCS3, nIRQ1           |
|        | P26         | A14                   |        | P82            | nCS2, nIRQ2           |
|        | P27         | A15                   |        | P83            | nCS1, nIRQ3           |
| Port 3 | P30         | D8                    |        | P84            | nCS0                  |
|        | P31         | D9                    | Port 9 | P90            | TxD0                  |
|        | P32         | D10                   |        | P91            | RxD0                  |
|        | P33         | D11                   |        | P92            | TxD1                  |
|        | P34         | D12                   |        | P93            | RxD1                  |
|        | P35         | D13                   |        | XP96           | XFVPPD                |
|        | P36         | D14                   |        | P97            | nTRST                 |
|        | P37         | D15                   | Ì      |                |                       |

Note: The port functions are changed by the Mode setting or by user definition. The Default functions are shown in Section **4.3.2 PINMUX Register** 



# 4.3 Register Description

## 4.3.1 Register Memory Map

**Table 4.2** is the memory map of the MCU Controller. The base address of the MCU control Register is **0x0900\_0000**. **Table 4.3** shows the initial value in each mode. The initial values varyby operation mode.

Table 4.2 Memory map of the MCU Controller

| Reg. | I/O<br>OFFSET | Dir. | Description                         |
|------|---------------|------|-------------------------------------|
| PAMR | 0x0000        | R/W  | Pin MUX Control Register for Port A |
| PBMR | 0x0004        | R/W  | Pin MUX Control Register for Port B |
| P1MR | 0x0008        | R/W  | Pin MUX Control Register for Port 1 |
| P2MR | 0x000C        | R/W  | Pin MUX Control Register for Port 2 |
| P3MR | 0x0010        | R/W  | Pin MUX Control Register for Port 3 |
| P4MR | 0x0014        | R/W  | Pin MUX Control Register for Port 4 |
| P5MR | 0x0018        | R/W  | Pin MUX Control Register for Port 5 |
| P6MR | 0x001C        | R/W  | Pin MUX Control Register for Port 6 |
| P7MR | 0x0020        | R/W  | Pin MUX Control Register for Port 7 |
| P8MR | 0x0024        | R/W  | Pin MUX Control Register for Port 8 |
| P9MR | 0x0028        | R/W  | Pin MUX Control Register for Port 9 |
| DCR  | 0x002C        | R    | MCU Device Code Register            |

Table 4.3 MCU Controller Initial values in each mode

| Reg. | Mode<br>2  | Mode<br>3,4 | MODE<br>5,7 | MODE<br>6  |  |  |
|------|------------|-------------|-------------|------------|--|--|
| PAMR | 0x0000     | 0x0000      | 0x1540      | 0x1540     |  |  |
| PBMR | 0x0000     | 0x0000      | 0x0055      | 0x0000     |  |  |
| P1MR | 0x0000     | 0x0000      | 0x00FF      | 0x0000     |  |  |
| P2MR | 0x0000     | 0x0000      | 0x00FF      | 0x0000     |  |  |
| P3MR | 0x00FF     | 0x0000      | 0x00FF      | 0x0000     |  |  |
| P4MR | 0x0000     | 0x0000      | 0x00FF      | 0x0000     |  |  |
| P5MR | 0x0000     | 0x0000      | 0x000F      | 0x0000     |  |  |
| P6MR | 0x0000     | 0x0000      | 0x03FF      | 0x0000     |  |  |
| P7MR | 0x0000     | 0x0000      | 0x0000      | 0x0000     |  |  |
| P8MR | 0x0000     | 0x0000      | 0x00D4      | 0x0000     |  |  |
| P9MR | 0x0000     | 0x0000      | 0x0000      | 0x0000     |  |  |
| DCR  | 0x39437092 | 0x39437092  | 0x39437092  | 0x39437092 |  |  |



# 4.3.2 PINMUX Register

PAMR Port A Multiplex Register (0x0900\_0000 R/W)

|      | b31  | b14                          | b13 | b12 | b11   | b10     | b9   | b8     | b7    | 7 b6               | b5          | b4 | b3       | b2   | b1  | b0  |
|------|------|------------------------------|-----|-----|-------|---------|------|--------|-------|--------------------|-------------|----|----------|------|-----|-----|
| PAMR | Rese | erved                        | P   | PA7 |       | PA6     |      | PA5    |       | PA4                |             | A3 | PA2      |      | PA1 | PA0 |
|      |      | Initial value : depends on o |     |     | on op | erating | mode | (refer | to Ta | able 4.3)          |             |    |          |      |     |     |
|      |      |                              |     | •   | •     | ŭ       | PA7  | •      | 00    | : A20 <sup>^</sup> |             | 01 | : TIOCB2 |      |     |     |
|      |      |                              |     |     |       |         |      |        | 1x    | : PA7              |             |    |          |      |     |     |
|      |      |                              |     |     |       |         | PA6  |        | 00    | : A21              |             | 01 | : TI     | OCA2 |     |     |
|      |      |                              |     |     |       |         |      | 1x     | : PA6 |                    |             |    |          |      |     |     |
|      |      |                              |     |     |       | PA5     |      | 00     | : A22 |                    | 01 : TIOCB1 |    |          |      |     |     |
|      |      |                              |     |     |       |         |      | 1x     | : PA5 |                    |             |    |          |      |     |     |
|      |      |                              |     |     |       |         | PA4  |        | 00    | : A23              |             | 01 | : TI     | OCA1 |     |     |
|      |      |                              |     |     |       |         |      |        | 1x    | : PA4              |             |    |          |      |     |     |
|      |      |                              |     |     |       |         | PA3  |        | 00    | : TCLKI            | )           | 01 | : TI     | OCB0 |     |     |
|      |      |                              |     |     |       |         |      |        | 1x    | : PA3              |             |    |          |      |     |     |
|      |      |                              |     |     |       |         | PA2  |        | 00    | : TCLK             |             | 01 | : TI     | OCA0 |     |     |
|      |      |                              |     |     |       |         |      |        | 1x    | : PA2              |             |    |          |      |     |     |
|      |      |                              |     |     |       |         | PA1  |        | 0     | : TCLKE            |             | 1  | : P/     |      |     |     |
|      |      |                              |     |     |       |         | PA0  |        | 0     | : TCLKA            |             | 1  | : P/     | 40   |     |     |

PBMR Port B Multiplex Register (0x0900\_0004 R/W)

|      | b31 b14 |                 | b11    | b10     | b9    | b8       | b8 b7 l       |           | b5         | b4  | b3    | b2    | b1 | b0 |
|------|---------|-----------------|--------|---------|-------|----------|---------------|-----------|------------|-----|-------|-------|----|----|
| PBMR | Res     | PB7             | PB6    | PB5     | PB4   |          | PB3           | PB2       |            | PB1 |       | P     | B0 |    |
|      | Initial | value : depends | on ope | erating | mode  | (refer   | to <b>T</b> a | able 4.3) |            |     |       |       |    |    |
|      |         |                 |        |         | PB7   |          | 0             | : TCK     |            | 1   | : Pl  | B7    |    |    |
|      |         |                 |        |         | PB6   |          | 0             | : TDI     |            | 1   | : Pl  | B6    |    |    |
|      |         |                 |        |         | PB5 0 |          |               | : TDO     |            | 1   | : PB5 |       |    |    |
|      |         |                 |        |         | PB4   |          | 0 : TMS       |           | 1 : PB4    |     |       |       |    |    |
|      |         |                 |        |         | PB3   |          | 00 : /CS4     |           | 01 : TIOCB |     | OCB4  |       |    |    |
|      |         |                 |        |         |       | 1x : PB3 |               | : PB3     |            |     |       |       |    |    |
|      |         |                 |        |         | PB2   |          | 00            | : /CS5    |            | 01  | : TI  | IOCA4 |    |    |
|      |         |                 |        |         |       |          | 1x            | : PB2     |            |     |       |       |    |    |
|      |         |                 |        |         | PB1   |          | 00            | :/CS6     |            | 01  | : TI  | OCB3  |    |    |
|      |         |                 |        |         |       | 1x       | : PB1         |           |            |     |       |       |    |    |
|      |         |                 |        |         | PB0   |          | 00            | : /CS7    |            | 01  | : TI  | IOCA3 |    |    |
|      |         |                 |        |         |       |          | 1x            | : PB0     |            |     |       |       |    |    |



|      |                        |                            |                 |            |     |        |              |     | Cha | apter |
|------|------------------------|----------------------------|-----------------|------------|-----|--------|--------------|-----|-----|-------|
| P1MR | Port 1 Multiplex F     | Register (0x0900_0008      | R/W)            |            |     |        |              |     |     |       |
|      | b31                    | b8                         | b7              | b6         | b5  | b4     | b3           | b2  | b1  | b0    |
| P1MR | Reser                  | und                        | P17             | P16        | P15 | P14    | P13          | P12 | P11 | P10   |
|      |                        |                            |                 |            | PID | P14    | PIS          | PIZ | PII | PIU   |
|      | Initial value : depend | ds on operating mode (refe |                 |            |     |        | Б.           | -   |     |       |
|      |                        | P17<br>P16                 |                 | A7<br>A6   |     | 1      | : P′<br>: P′ |     |     |       |
|      |                        | P15                        | -               | A6<br>A5   |     | 1<br>1 | : P          | -   |     |       |
|      |                        | P14                        |                 | A4         |     | 1      | .г<br>:Р′    |     |     |       |
|      |                        | P13                        |                 | A3         |     | 1      | .г<br>:Р′    |     |     |       |
|      |                        | P12                        |                 | A2         |     | 1      | : P          |     |     |       |
|      |                        | P11                        |                 | A1         |     | 1      | : P1         |     |     |       |
|      |                        | P10                        | -               | Α0         |     | 1      | : P          |     |     |       |
| P2MR | Port B Multiplex       | Register (0x0900_0000      | CR/W)           |            |     |        |              |     |     |       |
|      | b31                    | b8                         | b7              | b6         | b5  | b4     | b3           | b2  | b1  | b0    |
| P2MR | Reser                  | ved                        | P27             | P26        | P25 | P24    | P23          | P22 | P21 | P20   |
| •    | Initial value : depend | ds on operating mode (refe | r to <b>Tab</b> | le 4.3)    | •   |        |              |     | •   |       |
|      |                        | P27                        |                 | A15        |     | 1      | : P2         |     |     |       |
|      |                        | P26                        | -               | A14        |     | 1      | : P2         | -   |     |       |
|      |                        | P25                        |                 | A13        |     | 1      | : P2         |     |     |       |
|      |                        | P24<br>P23                 | -               | A12        |     | 1      | : P2         |     |     |       |
|      |                        | P23<br>P22                 |                 | A11<br>A10 |     | 1      | : P2<br>: P2 |     |     |       |
|      |                        | P21                        |                 | A10        |     | 1      | . F2         |     |     |       |
|      |                        | P20                        | -               | A8         |     | 1      | : P2         |     |     |       |
| P3MR | Port 3 Multiplex F     | Register (0x0900_0010      | R/W)            |            |     |        |              |     |     |       |
| _    | b31                    | b8                         | b7              | b6         | b5  | b4     | b3           | b2  | b1  | b0    |

Reserved

P34

P33

P32

P31

P30



P3MR

AX07CF192

P34

P35

P37

0 0 0

0

P36

: D11

: D12

: D13

: D14

: D15

P33

: P37 : P36 : P35

: P34

: P33 : P32 : P31 : P30

P32

P31

P30

|                                                                        |                                                                                      |                   |                                     |               |      |       |      |      |      |            | ~   | apter |  |
|------------------------------------------------------------------------|--------------------------------------------------------------------------------------|-------------------|-------------------------------------|---------------|------|-------|------|------|------|------------|-----|-------|--|
| P4MR                                                                   | Port 4 Multiple                                                                      | ex Register (0x0  | 0900_0                              | 0014 <b>I</b> | R/W) |       |      |      |      |            |     |       |  |
|                                                                        | b31                                                                                  | b                 | 3                                   |               | b7   | b6    | b5   | b4   | b3   | b2         | b1  | b0    |  |
| P4MR                                                                   | Re                                                                                   |                   |                                     | P47           | P46  | P45   | P44  | P43  | P42  | P41        | P40 |       |  |
|                                                                        | Initial value : der                                                                  | (refer            | to <b>Tab</b>                       | le 4.3)       | l    | l     | l    |      | l    | 1          |     |       |  |
|                                                                        | Initial value: depends on operating mode (refer to <b>Table 4.3</b> ) P47 0:D7 1:P47 |                   |                                     |               |      |       |      |      |      | <b>1</b> 7 |     |       |  |
|                                                                        |                                                                                      |                   | 0 : D6                              |               |      | 1     |      |      |      |            |     |       |  |
|                                                                        |                                                                                      |                   | P45                                 |               | 0 :  | D5    |      | 1    | : P4 | <b>1</b> 5 |     |       |  |
|                                                                        |                                                                                      |                   | P44                                 |               |      | D4    |      | 1    | : P4 |            |     |       |  |
|                                                                        |                                                                                      |                   | P43                                 |               |      | D3    |      | 1    | : P4 | -          |     |       |  |
|                                                                        |                                                                                      |                   | P42                                 |               |      | D2    |      | 1    | : P4 |            |     |       |  |
|                                                                        |                                                                                      |                   | P41                                 |               |      | D1    |      | 1    | : P4 |            |     |       |  |
|                                                                        |                                                                                      |                   | P40                                 |               | 0 :  | D0    |      | 1    | : P4 | 40         |     |       |  |
| P5MR                                                                   | Port 5 Multiple                                                                      | ex Register (0x0  | 0900_0                              | )018 <b>I</b> | R/W) |       |      |      |      |            |     |       |  |
|                                                                        | b31                                                                                  |                   |                                     |               | b    | 4     |      |      | b3   | b2         | b1  | b0    |  |
| P5MR                                                                   |                                                                                      | ed                |                                     |               |      |       |      | P53  | P52  | P51        | P50 |       |  |
| Initial value : depends on operating mode (refer to <b>Table 4.3</b> ) |                                                                                      |                   |                                     |               |      |       |      |      |      |            | 1   |       |  |
|                                                                        | P53 0 : A19 1 : P53                                                                  |                   |                                     |               |      |       |      |      |      |            |     |       |  |
|                                                                        |                                                                                      |                   | P52 0 : A18                         |               |      |       |      | 1    |      | : P52      |     |       |  |
|                                                                        |                                                                                      |                   | P51                                 | 0 : A17       |      |       |      | 1    | : P  |            |     |       |  |
|                                                                        |                                                                                      |                   | P50                                 |               | 0 :  | A16   |      | 1    | : P  | 50         |     |       |  |
| P6MR                                                                   | Port 6 Multiple                                                                      | ex Register (0x0  | 0900_0                              | 001C          | R/W) |       |      |      |      |            |     |       |  |
|                                                                        | b31                                                                                  | b10               | b9                                  | b8            | b7   | b6    | b5   | b4   | b3   | b2         | b1  | b0    |  |
| P6MR                                                                   | Reserve                                                                              | d                 | P66                                 | P65           | P64  | P63   | P67  | P    | 62   | P          | 31  | P60   |  |
|                                                                        | Initial value : dep                                                                  | ends on operating | n operating mode (refer to Table 4. |               |      |       |      |      |      |            |     | I .   |  |
|                                                                        | •                                                                                    |                   | P66                                 |               |      | /LWR  |      | 1    | : P6 |            |     |       |  |
|                                                                        |                                                                                      | P65               |                                     | 0 :/HWR       |      |       |      | : P6 |      |            |     |       |  |
|                                                                        |                                                                                      |                   | P64                                 |               |      | /RD   |      | 1    | : P6 |            |     |       |  |
|                                                                        |                                                                                      |                   | P63                                 |               |      | /AS   |      | 1    | : P6 |            |     |       |  |
|                                                                        |                                                                                      |                   | P67<br>P62                          |               |      | BCLK  |      | 1    | : P6 |            |     |       |  |
|                                                                        |                                                                                      |                   |                                     | /BACK         |      | 01    | : P6 | 02   |      |            |     |       |  |
|                                                                        |                                                                                      |                   |                                     |               | ıx . | KASAr | VH(1 |      |      |            |     |       |  |



AX07CF192 70

: Reserved

: Reserved : /WAIT 01 : P61

: P60

:/BREQ

1x

00

1x

0

P61

P60

| PIWIK | Port 7 Multiplex Register (0x0900_0020 R/W) |              |         |             |                         |                   |                          |     |        |        |                  |     |     |
|-------|---------------------------------------------|--------------|---------|-------------|-------------------------|-------------------|--------------------------|-----|--------|--------|------------------|-----|-----|
|       | b31                                         | b            | 9       |             | b8                      | b7                | <b>7</b> b6              | b5  | b4     | b3     | b2               | b1  | b0  |
| P7MR  | Res                                         | Reserved     |         |             | F                       | 77                | F                        | P76 | P74    | P73    | P72              | P71 | P70 |
| _     | Initial value : depends on operating mode   |              |         |             |                         |                   |                          |     | 0.4    | //5    | .07              |     |     |
|       |                                             |              |         | P77         | 00 : TIOCB5<br>1x : P77 |                   |                          | 01  | :/IF   | (Q/    |                  |     |     |
|       |                                             | P76          |         |             |                         | 00 : TIOCA5       |                          |     | 01     | : /IF  | RQ6              |     |     |
|       |                                             |              |         | 1x<br>P74   | : P76<br>0 : AN4        |                   |                          | 1   | : Re   | eserve | ed               |     |     |
|       |                                             |              |         | P73         |                         | 0 : AN3           |                          |     | 1      | : Re   | eserve           | ed  |     |
|       |                                             |              |         | P72         |                         | 0                 | : AN2                    |     | 1      |        | eserve           |     |     |
|       |                                             |              |         | P71<br>P70  |                         | 0                 | : AN1<br>: AN0           |     | 1<br>1 |        | eserve<br>eserve |     |     |
| P8MR  | Port 8 Multip                               | olex Registe | r (0x0  | 900_        | 0024                    | R/W               | )                        |     |        |        |                  |     |     |
|       | •                                           |              | •       |             |                         |                   | •                        |     |        |        |                  |     |     |
| г     | b31                                         |              | b8      |             |                         | b7                | 7 b6                     | b5  | b4     | b3     | b2               | b1  | b0  |
| P8MR  |                                             | Reserved     |         |             |                         | P8                |                          | P83 | P8     | P82 P  |                  | 81  | P80 |
|       | Initial value : d                           | epends on op | erating | mode<br>P84 | (refer                  | to <b>T</b> a     | <b>able 4.3</b><br>CS0 : | 3)  | 1      | : P8   | 24               |     |     |
|       |                                             |              |         | P83         |                         | 00                | :/CS1                    |     | 01     | : /IF  |                  |     |     |
|       |                                             |              |         | Doo         |                         | 1x                | : P83                    |     | 0.4    | //5    |                  |     |     |
|       |                                             |              |         | P82         |                         | 00<br>1x          | : /CS2<br>: P82          |     | 01     | : /IF  | (Q2              |     |     |
|       |                                             |              |         | P81         |                         | 00                | : /CS3                   |     | 01     | : /IF  | RQ1              |     |     |
|       |                                             |              |         | P80         |                         | 1x<br>0           | : P81<br>: /IRQ0         | )   | 1      | : P8   | 80               |     |     |
| P9MR  | Port 9 Multip                               | olex Registe | r (0x0  | 900         | 0028                    | R/W               | )                        |     |        |        |                  |     |     |
|       |                                             |              |         | _           |                         |                   | ,                        |     |        |        |                  |     |     |
| Г     | b31                                         | b11          | b10     | b9          | b8                      | b7                | 7 b6                     | b5  | b4     | b3     | b2               | b1  | b0  |
| P9MR  | Reserved                                    |              |         |             |                         |                   |                          |     | 93 P92 |        | 92               | P91 | P90 |
|       | Initial value : de                          | epends on op | erating | mode<br>P97 | (refer                  | to <b>Ta</b><br>0 | able 4.3<br>TRS :        |     | 1      | : P9   | 17               |     |     |
|       |                                             |              |         | P95         |                         | 00                | :/IRQ                    |     | 01     | : P9   |                  |     |     |
|       |                                             |              |         | Do 4        |                         | 1x                | : Rese                   |     |        | -      |                  |     |     |
|       |                                             |              |         | P94         |                         | 00<br>1x          | : /IRQ4<br>: Rese        |     | 01     | : P9   | 94               |     |     |
|       |                                             |              |         | P93         |                         | 00                | :/RxD                    | 1   | 01     | : P9   | 93               |     |     |
|       |                                             |              |         | P92         |                         | 1x<br>00          | : Rese<br>:/TxD          |     | 01     | : P9   | 12               |     |     |
|       |                                             |              |         | . 0_        |                         | 1x                | : Rese                   |     | 31     |        | _                |     |     |
|       |                                             |              |         | P91         |                         | 0                 | : RxD0                   | )   | 1      | : P9   |                  |     |     |
|       |                                             |              |         | P90         |                         | 0                 | : TxD0                   |     | 1      | : P9   | JU               |     |     |

Port 7 Multiplex Register (0x0900\_0020 R/W)

# 4.3.3 MCU Device Code Register (0x0900\_002C Read Only)

This Register is read only. The Device Code Value is '0x3943\_7092'



P7MR

AX07CF192

# Chapter 5 Power Management Unit



## 5.1 General Description

The PMU block provides:

- Clock distribution throughout the system
- Reset, RUN and Power down mode control



Figure 5.1 PMU Block Diagram



## 5.2 Operation Modes

### 5.2.1 Introduction

The PMU consists of a clock controller and a reset controller. The user can control the internal clocks of the embedded peripherals and the main clock of the MCU by setting the PMU registers. The MCU has four reset sources: external power-on reset, soft-reset of PMU, soft-reset from WDT and overflow reset from WDT. The PMU has status registers that hold the reset value and PMU status.

To improve power management, support for a power-saving mode is included whereby bus clocks may be disabled (or dropped to a lower frequency).

The reset and power-down mechanism provides:

- Stable power-up sequence
- Power On Reset
- Soft Reset

Additionally the system bus, once operational, operates in one of two well-defined modes:

- RUN
- Power-down mode

### 5.2.2 Reset and Operation Modes

Four modes are available as follows:

### RESET

At power-on, watchdog timer overflow, watchdog soft-reset or PMU soft-reset, the MCU is initialized

### Power on Reset

This is an asychronous reset initiated by the nRES pin. It triggers the internal bus reset signal (BnRES) which is maintained until the bus clock is stable (see Figure 5.5.1).

If any external devices are attached to the AX07CF192's buses they must recognize the POR signal and disable their output drivers (and wait for a valid clock). The MCU starts running 32 clocks after the end of the reset timing interval (rising edge of nRES).

#### Soft- Reset from the PMU

The soft-reset can be used for soft resetting of the bus for a number of clock cycles. In this reset state the PMU block initializes all the ASB blocks, Bus controller, DRAM Controller, DMA Controller, ARM CPU core, and Arbiter, Decoder. This reset is initiated by writing to the RSTCR register.



### Overflow and Soft-Reset of Watchdog timer

The watchdog timer can generate a reset signal in several ways. In watchdog mode, when the timer overflows a POR or Manual reset can be selected (see Figure 5.4 and 5.5). In interval timer mode a reset can be generated via an interrupt when the counter reaches the set register value. More detailed information can be found in Chapter 7.

### PDN - Power-Down Mode

When the MCU system is in the PDN State, the PMU block disables all of the blocks in the ASB and APB, to minimize the system power consumption. Although the MCU is in power down mode, the user can still utilize the interrupt controller block.

### Wake-up from the PDN Mode.

The Wake-up is a temporary state between the power down state and the RUN state. After the wake-up state the transition to the RUN state occurs automatically. The wake-up state is triggered by the nFIQ or nIRQ interrupts.



Figure 5.2 Reset and Power Management State Machine.



## 5.3 Power Management Unit Register Map

The start address of the PMU (Power Management Unit) is **0x0900\_1000**.

Table 5.1 Register Map of the PMU

| Name   | I/O Offset | DIR | Description                                                |
|--------|------------|-----|------------------------------------------------------------|
| PMUCR  | 0x1000     | W   | PMU operation mode control register.                       |
| PMUSR  | 0x1000     | R   | PMU status register shows the immediately prior PMU state. |
| PCLKCR | 0x1008     | R/W | Peripheral clock control register.                         |
| MEMSR  | 0x100C     | R   | Memory remap status register.                              |
| MEMCR  | 0x1010     | W   | Memory remap control register                              |
| RSTCR  | 0x1030     | W   | Soft-Reset control register                                |



## 5.4 Register Description

The PMU supplies the clock to all of the blocks in the MCU. The start address of the register is **0x0900\_1000**.

### **PMUCR**

### PMU Control Register (0x0900\_1000 Write-Only)



PD

11 : Entering the Power down Mode00 : Clear PMU Status Register

This register controls the operation mode of the PMU. After a power on reset the register value is initialized to 00. If PMUCR is written to 11, the device enters the PD (Power Down) mode. Writing other values does not affect the device. The address of the register is 0x0900\_1000.

### **PMUST**

### PMU Status Register (0x0900\_1000 Read-Only)

|       | b31 - b8 | b5 | b4  | b3   | b2    | b1 | b0  |   |
|-------|----------|----|-----|------|-------|----|-----|---|
| PMUST | Reserved | PM | UST | Rese | erved | PM | UST | ı |
| Reset | -        | 0  | 0   |      | -     | 0  | 0   |   |

Initial value: 0x-00

This register holds the previous status and reset state of PMU. The address of the register is 0x0900\_1000.

PMUST [5:4] (Previous Reset Status bits)

00 - The Power-On reset state (nPOR)

01 - PMU Soft-reset state

10 - WDT Soft-reset state (after MNRESET)

11 – WDT Overflow-reset state (after PORESET)

PMUST [1:0] (PMU Status bits)

00 - Start after Power-On reset

01 – reserved state

10 - reserved state

11 - Start after Power-Down mode



## PCLKCR Clock Control Register (0x0900\_1008 R/W)

|        | b31 - b16 | b15        | b14        | b13  | b12   | b11 | b10  | b9   | b8 | b7    | b6 | B5  | b4   | b3 | b2 | b1   | b0 |
|--------|-----------|------------|------------|------|-------|-----|------|------|----|-------|----|-----|------|----|----|------|----|
| PCLKCR | Reserved  | WU_SEL     | INTC_CC    | V    | /DT_C | C   | UART | _Clk | UA | ART_C | CC | TIN | ΛER_ | СС | Al | DC_C | С  |
| Reset  | -         | 0          | 0          | 0    | 0     | 0   | 0    | 0    | 0  | 0     | 0  | 0   | 0    | 0  | 0  | 0    | 0  |
|        |           | Initial va | lue : 0x00 | 0000 | 000   |     |      |      |    |       |    |     |      |    |    |      |    |

The address of register is 0x0900\_1008.

WU\_SEL: Wake-up source interrupt select register 0 - MCU wake-up when nFIQ interrupt occurs 1 - MCU wake-up when nIRQ interrupt occurs

INTC\_CC: Interrupt controller clock control register

- 0 Interrupt controller uses the XIN clock. XIN is not killed in any mode
- 1 Interrupt controller uses the BCLK of the internal Bus clock. The Bus clock is killed when in Power-down mode

WDT\_CC: Clock control register of WDT 000 - BCLK 001 - BCLK/2 010 ~ 111 - Reserved

UART\_CIk: UART0,1 clocks on-off control register.
00 - UART0,1 clocks ON
01 - UART1 clock ON, UART0 clock OFF
10 - UART1 clock OFF, UART0 clock ON
11 - UART0,1 clocks OFF

**UART\_CC**: Clock Control register of UART. 000 - BCLK 001 - BCLK/2 010 ~ 111 - Reserved

**TIMER\_CC**: Clock Control register of TIMER. 000 - BCLK 001 - BCLK/2 010 ~ 111 - Reserved

**ADC\_CC**: Clocks Control register of ADC. Values are the same as WDT\_CC



### MEMCR MEMSR

### Memory map Control Register (0x0900\_1010 Write-Only) Memory map Status Register (0x0900\_100C Read-Only)

|                | b31 - b3 | b2 | b1       | b0    |
|----------------|----------|----|----------|-------|
| MEMCR<br>MEMSR | Reserved | SM | On-Flash | REMAP |
| Reset          | <u>-</u> | 0  | 0        | 0     |

Initial value: 0x-0

During write operation, the address of the register is 0x0900\_1010 and during read operation, the address of the register is 0x0900\_100C.

**SM**: External bus controller mapping change.

- 0 Each nCS0 ~ nCS7 of address space is 16MB in size
- 1 Each nCS0 ~ nCS7 of address space is 1MB in size

On-Flash: Re-mapping of Flash start address to 0x0 in MODES 6 and 7.

- 0 Default value.
- 1 Re-mapping of Flash start address to 0x0 in the memory map. It is valid in MODES 6 and 7.

**REMAP**: Re-map internal SRAM address location.

- 0 internal SRAM at 0x0803\_0000
- 1 Re-mapping of internal SRAM start address to 0x0 in the memory map. It is used in MODES 2,3,4,5,6 and 7.

### RSTCR Soft-Reset Control Register (0x0900\_1030 Write-Only)

|       | b31 - b1 | b0    |
|-------|----------|-------|
| RSTCR | Reserved | RSTCR |
| Reset | -        | -     |

**RSTCR** 1 : Software-reset 0 : Normal

This register is used for generating Soft-reset operation. The MCU enters into the reset state when this register is set high. It is cleared automatically at the end of the Soft-Reset. The address is  $0x0900\_1030$ .



## 5.5 Signal Timing Diagram

The PMU signal timing is as shown below.

### 5.5.1 Power on Reset



Figure 5.3 Power on Reset Timing Diagram

## 5.5.2 Watch Dog Timer Overflow



Figure 5.4 Watchdog Timer Overflow Timing Diagram



### 5.5.3 Soft-Reset

There are two Soft-Reset cases. The first Soft-Reset operation is initiated by the MAN\_RST signal from the WDT.

The other is from the PMU reset control register.



Figure 5.5 Soft Reset (from WDT) Timing Diagram



Figure 5.6 Soft Reset (from PMU) Timing Diagram



# Chapter 6 **The Interrupt Controller**



## 6.1 About the Interrupt controller

The interrupt controller has the following features:

- Asynchronous interrupt controller
- 8 external interrupt sources
- 13 internal interrupt sources
- Low interrupt latency
- Selectable level- or edge-trigger on all interrupt source inputs
- Each interrupt source and output signal is maskable
- Selectable output paths (IRQ or FIQ) for each interrupt source



Figure 6.1 Interrupt Control Flow Diagram



AX07CF192

83

### 6.1.1 Interrupt sources

The interrupt controller provides an interface between multiple interrupt sources and the processor. The interrupt controller supports internal and external interrupt sources. Internally there are 11 peripheral interrupt sources. Externally there are 8 interrupt sources. Therefore certain interrupt bits can be defined for the basic functionality required in any system, while the remaining bits are available for use by other devices in any particular implementation.

Table 6.1 Interrupt Controller Default Setting Value

|               | Wolfer Delatit Setting Value |
|---------------|------------------------------|
| Interrupt No. | INTERRUPT SOURCES            |
| INT0          | External Interrupt 0         |
| INT1          | External Interrupt 1         |
| INT2          | External Interrupt 2         |
| INT3          | External Interrupt 3         |
| INT4          | External Interrupt 4         |
| INT5          | External Interrupt 5         |
| INT6          | External Interrupt 6         |
| INT7          | External Interrupt 7         |
| INT8          | reserved                     |
| INT9          | reserved                     |
| INT10         | WDT                          |
| INT11         | UART0                        |
| INT12         | UART1                        |
| INT13         | ADC                          |
| INT14         | Timer 0                      |
| INT15         | Timer 1                      |
| INT16         | Timer 2                      |
| INT17         | Timer 3                      |
| INT18         | Timer 4                      |
| INT19         | Timer 5                      |
| INT20         | Software Interrupt           |

The user can set the active mode of all interrupt source inputs. The default mode is falling-edge triggered. Any inversion or latching required to provide edge sensitivity must be provided at the generating source of the interrupt.

No hardware priority scheme or any form of interrupt vectoring is provided, but the priority can be determined using the FIQ and IRQ mask registers under software control.

The FIQ and IRQ mask registers may also be used to generate an interrupt under software control. Typically these registers are used to determine whether either an FIQ or IRQ interrupt is generated.



### 6.1.2 Interrupt Control

The interrupt controller provides the interrupt source status and the interrupt request status. The interrupt mask registers are used to determine whether an active interrupt source should generate an interrupt request to the processor or not. A logic-level HIGH in the interrupt mask register indicates that the interrupt source is masked and will not generate a request.

The FIQ and IRQ mask registers indicate whether the interrupt source causes a processor interrupt or not.

The interrupt modes are configurable by the interrupt trigger mode and interrupt trigger polarity registers. The Interrupt direction register indicates whether each interrupt source drives IRQ or FIQ.

The FIQ and IRQ status register is used to reflect the status of all channels set to produce an FIQ interrupt or IRQ interrupt. The status registers are cleared by writing '1' to the ISCR register in edge trigger mode only.

Bit 20 is used as a software interrupt source. When source mask control register bit 20 is HIGH, an interrupt request occurs. To disable the software interrupt, Source Mask Control Register bit 20 should be Low. The Software interrupt source input is fixed active HIGH and level sensitive.



## 6.2 Interrupt Controller Registers

The start address of the interrupt controller is **0x0900\_1200**. The offset of any particular register from the start address is fixed. The following registers are provided for both FIQ and IRQ interrupt controllers:

Table 6.2 Memory Map of the Interrupt Controller

| REG. | I/O OFFSET | Dir | Description                     |
|------|------------|-----|---------------------------------|
| GMR  | 0x1200     | R/W | Global Mask Register            |
| TMR  | 0x1204     | R/W | Trigger Mode Register           |
| TPR  | 0x1208     | R/W | Trigger Polarity Register       |
| IDR  | 0x120C     | R/W | Interrupt Direction Register    |
| FSR  | 0x1210     | R   | FIQ Status Register             |
| ISR  | 0x1214     | R   | IRQ Status Register             |
| FMR  | 0x1218     | R/W | FIQ Mask Register               |
| IMR  | 0x121C     | R/W | IRQ Mask Register               |
| ISCR | 0x1220     | W   | Interrupt Status Clear Register |

### GMR Global Mask Register (0x0900\_1200 R/W)

|       | b31 - b21         | b20b  | o19b  | 18b17  | 'b16 | b15   | b14   | b13   | b12 | b11 | b10 | b9  | b8   | b7  | b6 | b5 | b4 | b3 | b2 | b1 | b0 |
|-------|-------------------|-------|-------|--------|------|-------|-------|-------|-----|-----|-----|-----|------|-----|----|----|----|----|----|----|----|
| GMR   | Reserved          | 120   | I19 I | 18 I17 | l16  | 115   | l14   | l13   | l12 | 111 | l10 | 19  | 18   | 17  | 16 | 15 | 4  | В  | 12 | 11 | Ю  |
| Reset | 0000000           | 1     | 1     | 1 1    | 1    | 1     | 1     | 1     | 1   | 1   | 1   | 1   | 1    | 1   | 1  | 1  | 1  | 1  | 1  | 1  | 1  |
|       | Initial value : ( | )x01F | FFF   | FF     |      | Bit : | field | -01 k | 124 |     | 1   | : M | lasł | (   |    |    |    |    |    |    |    |
|       |                   |       |       |        |      |       |       |       |     |     | 0   | : U | nm   | ask |    |    |    |    |    |    |    |

The interrupt mask register is used to mask the interrupt input sources and defines which active sources will generate an interrupt request to the processor. If certain bits within the interrupt controller are not implemented, the corresponding bits in the interrupt mask register must be masked. A bit value of 0 indicates that the interrupt is unmasked and will allow an interrupt request to reach the processor. A bit value of 1 indicates that the interrupt is masked. Once a bit is masked, the corresponding bit in the status register is cleared. On reset, all interrupt input-sources are masked.

### TMR Trigger Mode Register (0x0900\_1204 R/W)



The interrupt trigger mode register is used to configure the interrupts in conjunction with the interrupt trigger polarity register. Each interrupt can be configured to be level or edge triggered. A bit value of 0 indicates that the interrupt is configured to be edge triggered and a bit value of 1 indicates that the interrupt is level triggered. On reset, all interrupt input sources are configured to be edge triggered.



**TPR** 

### Trigger Polarity Register (0x0900\_1208 R/W)



The interrupt trigger polarity register is used to configure the interrupts in conjunction with the interrupt trigger mode register. Each interrupt can be configured to be rising/high or falling/low active. A bit value of 0 indicates that the interrupt is configured to be falling active for edge trigger mode and low active for level trigger mode. A bit value of 1 indicates that the interrupt is configured to be rising active for edge trigger mode and high active for level trigger mode. On reset, all interrupt input sources are configured to be falling/low active.

Table 6.3 Interrupt Source Trigger Mode

| DETECTION MODE         | TMR | TPR |
|------------------------|-----|-----|
| Falling-Edge (Default) | 0   | 0   |
| Rising-Edge            | 0   | 1   |
| Low-Level              | 1   | 0   |
| High-Level             | 1   | 1   |

**IDR** 

### Interrupt Direction Register (0x0900\_120C R/W)

|       | b31 - b21         | b20  | b19 | b18 | b17 | b16 | b15   | b14   | b13  | b12 | b11 | b10        | b9  | b8   | b7   | b6  | b5  | b4 | b3 | b2 | b1 | b0 |
|-------|-------------------|------|-----|-----|-----|-----|-------|-------|------|-----|-----|------------|-----|------|------|-----|-----|----|----|----|----|----|
| IDR   | Reserved          | 120  | l19 | l18 | 117 | l16 | 115   | l14   | l13  | l12 | 111 | <b>I10</b> | 19  | 18   | 17   | 16  | 15  | 4  | В  | 12 | 11 | Ю  |
| Reset | 0000000           | 0    | 0   | 0   | 0   | 0   | 0     | 0     | 0    | 0   | 0   | 0          | 0   | 0    | 0    | 0   | 0   | 0  | 0  | 0  | 0  | 0  |
|       | Initial value : 0 | 00x( | 000 | 000 |     |     | Bit 1 | field | 110- | 124 |     | 1          | : D | irec | tion | to  | FIQ |    |    |    |    |    |
|       |                   |      |     |     |     |     |       |       |      |     |     | 0          | : D | irec | tion | to. | IRC | )  |    |    |    |    |

The interrupt direction register is used to determine whether each interrupt source drives IRQ or FIQ. A bit value of 0 indicates that the interrupt is driven to IRQ and a bit value of 1 indicates that the interrupt is driven to FIQ. On reset, all interrupt input sources drive IRQ.



### FIQ Status Register (0x0900\_1210 Read Only)



The FIQ status register is used to reflect the status of all channels set to produce an FIQ interrupt (IDRn = 1). When an interrupt is set for an FIQ to occur, the corresponding bit is set in the FIQ status register. The interrupt handler will examine this register to determine the channel(s) that caused the FIQ interrupt. When the status clear register is written to '1', the corresponding bit is cleared if that channel is configured for edge trigger mode. A HIGH bit indicates that the interrupt is active and will generate an interrupt to the processor.

### ISR IRQ Status Register (0x0900\_1214 Read Only)



The IRQ status register is used to reflect the status of all channels set to produce an IRQ interrupt (IDR(i) = 0). When an interrupt is set for an IRQ to occur, the corresponding bit is set in the IRQ status register. The interrupt handler will examine this register to determine the channel(s) that caused the IRQ interrupt. When the status clear register is written to '1', the corresponding bit is cleared if that channel is configured for edge trigger mode. A HIGH bit indicates that the interrupt is active and will generate an interrupt to the processor.

### FMR FIQ Mask Register (0x0900\_1218 R/W)

|       | b31 - b21         | b20 | b19 | b18 | b17 | b16 | b15   | b14   | b13   | b12 | b11 | b10 | b9  | b8   | b7    | b6  | b5 | b4 | b3 | b2 | b1 | b0 |
|-------|-------------------|-----|-----|-----|-----|-----|-------|-------|-------|-----|-----|-----|-----|------|-------|-----|----|----|----|----|----|----|
| FMR   | Reserved          | 120 | l19 | l18 | 117 | l16 | 115   | l14   | l13   | l12 | 111 | l10 | 19  | 18   | 17    | 16  | 15 | 4  | 13 | 12 | 11 | Ю  |
| Reset | 0000000           | 0   | 0   | 0   | 0   | 0   | 0     | 0     | 0     | 0   | 0   | 0   | 0   | 0    | 0     | 0   | 0  | 0  | 0  | 0  | 0  | 0  |
|       | Initial value : 0 | x00 | 000 | 000 | )   |     | Bit : | field | d 10- | 124 |     | 1   | : D | isat | ole I | FIQ |    |    |    |    |    |    |
|       |                   |     |     |     |     |     |       |       |       |     |     | 0   | : E | nab  | le F  | IQ  |    |    |    |    |    |    |

The FIQ request mask register is used to mask the request to generate an interrupt to the processor. If certain bits within the interrupt controller are not implemented, the corresponding bits in the FIQ request mask register must be masked. A bit value of 0 indicates that the interrupt is unmasked and will allow an interrupt request to reach the processor. A bit value of 1 indicates that the interrupt is masked. On reset, all FIQ requests are unmasked.



### IRQ Mask Register (0x0900\_121C R/W)



The IRQ request mask register is used to mask the request to generate an interrupt to the processor. If certain bits within the interrupt controller are not implemented, the corresponding bits in the IRQ request mask register must be masked. A bit value of 0 indicates that the interrupt is unmasked and will allow an interrupt request to reach the processor. A bit value of 1 indicates that the interrupt is masked. On reset, all IRQ requests are unmasked.

### ISCR Interrupt Status Clear Register (0x0900\_1220 Write Only)

|       | b31 - b21         | b20  | b19 | b18 | b17 | b16 | b15 | b14   | b13 | b12  | b11 | b10 | B9  | b8   | b7   | b6   | b5    | B4    | b3 | b2 | b1 | b0 |
|-------|-------------------|------|-----|-----|-----|-----|-----|-------|-----|------|-----|-----|-----|------|------|------|-------|-------|----|----|----|----|
| ISCR  | Reserved          | 120  | l19 | l18 | 117 | 116 | l15 | l14   | l13 | l12  | 111 | l10 | 19  | 18   | 17   | 16   | 15    | 4     | ß  | 12 | 11 | Ю  |
| Reset | 0000000           | 0    | 0   | 0   | 0   | 0   | 0   | 0     | 0   | 0    | 0   | 0   | 0   | 0    | 0    | 0    | 0     | 0     | 0  | 0  | 0  | 0  |
|       | Initial value : ( | )x00 | 000 | 000 | )   |     | Bit | field | 10- | ·124 |     | 1   | : C | lear | Int  | erru | ıpt S | Stati | JS |    |    |    |
|       |                   |      |     |     |     |     |     |       |     |      |     | 0   | : N | o a  | ctio | n    |       |       |    |    |    |    |

The status clear register is used to clear bits in the status register configured for edge trigger mode. If the channels are configured for level trigger mode, the corresponding bits in the FIQ status register and the IRQ status register have no effect. This register is cleared when written to '1'. When writing to this register, each data bit that is HIGH causes the corresponding bit in the status register to be cleared. Data bits that are LOW have no effect on the corresponding bit in the status register. Note that the status clear register has an effect on the status register in the edge trigger mode.



## Chapter 7 Watchdog Timer



## 7.1 General Description

- Watchdog timer mode and Interval timer mode
- Generates interrupt signal (INT\_WDT) to the interrupt controller in either mode
- Outputs signals **PORESET** and **MNRESET** to the PMU (Power Management Unit)
- Eight counter clock sources
- Selection whether to reset the chip internally or not
- Two types of reset signal : power-on reset and manual reset



Figure 7.1 Watchdog Timer Module Block Diagram



## 7.2 Watchdog Timer Introduction

The AX07CF192 has a one-channel watchdog timer (WDT) for monitoring system operations. If the system locks up and the timer counter overflows without being rewritten correctly by the CPU, a reset signal is output to PMU.

When this watchdog function is not needed, the WDT can be used as an interval timer. In the interval timer mode, an interval timer interrupt is generated at each counter overflow.

The WDT has a clock generator that produces eight counter clock sources. The clock signals are obtained by dividing down the frequency of the system clock. Users can select one of eight internal clock sources for input to the **WTCNT** by means of CKS2 - CKS0 in the **WTCR**.



## 7.3 Watchdog Timer Operation

### **The Watchdog Timer Mode**

To use the WDT as a watchdog timer, set the WT/nIT and TMEN bits of the WTCR to a logic 1. Software must prevent WTCNT overflow by rewriting the TCNT value (normally by writing 0x00) before overflow occurs. If the WTCNT fails to be rewritten and overflows due to a system crash or the like, the **INT\_WDT** and **PORESET/MNRESET** signals are output. The INT\_WDT signal is not output if INTEN is disabled (INTEN = 0).



Figure 7.2 Operation in the Watchdog Timer Mode

If the RSTEN bit in the WTCR is set to 1, a signal to reset the chip will be generated internally when TCNT overflows. Either a power-on reset or a manual reset can be selected by the RSTSEL bit.



### The Interval Timer Mode

To use the WDT as an interval timer, clear WT/nIT to 0 and set TMEN to 1. A watchdog timer interrupt (**INT\_WDT**) is generated each time the timer counter overflows. This function can be used to generate interval timer interrupts at regular intervals.



Figure 7.3 Operation in the Interval Timer Mode

### 7.3.1 Timing of Setting and Clearing the Overflow Flag

### Timing of setting the overflow flag

In the interval timer mode when the WTCNT overflows, the ITOVF flag is set to 1 and watchdog timer interrupt (INT\_WDT) is requested.

In the watchdog timer mode when the WTCNT overflows, the WTOVF bit of the SR is set to 1 and a WDTOUT signal is output. When the RSTEN bit is set to 1, a WTCNT overflow causes an internal reset signal to be generated for the entire chip.

### Timing of clearing the overflow flag

When the Reset Status Register (WRSR) is read, the overflow flag is cleared.



## 7.4 Watchdog Timer Memory Map

The WDT has five registers. They are used to select the internal clock source, switch to the WDT mode, control the reset signal, and test it. The start address of the watchdog timer is fixed to **0x0900\_1100** and the offset of any particular register from the base address is fixed.

Table 7.1 Memory Map of the Watchdog Timer APB Peripheral

| Name  | I/O Offset | DIR | Description                   |
|-------|------------|-----|-------------------------------|
| WTCR  | 0x1100     | R/W | WDT control. (8-bit)          |
| WRSR  | 0x1104     | R   | WDT Reset status reg. (2-bit) |
| WTCNT | 0x1108     | R/W | WDT Timer counter. (8-bit)    |



#### 7.5 **Watchdog Timer Register Descriptions**

The following registers are provided for the watchdog timer:

| WTCR | Watchdog Timer Control Register | (0x0900 1100 R/W) |
|------|---------------------------------|-------------------|
|      |                                 |                   |

|       | b31 - b8 | b7    | b6     | b5   | b4    | В3     | b2 | b1    | b0 |
|-------|----------|-------|--------|------|-------|--------|----|-------|----|
| WTCR  | Reserved | INTEN | WT/nIT | TMEN | RSTEN | RSTSEL |    | CKSEL |    |
| Reset | =        | 0     | 0      | 0    | 0     | 0      | 0  | 0     | 0  |

Initial value: 0x-00

CKSEL: Clock select. Select one of eight internal clock sources for input to the WTCNT.

000 - BCLK / 2

001 - BCLK / 8

010 - BCLK / 32

011 - BCLK / 64

100 - BCLK / 256

101 - BCLK / 512 110 - BCLK / 2048

111 - BCLK / 8192

RSTSEL: Reset select register. Select the type of internal reset generated if WTCNT overflows in the watchdog timer mode.

0 - Power-on reset

1- Manual reset

RSTEN: Reset enable register. Select whether to reset the chip internally or not if WTCNT overflows in the watchdog timer mode.

0 - Disable

1- Enable

**TMEN**: Timer enable register. Enable or disable the timer.

0 - Disable

1- Enable.

WT/nIT: Timer mode select register. Select whether to use the WDT as a watchdog timer or interval timer.

0 - Interval timer mode

1- Watchdog timer mode

INTEN: Interrupt enable register. Enable or disable the interrupt request, INT\_WDT.

0 - Disable

1- Enable



AX07CF192 96 8-bit read / write register. The start address of register is 0x0900\_1100. The following functions are provided :

- Select the timer mode
- Select the internal clock source
- Select the reset mode
- Set the timer enable bit
- Enable interrupt request
- Enable reset signal occurrence

The clock signals are obtained by dividing down the system clock.

Table 7.2 Internal Counter Clock Sources (SYSCLK = 40 MHz)

| CKSEL | CLOCK SOURCE  | OVERFLOW INTERVAL |
|-------|---------------|-------------------|
| 000   | SYSCLK/2      | 12.8 us           |
| 001   | SYSCLK / 8    | 51.2 us           |
| 010   | SYSCLK / 32   | 204.8 us          |
| 011   | SYSCLK / 64   | 409.6 us          |
| 100   | SYSCLK / 256  | 1.64 ms           |
| 101   | SYSCLK / 512  | 3.28 ms           |
| 110   | SYSCLK / 2048 | 13.11 ms          |
| 111   | SYSCLK / 8192 | 52.43 ms          |

### WRSR Reset Status Register ( 0x0900\_1104 Read-Only )

|       | D31 - D2 | DΊ    | DU    |
|-------|----------|-------|-------|
| WRSR  | Reserved | ITOVF | WTOVF |
| Reset | •        | 0     | 0     |

Initial value : 0x-0 1 : Overflowed 0 : Normal

WTOVF: Watchdog timer overflow flag. Indicates that the WTCNT has overflowed in the watchdog timer mode. ITOVF: Interval timer overflow flag. Indicates that the WTCNT has overflowed in the watchdog timer mode.

Two-bit read only register. The **WRSR** indicates whether **WTCNT** has overflowed or not. The **WRSR** is initialized to 0x0 by the reset signal, **BnRES**.

Bit 0 (WTOVF) indicates that the **WTCNT** has overflowed in the watchdog timer mode. Bit 1 (ITOVF) indicates that the **WTCNT** has overflowed in the interval timer mode.

### WTCNT Watchdog Timer Counter ( 0x0900\_1108 R/W )

|       | b31 - b8          | b7 | b6           | b5  | b4 | b3 | b2 | b1         | b0 |
|-------|-------------------|----|--------------|-----|----|----|----|------------|----|
| WTCNT | Reserved          | 17 | 16           | 15  | 14 | 13 | 12 | <b>I</b> 1 | Ю  |
| Reset | =                 | 0  | 0            | 0   | 0  | 0  | 0  | 0          | 0  |
|       | Initial value : 0 |    | Bit field IO | -I7 |    |    |    |            |    |

8-bit read / write upcounter. When the timer is enabled, the timer counter starts counting pulses from the selected clock source. When the value of the **WTCNT** changes from 0xFF-0x00(overflows), a watchdog timer overflow signal is generated in both timer modes. The **WTCNT** is initialized to 0x00 by a power-reset (**nB\_RES**).



## 7.6 Examples of Register Setting

## 7.6.1 Interval Timer Mode

WTCNT = 0x00WTCR = 0xA0



Figure 7.4 Interrupt Clear in the Interval Timer Mode



## 7.6.2 Watchdog Timer Mode with Internal Reset Disable

WTCNT = 0x00 (normally) WTCR = 0xE0



Figure 7.5 Interrupt Clear in the Watchdog Timer Mode with Reset Disable



## 7.6.3 Watchdog Timer Mode with Power-on Reset

WTCNT = 0x00 WTCR = 0xF0



Figure 7.6 Interrupt Clear in the Watchdog Timer Mode with Power-on Reset



## 7.6.4 Watchdog Timer Mode with Manual Reset

WTCNT = 0x00WTCR = 0xF8



Figure 7.7 Interrupt Clear in the Watchdog Timer Mode with Manual Reset



## Chapter 8 **The General Purpose Timer**



AX07CF192 102

## 8.1 About the General Purpose Timer Unit

The general-purpose timer unit has:

- Six channels with 16-bit counters
- 12 different pulse outputs and 12 different pulse inputs
- Independent functionality with 12 general registers
- Compare match waveform output function
- Input capture function
- Counter-clearing function at compare match or input capture mode
- Synchronizing mode
- PWM mode
- 18 interrupt sources
- Selectable 4 internal clock sources and 4 external clock sources



Figure 8.1 General-purpose Timer Unit Module Block Diagram



AX07CF192

### 8.1.1 General Purpose Timer Unit Introduction

The AX07CF192 has a general-purpose timer unit (GPTU) with six channels of 16-bit timers. There are two counter operation modes: a free-running mode and a periodic mode. Each channel has independent operating modes. There are common functions for each channel: counter operation, input capture, compare match, PWM, and synchronized clear and write.

It is possible to select one of eight counter clock sources for all channels.

• Internal clock : counting at falling edge

BCLK / 2 BCLK / 4 BCLK / 16 BCLK / 64

• External clock: counting at falling edge.

There are five operating modes which can be configured individually. The operating modes are.

- Free Running Mode
- Compare Match Mode
- Input Capture Mode
- Synchronized Clear and Write Mode
- PWM(Pulse-Width-Modulation) Mode

There are four kinds of counter clear sources which are user selectable.

- None: never clear until overflow for free running mode
- GRA match or TPA input capture
- GRB match or TPB input capture
- Synchronous clear



## 8.2 General Purpose Timer Unit Memory Map

### 8.2.1 Register Assignment

The base address of the general-purpose timer unit is  $0x0900\_1300$  and the offset of any particular register from the base address is fixed.

Table 8.1 Timer Global Control Register Map

| REG.    | I/O<br>OFFSET | DIR. | DESCRIPTION             |
|---------|---------------|------|-------------------------|
| TSTARTR | 0x1300        | R/W  | Timer Start Register    |
| TSYNCR  | 0x1304        | R/W  | Timer Sync. Register    |
| TPWMR   | 0x1308        | R/W  | Timer PWM Mode Register |
| -       | 0x130C        | W    | (test only)             |
| -       | 0x1310        | R    | (test only)             |
| -       | 0x1314        | W    | (test only)             |
|         | 0x1318        | R    | (test only)             |

Table 8.2 Timer Channel Control Register Map

| 3      |               |      |                                   |  |  |  |  |  |
|--------|---------------|------|-----------------------------------|--|--|--|--|--|
| REG.   | I/O<br>OFFSET | DIR. | DESCRIPTION                       |  |  |  |  |  |
| TCR0   | 0x1320        | R/W  | Timer 0 Control Register          |  |  |  |  |  |
| TIOCR0 | 0x1324        | R/W  | Timer 0 I/O Control Register      |  |  |  |  |  |
| TIER0  | 0x1328        | R/W  | Timer 0 Interrupt Enable Register |  |  |  |  |  |
| TSR0   | 0x132C        | R    | Timer 0 Interrupt Status Register |  |  |  |  |  |
| TCNT0  | 0x1330        | R/W  | Timer 0 Counter Register          |  |  |  |  |  |
| GRA0   | 0x1334        | R/W  | Timer 0 General Register A        |  |  |  |  |  |
| GRB0   | 0x1338        | R/W  | Timer 0 General Register B        |  |  |  |  |  |

GP Timer Unit has consists of six unit timer channels and each address starts as follows:

**Table 8.3 Timer Channel Starting Address** 

| Timer No. | Starting Offsets |
|-----------|------------------|
| Timer 0   | 0x1320           |
| Timer 1   | 0x1340           |
| Timer 2   | 0x1360           |
| Timer 3   | 0x1380           |
| Timer 4   | 0x13A0           |
| Timer 5   | 0x13D0           |



### 8.2.2 General Purpose Timer Unit Register Descriptions

The base address of the general-purpose timer unit is **0x0900\_1300**. The following registers are provided for the general purpose timer unit:

### 8.2.2.1 Timer Global Control Registers

TSTARTR Timer Start Register (0x0900\_1300 R/W)

|                            | b31  | b8   | b7  | b6  | b5   | b4   | b3   | b2   | b1   | b0   |
|----------------------------|------|------|-----|-----|------|------|------|------|------|------|
| TSTARTR                    | Rese | rved | res | res | STR5 | STR4 | STR3 | STR2 | STR1 | STR0 |
| Reset                      | -    |      | 1   | 1   | 0    | 0    | 0    | 0    | 0    | 0    |
| Initial value : 0xXXXXXXC0 |      |      |     |     |      |      |      |      |      |      |

STRn 1 : Start Timer Channel n

0 : Stop Timer Channel n

8-bit read / write register that starts and stops the counter of each channel.

### TSYNCR Timer Sync. Register (0x0900\_1304 R/W)

Initial value: 0xXXXXXXC0

|        | b31      | b8 | b7  | b6  | b5    | b4    | b3    | b2    | b1    | b0    |
|--------|----------|----|-----|-----|-------|-------|-------|-------|-------|-------|
| TSYNCR | Reserved |    | res | res | SYNC5 | SYNC4 | SYNC3 | SYNC2 | SYNC1 | SYNC0 |
| Reset  | -        |    | 1   | 1   | 0     | 0     | 0     | 0     | 0     | 0     |

**SYNC** 1: Operates Synchronously with the other sync.

channel

0 : Independent Counting

8-bit read / write register that selects the timer synchronizing mode for each channel.

### TPWMR Timer PWM Mode Register (0x0900\_1308 R/W)

|                             | b31      | b8  | b7  | b6  | b5   | b4   | b3   | b2   | b1   | b0   |  |
|-----------------------------|----------|-----|-----|-----|------|------|------|------|------|------|--|
| TPWMR                       | Reser    | ved | res | res | PWM5 | PWM4 | PWM3 | PWM2 | PWM1 | PWM0 |  |
| Reset                       | <u>-</u> |     | 1   | 1   | 0    | 0    | 0    | 0    | 0    | 0    |  |
| Initial value : 0x XXXXXXC0 |          |     |     |     |      |      |      |      |      |      |  |

**PWMn** 1: PWM Mode

0: Counter Mode

8-bit read / write register that selects the PWM mode for each channel.



### 8.2.2.2 Timer Channel Control Registers

### TCR0 Timer 0 Control Register (0x0900\_1320 R/W)

0x1340 for Timer 1,0x1360 for Timer 2, 0x1380 for Timer 3, 0x13A0 for Timer 4, 0x13D0 for Timer 5

|       | b31      | b8 | b7  | b6   | b5 | b4  | b3  | b2   | b1  | b0 |
|-------|----------|----|-----|------|----|-----|-----|------|-----|----|
| TCR0  | Reserved |    | res | CCLR |    | res | res | TPSC |     |    |
| Reset | -        |    | 1   | 0    | 0  | 1   | 1   |      | 000 |    |

Initial value: 0xXXXXXX98

**CCLR** Select the Counter clear condition

00 : not cleared (free-running mode)01 : cleared by GRA compare match or input capture (periodic mode)10 : cleared by GRB compare match

or input capture (periodic mode)
11 : cleared in synchronization with the

other sync. timer

TPSC Select the Count clock Source

000: BCLK/2 001: BCLK/4 010: BCLK/16 011: BCLK/64 100: Ext CLKA 101: Ext CLKB 110: Ext CLKC

8-bit readable and writable register for each channel that selects the timer counter clock source and the counter clear source.



### TIOCR0

### Timer 0 I/O Control Register (0x0900\_1324 R/W)

0x1344 for Timer 1,0x1364 for Timer 2, 0x1384 for Ti mer 3, 0x13A4 for Timer 4, 0x13D4 for Timer 5

|        | b31      | b8 | b7  | b6  | b5 | b4 | b3  | b2  | b1  | b0 |
|--------|----------|----|-----|-----|----|----|-----|-----|-----|----|
| TIOCR0 | Reserved |    | res | IOB |    |    | res | IOA |     |    |
| Reset  | -        |    | 1   | 00  | )  | 1  | 1   |     | 000 |    |

Initial value: 0xXXXXXX88

IOB Select GRB Function

000: compare match with pin output disable 001: 0 output at GRB compare match 010: 1 output at GRB compare match 011: toggle output at GRB compare match 100: GRB captures the rising edge of input 101: GRB captures the falling edge of input 110: GRB captures both edge of input

111: Don't care

IOA Select GRA Function

000: compare match with pin output disable 001: 0 output at GRA compare match 010: 1 output at GRA compare match 011: toggle output at GRA compare match 100: GRA captures the rising edge of input 101: GRA captures the falling edge of input 110: GRA captures both edge of input

111: Don't care

8-bit read / write register that selects the output compare or input capture function for GRA and GRB, and selects the function of the **TIOCA***n* and **TIOCB***n* pins. TIOCR*n* controls the GRA and GRB.



#### TIER0

#### Timer 0 Interrupt Enable Register (0x0900\_1328 R/W)

0x1348 for Timer 1,0x1368 for Timer 2, 0x1388 for Timer 3, 0x13A8 for Timer 4, 0x13D8 for Timer 5

|       | b31      | b8 | b7  | b6  | b5  | b4  | b3  | b2    | b1    | b0    |
|-------|----------|----|-----|-----|-----|-----|-----|-------|-------|-------|
| TIER0 | Reserved |    | Res | res | res | res | res | OVFIE | MCIBE | MCIAE |
| Reset | -        |    | 1   | 1   | 1   | 1   | 1   | 0     | 0     | 0     |

Initial value: 0xXXXXXF8

**OVFIE** 0 : Disable Overflow Interrupt

1 : Enable Overflow Interrupt

MCIBE 0: Disable GRB Match or

GRB capture Interrupt

1 : Enable GRB Match or GRB capture Interrupt

MCIAE 0: Disable GRA Match or

GRA capture Interrupt
1: Enable GRA Match or
GRA capture Interrupt

8-bit read / write register that controls the enabling/disabling of an overflow interrupt request and the general register compare match/input capture interrupt requests. TIER*n* controls the interrupt enable/disable.

#### TSR<sub>0</sub>

#### Timer 0 Status Register (0x0900\_132C Read Only)

0x134C for Timer 1,0x136C for Timer 2, 0x138C for Timer 3, 0x13AC for Timer 4, 0x13DC for Timer 5

|       | b31      | b8 | b7  | b6  | b5  | b4  | b3  | b2   | b1   | b0   |   |
|-------|----------|----|-----|-----|-----|-----|-----|------|------|------|---|
| TSR0  | Reserved |    | res | res | res | res | res | OVFI | MCIB | MCIA |   |
| Reset | -        |    | 1   | 1   | 1   | 1   | 1   | 0    | 0    | 0    | _ |

Initial value: 0xXXXXXXF8

**OVFI** 0 : no overflow occurs

1: Overflow occurs

MCIB 0 : no GRB Match or Capture occurs

1 : GRB Match or Capture occurs

MCIA 0 : no GRA Match or Capture occurs

1 : GRA Match or Capture occurs

8-bit read only register containing the flags that indicate TCNT overflow and GRA/GRB compare match or input capture. These flags are interrupt sources. Reading this register will clear all the interrupt flags.



#### TCNT0 Timer 0 Counter (0x0900\_1330 R/W) 0x1350 for Timer 1,0x1370 for Timer 2, 0x1390 for Timer 3, 0x13B0 for Timer 4, 0x13E0 for Timer 5 B15 b14 b13 b12 b11 b10 b9 b31 b16 b8 B7 b6 b5 b4 b3 b2 b1 b0 TCNT0 Reserved TCNT Reset 0 0 0 0 Initial value: 0xXXXX0000 **TCNT** 16bit Counter Value 16-bit read / writle counter. The clock source is selected by the TCR for each channel. TCNT is cleared to 0x0000 by compare match with the corresponding GRA or GRB, or by input capture to GRA or GRB. When TCNT is overflow, OVFI in the TSR is set to '1'. General Register A,B 16-bit read / write register. There are 2 general registers for each channel (total 12). Each general register can function as either an output compare register or an input capture register by the setting in the TIOCR. **GRA0** General Register A (0x0900\_1334 R/W) 0x1354 for Timer 1,0x1374 for Timer 2, 0x1394 for Timer 3, 0x13B4 for Timer 4, 0x13E4 for Timer 5 b31 b16 b15 b14 b13 b12 b11 b10 b9 b8 b7 b6 b5 b4 b3 b2 b1 b0 GRA0 Reserved **GRA** 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 Reset Initial value: 0xXXXX0000 **GRA** 16bit Compare Match A Value GRB0 General Register B (0x0900\_1338 R/W) 0x1358 for Timer 1,0x1378 for Timer 2, 0x1398 for Timer 3, 0x13B8 for Timer 4, 0x13E8 for Timer 5

b15 b14 b13 b12 b11 b10 b9 b8 b7

**GRB** 

0

0 0 0

0 0



b31

GRB0

Reset

b16

Initial value: 0xXXXX0000

Reserved

**AX07CF192** 110

b6

0 0 0 0 0 0

16bit Compare Match B Value

GRB

0 0 0

b5 b4

b3 b2 b1 b0

0

## 8.3 General Purpose Timer Unit Operation

There are five operating modes described below.

- Free Running Mode
- Compare Match Mode
- Input Capture Mode
- Synchronized Clear and Write Mode
- PWM(Pulse-Width-Modulation) Mode



#### 8.3.1 Free Running Mode

A reset of the counters for channels 0 - 5 leaves them all in the free-running mode. When a corresponding bit in the TSR is set to 1, the corresponding timer counter operates as a free-running counter and begins to increment. When the count wraps round from 0xFFFF to 0x0000, the overflow flag (OVFI) in the timer status register (TSR) is set to 1. If the OVFIE bit in the timer's corresponding interrupt enable register (TIER) is set to 1, the CPU will be asked for an interrupt. After the TCNT overflows, counting continues from 0x0000. *Figure 8.2* shows an example of free-running counting.

Periodic counter operation is obtained for a given channel's TCNT by selecting compare match as a TCNT clear source. (Set the GRA or GRB for period setting to output compare register and select counter clear upon compare match using the CCLR1 and CCLR0 bits of the timer control register (TCR). After setting, the TCNT begins incrementing as a periodic counter when the corresponding bit of TSTARTR is set to 1. When the count matches GRA or GRB, the MCIA/MCIB bit in the TSR is set to 1 and the counter is automatically cleared to 0x0000. If the MCIAE/MCIBE bit of the corresponding TIER is set to 1 at this point, the CPU will be asked for an interrupt. After the compare match, TCNT continues counting from 0x0000. *Figure 8.3* shows an example of periodic counting.



Figure 8.2 Free-Running Counter Operation





Figure 8.3 Periodic Counter Operation



#### 8.3.2 Compare Match Mode

Each channel has 2 user settable general registers When the counter reaches the user programmed value, the channel generates a user-defined interrupt and an external output. The output value can be '1', '0', or toggle value. The counter can be cleared (user setting) when a match with the general register is detected.



Figure 8.4 Example of 0 Output/1 Output





Figure 8.5 Example of Toggle Output



Figure 8.6 Compare Match Signal Output Timing



#### 8.3.3 Input Capture Mode

When set to input capture mode, at the rising/falling edge of either capture input, TIOCA or TIOCB, the counter value is transferred to GRA or GRB respectively. Also setting the MCIAE or MCIBE in TIER the interrupt can be generated by an external capture event. The capture data and interrupt are generated after 2 timer clocks. If the CCR field in TCR is appropriately set, the counter will be cleared when the edge of TIOCA or TIOCB is detected.



Figure 8.7 Input Capture Operation



#### 8.3.4 Synchronized Clear and Write Mode

If several channels are set to synchronization mode, and one of them is cleared by a compare match or input capture, the other channels can also be cleared simultaneously. If several channels are set to synchronization mode and the user writes to any one of them, the other channels can also be written with the same value simultaneously.



Figure 8.8 Synchronized Operation Example



#### 8.3.5 **PWM Mode**

The PWM mode is controlled using both the GRA and GRB in pairs. The PWM waveform is output from the TIOCA output pin. The PWM waveform's 1 output timing is set in GRA and the 0 output timing is set in GRB. A PWM waveform with duty cycle between 0% and 100% can be output from the TIOCA pin by having either compare match GRA or GRB be the counter clear source for the timer counter. All five channels can be set to PWM mode.

#### 8.3.5.1 PWM Mode Operation

**Figure 8.9** illustrates PWM mode operations. When the PWM mode is set, the TIOCA pin becomes the output pin. Output is 1 when the TCNT matches the GRA, and 0 when TCNT matches the GRB. The TCNT can be cleared by compare match with either GRA or GRB. This can be used in both free-running and synchronized operation.



Figure 8.9 PWM Mode Operation Example 1



*Figure 8.10* shows examples of PWM waveforms output with 0% and 100% duty cycles. A 0% duty cycle waveform can be obtained by setting the counter clear source to GRB and then setting GRA to a larger value than GRB. A 100% duty waveform can be obtained by setting the counter clear source to GRA and then setting GRB to a larger value than GRA



Figure 8.10 PWM Mode Operation Example 2



AX07CF192

119



Figure 8.11 Reset-Synchronized PWM Mode Operation Example

#### **Reset-Synchronized PWM Mode Operation:**

**Figure 8.11** shows an example of operation in the reset-synchronized PWM mode. TCNT1 operates as an upcounter that is cleared to 0x0000 at compare match with GRA1. TCNT2 runs independently and is isolated from GRA2 and GRB2. The PWM waveform outputs toggle at each compare match (GRB1, GRB2, and GRB3 with TCNT1) and when the counter cleared.



# Chapter 9

# **UART (Universal Asynchronous Receiver/Transmitter)**



#### 9.1 General Description

This module is a Universal Asynchronous Receiver/Transmitter (UART) with FIFOs, and is functionally identical to the 16550. The UART can be put into an alternate mode (FIFO mode) to relieve the CPU of excessive software overhead.

In this mode internal FIFOs are activated allowing 16 bytes plus 3 bits of error data per byte in the RCVR FIFO, to be stored in both receive and transmit modes. All the logic is on the chip to minimize the system overhead and maximize system efficiency.

The UART performs serial-to-parallel conversion on data characters received from a peripheral device and parallel-to-serial conversion on data characters received from the CPU. The CPU can read the complete status of the UART at any time during operation. Status information includes the type and condition of the transfer operations performed by the UART, as well as any error conditions (parity, overrun, framing, or break interrupt).

The UART includes a programmable baud rate generator that is capable of dividing the timing reference clock input by divisors of 1 to 65535 and producing a 16x clock for driving the internal transmitter logic. Provisions are also included to use this 16x clock to drive the receiver logic. In addition to baud rate generation, the UART also includes a clock divider which divides the input system clock by setting an 8-bit divider register.

The UART has a processor interrupt system. Interrupts can be programmed to the user's requirements, minimizing the computing required to handle the communications link. The standard 16450/16550 UART features modem control signals which are duplicated internally, but are concealed from the outside.



Figure 9.1 TOP BLOCK Diagram



#### 9.2 Features

- Capable of running all existing 16550 software.
- After reset, all registers are identical to the 16450 register set.
- The FIFO mode transmitter and receiver are each buffered with 16-byte FIFO's to reduce the number of interrupts presented to the CPU.
- Adds or deletes standard asynchronous communication bits (start, stop, and parity) to or from the serial data.
- Hold and shift registers in the 16450 mode eliminate the need for precise synchronization between the CPU and serial data.
- Independently controlled transmit, receive, line status and data set interrupts.
- Programmable baud generator divides any input clock by 1 to 65535 and generates 16x clock
- Input clock divider by setting an 8-bit divider register.
- Independent receiver clock input.
- Fully programmable serial-interface characteristics:
  - 5-, 6-, 7- or 8-bit characters
  - · Even, odd, or no-parity bit generation and detection
  - 1-, 1.5- or 2-stop bit generation and detection
  - · Baud generation (DC to 256k baud)
- False start bit detection.
- Complete status reporting capabilities.
- Line break generation and detection.
- Internal diagnostic capabilities .
- Loopback controls for communications link fault isolation
- Full prioritized interrupt system controls.

## 9.3 Signal Description

Table 9.1 Signal Descriptions

| Name | Type | Description                                                                                                                                                                  |
|------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RxD0 | I    | Serial Input 0. Serial data input from the communications link (peripheral device, modem or data set).                                                                       |
| RxD1 | I    | Serial Input 1. Serial data input from the communications link (peripheral device, modem or data set).                                                                       |
| TxD0 | 0    | Serial Output 0. Composite serial data output to the communications link (peripheral, modem or data set). This signal is set to the '1' state upon a Master Reset operation. |
| TxD1 | 0    | Serial Output 1. Composite serial data output to the communications link (peripheral, modem or data set). This signal is set to the '1' state upon a Master Reset operation. |



## 9.4 Internal Block Diagram



Figure 9.2 Internal UART Diagram



AX07CF192

## 9.5 Registers Description

There are two UARTs implemented in the design, the base addresses are  $0x0900\_1400$  for UART0 and  $0x0900\_1500$  for UART1.

Table 9.2 UART Register Address Map (0x1500 in UART1)

| Tubic oil | OANT Negist | Ci Addit | 233 Map (OX 1300 III OART I)   |
|-----------|-------------|----------|--------------------------------|
| Reg.      | I/O         | Dir,     | Description                    |
| Name      | Offset      |          | ·                              |
| RBR       | 0x1400      | R        | Receiver Buffer (DLAB = 0)     |
| THR       | 0x1400      | W        | Transmitter Holding (DLAB = 0) |
| IER       | 0x1404      | R/W      | Interrupt Enable               |
| IIR       | 0x1408      | R        | Interrupt Identification       |
| FCR       | 0x1408      | W        | FIFO Control                   |
| LCR       | 0x140C      | R/W      | Line Control                   |
| LTR       | 0x1410      | R/W      | Loop Test Control              |
| LSR       | 0x1414      | R/W      | Line Status                    |
| -         | 0x1418      | -        | Reserved                       |
| SCR       | 0x141C      | R/W      | Scratch Register               |
| DLL       | 0x1400      | R/W      | Divisor Latch LSB (DLAB = 1)   |
| DLM       | 0x1404      | R/W      | Divisor Latch MSB (DLAB = 1)   |
| CLKCR     | 0x1420      | R.W      | Clock Control                  |
| CLKDR     | 0x1424      | R/W      | Clock Divisor                  |

Table 9.3 UART Register Reset Values

| Reg. | Reset Values |
|------|--------------|
| IER  | 0x00         |
| IIR  | 0x01         |
| FCR  | 0x00         |
| LCR  | 0x00         |
| LTR  | 0x00         |
| LSR  | 0x60         |
| TxD  | <b>'1'</b>   |



#### **CLKCR** Clock Control Register (0x1420 R/W)



Initial value: 0xXXXXXX00

**CKEN** 0: Disable UART Clock

1: Enable UART Clock

The system programmer starts and stops the UART clock generator by means of the Clock Control Register (CLKCR). The programmer can also read the contents of the Clock Control Register. The CKEN bit is the start clock bit. When this bit is logic 1, the UART clock is generated from the on-chip clock generator. If this bit is a logic 0, then the clock generator is stopped.

#### **CLKDR** Clock Divisor Register (0x1424 R/W)

|       | b31      | b8 | b7 | b6 | b5 | b4 | b3  | b2 | b1 | b0 |
|-------|----------|----|----|----|----|----|-----|----|----|----|
| CLKDR | Reserved |    |    |    |    | CK | DIV |    |    |    |
| Reset | -        |    |    |    |    | 0  | 0   |    |    |    |

Initial value: 0xXXXXXX00

**CKDIV** 8-bit UART Clock Divisor Value

The UART contains a programmable Clock Generator that is capable of taking any clock input and dividing it by any divisor from 0 to 255. One 8-bit register stores the divisor in an 8-bit binary format. This Divisor Register must be loaded before setting the Clock Control Register to ensure proper operation of the UART Clock Generator.



AX07CF192 126

## LCR Line Control Register (0x1400 ReadOnly)

|       | b31            | b8             | b7     | b6    | b5     | b4             | b3    | b2      | b1 | b0  |  |  |  |
|-------|----------------|----------------|--------|-------|--------|----------------|-------|---------|----|-----|--|--|--|
| LCR   | Reserved       |                | DLAB   | BREAK | STICKP | PARITY         | PEN   | STOPBIT | D  | LEN |  |  |  |
| Reset | -              |                | 0      | 0     | 0      | 0              | 0     | 0       | (  | 00  |  |  |  |
|       | Initia         | al value : 0x) | XXXXXX |       |        |                |       |         |    |     |  |  |  |
|       |                |                |        |       |        | 00: 5-bit [    |       |         |    |     |  |  |  |
|       |                |                |        |       |        | 01: 6-bit [    |       |         |    |     |  |  |  |
|       |                |                |        |       |        | 10: 7-bit Data |       |         |    |     |  |  |  |
|       | 11: 8-bit Data |                |        |       |        |                |       |         |    |     |  |  |  |
|       |                |                |        |       |        | '0: 1 stop     |       |         |    |     |  |  |  |
|       |                |                |        |       |        | 1: 1.5 / 2     | •     |         |    |     |  |  |  |
|       |                |                |        |       |        | 0: Disabl      |       |         |    |     |  |  |  |
|       |                |                |        |       |        | 1: Enable      | •     |         |    |     |  |  |  |
|       |                |                |        |       |        | 0: Odd P       | •     |         |    |     |  |  |  |
|       |                |                |        |       |        | 1: Even F      | •     |         |    |     |  |  |  |
|       |                |                |        |       |        | 0: Stick F     | •     |         |    |     |  |  |  |
|       |                |                |        |       |        | 1: Stick F     |       |         |    |     |  |  |  |
|       |                |                |        |       | BREAK  | 0: Nomal       |       | ssion   |    |     |  |  |  |
|       |                |                |        |       |        | 1: Send I      |       |         |    |     |  |  |  |
|       |                |                |        |       | DLAB   | 0: Nomal       | state |         |    |     |  |  |  |

The system programmer can specify the format of the asynchronous data communications exchange and set the Divisor Latch Access bit (DLAB) via the Line Control Register (LCR). The programmer can also read the contents of the Line Control Register. This read capability simplifies system programming and eliminates the need for separate storage of the line characteristics in system memory. Table 9.8 Summary of Registers shows the contents of the LCR. Details on each bit are:

1: Divisor Latch Access Mode

**DLEN** These two bits specify the number of bits in each transmitted and received serial character.

STOPBIT This bit specifies the number of Stop bits transmitted and received in each serial character. If bit 2 is a logic 0, one Stop bit is generated in the transmitted data. If bit 2 is a logic 1 when a 5-bit word length is selected via bits 0 and 1, one and a half Stop bits are generated. If bit 2 is a logic 1 when either a 6-, 7-, or 8-bit word length is selected, two Stop bits are generated. The Receiver checks the first Stop-bit only, regardless of the number of selected Stop bits.

PEN This bit is the Parity Enable bit. When bit 3 is a logic 1, a Parity bit is generated (transmit data) or checked (receive data) between the last data word bit and Stop bit of the serial data. (The Parity bit is used to produce an even or odd number of 1s when the data word bits and the Parity bit are summed.)

**PARITY** This bit is the Even Parity Select bit. When bit 3 is a logic 1 and bit 4 is a logic 0, an odd number of logic 1s is transmitted or checked in the data word bits and Parity bit. When bit 3 is a logic 1 and bit 4 is a logic 1, an even number of logic 1s is transmitted or checked.

**STICKP** This bit is the Stick Parity bit. When bits 3, 4, and 5 are logic 1, the Parity bit is transmitted and checked as a logic 0. If bits 3 and 5 are 1 and bit 4 is a logic 0, then the Parity bit is transmitted and checked as a logic 1. If bit 5 is a logic 0 Stick Parity is disabled.

BREAK This bit is the Break Control bit. It causes a break condition to be transmitted to the receiving UART. When it is set to a logic 1, the serial output (TxD) is forced to be the Spacing (logic 0) state. The break is disabled by setting bit 6 to a logic 0. The Break Control bit acts only on TxD and has no effect on the transmitter logic.

<sup>\*\*</sup> Note: This feature enables the CPU to alert a terminal in a computer communications system. If the following sequence is followed, no erroneous or extraneous characters will be transmitted because of the break.



DLAB This bit is the Divisor Latch Access Bit. It must be set to high (logic 1) to access the Divisor Latches of the Baud Generator during a Read or Write operation. It must be set to low (logic 0) to access the Receiver Buffer, the Transmitter Holding Register, or the Interrupt Enable Register.

#### Divisor Latch Register (0x1400/0x1404 R/W) b31 b8 b7 b5 b4 b3 b2 b1 b0 DLL Reserved DLL Reset 00 Initial value: 0xXXXXXX00 DLL Divisor Latch Lower Byte b31 b8 b7 b6 b5 b4 b3 b2 b1 b0 DLM Reserved DLM Reset 00

DLM

Initial value: 0xXXXXXX00

The UART contains a programmable Baud Rate Generator that is capable of taking any clock input from DC to 8.0 MHz and dividing it by any divisor from 2 to 65535. 4MHz is the highest input clock frequency recommended when the divisor=1. The output frequency of the Baud Rate Generator is 16 x the Baud rate [divisor # = (frequency input) / (baud rate x 16)]. Two 8-bit latches store the divisor in a 16-bit binary format. These Divisor Latches must be loaded during initialization to ensure the proper operation of the Baud Rate Generator. Upon loading either of the Divisor Latches, a 16-bit Baud counter is immediately loaded.

Divisor Latch Upper Byte

Table 12-5 Baud rates provide decimal divisors to use with crystal frequencies of 1.8432 MHz and 3.6864 MHz. For baud rates of 38400 and below, the error obtained is minimal. The accuracy of the desired baud rate depends on the chosen crystal frequency. Using a divisor of zero is not recommended.



DLL/DLM

AX07CF192 128

Table 9.4a Divisor Values for each Baud rate (CLK=1.8432MHz)

|                      | 1.8432 MHz               | <u> </u>         |
|----------------------|--------------------------|------------------|
| Desired<br>Baud Rate | Decimal Divisor<br>Value | Error Percentage |
| 50                   | 2304                     | -                |
| 75                   | 1536                     | -                |
| 110                  | 1047                     | 0.026            |
| 150                  | 768                      | -                |
| 300                  | 384                      | -                |
| 600                  | 192                      | -                |
| 1200                 | 96                       | -                |
| 1800                 | 64                       | -                |
| 2000                 | 58                       | -                |
| 2400                 | 48                       | -                |
| 3600                 | 32                       | -                |
| 4800                 | 24                       | -                |
| 7200                 | 16                       | -                |
| 9600                 | 12                       | -                |
| 19200                | 6                        | -                |
| 38400                | 3                        | -                |
| 57600                | 2                        | -                |
| 115200               | 1                        | -                |

Table 9.4b Divisor Values for each Baud rate (CLK=3.6864MHz)

|                      | 3.6864 MHz               |                  |
|----------------------|--------------------------|------------------|
| Desired<br>Baud Rate | Decimal Divisor<br>Value | Error Percentage |
| 50                   | 4608                     | -                |
| 110                  | 2094                     | 0.026            |
| 300                  | 768                      | -                |
| 1200                 | 192                      | -                |
| 2400                 | 96                       | -                |
| 4800                 | 48                       | -                |
| 9600                 | 24                       | -                |
| 19200                | 12                       | -                |
| 38400                | 6                        | -                |
| 57600                | 4                        | -                |
| 115200               | 2                        | -                |



|       | b31    | b8             | b7       | b6   | b5                   | b4        | b3         | b2    | b1 | b0 |
|-------|--------|----------------|----------|------|----------------------|-----------|------------|-------|----|----|
| LSR   | Reser  | ved            | FIFOE    | TEMT | THRE                 | BI        | FE         | PE    | OE | DR |
| Reset | -      |                | 0        | 1    | 1                    | 0         | 0          | 0     | 0  | 0  |
|       | Initia | al value : 0x) | XXXXXX60 | )    |                      |           |            |       |    |    |
|       |        |                |          |      | DR                   | 0: No da  | ta receive | ed    |    |    |
|       |        |                |          |      |                      | 1: Receiv |            |       |    |    |
|       |        |                |          |      | OE                   | 0: No ove |            | r     |    |    |
|       |        |                |          |      |                      | 1: Overru | ın Error   |       |    |    |
|       |        |                |          |      | PE                   | 0: No pa  | rity error |       |    |    |
|       |        |                |          |      |                      | 1: Parity | Error      |       |    |    |
|       |        |                |          |      | FE                   | 0: No fra | ming erro  | r     |    | 1: |
|       |        |                |          |      | Framing I            | Error     |            |       |    |    |
|       |        |                |          |      | BI                   | 0: No bre | eak detec  | ted   |    | 1: |
|       |        |                |          |      | Break Inte           | errupted  |            |       |    |    |
|       |        |                |          |      | THRE                 | 0: THR n  | ot empty   |       |    |    |
|       |        |                |          |      |                      | 1: THR E  | mpty       |       |    |    |
|       |        |                |          |      | TEMT                 | 0: Transi | mitter not | empty |    |    |
|       |        |                |          |      | 1: Transmitter Empty |           |            |       |    |    |
|       |        |                |          |      | FIFOE                | 0: FIFO i | s valid    |       |    |    |

This register provides status information to the CPU concerning the data transfer. **Table 5 Summary of Registers** shows the contents of the Line Status Register. Details of each bit are:

1: FIFO has Invalid data

- DR This bit is the receiver Data Ready indicator. Bit 0 is set to a logic 1 whenever a complete incoming character has been received and transferred into the Receiver Buffer Register or the FIFO. Bit 0 is reset to a logic 0 by reading all of the data in the Receiver Buffer Register or the FIFO.
- This bit is the Overrun Error indicator. Bit 1 indicates that data in the Receiver Buffer Register was not read by the CPU before the next character was transferred into the Receiver Buffer Register, thereby destroying the previous character. The OE indicator is set to a logic 1 upon the detection of an overrun condition, and reset whenever the CPU reads the contents of the Line Status Register. If the FIFO mode data continues to fill the FIFO beyond the trigger level, an overrun error will occur only after the FIFO is full and the next character has been completely received in the shift register. OE is indicated to the CPU as soon as it happens. The character in the shift register is overwritten, but it is not transferred to the FIFO.
- This bit is the Parity Error indicator. Bit 2 indicates that the received data character does not have the correct even or odd parity, as selected by the even-parity-select bit. The PE bit is set to a logic 1 upon the detection of a parity error and is reset to a logic 0 whenever the CPU reads the contents of the Line Status Register. In the FIFO mode this error is associated with the particular character in the FIFO to which it applies. This error is revealed to the CPU when its associated character is at the top of the FIFO.
- This bit is the Framing Error indicator. Bit 3 indicates that the received character did not have a valid stop bit. Bit 3 is set to a logic 1 whenever the Stop bit following the last data bit or parity bit is detected as a logic 0 bit (Spacing level). The FE indicator is reset whenever the CPU reads the contents of the Line Status Register. In the FIFO mode this error is associated with the particular character in the FIFO to which it applies. This error is revealed to the CPU when its associated character is at the top of the FIFO. The UART will try to resynchronize after a framing error. To do this, it assumes that the framing error was due to the next start bit, so it samples this "start" bit twice and then takes in the "data".



This bit is the Break Interrupt indicator. Bit 4 is set to a logic 1 whenever the received data input is held in the Spacing (logic 0) state for longer than a full word transmission time (that is, the total time of Start bit + data bits + Parity + Stop bits). The BI indicator is reset whenever the CPU reads the contents of the Line Status Register. In the FIFO mode this error is associated with the particular character in the FIFO to which it applies. This error is revealed to the CPU when its associated character is at the top of the FIFO. When break occurs only one zero character is loaded into the FIFO. The next character transfer is enabled after SIN goes to the marking state and receives the next valid start bit.

\*\* Note: Bits 1 through 4 are the error conditions that produce a Receiver Line Status interrupt whenever any of the corresponding conditions is detected and the interrupt is enabled.

THRE This bit is the Transmitter Holding Register Empty indicator. Bit 5 indicates that the UART is ready to accept a new character for transmission. In addition, this bit causes the UART to issue an interrupt to the CPU when the Transmit Holding Register Empty Interrupt enable is set to high. The THRE bit is set to a logic 1 when a character is transferred from the Transmitter Holding Register into the Transmitter Shift Register. The bit is reset to logic 0 concurrently with the loading of the Transmitter Holding Register by the CPU. In the FIFO mode this bit is set when the XMIT FIFO is empty; it is cleared when at least 1 byte is written to the XMIT FIFO.

**TEMT** This bit is the Transmitter Empty indicator. Bit 6 is set to a logic 1 whenever the Transmitter Holding Register (THR) and the Transmitter Shift Register (TSR) are both empty. It is reset to a logic 0 whenever either the THR or TSR contains a data character. In the FIFO mode this bit is set to one whenever the transmitter FIFO and register are both empty.

FIFOE In the 16450 mode, this is 0. In the FIFO mode, FIFOE is set when there is at least one parity error, framing error or break indication in the FIFO.

LSR7 is cleared when the CPU reads the LSR, if there are no subsequent errors in the FIFO.

\*\* Note: The Line Status Register is intended for read operations only.



## FCR FIFO Control Register (0x1408 WriteOnly)

|       | b31      | b8 | b7        | b6 | b5  | b4  | b3  | b2   | b1   | b0     |
|-------|----------|----|-----------|----|-----|-----|-----|------|------|--------|
| FCR   | Reserved |    | FIFODEPTH |    | Res | Res | Res | FCR2 | FCR1 | FIFOEN |
| Reset | -        |    | 00        |    | 0   | 0   | 0   | 0    | 0    | 0      |

Initial value: 0xXXXXXX00

FIFOEN 0: Disable FIFO

1: Enable Both Tx/Rx FIFO

FCR1 0: shift register not cleared 1: Self-clear shift register

FCR2 0: shift register not cleared

1: Self-clear shift register

FIFODEPTH Receive FIFO Trigger Level

00: 1 Byte01: 4 Bytes10: 8 Bytes11: 14 Bytes

This is a write only register at the same location as the IIR (the IIR is a read only register). This register is used to enable the FIFOs, clear the FIFOs and set the RCVR FIFO to trigger level

**FIFOEN** Writing a 1 to FCR0 enables both the XMIT and RCVR FIFOs. Resetting FCR0 will clear all bytes in both FIFOs. When changing from FIFO Mode to 16C450 Mode and vice versa, data is automatically cleared from the FIFOs. This bit must be a 1 when other FCR bits are written to or they will not be programmed.

FCR1 Writing a 1 to FCR1 resets its counter logic to 0. The shift register is not cleared. The 1 that is written to this bit position is self-cleared.

FCR2 Writing a 1 to FCR2 resets its counter logic to 0. The shift register is not cleared. The 1 that is written to this bit position is self-cleared.

FIFODEPTH These bits are used to set the trigger level for the RCVR FIFO interrupt.



#### IIR Interrupt Identification Register (0x1408 ReadOnly)

|       | b31   | b8  | b7   | b6 | b5  | b4  | b3  | b2  | b1 | b0   |
|-------|-------|-----|------|----|-----|-----|-----|-----|----|------|
| IIR   | Reser | ved | FIFO |    | Res | Res | FID | IID |    | IPEN |
| Reset | -     |     | 00   |    | 0   | 0   | 0   | 00  | 0  | 1    |

**FIFO** 

Initial value: 0xXXXXXX01

IPEN 0: Interrupt Pending

1: No Interrupt pending

IID/FID Interrupt Identification Value

(refer to Table 9.7) Indicate FIFO mode

00: None-FIFO mode

11: FIFO mode

In order to provide minimum software overhead during data character transfers, the UART prioritizes interrupts into four levels and records them in the Interrupt Identification Register. The four levels of interrupt conditions are as follows in order of priority:

- Receiver Line Status
- Received Data Ready
- Transmitter Holding Register Empty
- Modem status

When the CPU accesses the IIR, the UART freezes all interrupts and indicates the highest priority pending interrupt to the CPU. While this CPU access occurs, the UART records new interrupts, but does not change its current indication until the access is complete. *Table 9.6 Summary of Registers* shows the contents of the IIR. Details of each bit are:

**IPEN** This bit can be used in a prioritized interrupt environment to indicate whether an interrupt is pending or not. When bit 0 is a logic 0, an interrupt is pending and the IIR contents may be used as a pointer for the appropriate interrupt service routine. When bit 0 is a logic 1, no interrupt is pending.

IID These two bits of the IIR are used to identify the highest priority interrupt pending as indicated in *Table 9.5 Interrupt control functions*.

FID In the 16450 mode this bit is 0. In the FIFO mode this bit is set along with bit 2 when a time-out interrupt is pending.

**FIFO** These two bits are set when FIFOEN = 1.



Table 9.5 Interrupt Control Functions

| Priority<br>Level | FIFO<br>Mode<br>Only | Interrupt<br>Identification Register |       |       | Interrupt Set and Reset Functions           |                                                                                                                                                   |                                                                                                                             |  |  |  |  |
|-------------------|----------------------|--------------------------------------|-------|-------|---------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                   | Bit 3                | Bit 2                                | Bit 1 | Bit 0 | Interrupt<br>Type                           | Interrupt Source                                                                                                                                  | Interrupt<br>Reset Control                                                                                                  |  |  |  |  |
| -                 | 0                    | 0                                    | 0     | 1     | None                                        | None                                                                                                                                              | -                                                                                                                           |  |  |  |  |
| Highest           | 0                    | 1                                    | 1     | 0     | Receiver<br>Line Status                     | Overrun Error, Parity<br>Error, Framing Error or<br>Break Interrupt                                                                               | Reading the Line Status<br>Register                                                                                         |  |  |  |  |
| Second            | 0                    | 1                                    | 0     | 0     | Receiver<br>Data<br>Available               | Receiver Data Available or<br>Trigger Level Reached                                                                                               | Reading the Receiver<br>Buffer Register or the<br>FIFO drops below the<br>trigger level                                     |  |  |  |  |
| Second            | 1                    | 1                                    | 0     | 0     | Character<br>Time-out<br>Indication         | No Characters have been removed from or input to the RCVR FIFO during the last 4 Char. times and there is at least 1 Char. in it during this time | Reading the Receiver<br>Buffer Register                                                                                     |  |  |  |  |
| Third             | 0                    | 0                                    | 1     | 0     | Transmitter<br>Holding<br>Register<br>Empty | Transmitter Holding<br>Register Empty                                                                                                             | Reading the IIR Register<br>(if it is the source of<br>interrupt) or writing it into<br>the Transmitter Holding<br>Register |  |  |  |  |
| Fourth            | 0                    | 0                                    | 0     | 0     | Modem<br>Status                             | Clear to Send, Data Set<br>Ready, Ring Indicator, or<br>Data Carrier Detect                                                                       | Reading the Modem<br>Status Register                                                                                        |  |  |  |  |

#### IEN Interrupt Enable Register (0x1404 R/W)

|       | b31   | b8  | b7 | b6 | b5  | b4 | b3 | b2    | b1     | b0   |
|-------|-------|-----|----|----|-----|----|----|-------|--------|------|
| IEN   | Resei | ved |    |    | Res |    |    | RLSIE | THREIE | DRIE |
| Reset | -     |     | 0  | 0  | 0   | 0  | 0  | 0     | 0      | 0    |

Initial value: 0xXXXXXX00

DRIE 0: No data received

1: Received Data Ready

THREIE 0: No overrun error

1: Overrun Error

RLSIE 0: No parity error

1: Parity Error

This register enables the five types of UART interrupts. Each interrupt can individually activate the interrupt output signal. It is possible to totally disable the interrupt Enable Register (IER). Similarly, setting bits of the IER register to a logic 1 enables the selected interrupt(s). Disabling an interrupt prevents it from being indicated as active in the IIR and from activating the UART interrupt output signal. All other system functions operate as normal, including the setting of the Line Status Registers. *Table 9.6 the Summary of Registers* shows the contents of the IER. Details on each bit are:

DRIE This bit enables the Received Data Available Interrupt (and time-out interrupts in

the FIFO mode) when it is set to logic 1.

THREIE This bit enables the Transmitter Holding Register Empty Interrupt when set to

logic 1.

**RLSIE** This bit enables the Receiver Line Status Interrupt when it is set to logic 1.



#### LTR Loop Test Control Register (0x1410 R/W)



**LBON** 0: Normal Transmission 1: Loopback mode

This register controls the interface with the modem or data set (or a peripheral device emulating a modem). The contents of the Modem Control Register are indicated in *Table 9.6 Summary of Registers*, and are described below.

#### **LBON**

This bit provides a local loopback feature for diagnostic testing of the UART. When bit 4 is set to logic 1, the transmitter Serial Output (SOUT) is set to the Marking (logic 1) state. The receiver Serial Input (SIN) is disconnected; the output of the Transmitter Shift Register is "looped back" into the Receiver Shift Register input. The four Modem Control inputs (NCTS, NDSR, NDCD, and NRI) are disconnected. The two Modem Control outputs (NDTR and NRTS) and two internal nodes (OUT1 and OUT2) are internally connected to the four Modem Control inputs and the Modem Control output pins are forced to be their inactive state (high). In the diagnostic mode, the transmitted data is immediately received. This feature allows the processor to verify the transmit- and received-data paths of the UART.

In the diagnostic mode, the receiver and transmitter interrupts are fully operational.

#### SCR Scratch Register (0x141C R/W)

|       | b31    | b8             | b7       | B6 | b5  | B4        | b3      | b2 | b1 | b0 |  |
|-------|--------|----------------|----------|----|-----|-----------|---------|----|----|----|--|
| SCR   | Reser  | ved            |          |    | SCR |           |         |    |    |    |  |
| Reset | -      |                |          | 00 | )   |           |         |    |    |    |  |
|       | Initia | al value : 0x) | XXXXXX00 | (  | SCR | Scratch R | egister |    |    |    |  |

This 8-bit Read/Write Register does not control the UART in any way. It is intended to be used as a scratchpad register by the programmer to hold data temporarily.



#### 9.6 UART Operations

#### 9.6.1 FIFO Interrupt Mode Operation

# When the RCVR FIFO and receiver interrupts are enabled (FIFOEN = 1, DRIE = 1), RCVR interrupts occur as follows:

The received data available interrupt will be issued to the CPU when the FIFO has reached its programmed trigger level; it will be cleared as soon as the FIFO drops below its programmed trigger level.

The IIR receive data available indication also occurs when the FIFO trigger level is reached, and like the interrupt it is cleared when the FIFO drops below the trigger level.

The receiver line status interrupt (IIR=0x06), as before, has higher priority than the received data available (IIR=0x04) interrupt.

The data ready bit (DR) is set as soon as a character is transferred from the shift register to the RCVR FIFO. It is reset when the FIFO is empty.

# When RCVR FIFO and receiver interrupts are enabled, RCVR FIFO timeout interrupts occur as follows:

- 1. A FIFO timeout interrupt occurs under the following conditions:
  - at least one character is in the FIFO
  - the latest serial character received was longer than 4 continuous character times (if 2 stop bits are programmed, the second one is included in this time delay).
  - the latest CPU read of the FIFO was longer than 4 continuous character times.

This will cause a maximum character received to interrupt issued delay of 160 ms at 300 baud with a 12 bit character.

- 2. Character times are calculated by using the RCLK input for a clock signal (this makes the delay proportional to the baud rate).
- 3. When a timeout interrupt has occurred, it is cleared and the timer is reset when the CPU reads one character from the RCVR FIFO.
- 4. When a timeout interrupt has not occurred the timeout timer is reset after a new character is received or after the CPU reads the RCVR FIFO.

# When the XMIT FIFO and transmitter interrupts are enabled (FIFOEN = 1, THREIE = 1), XMIT interrupts occur as follows:

- 1. The transmitter holding register interrupt (IR=0x02) occurs when the XMIT FIFO is empty; it is cleared as soon as the transmitter holding register is written to. (1 to 16 characters may be written to the XMIT FIFO while this interrupt is serviced or the IIR is read.)
- 2. The transmitter FIFO empty indications will be delayed 1 character time minus the last stop bit time whenever the following occurs: THRE = 1 and there has not been at least two bytes at the same time in the transmit FIFO since the last THRE = 1. The first transmitter interrupt after changing fiFOEN will be immediate (if the interrupt is enabled, i.e. THREIE=1).

Character timeout and RCVR FIFO trigger level interrupts have the same priority as the current received data available interrupt; XMIT FIFO empty has the same priority as the current transmitter holding register empty interrupt.



## 9.6.2 FIFO Polled Mode Operation

When FIFOEN=1, resetting DRIE, THREIE, RLSIE or all to zero puts the UART in the FIFO Polled Mode. Since the RCVR and XMITTER are controlled separately, either one or both can be in the polled mode of operation.



## 9.7 Register Summary

Table 9.6 Summary of Registers

| Reg.  | Offset | Dir. |       |                            |                                | Bit   | Field |       |        |       | cf.    |
|-------|--------|------|-------|----------------------------|--------------------------------|-------|-------|-------|--------|-------|--------|
| Name  | Oliset | Dii. | Bit 7 | Bit 6                      | Bit 5                          | Bit 4 | Bit 3 | Bit 2 | Bit 1  | Bit 0 | CI.    |
| RBR   | 0x00   | R    |       | RBR                        |                                |       |       |       |        |       | DLAB=0 |
| THR   | 0x00   | W    |       |                            |                                | TI    | HR    |       |        |       | DLAB=0 |
| IER   | 0x04   | R/W  |       |                            |                                |       |       | RLSIE | THREIE | DRIE  |        |
| IIR   | 80x0   | R    |       | FID IID IPEN               |                                |       |       |       |        | IPEN  |        |
| FCR   | 0x08   | W    | FIFO  | FIFODEPTH FCR2 FCR1 FIFOEN |                                |       |       |       | FIFOEN |       |        |
| LCR   | 0x0C   | R/W  | DLAB  | BREAK                      | STICKF PARITY PEN STOPBIT DLEN |       |       |       | EN     |       |        |
| LTR   | 0x10   | R/W  |       |                            |                                | LBON  |       |       |        |       |        |
| LSR   | 0x14   | R    | FIFOE | TEMT                       | THRE                           | BI    | FE    | PE    | OE     | DR    |        |
| -     | 0x18   | -    |       |                            |                                |       |       |       |        |       |        |
| SCR   | 0x1C   | R/W  |       |                            |                                | S     | CR    |       |        |       |        |
| DLL   | 0x00   | R/W  |       | DLL                        |                                |       |       |       |        |       |        |
| DLM   | 0x01   | R/W  |       | DLM                        |                                |       |       |       |        |       |        |
| CLKCR | 0x20   | R/W  |       |                            |                                |       |       |       |        | CKEN  |        |
| CLKDR | 0x24   | R/W  |       |                            | •                              | CLŁ   | (DIV  |       | •      | •     |        |



# Chapter 10

# **GPIO (General Purpose Input Output)**



#### 10.1 General Description

The GPIO is an APB peripheral which provides 75 bits of programmable input /output divided into 11 ports; port A, port B, port 1, port 2, port 3, port 4, port 5, port 6, port 7, port 8 and port 9. Each pin is configurable as either an input or an output. At system reset, ports A, 1, 3, 5, 8, 9 are set by default to inputs and ports B, 2, 4, 6, 7 set to outputs.



Figure 10.1 GPIO Block Diagram and PADS Connections(example for Port A and Port B)

Each port has a data register and a data direction register. The data direction register defines whether each individual pin is an input or an output. The data register is used to read the value of the GPIO pins, both input and output, as well as to set the values of pins that are configured as outputs.



#### 10.2 **GPIO Registers**

The following user registers are provided:

PnDR\*

Port n Data Register. Values written to this read/write register will be input on port A pins if the corresponding data direction bits are set to HIGH (port input). Values read from this register reflect the external states of port n, not necessarily the value that was written to it. All bits are cleared by a system reset.

**PnDDR\*** Port n Data Direction Register. Bits set in this read/write register will select the corresponding pins in port n to become inputs, clearing a bit sets the pin to output. All bits are cleared by a system reset.

\*n is: A, B, 1, 2, 3, 4, 5, 6, 7, 8 or 9

#### 10.2.1 **Register Memory Map**

The start address of the GPIO is 0x0900\_1600 and the offset of each register from the base address is shown.

Table 10.1 GPIO Register Memory Map

| REG.  | I/O<br>OFFSET | DIR | DESCRIPTION                    |
|-------|---------------|-----|--------------------------------|
| PADR  | 0x1600        | R/W | 8-bit Port A Data register     |
| PADDR | 0X1604        | R/W | Port A Data Direction register |
| PBDR  | 0X1608        | R/W | 8-bit Port B Data register     |
| PBDDR | 0X160C        | R/W | Port B Data Direction register |
| P1DR  | 0X1610        | R/W | 8-bit Port 1 Data register     |
| P1DDR | 0X1614        | R/W | Port 1 Data Direction register |
| P2DR  | 0X1618        | R/W | 8-bit Port 2 Data register     |
| P2DDR | 0X161C        | R/W | Port 2 Data Direction register |
| P3DR  | 0X1620        | R/W | 8-bit Port 3 Data register     |
| P3DDR | 0X1624        | R/W | Port 3 Data Direction register |
| P4DR  | 0X1628        | R/W | 8-bit Port 4 Data register     |
| P4DDR | 0X162C        | R/W | Port 4 Data Direction register |
| P5DR  | 0X1630        | R/W | 4-bit Port 5 Data register     |
| P5DDR | 0X1634        | R/W | Port 5 Data Direction register |
| P6DR  | 0X1638        | R/W | 8-bit Port 6 Data register     |
| P6DDR | 0X163C        | R/W | Port 6 Data Direction register |
| P7DR  | 0X1640        | R/W | 3-bit Port 7 Data register     |
| P7DDR | 0X1644        | R/W | Port 7 Data Direction register |
| P8DR  | 0X1648        | R/W | 5-bit Port 8 Data register     |
| P8DDR | 0X164C        | R/W | Port 8 Data Direction register |
| P9DR  | 0X1650        | R/W | 7-bit Port 9 Data register     |
| P9DDR | 0X1654        | R/W | Port 9 Data Direction register |



AX07CF192 141

#### 10.3.1 Register Description

Each GPIO port has its own Data register and Data Direction register. Note: Not all those ports are 8-bit wide (see Table 10.1).

#### PnDR Port n Data Register (R/W, n is A,B,1,2,3,4,5,6,7,8 or 9)

|               | b31 - b8              | b7 | b6 | b5           | b4   | b3                | b2 | b1 | b0 |
|---------------|-----------------------|----|----|--------------|------|-------------------|----|----|----|
| P <i>n</i> DR | Reserved              | D7 | D6 | D5           | D4   | D3                | D2 | D1 | D0 |
| Reset         | -                     | 0  | 0  | 0            | 0    | 0                 | 0  | 0  | 0  |
|               | Initial value : 0x-00 |    |    | Bit field Do | )-D7 | 1 : On<br>0 : OFF |    |    |    |

#### PnDDR Port n Data Direction Register (R/W, n is A,B,1,2,3,4,5,6,7,8 or 9)

|                | b31 - b8         | b7 | b6              | b5 | b4 | b3                           | b2 | b1 | b0 |
|----------------|------------------|----|-----------------|----|----|------------------------------|----|----|----|
| P <i>n</i> DDR | Reserved         | 17 | 16              | 15 | 14 | 13                           | 12 | 11 | Ю  |
| Reset          | -                | 1  | 1               | 1  | 1  | 1                            | 1  | 1  | 1  |
|                | Initial value: 0 | E  | Bit field I0-I7 |    |    | 1 : Assign the port as Input |    |    |    |

0 : Assign the port as Output



#### 10.3 Functional Description

All block registers are cleared during power on reset.

This disables the output drivers for port A, 1, 3, 5, 8 and 9 (inputs by default) and enables the drivers for port B, 2, 4, 6 and 7 (outputs by default).

For each port there is a Data Register and a Data Direction Register. On reads, the Data Register contains the current status of the corresponding port pins whether they are configured as input or output. Writing to a Data Register only affects the pins that are configured as outputs.

The Data Direction Registers operates in a different manner on each port:

• For every port, a "0" in the data direction register indicates the port is defined as an output (default), a "1" in the data direction register indicates the port is defined as an input.



# Chapter 11 On-Chip SRAM



#### 11.1 General Description

The AX07CF192 has 4-kbytes of high-speed static RAM on-chip. The RAM is connected to the CPU by a 32-bit ASB (Advanced System Bus) bus. The CPU accesses byte data, halfword data, and word data in one cycle, making the RAM useful for rapid data transfer.

# 11.2 Functional Description

Data can be read from the on-chip SRAM, or data can be written to the SRAM in a single clock cycle through the ASB bus. The SRAM is implemented as a single module with 32-bit data bus and control lines.

The single cycle access makes the SRAM ideal for use as a program area, stack area, or data area, which requires high-speed access. The contents of the on-chip SRAM are retained in both standby and power-down modes.

Since the on-chip RAM is connected to the CPU by an internal 32-bit data bus, it can be written and read by word access. It can also be written and read by half-word or byte access.

The memory area **0x0803\_0000** to **0x0803\_FFFF** is allocated to the on-chip SRAM by default. The memory area is allocated from **0x0000\_0000** to **0x0000\_0FFF** in Remap mode. This Remap mode is entered by setting the REMAP flag in MEM\_CR of the PMU (see *Chapter 5 Power Management Unit* for detail).



# Chapter 12

# **On-chip Flash Memory**



# 12.1 General Description

The **AX07CF192** has 192-Kbytes of on-chip flash memory. The flash memory is connected to the CPU by a 16-bit data bus. The CPU accesses both half-word and word data in several states depending on the wait register value.

The on-chip flash memory booting option is enabled and disabled by setting the mode pins  $(MD_2 \text{ to } MD_0)$  as shown in **Table 12.1**.

#### 12.2 Features

- Memory organization: 96K x 16 (1.5Mbit)
- Operating Voltage: dual power 3.0V ~ 3.6V (Vcc), 4.5~5.5V (FTVPPD)
- Random access time: 90nsec
- Program time : typ. 100usec/word
- Erase block size: 32KB x 4, 24KB x 2, 8KB x 2
- Block erase time : typ. 1.5sec/32KB (pre program + erase)
- Multiple block erase command support (maximum 4 blocks)
- Endurance : Min. 100 cycles
- Both on-chip (user/boot mode) and on-board (PROM mode) program/erase support
- Bi-directional Data IO
- Operating current: Standby mode: 10uA
   Read/Program/Erase mode: max. 20mA



Table 12.1 Operating mode

| Table 1211 Operating mode |                 |                 |      |                                                           |  |  |  |  |  |
|---------------------------|-----------------|-----------------|------|-----------------------------------------------------------|--|--|--|--|--|
| MD <sub>2</sub>           | MD <sub>1</sub> | MD <sub>0</sub> | Mode | Description                                               |  |  |  |  |  |
| 0                         | 1               | 0               | M2   | External 8-bit data bus and 16-Mbyte address mode         |  |  |  |  |  |
| 0                         | 1               | 1               | МЗ   | External 16-bit data bus and 16-Mbyte address mode        |  |  |  |  |  |
| 1                         | 0               | 0               | M4   | Flash memory boot mode with external 16-bit data bus mode |  |  |  |  |  |
| 1                         | 0               | 1               | M5   | Flash memory boot mode (microcomputer mode)               |  |  |  |  |  |
| 1                         | 1               | 0               | M6   | UART booting mode with external 16-bit data bus           |  |  |  |  |  |
| 1                         | 1               | 1               | M7   | UART booting mode with microcomputer mode                 |  |  |  |  |  |



# 12.3 Block Diagram



Figure 12.1 Block Diagram of Flash Memory



Table 12.2 Signal description of Figure 12.1(BUS Interface)

| - Tal         | ole 12. | 2 Signal description of Figure 12.1(BOS interface)                                                                                                                                                  |
|---------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Name          | I/O     | Function                                                                                                                                                                                            |
| BnRES         | I       | This signal indicates the reset status of the ASB                                                                                                                                                   |
| BCLK          | - 1     | The ASB clock timing all bus transfers                                                                                                                                                              |
| DSELREG       | I       | When this signal is HIGH, it indicates that the Flash Memory configuration Internal registers are selected. (When BA[31:0] is set to the FMI Region, 0x09000200~0x090002ff, of the Memory Map)      |
| DSEL          | I       | When this signal is HIGH, it indicates that the Flash Memory Array address is selected. (When BA[31:0] is set to the Flash Memory Region of the Memory Map.)                                        |
| BWRITE        | I       | When this signal is HIGH, it indicates a write transfer and when LOW a read.                                                                                                                        |
| BSIZE[1:0]    | I       | These signals indicate the size of the transfer that may be byte, halfword, or word.                                                                                                                |
| BA[31:0]      | ı       | System address bus.  BA[[31:17] is used for selection between the Internal Register Block and Flash Memory. BA[16:0] is used for selection of a Specific Internal Register or Flash Memory Address. |
| BD[31:0]      | I/O     | Bi-directional system data bus.                                                                                                                                                                     |
| BWAIT         | 0       | Wait slave response signal. It is driven to a 1 when a Flash Memory Read operation is selected. It is asserted while the Flash Memory Read operation is incomplete.                                 |
| BERROR        | 0       | When BERROR is HIGH, a transfer error has occurred. When BERROR is LOW, then the transfer is successful                                                                                             |
| BLAST         | 0       | When BLAST is HIGH, the system decoder must allow sufficient time for address decoding. When BLAST is LOW, the next transfer may continue in a burst sequence.                                      |
| MODE<br>[2:0] | I       | These signals are directly connected to external pins $(MD_2 \sim MD_0)$ , and represent the operating modes shown in <i>Table12.1</i>                                                              |
| FTVPPD        | In      | External programming voltage for the flash memory. It is directly connected to the external pin in all operating modes.                                                                             |



# 12.4 Flash Memory Register Description

The registers used to control the on-chip flash memory when enabled are shown in *Table 12.3*. The base address of the flash memory register (FMU\_base) is **0x0900\_0200**.

Table 12.3 Flash Memory Registers

| rubic incomment regions. |                       |      |                             |                  |  |  |  |  |  |
|--------------------------|-----------------------|------|-----------------------------|------------------|--|--|--|--|--|
| Reg.                     | I/O<br>Offset         | Dir. | Description                 | Initial<br>Value |  |  |  |  |  |
| WAITREG                  | 0x0200                | R/W  | Wait Register               | 0x000F           |  |  |  |  |  |
| ADDREG                   | 0x0204                | R/W  | Address Register            | 0x0000           |  |  |  |  |  |
| DATAREG                  | 0x0208                | R/W  | Data Register               | 0xFFFF           |  |  |  |  |  |
| CONTREG                  | NTREG 0x020C R/W Conf |      | Control Register            | 0x0000           |  |  |  |  |  |
| EBR                      | 0x0210                | R/W  | Erase Block Select Register | 0x0000           |  |  |  |  |  |
| STATPWR                  | 0x0214                | R/W  | Status & Power Register     | 0x0000           |  |  |  |  |  |
| TESTR                    | 0x0218                | R/W  | Test Register               | 0x0400           |  |  |  |  |  |

#### **WAITREG**

#### Wait Control Register (WAITREG)

Bit

Initial Value Read/Write

| 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|
| W7  | W6  | W5  | W4  | W3  | W2  | W1  | W0  |
| 0   | 0   | 0   | 0   | 1   | 1   | 1   | 1   |
| R/W |

**WAITREG** is an 8-bit register used for bus access wait time control. The initial value is 0xF. Once a Read command is executed, the next command execution is delayed by the number of bus clocks (BCLK) set in WAITREG.

Therefore a Flash Memory Read Operation is performed during the time of WAITREG value \* period of BCLK. For a successful Flash Memory Read Operation without interruption, this time must be longer then a Flash Memory Access time (TACC). The typical value of WAITREG using a 33 MHz-clock input is 0x02, which means that the delay time is 90nsec.



#### ADDREG Address Register

| Bit        | 16  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
|            | A16 | A15 | A14 | A13 | A12 | A11 | A10 | A9  | A8  | A7  | A6  | A5  | A4  | A3  | A2  | A1  | A0  |
| Init. Val. | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| RD/WR      | R/W |

The address of a 16-bit word to be programmed or verified is stored in this register in the Program mode (including Pre-Program) and the Verify mode (program/erase verify). In Normal Read Mode, FA[16:0] is passed directly to the address decoding block without passing through ADDREG.

In Erase Mode, selecting a block in the 'block select register' causes the specified Flash Memory block to be erased.

Users can write to this register directly in mode1(PROM Mode) by setting the FR\_SEL signal, and the usable address range is 96K x16 bits, 0x00000~0x17FFF. In this mode, if FR\_SEL[2:0] is '001' and FWEB is rising-edge, FA[16:0] is passed into ADDREG. If FR\_SEL[2:0] is '001', FWEB is '1' and FOEB='0', users are able to read 16-bits of ADDREG[16:1] through FD[15:0] in this mode.

In other modes, except mode1, ADDRREG is written via the decoded value from BA[16:0] of the Flash Memory address write command (not the ADDRREG write) and read directly through an ADDRREG read.

#### DATAREG Data Register

| Bit        | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
|            | D15 | D14 | D13 | D12 | D11 | D10 | D9  | D8  | D7  | D6  | D5  | D4  | D3  | D2  | D1  | D0  |
| Init. Val. | 1   | 1   | 1   | 1   | 1   | 1   | 1   | 1   | 1   | 1   | 1   | 1   | 1   | 1   | 1   | 1   |
| RD/WR      | R/W |

Register for storing data that is programmed to the Flash Memory Address of ADDREG value in Program mode. Each bit location corresponds directly to a memory cell, a 0 will cause the cell to be programmed, a 1 will not program the cell. The Flash Memory can be programmed 16 bits at a time.

After a reset, the Data register output value is set to 0xFFFF and the other registers are set to '0'.

Users can write to this register directly in mode1 (PROM Mode). In this Mode, if FR\_SEL[2:0] = '001' and FWEB is rising-edge, FD[15:0] is passed into DATAREG. If FR\_SEL[2:0] = '010', FWEB = '1' and FOEB='0', users are able to read the 16 bits of DATAREG[15:0] through FD[15:0] .

In other modes, except mode 1, DATAREG is written via BD[16:0] of the Flash Memory address write command (not the DATAREG write) and read directly using DATAREG read.





**CONTREG** is an 8-bit register used for flash memory operating mode control. It can be read and written in all modes. It controls the state of the flash memory array during read, program and erase operations, and the charge pump operation mode. *Table 12.4* shows the function of each bit of the Control register.

The Program process uses one mode (PGM) and the Verify process has two modes (PGM\_VFY,ER\_VFY)

Table 12.4 Control Register

| Name    | Function                                                                     |
|---------|------------------------------------------------------------------------------|
| PGM_PWR | Program Power Setup (Drain/Positive Gate Pump Enable)                        |
| ER_PWR  | Erase Power Setup (Negative/Positive Gate Pump Enable)                       |
| PGM     | Program Start bit. Program Pulse Supply to Addressed Cell (Drain/Gate Pulse) |
| ERSE    | Erase Start bit. Erase Pulse Supply to Addressed Block (Gate/Bulk Pulse)     |
| PGM_VFY | Program Verify Read Enable (Positive Gate Pump Enable)                       |
| ER_VFY  | Erase Verify Read Enable (Positive Gate Pump Enable)                         |

The bits of the Control register as shown in *Table 12.4* are used to perform the Program/Erase/Verify process.

PGM\_PWR/ER\_PWR sets up the charge pump before Program and Erase. To make the high voltage necessary to program or erase the memory, set the PGM\_PWR for program or ER\_PWR for erase and wait for the pump setup time. After setting up the pump, set the PGM for program or ERSE for erase to start the program or erase process. In verify mode, without setting bit0 and bit1, set the bit corresponding to the verify mode required (PGM\_VFY,ER\_VFY) to set up the pump and perform a verify read.

In Mode1, if FR\_SEL[2:0] is '011' and FWEB is rising-edge, FD[7:0] is passed into CONTREG. If FR\_SEL[2:0] is '011', FWEB is '1' & FOEB='0', users are able to read 8-bit of CONTREG through FD[7:0].

In other modes, except mode1, CONTREG register writes and reads are both possible.



#### EBR Erase Block Select Register

| Bit           | 7     | 6    | 5    | 4    | 3    | 2    | 1    | 0     |
|---------------|-------|------|------|------|------|------|------|-------|
|               | SEC7  | SEC6 | SEC5 | SEC4 | SEC3 | SEC2 | SEC1 | SEC0  |
| Initial Value | 0     | 0    | 0    | 0    | 0    | 0    | 0    | 0     |
| Paad/Mrita    | D/\// | P/M  | P/M  | P/W  | P/W  | P/M  | R/M  | P/\// |

The Bits of this register are used as selectors for 'Erase block(sector)' and each bit of this register is matched to each erase block(sector). After setting CONTREG for erase, block erase is performed by setting each corresponding block number bit in EBR to 1. *Table 12.5* depicts the sector numbers, sector size and the address of the lower 18 bits. Multiple block erase is possible by setting multiple bits of this register. (Maximum 4 blocks at a time) In Mode1, if FR\_SEL[2:0] is '100' & FWEB is rising-edge, FD[7:0] is passed into EBR. If FR\_SEL[2:0] is '100', FWEB is '1'& FOEB is '0', users are able to read the 8-bit value of EBR[16:1] through FD[7:0].

In other modes, except mode 1, EBR register writes and reads are both possible.

Table 12.5 Erase Block Register

| Sector # | Sector Size   | Address Range     |  |  |  |  |
|----------|---------------|-------------------|--|--|--|--|
| Sector 0 | 8KB (4K-word) | 0x00000 ~ 0x01FFF |  |  |  |  |
| Sector 1 | 8KB           | 0x02000 ~ 0x03FFF |  |  |  |  |
| Sector 2 | 24KB          | 0x04000 ~ 0x0BFFF |  |  |  |  |
| Sector 3 | 24KB          | 0x0B000 ~ 0x0FFFF |  |  |  |  |
| Sector 4 | 32KB          | 0x10000 ~ 0x17FFF |  |  |  |  |
| Sector 5 | 32KB          | 0x18000 ~ 0x1FFFF |  |  |  |  |
| Sector 6 | 32KB          | 0x20000 ~ 0x27FFF |  |  |  |  |
| Sector 7 | 32KB          | 0x28000 ~ 0x2FFFF |  |  |  |  |

#### STATPWR Status & Power Register

| Bit           | 8     | 7     | 6    | 5         | 4 | 3        | 2 | 1         | 0 |  |
|---------------|-------|-------|------|-----------|---|----------|---|-----------|---|--|
|               | HVEEI | LVEEI | LVCC | VEEI[1:0] |   | reserved |   | VPPI[1:0] |   |  |
| Initial Value | 0     | 0     | 0    | 00        | ) | 0        | 0 | 00        |   |  |
| Read/Write    | R/W   | R/W   | R/W  | R/W       |   | -        |   | R/W       |   |  |

This register regulates the charge pump output voltage and indicates the status of the pump in Program and Erase modes. In the following table, bits[8:6] are status bits and bits[5:0] are power control bits to regulate the output voltage. Bit[s5:0] control the voltage needed in Program, erase and verify mode.

In Mode 1, if  $FR\_SEL[2:0]$  is '101' & FWEB is rising-edge, FD[5:0] is passed into STATPWR[5:0] (STATPWR[8:6] are read only). If  $FR\_SEL[2:0]$  is '101' and FWEB is '1', users are able to read 9 bits of STATPWR through FD[8:0].

In other modes, except mode 1, STATPWR writes and reads are both possible.



Table 12.6 Status & Power Register

|     |           | <u> </u>                                                              |  |  |  |  |  |  |  |
|-----|-----------|-----------------------------------------------------------------------|--|--|--|--|--|--|--|
| Bit | Name      | Function                                                              |  |  |  |  |  |  |  |
| 8   | HVEEI     | = 1, when the 'ER_PWR' in <b>CONTREG</b> is 1 and VEEI (Negative Gate |  |  |  |  |  |  |  |
|     |           | pump output voltage) is below –7V (i.e. –7.1V)                        |  |  |  |  |  |  |  |
| 7   | LVEEI     | = 1 when VEEI voltage has risen above -1V to discharge.               |  |  |  |  |  |  |  |
| 6   | LVCC      | = 1 when Charge Pump is running (PGM_PWR=1 or ER_PWR=1)               |  |  |  |  |  |  |  |
|     |           | and VDD falls below 2.9V.                                             |  |  |  |  |  |  |  |
| 5,4 | VEEI[1:0] | These bits define VEEI (Negative Gate Pump output voltage) when       |  |  |  |  |  |  |  |
|     |           | the 'ER_PWR' of CONTREG is 1.                                         |  |  |  |  |  |  |  |
|     |           | ("00": -9V, "01": -10V, "10": -8V, "11": -10V)                        |  |  |  |  |  |  |  |
| 3,2 | reserved  | These bits are reserved for future use                                |  |  |  |  |  |  |  |
| 1,0 | VPPI[1:0] | These bits define VPPI (Positive Gate Pump output voltage) when       |  |  |  |  |  |  |  |
|     |           | either PGM_PWR or ER_PWR is 1.                                        |  |  |  |  |  |  |  |
|     |           | These bits also define the VPPI value differently in program or erase |  |  |  |  |  |  |  |
|     |           | mode, when one of the verify mode enable bits in CONTREG is 1.        |  |  |  |  |  |  |  |
|     |           | Program/Erase Mode ("00": 9V, "01": 8V, "10": 10V, "11": 7V)          |  |  |  |  |  |  |  |
|     |           | Verify_Mode ("00": 4V, "01": 5V, "10": 6V, "11": 7V)                  |  |  |  |  |  |  |  |



# 12.5 On-Board Programming Mode

When the mode pins are set for the on-board programming mode and a reset-start is executed, the chip enters the on-board programming state in which on-chip flash memory programming, erasing, and verifying can be carried out. There are two operating modes – boot mode and user program mode – as set by the mode pins.

Boot mode is for use when user program mode is not available, such as the first time onboard programming is performed, or if the program activated in user program mode is accidentally erased.

#### 12.5.1 Boot Mode

When the mode pins are set for Modes 6 or 7 and a reset-start is executed, the AX07CF192 enters the Boot Mode programming state in which on-chip flash memory programming, erasing, verifying can be carried out. There are two operating modes in this mode – mode 6 is extended mode, mode 7 is one-chip microcontroller mode.

This device has an Internal ROM area for booting. This ROM area is located at 0x00000000, when SBM (Serial Boot Mode) = '1' (i.e. boot mode – Mode 6 or 7), and is used for Serial Boot when device is reset.

If boot mode is used, a flash memory programming control program must be prepared beforehand in the host, and UART channel 0 is used to download it.

When a reset-start is executed after setting the AX07CF192 to mode 6 or mode 7, the boot program is activated – the bit rate register value is set to 38400 bps (for a 33.86MHz clock), then the on-chip UART receives the user program (flash memory programming control program) from off-chip. The received user program is written into RAM (0x08030000~0x08030FFF).

**Figure 12.2** shows a system configuration diagram when using mode 6 or mode 7, and **Figure 12.3** show the boot program mode execution procedure.



Figure 12.2 System Configuration When Using On-Board Boot Mode





Figure 12.3 Boot Mode Execution Procedure

When boot mode is initiated, the AX07CF192 measures the low period of the asynchronous communication data transmitted continuously from the host. The UART transmit/receive format should be set as 8-bit data, 1 stop bit, no parity. To ensure correct UART operation, the host's transfer bit rate should be set to 38400 bps, and the operating frequency for this process should be 33.86MHz.



# **Application example (Boot Mode)**

#### 1. Download Application Program



Step 1. Set Serial Boot Mode to '1'
(the flash download algorithm program should be prepared in the host beforehand)

Step 2. Reset system

Step 3. ARM runs the Boot Program in internal ROM.

Step 4. Boot program receives flash download algorithm program through UART from Host.

Step 5. Store the flash download algorithm program into the internal SRAM.

#### 2. Run Downloaded Application Program



- Step 6. ARM branches to the start address of the flash download algorithm program.
- Step 7. The algorithm program gets flash ROM code from host through UART and executes flash ROM Write operation with the code.
- Step 8. End the flash ROM Write operation and Host changes system mode to Normal.

Step 9. Reset

Step 10. ARM Executes the New Program in the flash ROM.



#### 12.5.2 User Program Mode

When set to user program mode, the AX07CF192 can program and erase its flash memory by executing a user program/erase control program. Therefore, on-board reprogramming of the on-chip flash memory can be carried out by providing programming data and a program/erase control program in the host, and storing a transfer program for the program/erase control program in an on-chip flash memory area beforehand.

To select user program mode, select a mode that enables the on-chip flash memory (mode 4 or 5). Mode 4 is extended mode, and mode5 is one-chip micro-controller mode. The flash memory itself cannot be read while being programmed or erased, so the control program that performs program/erase should transferred from external memory to RAM and executed in RAM. *Figure 12.4* shows the execution procedure when user program mode is entered during program execution in RAM.



Figure 12.4 User Mode Execution Procedure



# **Application example (User Program Mode)**

#### 1. Download Application Program



Step 1. Set Serial Boot Mode to '1' Boot mode (mode 4 or 5)

Step 2. Reset system

Step 3. ARM runs Transfer Program in the flash memory, and transfers the program/erase control program to internal SRAM.

#### 2. Run Downloaded Application Program



- Step 4. ARM branches to the start address of the Program/erase control program in SRAM
- Step 5. If flash memory has been previously programmed, the Program/erase control program erases flash memory in block units
- Step 6. Program/erase control program gets user application program from host, through UART, and executes flash memory program operation to store the user application in flash memory
- Step 7. End the flash memory program operation and Host changes system mode to Normal.
- Step 8. Reset
- Step 9. ARM Executes New Program in the flash ROM.



## 12.6 Flash Memory Programming/Erasing

A software method, using the CPU, is employed to program and erase flash memory in the on-board programming modes. There are five flash memory operation modes: pre-program/program mode, post-program mode, erase mode, pre-program/program-verify mode, and erase verify mode. The transitions to these modes are made by setting CONTREG register.

The flash memory cannot be read while being programmed or erased. Therefore, the program (user program) that controls flash memory program/erase should be located and executed in on-chip RAM or external memory.

#### 12.6.1 Program & Program-Verify Mode

When writing data or programs to flash memory, the program flowchart shown in *Figure 12.5* should be followed. Flash Memory of AX07CF192 can be programmed 16bits at one time. In Program Verify, the data written in program mode is read to check whether it has been correctly written in the flash memory. If the result of a verify read at a certain address is not same as the programmed data for this address, the program must be retried until the Verify read result and the programmed data are matched.





Figure 12.5 Flash Program & Program Verify Sequence



AX07CF192

#### 12.6.2 Pre-program & Pre-program Verify Mode

This is the first step of the flash memory erase algorithm. Pre-program & Pre-program Verify must be done before block erase.

The difference between Program and Pre-program is that the purpose of Pre-program is to set any un-programmed cells in a block that is to be erased to a logic 0, to prevent overerasing during the erase process.

(Note: After an erase all cells are at a logic 1 level – referred to as 'unprogrammed'. Subsequently, when writing data to flash memory, only those bits desired to be at logic 0 are actually (electrically) programmed. Logic 1 bits are electrically left in their original state – i.e un-programmed)

When in Pre-program mode, the program address must start at the first address of the block to be erased, and increase by 2 to the last address of that block.

The relationship between each erase block and the corresponding flash memory address is shown in *Table 12.5* of chapter 12.3.

Pre-program needs to be followed by a pre-program verify read to ensure that every cell in the block was programmed successfully.

The CONTREG settings are the same as program & program verify mode.

The Flow of pre-program and pre-program verify is shown in Figure 12.6





Figure 12.6 Flash Pre-program & Pre-program Verify Sequence



AX07CF192

164

#### 12.6.3 Erase & Erase Verify Mode

Flash memory erase operations are performed block by block. To erase flash memory, sett the flash memory area to be erased in the erase block register (EBR). If multiple bits of the EBR register are set, multiple block are erased at the same time. The maximum number of blocks that can be erased at one time is four. After Erase, it is necessary to do an Erase verify read to ensure that every cell in the block was erased successively. When in Erase verify read mode, the verify address must start at first address of block to be erased, and increase by 2 to the last address of that block. The relationship between each erase block and the corresponding flash memory address is shown at the **Table 12.5** of chapter 12.3. If the result of verify read at a certain address is not 0xFFFF, the erase must be retried until the result of Verify read is 0xFFFF.

The Flow of erase & erase verify is shown at Figure 12.7.





Figure 12.7 Flash Erase & Erase Verify Sequence



#### 12.6.4 Erase Algorithm

When erasing flash memory, the sequence of *Figure 12.8* should be followed. It is composed of pre-program & pre-program verify, erase & erase-verify and post-program to prevent all cells in the erased block from being over-erased.



Figure 12.8 Flash Erase Algorithm



# 12.7 Flash Memory PROM Mode

The AX07CF192 has a PROM mode as well as the on-board programming modes for programming and erasing flash memory. In PROM mode, the on-chip flash memory can be programmed using a 7092 PROM writer.

#### 12.7.1 PROM Mode Setting

By setting FR\_SEL, the internal registers of flash memory are directly written or read through FD[15:0] as shown in *Table 12.7*. When the value of FR\_SEL[2:0] is set and FWEB = rising-edge, FD[15:0] signals are passed into the register selected by FR\_SEL. When the value of FR\_SEL[2:0] is set and FOEB is low, the register's value is read through FD[15:0].

Table 12.8 shows how the different external pins are set to write and read internal registers.

Table 12.7 FR\_SEL Value for access to internal Register

| FR_SEL[2:0] | Register Read | Register Write   |
|-------------|---------------|------------------|
| 000         | Read Data     | Reserved         |
| 001         | ADDREG        | ADDREG & DATAREG |
| 010         | DATAREG       | Reserved         |
| 011         | CONTREG       | CONTREG          |
| 100         | EBR           | EBR              |
| 101         | STATPWR[8:0]  | STATPWR[5:0]     |

Table 12.8 Settings for Register read/write

| Register | Pin Name |      |             |      |                   |               |  |  |  |  |  |
|----------|----------|------|-------------|------|-------------------|---------------|--|--|--|--|--|
| Mode     | FRSTB    | FCEB | FWEB        | FOEB | FD[15:0]          | FA[16:0]      |  |  |  |  |  |
| Read     | High     | Low  | High        | Low  | Read value output | Address input |  |  |  |  |  |
| Write    | High     | Low  | Rising edge | High | Write Value input | Address input |  |  |  |  |  |



#### 12.7.2 Memory Map

The memory map for PROM mode is shown in *Table 12.9* 

In PROM mode, the on-chip flash appears as 96K x 16 memory. Therefore, in order to access each 16 bits of data sequentially the address should be incremented by '1' (not by '2') each time. The Erase operation is performed sector by sector, with the corresponding addresses shown in *Table 12.9*.

Table 12.9 Erase Block Register

| Sector # | Sector Size   | FA [16:0]         |  |  |  |
|----------|---------------|-------------------|--|--|--|
| Sector 0 | 8KB (4K-word) | 0x00000 ~ 0x00FFF |  |  |  |
| Sector 1 | 8KB           | 0x01000 ~ 0x01FFF |  |  |  |
| Sector 2 | 24KB          | 0x02000 ~ 0x04FFF |  |  |  |
| Sector 3 | 24KB          | 0x05000 ~ 0x07FFF |  |  |  |
| Sector 4 | 32KB          | 0x08000 ~ 0x0BFFF |  |  |  |
| Sector 5 | 32KB          | 0x0C000 ~ 0x0FFFF |  |  |  |
| Sector 6 | 32KB          | 0x10000 ~ 0x13FFF |  |  |  |
| Sector 7 | 32KB          | 0x14000 ~ 0x17FFF |  |  |  |

#### 12.7.3 PROM Mode Operation

Each flash memory operation, such as program, erase or read, is made by writing and reading the flash memory internal register. *Table 12.10* shows various flash memory operations and the register read/write sequence for each. For every operation except for memory normal read and erase, the 1st and 2nd cycles determine which operation will be performed, and 3rd cycle sets the flash memory address to be programmed or verified. Therefore, only the 3rd cycle needs to be repeated if subsequent flash memory address es are programmed or verified. During the Erase operation, the 2nd and 3rd cycles have to be repeated.

For Verify read operation (Pre-Program/program Verify and erase verify), it is necessary to execute a normal memory read operation after the 3rd cycle in order to obtain the result of verify read.



Table 12.10 Settings for Flash PROM read/write

|                         |        | 1st Cycle | )       | 2      | 2nd Cycle | 9       | 3rd Cycle |      |         |  |
|-------------------------|--------|-----------|---------|--------|-----------|---------|-----------|------|---------|--|
| Operation               | FR_SEL | Mode      | Address | FR_SEL | Mode      | Address | FR_SEL    | Mode | Address |  |
|                         |        |           | Data    |        |           | Data    |           |      | Data    |  |
| Memory                  | 000    | R         | RA      |        |           |         |           |      |         |  |
| Normal Read             |        |           | Dout    |        |           |         |           |      |         |  |
| Memory                  | 011    | W         | Х       | 011    | W         | -       | 001       | W    | WA      |  |
| Program<br>/Pre-program |        |           | 0x0001  |        |           | 0x0005  |           |      | Din     |  |
| Memory                  | 011    | W         | -       | 011    | W         | W -     |           | W    | WA      |  |
| Post-program            |        |           | 0x0001  |        |           | 0x0041  |           |      | Din     |  |
| Memory                  | 011    | W         | Х       | 100    | W -       |         | 011       | W    | -       |  |
| Erase                   |        |           | 0x0002  |        |           | BN      |           |      | 0X000A  |  |
| Program/Pre-            | 101    | W         | -       | 011    | - W       |         | 001       | W    | RA      |  |
| program<br>verify       |        |           | 0x0001  |        |           | 0X0010  |           |      | -       |  |
| Erase Verify            | 101    | W         | -       | 011    | W         | -       | 001       | W    | RA      |  |
| read                    |        |           | 0x0000  |        |           | 0x0020  |           |      | -       |  |

\*RA: Read Address WA: Write address Dout: Read data Din: Program data -: don't care R: Read W: Write BN: Erase Block Number(see *Table 12.6*)



AX07CF192 170

# 12.7.4 Timing Diagram and AC/DC Characteristics

This timing diagram follows the sequence that is shown on *Table 12.11*.



Figure 12.9 Timing Diagram of Read





Figure 12.10 Timing Diagram of Pre-Program/Program



Figure 12.10 Erase Time Diagram





Figure 12.12 Timing Diagram of Pre-Program/Program Verify



Figure 12.13 Timing Diagram of Erase Verify



Table 12.11 DC Characteristics

 $(V_{DD} = 3.3V \pm 10\%, Vss = 0V, FTVPPD = 5V \pm 10\%, Ta = 25 °C \pm 10\%)$ 

|                    | ltem         | Symbol | Min                  | Тур | Max                  | Unit | Test<br>Condition |
|--------------------|--------------|--------|----------------------|-----|----------------------|------|-------------------|
| Input h            | nigh voltage | Vih    | 0.7x V <sub>DD</sub> |     | V <sub>DD</sub> +0.5 | V    |                   |
| Input I            | ow voltage   | Vil    | -0.5                 |     | 0.3x V <sub>DD</sub> | V    |                   |
| Output             | high voltage | Voh    | 2.4                  |     |                      | V    | Ioh=0.8mA         |
| Output             | low voltage  | Vol    |                      |     | 0.4                  | V    | Iol=0.8mA         |
| Vcc                | Reading      | ldd    |                      | 20  | 40                   | mΑ   |                   |
| current            | Programming  | ldd    | -                    | 40  | 80                   | mΑ   |                   |
|                    | Erasing      | ldd    | -                    | 25  | 50                   | mΑ   |                   |
| FXTVPPD<br>Current | Programming  | lppd   |                      | 10  | 20                   | mA   |                   |

Table 12.12 AC Characteristics

 $(V_{DD} = 3.3V \pm 10\%, Vss = 0V, FXTVPPD = 5V \pm 10\%, Ta = 25 \degree C \pm 10\%)$ 

|                                 |        |     |     | ,   |      |
|---------------------------------|--------|-----|-----|-----|------|
| Item                            | Symbol | Min | Тур | Max | Unit |
| CEB output delay time           | TCEB   |     | 70  | 90  | ns   |
| OEB output delay time           | TOEB   |     | 5   | 10  | ns   |
| Output disable delay time       | TOEBH  | 1   | 2   |     | ns   |
| R_SEL output delay time         | TR_SEL |     | 1   | 2   | ns   |
| Access time                     | TACC   |     | 70  | 90  | ns   |
| Reset Pulse Width               | Trst   | 300 | 500 |     | us   |
| Power up time                   | Tpup   | 8   | 10  |     | us   |
| Discharge time(Program, Verify) | Tpdw   | 1   | 10  |     | us   |
| Discharge time(Erase)           |        | 10  | 20  |     | us   |
| Program time                    | Tpgm   | 30  | 30  |     | us   |
| CEB Setup time                  | Tces   | 100 | 200 |     | us   |
| WEB Pulse Width                 | Twep   | 100 | 200 |     | ns   |
| WEB rise time                   | Tr     |     | 20  | 30  | ns   |
| WEB fall time                   | Tf     |     | 20  | 30  | ns   |
| Data Setup time                 | Tds    | 50  | 150 |     | ns   |
| Data Hold time                  | Tdh    | 50  | 80  |     | ns   |
| Erase time                      | Tera   | 1   | 2   | 2   | ms   |
| Verify Setup time               | Tvfy   | 8   | 10  |     | us   |
| Verify data out time            | Tdout  | 2   | 2   |     | us   |



# Chapter 13 **A/D Converter**



#### 13.1 Overview

The AX07CF192 has a 10-bit successive-approximation A/D converter with five analog input channels. The input channels are multiplexed into the converter. The serial output is configured to interface with standard shift registers. The differential analog voltage input allows for common-mode rejection or offset of the analog zero input voltage value. The voltage reference input can be adjusted to effectively scale the input voltage span while retaining the full 10bits of resolution.

#### 13.1.1 Features

A/D converter features are listed below.

- 10-bit resolution
- 5 input channels
- Selectable analog conversion voltage range:
   The analog voltage conversion range can be programmed by input of an analog reference voltage at the V<sub>REF</sub> pin.
  - High-speed conversion: minimum 2us per channel (with 8MHz ADC clock)
    Analog input range: GND to AVREF
- Five 10-bit data registers
- A/D conversion results are transferred for storage into data registers corresponding to the channels.
- Sample-and-hold function
- A/D interrupt requested at end of conversion:
   At the end of A/D conversions, an A/D End Interrupt (ADI) can be requested.



Figure 13.1 Block Diagram of A/D Converter



# 13.1.2 Pin Configuration

**Table 13.1** summarizes the A/D converter's input pins.  $AV_{DD}$  and  $AV_{SS}$  are the power supply for the analog circuits in the A/D converter.  $V_{REF}$  is the A/D conversion reference voltage.

Table 13.1 A/D Converter Pins

| Pin Name                 | 1/0   | Function                 |
|--------------------------|-------|--------------------------|
| AV <sub>DD</sub>         | Input | Analog power supply      |
| AV <sub>SS</sub>         | Input | Analog ground            |
| <b>AV</b> <sub>REF</sub> | Input | Analog reference voltage |
| AN <sub>0</sub>          | Input | Analog input channel 0   |
| AN <sub>1</sub>          | Input | Analog input channel 1   |
| AN <sub>2</sub>          | Input | Analog input channel 2   |
| AN <sub>3</sub>          | Input | Analog input channel 3   |
| AN <sub>4</sub>          | Input | Analog input channel 4   |



## 13.2 A/D Converter Registers

The registers used to control the A/D converter when enabled are shown in *Table 13.2*. The base address of the A/D converter is **0x0900\_1700**.

Table 13.2 Summarizes the A/D converter's registers.

| Reg.Name | I/O<br>Offset | R/W | Name                      | Initial Value |  |  |  |  |  |  |  |
|----------|---------------|-----|---------------------------|---------------|--|--|--|--|--|--|--|
| ADCSR    | 0x1700        | R/W | Control & Status Register | 0x00          |  |  |  |  |  |  |  |
| ADCCR    | 0x1704        | R/W | Control Register          | 0x1           |  |  |  |  |  |  |  |
| ADDR0    | 0x1708        | R   | Data Register 0           | 0x0000        |  |  |  |  |  |  |  |
| ADDR1    | 0x170C        | R   | Data Register 1           | 0x0000        |  |  |  |  |  |  |  |
| ADDR2    | 0x1710        | R   | Data Register 2           | 0x0000        |  |  |  |  |  |  |  |
| ADDR3    | 0x1714        | R   | Data Register 3           | 0x0000        |  |  |  |  |  |  |  |
| ADDR4    | 0x1718        | R   | Data Register 4           | 0x0000        |  |  |  |  |  |  |  |

#### 13.2.1 Register Descriptions

#### ADCSR AD Control & Status Register (0x0900\_1700 R/W)

| Bit        | b7                          | b7 b6 b5          |      | b5 b4 b3 |     | b2 b1 b0 |     |     |  |  |
|------------|-----------------------------|-------------------|------|----------|-----|----------|-----|-----|--|--|
| ADCSR      | ADF                         | ADST              | ADIE | AC       | KS  | ACHS     | CHS |     |  |  |
| Init. Val. | 0                           | 0                 | 0    | 0        | 0 0 |          | 0   | 0   |  |  |
| RD/WR      | <sub>R/W</sub><br>Initial V | R/W<br>alue: 0x00 | R/W  | R/W      | R/W | R/W      | R/W | R/W |  |  |

**ACHS** Channel select (Select the analog input channel)

000: Analog input channel 0 001: Analog input channel 1 010: Analog input channel 2 011: Analog input channel 3 100: Analog input channel 4

**ACKS** Clock select (Select the A/D conversion time)

00 : 1/8 times the ADC input clock (ADCLK) 01 : 1/4 times the ADC input clock (ADCLK) 10 : 1/2 times the ADC input clock (ADCLK) 11 : ADC input clock is from the timer block

**ADIE** A/D interrupt enable (Enables and disables A/D conversion)

0 : A/D end interrupt request (INT\_ADC) is disabled. 1 : A/D end interrupt request (INT\_ADC) is enabled.

ADST A/D start (Starts or stops A/D conversion)

0: A/D conversion is stopped

1 : A/D conversion start; ADST is automatically cleared to 0 when conversion ends.



ADF A/D end flag (Indicates end of A/D conversion)
0 : [Clearing condition] Read when ADF=1,
then write 0 in ADF.
1 : [Setting condition] Automatically set when
conversion end

ADCSR is the control and status register for the A/D converter. ACH[2:0] is used for selection of the analog input channel. CKS[1:0] is used for selection of the A/D converter input clock. When these signals are '00', the main clock for the A/D converter is 1/8 times the input clock (ADCLK), which is the same as the system operation clock.. When these signals are '01', then the main clock for the A/D converter is 1/4 ADCLK. When these signals are '10', then the main clock for the A/D converter is 1/2 ADCLK. When these signals are '11', then the main clock for the A/D converter is the external clock from the Timer block. The ADIE bit is the interrupt enable control signal. When this signal is '0', the A/D converter does not generate an interrupt at the end of an A/D conversion. When this signal is '1', the A/D converter generates an end of conversion interrupt. The ADST bit indicates the start of A/D conversion. When this signal is '1', the A/D converter starts an A/D conversion and the bit remains high during the conversion. ADF indicates the end of conversion. When this bit is '1', the A/D converter indicates the conversion is complete. This signal is auto-cleared by reading this bit.

#### **ADCCR**

#### AD Control Register (0X0900\_1704 R/W)

| Bit        | b15-b2                               | b1     | b0      |
|------------|--------------------------------------|--------|---------|
| ADCCR      | Reserved                             | CALEND | AIOSTOP |
| Init. Val. |                                      | 0      | 1       |
| RD/WR      |                                      | R      | R/W     |
|            | Initial value: 0x01 bit field: I0-I1 |        |         |

**CALEND** Calibration end (Indicates end of calibration time)

0 : Indicates calibration incomplete.1 : Indicates the end of calibration.

#### **AIOSTOP** Power save mode

0 : A/D converter is in normal operation mode

1 : A/D converter is in power save mode, not operating

CALEND indicates the end of calibration time (T<sub>cal</sub>). This signal is read only. AIOSTOP is used to set the power save mode of the A/D converter. When this signal is '0', the A/D converter will entering normal operation mode after the calibration time, or power up time. See *Figure 13.2 A/D converter operation* for detailed timing diagram.



# ADDR0~4 A/D Data Register 0 to 4 (0x0900\_1708 ~ 0x0900\_1718 R)

| Bit                   | b15 | b14 | b13 | b12 | b11 | b10 | b9        | b8       | b7  | b6  | b5  | b4  | b3  | B2  | b1  | b0  |
|-----------------------|-----|-----|-----|-----|-----|-----|-----------|----------|-----|-----|-----|-----|-----|-----|-----|-----|
|                       | AD9 | AD8 | AD7 | AD6 | AD5 | AD4 | AD3       | AD2      | AD1 | AD0 | Rev | Rev | Rev | Rev | Rev | Rev |
| Init. Val.            | 0   | 0   | 0   | 0   | 0   | 0   | 0         | 0        | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| RD/WR                 | R   | R   | R   | R   | R   | R   | R         | R        | R   | R   | R   | R   | R   | R   | R   | R   |
| Initial value: 0x0000 |     |     |     |     |     | k   | oit field | d: 16-11 | 5   |     |     |     |     |     |     |     |

AD[9:0] A/D conversion data (10-bit giving an A/D conversion result)

Rev Reserved bit



## 13.3 Operation

The A/D converter operates by successive approximation with 10-bit resolution. *Figure 13.2* show the operation of A/D converter.



Figure 13.2 A/D converter Operation



### 13.4 Interrupts

The A/D converter generates an interrupt (INT\_ADC) at the end of A/D conversion. The INT\_ADC interrupt request can be enabled or disabled by the ADIE bit in ADCSR.

#### 13.5 Usage Notes

When using the A/D converter, note the following points:

- 1. Analog Input Voltage Range: During A/D conversion, the voltages input to the analog input pins  $AN_n$  should be in the range  $AV_{ss} \le AN_n \le V_{REF}$ .
- 2. Relationships of AV $_{CC}$  and AV $_{SS}$  to V $_{CC}$  and V $_{SS}$ : AV $_{CC}$ , AV $_{SS}$ , V $_{CC}$ , and V $_{SS}$  should be related as follows: AV $_{SS}$  = V $_{SS}$ . AV $_{CC}$  and AV $_{SS}$  must not be left open, even if the A/D converter is not used.
- 3.  $V_{REF}$  Programming Range: The reference voltage input at the  $V_{REF}$  pin should be in the range  $V_{REF} \le AV_{CC}$ .

Note on Board Design: In board layout, separate the digital circuits from the analog circuits as much as possible. Particularly avoid layouts in which the signal lines of digital circuits cross or closely approach the signal lines of analog circuits. Induction and other effects may cause the analog circuits to operate incorrectly, or may adversely affect the accuracy of A/D conversion. The analog input signals (AN $_0$  to AN $_4$ ), analog reference voltage (VREF), and analog supply voltage (AV $_{\rm CC}$ ) must be separated from the digital circuitry by the analog ground (AV $_{\rm SS}$ ). The analog ground (AV $_{\rm SS}$ ) should be connected to a stable digital ground (VS $_{\rm SS}$ ) at one point on the board.

Note on Noise: To prevent damage from surges and other abnormal voltages at the analog input pins (AN $_0$  to AN $_4$ ) and analog reference voltage pin (V<sub>REF</sub>), connect a protection circuit like the one in *Figure 13.3* between AV $_{CC}$  and AV $_{SS}$ . The bypass capacitors connected to AV $_{CC}$  and V<sub>REF</sub> and the filter capacitors connected to AN $_0$  to AN $_4$  must be connected to AV $_{SS}$ .

 A/D Conversion Accuracy Definitions: A/D conversion accuracy in the AX07CF192 is defined as follows:

• Resolution: Digital output code length of A/D converter

• Offset error: Deviation from ideal A/D conversion characteristic of analog input

voltage required to raise digital output from minimum voltage value

0000000000 to 0000000001 (figure 13.4)

• Full-scale error: Deviation from ideal A.D conversion characteristic of analog input

voltage required to raise digital output from 1111111110 to

1111111111 (figure 13.4)

• Quantization error: Intrinsic error of the A/D converter;1/2 LSB (figure 13.5)

• Nonlinearity error: Deviation from ideal A/D conversion characteristic in range from

zero volts to full scale, exclusive of offset error, full-scale error, and

quantization error.

• Absolute accuracy: Deviation of digital value from analog input value, including offset

error, full-scale error, quantization error, and nonlinearity error.





Figure 13.3 Example of Analog Input Circuit



Figure 13.4 A/D Converter Accuracy Definitions (1)





Figure 13.5 A/D Converter Accuracy Definitions (2)

7. Effect on Absolute Accuracy: Attaching an external capacitor creates a coupling with ground, so if there is noise on the ground line, it may degrade absolute accuracy. The capacitor must be connected to an electrically stable ground, such as AVSS.

If a filter circuit is used, be careful of interference with digital signals on the same board, and make sure the circuit does not act as an antenna.



# 13.6 Example

|          | AREA<br>ENTRY                                 | ADDONE, CODE, READO                                                                                            | NLY                                                                                                                           |
|----------|-----------------------------------------------|----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
|          | ldr<br>add<br>mov<br>str                      | r0, =ADC_base<br>r0, r0, #ADCCR<br>r1, #0<br>r1, [r0]                                                          | ; Make <b>AOPSTOP</b> to <b>LOW</b> to release power down mode, ; then set normal operation mode.                             |
|          | loop<br>ldr<br>cmp<br>bne                     | r2, [r0]<br>r2, #2<br>loop                                                                                     | ; Check whether <b>CALEND</b> is set to 1 or not. ; (Check it's in the range of calibration time)                             |
|          | ldr<br>add<br>mov<br>str                      | r0, =ADC_base<br>r0, r0, #ADCSR<br>r1, #0x40<br>r1, [r0]                                                       | ; Set the control bit in ADCSR register<br>; <b>AD conversion start</b> , CKS=1/8 ADCLK, ACH=0ch<br>;(set ADST, CKS=0, ACH=0) |
| loop_adf | adr<br>and<br>cmp<br>bne<br>ldr<br>and<br>str | r2, [r0]<br>r2, r2, #0x80<br>r2, #0x80<br>loop_adf<br>r1, [r0]<br>r1, r1, #0x7f ; Clear <b>ADF</b><br>r1, [r0] | ;check ADF (AD conversion END) to 0                                                                                           |
|          | ldr<br>add<br>ldr                             | r0, =ADC_base<br>r0, r0, #ADDR0<br>r1, [r0]                                                                    | ;read ADDR0 register into R1 register                                                                                         |
|          | END                                           |                                                                                                                |                                                                                                                               |



# Chapter 14 **Electrical Characteristics**



AX07CF192 186

# 14.1 Absolute Maximum Ratings

Table 14.1 lists the absolute maximum ratings(Note1 and 2).

Table 14.1 Absolute Maximum Ratings

| Item                                            | Symbol           | Value                          |
|-------------------------------------------------|------------------|--------------------------------|
| Power supply voltage                            | $V_{DD}$         | -0.5V to 4.6V                  |
| DC Input Voltage (except I/O pins)              | $V_{IN}$         | -0.5V to 6.0V                  |
| DC Output Voltage (Output in high or low state) | V <sub>OUT</sub> | -0.5V to V <sub>DD</sub> +0.5V |
| DC Output Voltage (Output in 3-state)           | V <sub>OUT</sub> | -0.5V to +6.0V                 |
| Reference Voltage                               | $V_{REF}$        | -0.3V to AV <sub>DD</sub> +0.3 |
| Analog Power supply voltage                     | AVcc             | -0.3V to 3.6V                  |
| Analog Input Voltage                            | $V_{AN}$         | -0.3V to AV <sub>DD</sub> +0.3 |
| Storage Temperature range                       | Ts               | -65 to +150 °C                 |

**Note1:** Absolute maximum continuous ratings are those values which damage to the device may occur. Exposure to these conditions or conditions beyond those indicated may adversely affect device reliability. Functional operation under absolute-maximum-rated conditions is not implied.

**Note2:** Under transient conditions these ratings may be exceeded as elsewhere in this specification.

#### 14.2 Recommended Operating Conditions:

Table 14.2 lists the recommended operating conditions.

Table 14.2 Recommended Operating Conditions

| Symbol           | Parameter                       | MIN | MAX      | UNIT |
|------------------|---------------------------------|-----|----------|------|
| $V_{DD}$         | Supply voltage                  | 3.0 | 3.6      | V    |
| V <sub>IN</sub>  | Input voltage                   | 0   | 5.5      | V    |
| Vout             | Output voltage outputs active   | 0   | $V_{DD}$ | V    |
| Vout             | Output voltage outputs disabled | 0   | 5.5      | V    |
| V <sub>PPD</sub> | Flash program/erase voltage     | 4.5 | 5.5      | V    |
| T <sub>A</sub>   | Operating free-air temperature  | -40 | 85       | °C   |



#### 14.3 DC Characteristics

Table 14.3 lists the DC characteristics.

Table 14.3 DC Characteristics

| ITEM                             | SYM<br>BOL      | MIN          | MAX           | UNIT | TEST Conditions                     |
|----------------------------------|-----------------|--------------|---------------|------|-------------------------------------|
| Input Low Voltage                | VIL             | -0.5         | $0.3XV_{DD}$  | V    | VDD=3.0V to 3.6V                    |
| Input High Voltage               | V <sub>IH</sub> | $0.7XV_{DD}$ | $V_{DD}$ +0.5 | V    | VDD=3.0V to 3.6V                    |
| Output Low Voltage               | V <sub>OL</sub> | -            | 0.4           | V    | VDD=3.0V<br>I <sub>OL</sub> =0.8mA  |
| Output High<br>Voltage           | V <sub>OH</sub> | 2.4          | -             | V    | VDD=3.0V<br>I <sub>OH</sub> =-0.8mA |
| Input current at maximum voltage | lı              | -            | 1             | mA   | VDD=3.0V to 3.6V<br>Input=5.5V      |

Table 14.4 lists the IO circuit with pull-ups

Table 14.4 IO Circuits with pull-ups

|                       | Min Current(at PAD = 0V) | Max Current (at PAD = 0V) |
|-----------------------|--------------------------|---------------------------|
| 3.3V Pull-up          | 30uA                     | -146uA                    |
| Equivalent resistance | 88.3kOhms                | 24.7kOhms                 |

Table 14.5 lists the IO circuit with pull-downs

Table 14.5 IO Circuits with pull-downs

|                       | Min Current(at PAD = 2.65V) | Max Current (at PAD = 3.6V) |
|-----------------------|-----------------------------|-----------------------------|
| Pull-down             | 31uA                        | 159uA                       |
| Equivalent resistance | 85.5kOhms                   | 22.6kOhms                   |



#### 14.4 AC Characteristics

Timing measurement conditions is following that unless otherwise specified:

**VDD: 3.3V** 

Junction Temperature: 25 °C

**Process: Typical** 

Low-voltage input signal rising and falling edges switching time: 0.3ns

Clock timing parameters are listed in *Table 14.6*, control signal timing parameters in *Table 14.7*, and bus timing parameters in *Table 14.8*.

Table 14.6 Clock Timing

| Item                   | Symbol           | Min. | Max. | Units | Test<br>Conditions |
|------------------------|------------------|------|------|-------|--------------------|
| Clock cycle time       | t <sub>CYC</sub> | 20   | 1000 | ns    | Figure 14.3        |
| Clock pulse low width  | t <sub>CL</sub>  | 10   | -    | ns    |                    |
| Clock pulse high width | t <sub>CH</sub>  | 10   | -    | ns    |                    |
| Clock rise time        | t <sub>Cr</sub>  | -    | 10   | ns    |                    |
| Clock fall time        | t <sub>Cf</sub>  | -    | 10   | ns    |                    |
| Clock oscillator       | tosc1            | 20   | -    | ms    | Figure 14.1        |
| Settling time at reset |                  |      |      |       |                    |

Table 14.7 Control Signal Timing

| Tubic i iii Condici | Table 1 III Cond of Cignal 1 IIIIII |      |      |       |                    |  |  |
|---------------------|-------------------------------------|------|------|-------|--------------------|--|--|
| Item                | Symbol                              | Min. | Max. | Units | Test<br>Conditions |  |  |
| nRES setup time     | t <sub>RESS</sub>                   | 200  | -    | ns    | Figure 14.2        |  |  |
| nRES pulse width    | t <sub>RESW</sub>                   | 5    | -    | tcyc  |                    |  |  |
| Mode programming    | t <sub>MDS</sub>                    | 200  | -    | ns    |                    |  |  |
| setup time          |                                     |      |      |       |                    |  |  |



Table 14.8 Bus Timing

| units: |  |
|--------|--|
|        |  |

| Table 14.8 Bus Timing      |                    |      |      | (units: ns)        |
|----------------------------|--------------------|------|------|--------------------|
| Item                       | Symbol             | Min. | Max. | Test<br>Conditions |
| Address delay time         | t <sub>AD</sub>    | -    | 20   | Figure 14.3        |
| Address hold time          | t <sub>AH</sub>    | 0    | -    | Figure 14.4        |
| Read strobe delay time     | t <sub>RSD</sub>   | -    | 20   |                    |
| Address strobe delay time  | t <sub>ASD</sub>   | -    | 20   |                    |
| Write strobe delay time    | t <sub>WSD</sub>   | -    | 20   |                    |
| Strobe delay time          | t <sub>SD</sub>    | -    | 20   |                    |
| Write strobe pulse width 1 | t <sub>WSW1</sub>  | 20   | -    |                    |
| Address setup time 1       | t <sub>AS1</sub>   | 10   | -    | 1                  |
| Read data setup time       | t <sub>RDS</sub>   | 20   | -    | =                  |
| Read data hold time        | t <sub>RDH</sub>   | 0    | -    |                    |
| Write data delay time      | t <sub>WDD</sub>   | -    | 20   |                    |
| Write data setup time 1    | t <sub>WDS1</sub>  | 10   | -    |                    |
| Write data hold time       | t <sub>WDH</sub>   | 0    | -    |                    |
| Read data access time 1    | t <sub>ACC1</sub>  | -    | 40   |                    |
| Read data access time 3    | t <sub>ACC3</sub>  | -    | 40   |                    |
| Precharge time 1           | t <sub>PCH1</sub>  | 20   | -    | Figure 14.5        |
| Precharge time 2           | t <sub>PCH2</sub>  | 0    | -    |                    |
| Wait setup time            | t <sub>WTS</sub>   | 20   | -    |                    |
| Wait hold time             | t <sub>WTH</sub>   | 5    | -    |                    |
| Bus request setup time     | t <sub>BRQS</sub>  | 20   | -    | Figure 14.6        |
| Bus acknowledge time 1     | t <sub>BACD1</sub> | -    | 30   |                    |
| Bus acknowledge time 2     | t <sub>BACD2</sub> | -    | 30   |                    |
| Bus-floating time          | t <sub>BZD</sub>   | -    | 30   |                    |



#### 14.4 AD Conversion characteristics (Preliminary)

Table 14.9 lists the operation conditions of the AD Conversion

Table 14.9 Operating Conditions of the AD Conversion

| Parameter         | Symbol           | Min.    | Max.      | Units |
|-------------------|------------------|---------|-----------|-------|
| Power Supply      | AVDD             | 3.0     | 3.6       | V     |
| Analog Input      | AN               | GND+0.2 | AVREF-0.2 | V     |
| Clock Pulse Width | T <sub>PWL</sub> | 62.5    |           | ns    |
| Operating         | T <sub>OP</sub>  | -40     | 85        | °C    |
| Temperature       |                  |         |           |       |

Table 14.10 lists the electrical characteristics of the AD converter

Table 14.10 Electrical characteristics of the AD converter

Conditions : Analog input frequency F<sub>IN</sub>=1.26KHz, ADCLK=7.5MHz, AV<sub>DD</sub>=DV<sub>DD</sub>=AV<sub>REF</sub>=3.3V T=25 °C

| Symbol            | Parameter                           | Conditions                                                                   | Min.        | Тур. | Max.                      | Units |
|-------------------|-------------------------------------|------------------------------------------------------------------------------|-------------|------|---------------------------|-------|
| I <sub>DD</sub>   | Normal                              | ADCLK=7.5MHz<br>Input=AV <sub>REF</sub><br>F <sub>IN</sub> =1.26KHz ramp     |             |      | 2.0                       | mA    |
|                   | Power Down                          | ADCLK=7.5MHz                                                                 |             |      | 50                        | uA    |
| AN                | Analog input voltage                |                                                                              | GND+<br>0.2 |      | AV <sub>REF</sub><br>-0.2 | V     |
| Accuracy          | Resolution                          |                                                                              |             |      | 10                        | bits  |
| INL               | Integral Non-<br>linearity          | ADCLK=7.5MHz<br>Input=0-AVREF(V)<br>(F <sub>IN</sub> =1.26KHz)               |             |      | ±2.0                      | LSB   |
| DNL               | Differential Non-<br>linearity      | ADCLK=7.5MHz<br>Input=0-AV <sub>REF</sub><br>(F <sub>IN</sub> =1.26KHz ramp) |             |      | ±1.0                      | LSB   |
| SNR               | Signal-to-Noise<br>Ratio            | Fsample=500Ksps,<br>F <sub>IN</sub> =1.26KHz                                 | 48          | 54   |                           | dB    |
| SNDR              | Signal-to-Noise<br>Distortion Ratio |                                                                              | 45          | 54   |                           | dB    |
| ADCLK             |                                     |                                                                              | 2           | 4    | 8                         | MHz   |
| t <sub>c</sub>    | Conversion time                     |                                                                              | 2           | 4    | 8                         | us    |
| C <sub>o</sub>    | Output capacitance                  |                                                                              |             | 20   |                           | pF    |
| Rref              | Reference resistance                |                                                                              |             | 10K  |                           | 0     |
| AV <sub>REF</sub> | Analog<br>Reference<br>Voltage      |                                                                              |             |      | AV <sub>DD</sub>          | V     |
| T <sub>CAL</sub>  | Power up time                       | Calibration time                                                             |             | 22   |                           | ms    |
| THD               | Total harmonic distortion           |                                                                              | 55          | 60   |                           | dB    |
| AVDD              | Analog power                        |                                                                              | 3.0         | 3.3  | 3.6                       | V     |
| DVDD              | Digital power                       |                                                                              | 3.0         | 3.3  | 3.6                       | V     |
| F <sub>IN</sub>   | Analog input frequency              |                                                                              |             |      | 5                         | KHz   |



# 14.5 Operational Timing

#### 14.5.1 Clock Timing

Figure. 14.1 shows the settling time of the crystal oscillator.



Figure 14.1 The settling time of the crystal oscillator

#### 14.5.2 Reset Timing

Figure 14.2 show the reset input timing and reset output timing.



Figure 14.2 Reset Input Timing



#### 14.5.3 Bus Timing

Figure 14.3 and Figure 14.6 show the timing diagram of the bus controller.



Figure 14.3 The Write Timing Diagram of the Bus Controller



Figure 14.4 The Read Timing Diagram of the Bus Controller





Figure 14.5 Basic Bus Cycle with External Wait State



Figure 14.6 Bus Release Mode Timing

