



# Rabbit® 5000 Microprocessor

**User's Manual** 

019-0168\_E

## Rabbit 5000 Microprocessor User's Manual

Part Number 019-0168 • Printed in the U.S.A.

Digi International Inc. © 2013 • All rights reserved.

Digi International Inc. reserves the right to make changes and improvements to its products without providing notice.

### **Trademarks**

 $Rabbit^{\circledR} \ and \ Dynamic \ C^{\circledR} \ are \ registered \ trademarks \ of \ Digi \ International \ Inc.$   $Windows^{\circledR} \ is \ a \ registered \ trademark \ of \ Microsoft \ Corporation.$ 

The latest revision of this manual is available at www.digi.com.

# **TABLE OF CONTENTS**

| Chapter 1. The Rabbit 5000 Processor | 13  |
|--------------------------------------|-----|
| 1.1 Introduction                     | 13  |
| 1.2 Features                         |     |
| 1.3 Block Diagram                    |     |
| 1.4 Basic Specifications             |     |
| 1.5 Comparing Rabbit Microprocessors |     |
| 1.3 Companing Rabolt Microprocessors | 1 c |
| Chapter 2. Clocks                    | 21  |
| 2.1 Overview                         | 21  |
| 2.1.1 Block Diagram                  | 22  |
| 2.1.2 Registers                      |     |
| 2.2 Dependencies                     |     |
| 2.2.1 I/O Pins                       |     |
| 2.2.2 Other Registers                | 23  |
| 2.3 Operation                        |     |
| 2.3.1 Main Clock                     | 24  |
| 2.3.2 Spectrum Spreader              | 25  |
| 2.3.3 Clock Doubler                  |     |
| 2.3.4 32 kHz Clock                   |     |
| 2.4 Register Descriptions            | 32  |
|                                      |     |
| Chapter 3. Reset and Bootstrap       | 37  |
| 3.1 Overview                         | 37  |
| 3.1.1 Block Diagram                  | 38  |
| 3.1.2 Registers                      |     |
| 3.2 Dependencies                     |     |
| 3.2.1 I/O Pins                       | 39  |
| 3.2.2 Clocks                         | 39  |
| 3.2.3 Other Registers                | 39  |
| 3.2.4 Interrupts                     | 39  |
| 3.3 Operation                        |     |
| 3.3.1 Asynchronous Serial Bootstrap  |     |
| 3.3.2 Serial Flash Bootstrap         |     |
| 3.3.3 Parallel Bootstrap             | 43  |
| 3.4 Register Descriptions            | 44  |
|                                      |     |
| Chapter 4. System Management         | 45  |
| 4.1 Overview                         | 45  |
| 4.1.1 Block Diagram                  |     |
| 4.1.2 Registers                      | 47  |
| 4.2 Dependencies                     |     |
| 4.2.1 I/O Pins                       |     |
| 4.2.2 Clocks                         | 48  |
| 4.2.3 Interrupts                     | 48  |

| 4.3 Operation                             | 49 |
|-------------------------------------------|----|
| 4.3.1 Periodic Interrupt                  |    |
| 4.3.2 Real-Time Clock                     | 49 |
| 4.3.3 Watchdog Timer                      | 50 |
| 4.3.4 Secondary Watchdog Timer            | 50 |
| 4.4 Register Descriptions                 | 31 |
| Chapter 5. Memory Management              | 57 |
| 5.1 Overview                              | 57 |
| 5.1.1 Block Diagram                       | 60 |
| 5.1.2 Registers                           | 61 |
| 5.2 Dependencies                          |    |
| 5.2.1 I/O Pins                            |    |
| 5.2.2 Clocks                              |    |
| 5.2.4 Interrupts                          |    |
| 5.3 Operation                             |    |
| 5.3.1 Memory Management Unit (MMU)        |    |
| 5.3.2 Memory Bank Operation               | 64 |
| 5.3.3 Memory Modes                        |    |
| 5.3.4 Separate Instruction and Data Space | 68 |
| 5.3.5 Memory Protection                   |    |
| 5.4 Register Descriptions                 |    |
|                                           |    |
| Chapter 6. Interrupts                     | 81 |
| 6.1 Overview                              |    |
| 6.2 Operation                             |    |
| 6.3 Interrupt Tables                      |    |
| 0.5 interrupt ruotes                      |    |
| Chapter 7. External Interrupts            | 85 |
| 7.1 Overview                              |    |
| 7.1 Overview 7.2 Block Diagram            |    |
| 7.2.1 Registers                           |    |
| 7.3 Dependencies                          |    |
| 7.3.1 I/O Pins                            |    |
| 7.3.2 Clocks                              |    |
| 7.3.3 Interrupts                          |    |
| 7.4 Operation                             |    |
| 7.4.1 Example ISR                         |    |
| 7.5 Register Descriptions                 | 88 |
| Chapter 9 Parallal Part A                 | 90 |
| Chapter 8. Parallel Port A                | 89 |
| 8.1 Overview                              |    |
| 8.1.1 Block Diagram                       |    |
| 8.2 Dependencies                          |    |
| 8.2.1 I/O Pins                            |    |
| 8.2.2 Clocks                              |    |
| 8.2.3 Other Registers                     | 90 |
| 8.2.4 Interrupts                          |    |
| 8.3 Operation                             |    |
| 8.4 Register Descriptions                 | 91 |

| Chapter 9. Parallel Port B  | 93       |
|-----------------------------|----------|
| 9.1 Overview                | 93       |
| 9.1.1 Block Diagram         |          |
| 9.1.2 Registers             | 94       |
| 9.2 Dependencies            |          |
| 9.2.1 I/O Pins              | 94       |
| 9.2.2 Clocks                | 94       |
| 9.2.3 Other Registers       | 94       |
| 9.3 Operation               | 95       |
| 9.4 Register Descriptions   |          |
| Chapter 10. Parallel Port C | 97       |
| 10.1 Overview               | 97       |
| 10.1.1 Block Diagram        | 98       |
| 10.1.2 Registers            | 98       |
| 10.2 Dependencies           |          |
| 10.2.1 I/O Pins             |          |
| 10.2.2 Clocks               | 99<br>oc |
| 10.2.4 Interrupts           | 99       |
| 10.3 Operation              | 99       |
| 10.4 Register Descriptions  |          |
| Chapter 11. Parallel Port D | 105      |
| 11.1 Overview               |          |
| 11.1.1 Block Diagram        |          |
| 11.1.2 Registers            |          |
| 11.2 Dependencies           | 109      |
| 11.2.1 I/O Pins             | 109      |
| 11.2.2 Clocks               |          |
| 11.2.3 Other Registers      |          |
| 11.2.4 Interrupts           |          |
| 11.4 Register Descriptions  |          |
|                             |          |
| Chapter 12. Parallel Port E | 123      |
| 12.1 Overview               |          |
| 12.1.1 Block Diagram        |          |
| 12.1.2 Registers            |          |
| 12.2 Dependencies           |          |
| 12.2.1 I/O Pins             |          |
| 12.2.3 Other Registers      |          |
| 12.2.4 Interrupts           |          |
| 12.3 Operation              |          |
| 12.4 Register Descriptions  | 128      |
| Chapter 13. Parallel Port H | 143      |
| 13.1 Overview               | 143      |
| 13.1.1 Block Diagram        |          |
| 13.1.2 Registers            | 144      |
| 13.2 Dependencies           |          |
| 13.2.1 I/O Pins             |          |
| 13.2.2 Clocks               |          |
| 13.2.3 Other Registers      | 143      |
| 13.3 Operation              |          |

| 13.4 Register Descriptions          | 146 |
|-------------------------------------|-----|
| Chapter 14. Timer A                 | 149 |
| 14.1 Overview                       | 149 |
| 14.1.1 Block Diagram                | 151 |
| 14.1.2 Registers                    |     |
| 14.2 Dependencies                   |     |
| 14.2.1 I/O Pins                     |     |
| 14.2.2 Clocks                       |     |
| 14.2.3 Other Registers              |     |
| 14.2.4 Interrupts                   |     |
| 14.3.1 Handling Interrupts          |     |
| 14.3.2 Example ISR                  |     |
| 14.4 Register Descriptions          |     |
|                                     |     |
| Chapter 15. Timer B                 | 157 |
| 15.1 Overview                       | 157 |
| 15.1.1 Block Diagram                |     |
| 15.1.2 Registers                    |     |
| 15.2 Dependencies                   |     |
| 15.2.1 I/O Pins                     |     |
| 15.2.2 Clocks                       |     |
| 15.2.3 Other Registers              |     |
| 15.2.4 Interrupts                   |     |
| 15.3 Operation                      |     |
| 15.3.1 Handling Interrupts          |     |
| 15.3.2 Example ISR                  | 137 |
| 13.4 Register Descriptions          | 100 |
| Chapter 16. Timer C                 | 163 |
| 16.1 Overview                       | 163 |
| 16.1.1 Block Diagram                |     |
| 16.1.2 Registers                    |     |
| 16.2 Dependencies                   |     |
| 16.2.1 I/O Pins                     |     |
| 16.2.2 Clocks                       |     |
| 16.2.3 Other Registers              |     |
| 16.2.4 Interrupts                   |     |
| 16.3 Operation                      |     |
| 16.3.1 Handling Interrupts          |     |
| 16.4 Register Descriptions          |     |
| 10.1 Register Descriptions          | 100 |
| Chapter 17. Serial Ports A – D      | 171 |
| 17.1 Overview                       |     |
| 17.1.1 Block Diagram                |     |
| 17.1.1 Block Diagram                |     |
| 17.1.2 Registers  17.2 Dependencies |     |
| 17.2.1 I/O Pins                     |     |
| 17.2.2 Clocks                       |     |
| 17.2.3 Other Registers              |     |
| 17.2.4 Interrupts                   |     |
| 17.3 Operation                      |     |
| 17.3.1 Asynchronous Mode            |     |
| 17.3.2 Clocked Serial Mode          | 178 |

| 17.4 Register Descriptions                                                        | 180 |
|-----------------------------------------------------------------------------------|-----|
| Chapter 18. Serial Ports E – F                                                    | 187 |
| 18.1 Overview                                                                     |     |
| 18.1.1 Block Diagram                                                              |     |
| 18.1.2 Registers                                                                  |     |
| 18.2.1 I/O Pins                                                                   |     |
| 18.2.2 Clocks                                                                     |     |
| 18.2.3 Other Registers                                                            |     |
| 18.2.4 Interrupts                                                                 | 193 |
| 18.3 Operation                                                                    |     |
| 18.3.1 Asynchronous Mode                                                          | 192 |
| 18.3.2 HDLC Mode                                                                  |     |
| 18.3.3 More on Clock Synchronization and Data Encoding 18.4 Register Descriptions |     |
| 10.1 Register Descriptions                                                        |     |
| Chapter 19. Slave Port                                                            | 203 |
| 19.1 Overview                                                                     |     |
| 19.1.1 Block Diagram                                                              |     |
| 19.1.2 Registers                                                                  |     |
| 19.2.1 I/O Pins                                                                   |     |
| 19.2.2 Clocks                                                                     |     |
| 19.2.3 Interrupts                                                                 | 203 |
| 19.3 Operation                                                                    |     |
| 19.3.1 Master Setup                                                               | 207 |
| 19.3.2 Slave Setup                                                                | 207 |
| 19.3.3 Master/Slave Communication                                                 |     |
| 19.3.4 Slave/Master Communication                                                 |     |
| 19.3.5 Handling Interrupts                                                        |     |
| 19.3.7 Other Configurations                                                       |     |
| 19.3.8 Timing Diagrams                                                            |     |
| 19.4 Register Descriptions                                                        | 212 |
| Chapter 20. Analog Components                                                     | 215 |
| 20.1 Overview                                                                     |     |
| 20.2 Block Diagram                                                                |     |
| •                                                                                 |     |
| 20.2.1 Registers                                                                  |     |
| 20.3.1 I/O Pins                                                                   |     |
| 20.3.2 Clocks                                                                     | 219 |
| 20.4 Operation                                                                    |     |
| 20.4.1 Fast A/D Converter                                                         |     |
| 20.4.2 Fast D/A Converter                                                         | 220 |
| 20.4.3 Slow A/D Converter                                                         |     |
| 20.5 Sample Circuits                                                              |     |
| 20.6 Register Descriptions                                                        | 223 |
| Chapter 21. DMA Channels                                                          | 229 |
| 21.1 Overview                                                                     |     |
| 21.1.1 Block Diagram                                                              |     |
| 21.1.2 Registers                                                                  |     |
| 21.2 Dependencies                                                                 | 234 |
| 21.2.1 I/O Pins                                                                   | 234 |
| 21.2.2 Clocks                                                                     | 234 |
| 21.2.3 Interrupts                                                                 | 234 |
| 21.3 Operation                                                                    | 235 |

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 236                                                                                  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|
| 21.3.2 Example ISR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                      |
| 21.3.3 DMA Priority with the Processor                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                      |
| 21.3.4 DMA Channel Priority                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                      |
| 21.3.5.1 Single Buffer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 230                                                                                  |
| 21.3.5.2 Buffer Array                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                      |
| 21.3.5.3 Linked List                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                      |
| 21.3.5.4 Circular Queue                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                      |
| 21.3.5.5 Linked Array                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                      |
| 21.3.6 DMA with Peripherals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                      |
| 21.3.6.2 DMA with Fiber serial Forts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                      |
| 21.3.6.2 DMA with Ethernet                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                      |
| 21.3.6.4 DMA with PWM and Timer C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                      |
| 21.4 Register Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 243                                                                                  |
| Chapter 22. 10/100Base-T Ethernet                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 257                                                                                  |
| 22.1 Overview                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                      |
| 22.1.1 Block Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                      |
| 22.1.2 Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                      |
| 22.2 Dependencies                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                      |
| 22.2.1 I/O Pins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                      |
| 22.2.2 Clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                      |
| 22.2.4 Interrupts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                      |
| 22.3 Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                      |
| 22.3.1 Setup                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                      |
| 22.3.2 Transmit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                      |
| 22 2 2 D ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                      |
| 22.3.3 Receive                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                      |
| 22.3.4 Handling Interrupts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                      |
| 22.3.4 Handling Interrupts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                      |
| 22.3.4 Handling Interrupts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                      |
| 22.3.4 Handling Interrupts 22.3.5 Multicast Addressing 22.4 Register Descriptions  Chapter 23. 802.11b/g Wireless                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                      |
| 22.3.4 Handling Interrupts 22.3.5 Multicast Addressing 22.4 Register Descriptions  Chapter 23. 802.11b/g Wireless 23.1 Overview                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                      |
| 22.3.4 Handling Interrupts 22.3.5 Multicast Addressing 22.4 Register Descriptions  Chapter 23. 802.11b/g Wireless 23.1 Overview 23.1.1 Block Diagram                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                      |
| 22.3.4 Handling Interrupts 22.3.5 Multicast Addressing 22.4 Register Descriptions  Chapter 23. 802.11b/g Wireless 23.1 Overview 23.1.1 Block Diagram 23.1.2 Registers                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                      |
| 22.3.4 Handling Interrupts 22.3.5 Multicast Addressing 22.4 Register Descriptions  Chapter 23. 802.11b/g Wireless 23.1 Overview 23.1.1 Block Diagram 23.1.2 Registers 23.2 Dependencies                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                      |
| 22.3.4 Handling Interrupts 22.3.5 Multicast Addressing 22.4 Register Descriptions  Chapter 23. 802.11b/g Wireless 23.1 Overview 23.1.1 Block Diagram 23.1.2 Registers 23.2 Dependencies 23.2.1 I/O Pins                                                                                                                                                                                                                                                                                                                                                                         |                                                                                      |
| 22.3.4 Handling Interrupts 22.3.5 Multicast Addressing 22.4 Register Descriptions  Chapter 23. 802.11b/g Wireless 23.1 Overview 23.1.1 Block Diagram 23.1.2 Registers 23.2 Dependencies 23.2.1 I/O Pins 23.3 Clocks                                                                                                                                                                                                                                                                                                                                                             | 265 266 267  281 281 282 283 285 285                                                 |
| 22.3.4 Handling Interrupts 22.3.5 Multicast Addressing 22.4 Register Descriptions  Chapter 23. 802.11b/g Wireless 23.1 Overview 23.1.1 Block Diagram 23.1.2 Registers 23.2 Dependencies 23.2.1 I/O Pins 23.3 Clocks 23.3.1 Other Registers                                                                                                                                                                                                                                                                                                                                      | 265 266 267  281 281 282 283 285 285 286                                             |
| 22.3.4 Handling Interrupts 22.3.5 Multicast Addressing 22.4 Register Descriptions  Chapter 23. 802.11b/g Wireless 23.1 Overview 23.1.1 Block Diagram 23.1.2 Registers 23.2 Dependencies 23.2.1 I/O Pins 23.3 Clocks 23.3.1 Other Registers 23.2.2 Interrupts                                                                                                                                                                                                                                                                                                                    |                                                                                      |
| 22.3.4 Handling Interrupts 22.3.5 Multicast Addressing 22.4 Register Descriptions  Chapter 23. 802.11b/g Wireless 23.1 Overview 23.1.1 Block Diagram 23.1.2 Registers 23.2 Dependencies 23.2.1 I/O Pins 23.3 Clocks 23.3.1 Other Registers                                                                                                                                                                                                                                                                                                                                      |                                                                                      |
| 22.3.4 Handling Interrupts 22.3.5 Multicast Addressing 22.4 Register Descriptions  Chapter 23. 802.11b/g Wireless 23.1 Overview 23.1.1 Block Diagram 23.1.2 Registers 23.2 Dependencies 23.2.1 I/O Pins 23.3 Clocks 23.3.1 Other Registers 23.3.2 Interrupts 23.4 Operation  Chapter 24. Input Capture                                                                                                                                                                                                                                                                          | 265 266 267  281 281 282 283 285 285 286 286 286                                     |
| 22.3.4 Handling Interrupts 22.3.5 Multicast Addressing 22.4 Register Descriptions  Chapter 23. 802.11b/g Wireless 23.1 Overview 23.1.1 Block Diagram 23.1.2 Registers 23.2 Dependencies 23.2.1 I/O Pins 23.3 Clocks 23.3.1 Other Registers 23.3.2 Interrupts 23.4 Operation  Chapter 24. Input Capture 24.1 Overview                                                                                                                                                                                                                                                            | 265 266 267  281 281 282 283 285 286 286 286 286 286                                 |
| 22.3.4 Handling Interrupts 22.3.5 Multicast Addressing 22.4 Register Descriptions  Chapter 23. 802.11b/g Wireless 23.1 Overview 23.1.1 Block Diagram 23.1.2 Registers 23.2 Dependencies 23.2.1 I/O Pins 23.3 Clocks 23.3.1 Other Registers 23.3.2 Interrupts 23.4 Operation  Chapter 24. Input Capture 24.1 Overview 24.1.1 Block Diagram                                                                                                                                                                                                                                       |                                                                                      |
| 22.3.4 Handling Interrupts 22.3.5 Multicast Addressing 22.4 Register Descriptions  Chapter 23. 802.11b/g Wireless 23.1 Overview 23.1.1 Block Diagram 23.1.2 Registers 23.2 Dependencies 23.2.1 I/O Pins 23.3 Clocks 23.3.1 Other Registers 23.3.2 Interrupts 23.4 Operation  Chapter 24. Input Capture 24.1 Overview 24.1.1 Block Diagram 24.1.2 Registers                                                                                                                                                                                                                      | 265 266 267  281 281 282 283 285 286 286 286 286 286 287 287                         |
| 22.3.4 Handling Interrupts 22.3.5 Multicast Addressing 22.4 Register Descriptions  Chapter 23. 802.11b/g Wireless 23.1 Overview 23.1.1 Block Diagram 23.1.2 Registers 23.2 Dependencies 23.2.1 I/O Pins 23.3 Clocks 23.3.1 Other Registers 23.3.2 Interrupts 23.4 Operation  Chapter 24. Input Capture 24.1 Overview 24.1.1 Block Diagram 24.1.2 Registers 24.2 Dependencies                                                                                                                                                                                                    | 265 266 267  281 281 282 283 285 286 286 286 286 286 287 287                         |
| 22.3.4 Handling Interrupts 22.3.5 Multicast Addressing 22.4 Register Descriptions  Chapter 23. 802.11b/g Wireless 23.1 Overview 23.1.1 Block Diagram 23.1.2 Registers 23.2 Dependencies 23.2.1 I/O Pins 23.3 Clocks 23.3.1 Other Registers 23.3.2 Interrupts 23.4 Operation  Chapter 24. Input Capture 24.1 Overview 24.1.1 Block Diagram 24.1.2 Registers 24.2 Dependencies 24.2.1 I/O Pins                                                                                                                                                                                    | 265 266 267  281 281 282 283 285 285 286 286 286 286 287 287                         |
| 22.3.4 Handling Interrupts 22.3.5 Multicast Addressing 22.4 Register Descriptions  Chapter 23. 802.11b/g Wireless 23.1 Overview 23.1.1 Block Diagram 23.1.2 Registers 23.2 Dependencies 23.2.1 I/O Pins 23.3 Clocks 23.3.1 Other Registers 23.3.2 Interrupts 23.4 Operation  Chapter 24. Input Capture 24.1 Overview 24.1.1 Block Diagram 24.1.2 Registers 24.2 Dependencies 24.2.1 I/O Pins 24.2.2 Clocks                                                                                                                                                                      |                                                                                      |
| 22.3.4 Handling Interrupts 22.3.5 Multicast Addressing 22.4 Register Descriptions  Chapter 23. 802.11b/g Wireless 23.1 Overview 23.1.1 Block Diagram 23.1.2 Registers 23.2 Dependencies 23.2.1 I/O Pins 23.3 Clocks 23.3.1 Other Registers 23.2.2 Interrupts 23.4 Operation  Chapter 24. Input Capture 24.1 Overview 24.1.1 Block Diagram 24.1.2 Registers 24.2 Dependencies 24.2.1 I/O Pins 24.2.2 Clocks 24.2.3 Other Registers                                                                                                                                               | 265 266 267  281 281 281 282 283 285 285 286 286 286 286 287 287 287 288 290 290     |
| 22.3.4 Handling Interrupts 22.3.5 Multicast Addressing 22.4 Register Descriptions  Chapter 23. 802.11b/g Wireless 23.1 Overview 23.1.1 Block Diagram 23.1.2 Registers 23.2 Dependencies 23.2.1 I/O Pins 23.3 Clocks 23.3.1 Other Registers 23.3.2 Interrupts 23.4 Operation  Chapter 24. Input Capture 24.1 Overview 24.1.1 Block Diagram 24.1.2 Registers 24.2 Dependencies 24.2.1 I/O Pins 24.2.2 Clocks                                                                                                                                                                      | 265 266 267  281 281 281 282 283 285 286 286 286 286 287 287 287 287 288 290 290 290 |
| 22.3.4 Handling Interrupts 22.3.5 Multicast Addressing 22.4 Register Descriptions  Chapter 23. 802.11b/g Wireless 23.1 Overview 23.1.1 Block Diagram 23.1.2 Registers 23.2 Dependencies 23.2.1 I/O Pins 23.3 Clocks 23.3.1 Other Registers 23.2.2 Interrupts 23.4 Operation  Chapter 24. Input Capture 24.1 Overview 24.1.1 Block Diagram 24.1.2 Registers 24.2 Dependencies 24.2.1 I/O Pins 24.2.2 Clocks 24.2.3 Other Registers 24.2.4 Interrupts                                                                                                                             |                                                                                      |
| 22.3.4 Handling Interrupts 22.3.5 Multicast Addressing 22.4 Register Descriptions  Chapter 23. 802.11b/g Wireless 23.1 Overview 23.1.1 Block Diagram 23.1.2 Registers 23.2 Dependencies 23.2.1 I/O Pins 23.3 Clocks 23.3.1 Other Registers 23.3.2 Interrupts 23.4 Operation  Chapter 24. Input Capture 24.1 Overview 24.1.1 Block Diagram 24.1.2 Registers 24.2 Dependencies 24.2.1 I/O Pins 24.2.2 Clocks 24.2.3 Other Registers 24.2.3 Other Registers 24.2.4 Interrupts 24.3 Operation  24.3.1 Input-Capture Channel 24.3.1 Input-Capture Channel 24.3.2 Handling Interrupts |                                                                                      |
| 22.3.4 Handling Interrupts 22.3.5 Multicast Addressing 22.4 Register Descriptions  Chapter 23. 802.11b/g Wireless 23.1 Overview 23.1.1 Block Diagram 23.1.2 Registers 23.2 Dependencies 23.2.1 I/O Pins 23.3 Clocks. 23.3.1 Other Registers 23.3.2 Interrupts 23.4 Operation  Chapter 24. Input Capture 24.1 Overview 24.1.1 Block Diagram 24.1.2 Registers 24.2 Dependencies 24.2.1 I/O Pins 24.2.2 Clocks 24.2.3 Other Registers 24.2.4 Interrupts 24.3 Operation 24.3.1 Input-Capture Channel                                                                                |                                                                                      |

| 24.3.5 Count Mode                                           | 292  |
|-------------------------------------------------------------|------|
| 24.4 Register Descriptions                                  | 293  |
| Chapter 25. Quadrature Decoder                              | 299  |
| 25.1 Overview                                               | 299  |
| 25.1.1 Block Diagram                                        |      |
| 25.1.2 Registers                                            |      |
| 25.2 Dependencies                                           |      |
| 25.2.1 I/O Pins                                             |      |
| 25.2.2 Clocks                                               | 302  |
| 25.2.3 Other Registers                                      |      |
| 25.2.4 Interrupts                                           |      |
|                                                             |      |
| 25.3.1 Handling Interrupts                                  | 303  |
| 25.4 Register Descriptions                                  |      |
| Chapter 26. Pulse Width Modulator                           | 307  |
| 26.1 Overview                                               |      |
| 26.1.1 Block Diagram                                        |      |
| 26.1.2 Registers                                            | 309  |
| 26.2 Dependencies                                           | 310  |
| 26.2.1 I/O Pins                                             |      |
| 26.2.2 Clocks                                               |      |
| 26.2.3 Other Registers                                      | 310  |
| 26.2.4 Interrupts                                           | 310  |
| 26.3 Operation                                              |      |
| 26.3.1 Handling Interrupts                                  |      |
| 26.3.2 Example ISR                                          |      |
| 20.4 Register Descriptions                                  |      |
| Chapter 27. External I/O Control                            | 315  |
| 27.1 Overview                                               | 315  |
| 27.1.1 External I/O Bus                                     | 315  |
| 27.1.2 I/O Strobes                                          | 316  |
| 27.1.3 I/O Handshake                                        |      |
| 27.1.4 Block Diagram                                        |      |
| 27.1.5 Registers 27.2 Dependencies                          |      |
|                                                             | 319  |
| 27.2.1 I/O Pins                                             |      |
| 27.2.2 Clocks 27.2.3 Other Registers 27.2.3 Other Registers | 319  |
| 27.2.4 Interrupts                                           |      |
| 27.3 Operation                                              |      |
| 27.3.1 External I/O Bus                                     |      |
| 27.3.2 I/O Strobes                                          |      |
| 27.3.3 I/O Handshake                                        |      |
| 27.4 Register Descriptions                                  | 321  |
| Chapter 28. Breakpoints                                     | 331  |
| 28.1 Overview                                               | 331  |
| 28.1.1 Block Diagram                                        |      |
| 28.1.2 Registers                                            |      |
| 28.2 Dependencies                                           | 334  |
| 28.2.1 I/O Pins                                             |      |
| 28.2.2 Clocks                                               |      |
| 28.2.3 Other Registers                                      | 334  |
| 28.2.4 Interrupts                                           | 334  |
| 40 J. VU514HUH                                              | 1 14 |

| 28.3.1 Handling Interrupts                              |     |
|---------------------------------------------------------|-----|
| 28.3.2 Example ISR                                      |     |
| 28.4 Register Descriptions                              | 336 |
| Chapter 29. Low-Power Operation                         | 339 |
| 29.1 Overview                                           |     |
|                                                         |     |
| 29.1.1 Registers 29.2 Operation                         |     |
| 29.2.1 Unused Pins                                      |     |
| 29.2.2 Clock Rates                                      |     |
| 29.2.3 Short Chip Selects                               |     |
| 29.2.4 Self-Timed Chip Selects                          |     |
| 29.3 Register Descriptions                              | 348 |
| Chapter 30. System/User Mode                            | 351 |
| 30.1 Overview                                           |     |
|                                                         |     |
| 30.1.1 Registers 30.2 Dependencies                      |     |
| 30.2.1 I/O Pins                                         |     |
| 30.2.2 Clocks                                           |     |
| 30.2.3 Other Registers                                  |     |
| 30.2.4 Interrupts                                       | 354 |
| 30.3 Operation                                          | 355 |
| 30.3.1 Memory Protection Only                           | 355 |
| 30.3.2 Mixed System/User Mode Operation                 | 356 |
| 30.3.3 Complete Operating System                        | 356 |
| 30.3.4 Enabling the System/User Mode                    |     |
| 30.3.6 System Mode Violation Interrupt                  | 359 |
| 30.3.7 Handling Interrupts in the System/User Mode      | 360 |
| 30.4 Register Descriptions                              |     |
| Chantar 24 Specifications                               | 369 |
| Chapter 31. Specifications                              |     |
| 31.1 DC Characteristics                                 |     |
| 31.2 AC Characteristics                                 |     |
| 31.3 Memory Access Times                                |     |
| 31.3.1 Memory Reads                                     |     |
| 31.3.2 Memory Writes                                    |     |
| 31.3.4 External I/O Writes                              |     |
| 31.3.5 Memory Access Times                              |     |
| 31.4 Clock Speeds                                       | 381 |
| 31.4.1 Recommended Clock/Memory Configurations          | 381 |
| 31.5 Power and Current Consumption                      | 385 |
| 31.5.1 Sleepy Mode Current Consumption                  |     |
| 31.5.2 Battery-Backed Clock Current Consumption         | 387 |
| Chapter 32. Package Specifications and Pinout           | 389 |
| 32.1 Ball Grid Array Packages                           | 389 |
| 32.1.1 Pinout 17 × 17 Ethernet Option                   |     |
| 32.1.2 Pinout 17 × 17 Wi-Fi Option                      | 390 |
| 32.1.3 Mechanical Dimensions and Land Pattern           | 391 |
| 32.2 Rabbit Pin Descriptions                            | 393 |
| Appendix A. Parallel Port Pins with Alternate Functions | 397 |
| A.1 Alternate Parallel Port Pin Outputs                 |     |
|                                                         |     |

| Appendix B. Rabbit 5000 Errata | 401 |
|--------------------------------|-----|
| B.1 Errata                     | 401 |
|                                |     |
| Index                          | 405 |



## 1. THE RABBIT 5000 PROCESSOR

#### 1.1 Introduction

Rabbit Semiconductor was formed expressly to design a a better microprocessor for use in small- and medium-scale single-board computers. The first microprocessors were the *Rabbit 2000*, *Rabbit 3000*, and the *Rabbit 4000*. The latest microprocessor is the *Rabbit 5000*. Rabbit microprocessor designers have had years of experience using Z80, Z180, and HD64180 microprocessors in small single-board computers. The Rabbit microprocessors share a similar architecture and a high degree of compatibility with these microprocessors, but represent a vast improvement.

The Rabbit 5000 is a high-performance microprocessor with low electromagnetic interference (EMI), and is designed specifically for embedded control, communications, and network connectivity. Extensive integrated features and glueless architecture facilitate rapid hardware design, while a C-friendly instruction set promotes efficient development of even the most complex applications.

The Rabbit 5000 is the first Rabbit microprocessor to have a full 16-bit internal bus architecture, providing significant performance improvements when used with external 16-bit memory devices. It also has the ability to support both 8-bit and 16-bit external memory devices.

The Rabbit 5000 is also the fastest microprocessor from Rabbit, now a Digi International brand, running at up to 100 MHz, with compact code and support for up to 16 MB of memory. Operating with a 1.8 V core and 3.3 V I/O, the Rabbit 5000 boasts eight channels of DMA, six serial ports with IrDA, 48+ digital I/O, quadrature decoder, PWM outputs, and pulse capture and measurement capabilities. It also features a battery-backable real-time clock, glueless memory and I/O interfacing, and ultra-low power modes. Four levels of interrupt priority allow fast response to real-time events. Its compact instruction set and high clock speeds give the Rabbit 5000 exceptionally fast math, logic, and I/O performance.

The Rabbit 5000 contains 128 KB of internal high-speed 16-bit SRAM, which can be used for code and/or data. It is capable of booting off of a standard serial flash, so a microcontroller application with no external parallel memory is possible.

The Rabbit 5000 provides two options for network connectivity — a full 10/100Base-T Ethernet MAC with a standard MII PHY interface, and a wireless 802.11b/g MAC compatible with several standard Wi-Fi transceivers. The two network interfaces share both internal resources and I/O pins, and so only one can be enabled at a time.

#### 1.2 Features

The Rabbit 5000 has several powerful design features that practically eliminate EMI problems, which is essential for OEMs who need to pass CE and regulatory radio-frequency emissions tests. The amplitude of any electromagnetic radiation is reduced by the internal spectrum spreader, by gated clocks (which prevent unnecessary clocking of unused registers), and by separate power planes for the processor core and I/O pins (which reduce noise crosstalk). An external I/O bus can be used by designers to enable separate buses for I/O and memory, or to limit loading the memory bus to reduce EMI and ground bounce problems when interfacing external peripherals to the processor. The external I/O bus accomplishes this by duplicating the Rabbit's data bus on Parallel Port A, and uses Parallel Port B to provide the processor's six or eight least significant address lines for interfacing with external peripherals.

The high-performance instruction set offers both greater efficiency and execution speed of compiler-generated C code. Instructions include numerous single-byte opcodes that execute in two clock cycles, 16-bit and 32-bit loads and stores, 16-bit and 32-bit logical and arithmetic operations,  $16 \times 16$  multiply (executes in 12 clocks), long jumps and returns for accessing a full 16 MB of memory, and one-byte prefixes to turn memory-access instructions into internal and external I/O instructions. Hardware-supported breakpoints ease debugging by trapping on code execution or data reads and writes.

The Rabbit 5000 requires no external memory driver or interface-logic. Its 24-bit address bus, 8-bit or 16-bit data bus, three chip-select lines, two output-enable lines, and two write-enable lines can be interfaced directly with up to six memory devices. Up to 1 MB of memory can be accessed directly via the Dynamic C development software, and up to 16 MB can be interfaced with additional software development. The Rabbit 5000 also contains 128 KB of internal high-speed 16-bit SRAM, which can be used in addition to any external memory devices.

A built-in slave port allows the Rabbit 5000 to be used as master or slave in multi-processor systems, permitting separate tasks to be assigned to dedicated processors. An 8-line data port and five control signals simplify the exchange of data between devices. A remote cold boot enables startup and programming via a serial port, a slave port, or from a standard external serial flash device.

The Rabbit 5000 features six 8-bit parallel ports, yielding a total of 48 digital I/O. Six CMOS-compatible serial ports are available. All six are configurable as asynchronous (including output pulses in IrDA format), while four are configurable as clocked serial (SPI) and two are configurable as SDLC/HDLC. The various internal peripherals share the parallel port's I/O pins.

The Rabbit 5000 also offers many specialized peripherals. Two input-capture channels each have a 16-bit counter, clocked by the output of an internal timer, that can be used to capture and measure pulses. These measurements can be extended to a variety of functions such as measuring pulse widths or for baud-rate autodetection. Two Quadrature Decoder channels each have two inputs, as well as an 8- or 10-bit up/down counter. Each quadrature

decoder channel provides a direct interface to optical encoder units. Four independent pulse-width modulator (PWM) outputs, each based on a 1024-pulse frame, are driven by the output of a programmable internal timer. The PWM outputs can be filtered to create a 10-bit D/A converter or they can be used directly to drive devices such as motors or solenoids. Two external interrupt vectors can multiplex inputs from up to six external pins.

The Rabbit 5000 has three timer systems. Timer A consists of ten 8-bit counters, each of which has a programmed time constant. Six of them can be cascaded from the primary Timer A counter. Timer B contains a 10-bit counter, two match registers, and two step registers. An interrupt can be generated or the output pin can be updated when the counter reaches a match value, and the match value can then be incremented automatically by the step value. Timer C is a 16-bit counter that counts up to a programmable limit. It contains eight match registers so that up to four PWM (both synchronous and variable-phase) or quadrature decoder signals can be created.

The Rabbit 5000 also provides support for protected operating systems. Support for two levels of operation, known as *system* and *user* modes, allow application-critical code to operate in safety while user code is prevented from inadvertently disturbing the setup of the processor. Memory blocks as small as 4 KB can be write-protected against accidental writes by user code, and stack over/underflows can be trapped by high-priority interrupts.

Security features are also available in the Rabbit 5000. Portions of the new instruction set were introduced to increase encryption algorithm speeds dramatically, and 32 bytes of battery-backed RAM can store an encryption key away from prying eyes.

The Rabbit 5000 supports eight channels of DMA access to internal or external memory, internal I/O addresses, and the external I/O bus. Directing a DMA channel to or from an internal peripheral such as a serial port or the Ethernet port automatically connects DMA enable signals. Burst size, priority, and guaranteed cycles for the processor are all under program control.

The Rabbit 5000 contains an 802.11b/g wireless MAC peripheral, also designed to operate with the DMA peripheral. It includes support for all standard Wi-Fi features, including infrastructure and ad-hoc modes. The high-speed internal A/D converter and D/A converter and clocked-serial control port provide a generic interface to several common Wi-Fi transceivers. A low-speed A/D converter is also available to monitor the transmit signal strength if desired. The two A/D converters and single D/A converter are available for customer use when the Wi-Fi peripheral is disabled.

The Rabbit 5000 also contains a full-featured 10/100Base-T Ethernet MAC peripheral. Designed to operate with the DMA peripheral, the Ethernet peripheral is fully compliant with the 802.3 Ethernet standard, including support for auto-negotiation, link detection, multicast filtering, and broadcast addresses. An industry-standard MII interface is used to connect to an external PHY device.

## 1.3 Block Diagram



## 1.4 Basic Specifications

Two versions of the Rabbit 5000 are available—the standard 289-ball BGA and a compact 196-ball BGA for specialty Wi-Fi applications. The larger package is intended for most Rabbit applications; the smaller package has specific features and limitations, and is not presently offered for sale. If you need further information, please contact your Rabbit sales representative.

Table 1-1. Rabbit 5000 Specifications and Features

| Package                   | 289-ball BGA                                                                                        | 196-ball BGA           |  |  |
|---------------------------|-----------------------------------------------------------------------------------------------------|------------------------|--|--|
| Package Size              | 15 mm × 15 mm × 1.4 mm                                                                              | 12 mm × 12 mm × 1.2 mm |  |  |
| Operating Voltage         | 1.8 V DC core, 3.3 V DC I/O ring                                                                    |                        |  |  |
| Operating Current         | 0.57 mA/MHz @ 1.8 V/3.3 V<br>(Wi-Fi and Ethernet diabled)                                           |                        |  |  |
| Operating Temp.           | -40°C to +85°C                                                                                      |                        |  |  |
| Maximum Clock Speed       | 100 1                                                                                               | MHz                    |  |  |
| Digital I/O               | 48+ (arranged in six 8-bit ports)                                                                   | 19                     |  |  |
| Network Interfaces        | 10/100Base-T<br>802.11b/g Wi-Fi                                                                     | 802.11b/g Wi-Fi        |  |  |
| Serial Ports              | 6 CMOS-compatible                                                                                   | 2 CMOS-compatible      |  |  |
| Baud Rate                 | Clock speed/8 ma                                                                                    | ax. asynchronous       |  |  |
| Address Bus               | 20/24-bit                                                                                           | 8-bit                  |  |  |
| Data Bus                  | 8/16-bit                                                                                            | 8/16-bit               |  |  |
| Timers                    | Ten 8-bit, one 10-bit with 2 match registers, and one 16-bit with 8 match registers                 |                        |  |  |
| Real-Time Clock           | Yes, battery-backable                                                                               |                        |  |  |
| RTC Oscillator Circuitry  | Exte                                                                                                | ernal                  |  |  |
| Watchdog Timer/Supervisor | Yes                                                                                                 |                        |  |  |
| Clock Modes               | 1×, 2×, /2, /3, /4, /6, /8                                                                          |                        |  |  |
| Power-Down Modes          | Sleepy (32 kHz)<br>Ultra-Sleepy (16, 8, 2 kHz)                                                      |                        |  |  |
| External I/O Bus          | 8 data, 8 address lines                                                                             | No                     |  |  |
| A/D Converters            | 10-bit, 2 synchronous channels, up to 40 megasamples/s 10-bit, single channel, up to 300 ksamples/s |                        |  |  |
| D/A Converters            | 10-bit, 2 synchronous channels, up to 40 megasamples/s                                              |                        |  |  |

## 1.5 Comparing Rabbit Microprocessors

The Rabbit 2000, Rabbit 3000, Rabbit 4000, and Rabbit 5000 features are compared below.

| Feature                                                                                                  | Rabbit 5000                                                         | Rabbit 4000                                          | Rabbit 3000                             | Rabbit 2000                     |
|----------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|------------------------------------------------------|-----------------------------------------|---------------------------------|
| Maximum Clock Speed, industrial<br>Maximum Clock Speed,<br>commercial                                    | 100 MHz<br>100 MHz                                                  | 60 MHz<br>60 MHz                                     | 55.5 MHz<br>58.8 MHz                    | 30 MHz<br>30 MHz                |
| Maximum Crystal Frequency<br>Main Oscillator (may be doubled<br>internally up to maximum clock<br>speed) | 100 MHz                                                             | 60 MHz                                               | 30 MHz                                  | 30 MHz                          |
| 32.768 kHz Crystal Oscillator                                                                            | External                                                            | External                                             | External                                | Internal                        |
| Operating Voltage, core<br>Operation Voltage, I/O                                                        | $1.8 \text{ V} \pm 10\%$<br>$3.3 \text{ V} \pm 10\%$                | $1.8 \text{ V} \pm 10\%$<br>$3.3 \text{ V} \pm 10\%$ | $3.3 \text{ V} \pm 10\%$                | $5.0 \text{ V} \pm 10\%$        |
| Maximum I/O Input Voltage                                                                                | 3.6 V                                                               | 3.6 V                                                | 5.5 V                                   | 5.5 V                           |
| Current Consumption                                                                                      | 0.57 mA/MHz<br>@ 1.8 V/3.3 V<br>(Wi-Fi and<br>Ethernet<br>disabled) | 0.35 mA/MHz<br>@ 3.3 V                               | 2 mA/MHz<br>@ 3.3 V                     | 4 mA/MHz<br>@ 5 V               |
| Number of Package Pins                                                                                   | 289/196                                                             | 128                                                  | 128                                     | 100                             |
| Size of Package, LQFP/PQFP<br>Spacing Between Package Pins                                               | N/A                                                                 | 16×16×1.5 mm<br>0.4 mm (16 mils)                     | 16×16×1.5 mm<br>0.4 mm (16 mils)        | 24×18×3 mm<br>0.65 mm (26 mils) |
| Size of Package, BGA (mm) Spacing Between Package Pins                                                   | $15 \times 15 \times 1.4$<br>$12 \times 12 \times 1.2$<br>0.8  mm   | 10×10×1.2<br>0.8 mm                                  | 10×10×1.2<br>0.8 mm                     | Not available                   |
| Separate Power and Ground for I/O Buffers (EMI reduction)                                                | Yes                                                                 | Yes                                                  | Yes                                     | No                              |
| Clock Spectrum Spreader                                                                                  | Yes                                                                 | Yes                                                  | Yes                                     | Rabbit 2000B/C                  |
| Clock Modes                                                                                              | 1×, 2×, /2, /3, /4, /6, /8                                          | 1×, 2×, /2, /3,<br>/4, /6, /8                        | 1x, 2x, /2, /3<br>/4, /6, /8            | 1x, 2x, /4, /8                  |
| Powerdown Modes, sleepy<br>Powerdown Modes, ultra sleepy                                                 | 32 kHz<br>16, 8, 4, 2 kHz                                           | 32 kHz<br>16, 8, 4, 2 kHz                            | 32 kHz<br>16, 8, 4, 2 kHz               | 32 kHz                          |
| Low-Power Memory Control                                                                                 | Short and<br>Self-Timed<br>Chip Selects                             | Short and<br>Self-Timed<br>Chip Selects              | Short and<br>Self-Timed<br>Chip Selects | None                            |
| Extended Memory Timing for High-Frequency Operation                                                      | Yes                                                                 | Yes                                                  | Yes                                     | No                              |
| Number of 8-bit I/O Ports                                                                                | 6                                                                   | 5                                                    | 7                                       | 5                               |

| Feature                                                    | Rabbit 5000    | Rabbit 4000    | Rabbit 3000    | Rabbit 2000    |
|------------------------------------------------------------|----------------|----------------|----------------|----------------|
| Auxiliary I/O Data/Address Bus                             | Yes            | Yes            | Yes            | None           |
| Number of Serial Ports                                     | 6              | 6              | 6              | 4              |
| Serial Ports Capable of SPI/<br>Clocked Serial             | 4 (A, B, C, D) | 4 (A, B, C, D) | 4 (A, B, C, D) | 2 (A, B)       |
| Serial Ports Capable of SDLC/<br>HDLC                      | 2 (E, F)       | 2 (E, F)       | 2 (E, F)       | None           |
| Asynch Serial Ports With Support for IrDA Communication    | 6              | 6              | 6              | None           |
| Serial Ports with Support for SDLC/HDLC IrDA Communication | 2              | 2              | 2              | None           |
| Maximum Asynchronous Baud<br>Rate                          | Clock Speed/8  | Clock Speed/8  | Clock Speed/8  | Clock Speed/32 |
| Ethernet Port                                              | 10/100Base-T   | 10Base-T       | None           | None           |
| Wi-Fi                                                      | Yes            | No             | No             | No             |
| PWM Outputs                                                | 4              | 4              | 4              | None           |
| Variable-Phase PWM Outputs (PPM)                           | 4              | 4              | None           | None           |
| Input Capture Units                                        | 2              | 2              | 2              | None           |
| Quadrature Decoders                                        | 2 channels     | 2 channels     | 2 channels     | None           |

# 2. CLOCKS

#### 2.1 Overview

The Rabbit 5000 supports up to three separate clocks at once—the main clock, the 32 kHz clock, and the 20 MHz Wi-Fi clock. The main clock is used to drive the processor clock and the peripheral clock inside the processor. The 32 kHz clock is used to drive the asynchronous serial bootstrap, the real-time clock, the periodic interrupt, and the watchdog timers

The Rabbit 5000 has a spectrum spreader on the main clock that shortens and lengthens clock cycles. This has the net effect of reducing the peak energy of clock harmonics by spreading the spectral energy into nearby frequencies, which reduces EMI and facilitates government-mandated EMI testing. Gated clocks are used whenever possible to avoid clocking unused portions of the processor, and separate power-supply pins for the core and I/O ring further reduce EMI from the Rabbit 5000.

The main clock can be doubled or divided by 2, 4, 6, or 8 to reduce EMI and power consumption. The 32 kHz clock (which can be divided by 2, 4, 8, or 16) can be used instead of the main clock to generate processor and peripheral clocks as low as 2 kHz for significant power savings. Note that dividing the 32 kHz clock only affects the processor and peripheral clocks; the full 32 kHz signal is still provided to the real-time clock and watchdog timer peripherals that use it directly. The periodic interrupt is disabled automatically since there is not enough time to process it when running off the 32 kHz clock.

There is also a 25 MHz Ethernet clock that is provided to the external PHY chip if you are using the Ethernet option, but this Ethernet clock is not applied directly to the Rabbit 5000. The Ethernet clock can be driven by the processor clock, the processor clock divided by 2, or by the input on PE6. The Ethernet clock needs to be 25 MHz to conform to the 10/100Base-T specification. See Chapter 22 for more details on the Ethernet clock.

## 2.1.1 Block Diagram



## 2.1.2 Registers

| Register Name                      | Mnemonic | I/O Address | R/W | Reset    |
|------------------------------------|----------|-------------|-----|----------|
| Global Control/Status Register     | GCSR     | 0x0000      | R/W | 11000000 |
| Global Clock Modulator 0 Register  | GCM0R    | 0x000A      | W   | 00000000 |
| Global Clock Modulation 1 Register | GCM1R    | 0x000B      | W   | 00000000 |
| Global Clock Double Register       | GCDR     | 0x000F      | R/W | 00000000 |

## 2.2 Dependencies

#### 2.2.1 I/O Pins

The main clock input is on the CLKI pin. There is an internal Schmitt trigger on this pin to mitigate any noise problems associated with slowly transitioning signals.

The main clock disable output is on the CLKIEN pin. Its state is changed by one of the bit combinations of bits 4:2 in GCSR. The CLKIEN pin will output low to disable an external main oscillator when the 32 kHz mode with main oscillator disabled is selected, and will output high for all other clock modes

The 32 kHz clock input is on the CLK32K pin. There is an internal Schmitt trigger on this pin as well.

The peripheral clock or peripheral clock divided by 2 may be optionally output on the CLK pin by enabling it via bits 7:6 in GOCR.

The 20 MHz Wi-Fi clock input is located on the CLK\_IN pin; a PLL multiplies clocks up to the 80 MHz required for the Wi-Fi peripheral.

### 2.2.2 Other Registers

| Register | Function                           |
|----------|------------------------------------|
| GOCR     | Used to set up the CLK output pin. |

## 2.3 Operation

### 2.3.1 Main Clock

The main clock is input on the CLKI pin, and is optionally sent through the spectrum spreader and then the clock doubler. Both of these are described in greater detail below.

Different main clock modes may be selected via the GCSR, as shown in Table 2-1. Note that one GCSR setting slows the processor clock while the peripheral clock operates at full speed; this allows some power reduction while keeping settings like serial baud rates and the PWM at their desired values.

Table 2-1. Clock Modes

| GCSR Setting | Processor Clock                                                                     | Peripheral Clock                          |
|--------------|-------------------------------------------------------------------------------------|-------------------------------------------|
| xxx010xx     | Main clock                                                                          | Main clock                                |
| xxx011xx     | Main clock / 2                                                                      | Main clock / 2                            |
| xxx110xx     | Main clock / 4                                                                      | Main clock / 4                            |
| xxx111xx     | Main clock / 6                                                                      | Main clock / 6                            |
| xxx000xx     | Main clock / 8                                                                      | Main clock / 8 (default on startup)       |
| xxx001xx     | Main clock / 8                                                                      | Main clock                                |
| xxx100xx     | 32 kHz clock (possibly divided)                                                     | 32 kHz clock (possibly divided via GPSCR) |
| xxx101xx     | 32 kHz clock (possibly divided);<br>main clock disabled via CLKIEN<br>output signal | 32 kHz clock (possibly divided via GPSCR) |

When the 32 kHz clock is enabled in GCSR, it can be further divided by 2, 4, 6, or 8 to generate even lower frequencies by enabling those modes in bits 0–2 of GPSCR. See Table 2-4 for more details.

## 2.3.2 Spectrum Spreader

When enabled, the spectrum spreader stretches and compresses the main clock in a complex pattern that spreads the energy of the clock harmonics over a wider range of frequencies.



Figure 2-1. Effects of Spectrum Spreader

There are three settings that correspond to normal and strong spreading in the 0–50 MHz and >50 MHz main clock range. Each setting will affect the clock cycle differently; the maximum cycle shortening (at 1.8 V and 25°C) is shown in Table 2-2 below.

Table 2-2. Spectrum Spreader Settings

| 0–50 MHz | > 50 MHz | GCM0R<br>Value | Description                                                                               | Max. Cycle<br>Shortening |
|----------|----------|----------------|-------------------------------------------------------------------------------------------|--------------------------|
| _        | Normal   | 0x40           | Normal spreading of frequencies over 50 MHz                                               | 2.3 ns                   |
| Normal   | Strong   | 0x00           | Normal spreading of frequencies up to 50 MHz; strong spreading of frequencies over 50 MHz | 3 ns                     |
| Strong   | _        | 0x80           | Strong spreading of frequencies up to 50 MHz; normal spreading of frequencies over 50 MHz | 4.5 ns                   |

The spectrum spreader either stretches or shrinks the low plateau of the clock by a maximum of 3 ns for the normal spreading and up to 4.5 ns for the strong spreading. If the clock doubler is used, this will cause an additional asymmetry between alternate clock cycles.

Both normal and strong modes reduce clock harmonics by approximately 15 dB for frequencies above 100 MHz; for lower frequencies the strong setting has a greater effect in reducing the peak spectral strength as shown in Figure 2-2.



Figure 2-2. Peak Spectral Amplitude Reduction by Spectrum Spreader

Two registers control the clock spectrum spreader. These registers must be loaded in a specific manner with proper time delays. GCM0R is only read by the spectrum spreader at the moment when the spectrum spreader is enabled by storing 0x080 in GCM1R. If GCM1R is cleared (when disabling the spectrum spreader), there is up to a 500-clock delay before the spectrum spreader is actually disabled. The proper procedure is to clear GCM1R, wait for 500 clocks, set GCM0R, and then enable the spreader by storing 0x080 in GCM1R.

The spectrum spreader is applied to the main clock before the clock doubler, so if both are enabled there will be additional asymmetry between alternate clock cycles. If the clock doubler is used, the spectrum spreader affects every other cycle and reduces the clock high time. If the doubler is not used, then the spreader affects every clock cycle, and the clock low time is reduced.

#### 2.3.3 Clock Doubler

The clock doubler allows a lower frequency crystal to be used for the main oscillator and to provide an added range over which the clock frequency can be adjusted. The clock doubler is controlled via the Global Clock Double Register (GCDR).

The clock doubler uses an on-chip delay circuit that must be programmed by the user at startup if there is a need to double the clock. Table 2-3 lists the recommended delays in GCDR for various oscillator or crystal frequencies.

Table 2-3. Recommended Delays Set In GCDR for Clock Doubler

| Recommended GCDR Value | Frequency Range     |
|------------------------|---------------------|
| 0x0F                   | ≤7.3728 MHz         |
| 0x0B                   | 7.3728–11.0592 MHz  |
| 0x09                   | 11.0592–16.5888 MHz |
| 0x06                   | 16.5888–20.2752 MHz |
| 0x03                   | 20.2752-52.8384 MHz |
| 0x01                   | 52.8384-77.4144 MHz |
| 0x00                   | >77.4144 MHz        |

When the clock doubler is used and there is no subsequent division of the clock, the output clock will be asymmetric, as shown in Figure 2-3.



Figure 2-3. Effect of Clock Doubler

The doubled-clock low time is subject to wide (50%) variation since it depends on process parameters, temperature, and voltage. The times given above are for a core supply voltage of 1.8 V and a temperature of 25°C. The values increase or decrease by 1% for each 5°C increase or decrease in temperature. The doubled clock is created by xor'ing the delayed and inverted clock with itself. If the original clock does not have a 50-50 duty cycle, then alternate clocks will have a slightly different length. Since the duty cycle of the built-in oscillator can be as asymmetric as 52%/48%, the clock generated by the clock doubler will exhibit up to a 4% variation in period on alternate clocks. The memory access time is not affected because the memory bus cycle is 2 clocks long and includes both a long and a short

clock, resulting in no net change due to asymmetry. However, if an odd number of wait states is used, then the memory access time will be affected slightly

The maximum allowed clock speed must be reduced slightly if the clock is supplied via the clock doubler. The only signals clocked on the falling edge of the clock are the memory and I/O write pulses, and the early option memory output enable. See Chapter 5 for more information on the early output enable and write enable options.

The power consumption is proportional to the clock frequency, and for this reason power can be reduced by slowing the clock when less computing activity is taking place. The clock doubler provides a convenient method of temporarily speeding up or slowing down the clock as part of a power management scheme.

#### 2.3.4 32 kHz Clock

The 32.768 kHz clock is used to drive the asynchronous serial bootstrap, the real-time clock, the periodic interrupt, and the watchdog timers. If these features are not used in a design, the use of the 32 kHz clock is optional.

A simplified version of the recommended oscillator circuit for the Rabbit 5000 is shown below. The values of resistors and capacitors may need to be adjusted for various frequencies and crystal load capacitances. Technical Note TN235, "External 32.768 kHz Oscillator Circuits", is available on the Rabbit Web site and goes into this circuit in detail.



Figure 2-4. Basic 32.768 kHz Oscillator Circuit

The 32.768 kHz circuit consumes microampere-level currents and has a very high impedance, making it susceptible to noise, moisture, and environmental contaminants. It is strongly recommended to conformally coat this circuit to limit the effects of humidity and dust on the oscillation frequency. Details about this requirement are available in Technical Note TN303, "Conformal Coating", from the Rabbit Web site.

The 32.768 kHz oscillator is slow to start oscillating after power-on. The startup delay may be as much as 5 seconds. For this reason, a wait loop in the BIOS waits until this oscillator is oscillating regularly before continuing the startup procedure. If the clock is battery-backed, there will be no startup delay since the oscillator is already oscillating. Crystals with low series resistance ( $R < 35 \text{ k}\Omega$ ) will start faster.

The 32 kHz oscillator can be used to drive the processor and the peripheral clock to provide significant power savings in "ultra-sleepy" modes. The 32 kHz oscillator can be divided by 2, 4, 8, or 16 to provide clock speeds as low as 2.048 kHz. Special self-timed chip selects are available to keep the memory devices enabled for as short a time as possible when an ultra-sleepy mode is enabled; see Chapter 29 for more details on reducing power consumption.

Table 2-4. Ultra-Sleepy Clock Modes

| GPSCR<br>Setting | Processor and<br>Peripheral Clock |  |  |
|------------------|-----------------------------------|--|--|
| xxxxx000         | 32.768 kHz                        |  |  |
| xxxxx100         | 16.384 kHz                        |  |  |
| xxxxx101         | 8.192 kHz                         |  |  |
| xxxxx110         | 4.096 kHz                         |  |  |
| xxxxx111         | 2.048 kHz                         |  |  |

When the 32 kHz clock is enabled, the periodic interrupt is disabled automatically. The real-time clock and watchdog timers keep running, and use the full 32 kHz clock speed even when the processor and peripheral clocks use a divider on the 32 kHz clock.

# 2.4 Register Descriptions

| Global Control/Status Register (GCSR) (Address = 0x0000) |                                                                                                                                     |                                                                                                                                                                          |  |  |
|----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit(s)                                                   | Value                                                                                                                               | Description                                                                                                                                                              |  |  |
| 7:6                                                      | 00                                                                                                                                  | No reset or watchdog timer timeout since the last read.                                                                                                                  |  |  |
| (rd-only)                                                | 01                                                                                                                                  | The watchdog timer timed out. These bits are cleared by a read of this register                                                                                          |  |  |
|                                                          | 10                                                                                                                                  | This bit combination is not possible.                                                                                                                                    |  |  |
|                                                          | 11                                                                                                                                  | Reset occurred. These bits are cleared by a read of this register.                                                                                                       |  |  |
| 5                                                        | 0                                                                                                                                   | No effect on the periodic interrupt. This bit will always be read as zero.                                                                                               |  |  |
|                                                          | 1                                                                                                                                   | Force a periodic interrupt to be pending.                                                                                                                                |  |  |
| 4:2                                                      | 000                                                                                                                                 | Processor clock from the main clock, divided by 8. Peripheral clock from the main clock, divided by 8.                                                                   |  |  |
|                                                          | 001                                                                                                                                 | Processor clock from the main clock, divided by 8. Peripheral clock from the main clock.                                                                                 |  |  |
|                                                          | 010                                                                                                                                 | Processor clock from the main clock. Peripheral clock from the main clock.                                                                                               |  |  |
|                                                          | 011                                                                                                                                 | Processor clock from the main clock, divided by 2. Peripheral clock from the main clock, divided by 2.                                                                   |  |  |
|                                                          | Processor clock from the 32 kHz clock, optionally divided via G<br>Peripheral clock from the 32 kHz clock, optionally divided via G |                                                                                                                                                                          |  |  |
| 101                                                      |                                                                                                                                     | Processor clock from the 32 kHz clock, optionally divided via GPSCR.  Peripheral clock from the 32 kHz clock, optionally divided via GPSCR.  The main clock is disabled. |  |  |
|                                                          | 110                                                                                                                                 | Processor clock from the main clock, divided by 4. Peripheral clock from the main clock, divided by 4.                                                                   |  |  |
|                                                          | Processor clock from the main clock, divided by 6. Peripheral clock from the main clock, divided by 6.                              |                                                                                                                                                                          |  |  |
| 1:0                                                      | 00                                                                                                                                  | Periodic interrupts are disabled.                                                                                                                                        |  |  |
|                                                          | 01                                                                                                                                  | Periodic interrupts use Interrupt Priority 1.                                                                                                                            |  |  |
|                                                          | 10                                                                                                                                  | Periodic interrupts use Interrupt Priority 2.                                                                                                                            |  |  |
|                                                          | 11                                                                                                                                  | Periodic interrupts use Interrupt Priority 3.                                                                                                                            |  |  |

| Glob   | al Clock M | odulator 0 Register                                    | (GCM0R)               | (Address = 0x000A)            |
|--------|------------|--------------------------------------------------------|-----------------------|-------------------------------|
| Bit(s) | Value      |                                                        | Description           |                               |
| 7:6    | 00         | Clock dither in 1 ns steps function is enabled.        | from 0 ns to 26 ns. D | o not modify while the dither |
|        | 01         | Clock dither in 0.5 ns steps, from 0 ns to 13 ns.      |                       |                               |
|        | 10         | Clock dither in 2 ns steps, from 0 ns to 52 ns.        |                       |                               |
|        | 11         | This bit combination is reserved and must not be used. |                       |                               |
| 5:0    |            | These bits are reserved an                             | d should be written w | ith zeros.                    |

| Globa  | al Clock M | odulator 1 Register                                                                                                                     | (GCM1R)                | (Address = 0x000B) |
|--------|------------|-----------------------------------------------------------------------------------------------------------------------------------------|------------------------|--------------------|
| Bit(s) | Value      |                                                                                                                                         | Description            |                    |
| 7      | 0          | Disable the clock dither function. The disable does not take effect until the dither pattern has returned to the 0 ns base delay value. |                        |                    |
|        | 1          | Enable the clock dither function.                                                                                                       |                        |                    |
| 6:0    |            | These bits are reserved as                                                                                                              | nd should be written w | vith zeros.        |

| Global Clock Double Register (GC |       |                                                                  | (GCDR)                                           | (Address = 0x000F) |
|----------------------------------|-------|------------------------------------------------------------------|--------------------------------------------------|--------------------|
| Bit(s)                           | Value | Description                                                      |                                                  |                    |
| 7:5                              |       | These bits are reserved and s                                    | should be written wi                             | ith zeros.         |
| 4:0                              | 00000 | The clock doubler circuit is                                     | disabled.                                        |                    |
|                                  | 00001 | 6 ns nominal low time.                                           |                                                  |                    |
|                                  | 00010 | 7 ns nominal low time.                                           |                                                  |                    |
|                                  | 00011 | 8 ns nominal low time.                                           |                                                  |                    |
|                                  | 00100 | 9 ns nominal low time.                                           |                                                  |                    |
|                                  | 00101 | 10 ns nominal low time.                                          |                                                  |                    |
|                                  | 00110 | 11 ns nominal low time.                                          |                                                  |                    |
|                                  | 00111 | 12 ns nominal low time.                                          |                                                  |                    |
|                                  | 01000 | 13 ns nominal low time.  14 ns nominal low time.                 |                                                  |                    |
|                                  | 01001 |                                                                  |                                                  |                    |
|                                  | 01010 | 15 ns nominal low time.                                          | 15 ns nominal low time.  16 ns nominal low time. |                    |
|                                  | 01011 | 16 ns nominal low time.                                          |                                                  |                    |
|                                  | 01100 | 17 ns nominal low time.                                          |                                                  |                    |
|                                  | 01101 | 18 ns nominal low time.                                          |                                                  |                    |
|                                  | 01110 | 19 ns nominal low time.                                          |                                                  |                    |
|                                  | 01111 | 20 ns nominal low time.                                          |                                                  |                    |
|                                  | 10001 | 3 ns nominal low time.                                           |                                                  |                    |
|                                  | 10010 | 4 ns nominal low time.                                           |                                                  |                    |
|                                  | 10011 | 5 ns nominal low time.                                           |                                                  |                    |
|                                  | other | Any bit combination not listed is reserved and must not be used. |                                                  |                    |

| Glo    | bal Outpu | t Control Register (GOCR) (Address = 0x000E)                 |  |  |
|--------|-----------|--------------------------------------------------------------|--|--|
| Bit(s) | Value     | Description                                                  |  |  |
| 7:6    | 00        | CLK pin is driven with peripheral clock.                     |  |  |
|        | 01        | CLK pin is driven with peripheral clock divided by 2.        |  |  |
|        | 10        | CLK pin is low.                                              |  |  |
|        | 11        | CLK pin is high.                                             |  |  |
| 5:4    | 00        | STATUS pin is active (low) during a first opcode byte fetch. |  |  |
|        | 01        | STATUS pin is active (low) during an interrupt acknowledge.  |  |  |
|        | 10        | STATUS pin is low.                                           |  |  |
|        | 11        | STATUS pin is high.                                          |  |  |
| 3:2    | 00        | /WDTOUT pin functions normally.                              |  |  |
|        | 01        | Enable /WDTOUT for test mode. Rserved for internal use only. |  |  |
|        | 10        | /WDTOUT pin is low (1 cycle min, 2 cycles max, of 32 kHz).   |  |  |
|        | 11        | This bit combination is reserved and should not be used.     |  |  |
| 1:0    | 00        | /BUFEN pin is active (low) during external I/O cycles.       |  |  |
|        | 01        | /BUFEN pin is active (low) during data memory accesses.      |  |  |
|        | 10        | /BUFEN pin is low.                                           |  |  |
|        | 11        | /BUFEN pin is high.                                          |  |  |

# 3. RESET AND BOOTSTRAP

### 3.1 Overview

The Rabbit 5000's /RESET pin initializes everything in the processor except for the real-time clock registers and the contents of the battery-backed onchip-encryption RAM. If a write cycle is in progress, it waits until the write cycle is completed to avoid potential memory corruption.

After reset, the Rabbit 5000 checks the state of the SMODE and SYSCFG pins. Depending on the state of the SMODE pins, it either begins normal operation by fetching instruction bytes from memory bank zero, which is mapped to either /CS0 or /CS3 depending on the state of the SYSCFG0 pin, or it enters a special bootstrap mode where it fetches bytes from either Serial Port A or the slave port. In this mode, bytes can be written to internal registers to set up the Rabbit 5000 for a particular configuration, or to memory to load a program. The processor can begin normal operation once the bootstrap operation is completed.

# 3.1.1 Block Diagram





# 3.1.2 Registers

| Register Name               | Mnemonic | I/O Address | R/W | Reset    |
|-----------------------------|----------|-------------|-----|----------|
| Slave Port Control Register | SPCR     | 0x0024      | R/W | 0xx00000 |

38

# 3.2 Dependencies

### 3.2.1 I/O Pins

SMODE0, SMODE1 — When the Rabbit 5000 is first powered up or when it is reset, the state of the SMODE0 and SMODE1 pins controls its operation.

SYSCFG0 — When the Rabbit 5000 is first powered up or when it is reset, the state of this pin controls whether memory bank zero is mapped to /CS0 or the internal SRAM (/CS3).

SYSCFG1 — This pin should always be tied to ground.

/RESET — Pulling the /RESET pin low will initialize everything in the Rabbit 5000 except for the real-time clock registers and the onchip-encryption RAM.

/CS1 — During reset the impedance of the /CS1 pin is high, and all other memory and I/O control signals are held high. The special behavior of /CS1 allows an external RAM to be powered by the same source as the VBATIO pin (which powers /CS1). In this case, a pullup resistor is required on /CS1 to keep the RAM deselected during powerdown.

RESOUT — The RESOUT pin, which is powered by the backup battery, is high during reset and powerdown as long as VBAT and VBATIO are present, but low at all other times, and can be used to control an external power switch to disconnect VDDIO from VBATIO when the main power source is removed.

#### 3.2.2 Clocks

The processor requires a 32 kHz clock input to generate the 2400 bps internal clock required for asynchronous serial bootstrap, which is used when booting via Dynamic C and the Rabbit Field Utility. No 32 kHz clock is required for either clocked serial or slave port bootstrap.

When the processor comes out of reset, the CPU clock and peripheral clocks are both in divide-by-8 mode.

# 3.2.3 Other Registers

| Register    | Function                                                                             |  |
|-------------|--------------------------------------------------------------------------------------|--|
| <u>SPCR</u> | Enable/disable processor monitoring of SMODE pins; read current state of SMODE pins. |  |

## 3.2.4 Interrupts

There are no interrupts associated with reset or bootstrap.

# 3.3 Operation

Pulling the /RESET pin low will initialize everything in the Rabbit 5000 except for the real-time clock registers and the onchip-encryption RAM. The reset of the Rabbit 5000 is delayed until any write cycles in progress are completed; the reset takes effect as soon as no write cycles are occurring. The reset sequence requires a minimum of 128 cycles of the main clock to complete in either case.

During reset, the impedance of the /CS1 pin is high and all other memory and I/O control signals are held high. The special behavior of /CS1 allows an external RAM to be powered by the same source as the VBATIO pin (which powers /CS1). In this case, a pullup resistor is required on /CS1 to keep the RAM deselected during powerdown. The RESOUT pin, which is powered by the backup battery, is high during reset and powerdown as long as VBAT and VBATIO are present, but low at all other times, and can be used to control an external power switch to disconnect VDDIO from VBATIO when the main power source is removed.

Table 3-1 lists the condition of the processor after reset takes place. The state of all registers after reset is provided in the chapter describing the specific peripheral.

Table 3-1. Rabbit 5000 Condition After Reset

| Function                                       | Operation After Reset                         |  |
|------------------------------------------------|-----------------------------------------------|--|
| CPU Clock,<br>Peripheral Clock                 | Divide-by-8 mode                              |  |
| Clock Doubler,<br>Clock Dither                 | Disabled                                      |  |
| Memory Bank 0<br>Control Register              | /CS0, /OE0, write-protected,<br>4 wait states |  |
| Memory Advanced<br>Control Register            | 8-bit interface                               |  |
| CPU Registers:<br>PC, SP, IIR, EIR,<br>SU, HTR | 0x0000                                        |  |
| Interrupt Priority<br>(IP Register)            | 0xFF (Priority 3)                             |  |
| Watchdog Timer                                 | Enabled (2 seconds)                           |  |
| Secondary<br>Watchdog Timer                    | Disabled                                      |  |

The processor checks the SMODE and SYSCFG0 pins after the /RESET signal is inactive. Table 3-2 summarizes what happens.

Table 3-2. SMODE Pin Settings

| SMODE Pins [1,0] | SYSCFG0 | Operation                                                                                                                |
|------------------|---------|--------------------------------------------------------------------------------------------------------------------------|
| 00               | 0       | No bootstrap; code is fetched from address 0x0000 on /CS0, /OE0.                                                         |
| 00               | 1       | No bootstrap; code is fetched from address 0x0000 on /CS3, /OE0. The internal SRAM is enabled as a 16-bit memory device. |
| 01               | X       | Bootstrap from the slave port.                                                                                           |
| 10               | X       | Bootstrap from Serial Port A, serial flash mode.                                                                         |
| 11               | X       | Bootstrap from Serial Port A, asynchronous mode.                                                                         |

If both SMODE pins are zero, the Rabbit 5000 begins fetching instructions from the memory device mapped into memory bank 0. When SYSCFG0 is low, memory bank 0 is set to /CS0 and /OE0. If SYSCFG0 is high, memory bank 0 is set to /CS3 and /OE0, and the internal SRAM is selected in 16-bit mode. If a 16-bit memory is used in memory bank 0, the first section of code must immediately select the 16-bit bus mode. Chapter 5 provides a short sample program to do this.

If either of the SMODE pins is high, the processor will enter the bootstrap mode and accept triplets from Serial Port A, the serial flash bootstrap port, or the slave port, depending on the SMODE pin selection. It is good practice to place pulldown resistors on the SMODE pins to ensure the proper operation of your design.

In the bootstrap mode, the processor inhibits the normal memory fetch, and instead fetches instructions from a small internal boot ROM. This program reads triplets of three bytes from the selected peripheral. The first byte is the most-significant byte of a 16-bit address, the second byte is the least-significant byte of the address, and the third byte is the data to be written. If the uppermost bit of the address is 1, then the address is assumed to be an internal register address instead of a memory address, and the data are written to the appropriate register instead. For example, a triplet of (0x04, 0x34, 0x5A) will write 0x5A to logical memory address 0x0434, while a triplet of (0x80, 0x34, 0x5A) will write 0x5A to processor register 0x34. Processor registers with addresses above 0xFF are not accessible in the bootstrap mode.

The boot ROM program waits for data to be available; each byte received automatically resets the watchdog timer with a 2-second timeout. Bytes must be received quickly enough to prevent timeout (or the watchdog must be disabled).

The device checks the state of the SMODE pins each time it jumps back to the start of the ROM program and responds according to the current state. In addition, by setting bit 7 of

the Slave Port Control Register (SPCR) high, the processor can be told to ignore the state of the SMODE pins and continue normal operation.

Note that the processor can be told to re-enter bootstrap mode at any time by setting bit 7 of SPCR low; once this occurs and the least significant four bits of the current PC address are zero, the processor will sample the state of the SMODE pins and respond accordingly. This feature allows in-line downloading from the selected bootstrap port; once the download is complete, bit 7 of SPCR can be set high and the processor will continue operating from where it left off

As a security feature, any attempt to enter the bootstrap mode from either the SMODE pins or by writing to bit 7 of the SPCR will erase the data stored in the onchip-encryption RAM. This prevents loading a small program in memory to read out the data.

## 3.3.1 Asynchronous Serial Bootstrap

When the *asynchronous serial bootstrap mode* is selected by the SMODE pins, the Rabbit 5000 will being accepting triplets at 2400 bps on Serial Port A. The baud rate is generated from the 32 kHz clock input, so a 32 kHz clock is required for this mode.

## 3.3.2 Serial Flash Bootstrap

When the *serial flash bootstrap mode* is selected by the SMODE pins, the Rabbit 5000 will enable the SPI serial flash bootstrap port on pins PD4, PD5, PD6, and PB0; the pins' functionality is listed in Table 3-3 below. Note that these pins can be used for Serial Port B in normal operation, so the serial flash may use the serial port as a regular serial port if desired.

| Pin | SPI Signal | Operation                               |  |
|-----|------------|-----------------------------------------|--|
| PD4 | MOSI       | Rabbit data transmit (to serial flash)  |  |
| PD5 | MISO       | Rabbit data receive (from serial flash) |  |
| PD6 | CS         | Chip select (to serial flash)           |  |
| PB0 | SCK        | Serial clock (output to serial flash)   |  |

Table 3-3. Serial Flash Bootstrap Pin Functions

The Rabbit 5000 divides the main clock by 64 to provide the SPI clock for the serial flash bootstrap. Once this mode is entered, the Rabbit 5000 will send the byte sequence "0x03 0x00 0x00 0x00", which is an industry-standard command that enables continuous read mode starting at serial flash address 0x0. Figure 3-1 provides a sample timing diagram. The Rabbit 5000 will then read triplets out of the serial flash until the bootstrap mode is exited.



Figure 3-1. SPI Timing Diagram for Serial Flash Bootstrap Mode

# 3.3.3 Parallel Bootstrap

When the *parallel bootstrap mode* is selected by the SMODE pins, the Rabbit 5000 will enable the parallel slave port interface on Parallel Ports A and B, and will wait for triplets to be sent to that interface. See Chapter 19 for more details on the operation of the slave port.

# 3.4 Register Descriptions

| S      | lave Port ( | Control Register (SPCR) (Address = 0x0024)                                                                                  |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit(s) | Value       | Description                                                                                                                 |  |  |
| 7      | 0           | Program fetch as a function of the SMODE pins.                                                                              |  |  |
|        | 1           | Ignore the SMODE pins program fetch function.                                                                               |  |  |
| 6:5    | Read        | These bits report the state of the SMODE pins.                                                                              |  |  |
|        | Write       | These bits are ignored and should be written with zero.                                                                     |  |  |
| 4:2    | 000         | Disable the slave port. Parallel Port A is a byte-wide input port.                                                          |  |  |
|        | 001         | Disable the slave port. Parallel Port A is a byte-wide output port.                                                         |  |  |
|        | 010         | Enable the slave port, with /SCS from Parallel Port E bit 7.                                                                |  |  |
|        | 011         | Enable the external I/O bus. Parallel Port A is used for the data bus and Parallel Port B[7:2] is used for the address bus. |  |  |
|        | 100         | This bit combination is reserved and should not be used.                                                                    |  |  |
|        | 101         | This bit combination is reserved and should not be used.                                                                    |  |  |
|        | 110         | Enable the slave port, with /SCS from Parallel Port B bit 6.                                                                |  |  |
|        | 111         | Enable the external I/O bus. Parallel Port A is used for the data bus and Parallel Port B[7:0] is used for the address bus. |  |  |
| 1:0    | 00          | Slave port interrupts are disabled.                                                                                         |  |  |
|        | 01          | Slave port interrupts use Interrupt Priority 1.                                                                             |  |  |
|        | 10          | Slave port interrupts use Interrupt Priority 2.                                                                             |  |  |
|        | 11          | Slave port interrupts use Interrupt Priority 3.                                                                             |  |  |

# 4. System Management

#### 4.1 Overview

There are a number of basic system peripherals in the Rabbit 5000 processor, some of which are covered in later chapters. The peripherals covered in this chapter are the periodic interrupt, the real-time clock, the watchdog timers, the battery-backed onchip-encryption RAM, and some of the miscellaneous output pins and their control and processor registers that provide the processor ID and revision numbers.

The periodic interrupt, when enabled, is generated every 16 clocks of the 32 kHz clock (every 488 μs, or 2.048 kHz). This interrupt can be used to perform periodic tasks.

The real-time clock (RTC) consists of a 48-bit counter that is clocked by the 32 kHz clock. It is powered by the VBAT pin, and so can be battery-backed. The value in the counter is not affected by reset, and can only be set to zero by writing to the RTC control register. The 48-bit width provides a 272-year span before rollover occurs.

There are two watchdog timers in the Rabbit 5000, both clocked by the 32 kHz clock. The main watchdog timer can be set to time out from 250 ms to 2 seconds, and resets the processor if not reloaded within that time. Its purpose is to restart the processor when it detects that a program gets stuck or disabled.

The secondary watchdog timer can time out from 30.5 µs up to 7.8 ms, and generates a Priority 3 secondary watchdog interrupt when it is not reset within that time. The primary use for the secondary watchdog is to act as a safety net for the periodic interrupt — if the secondary watchdog is reloaded in the periodic interrupt, it will count down to zero if the periodic interrupt stops occurring. In addition, it can be used as a periodic interrupt on its own.

The battery-backed onchip-encryption RAM consists of 32 bytes of memory that are powered by the VBAT pin. Their values are not affected by reset, but are erased if the state of the SMODE pins changes. These 32 bytes are intended for storing sensitive data (such as an encryption key) somewhere other than an external memory device. The "tamper-protection" erase feature prevents loading a program into the onchip-encryption RAM via the programming port and reading out the bytes.

The following other registers are also described in this chapter.

- Global Output Control Register (GOCR), which controls the behavior of the CLK, STATUS, /WDT, and /BUFEN pins
- Global CPU Register (GCPU), which holds the identification number of the processor.
- Global Revision Register (GREV), which hold the revision number of the processor.

# 4.1.1 Block Diagram



# 4.1.2 Registers

| Register Name                                   | Mnemonic          | I/O Address   | R/W | Reset    |
|-------------------------------------------------|-------------------|---------------|-----|----------|
| Global Control/Status Register                  | GCSR              | 0x0000        | R/W | 11000000 |
| Real-Time Clock Control Register                | RTCCR             | 0x0001        | W   | 00000000 |
| Real-Time Clock Byte 0 Register                 | RTC0R             | 0x0002        | R/W | xxxxxxx  |
| Real-Time Clock Byte 1 Register                 | RTC1R             | 0x0003        | R   | xxxxxxx  |
| Real-Time Clock Byte 2 Register                 | RTC2R             | 0x0004        | R   | xxxxxxxx |
| Real-Time Clock Byte 3 Register                 | RTC3R             | 0x0005        | R   | xxxxxxx  |
| Real-Time Clock Byte 4 Register                 | RTC4R             | 0x0006        | R   | xxxxxxx  |
| Real-Time Clock Byte 5 Register                 | RTC5R             | 0x0007        | R   | xxxxxxx  |
| Watchdog Timer Control Register                 | WDTCR             | 0x0008        | W   | 00000000 |
| Watchdog Timer Test Register                    | WDTTR             | 0x0009        | W   | 00000000 |
| Secondary Watchdog Timer Register               | SWDTR             | 0x000C        | W   | 11111111 |
| Global Output Control Register                  | GOCR              | 0x000E        | R/W | 00000000 |
| Global ROM Configuration Register               | GROM              | 0x002C        | R   | 0xx00000 |
| Global RAM Configuration Register               | GRAM              | 0x002D        | R   | 0xx00000 |
| Global CPU Configuration Register               | GCPU              | 0x002E        | R   | 0xx00010 |
| Global Revision Register                        | GREV              | 0x002F        | R   | 0xx00000 |
| Battery-Backed Onchip-Encryption RAM Byte 00–1F | VRAM00–<br>VRAM1F | 0x0600-0x061F | R/W | xxxxxxxx |

# 4.2 Dependencies

### 4.2.1 I/O Pins

The CLK, STATUS, /WDTOUT, and /BUFEN pins are controlled by GOCR. Each of these pins can be used as general-purpose outputs by driving them high or low.

- The CLK pin can output the peripheral clock, the peripheral clock divided by two, or be driven high or low.
- The STATUS pin can be active low during the first byte of each opcode fetch, active low during an interrupt acknowledge, or driven high or low.
- The /WDTOUT pin can be active low whenever the watchdog timer resets the device or driven low.
- The /BUFEN pin can be active low during external I/O cycles, active low during data memory cycles, or driven high or low.

The values in the battery-backed onchip-encryption RAM bytes are cleared if the signal on the SMODE pins changes state.

#### 4.2.2 Clocks

The periodic interrupt, real-time clock, watchdog timer, and secondary watchdog timer require the 32 kHz clock.

# 4.2.3 Interrupts

The periodic interrupt is enabled in GCSR, and will occur every 488 μs. It is cleared by reading GCSR. It can operate at Priority 1, 2, or 3.

The secondary watchdog interrupt will occur whenever the secondary watchdog is enabled and allowed to count down to zero. It is cleared by restarting the secondary watchdog by writing to WDTCR. The secondary watchdog interrupt always occurs at Priority 3.

# 4.3 Operation

## 4.3.1 Periodic Interrupt

The following steps explain how a periodic interrupt is used.

- 1. Write the vector to the interrupt service routine to the internal interrupt table.
- 2. Enable the periodic interrupt by writing to GCSR.
- 3. The interrupt request is cleared by reading from GCSR.

A sample interrupt handler is shown below.

```
periodic_isr::
   push af
   ioi ld a, (GCSR)    ; clear the interrupt request and get status
   ; handle any periodic tasks here

   pop af
   ipres
   ret
```

#### 4.3.2 Real-Time Clock

The real-time clock consists of six 8-bit registers that together comprise a 48-bit value. The real-time clock is not synchronized to the read operation, so the least-significant bit should be read twice and checked for matching values; if the two reads do not match, then the real-time clock may have been updating during the read and should be read again.

Writing to RTC0R latches the current real-time clock value into the RTCxR holding registers, so the following sequence should be used to read the real-time clock.

- 1. Write any value to RTC0R and then read back a value from RTC0R.
- 2. Write a value to RTC0R again, and again read back a value from RTC0R.
- 3. If the two values do not match, repeat Step 2 until the last two readings are identical.
- 4. At this point, registers RTC1R through RTC6R can also be read and used.

Note that the periodic interrupt and the real-time clock are clocked by the same edge of the 32 kHz clock; if read from the periodic interrupt, the count is guaranteed to be stable and only needs to be read once (assuming it occurs within one clock of the 32 kHz clock).

The real-time clock can be reset by writing the sequence 0x40 - 0x80 to RTCCR. It can be reset and left in the byte increment mode by writing 0x40 - 0xC0 to RTCCR and then writing bytes repeatedly to RTCCR to increment the appropriate bytes of the real-time clock. The byte increment mode is disabled by writing 0x00 to RTCCR.

## 4.3.3 Watchdog Timer

The watchdog timer is enabled on reset with a 2-second timeout. Unless specific data are written to WDTCR before that time expires, the processor will be reset. The watchdog timer can be disabled by writing a sequence of two bytes to WDTTR as described in the register description.

 WDTCR Value
 Effect

 0x5A
 Restart watchdog timer with 2-second timeout.

 0x57
 Restart watchdog timer with 1-second timeout.

 0x59
 Restart watchdog timer with 500-millisecond timeout.

 0x53
 Restart watchdog timer with 250-millisecond timeout.

 0x5F
 Restart the secondary watchdog timer.

Table 4-1. Watchdog Timer Settings

The watchdog timer also contains a special test mode that speeds up the timeout period by clocking it with the peripheral clock instead of the 32 kHz clock. This mode can be enabled by writing to WDTTR.

## 4.3.4 Secondary Watchdog Timer

The secondary watchdog timer is disabled on reset. The following steps explain how to use the secondary watchdog timer.

- 1. Write the vector to the interrupt service routine to the internal interrupt table.
- 2. Write the desired timeout period to SWDTR. This also enables the secondary watchdog timer
- 3. Restart the secondary watchdog timer by either writing the timeout period to SWDTR or writing 0x5F to WDTCR.

If the secondary watchdog timer counts down to zero, a Priority 3 secondary watchdog interrupt will occur. This interrupt request is cleared by writing a new timeout value to SWDTR. A sample interrupt handler is shown below.

# 4.4 Register Descriptions

| bal Contr | ol/Status Register (GCSR) (Address = 0x0000)                                                                                                                             |  |  |  |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Value     | Description                                                                                                                                                              |  |  |  |
| 00        | No reset or watchdog timer timeout since the last read.                                                                                                                  |  |  |  |
| 01        | The watchdog timer timed out. These bits are cleared by a read of this register.                                                                                         |  |  |  |
| 10        | his bit combination is not possible.                                                                                                                                     |  |  |  |
| 11        | Reset occurred. These bits are cleared by a read of this register.                                                                                                       |  |  |  |
| 0         | No effect on the periodic interrupt. This bit will always be read as zero.                                                                                               |  |  |  |
| 1         | Force a periodic interrupt to be pending.                                                                                                                                |  |  |  |
| 000       | Processor clock from the main clock, divided by eight.  Peripheral clock from the main clock, divided by eight.                                                          |  |  |  |
| 001       | Processor clock from the main clock, divided by eight.  Peripheral clock from the main clock.                                                                            |  |  |  |
| 010       | Processor clock from the main clock.  Peripheral clock from the main clock.                                                                                              |  |  |  |
| 011       | Processor clock from the main clock, divided by two.  Peripheral clock from the main clock, divided by two.                                                              |  |  |  |
| 100       | Processor clock from the 32 kHz clock, optionally divided via GPSCR.  Peripheral clock from the 32 kHz clock, optionally divided via GPSCR.                              |  |  |  |
| 101       | Processor clock from the 32 kHz clock, optionally divided via GPSCR.  Peripheral clock from the 32 kHz clock, optionally divided via GPSCR.  The main clock is disabled. |  |  |  |
| 110       | Processor clock from the main clock, divided by four.  Peripheral clock from the main clock, divided by four.                                                            |  |  |  |
| 111       | Processor clock from the main clock, divided by six.  Peripheral clock from the main clock, divided by six.                                                              |  |  |  |
| 00        | Periodic interrupts are disabled.                                                                                                                                        |  |  |  |
| 01        | Periodic interrupts use Interrupt Priority 1.                                                                                                                            |  |  |  |
| 10        | Periodic interrupts use Interrupt Priority 2.                                                                                                                            |  |  |  |
| 11        | Periodic interrupts use Interrupt Priority 3.                                                                                                                            |  |  |  |
|           | Value  00 01 10 11 00 1 000 001 010 011 100 111 000 101 110 110                                                                                                          |  |  |  |

| Real   | -Time Cloc | ck Control Register (RTCCR) (Address = 0x0001)                                                                                                                         |  |  |
|--------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit(s) | Value      | Description                                                                                                                                                            |  |  |
| 7:0    | 0x00       | No effect on the real-time clock counter, or disable the byte increment function, or cancel the real-time clock reset command.                                         |  |  |
|        | 0x40       | Arm the real-time clock for reset or byte increment. This command must be written prior to either the real-time clock reset command or the first byte increment write. |  |  |
|        | 0x80       | Reset all six bytes of the real-time clock counter to 0x00. The reset must be preceded by writing 0x40 to arm the reset function.                                      |  |  |
|        | 0xC0       | Reset all six bytes of the real-time clock counter to 0x00, and remain in byte-increment mode in preparation for setting the time.                                     |  |  |
| 7:6    | 01         | This bit combination must be used with every byte-increment write.                                                                                                     |  |  |
| 5:0    | 0          | No effect on the real-time clock counter.                                                                                                                              |  |  |
|        | 1          | Increment the corresponding byte of the real-time clock counter.                                                                                                       |  |  |

| R      | eal-Time C | lock x Register                                                                                                                         | (RTC0R)<br>(RTC1R)<br>(RTC2R)<br>(RTC3R)<br>(RTC4R)<br>(RTC5R) | (Address = 0x0002)<br>(Address = 0x0003)<br>(Address = 0x0004)<br>(Address = 0x0005)<br>(Address = 0x0006)<br>(Address = 0x0007 |
|--------|------------|-----------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|
| Bit(s) | Value      | Description                                                                                                                             |                                                                |                                                                                                                                 |
| 7:0    | Read       | The current value of the 48-bit real-time clock counter is returned.                                                                    |                                                                |                                                                                                                                 |
|        | Write      | Writing to RTC0R transfers the current count of the real-time clock to a holding register while the real-time clock continues counting. |                                                                |                                                                                                                                 |

| Wate   | chdog Tim | er Control Register                                        | (WDTCR)                 | (Address = 0x0008) |
|--------|-----------|------------------------------------------------------------|-------------------------|--------------------|
| Bit(s) | Value     | Description                                                |                         |                    |
| 7:0    | 0x5A      | Restart the watchdog time                                  | er with a 2-second time | eout period.       |
|        | 0x57      | Restart the watchdog timer with a 1-second timeout period. |                         |                    |
|        | 0x59      | Restart the watchdog timer with a 500 ms timeout period.   |                         |                    |
|        | 0x53      | Restart the watchdog timer with a 250 ms timeout period.   |                         |                    |
|        | 0x5F      | Restart the secondary watchdog timer.                      |                         |                    |
|        | other     | No effect on watchdog tin                                  | ner or secondary watch  | ndog timer.        |

| Wa     | tchdog Tir | ner Test Register                                                                                                                                                                                                                                                                                                  | (WDTTR)                | (Address = 0x0009)                 |
|--------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|------------------------------------|
| Bit(s) | Value      | Description                                                                                                                                                                                                                                                                                                        |                        |                                    |
| 7:0    | 0x51       | Clock the least significan                                                                                                                                                                                                                                                                                         | t byte of the watchdog | g timer from the peripheral clock. |
|        | 0x52       | Clock the most significan                                                                                                                                                                                                                                                                                          | t byte of the watchdog | g timer from the peripheral clock. |
|        | 0x53       | Clock both bytes of the watchdog timer, in parallel, from the peripheral clock.                                                                                                                                                                                                                                    |                        |                                    |
|        | 0x54       | Disable the watchdog timer. This value, by itself, does not disable the watchdog timer. Only a sequence of two writes, where the first write is 0x51, 0x52, or 0x53, followed by a write of 0x54, actually disables the watchdog timer. The watchdog timer will be re-enabled by any other write to this register. |                        |                                    |
|        | other      | Normal clocking (32 kHz clock) for the watchdog timer.                                                                                                                                                                                                                                                             |                        |                                    |

| Secon  | Secondary Watchdog Timer Register |                                                              | (SWDTR)                                                                | (Address = 0x000C)                                                                                                                |  |  |
|--------|-----------------------------------|--------------------------------------------------------------|------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit(s) | Value                             | Description                                                  |                                                                        |                                                                                                                                   |  |  |
| 7:0    |                                   | will take effect the next tin<br>to zero. The timer counts n | me that the secondary nodulo $n + 1$ , where $n$ timer can be disabled | imer is stored. This time constant watchdog counter counts down is the programmed time constant. by writing the sequence $0x5A -$ |  |  |

| Globa           | I ROM Cor | nfiguration Register                           | (Address = 0x002C) |  |  |  |
|-----------------|-----------|------------------------------------------------|--------------------|--|--|--|
| Bit(s)          | Value     | Description                                    |                    |  |  |  |
| 7               | 0         | Program fetch as a function of the SMODE pins. |                    |  |  |  |
| (Read-<br>only) | 1         | Ignore the SMODE pins program fetch function.  |                    |  |  |  |
| 6:5             | Read      | These bits report the state of the SMODE pins. |                    |  |  |  |
| 4:0             | 00000     | ROM identifier for this vers                   | ion of the chip.   |  |  |  |

| Globa           | I RAM Cor | nfiguration Register                           | (GRAM)               | (Address = 0x002D) |  |  |
|-----------------|-----------|------------------------------------------------|----------------------|--------------------|--|--|
| Bit(s)          | Value     | Description                                    |                      |                    |  |  |
| 7               | 0         | Program fetch as a function of the SMODE pins. |                      |                    |  |  |
| (Read-<br>only) | 1         | Ignore the SMODE pins program fetch function.  |                      |                    |  |  |
| 6:5             | Read      | These bits report the state of the SMODE pins. |                      |                    |  |  |
| 4:0             | 00001     | RAM identifier for this v                      | rersion of the chip. |                    |  |  |

| Glo    | bal Outpu             | t Control Register (GOCR) (Address = 0x000E)                  |  |  |  |  |  |
|--------|-----------------------|---------------------------------------------------------------|--|--|--|--|--|
| Bit(s) | Value                 | Description                                                   |  |  |  |  |  |
| 7:6    | 00                    | CLK pin is driven with peripheral clock.                      |  |  |  |  |  |
|        | 01                    | CLK pin is driven with peripheral clock divided by 2.         |  |  |  |  |  |
|        | 10                    | CLK pin is low.                                               |  |  |  |  |  |
|        | 11                    | CLK pin is high.                                              |  |  |  |  |  |
| 5:4    | 00                    | STATUS pin is active (low) during a first opcode byte fetch.  |  |  |  |  |  |
|        | 01                    | STATUS pin is active (low) during an interrupt acknowledge.   |  |  |  |  |  |
|        | 10                    | STATUS pin is low.                                            |  |  |  |  |  |
|        | 11                    | STATUS pin is high.                                           |  |  |  |  |  |
| 3:2    | 00                    | /WDTOUT pin functions normally.                               |  |  |  |  |  |
|        | 01                    | Enable /WDTOUT for test mode. Reserved for internal use only. |  |  |  |  |  |
|        | 10                    | /WDTOUT pin is low (1 cycle min, 2 cycles max, of 32 kHz).    |  |  |  |  |  |
|        | 11                    | This bit combination is reserved and should not be used.      |  |  |  |  |  |
| 1:0    | 00                    | /BUFEN pin is active (low) during external I/O cycles.        |  |  |  |  |  |
|        | 01                    | /BUFEN pin is active (low) during data memory accesses.       |  |  |  |  |  |
|        | 10 /BUFEN pin is low. |                                                               |  |  |  |  |  |
|        | 11                    | /BUFEN pin is high.                                           |  |  |  |  |  |

|                 | Global C | PU Register                                    | (GCPU) | (Address = 0x002E) |  |  |
|-----------------|----------|------------------------------------------------|--------|--------------------|--|--|
| Bit(s)          | Value    | Description                                    |        |                    |  |  |
| 7               | 0        | Program fetch as a function of the SMODE pins. |        |                    |  |  |
| (Read-<br>only) | 1        | Ignore the SMODE pins program fetch function.  |        |                    |  |  |
| 6:5             | Read     | These bits report the state of the SMODE pins. |        |                    |  |  |
| 4:0             | 00011    | CPU identifier for this version of the chip.   |        |                    |  |  |

|                 | Global Rev | rision Register                                | (GREV)               | (Address = 0x002F) |  |  |
|-----------------|------------|------------------------------------------------|----------------------|--------------------|--|--|
| Bit(s)          | Value      | Description                                    |                      |                    |  |  |
| 7               | 0          | Program fetch as a function of the SMODE pins. |                      |                    |  |  |
| (Read-<br>only) | 1          | Ignore the SMODE pins program fetch function.  |                      |                    |  |  |
| 6:5             | Read       | These bits report the state of the SMODE pins. |                      |                    |  |  |
| 4:0             | 00011      | CPU identifier for this                        | version of the chip. |                    |  |  |

| Battery-Backed Onchip-Encryption RAM |       | (VRAM00)<br>through<br>(VRAM31)                                        | (Address = 0x0600)<br>through<br>(Address = 0x061F) |  |  |
|--------------------------------------|-------|------------------------------------------------------------------------|-----------------------------------------------------|--|--|
| Bit(s)                               | Value | Description                                                            |                                                     |  |  |
| 7:0                                  |       | General-purpose RAM locations. Cleared by Intrusion Detect conditions. |                                                     |  |  |

# 5. MEMORY MANAGEMENT

#### 5.1 Overview

The Rabbit 5000 supports both 8-bit and 16-bit external flash and SRAM devices; three chip selects and two read/write-enable strobes allow up to six external devices to be attached at once. The 8-bit mode allows 0, 1, 2, or 4 wait states to be specified for each device, and the 16-bit mode allows 0 to 7 wait states depending on the settings. Both 8-bit and 16-bit page-mode devices are also supported.

In addition, the Rabbit 5000 contains 128 KB of internal SRAM that resides on its own chip select signal. It can be enabled in either 8- or 16-bit mode.

The Rabbit 5000's physical memory space contains four consecutive banks, each of which can be mapped to an individual chip-select/enable strobe pair. The banks can be set for equal sizes ranging from 128 KB up to 4 MB, providing a total physical memory range from 512 KB up to 16 MB. Figure 5-1 shows a sample configuration.



Figure 5-1. Mapping Rabbit 5000 Physical Memory Space

Either one or both of the two most significant address bits (which are used to select the quadrant) can be inverted, providing the ability to bank-switch other pages from a larger memory device into the same memory bank.

Code is executed in the 64 KB logical memory space, which is divided into four segments: root, data, stack, and XMEM. The root segment is mapped directly to physical address 0x0000000, while the data and stack segments can be mapped to 4 KB boundaries anywhere in the physical space. The boundaries between the root and data segments and the data and stack segments can be adjusted in 4 KB blocks as well.

The XMEM segment is a fixed 8 KB, and points to a physical memory address block specified in the XPC register. It is possible to run code in the XMEM window, providing an easy means of storing and executing code beyond the 64 KB logical memory space. Special call and return instructions to physical addresses are provided that automatically update the XPC register as necessary.



Figure 5-2. Logical and Physical Memory Mapping

The Rabbit 2000 and 3000 had numerous instructions for reading and writing data to logical addresses, but only had limited support for reading and writing data to a physical memory address. In the Rabbit 4000, a wide range of instructions was provided to read and write to physical addresses. The same instructions can be used to write to logical addresses. All of these instructions are available in the Rabbit 5000.

The 64 KB logical memory space limitation can also be expanded by using the separate instruction and data space mode. When this mode is enabled, address bit A16 is inverted for all data accesses in the root and/or data segments, and address bit A19 is inverted for all data accesses in the root and/or data segments *before* bank selection (physical device) occurs. These two features allow both code and data to access separate 64 KB logical spaces instead of sharing a single space.

It is possible to protect memory in the Rabbit 5000 at three different levels—each of the memory banks can be made read-only, physical memory can be write-protected in 64 KB blocks, and two of those 64 KB blocks can be protected with a granularity of 4 KB. A Priority 3 interrupt will occur if a write is attempted in one of the protected 64 KB or 4 KB blocks. In addition, it is possible to place limits around the code execution stack and generate an interrupt if a stack-related write occurs within 16 bytes of those limits.

## 5.1.1 Block Diagram



# 5.1.2 Registers

| Register Name                         | Mnemonic  | I/O Address | R/W | Reset    |
|---------------------------------------|-----------|-------------|-----|----------|
| MMU Instruction/Data Register         | MMIDR     | 0x0010      | R/W | 00000000 |
| Stack Segment Register                | STACKSEG  | 0x0011      | R/W | 00000000 |
| Stack Segment LSB Register            | STACKSEGL | 0x001A      | R/W | 00000000 |
| Stack Segment MSB Register            | STACKSEGH | 0x001B      | R/W | 00000000 |
| Data Segment Register                 | DATSEG    | 0x0012      | R/W | 00000000 |
| Data Segment LSB Register             | DATSEGL   | 0x001E      | R/W | 00000000 |
| Data Segment MSB Register             | DATSEGH   | 0x001F      | R/W | 00000000 |
| Segment Size Register                 | SEGSIZE   | 0x0013      | R/W | 11111111 |
| Memory Bank 0 Control Register        | MB0CR     | 0x0014      | R/W | 00001000 |
| Memory Bank 1 Control Register        | MB1CR     | 0x0015      | R/W | xxxxxxxx |
| Memory Bank 2 Control Register        | MB2CR     | 0x0016      | R/W | xxxxxxxx |
| Memory Bank 3 Control Register        | MB3CR     | 0x0017      | R/W | xxxxxxxx |
| MMU Expanded Code Register            | MECR      | 0x0018      | R/W | 00000000 |
| Memory Timing Control Register        | MTCR      | 0x0019      | R/W | 00000000 |
| Memory Alternate Control Register     | MACR      | 0x001D      | R/W | 00000000 |
| Advanced /CS0 Control Register        | ACS0CR    | 0x0410      | R/W | 00000000 |
| Advanced /CS1 Control Register        | ACS1CR    | 0x0411      | R/W | 00000000 |
| Advanced /CS2 Control Register        | ACS2CR    | 0x0412      | R/W | 00000000 |
| RAM Segment Register                  | RAMSR     | 0x0448      | R/W | 00000000 |
| Write-Protect Control Register        | WPCR      | 0x0440      | R/W | 00000000 |
| Write-Protect x Register              | WPxR      | 0x460+x     | W   | 00000000 |
| Write-Protect Segment A Register      | WPSAR     | 0x0480      | W   | 00000000 |
| Write-Protect Segment A Low Register  | WPSALR    | 0x0481      | W   | 00000000 |
| Write-Protect Segment A High Register | WPSAHR    | 0x0482      | W   | 00000000 |
| Write-Protect Segment B Register      | WPSBR     | 0x0484      | W   | 00000000 |
| Write-Protect Segment B Low Register  | WPSBLR    | 0x0485      | W   | 00000000 |
| Write-Protect Segment B High Register | WPSBHR    | 0x0486      | W   | 00000000 |
| Stack Limit Control Register          | STKCR     | 0x0444      | R/W | 00000000 |
| Stack Low Limit Register              | STKLLR    | 0x0445      | W   | xxxxxxx  |
| Stack High Limit Register             | STKHLR    | 0x0446      | W   | xxxxxxx  |

# 5.2 Dependencies

### 5.2.1 I/O Pins

There are three chip select pins, /CS0, /CS1, and /CS2; two read strobes, /OE0 and /OE1; and two write strobes, /WE0 and /WE1. /CS3 is available to the internal SRAM only and does not come out to a pin.

There are eight dedicated data bus pins, D0 through D7. If the 16-bit mode is enabled, then PH0–PH7 automatically act as the upper byte of the data bus, D8 through D15.

There are 20 dedicated address pins, A0 through A19. Up to four more address pins can be enabled on PE0–PE3, representing A20 through A23.

Pin PE4 can be enabled as /A0 to allow byte reads and writes in 16-bit SRAM devices.

#### 5.2.2 Clocks

All memory operations are clocked by the processor clock.

# 5.2.3 Other Registers

| Register           | Function                |
|--------------------|-------------------------|
| PEFR, PEALR, PEAHR | Enable A20-A23 and /A0. |

# 5.2.4 Interrupts

When a write is attempted to a write-protected 64 KB or 4 KB block, a write-protection violation interrupt is generated. The interrupt request is cleared when it is handled. The write-protection violation interrupt vector is in the IIR at offset 0x090. It is always set to Priority 3.

When a stack-related write is attempted to a region outside that set by the stack limit registers, a stack limit violation occurs. The interrupt request is cleared when it is handled. The stack limit violation interrupt vector is in the IIR at offset 0x1B0. It is always set to Priority 3.

# 5.3 Operation

# 5.3.1 Memory Management Unit (MMU)

Code execution takes place in the 64 KB logical memory space, which is divided into four segments: root, data, stack, and extended (XMEM). The root segment is always mapped starting at physical address 0x000000, but the other segments can be remapped to start at any physical 4 KB block boundary.

The data and stack segment mappings are set by writing to the appropriate register, as shown in Table 5-1. The DATASEG and STACKSEG registers provide backwards compatibility to the Rabbit 2000 and 3000 processors; these registers map directly to DATASEGL and STACKSEGL, but the contents of DATASEGH and STACKSEGH are set to zero.

Table 5-1. Memory Management Registers

| Register  | Segment | Size    | Comments                                              |
|-----------|---------|---------|-------------------------------------------------------|
| DATASEG   | Data    | 8 bits  | Maps to DATASEGL;<br>DATASEGH set to 0x00             |
| DATASEGL  | Data    | 8 bits  | _                                                     |
| DATASEGH  | Data    | 4 bits  | _                                                     |
| STACKSEG  | Stack   | 8 bits  | Maps to STACKSEGL;<br>STACKSEGH set to 0x00           |
| STACKSEGL | Stack   | 8 bits  | _                                                     |
| STACKSEGH | Stack   | 4 bits  | _                                                     |
| XPC       | XMEM    | 8 bits  | Loaded via instructions LD XPC, A and LD A, XPC       |
| LXPC      | XMEM    | 12 bits | Loaded via instructions:  LD LXPC, HL and LD HL, LXPC |

Each of these registers provides a 4 KB offset that is added to the logical address to provide a physical address as shown in Figure 5-3.



Figure 5-3. MMU Operation

### 5.3.2 Memory Bank Operation

On startup the Rabbit 5000 checks the status of the SYSCFG pins. To provide support for external memory, both SYSCFG pins should be set low and Memory Bank 0 enabled to use /CS0, /OE0, and /WE0 in 8-bit mode with four wait states and write protection enabled. It is expected that an external flash device containing startup code is attached to those strobes. The other memory banks come up undefined and their controls should be set via the appropriate MBxCR register to a valid setting before use.

If SYSCFG0 is high and SYSCFG1 is low, Memory Bank 0 is enabled to use /CS3, /OE0, and /WE0 in 16-bit mode. This allows the processor to start operation directly out of the internal SRAM.

The size of the memory banks is defined in the MECR register. The default size is 256 KB (the bank selection looks at the two most significant address bits), but this value can be adjusted down to 128 KB or up to 4 MB per bank.

The two address bits used to select the bank can be inverted in MBxCR, which enables mapping different sections of a memory device larger than the current memory bank into memory. Figure 5-4 shows an example of this feature.



Figure 5-4. Mapping Different Sections of a Memory Device
Larger Than the Current Memory Bank

It is possible to extend the timing of the /OE and/or /WE strobes by one half of a clock. This provides slightly longer strobes for slower memories; see the timing diagrams in Chapter 31. These options are available in MTCR.

It is possible to force /CS1 to be always active in MMIDR; enabling this will cause conflicts only if a device shares a /OE or /WE strobe with another device. This option allows faster access to particular memory devices.

## 5.3.3 Memory Modes

The Rabbit 5000 supports both 8-bit and 16-bit memories on all chip selects, including the internal SRAM. It also provides support for page-mode devices. The mode for each chip select is set in MACR; 8-bit mode is the default for all chip selects.

When in basic 8-bit mode, the wait states are selected in the memory bank registers, MBxCR; the options are 0, 1, 2, or 4 wait states. Note that this may put an upper bound on the processor clock speed, depending on the access time of your 8-bit memory device. When in 16-bit or page-mode (either 8- or 16-bit), the wait states are selected by both the MBxCR and the advanced chip select registers, ACSxCR.

When the 16-bit mode is enabled, Parallel Port H is used for the high byte of the data, and is configured automatically for this operation, overriding any other Parallel Port H function.

| Mode             | Byte<br>Writes? | Word<br>Reads? | Word<br>Writes? | Wait State<br>Register | Wait State<br>Options                   |
|------------------|-----------------|----------------|-----------------|------------------------|-----------------------------------------|
| 8-bit            | Yes             | No             | No              | MBxCR                  | 0, 1, 2, 4                              |
| 16-bit           | Selectable      | Yes            | Yes             | MBxCR<br>ACSxCR        | 0–11                                    |
| 8-bit Page Mode  | Yes             | No             | No              | MBxCR<br>ACSxCR        | 0–11 first access,<br>0–7 page accesses |
| 16-bit Page Mode | Selectable      | Yes            | Yes             | MBxCR<br>ACSxCR        | 0–11 first access,<br>0–7 page accesses |

Table 5-2. Memory Modes

A 16-bit memory device may or may not support byte writes, so there is an option to select between these two cases in ACSxCR. With the default option any byte writes or unaligned word writes to a 16-bit memory will be suppressed (i.e., the /WE will not be asserted). Any aligned word reads or writes are recognized internally and are combined into just one write transaction on the external bus. The other option for the 16-bit bus does not inhibit byte writes or unaligned word writes, and replicates the byte data on both halves of the data bus in these cases. In this mode the A0 and /A0 signals must be used by the memory to enable the individual bytes.

Table 5-3. A0 and /A0 Signals for Various Transaction Types

| Transaction Type                  | Α0   | /A0  |
|-----------------------------------|------|------|
| Word Read (prefetch only)         | Low  | Low  |
| Word Write                        | Low  | Low  |
| Byte Read or Write — Even Address | Low  | High |
| Byte Read or Write — Odd Address  | High | Low  |

All of the power-saving modes in Chapter 29 can be used with the 16-bit mode.

The second advanced bus mode is the Page Mode. This mode also can be enabled for any external chip select, and can be used with either 8-bit or 16-bit memories connected to these chip selects. Page-Mode memories provide for a faster access time if the requested data are in the same page as the previous data. In the Rabbit 5000 (and most memory devices) a page can be selected as either 8 or 16 bytes. Thus, if an address is identical to the previous address except in the lower four bits, the access time is assumed to be faster. These wait-state options are also controlled in the ACSxCR.

In Page Mode the chip select and /OE remain active from one page access to the next, and only the three or four least-significant bits of the address change to request the new data. This obviously interferes with a number of the power-saving modes and will take precedence over them for chip select accesses, as appropriate. The power-saving modes will still apply to the other chip select and output-enable signals. The logic recognizes which /OE is being used with each chip select in the Page Mode.

As mentioned previously, the ACSxCR registers each contain three fields to control the generation of wait states in the advanced bus modes. These settings are in addition to the wait-state setting in MBxCR when an advanced bus mode is enabled. When the 16-bit bus is enabled, one to seven automatic wait states for memory read bus cycles can be enabled in addition to the zero to four wait states in MBxCR. This setting is also used for the first access when the Page Mode is enabled; a second setting selects the number of wait states for all subsequent reads in the Page Mode, allowing from zero to three automatic wait states for the same-page accesses in the Page Mode. The choices available for the advanced bus wait states are sufficient to allow interfacing to a variety of standard memories for any Rabbit 5000 speed grade.

When a 16-bit memory is connected to /CS0, the first few instructions must program the device to operate in 16-bit mode. This code is shown below. This code should be the first thing executed by your device. Because the processor is fetching bytes from a 16-bit memory device that is not connected to A0, only one-byte instructions can be used, and they must occur in pairs.

```
0000h
ORG
XOR
         Α
                    ; a <= 00000000
XOR
         Α
         H, A
                    ; h <= 00000000
LD
LD
         H, A
SCF
SCF
RLA
                    ; a <= 00000001
                    ; a <= 00000010
RT.A
         B, A
                    ; b <= 00000010
LD
LD
         B, A
SCF
SCF
ADC
         A, B
                    ; a <= 00000101
                    ; a <= 00000111
ADC
         A, B
ADD
         A, A
                    ; a <= 00001110
```

```
; a <= 00011100
ADD
         A, A
SCF
SCF
         A, H
ADC
                    ; a <= 00011101
ADC
                    ; 1 <= 00011101
         L, A
LD
         L, A
LD
IOI
                    ; two IOIs same as one
IOI
LD
         (HL), B
                    ; MACR <= 00000010
T.D
          (HL), B
                    ; dummy memory write (no /WE)
NOP
                    ; required delay to start
NOP
                    ; up the 16-bit bus
```

# 5.3.4 Separate Instruction and Data Space

To make better use of the 64 KB of logical space, an option is provided to map code and data accesses in the same address space to separate devices. This is accomplished by enabling the inversion of A16 and the most-significant bit of the bank select bits for accesses in the root and data segments. Careful use of these features allows both code and data to separately use up to 64 KB of logical memory.

The RAM segment register (RAMSR) provides a shortcut for updating code by accessing it as data. It provides a "window" that uses the instruction address decoding when read or written as data. This mapping will only occur when the RAMSR is within the root or data segments; the RAMSR will be ignored if it is mapped to the stack segment or XPC window.

The *Rabbit 5000 Designer's Handbook* provides further details on the use of the separate instruction and data space feature.

## 5.3.5 Memory Protection

Memory blocks may be protected at three separate granularities, as shown in Table 5-4. Writes can be prevented to any memory bank by writing to MBxCR. Writes can be prevented and trapped at a resolution of 64 KB by enabling protection for that block in the appropriate WPxR register. For further control, two of those 64 KB blocks can be further subdivided into 4 KB blocks by selecting them as the write protect segments A or B.

When a write is attempted to a block protected in WPxR, WPSxLR, or WPSxHR, a Priority 3 write-protect interrupt occurs. This feature is automatically enabled by writing to the block protection registers; to disable it, set all the write-protect block registers to zero.

| Method                    | Block Size    | Registers Used        |
|---------------------------|---------------|-----------------------|
| Memory Bank               | 128 KB – 4 MB | MBxCR, MECR           |
| Write-Protect Blocks      | 64 KB         | WPCR, WPxR            |
| Write Protect Segment A/B | 4 KB          | WPSxR, WPSxLR, WPSxHR |

Table 5-4. Memory Protection Options

### 5.3.6 Stack Protection

The Rabbit 5000 provides stack overflow and underflow protection. Low and high logical address limits can be set in STKLLR and STKHLR; a Priority 3 stack-violation interrupt occurs when a stack-based write occurs within the 16 bytes below the upper limit or within the 16 bytes above the lower limit. Note that the writes will still occur even if they are within the 16 bytes surrounding the limits, but the interrupt can serve as a warning to the application that the stack is in danger of being over or underrun.

The stack checking can be enabled or disabled by writing to STKCR.

# **5.4 Register Descriptions**

| MM     | MMU Instruction/Data Register (MMIDR) (Address = 0x0010)                                                                                                                   |                                                                                                                                                                        |  |  |  |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit(s) | Value                                                                                                                                                                      | Description                                                                                                                                                            |  |  |  |
| 7      | 0                                                                                                                                                                          | Internal I/O addresses are decoded using only the lower eight bits of the internal I/O address bus. This restricts internal I/O addresses to the range 0x0000–0x00FF.  |  |  |  |
|        | Internal I/O addresses are decoded using all 15 bits of the address internal address bus. This option must be selected to access internal I/O addresses 0x0100 and higher. |                                                                                                                                                                        |  |  |  |
| 6      |                                                                                                                                                                            | This bit is reserved an must be written with zero.                                                                                                                     |  |  |  |
| 5      | 0                                                                                                                                                                          | Enable A16 and bank select address MSB inversion independent of instruction/data.                                                                                      |  |  |  |
|        | Enable A16 and bank select address MSB inversion for data accesses enables the instruction/data split.                                                                     |                                                                                                                                                                        |  |  |  |
| 4      | 0                                                                                                                                                                          | Normal /CS1 operation.                                                                                                                                                 |  |  |  |
|        | 1                                                                                                                                                                          | Force /CS1 always active. This will not cause any conflicts as long as the memory using /CS1 does not also share an output enable or write enable with another memory. |  |  |  |
| 3      | 0                                                                                                                                                                          | Normal operation.                                                                                                                                                      |  |  |  |
|        | 1                                                                                                                                                                          | For a data segment access, invert bank select address MSB before MBxCR decision.                                                                                       |  |  |  |
| 2      | 0                                                                                                                                                                          | Normal operation.                                                                                                                                                      |  |  |  |
|        | 1                                                                                                                                                                          | For a data segment access, invert A16                                                                                                                                  |  |  |  |
| 1      | 0                                                                                                                                                                          | Normal operation.                                                                                                                                                      |  |  |  |
|        | 1                                                                                                                                                                          | For a root segment access, invert bank select address MSB before MBxCR decision.                                                                                       |  |  |  |
| 0      | 0                                                                                                                                                                          | Normal operation.                                                                                                                                                      |  |  |  |
|        | 1                                                                                                                                                                          | For a root segment access, invert A16                                                                                                                                  |  |  |  |

|        | Stack Segi | ment Register                                       | (STACKSEG)                                         | (Address = 0x0011)              |
|--------|------------|-----------------------------------------------------|----------------------------------------------------|---------------------------------|
| Bit(s) | Value      | Description                                         |                                                    |                                 |
| 7:0    | Read       | The current contents of this register are reported. |                                                    |                                 |
|        | Write      | Eight LSBs (MSBs a<br>SEGSIZ[7:4] ≤ Add             | are set to zero by write) of phy<br>r[15:12] < 0xE | ysical address offset to use if |

| Sta    | ack Segme | ent Low Register                                    | (STACKSEGL)                | (Address = 0x001A)            |
|--------|-----------|-----------------------------------------------------|----------------------------|-------------------------------|
| Bit(s) | Value     |                                                     | Description                |                               |
| 7:0    | Read      | The current contents of this register are reported. |                            |                               |
|        | Write     | Eight LSBs of physical a 0xE                        | ddress offset to use if SE | $GSIZ[7:4] \le Addr[15:12] <$ |

| St     | ack Segme | nt High Register                                                                                        | (STACKSEGH)                   | (Address = 0x001B)             |
|--------|-----------|---------------------------------------------------------------------------------------------------------|-------------------------------|--------------------------------|
| Bit(s) | Value     | Description                                                                                             |                               |                                |
| 7:4    |           | These bits are reserved and should always be written as zero. These bits always return zeros when read. |                               |                                |
| 3:0    | Read      | The current contents of this register are reported.                                                     |                               |                                |
|        | Write     | Four MSBs of physica<br>0xE                                                                             | l address offset to use if SE | $EGSIZ[7:4] \le Addr[15:12] <$ |

| Data Segment Register |       | (DATSEG)                                                                                                                 | (Address = 0x0012) |                                   |
|-----------------------|-------|--------------------------------------------------------------------------------------------------------------------------|--------------------|-----------------------------------|
| Bit(s)                | Value | Description                                                                                                              |                    |                                   |
| 7:0                   | Read  | The current contents of this register are reported.                                                                      |                    |                                   |
|                       | Write | Eight LSBs (MSBs are set to zero by write) of physical address offset to use if: SEGSIZ[3:0] ≤ Addr[15:12] < SEGSIZ[7:4] |                    | nysical address offset to use if: |

| Da     | Data Segment Low Register |                                                                                         | (DATSEGL) | (Address = 0x001E) |
|--------|---------------------------|-----------------------------------------------------------------------------------------|-----------|--------------------|
| Bit(s) | Value                     | Description                                                                             |           |                    |
| 7:0    |                           | Eight LSBs of physical address offset to use if SEGSIZ[3:0] ≤ Addr[15:12] < SEGSIZ[7:4] |           |                    |

| Data Segment High Register |       | (DATSEGH)                                                                                               | (Address = 0x001F) |  |
|----------------------------|-------|---------------------------------------------------------------------------------------------------------|--------------------|--|
| Bit(s)                     | Value | Description                                                                                             |                    |  |
| 7:4                        |       | These bits are reserved and should always be written as zero. These bits always return zeros when read. |                    |  |
| 3:0                        |       | Four MSBs of physical address offset to use if SEGSIZ[3:0] ≤ Addr[15:12] < SEGSIZ[7:4]                  |                    |  |

|        | Segment Size Register |                                                                       | (SEGSIZ) | (Address = 0x0013) |
|--------|-----------------------|-----------------------------------------------------------------------|----------|--------------------|
| Bit(s) | Value                 | Description                                                           |          |                    |
| 7:0    | Read                  | The current contents of this register are reported.                   |          |                    |
| 7:4    | Write                 | Boundary value for switching from DATSEG to STACKSEG for translation. |          |                    |
| 3:0    | Write                 | Boundary value for switching from none to DATSEG for translation.     |          |                    |

| Men                                                                 | nory Bank | x Control Register                                                                               | (MB0CR)<br>(MB1CR)<br>(MB2CR)<br>(MB3CR) | (Address = 0x0014)<br>(Address = 0x0015)<br>(Address = 0x0016)<br>(Address = 0x0017) |  |
|---------------------------------------------------------------------|-----------|--------------------------------------------------------------------------------------------------|------------------------------------------|--------------------------------------------------------------------------------------|--|
| Bit(s)                                                              | Value     |                                                                                                  | Description                              |                                                                                      |  |
| 7:6                                                                 | 00        | Four (five for writes) wait states for accesses in this bank.                                    |                                          |                                                                                      |  |
|                                                                     | 01        | Two (three for writes) wa                                                                        | it states for accesses in                | this bank.                                                                           |  |
|                                                                     | 10        | One (two for writes) wait                                                                        | states for accesses in t                 | his bank.                                                                            |  |
|                                                                     | 11        | Zero (one for writes) wai                                                                        | t states for accesses in                 | his bank.                                                                            |  |
| 5                                                                   | 0         | Pass bank select address                                                                         | MSB for accesses in th                   | is bank.                                                                             |  |
|                                                                     | 1         | Invert bank select address                                                                       | s MSB for accesses in t                  | his bank.                                                                            |  |
| 4                                                                   | 0         | Pass bank select address                                                                         | LSB for accesses in thi                  | s bank.                                                                              |  |
|                                                                     | 1         | Invert bank select address LSB for accesses in this bank.                                        |                                          |                                                                                      |  |
| 3:2                                                                 | 00        | /OE0 and /WE0 are active for accesses in this bank.                                              |                                          |                                                                                      |  |
|                                                                     | 01        | /OE1 and /WE1 are activ                                                                          | e for accesses in this ba                | ınk.                                                                                 |  |
|                                                                     | 10        | /OE0 only is active for accesses in this bank (i.e., read-only). Tran normal in every other way. |                                          |                                                                                      |  |
|                                                                     | 11        | /OE1 only is active for ac<br>normal in every other wa                                           |                                          | , read-only). Transactions are                                                       |  |
| 1:0                                                                 | 00        | /CS0 is active for accesse                                                                       | es in this bank.                         |                                                                                      |  |
|                                                                     | 01        | /CS1 is active for accesse                                                                       | es in this bank.                         |                                                                                      |  |
|                                                                     | 10        | /CS2 is active for accesse                                                                       | es in this bank.                         |                                                                                      |  |
| /CS3 (internal memory) is operation is selected (by str MB0CR only. |           |                                                                                                  |                                          | this bank. When standalone t combination is forced for                               |  |

| MN     | IU Expand                                                        | ed Code Register (MECR) (Address = 0x0018)                                    |  |  |  |
|--------|------------------------------------------------------------------|-------------------------------------------------------------------------------|--|--|--|
| Bit(s) | Value                                                            | Description                                                                   |  |  |  |
| 7:5    | 000                                                              | Bank select address is A[19:18].                                              |  |  |  |
|        | 001                                                              | Bank select address is A[20:19].                                              |  |  |  |
|        | 010                                                              | Bank select address is A[21:20].                                              |  |  |  |
|        | 011                                                              | Bank select address is A[22:21].                                              |  |  |  |
|        | 100                                                              | Bank select address is A[23:22].                                              |  |  |  |
|        | 101                                                              | This bit combination is reserved and should not be used.                      |  |  |  |
|        | 110                                                              | This bit combination is reserved and should not be used.                      |  |  |  |
|        | 111                                                              | Bank select address is A[18:17].                                              |  |  |  |
| 4:3    |                                                                  | These bits are reserved and should be written with zeros. Read returns zeros. |  |  |  |
| 2:0    | 000                                                              | Normal operation.                                                             |  |  |  |
|        | 001                                                              | This bit combination is reserved and should not be used.                      |  |  |  |
|        | 010                                                              | This bit combination is reserved and should not be used.                      |  |  |  |
|        | 011                                                              | This bit combination is reserved and should not be used.                      |  |  |  |
|        | 100                                                              | For an XPC access, use MB0CR independent of bank select address.              |  |  |  |
|        | 101                                                              | For an XPC access, use MB1CR independent of bank select address.              |  |  |  |
|        | 110                                                              | For an XPC access, use MB2CR independent of bank select address.              |  |  |  |
|        | For an XPC access, use MB3CR independent of bank select address. |                                                                               |  |  |  |

| Men    | nory Timin | g Control Register (MTCR) (Address = 0x0019)                                           |  |  |  |
|--------|------------|----------------------------------------------------------------------------------------|--|--|--|
| Bit(s) | Value      | Description                                                                            |  |  |  |
| 7:4    |            | These bits are reserved and should be written with zeros.                              |  |  |  |
| 3      | 0          | Normal timing for /OE1 (rising edge to rising edge, one clock minimum).                |  |  |  |
|        | 1          | Extended timing for /OE1 (one-half clock earlier than normal).                         |  |  |  |
| 2      | 0          | Normal timing for /OE0 (rising edge to rising edge, one clock minimum).                |  |  |  |
|        | 1          | Extended timing for /OE0 (one-half clock earlier than normal).                         |  |  |  |
| 1      | 0          | Normal timing for /WE1 (rising edge to falling edge, one and one-half clocks minimum). |  |  |  |
|        | 1          | Extended timing for /WE1 (falling edge to falling edge, two clocks minimum).           |  |  |  |
| 0      | 0          | Normal timing for /WE0 (rising edge to falling edge, one and one-half clocks minimum). |  |  |  |
|        | 1          | Extended timing for /WE0 (falling edge to falling edge, two clocks minimum).           |  |  |  |

| Mem                                     | ory Alterna                                                                                           | ate Control Register (MACR) (Address = 0x001D)                                                                                                    |  |
|-----------------------------------------|-------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit(s)                                  | Value                                                                                                 | Description                                                                                                                                       |  |
| 7                                       | Normal 8-bit operation for /CS3. Use MBxCR for wait states. The only when external memory is present. |                                                                                                                                                   |  |
|                                         | 1                                                                                                     | Normal 16-bit operation for /CS3. Use MBxCR for wait states. When standalone operation is selected (by strapping a pin), this bit is forced high. |  |
| 6                                       |                                                                                                       | This bit is reserved and must not be used.                                                                                                        |  |
| 5:4                                     | 00                                                                                                    | Normal 8-bit operation for /CS2.                                                                                                                  |  |
|                                         | 01                                                                                                    | Page-Mode 8-bit operation for /CS2.                                                                                                               |  |
|                                         | 10                                                                                                    | Normal 16-bit operation for /CS2.                                                                                                                 |  |
|                                         | 11                                                                                                    | Page-Mode 16-bit operation for /CS2.                                                                                                              |  |
| 3:2 00 Normal 8-bit operation for /CS1. |                                                                                                       | Normal 8-bit operation for /CS1.                                                                                                                  |  |
|                                         | 01                                                                                                    | Page-Mode 8-bit operation for /CS1.                                                                                                               |  |
|                                         | 10                                                                                                    | Normal 16-bit operation for /CS1.                                                                                                                 |  |
|                                         | 11                                                                                                    | Page-Mode 16-bit operation for /CS1.                                                                                                              |  |
| 1:0                                     | 00                                                                                                    | Normal 8-bit operation for /CS0.                                                                                                                  |  |
|                                         | 01                                                                                                    | Page-Mode 8-bit operation for /CS0.                                                                                                               |  |
|                                         | 10                                                                                                    | Normal 16-bit operation for /CS0.                                                                                                                 |  |
|                                         | 11                                                                                                    | Page-Mode 16-bit operation for /CS0.                                                                                                              |  |

| Advanced Chip Select x Control Register |       |                                                                                                                                                                                                                               | (ACS0CR)<br>(ACS1CR)<br>(ACS2CR) | (Address = 0x0410)<br>(Address = 0x0411)<br>(Address = 0x0412) |  |
|-----------------------------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|----------------------------------------------------------------|--|
| Bit(s)                                  | Value |                                                                                                                                                                                                                               | Description                      |                                                                |  |
| 7:5                                     | 000   | Zero extra wait states for re                                                                                                                                                                                                 | eads, writes, or first P         | age-Mode access.                                               |  |
|                                         | 001   | One extra wait state for rea                                                                                                                                                                                                  | ds, writes, or first Pa          | ge-Mode read access.                                           |  |
|                                         | 010   | Two extra wait states for re                                                                                                                                                                                                  | eads, writes, or first P         | age-Mode access.                                               |  |
|                                         | 011   | Three extra wait states for                                                                                                                                                                                                   | reads, writes, or first          | Page-Mode read access.                                         |  |
|                                         | 100   | Four extra wait states for re                                                                                                                                                                                                 | eads, writes, or first P         | age-Mode read access.                                          |  |
|                                         | 101   | Five extra wait states for reads, writes, or first Page-Mode read access.  Six extra wait state for reads, writes, or first Page-Mode read access.  Seven extra wait state for reads, writes, or first Page-Mode read access. |                                  |                                                                |  |
|                                         | 110   |                                                                                                                                                                                                                               |                                  |                                                                |  |
|                                         | 111   |                                                                                                                                                                                                                               |                                  |                                                                |  |
| 4:3                                     | 00    | Zero extra wait states for subsequent Page-Mode accesses.                                                                                                                                                                     |                                  |                                                                |  |
|                                         | 01    | One extra wait state for subsequent Page-Mode accesses.                                                                                                                                                                       |                                  |                                                                |  |
|                                         | 10    | Two extra wait states for su                                                                                                                                                                                                  | ıbsequent Page-Mode              | accesses.                                                      |  |
|                                         | 11    | Three extra wait states for subsequent Page-Mode accesses.                                                                                                                                                                    |                                  |                                                                |  |
| 2                                       |       | This bit is reserved and sho                                                                                                                                                                                                  | ould not be used.                |                                                                |  |
| 1                                       | 0     | Page size 16 bytes.                                                                                                                                                                                                           |                                  |                                                                |  |
|                                         | 1     | Page size 8 bytes.                                                                                                                                                                                                            |                                  |                                                                |  |
| 0                                       | 0     | Disable byte writes on 16-l                                                                                                                                                                                                   | oit bus.                         |                                                                |  |
|                                         | 1     | Enable byte writes on 16-b                                                                                                                                                                                                    | it bus.                          |                                                                |  |

|        | RAM Segment Register |                                                                       | (RAMSR)                      | (Address = 0x0448)      |  |
|--------|----------------------|-----------------------------------------------------------------------|------------------------------|-------------------------|--|
| Bit(s) | Value                | Description                                                           |                              |                         |  |
| 7:2    |                      | Compare value for RAM segment limit checking.                         |                              |                         |  |
| 1:0    | 00                   | Disable RAM segment limit checking.                                   |                              |                         |  |
|        | 01                   | Select data-type MMU translation if PC[15:10] is equal to RAMSR[7:2]. |                              |                         |  |
|        | 10                   | Select data-type MMU translation if PC[15:11] is equal to RAMSR[7:3]. |                              |                         |  |
|        | 11                   | Select data-type MM                                                   | U translation if PC[15:12] i | is equal to RAMSR[7:4]. |  |

| Write  | e Protectio | n Control Register                                        | (WPCR)            | (Address = 0x0440) |
|--------|-------------|-----------------------------------------------------------|-------------------|--------------------|
| Bit(s) | Value       | Description                                               |                   |                    |
| 7:1    |             | These bits are reserved and should be written with zeros. |                   |                    |
| 0      | 0           | Write protection in User Mode only.                       |                   |                    |
|        | 1           | Write protection in System                                | n and User modes. |                    |

|        | Write-Prot | ect x Register                                                                                                                                                                                                                                              | (WP0R)  | (Address = 0x0460) |  |
|--------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|--------------------|--|
|        |            |                                                                                                                                                                                                                                                             | (WP1R)  | (Address = 0x0461) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP2R)  | (Address = 0x0462) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP3R)  | (Address = 0x0463) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP4R)  | (Address = 0x0464) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP5R)  | (Address = 0x0465) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP6R)  | (Address = 0x0466) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP7R)  | (Address = 0x0467) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP8R)  | (Address = 0x0468) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP9R)  | (Address = 0x0469) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP10R) | (Address = 0x046A) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP11R) | (Address = 0x046B) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP12R) | (Address = 0x046C) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP13R) | (Address = 0x046D) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP14R) | (Address = 0x046E) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP15R) | (Address = 0x046F) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP16R) | (Address = 0x0470) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP17R) | (Address = 0x0471) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP18R) | (Address = 0x0472) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP19R) | (Address = 0x0473) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP20R) | (Address = 0x0474) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP21R) | (Address = 0x0475) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP22R) | (Address = 0x0476) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP23R) | (Address = 0x0477) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP24R) | (Address = 0x0478) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP25R) | (Address = 0x0479) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP26R) | (Address = 0x047A) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP27R) | (Address = 0x047B) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP28R) | (Address = 0x047C) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP29R) | (Address = 0x047D) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP30R) | (Address = 0x047E) |  |
|        |            |                                                                                                                                                                                                                                                             | (WP31R) | (Address = 0x047F) |  |
| Bit(s) | Value      | Description                                                                                                                                                                                                                                                 |         |                    |  |
| 7:0    | 0          | Disable write protection for the corresponding 64 KB segment.                                                                                                                                                                                               |         |                    |  |
|        | 1          | Enable write protection for the corresponding 64 KB segment. The eight-bit address of the segment to be write-protected is formed using bits [4:0] of the WPxR register address concatenated with the bit address of the corresponding bit in the register. |         |                    |  |

| Write  | e-Protect S | egment x Register                                                                                                                            | (WPSAR)<br>(WPSBR) | (Address = 0x0480)<br>(Address = 0x0484) |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------|--------------------|------------------------------------------|
| Bit(s) | Value       | Description                                                                                                                                  |                    |                                          |
| 7:0    |             | When these eight bits [23:16] match bits of the physical address, write-protect that 64 KB range in 4 KB increments using WPSxLR and WPSxHR. |                    |                                          |

| Write-F | Protect Seg | gment x Low Register (WPSALR) (Address = 0x0481) (WPSBLR) (Address = 0x0485)   |
|---------|-------------|--------------------------------------------------------------------------------|
| Bit(s)  | Value       | Description                                                                    |
| 7       | 0           | Disable 4 KB write protect for relative address 0x7000–0x7FFF in WP Segment x. |
|         | 1           | Enable 4 KB write protect for relative address 0x7000–0x7FFF in WP Segment x.  |
| 6       | 0           | Disable 4 KB write protect for relative address 0x6000–0x6FFF in WP Segment x. |
|         | 1           | Enable 4 KB write protect for relative address 0x6000–0x6FFF in WP Segment x.  |
| 5       | 0           | Disable 4 KB write protect for relative address 0x5000–0x5FFF in WP Segment x. |
|         | 1           | Enable 4 KB write protect for relative address 0x5000–0x5FFF in WP Segment x.  |
| 4       | 0           | Disable 4 KB write protect for relative address 0x4000–0x4FFF in WP Segment x. |
|         | 1           | Enable 4 KB write protect for relative address 0x4000–0x4FFF in WP Segment x.  |
| 3       | 0           | Disable 4 KB write protect for relative address 0x3000–0x3FFF in WP Segment x. |
|         | 1           | Enable 4 KB write protect for relative address 0x3000–0x3FFF in WP Segment x.  |
| 2       | 0           | Disable 4 KB write protect for relative address 0x2000–0x2FFF in WP Segment x. |
|         | 1           | Enable 4 KB write protect for relative address 0x2000–0x2FFF in WP Segment x.  |
| 1       | 0           | Disable 4 KB write protect for relative address 0x1000–0x1FFF in WP Segment x. |
|         | 1           | Enable 4 KB write protect for relative address 0x1000–0x1FFF in WP Segment x.  |
| 0       | 0           | Disable 4 KB write protect for relative address 0x0000–0x0FFF in WP Segment x. |
|         | 1           | Enable 4 KB write protect for relative address 0x0000–0x0FFF in WP Segment x.  |

| Write-P | Protect Seg | gment x High Register (WPSAHR) (Address = 0x0482) (WPSBHR) (Address = 0x0486)  |  |  |
|---------|-------------|--------------------------------------------------------------------------------|--|--|
| Bit(s)  | Value       | Description                                                                    |  |  |
| 7       | 0           | Disable 4 KB write protect for relative address 0xF000–0xFFFF in WP Segment x. |  |  |
|         | 1           | Enable 4 KB write protect for relative address 0xF000–0xFFFF in WP Segment x.  |  |  |
| 6       | 0           | Disable 4 KB write protect for relative address 0xE000–0xEFFF in WP Segment x. |  |  |
|         | 1           | Enable 4 KB write protect for relative address 0xE000–0xEFFF in WP Segment x.  |  |  |
| 5       | 0           | Disable 4 KB write protect for relative address 0xD000–0xDFFF in WP Segment x. |  |  |
|         | 1           | Enable 4 KB write protect for relative address 0xD000–0xDFFF in WP Segment x.  |  |  |
| 4       | 0           | Disable 4 KB write protect for relative address 0xC000–0xCFFF in WP Segment x. |  |  |
|         | 1           | Enable 4 KB write protect for relative address 0xC000–0xCFFF in WP Segment x.  |  |  |
| 3       | 0           | Disable 4 KB write protect for relative address 0xB000–0xBFFF in WP Segment x. |  |  |
|         | 1           | Enable 4 KB write protect for relative address 0xB000–0xBFFF in WP Segment x.  |  |  |
| 2       | 0           | Disable 4 KB write protect for relative address 0xA000–0xAFFF in WP Segment x. |  |  |
|         | 1           | Enable 4 KB write protect for relative address 0xA000–0xAFFF in WP Segment x.  |  |  |
| 1       | 0           | Disable 4 KB write protect for relative address 0x9000–0x9FFF in WP Segment x. |  |  |
|         | 1           | Enable 4 KB write protect for relative address 0x9000–0x9FFF in WP Segment x.  |  |  |
| 0       | 0           | Disable 4 KB write protect for relative address 0x8000–0x8FFF in WP Segment x. |  |  |
|         | 1           | Enable 4 KB write protect for relative address 0x8000–0x8FFF in WP Segment x.  |  |  |

| St     | Stack Limit Control Register |                                                           | (STKCR) | (Address = 0x0444) |
|--------|------------------------------|-----------------------------------------------------------|---------|--------------------|
| Bit(s) | Value                        | Description                                               |         |                    |
| 7:1    |                              | These bits are reserved and should be written with zeros. |         |                    |
| 0      | 0                            | Disable stack-limit checking.                             |         |                    |
|        | 1                            | Enable stack-limit chec                                   | king.   |                    |

| :      | Stack Low Limit Register |                                                                                                                                                                                                 | (STKLLR) | (Address = 0x0445) |
|--------|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------------------|
| Bit(s) | Value                    | Description                                                                                                                                                                                     |          |                    |
| 7:0    |                          | Lower limit for stack-limit checking. If a stack operation or stack-relative memory access is attempted at an address less than {STKLLR, 0x10}, a stack-limit violation interrupt is generated. |          |                    |

| Stack High Limit Register |       | Limit Register                                                                                                                                                                                     | (STKHLR) | (Address = 0x0446) |
|---------------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------------------|
| Bit(s)                    | Value | Description                                                                                                                                                                                        |          |                    |
| 7:0                       |       | Upper limit for stack-limit checking. If a stack operation or stack-relative memory access is attempted at an address greater than {STKHLR, 0xEF}, a stack-limit violation interrupt is generated. |          | •                  |

# 6. INTERRUPTS

#### 6.1 Overview

The Rabbit 5000 can operate at one of four priority levels, 0–3, with Priority 0 being the expected standard operating level. The current priority and up to three previous priority levels are kept in the processor's 8-bit IP register, where bits 0–1 contain the current priority. Every time an interrupt is handled or an IPSET instruction occurs, the value in the register is shifted left by two bits, and the new priority placed in bits 0–1. When an IPRES or IRET instruction occurs, the value in IP is shifted right by two bits (bits 0–1 are shifted into bits 6–7). On reset, the processor starts at Priority 3.

Most interrupts can be set to be Priority 1–3. A pending interrupt will be handled only if its interrupt priority is greater than the current processor priority. This means that even a Priority 3 interrupt can be blocked if the processor is currently at Priority 3. The System Mode Violation, Stack Limit Violation, Write Protection Violation, secondary watchdog, and breakpoint interrupts are always enabled at Priority 3. In addition, when the System/ User Mode is enabled and the processor is in the User Mode, the processor will not actually enter Priority 3; any attempt to enter Priority 3 will actually be requested as Priority 2.

When an interrupt is handled, a call is executed to a fixed location in the interrupt vector tables. This operation requires 11 clocks, the minimum interrupt latency for the Rabbit 5000. There are two vector tables, the internal and the external interrupt vector tables, that can be located anywhere in logical memory by setting the processor's IIR and EIR registers. The IIR and EIR registers hold the upper byte of each table's address. For example, if IIR is loaded with 0xC4, then the internal interrupt vector table will start at the logical memory address 0xC400

The internal interrupt vector table occupies 512 bytes, and the external interrupt vector table is 256 bytes in size. Since the RST and SYSCALL vectors use all eight bits of the IIR for addressing, the lowermost bit of IIR should always be set to zero so to keep some vectors from inadvertently overlapping.

Each interrupt's vector begins on a 16-byte boundary inside the vector tables. It may be possible to fit a small routine into that space, but it is typical to place a call to a separate routine in that location.

Some Rabbit 5000 instructions are "chained atomic," which means that an interrupt cannot occur between that instruction and the following instruction. These instructions are useful for doing things like exiting interrupt handlers properly or updating semaphores.

Chapter 6 Interrupts 81

## 6.2 Operation

To ensure proper operation, all interrupt handler routines should be written according to the following guidelines.

- Push all registers to be used by the routine onto the stack before use, and pop them off the stack before returning from the ISR.
- Keep the ISR as short and fast as possible. The use of assembly code is strongly recommended.
- If the ISR will run for some time, lower the interrupt priority as soon as possible within the ISR to allow other interrupts to occur.
- A number of special rules apply to interrupts when operating in the system/user mode; please see the appropriate chapter for more details.

## 6.3 Interrupt Tables

Table 6-1 shows the structure of the internal interrupt vector table. The first column is the vector address offset within the table. The second column shows the vectors in the first 256 bytes of the table, and the third column shows the vectors in the second 256 bytes.

Table 6-1. Internal Interrupt Vector Table Structure

| Offset | 0x0000 + Offset         | 0x0100 + Offset         |
|--------|-------------------------|-------------------------|
| 0x00   | Periodic Interrupt      | _                       |
| 0x10   | Secondary Watchdog      | _                       |
| 0x20   | RST 10                  | _                       |
| 0x30   | RST 18                  | _                       |
| 0x40   | RST20                   | _                       |
| 0x50   | RST 28                  | _                       |
| 0x60   | Syscall instruction     | _                       |
| 0x70   | RST 38                  | PWM                     |
| 0x80   | Slave Port              | Sys/User Mode Violation |
| 0x90   | Write Protect Violation | Quadrature Decoder      |
| 0xA0   | Timer A                 | Input Capture           |
| 0xB0   | Timer B                 | Stack Limit Violation   |
| 0xC0   | Serial Port A           | Serial Port E           |
| 0xD0   | Serial Port B           | Serial Port F           |
| 0xE0   | Serial Port C           | Network Port B/C        |
| 0xF0   | Serial Port D           | Timer C                 |

Table 6-2 shows the structure of the external interrupt vector table. Each interrupt vector falls on a 16-byte boundary inside the table.

Table 6-2. External Interrupt Vector Table Structure

| Offset | 0x0000+              |
|--------|----------------------|
| 0x00   | External Interrupt 0 |
| 0x10   | External Interrupt 1 |
| 0x20   | _                    |
| 0x30   | _                    |
| 0x40   | Breakpoints          |
| 0x50   | _                    |
| 0x60   | _                    |
| 0x70   | _                    |
| 0x80   | DMA Channel 0        |
| 0x90   | DMA Channel 1        |
| 0xA0   | DMA Channel 2        |
| 0xB0   | DMA Channel 3        |
| 0xC0   | DMA Channel 4        |
| 0xD0   | DMA Channel 5        |
| 0xE0   | DMA Channel 6        |
| 0xF0   | DMA Channel 7        |

There is a priority among interrupts if multiple requests are pending, as shown in Table 6-3. Interrupts marked as "cleared automatically" have their requests cleared when the interrupt is first handled.

Chapter 6 Interrupts 83

Table 6-3. Interrupt Priorities

| Priority | Interrupt Source           | Action Required to Clear the Interrupt                                                        |  |  |
|----------|----------------------------|-----------------------------------------------------------------------------------------------|--|--|
| Highest  | Breakpoint                 | Read the status from BDCR.                                                                    |  |  |
|          | System Mode Violation      | Cleared automatically.                                                                        |  |  |
|          | Stack Limit Violation      | Cleared automatically.                                                                        |  |  |
|          | Write Protection Violation | Cleared automatically.                                                                        |  |  |
|          | Secondary Watchdog         | Restart secondary watchdog by writing to WDTCR.                                               |  |  |
|          | External Interrupt 1       | Cleared automatically.                                                                        |  |  |
|          | External Interrupt 0       | Cleared automatically.                                                                        |  |  |
|          | Periodic Interrupt         | Read the status from GCSR.                                                                    |  |  |
|          | Quadrature Decoder         | Read the status from QDCSR.                                                                   |  |  |
|          | Timer B                    | Read the status from TBCSR.                                                                   |  |  |
|          | Timer A                    | Read the status from TACSR.                                                                   |  |  |
|          | Input Capture              | Read the status from ICCSR.                                                                   |  |  |
|          | PWM                        | Write any PWM register.                                                                       |  |  |
|          | Timer C                    | Read the status from TCCSR.                                                                   |  |  |
|          | Slave Port                 | Rd: Read from SPD0R, SPD1R or SPD2R. Wr: Write to SPD0R, SPD1R, SPD2R or dummy write to SPSR. |  |  |
|          | DMA 7                      | Cleared automatically.                                                                        |  |  |
| ŀ        | DMA 6                      | Cleared automatically.                                                                        |  |  |
|          | DMA 5                      | Cleared automatically.                                                                        |  |  |
|          | DMA 4                      | Cleared automatically.                                                                        |  |  |
|          | DMA 3                      | Cleared automatically.                                                                        |  |  |
|          | DMA 2                      | Cleared automatically.                                                                        |  |  |
|          | DMA 1                      | Cleared automatically.                                                                        |  |  |
|          | DMA 0                      | Cleared automatically.                                                                        |  |  |
|          | Network Port B/C           | Read interrupt status from NBCSR or NCCSR.                                                    |  |  |
|          | Serial Port E              | Rx: Read from SEDR or SEAR. Tx: Write to SEDR, SEAR, SELR or dummy write to SESR.             |  |  |
|          | Serial Port F              | Rx: Read from SFDR or SFAR.  Tx: Write to SFDR, SFAR, SFLR or dummy write to SFSR.            |  |  |
|          | Serial Port A              | Rx: Read from SADR or SAAR. Tx: Write to SADR, SAAR, SALR or dummy write to SASR.             |  |  |
|          | Serial Port B              | Rx: Read from SBDR or SBAR.  Tx: Write to SBDR, SBAR, SBLR or dummy write to SBSR.            |  |  |
|          | Serial Port C              | Rx: Read from SCDR or SCAR.  Tx: Write to SCDR, SCAR, SCLR or dummy write to SCSR.            |  |  |
| Lowest   | Serial Port D              | Rx: Read from SDDR or SDAR. Tx: Write to SDDR, SDAR, SDLR or dummy write to SDSR.             |  |  |

# 7. EXTERNAL INTERRUPTS

#### 7.1 Overview

The Rabbit 5000 has six external interrupts available, and they share two interrupt vectors. In the case of multiple interrupts sharing an interrupt vector, the data register corresponding to the parallel port(s) being used can be read. Each interrupt vector can be set to trigger on a rising edge, a falling edge, or either edge.

The signal on the external interrupt pin must be present for at least three peripheral clock cycles to be detected. In addition, the Rabbit 5000 has a minimum latency of 11 clocks to respond to an interrupt, so the minimum external interrupt response time is three peripheral clock cycles plus 11 processor clock cycles.

## 7.2 Block Diagram



#### 7.2.1 Registers

| Register Name                | Mnemonic | I/O Address | R/W | Reset     |
|------------------------------|----------|-------------|-----|-----------|
| Interrupt 0 Control Register | I0CR     | 0x0098      | R/W | xx0000000 |
| Interrupt 1 Control Register | I1CR     | 0x0099      | R/W | xx000000  |

## 7.3 Dependencies

#### 7.3.1 I/O Pins

The external interrupts can be enabled on pins PD0, PD1, PE0, PE1, PE4, and PE5. Each pin is associated with a particular interrupt vector as shown in Table 7-1 below.

Table 7-1. Rabbit 5000 Interrupt Vectors

| Vector Register |      | Pins          |
|-----------------|------|---------------|
| Interrupt 0     | I0CR | PD0, PE0, PE4 |
| Interrupt 1     | I1CR | PD1, PE1, PE5 |

#### 7.3.2 Clocks

The external interrupts are controlled by the peripheral clock. A pulse must be present for at least three peripheral clock cycles to trigger an interrupt.

### 7.3.3 Interrupts

An external interrupt is generated whenever the selected edge occurs on an enabled pin. The interrupt request is automatically cleared when the interrupt is handled.

The external interrupt vectors are in the EIR at offsets 0x000 and 0x010. They can be set as Priority 1, 2, or 3 in the appropriate LxCR.

# 7.4 Operation

The following steps must be taken to enable the external interrupts.

- 1. Write the vector(s) to the interrupt service routine to the external interrupt table.
- 2. Configure IxCR to select which pins are enabled for external interrupts, what edges are detected on each pin, and the interrupt priority.
- 3. When an interrupt occurs, read PDDR and/or PEDR to determine which pin has a signal if more than one pin is enabled for a given external interrupt.

## 7.4.1 Example ISR

A sample interrupt handler is shown below.

```
extInt_isr::
; respond to external interrupt here
; interrupt is automatically cleared by interrupt acknowledge
ipres
ret
```

# 7.5 Register Descriptions

| In     | nterrupt x ( | Control Register                                     | (I0CR)<br>(I1CR)                               | (Address = 0x0098)<br>(Address = 0x0099) |
|--------|--------------|------------------------------------------------------|------------------------------------------------|------------------------------------------|
| Bit(s) | Value        | Description                                          |                                                |                                          |
| 7:6    | 00           | Parallel Port D low nibble                           | Parallel Port D low nibble interrupt disabled. |                                          |
|        | 01           | Parallel Port D low nibble                           | interrupt on falling edge.                     |                                          |
|        | 10           | Parallel Port D low nibble                           | interrupt on rising edge.                      |                                          |
|        | 11           | Parallel Port D low nibble                           | interrupt on both edges.                       |                                          |
| 5:4    | 00           | Parallel Port E high nibble                          | interrupt disabled.                            |                                          |
|        | 01           | Parallel Port E high nibble                          | interrupt on falling edge.                     |                                          |
|        | 10           | Parallel Port E high nibble                          | interrupt on rising edge.                      |                                          |
|        | 11           | Parallel Port E high nibble interrupt on both edges. |                                                |                                          |
| 3:2    | 00           | Parallel Port E low nibble                           | interrupt disabled.                            |                                          |
|        | 01           | Parallel Port E low nibble                           | interrupt on falling edge.                     |                                          |
|        | 10           | Parallel Port E low nibble                           | interrupt on rising edge.                      |                                          |
|        | 11           | Parallel Port E low nibble                           | interrupt on both edges.                       |                                          |
| 1:0    | 00           | This external interrupt is d                         | isabled.                                       |                                          |
|        | 01           | This external interrupt use                          | s Interrupt Priority 1.                        |                                          |
|        | 10           |                                                      |                                                |                                          |
|        | 11           |                                                      |                                                |                                          |

# 8. PARALLEL PORT A

#### 8.1 Overview

Parallel Port A is a byte-wide port that can be used as an input or an output port. Parallel Port A is also used as the data bus for the slave port and external I/O bus. The Slave Port Control Register (SPCR) is used to configure how Parallel Port A is used. Parallel Port A is an input at startup or reset. If the SMODE pins have selected the slave port bootstrap mode, Parallel Port A will be the slave port data bus until disabled by the processor. Parallel Port A can also be used as an external I/O data bus to isolate external I/O from the main data bus.

Table 8-1. Parallel Port A Pin Alternate Output Functions

| Pin Name | Slave Port<br>Data Bus | External I/O<br>Bus |  |
|----------|------------------------|---------------------|--|
| PA[7:0]  | SD[7:0]                | ID[7:0]             |  |

#### 8.1.1 Block Diagram



8.1.2 Registers

| Register Name        | Mnemonic | I/O Address | R/W | Reset   |
|----------------------|----------|-------------|-----|---------|
| Port A Data Register | PADR     | 0x0030      | R/W | xxxxxxx |

## 8.2 Dependencies

#### 8.2.1 I/O Pins

Parallel Port A uses pins PA0 through PA7. These pins can be used as follows.

- General-purpose 8-bit data input (write 0x080 to SPCR)
- General-purpose 8-bit data output (write 0x084 to SPCR)
- Slave port data bus (write 0x088 to SPCR)
- External I/O data bus (write 0x08C to SPCR)

All Parallel Port A bits are inputs at startup or reset.

See the associated peripheral chapters for details on how they use Parallel Port A.

#### 8.2.2 Clocks

Any outputs on Parallel Port A are clocked by the peripheral clock.

### 8.2.3 Other Registers

| Register | Function                        |
|----------|---------------------------------|
| SPCR     | Used to set up Parallel Port A. |

### 8.2.4 Interrupts

There are no interrupts associated with Parallel Port A, except when the slave port is being used.

# 8.3 Operation

The following steps explain how to set up Parallel Port A.

- 1. Select the desired mode using SPCR.
- 2. If the slave port or external I/O bus is selected, refer to the chapters for those peripherals for further setup.

Once Parallel Port A is set up, data can be read or written by accessing PADR. Note that Parallel Port A is not available for general-purpose I/O while the slave port or the external I/O bus is selected. Selecting these options for Parallel Port A affects Parallel Port B because Parallel Port B is then used for address and control signals.

# 8.4 Register Descriptions

| Pa     | Parallel Port A Data Register |                                                                                                                                                            | (PADR) | (Address = 0x0030) |
|--------|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------|
| Bit(s) | Value                         | Description                                                                                                                                                |        |                    |
| 7:0    | Read                          | The current state of Parallel Port A pins PA7–PA0 is reported.                                                                                             |        |                    |
|        | Write                         | The Parallel Port A buffer is written with this value for transfer to the Parallel Port A output register on the next rising edge of the peripheral clock. |        |                    |

| S      | lave Port (                                                      | Control Register (SPCR) (Address = 0x0024)                                                                                  |
|--------|------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit(s) | Value                                                            | Description                                                                                                                 |
| 7      | 0                                                                | Program fetch as a function of the SMODE pins.                                                                              |
|        | 1                                                                | Ignore the SMODE pins program fetch function.                                                                               |
| 6:5    | read                                                             | These bits report the state of the SMODE pins.                                                                              |
|        | write                                                            | These bits are ignored and should be written with zero.                                                                     |
| 4:2    | 000                                                              | Disable the slave port. Parallel Port A is a byte-wide input port.                                                          |
|        | 001                                                              | Disable the slave port. Parallel Port A is a byte-wide output port.                                                         |
|        | 010 Enable the slave port, with /SCS from Parallel Port E bit 7. |                                                                                                                             |
|        | 011                                                              | Enable the external I/O bus. Parallel Port A is used for the data bus and Parallel Port B[7:2] is used for the address bus. |
|        | 100                                                              | This bit combination is reserved and should not be used.                                                                    |
|        | 101                                                              | This bit combination is reserved and should not be used.                                                                    |
|        | 110                                                              | Enable the slave port, with /SCS from Parallel Port B bit 6.                                                                |
|        | 111                                                              | Enable the external I/O bus. Parallel Port A is used for the data bus and Parallel Port B[7:0] is used for the address bus. |
| 1:0    | 00                                                               | Slave port interrupts are disabled.                                                                                         |
|        | 01                                                               | Slave port interrupts use Interrupt Priority 1.                                                                             |
|        | 10                                                               | Slave port interrupts use Interrupt Priority 2.                                                                             |
|        | 11                                                               | Slave port interrupts use Interrupt Priority 3.                                                                             |

# 9. PARALLEL PORT B

#### 9.1 Overview

Parallel Port B is a byte-wide port with each bit programmable for direction. The Parallel Port B pins are also used to access other peripherals on the chip—the slave port, the auxiliary I/O address bus, and clock I/O for clocked serial mode option for Serial Ports A and B. The Slave Port Control Register (SPCR) is used to configure how Parallel Port B is used when selecting the slave port or the external I/O bus modes.

When the slave port is enabled, either under program control or during parallel bootstrap, Parallel Port B pins carry the Slave Attention output signal, and the Slave Read strobe, Slave Write strobe, and Slave Address inputs. The Slave Chip Select can also be programmed to come from a Parallel Port B pin.

When the external I/O bus option is enabled, either six or eight pins carry the external I/O address signals selected in SPCR.

Two pins are used for the clocks for Serial Ports A and B when they are configured for the clocked serial mode. These two inputs can be used as clock outputs for these ports if selected in the respective serial port control registers. Note that the clocked serial output clock selection overrides all other programming for the two relevant Parallel Port B pins.

Table 9-1. Parallel Port B Pin Alternate Output Functions

| Pin Name | Slave Port | Serial Ports<br>A–D | External I/O<br>Bus |
|----------|------------|---------------------|---------------------|
| PB7      | /SLVATTN   | _                   | IA5                 |
| PB6      | /SCS       | _                   | IA4                 |
| PB5      | SA1        | _                   | IA3                 |
| PB4      | SA0        | _                   | IA2                 |
| PB3      | /SRD       | _                   | IA1                 |
| PB2      | /SWR       | _                   | IA0                 |
| PB1      | _          | SCLKA               | IA7                 |
| PB0      | _          | SCLKB               | IA6                 |

### 9.1.1 Block Diagram



#### 9.1.2 Registers

| Register Name                  | Mnemonic | I/O Address | R/W | Reset    |
|--------------------------------|----------|-------------|-----|----------|
| Port B Data Register           | PBDR     | 0x0040      | R/W | 00xxxxxx |
| Port B Data Direction Register | PBDDR    | 0x0047      | R/W | 11000000 |

## 9.2 Dependencies

#### 9.2.1 I/O Pins

Parallel Port B uses pins PB0 through PB7. These pins can be used individually as data inputs or outputs; as the address bits for the external I/O bus; as control signals for the slave port; or as clocks for Serial Ports A and B.

On startup, bits 6 and 7 are outputs set low for backwards compatibility with the Rabbit 2000. All other pins are inputs.

Note that when the external I/O bus or slave port is enabled in SPCR, the Parallel Port B pins associated with those peripherals perform those actions, no matter what the settings are in PBDR or PBDDR. See the associated peripheral chapters for details on how they use Parallel Port B.

#### **9.2.2 Clocks**

All outputs on Parallel Port B are clocked by the peripheral clock (perclk).

### 9.2.3 Other Registers

| Register | Function                                                                                          |
|----------|---------------------------------------------------------------------------------------------------|
| SPCR     | Sets the Parallel Port B function for some pins if the slave port or external I/O bus is enabled. |

### 9.2.4 Interrupts

There are no interrupts associated with Parallel Port B, except when the slave port is being used.

## 9.3 Operation

The following steps must be taken before using Parallel Port B.

- 1. Select the desired input/output direction for each pin via PBDDR. Note that this setting is superseded for some pins if the slave port or external I/O bus is enabled in SPCR or if the clocked serial mode is enabled for Serial Ports A or B.
- 2. If the slave port or the external I/O bus is selected, refer to the chapters for those peripherals for further setup information.

Once the port is set up, data can be read or written by accessing PBDR. The value in PBDR of an output pin will reflect its current output value, but any value written to an input pin will not appear on that pin until that pin becomes an output.

## 9.4 Register Descriptions

| Pa     | rallel Port | B Data Register                                                                                                                                            | (PBDR) | (Address = 0x0040) |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------|
| Bit(s) | Value       | Description                                                                                                                                                |        |                    |
| 7:0    | Read        | The current state of Parallel Port B pins PB7–PB0 is reported.                                                                                             |        |                    |
|        | Write       | The Parallel Port B buffer is written with this value for transfer to the Parallel Port B output register on the next rising edge of the peripheral clock. |        |                    |

| Paralle | l Port B Da | ta Direction Register                    | (PBDDR)     | (Address = 0x0047) |
|---------|-------------|------------------------------------------|-------------|--------------------|
| Bit(s)  | Value       |                                          | Description |                    |
| 7:0     | 0           | The corresponding port bit is an input.  |             |                    |
|         | 1           | The corresponding port bit is an output. |             |                    |

| S      | lave Port ( | Control Register (SPCR) (Address = 0x0024)                                                                                  |  |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit(s) | Value       | Description                                                                                                                 |  |  |  |
| 7      | 0           | Program fetch as a function of the SMODE pins.                                                                              |  |  |  |
|        | 1           | Ignore the SMODE pins program fetch function.                                                                               |  |  |  |
| 6:5    | Read        | These bits report the state of the SMODE pins.                                                                              |  |  |  |
|        | Write       | These bits are ignored and should be written with zero.                                                                     |  |  |  |
| 4:2    | 000         | Disable the slave port. Parallel Port A is a byte-wide input port.                                                          |  |  |  |
|        | 001         | Disable the slave port. Parallel Port A is a byte-wide output port.                                                         |  |  |  |
|        | 010         | Enable the slave port, with /SCS from Parallel Port E bit 7.                                                                |  |  |  |
|        | 011         | Enable the external I/O bus. Parallel Port A is used for the data bus and Parallel Port B[7:2] is used for the address bus. |  |  |  |
|        | 100         | This bit combination is reserved and should not be used.                                                                    |  |  |  |
|        | 101         | This bit combination is reserved and should not be used.                                                                    |  |  |  |
|        | 110         | Enable the slave port, with /SCS from Parallel Port B bit 6.                                                                |  |  |  |
|        | 111         | Enable the external I/O bus. Parallel Port A is used for the data bus and Parallel Port B[7:0] is used for the address bus. |  |  |  |
| 1:0    | 00          | Slave port interrupts are disabled.                                                                                         |  |  |  |
|        | 01          | Slave port interrupts use Interrupt Priority 1.                                                                             |  |  |  |
|        | 10          | Slave port interrupts use Interrupt Priority 2.                                                                             |  |  |  |
|        | 11          | Slave port interrupts use Interrupt Priority 3.                                                                             |  |  |  |

# 10. PARALLEL PORT C

### 10.1 Overview

Parallel Port C is a byte-wide port with each bit programmable for data direction and drive level. These are simple inputs and outputs controlled and reported in the Port C Data Register (PCDR).

All the Parallel Port C pins have alternate output functions, and most of them can be used as inputs to various on-chip peripherals.

Table 10-1. Parallel Port C Pin Alternate Output Functions

| Pin Name | Alt Out 0 | Alt Out 1 | Alt Out 2 | Alt Out 3 |
|----------|-----------|-----------|-----------|-----------|
| PC7      | TXA       | 17        | PWM3      | SCLKC     |
| PC6      | TXA       | 16        | PWM2      | TXE       |
| PC5      | TXB       | 15        | PWM1      | RCLKE     |
| PC4      | TXB       | I4        | PWM0      | TCLKE     |
| PC3      | TXC       | 13        | TIMER C3  | SCLKD     |
| PC2      | TXC       | I2        | TIMER C2  | TXF       |
| PC1      | TXD       | I1        | TIMER C1  | RCLKF     |
| PC0      | TXD       | 10        | TIMER C0  | TCLKF     |

Table 10-2. Parallel Port C Pin Alternate Input Functions

| Pin Name | Input Capture | Serial Ports<br>A–D | Serial Ports<br>E–F |
|----------|---------------|---------------------|---------------------|
| PC7      | ×             | RXA                 | RXE                 |
| PC6      | _             | _                   | _                   |
| PC5      | ×             | RXB                 | RCLKE               |
| PC4      | _             | _                   | TCLKE               |
| PC3      | ×             | RXC                 | RXF                 |
| PC2      | _             | _                   | _                   |
| PC1      | ×             | RXD                 | RCLKF               |
| PC0      | _             | _                   | TCLKF               |

After reset, the default condition for Parallel Port C is four outputs (the even-numbered bits) and four inputs (the odd-numbered bits). For compatibility with the Rabbit 2000 and the Rabbit 3000 microprocessors, these outputs are driven with a logic zero (low) on PC6 and a logic one (high) on PC4, PC2, and PC0. When PCDR is read, the value of the voltage on the pin is returned. If the pin is an output, the value it is set to is returned.

### 10.1.1 Block Diagram



### 10.1.2 Registers

| Register Name                  | Mnemonic | I/O Address | R/W | Reset    |
|--------------------------------|----------|-------------|-----|----------|
| Port C Data Register           | PCDR     | 0x0050      | R/W | 00010101 |
| Port C Data Direction Register | PCDDR    | 0x0051      | R/W | 01010101 |
| Port C Alternate Low Register  | PCALR    | 0x0052      | R/W | 00000000 |
| Port C Alternate High Register | PCAHR    | 0x0053      | R/W | 00000000 |
| Port C Drive Control Register  | PCDCR    | 0x0054      | R/W | 00000000 |
| Port C Function Register       | PCFR     | 0x0055      | R/W | 00000000 |

## 10.2 Dependencies

#### 10.2.1 I/O Pins

Parallel Port C uses pins PC0 through PC7. These pins can be used individually as data inputs or outputs; as serial port transmit and receive for Serial ports A–F; as clocks for Serial Ports C–F; as external I/O strobes; or as outputs for the PWM and Timer C peripherals. The input capture peripheral can also watch pins PC7, PC5, PC3, and PC1.

On startup, PC4, PC2, and PC0 are outputs set high, PC6 is set low, and the other pins are inputs for compatibility with the Rabbit 3000.

The individual pins can be set to be open-drain via PCDCR.

See the associated peripheral chapters for details on how they use Parallel Port C.

#### 10.2.2 Clocks

All outputs on Parallel Port C are clocked by the peripheral clock.

### 10.2.3 Other Registers

| Register                              | Function                                                                        |  |
|---------------------------------------|---------------------------------------------------------------------------------|--|
| SACR, SBCR, SCCR,<br>SDCR, SECR, SFCR | Select a Parallel Port C pin as serial data (and optional clock) input.         |  |
| ICS1R, ICS2R                          | Select a Parallel Port C pin as a start/stop condition for Input Capture input. |  |

### 10.2.4 Interrupts

There are no interrupts associated with Parallel Port C.

# 10.3 Operation

The following steps must be taken before using Parallel Port C.

- 1. Select the desired input/output direction for each pin via PCDDR.
- 2. Select driven or open-drain functionality for outputs via PCDCR.
- 3. If an alternate peripheral output function is desired for a pin, select it via PCALR or PCAHR and then enable it via PCFR. Refer to the appropriate peripheral chapter for further use of that pin.

Once the port is set up, data can be read or written by accessing PCDR. The value in PCDR of an output pin will reflect its current output value, but any value written to an input pin will not appear on that pin until that pin becomes an output.

# 10.4 Register Descriptions

| Pa     | arallel Port | C Data Register                                                                                                                                            | (PCDR) | (Address = 0x0050) |
|--------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------|
| Bit(s) | Value        | Description                                                                                                                                                |        |                    |
| 7:0    | Read         | The current state of Parallel Port C pins PC7–PC0 is reported.                                                                                             |        |                    |
|        | Write        | The Parallel Port C buffer is written with this value for transfer to the Parallel Port C output register on the next rising edge of the peripheral clock. |        |                    |

| Paralle | Parallel Port C Data Direction Register |                                         | (PCDDR)       | (Address = 0x0051) |
|---------|-----------------------------------------|-----------------------------------------|---------------|--------------------|
| Bit(s)  | Value                                   | Description                             |               |                    |
| 7:0     | 0                                       | The corresponding port bit is an input. |               |                    |
|         | 1                                       | The corresponding port bit              | is an output. |                    |

| Paralle | l Port C Al | ternate Low Register (PCALR) (Address = 0x0052)      |  |  |  |  |
|---------|-------------|------------------------------------------------------|--|--|--|--|
| Bit(s)  | Value       | Description                                          |  |  |  |  |
| 7:6     | 00          | Parallel Port C bit 3 alternate output 0 (TXC).      |  |  |  |  |
|         | 01          | Parallel Port C bit 3 alternate output 1 (I3).       |  |  |  |  |
|         | 10          | Parallel Port C bit 3 alternate output 2 (TIMER C3). |  |  |  |  |
|         | 11          | Parallel Port C bit 3 alternate output 3 (SCLKD).    |  |  |  |  |
| 5:4     | 00          | Parallel Port C bit 2 alternate output 0 (TXC).      |  |  |  |  |
|         | 01          | Parallel Port C bit 2 alternate output 1 (I2).       |  |  |  |  |
|         | 10          | Parallel Port C bit 2 alternate output 2 (TIMER C2). |  |  |  |  |
|         | 11          | Parallel Port C bit 2 alternate output 3 (TXF).      |  |  |  |  |
| 3:2     | 00          | Parallel Port C bit 1 alternate output 0 (TXD).      |  |  |  |  |
|         | 01          | Parallel Port C bit 1 alternate output 1 (I1).       |  |  |  |  |
|         | 10          | Parallel Port C bit 1 alternate output 2 (TIMER C1). |  |  |  |  |
|         | 11          | Parallel Port C bit 1 alternate output 3 (RCLKF).    |  |  |  |  |
| 1:0     | 00          | Parallel Port C bit 0 alternate output 0 (TXD).      |  |  |  |  |
|         | 01          | Parallel Port C bit 0 alternate output 1 (I0).       |  |  |  |  |
|         | 10          | Parallel Port C bit 0 alternate output 2 (TIMER C0). |  |  |  |  |
|         | 11          | Parallel Port C bit 0 alternate output 3 (TCLKF).    |  |  |  |  |

| Paralle | l Port C Al | ternate High Register (PCAHR)                     | (Address = 0x0053) |  |  |  |  |
|---------|-------------|---------------------------------------------------|--------------------|--|--|--|--|
| Bit(s)  | Value       | Description                                       | 1                  |  |  |  |  |
| 7:6     | 00          | Parallel Port C bit 7 alternate output 0 (TXA).   |                    |  |  |  |  |
|         | 01          | Parallel Port C bit 7 alternate output 1 (I7).    |                    |  |  |  |  |
|         | 10          | Parallel Port C bit 7 alternate output 2 (PWM3    | ).                 |  |  |  |  |
|         | 11          | Parallel Port C bit 7 alternate output 3 (SCLKC   | C).                |  |  |  |  |
| 5:4     | 00          | Parallel Port C bit 6 alternate output 0 (TXA).   |                    |  |  |  |  |
|         | 01          | Parallel Port C bit 6 alternate output 1 (I6).    |                    |  |  |  |  |
|         | 10          | Parallel Port C bit 6 alternate output 2 (PWM2    | ).                 |  |  |  |  |
|         | 11          | Parallel Port C bit 6 alternate output 3 (TXE).   |                    |  |  |  |  |
| 3:2     | 00          | Parallel Port C bit 5 alternate output 0 (TXB).   |                    |  |  |  |  |
|         | 01          | Parallel Port C bit 5 alternate output 1 (I5).    |                    |  |  |  |  |
|         | 10          | Parallel Port C bit 5 alternate output 2 (PWM1    | ).                 |  |  |  |  |
|         | 11          | Parallel Port C bit 5 alternate output 3 (RCLKI   | Ε).                |  |  |  |  |
| 1:0     | 00          | Parallel Port C bit 4 alternate output 0 (TXB).   |                    |  |  |  |  |
|         | 01          |                                                   |                    |  |  |  |  |
|         | 10          | Parallel Port C bit 4 alternate output 2 (PWM0).  |                    |  |  |  |  |
|         | 11          | Parallel Port C bit 4 alternate output 3 (TCLKE). |                    |  |  |  |  |

| Paralle | Parallel Port C Drive Control Register |                                                                   | (PCDCR) | (Address = 0x0054) |  |  |
|---------|----------------------------------------|-------------------------------------------------------------------|---------|--------------------|--|--|
| Bit(s)  | Value                                  | Description                                                       |         |                    |  |  |
| 7:0     | 0                                      | The corresponding port bit, as an output, is driven high and low. |         |                    |  |  |
|         | 1                                      | The corresponding port bit, as an output, is open-drain.          |         |                    |  |  |

| Para   | Parallel Port C Function Register |                                                                                      | (PCFR) | (Address = 0x0055) |  |  |
|--------|-----------------------------------|--------------------------------------------------------------------------------------|--------|--------------------|--|--|
| Bit(s) | Value                             | Description                                                                          |        |                    |  |  |
| 7:0    | 0                                 | The corresponding port bit functions normally.                                       |        |                    |  |  |
|        | 1                                 | The corresponding port bit carries its alternate signal as an output. See Table 10-1 |        |                    |  |  |

| Se     | erial Port x | Control Register                                                                                                                                   | (SACR)<br>(SBCR)<br>(SCCR)<br>(SDCR) | (Address = 0x00C4)<br>(Address = 0x00D4)<br>(Address = 0x00E4)<br>(Address = 0x00F4) |  |  |  |
|--------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|--------------------------------------------------------------------------------------|--|--|--|
| Bit(s) | Value        |                                                                                                                                                    | Description                          |                                                                                      |  |  |  |
| 7:6    | 00           | No operation. These bits are                                                                                                                       | ignored in the async                 | rhronous mode.                                                                       |  |  |  |
|        | 01           | In the clocked serial mode, s                                                                                                                      | tart a byte-receive o                | peration.                                                                            |  |  |  |
|        | 10           | In the clocked serial mode, s                                                                                                                      | tart a byte-transmit o               | operation.                                                                           |  |  |  |
|        | 11           | In the clocked serial mode, s operation simultaneously.                                                                                            | tart a byte-transmit o               | operation and a byte-receive                                                         |  |  |  |
| 5:4    | 00           | Parallel Port C is used for input.                                                                                                                 |                                      |                                                                                      |  |  |  |
|        | 01           | Parallel Port D is used for input.                                                                                                                 |                                      |                                                                                      |  |  |  |
|        | 10           | Parallel Port E is used for inp                                                                                                                    |                                      |                                                                                      |  |  |  |
|        | 11           | Disable the receiver input.                                                                                                                        |                                      |                                                                                      |  |  |  |
| 3:2    | 00           | Asynchronous mode with 8 l                                                                                                                         | oits per character.                  |                                                                                      |  |  |  |
|        | 01           | Asynchronous mode with 7 bits per character. In this mode the most sign bit of a byte is ignored for transmit, and is always zero in receive data. |                                      |                                                                                      |  |  |  |
|        | 10           | Clocked serial mode with ex                                                                                                                        | ternal clock.                        |                                                                                      |  |  |  |
|        | 11           | Clocked serial mode with int                                                                                                                       | ernal clock.                         |                                                                                      |  |  |  |
| 1:0    | 00           | The serial port interrupt is disabled.                                                                                                             |                                      |                                                                                      |  |  |  |
|        | 01           | The serial port uses Interrupt Priority 1.                                                                                                         |                                      |                                                                                      |  |  |  |
|        | 10           | The serial port uses Interrupt Priority 2.                                                                                                         |                                      |                                                                                      |  |  |  |
|        | 11           | The serial port uses Interrupt Priority 3.                                                                                                         |                                      |                                                                                      |  |  |  |

| Inpu   | ut Capture                                  | Source x Register (ICS1R) (Address = 0x0 (ICS2R) (Address = 0x0 |  |  |  |  |
|--------|---------------------------------------------|-----------------------------------------------------------------|--|--|--|--|
| Bit(s) | Value                                       | Description                                                     |  |  |  |  |
| 7:6    | 00                                          | Parallel Port C used for Start condition input.                 |  |  |  |  |
|        | 01                                          | Parallel Port D used for Start condition input.                 |  |  |  |  |
|        | 10                                          | Parallel Port E used for Start condition input.                 |  |  |  |  |
|        | 11                                          | This bit combination is reserved and should not be used.        |  |  |  |  |
| 5:4    | 00                                          | Use port bit 1 for Start condition input.                       |  |  |  |  |
|        | 01                                          | Use port bit 3 for Start condition input.                       |  |  |  |  |
|        | 10                                          | Use port bit 5 for Start condition input.                       |  |  |  |  |
|        | 11                                          | Use port bit 7 for Start condition input.                       |  |  |  |  |
| 3:2    | 00                                          | Parallel Port C used for Stop condition input.                  |  |  |  |  |
|        | 01                                          | Parallel Port D used for Stop condition input.                  |  |  |  |  |
|        | 10                                          | Parallel Port E used for Stop condition input.                  |  |  |  |  |
|        | 11                                          | This bit combination is reserved and should not be used.        |  |  |  |  |
| 1:0    | 00                                          | Use port bit 1 for Stop condition input.                        |  |  |  |  |
|        | 01                                          | Use port bit 3 for Stop condition input.                        |  |  |  |  |
|        | 10                                          | Use port bit 5 for Stop condition input.                        |  |  |  |  |
|        | 11 Use port bit 7 for Stop condition input. |                                                                 |  |  |  |  |

# 11. PARALLEL PORT D

#### 11.1 Overview

Parallel Port D is a byte-wide port with each bit programmable for data direction and drive level. These are simple inputs and outputs controlled and reported in the Port D Data Register (PDDR).

All of the Parallel Port D pins have alternate output functions, and all of them can be used as inputs to various on-chip peripherals.

When used as outputs, the Parallel Port D bits are buffered, with the data written to PDDR transferred to the output pins on a selected timing edge. Either the peripheral clock or the outputs of Timer A1, Timer B1, or Timer B2 can be used for this function, with each nibble of the port having a separate select field to control this timing. Each bit can either be programmed as open-drain or driven high and low.

Because of the buffered nature of Parallel Port D, a read-modify-write type of operation can lead to old data being written to PDDR. To alleviate this potential problem, each bit of the port can be written individually using a separate address for each bit.

Table 11-1. Parallel Port D Pin Alternate Output Functions

| Pin Name | Alt Out 0 | Alt Out 1 | Alt Out 2 | Alt Out 3 |
|----------|-----------|-----------|-----------|-----------|
| PD7      | IA7       | I7        | PWM3      | SCLKC     |
| PD6      | TXA       | I6        | PWM2      | TXE       |
| PD5      | IA6       | I5        | PWM1      | RCLKE     |
| PD4      | TXB       | I4        | PWM0      | TCLKE     |
| PD3      | IA7       | I3        | TIMER C3  | SCLKD     |
| PD2      | SCLKC     | I2        | TIMER C2  | TXF       |
| PD1      | IA6       | I1        | TIMER C1  | RCLKF     |
| PD0      | SCLKD     | 10        | TIMER C0  | TCLKF     |

Table 11-2. Parallel Port D Pin Alternate Input Functions

| Pin Name | Input<br>Capture | Serial<br>Ports A–D | Serial<br>Ports E-F | DMA   | External Interrupts | Quad<br>Decode |
|----------|------------------|---------------------|---------------------|-------|---------------------|----------------|
| PD7      | ×                | RXA                 | RXE                 | _     | _                   | _              |
| PD6      |                  |                     |                     | _     |                     |                |
| PD5      | ×                | RXB                 | RCLKE               | _     | _                   |                |
| PD4      | _                | _                   | TCLKE               | _     | _                   | _              |
| PD3      | ×                | RXC                 | RXF                 | DREQ1 | _                   | QRD2A          |
| PD2      | _                | SCLKC               | _                   | DREQ0 | _                   | QRD2B          |
| PD1      | ×                | RXD                 | RCLKF               | _     | INT1                | QRD1A          |
| PD0      | _                | SCLKD               | TCLKF               | —     | INT0                | QRD1B          |

# 11.1.1 Block Diagram



# 11.1.2 Registers

| Register Name                  | Mnemonic | I/O Address | R/W | Reset    |
|--------------------------------|----------|-------------|-----|----------|
| Port D Data Register           | PDDR     | 0x0060      | R/W | xxxxxxxx |
| Port D Alternate Low Register  | PDALR    | 0x0062      | R/W | 00000000 |
| Port D Alternate High Register | PDAHR    | 0x0063      | R/W | 00000000 |
| Port D Control Register        | PDCR     | 0x0064      | R/W | xx00xx00 |
| Port D Function Register       | PDFR     | 0x0065      | R/W | xxxxxxxx |
| Port D Drive Control Register  | PDDCR    | 0x0066      | R/W | xxxxxxx  |
| Port D Data Direction Register | PDDDR    | 0x0067      | R/W | 00000000 |
| Port D Bit 0 Register          | PDB0R    | 0x0068      | W   | xxxxxxxx |
| Port D Bit 1 Register          | PDB1R    | 0x0069      | W   | xxxxxxx  |
| Port D Bit 2 Register          | PDB2R    | 0x006A      | W   | xxxxxxxx |
| Port D Bit 3 Register          | PDB3R    | 0x006B      | W   | xxxxxxxx |
| Port D Bit 4 Register          | PDB4R    | 0x006C      | W   | xxxxxxxx |
| Port D Bit 5 Register          | PDB5R    | 0x006D      | W   | xxxxxxxx |
| Port D Bit 6 Register          | PDB6R    | 0x006E      | W   | xxxxxxx  |
| Port D Bit 7 Register          | PDB7R    | 0x006F      | W   | xxxxxxxx |

### 11.2 Dependencies

#### 11.2.1 I/O Pins

Parallel Port D uses pins PD0 through PD7. These pins can be used individually as data inputs or outputs; as serial port transmit and receive for Serial Ports A, B, E, and F; as clocks for Serial Ports C–F; as external I/O strobes; or as outputs for the PWM and Timer C peripherals. The input capture peripheral can also watch pins PD7, PD5, PD3, and PD1.

All pins are set as inputs on startup.

The individual bits can be set to be open-drain via PDDCR.

See the associated peripheral chapters for details on how they use Parallel Port D.

#### 11.2.2 Clocks

All outputs on Parallel Port D are clocked by the peripheral clock unless changed in PDCR, where the option of updating the Parallel Port D pins can be synchronized to the output of Timer A1, Timer B1, or Timer B2.

#### 11.2.3 Other Registers

| Register                              | Function                                                                        |
|---------------------------------------|---------------------------------------------------------------------------------|
| SACR, SBCR, SCCR,<br>SDCR, SECR, SFCR | Select a Parallel Port D pin as serial data (and optional clock) input.         |
| ICS1R, ICS2R                          | Select a Parallel Port D pin as a start/stop condition for Input Capture input. |
| QDCR                                  | Select a Parallel Port D pin as a Quadrature Decoder input.                     |
| IOCR, I1CR                            | Select a Parallel Port D pin as an external interrupt input.                    |
| DMR0CR, DMR1CR                        | Select a Parallel Port D pin as an external DMA request input.                  |

#### 11.2.4 Interrupts

External interrupts can be accepted from pins PD1 or PD0; see Chapter 7 for more details.

### 11.3 Operation

The following steps must be taken before using Parallel Port D.

- 1. Select the desired input/output direction for each pin via PDDDR.
- 2. Select high/low or open-drain functionality for outputs via PDDCR.
- 3. If an alternative peripheral output function is desired for a pin, select it via PDALR or PDAHR and then enable it via PDFR. Refer to the appropriate peripheral chapter for further use of that pin.

Once Parallel Port D is set up, data can be read or written by accessing PDDR. Read PDDR to learn the current state of a Parallel Port D pin; any value written to an input pin will not appear on that pin until that pin becomes an output.

# 11.4 Register Descriptions

| Parallel Port D Data Register |       | (PDDR)                                                                                                                                                                                                        | (Address = 0x0060) |  |  |
|-------------------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|--|--|
| Bit(s)                        | Value | Description                                                                                                                                                                                                   |                    |  |  |
| 7:0                           | Read  | The current state of Parallel Port D pins PD7–PD0 is reported.                                                                                                                                                |                    |  |  |
|                               | Write | The Parallel Port D buffer is written with this value for transfer to the Parallel Port D output register on the next rising edge of the port transfer clock. The port transfer clock is established by PDCR. |                    |  |  |

| Paralle | I Port D A | ternate Low Register (PDALR) (Address = 0x0062)      |  |  |  |
|---------|------------|------------------------------------------------------|--|--|--|
| Bit(s)  | Value      | Description                                          |  |  |  |
| 7:6     | 00         | Parallel Port D bit 3 alternate output 0 (IA7).      |  |  |  |
|         | 01         | Parallel Port D bit 3 alternate output 1 (I3).       |  |  |  |
|         | 10         | Parallel Port D bit 3 alternate output 2 (TIMER C3). |  |  |  |
|         | 11         | Parallel Port D bit 3 alternate output 3 (SCLKD).    |  |  |  |
| 5:4     | 00         | Parallel Port D bit 2 alternate output 0 (SCLKC).    |  |  |  |
|         | 01         | Parallel Port D bit 2 alternate output 1 (I2).       |  |  |  |
|         | 10         | Parallel Port D bit 2 alternate output 2 (TIMER C2). |  |  |  |
|         | 11         | Parallel Port D bit 2 alternate output 3 (TXF).      |  |  |  |
| 3:2     | 00         | Parallel Port D bit 1 alternate output 0 (IA6).      |  |  |  |
|         | 01         | Parallel Port D bit 1 alternate output 1 (I1).       |  |  |  |
|         | 10         | Parallel Port D bit 1 alternate output 2 (TIMER C1). |  |  |  |
|         | 11         | Parallel Port D bit 1 alternate output 3 (RCLKF).    |  |  |  |
| 1:0     | 00         | Parallel Port D bit 0 alternate output 0 (SCLKD).    |  |  |  |
|         | 01         | Parallel Port D bit 0 alternate output 1 (I0).       |  |  |  |
|         | 10         | Parallel Port D bit 0 alternate output 2 (TIMER C0). |  |  |  |
|         | 11         | Parallel Port D bit 0 alternate output 3 (TCLKF).    |  |  |  |

| Paralle | l Port D Al | ternate High Register (PDAHR)                     | (Address = 0x0063) |  |  |
|---------|-------------|---------------------------------------------------|--------------------|--|--|
| Bit(s)  | Value       | Description                                       |                    |  |  |
| 7:6     | 00          | Parallel Port D bit 7 alternate output 0 (IA7).   |                    |  |  |
|         | 01          | Parallel Port D bit 7 alternate output 1 (I7).    |                    |  |  |
|         | 10          | Parallel Port D bit 7 alternate output 2 (PWM3).  |                    |  |  |
|         | 11          | Parallel Port D bit 7 alternate output 3 (SCLKC). |                    |  |  |
| 5:4     | 00          | Parallel Port D bit 6 alternate output 0 (TXA).   |                    |  |  |
|         | 01          | Parallel Port D bit 6 alternate output 1 (I6).    |                    |  |  |
|         | 10          | Parallel Port D bit 6 alternate output 2 (PWM2).  |                    |  |  |
|         | 11          | Parallel Port D bit 6 alternate output 3 (TXE).   |                    |  |  |
| 3:2     | 00          | Parallel Port D bit 5 alternate output 0 (IA6).   |                    |  |  |
|         | 01          | Parallel Port D bit 5 alternate output 1 (I5).    |                    |  |  |
|         | 10          | Parallel Port D bit 5 alternate output 2 (PWM1).  |                    |  |  |
|         | 11          | Parallel Port D bit 5 alternate output 3 (RCLKE). |                    |  |  |
| 1:0     | 00          | Parallel Port D bit 4 alternate output 0 (TXB).   |                    |  |  |
|         | 01          | Parallel Port D bit 4 alternate output 1 (I4).    |                    |  |  |
|         | 10          | Parallel Port D bit 4 alternate output 2 (PWM0).  |                    |  |  |
|         | 11          | Parallel Port D bit 4 alternate output 3 (TCLKE). |                    |  |  |

| Par    | allel Port [ | O Control Register                                                     | (PDCR)                    | (Address = 0x0064)    |  |  |
|--------|--------------|------------------------------------------------------------------------|---------------------------|-----------------------|--|--|
| Bit(s) | Value        |                                                                        | Description               |                       |  |  |
| 7:6    |              | These bits are ignored and                                             | l should be written wi    | th zero.              |  |  |
| 5:4    | 00           | The upper nibble of the po                                             | ort transfer clock is pe  | erclk/2.              |  |  |
|        | 01           | The upper nibble of the port transfer clock is the output of Timer A1. |                           |                       |  |  |
|        | 10           | The upper nibble of the port transfer clock is the output of Timer B1. |                           |                       |  |  |
|        | 11           | The upper nibble of the port transfer clock is the output of Timer B2. |                           |                       |  |  |
| 3:2    |              | These bits are ignored and should be written with zero.                |                           |                       |  |  |
| 1:0    | 00           | The lower nibble of the port transfer clock is perclk/2.               |                           |                       |  |  |
|        | 01           | The lower nibble of the port transfer clock is the output of Timer A1. |                           |                       |  |  |
|        | 10           | The lower nibble of the port transfer clock is the output of Timer B1. |                           |                       |  |  |
|        | 11           | The lower nibble of the po                                             | ort transfer clock is the | e output of Timer B2. |  |  |

| Parallel Port D Function Register |       | Function Register                              | (PDFR)                      | (Address = 0x0065)                 |  |
|-----------------------------------|-------|------------------------------------------------|-----------------------------|------------------------------------|--|
| Bit(s)                            | Value | Description                                    |                             |                                    |  |
| 7:0                               | 0     | The corresponding port bit functions normally. |                             |                                    |  |
|                                   | 1     | The corresponding port b                       | it carries its alternate si | gnal as an output. See Table 11-1. |  |

| Paralle | Parallel Port D Drive Control Register |                                                                   | (PDDCR)                  | (Address = 0x0066) |
|---------|----------------------------------------|-------------------------------------------------------------------|--------------------------|--------------------|
| Bit(s)  | Value                                  | Description                                                       |                          |                    |
| 7:0     | 0                                      | The corresponding port bit, as an output, is driven high and low. |                          |                    |
|         | 1                                      | The corresponding port bi                                         | t, as an output, is open | n-drain.           |

| Paralle | l Port D Da | a Direction Register (PDDDR) (Address = 0x0067) |  |  |
|---------|-------------|-------------------------------------------------|--|--|
| Bit(s)  | Value       | Description                                     |  |  |
| 7:0     | 0           | The corresponding port bit is an input.         |  |  |
|         | 1           | The corresponding port bit is an output.        |  |  |

| Pa     | Parallel Port D Bit 0 Register |                         | (PDB0R) | (Address = 0x0068)                                                         |  |
|--------|--------------------------------|-------------------------|---------|----------------------------------------------------------------------------|--|
| Bit(s) | Value                          | Description             |         |                                                                            |  |
| 7:1    |                                | These bits are ignored. |         |                                                                            |  |
| 0      | Write                          |                         |         | of this bit. The port buffer will be<br>t rising edge of the port transfer |  |

| Parallel Port D Bit 1 Register |       | (PDB1R)                 | (Address = 0x0069) |                                                                            |  |
|--------------------------------|-------|-------------------------|--------------------|----------------------------------------------------------------------------|--|
| Bit(s)                         | Value | Description             |                    |                                                                            |  |
| 7:2,0                          |       | These bits are ignored. |                    |                                                                            |  |
| 1                              | Write |                         |                    | of this bit. The port buffer will be<br>t rising edge of the port transfer |  |

| Parallel Port D Bit 2 Register |       | (PDB2R)                 | (Address = 0x006A) |                                                                            |  |
|--------------------------------|-------|-------------------------|--------------------|----------------------------------------------------------------------------|--|
| Bit(s)                         | Value | Description             |                    |                                                                            |  |
| 7:3,1:0                        |       | These bits are ignored. |                    |                                                                            |  |
| 2                              | Write |                         |                    | of this bit. The port buffer will be<br>t rising edge of the port transfer |  |

| Parallel Port D Bit 3 Register |       | (PDB3R)                 | (Address = 0x006B) |                                                                            |  |
|--------------------------------|-------|-------------------------|--------------------|----------------------------------------------------------------------------|--|
| Bit(s)                         | Value | Description             |                    |                                                                            |  |
| 7:4,2:0                        |       | These bits are ignored. |                    |                                                                            |  |
| 3                              | Write |                         |                    | of this bit. The port buffer will be<br>t rising edge of the port transfer |  |

| Parallel Port D Bit 4 Register |       | (PDB4R)                 | (Address = 0x006C) |                                                                            |  |
|--------------------------------|-------|-------------------------|--------------------|----------------------------------------------------------------------------|--|
| Bit(s)                         | Value | Description             |                    |                                                                            |  |
| 7:5,3:0                        |       | These bits are ignored. |                    |                                                                            |  |
| 4                              | Write |                         |                    | of this bit. The port buffer will be<br>t rising edge of the port transfer |  |

| Parallel Port D Bit 5 Register |       | (PDB5R)                 | (Address = 0x006D) |                                                                            |  |
|--------------------------------|-------|-------------------------|--------------------|----------------------------------------------------------------------------|--|
| Bit(s)                         | Value | Description             |                    |                                                                            |  |
| 7:6,4:0                        |       | These bits are ignored. |                    |                                                                            |  |
| 5                              | Write |                         |                    | of this bit. The port buffer will be<br>t rising edge of the port transfer |  |

| Pa     | Parallel Port D Bit 6 Register |                         | (PDB6R) | (Address = 0x006E)                                                         |  |
|--------|--------------------------------|-------------------------|---------|----------------------------------------------------------------------------|--|
| Bit(s) | Value                          | Description             |         |                                                                            |  |
| 7,5:0  |                                | These bits are ignored. |         |                                                                            |  |
| 6      | Write                          |                         |         | of this bit. The port buffer will be<br>t rising edge of the port transfer |  |

| Parallel Port D Bit 7 Register |       | (PDB7R)                 | (Address = 0x006F) |                                                                            |  |  |
|--------------------------------|-------|-------------------------|--------------------|----------------------------------------------------------------------------|--|--|
| Bit(s)                         | Value | Description             |                    |                                                                            |  |  |
| 6:0                            |       | These bits are ignored. |                    |                                                                            |  |  |
| 7                              | Write |                         |                    | of this bit. The port buffer will be<br>t rising edge of the port transfer |  |  |

| Se     | erial Port x | Control Register                                          | (SACR)<br>(SBCR)<br>(SCCR)<br>(SDCR) | (Address = 0x00C4)<br>(Address = 0x00D4)<br>(Address = 0x00E4)<br>(Address = 0x00F4) |  |
|--------|--------------|-----------------------------------------------------------|--------------------------------------|--------------------------------------------------------------------------------------|--|
| Bit(s) | Value        |                                                           | Description                          |                                                                                      |  |
| 7:6    | 00           | No operation. These bits are                              | ignored in the async                 | hronous mode.                                                                        |  |
|        | 01           | In the clocked serial mode, s                             | tart a byte-receive op               | peration.                                                                            |  |
|        | 10           | In the clocked serial mode, s                             | tart a byte-transmit o               | operation.                                                                           |  |
|        | 11           | In the clocked serial mode, so operation simultaneously.  | tart a byte-transmit o               | operation and a byte-receive                                                         |  |
| 5:4    | 00           | Parallel Port C is used for inp                           | out.                                 |                                                                                      |  |
|        | 01           | Parallel Port D is used for input.                        |                                      |                                                                                      |  |
|        | 10           | Parallel Port E is used for inp                           | ut.                                  |                                                                                      |  |
|        | 11           | Disable the receiver input.                               |                                      |                                                                                      |  |
| 3:2    | 00           | Asynchronous mode with 8 b                                | oits per character.                  |                                                                                      |  |
|        | 01           | Asynchronous mode with 7 bit of a byte is ignored for tra |                                      | this mode the most significant s zero in receive data.                               |  |
|        | 10           | Clocked serial mode with ex                               | ternal clock.                        |                                                                                      |  |
|        | 11           | Clocked serial mode with int                              | ernal clock.                         |                                                                                      |  |
| 1:0    | 00           | The serial port interrupt is di                           | sabled.                              |                                                                                      |  |
|        | 01           | The serial port uses Interrupt                            | Priority 1.                          |                                                                                      |  |
|        | 10           | The serial port uses Interrupt                            | Priority 2.                          |                                                                                      |  |
|        | 11           | The serial port uses Interrupt                            | Priority 3.                          |                                                                                      |  |

| Inpu   | ıt Capture | Source x Register (ICS1R) (Address = 0x0059) (ICS2R) (Address = 0x005D) |  |  |  |  |  |
|--------|------------|-------------------------------------------------------------------------|--|--|--|--|--|
| Bit(s) | Value      | Description                                                             |  |  |  |  |  |
| 7:6    | 00         | Parallel Port C used for Start condition input.                         |  |  |  |  |  |
|        | 01         | Parallel Port D used for Start condition input.                         |  |  |  |  |  |
|        | 10         | Parallel Port E used for Start condition input.                         |  |  |  |  |  |
|        | 11         | This bit combination is reserved and should not be used.                |  |  |  |  |  |
| 5:4    | 00         | Use port bit 1 for Start condition input.                               |  |  |  |  |  |
|        | 01         | Use port bit 3 for Start condition input.                               |  |  |  |  |  |
|        | 10         | Use port bit 5 for Start condition input.                               |  |  |  |  |  |
|        | 11         | Use port bit 7 for Start condition input.                               |  |  |  |  |  |
| 3:2    | 00         | Parallel Port C used for Stop condition input.                          |  |  |  |  |  |
|        | 01         | Parallel Port D used for Stop condition input.                          |  |  |  |  |  |
|        | 10         | Parallel Port E used for Stop condition input.                          |  |  |  |  |  |
|        | 11         | This bit combination is reserved and should not be used.                |  |  |  |  |  |
| 1:0    | 00         | Use port bit 1 for Stop condition input.                                |  |  |  |  |  |
|        | 01         | Use port bit 3 for Stop condition input.                                |  |  |  |  |  |
|        | 10         | Use port bit 5 for Stop condition input.                                |  |  |  |  |  |
|        | 11         | Use port bit 7 for Stop condition input.                                |  |  |  |  |  |

| Qu     | ad Decode | e Control Register (QDCR) (Address = 0x0091)                                                                                          |  |  |  |  |  |
|--------|-----------|---------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Bit(s) | Value     | Description                                                                                                                           |  |  |  |  |  |
| 7:6    | 00        | Disable Quadrature Decoder 2 inputs. Writing a new value to these bits will neause Quadrature Decoder 2 to increment or decrement.    |  |  |  |  |  |
|        | 01        | Quadrature Decoder 2 inputs from Parallel Port D bits 3 and 2.                                                                        |  |  |  |  |  |
|        | 10        | Quadrature Decoder 2 inputs from Parallel Port E bits 3 and 2.                                                                        |  |  |  |  |  |
|        | 11        | Quadrature Decoder 2 inputs from Parallel Port E bits 7 and 6.                                                                        |  |  |  |  |  |
| 5      | 0         | Eight-bit quadrature decoder counters (both channels).                                                                                |  |  |  |  |  |
|        | 1         | Ten-bit quadrature decoder counters (both channels).                                                                                  |  |  |  |  |  |
| 4      |           | This bit is reserved and should be written as zero.                                                                                   |  |  |  |  |  |
| 3:2    | 00        | Disable Quadrature Decoder 1 inputs. Writing a new value to these bits will not cause Quadrature Decoder 1 to increment or decrement. |  |  |  |  |  |
|        | 01        | Quadrature Decoder 1 inputs from Parallel Port D bits 1 and 0.                                                                        |  |  |  |  |  |
|        | 10        | Quadrature Decoder 1 inputs from Parallel Port E bits 1 and 0.                                                                        |  |  |  |  |  |
|        | 11        | Quadrature Decoder 1 inputs from Parallel Port E bits 5 and 4.                                                                        |  |  |  |  |  |
| 1:0    | 00        | Quadrature Decoder interrupts are disabled.                                                                                           |  |  |  |  |  |
|        | 01        | Quadrature Decoder interrupt use Interrupt Priority 1.                                                                                |  |  |  |  |  |
|        | 10        | Quadrature Decoder interrupt use Interrupt Priority 2.                                                                                |  |  |  |  |  |
|        | 11        | Quadrature Decoder interrupt use Interrupt Priority 3.                                                                                |  |  |  |  |  |

| In     | nterrupt x ( | Control Register                                       | (I0CR)<br>(I1CR)                               | (Address = 0x0098)<br>(Address = 0x0099) |  |  |  |  |
|--------|--------------|--------------------------------------------------------|------------------------------------------------|------------------------------------------|--|--|--|--|
| Bit(s) | Value        |                                                        | Description                                    |                                          |  |  |  |  |
| 7:6    | 00           | Parallel Port D low nibble in                          | Parallel Port D low nibble interrupt disabled. |                                          |  |  |  |  |
|        | 01           | Parallel Port D low nibble in                          | nterrupt on falling edge.                      |                                          |  |  |  |  |
|        | 10           | Parallel Port D low nibble in                          | nterrupt on rising edge.                       |                                          |  |  |  |  |
|        | 11           | Parallel Port D low nibble in                          | nterrupt on both edges.                        |                                          |  |  |  |  |
| 5:4    | 00           | Parallel Port E high nibble in                         | nterrupt disabled.                             |                                          |  |  |  |  |
|        | 01           | Parallel Port E high nibble interrupt on falling edge. |                                                |                                          |  |  |  |  |
|        | 10           | Parallel Port E high nibble in                         | nterrupt on rising edge.                       |                                          |  |  |  |  |
|        | 11           | Parallel Port E high nibble in                         | nterrupt on both edges.                        |                                          |  |  |  |  |
| 3:2    | 00           | Parallel Port E low nibble interrupt disabled.         |                                                |                                          |  |  |  |  |
|        | 01           | Parallel Port E low nibble in                          | terrupt on falling edge.                       |                                          |  |  |  |  |
|        | 10           | Parallel Port E low nibble in                          | terrupt on rising edge.                        |                                          |  |  |  |  |
|        | 11           | Parallel Port E low nibble in                          | iterrupt on both edges.                        |                                          |  |  |  |  |
| 1:0    | 00           | This external interrupt is dis                         | abled.                                         |                                          |  |  |  |  |
|        | 01           | This external interrupt uses                           | Interrupt Priority 1.                          |                                          |  |  |  |  |
|        | 10           | This external interrupt uses                           | Interrupt Priority 2.                          |                                          |  |  |  |  |
|        | 11           | This external interrupt uses                           | Interrupt Priority 3.                          |                                          |  |  |  |  |

| DMA Ma | aster Requ | uest 0 Control Register (DMR0CR) (Address = 0x0106)                      |  |  |  |  |  |
|--------|------------|--------------------------------------------------------------------------|--|--|--|--|--|
| Bit(s) | Value      | Description                                                              |  |  |  |  |  |
| 7:6    | 00         | External DMA Request 0 disabled.                                         |  |  |  |  |  |
|        | 01         | External DMA Request 0 enabled from Parallel Port D2.                    |  |  |  |  |  |
|        | 10         | External DMA Request 0 enabled from Parallel Port E2.                    |  |  |  |  |  |
|        | 11         | External DMA Request 0 enabled from Parallel Port E6.                    |  |  |  |  |  |
| 5      |            | This bit is reserved and should be written with zero.                    |  |  |  |  |  |
| 4:3    | 00         | External DMA Request 0 falling-edge triggered. One transfer per request. |  |  |  |  |  |
|        | 01         | External DMA Request 0 rising-edge triggered. One transfer per request.  |  |  |  |  |  |
|        | 10         | External DMA Request 0 active low. Transfers continue while low.         |  |  |  |  |  |
|        | 11         | External DMA Request 0 active high. Transfers continue while high.       |  |  |  |  |  |
| 2:0    | 000        | External DMA Request 0 supplied to DMA Channel 0.                        |  |  |  |  |  |
|        | 001        | External DMA Request 0 supplied to DMA Channel 1.                        |  |  |  |  |  |
|        | 010        | External DMA Request 0 supplied to DMA Channel 2.                        |  |  |  |  |  |
|        | 011        | External DMA Request 0 supplied to DMA Channel 3.                        |  |  |  |  |  |
|        | 100        | External DMA Request 0 supplied to DMA Channel 4.                        |  |  |  |  |  |
|        | 101        | External DMA Request 0 supplied to DMA Channel 5.                        |  |  |  |  |  |
|        | 110        | External DMA Request 0 supplied to DMA Channel 6.                        |  |  |  |  |  |
|        | 111        | External DMA Request 0 supplied to DMA Channel 7.                        |  |  |  |  |  |

| DMA Ma | aster Requ | uest 1 Control Register (DMR1CR) (Address = 0x0107)                     |
|--------|------------|-------------------------------------------------------------------------|
| Bit(s) | Value      | Description                                                             |
| 7:6    | 00         | External DMA Request 1 disabled.                                        |
|        | 01         | External DMA Request 1 enabled from Parallel Port D3.                   |
|        | 10         | External DMA Request 1 enabled from Parallel Port E3.                   |
|        | 11         | External DMA Request 1 enabled from Parallel Port E7.                   |
| 5      |            | This bit is reserved and should be written with zero.                   |
| 4:3    | 00         | External DMA Request 1 falling edge triggered. One byte per request.    |
|        | 01         | External DMA Request 1 rising edge triggered. One transfer per request. |
|        | 10         | External DMA Request 1 active low. Transfers continue while low.        |
|        | 11         | External DMA Request 1 active high. Transfers continue while high.      |
| 2:0    | 000        | External DMA Request 1 supplied to DMA Channel 0.                       |
|        | 001        | External DMA Request 1 supplied to DMA Channel 1.                       |
|        | 010        | External DMA Request 1 supplied to DMA Channel 2.                       |
|        | 011        | External DMA Request 1 supplied to DMA Channel 3.                       |
|        | 100        | External DMA Request 1 supplied to DMA Channel 4.                       |
|        | 101        | External DMA Request 1 supplied to DMA Channel 5.                       |
|        | 110        | External DMA Request 1 supplied to DMA Channel 6.                       |
|        | 111        | External DMA Request 1 supplied to DMA Channel 7.                       |

# 12. PARALLEL PORT E

#### 12.1 Overview

Parallel Port E is a byte-wide port with each bit programmable for data direction and drive level. These are simple inputs and outputs controlled and reported in the Port E Data Register (PEDR).

All of the Parallel Port E pins have alternate output functions, and all of them can be used as inputs to various on-chip peripherals.

When used as outputs, the Parallel Port E bits are buffered, with the data written to PEDR transferred to the output pins on a selected timing edge. Either the peripheral clock or the outputs of Timer A1, Timer B1, or Timer B2 can be used for this function, with each nibble of the port having a separate select field to control this timing. Each bit can either be programmed as open-drain or driven high and low.

Because of the buffered nature of Parallel Port E, using a read-modify-write type of operation can lead to old data being written to PEDR. To alleviate this potential problem, each bit of the port can be written individually using a separate address for each bit.

Bit 7 of Parallel Port E is used as the default chip select input for the slave port when the slave port is enabled, either for parallel bootstrap or under program control.

Table 12-1. Parallel Port E Pin Alternate Output Functions

| Pin Name | Alt Out 0 | Alt Out 1 | Alt Out 2 | Alt Out 3 |
|----------|-----------|-----------|-----------|-----------|
| PE7      | I7        | _         | PWM3      | SCLKC     |
| PE6      | I6        | _         | PWM2      | TXE       |
| PE5      | 15        | _         | PWM1      | RCLKE     |
| PE4      | I4        | /A0       | PWM0      | TCLKE     |
| PE3      | 13        | A23       | TIMER C3  | SCLKD     |
| PE2      | 12        | A22       | TIMER C2  | TXF       |
| PE1      | I1        | A21       | TIMER C1  | RCLKF     |
| PE0      | 10        | A20       | TIMER C0  | TCLKF     |

Table 12-2. Parallel Port E Pin Alternate Input Functions

| Pin Name | Input<br>Capture | I/O Hand-<br>shake | Serial<br>Ports A–D | Serial<br>Ports E-F | DMA   | External Interrupts | Quad<br>Decode |
|----------|------------------|--------------------|---------------------|---------------------|-------|---------------------|----------------|
| PE7      | ×                | ×                  | RXA                 | RXE                 | DREQ1 | _                   | _              |
| PE6      | _                | ×                  | _                   | _                   | DREQ0 | _                   | _              |
| PE5      | ×                | ×                  | RXB                 | RCLKE               | _     | INT1                | _              |
| PE4      | _                | ×                  | _                   | TCLKE               | _     | INT0                | _              |
| PE3      | ×                | ×                  | RXC                 | RXF                 | DREQ1 | _                   | QRD2A          |
| PE2      | _                | ×                  | SCLKC               | _                   | DREQ0 | _                   | QRD2B          |
| PE1      | ×                | ×                  | RXD                 | RCLKF               | _     | INT1                | QRD1A          |
| PE0      | _                | ×                  | SCLKD               | TCLKF               | _     | INT0                | QRD1B          |

### 12.1.1 Block Diagram



#### 12.1.2 Registers

| Register Name                  | Mnemonic | I/O Address | R/W | Reset    |
|--------------------------------|----------|-------------|-----|----------|
| Port E Data Register           | PEDR     | 0x0070      | R/W | xxxxxxx  |
| Port E Alternate Low Register  | PEALR    | 0x0072      | R/W | 00000000 |
| Port E Alternate High Register | PEAHR    | 0x0073      | R/W | 00000000 |
| Port E Control Register        | PECR     | 0x0074      | R/W | xx00xx00 |
| Port E Function Register       | PEFR     | 0x0075      | R/W | 00000000 |
| Port E Drive Control Register  | PEDCR    | 0x0076      | R/W | 00000000 |
| Port E Data Direction Register | PEDDR    | 0x0077      | R/W | 00000000 |
| Port E Bit 0 Register          | PEB0R    | 0x0078      | W   | xxxxxxxx |
| Port E Bit 1 Register          | PEB1R    | 0x0079      | W   | xxxxxxx  |
| Port E Bit 2 Register          | PEB2R    | 0x007A      | W   | xxxxxxxx |
| Port E Bit 3 Register          | PEB3R    | 0x007B      | W   | xxxxxxxx |
| Port E Bit 4 Register          | PEB4R    | 0x007C      | W   | xxxxxxxx |
| Port E Bit 5 Register          | PEB5R    | 0x007D      | W   | xxxxxxxx |
| Port E Bit 6 Register          | PEB6R    | 0x007E      | W   | xxxxxxxx |
| Port E Bit 7 Register          | PEB7R    | 0x007F      | W   | xxxxxxx  |

### 12.2 Dependencies

#### 12.2.1 I/O Pins

Parallel Port E uses the pins PE0 through PE7. These pins can be used individually as data inputs or outputs; as serial port transmit and receive for Serial Ports E and F; as clocks for Serial Ports C–F; as external I/O strobes; as outputs for the PWM and Timer C peripherals; or as the upper address bits A[23:20]. The input capture peripheral can also watch pins PE7, PE5, PE3, and PE1. There is also an option to provide the slave port chip select on PE7.

All pins are set as inputs on startup.

The individual bits can be set to be open-drain via PEDCR.

See the associated peripheral chapters for details on how they use Parallel Port E.

#### 12.2.2 Clocks

All outputs on Parallel Port E are clocked by the peripheral clock unless changed in PECR, where the option of updating the Parallel Port E pins can be synchronized to the output of Timer A1, Timer B1, or Timer B2.

#### 12.2.3 Other Registers

| Register                              | Function                                                                        |
|---------------------------------------|---------------------------------------------------------------------------------|
| SACR, SBCR, SCCR,<br>SDCR, SECR, SFCR | Select a Parallel Port E pin as serial data (and optional clock) input.         |
| ICS1R, ICS2R                          | Select a Parallel Port E pin as a start/stop condition for Input Capture input. |
| QDCR                                  | Select a Parallel Port E pin as a Quadrature Decoder input.                     |
| IOCR, I1CR                            | Select a Parallel Port E pin as an external interrupt input.                    |
| DMR0CR, DMR1CR                        | Select a Parallel Port E pin as an external DMA request input.                  |
| SPCR                                  | Select slave chip select on PE7.                                                |
| IHCR, IHSR, IHTR                      | Select a Parallel Port E pin for I/O handshake.                                 |

#### 12.2.4 Interrupts

External interrupts can be accepted from pins PE5, PE4, PE1 or PE0; see Chapter 7 for more details.

## 12.3 Operation

The following steps must be taken before using Parallel Port E.

- 1. Select the desired input/output direction for each pin via PEDDR.
- 2. Select high/low or open-drain functionality for outputs via PEDCR.
- 3. If an alternative peripheral output function is desired for a pin, select it via PEALR or PEAHR and then enable it via PEFR. Refer to the appropriate peripheral chapter for further use of that pin.

Once the port is set up, data can be read or written by accessing PEDR. Read PEDR to learn the current state of a Parallel Port E pin; any value written to an input pin will not appear on that pin until that pin becomes an output.

# 12.4 Register Descriptions

| Pa     | arallel Port | t E Data Register (PEDR) (Address = 0                                                                                                                                                                         |  | (Address = 0x0070) |
|--------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--------------------|
| Bit(s) | Value        | Description                                                                                                                                                                                                   |  |                    |
| 7:0    | Read         | The current state of Parallel Port E pins PE7–PE0 is reported.                                                                                                                                                |  |                    |
|        | Write        | The Parallel Port E buffer is written with this value for transfer to the Parallel Port E output register on the next rising edge of the port transfer clock. The port transfer clock is established by PECR. |  |                    |

| Paralle | el Port E A | Iternate Low Register (PEALR) (Address = 0x0072)     |  |  |  |
|---------|-------------|------------------------------------------------------|--|--|--|
| Bit(s)  | Value       | Description                                          |  |  |  |
| 7:6     | 00          | Parallel Port E bit 3 alternate output 0 (I3).       |  |  |  |
|         | 01          | Parallel Port E bit 3 alternate output 1 (A23).      |  |  |  |
|         | 10          | Parallel Port E bit 3 alternate output 2 (TIMER C3). |  |  |  |
|         | 11          | Parallel Port E bit 3 alternate output 3 (SCLKD).    |  |  |  |
| 5:4     | 00          | Parallel Port E bit 2 alternate output 0 (I2).       |  |  |  |
|         | 01          | Parallel Port E bit 2 alternate output 1 (A22).      |  |  |  |
|         | 10          | Parallel Port E bit 2 alternate output 2 (TIMER C2). |  |  |  |
|         | 11          | Parallel Port E bit 2 alternate output 3 (TXF).      |  |  |  |
| 3:2     | 00          | Parallel Port E bit 1 alternate output 0 (I1).       |  |  |  |
|         | 01          | Parallel Port E bit 1 alternate output 1 (A21).      |  |  |  |
|         | 10          | Parallel Port E bit 1 alternate output 2 (TIMER C1). |  |  |  |
|         | 11          | Parallel Port E bit 1 alternate output 3 (RCLKF).    |  |  |  |
| 1:0     | 00          | Parallel Port E bit 0 alternate output 0 (I0).       |  |  |  |
|         | 01          | Parallel Port E bit 0 alternate output 1 (A20).      |  |  |  |
|         | 10          | Parallel Port E bit 0 alternate output 2 (TIMER C0). |  |  |  |
|         | 11          | Parallel Port E bit 0 alternate output 3 (TCLKF).    |  |  |  |

| Paralle | l Port E Al | ternate High Register (PEAHR) (Address = 0x0073)             |  |  |  |
|---------|-------------|--------------------------------------------------------------|--|--|--|
| Bit(s)  | Value       | Description                                                  |  |  |  |
| 7:6     | 00          | Parallel Port E bit 7 alternate output 0 (I7).               |  |  |  |
|         | 01          | Parallel Port E bit 7 alternate output 1 (no functionality). |  |  |  |
|         | 10          | Parallel Port E bit 7 alternate output 2 (PWM3).             |  |  |  |
|         | 11          | Parallel Port E bit 7 alternate output 3 (SCLKC).            |  |  |  |
| 5:4     | 00          | Parallel Port E bit 6 alternate output 0 (I6).               |  |  |  |
|         | 01          | Parallel Port E bit 6 alternate output 1 (no functionality). |  |  |  |
|         | 10          | Parallel Port E bit 6 alternate output 2 (PWM2).             |  |  |  |
|         | 11          | Parallel Port E bit 6 alternate output 3 (TXE).              |  |  |  |
| 3:2     | 00          | Parallel Port E bit 5 alternate output 0 (I5).               |  |  |  |
|         | 01          | Parallel Port E bit 5 alternate output 1 (no functionality). |  |  |  |
|         | 10          | Parallel Port E bit 5 alternate output 2 (PWM1).             |  |  |  |
|         | 11          | Parallel Port E bit 5 alternate output 3 RCLKE).             |  |  |  |
| 1:0     | 00          | Parallel Port E bit 4 alternate output 0 (I4).               |  |  |  |
|         | 01          | Parallel Port E bit 4 alternate output 1 (/A0).              |  |  |  |
|         | 10          | Parallel Port E bit 4 alternate output 2 (PWM0).             |  |  |  |
|         | 11          | Parallel Port E bit 4 alternate output 3 (TCLKE).            |  |  |  |

| Par    | allel Port E | E Control Register (PECR) (Address = 0x0074)                 |  |  |  |
|--------|--------------|--------------------------------------------------------------|--|--|--|
| Bit(s) | Value        | Description                                                  |  |  |  |
| 7:6    |              | These bits are ignored and should be written with zero.      |  |  |  |
| 5:4    | 00           | The upper nibble peripheral clock is perclk/2.               |  |  |  |
|        | 01           | The upper nibble peripheral clock is the output of Timer A1. |  |  |  |
|        | 10           | The upper nibble peripheral clock is the output of Timer B1. |  |  |  |
|        | 11           | The upper nibble peripheral clock is the output of Timer B2. |  |  |  |
| 3:2    |              | These bits are ignored and should be written with zero.      |  |  |  |
| 1:0    | 00           | The lower nibble peripheral clock is perclk/2.               |  |  |  |
|        | 01           | The lower nibble peripheral clock is the output of Timer A1. |  |  |  |
|        | 10           | The lower nibble peripheral clock is the output of Timer B1. |  |  |  |
|        | 11           | The lower nibble peripheral clock is the output of Timer B2. |  |  |  |

| Para   | llel Port E | Function Register                              | (PEFR)                        | (Address = 0x0075)                 |
|--------|-------------|------------------------------------------------|-------------------------------|------------------------------------|
| Bit(s) | Value       |                                                | Description                   |                                    |
| 7:0    | 0           | The corresponding port bit functions normally. |                               |                                    |
|        | 1           | The corresponding port b                       | oit carries its alternate sig | gnal as an output. See Table 12-1. |

| Paralle | el Port E Dr | rive Control Register                                             | (PEDCR)              | (Address = 0x0076) |
|---------|--------------|-------------------------------------------------------------------|----------------------|--------------------|
| Bit(s)  | Value        | Description                                                       |                      |                    |
| 7:0     | 0            | The corresponding port bit, as an output, is driven high and low. |                      |                    |
|         | 1            | The corresponding port bit                                        | as an output, is ope | n-drain.           |

| Paralle | l Port E Da | ta Direction Register                   | (PEDDR)       | (Address = 0x0077) |
|---------|-------------|-----------------------------------------|---------------|--------------------|
| Bit(s)  | Value       |                                         | Description   |                    |
| 7:0     | 0           | The corresponding port bit is an input. |               |                    |
|         | 1           | The corresponding port bit              | is an output. |                    |

| Pa     | arallel Port | E Bit 0 Register        | (PEB0R) | (Address = 0x0078)                                                      |
|--------|--------------|-------------------------|---------|-------------------------------------------------------------------------|
| Bit(s) | Value        | Description             |         |                                                                         |
| 7:1    |              | These bits are ignored. |         |                                                                         |
| 0      | Write        |                         |         | of this bit. The port buffer will be<br>t rising edge of the peripheral |

| Pa     | rallel Port | t E Bit 1 Register (PEB1R) (Addre |  | (Address = 0x0079)                                                      |
|--------|-------------|-----------------------------------|--|-------------------------------------------------------------------------|
| Bit(s) | Value       | Description                       |  |                                                                         |
| 7:2,0  |             | These bits are ignored.           |  |                                                                         |
| 1      | Write       |                                   |  | of this bit. The port buffer will be<br>t rising edge of the peripheral |

| Pa      | rallel Port | t E Bit 2 Register (PEB2R) (A |  | (Address = 0x007A)                                                      |
|---------|-------------|-------------------------------|--|-------------------------------------------------------------------------|
| Bit(s)  | Value       | Description                   |  |                                                                         |
| 7:3,1:0 |             | These bits are ignored.       |  |                                                                         |
| 2       | Write       |                               |  | of this bit. The port buffer will be<br>t rising edge of the peripheral |

| Pa      | Parallel Port E Bit 3 Register |                         | (PEB3R)     | (Address = 0x007B)                                                      |
|---------|--------------------------------|-------------------------|-------------|-------------------------------------------------------------------------|
| Bit(s)  | Value                          |                         | Description |                                                                         |
| 7:4,2:0 |                                | These bits are ignored. |             |                                                                         |
| 3       | Write                          | 1 \                     |             | of this bit. The port buffer will be<br>t rising edge of the peripheral |

| Pa      | Parallel Port E Bit 4 Register |                         | (PEB4R)     | (Address = 0x007C)                                                      |
|---------|--------------------------------|-------------------------|-------------|-------------------------------------------------------------------------|
| Bit(s)  | Value                          |                         | Description |                                                                         |
| 7:5,3:0 |                                | These bits are ignored. |             |                                                                         |
| 4       | Write                          |                         |             | of this bit. The port buffer will be<br>t rising edge of the peripheral |

| Parallel Port E Bit 5 Register |       | (PEB5R)                 | (Address = 0x007D) |                                                                        |
|--------------------------------|-------|-------------------------|--------------------|------------------------------------------------------------------------|
| Bit(s)                         | Value | Description             |                    |                                                                        |
| 7:6,4:0                        |       | These bits are ignored. |                    |                                                                        |
| 5                              | Write |                         |                    | f this bit. The port buffer will be<br>t rising edge of the peripheral |

| Pa     | arallel Port | E Bit 6 Register        | (PEB6R) | (Address = 0x007E)                                                       |
|--------|--------------|-------------------------|---------|--------------------------------------------------------------------------|
| Bit(s) | Value        | Description             |         |                                                                          |
| 7,5:0  |              | These bits are ignored. |         |                                                                          |
| 6      | Write        | 1 , ,                   |         | of this bit. The port buffer will be<br>tt rising edge of the peripheral |

| Pa     | arallel Port | E Bit 7 Register        | (PEB7R) | (Address = 0x007F)                                                      |
|--------|--------------|-------------------------|---------|-------------------------------------------------------------------------|
| Bit(s) | Value        | Description             |         |                                                                         |
| 6:0    |              | These bits are ignored. |         |                                                                         |
| 7      | Write        |                         |         | of this bit. The port buffer will be<br>t rising edge of the peripheral |

| Se     | erial Port x | Control Register                                     | (SACR)<br>(SBCR)<br>(SCCR)<br>(SDCR)         | (Address = 0x00C4)<br>(Address = 0x00D4)<br>(Address = 0x00E4)<br>(Address = 0x00F4) |  |
|--------|--------------|------------------------------------------------------|----------------------------------------------|--------------------------------------------------------------------------------------|--|
| Bit(s) | Value        |                                                      | Description                                  |                                                                                      |  |
| 7:6    | 00           | No operation. These bits a                           | re ignored in the asyr                       | nchronous mode.                                                                      |  |
|        | 01           | In the clocked serial mode                           | e, start a byte-receive                      | operation.                                                                           |  |
|        | 10           | In the clocked serial mode                           | e, start a byte-transmit                     | operation.                                                                           |  |
|        | 11           | In the clocked serial mode operation simultaneously. | e, start a byte-transmit                     | operation and a byte-receive                                                         |  |
| 5:4    | 00           | Parallel Port C is used for                          | input.                                       |                                                                                      |  |
|        | 01           | Parallel Port D is used for input.                   |                                              |                                                                                      |  |
|        | 10           | Parallel Port E is used for                          | input.                                       |                                                                                      |  |
|        | 11           | Disable the receiver input.                          |                                              |                                                                                      |  |
| 3:2    | 00           | Asynchronous mode with                               | Asynchronous mode with 8 bits per character. |                                                                                      |  |
|        | 01           | Asynchronous mode with bit of a byte is ignored for  |                                              | n this mode the most significant ys zero in receive data.                            |  |
|        | 10           | Clocked serial mode with                             | external clock.                              |                                                                                      |  |
|        | 11           | Clocked serial mode with                             | internal clock.                              |                                                                                      |  |
| 1:0    | 00           | The serial port interrupt is disabled.               |                                              |                                                                                      |  |
|        | 01           | 01 The serial port uses Interrupt Priority 1.        |                                              |                                                                                      |  |
|        | 10           | The serial port uses Interru                         | upt Priority 2.                              |                                                                                      |  |
|        | 11           | The serial port uses Interru                         | upt Priority 3.                              |                                                                                      |  |

| Inpu   | ıt Capture | Source x Register                                                                    | (ICS1R)<br>(ICS2R)                             | (Address = 0x0059)<br>(Address = 0x005D) |  |  |
|--------|------------|--------------------------------------------------------------------------------------|------------------------------------------------|------------------------------------------|--|--|
| Bit(s) | Value      |                                                                                      | Description                                    |                                          |  |  |
| 7:6    | 00         | Parallel Port C used for Star                                                        | rt condition input.                            |                                          |  |  |
|        | 01         | Parallel Port D used for Sta                                                         | rt condition input.                            |                                          |  |  |
|        | 10         | Parallel Port E used for Star                                                        | rt condition input.                            |                                          |  |  |
|        | 11         | This bit combination is rese                                                         | erved and should not                           | t be used.                               |  |  |
| 5:4    | 00         | Use port bit 1 for Start cond                                                        | lition input.                                  |                                          |  |  |
|        | 01         | Use port bit 3 for Start cond                                                        | lition input.                                  |                                          |  |  |
|        | 10         | Use port bit 5 for Start condition input.  Use port bit 7 for Start condition input. |                                                |                                          |  |  |
|        | 11         |                                                                                      |                                                |                                          |  |  |
| 3:2    | 00         | Parallel Port C used for Sto                                                         | Parallel Port C used for Stop condition input. |                                          |  |  |
|        | 01         | Parallel Port D used for Sto                                                         | p condition input.                             |                                          |  |  |
|        | 10         | Parallel Port E used for Stop                                                        | p condition input.                             |                                          |  |  |
|        | 11         | This bit combination is reserved and should not be used.                             |                                                |                                          |  |  |
| 1:0    | 00         | Use port bit 1 for Stop cond                                                         | Use port bit 1 for Stop condition input.       |                                          |  |  |
|        | 01         | Use port bit 3 for Stop cond                                                         | lition input.                                  |                                          |  |  |
|        | 10         | Use port bit 5 for Stop cond                                                         | lition input.                                  |                                          |  |  |
|        | 11         | Use port bit 7 for Stop cond                                                         | lition input.                                  |                                          |  |  |

| Qu     | ad Decode | • Control Register (QDCR) (Address = 0x0091)                                                                                          |  |  |
|--------|-----------|---------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit(s) | Value     | Description                                                                                                                           |  |  |
| 7:6    | 00        | Disable Quadrature Decoder 2 inputs. Writing a new value to these bits will not cause Quadrature Decoder 2 to increment or decrement. |  |  |
|        | 01        | Quadrature Decoder 2 inputs from Parallel Port D bits 3 and 2.                                                                        |  |  |
|        | 10        | Quadrature Decoder 2 inputs from Parallel Port E bits 3 and 2.                                                                        |  |  |
|        | 11        | Quadrature Decoder 2 inputs from Parallel Port E bits 7 and 6.                                                                        |  |  |
| 5      | 0         | Eight-bit quadrature decoder counters (both channels).                                                                                |  |  |
|        | 1         | Ten-bit quadrature decoder counters (both channels).                                                                                  |  |  |
| 4      |           | This bit is reserved and should be written as zero.                                                                                   |  |  |
| 3:2    | 00        | Disable Quadrature Decoder 1 inputs. Writing a new value to these bits will not cause Quadrature Decoder 1 to increment or decrement. |  |  |
|        | 01        | Quadrature Decoder 1 inputs from Parallel Port D bits 1 and 0.                                                                        |  |  |
|        | 10        | Quadrature Decoder 1 inputs from Parallel Port E bits 1 and 0.                                                                        |  |  |
|        | 11        | Quadrature Decoder 1 inputs from Parallel Port E bits 5 and 4.                                                                        |  |  |
| 1:0    | 00        | Quadrature Decoder interrupts are disabled.                                                                                           |  |  |
|        | 01        | Quadrature Decoder interrupt use Interrupt Priority 1.                                                                                |  |  |
|        | 10        | Quadrature Decoder interrupt use Interrupt Priority 2.                                                                                |  |  |
|        | 11        | Quadrature Decoder interrupt use Interrupt Priority 3.                                                                                |  |  |

| lr     | nterrupt x ( | Control Register                                       | (I0CR)<br>(I1CR)                                      | (Address = 0x0098)<br>(Address = 0x0099) |  |  |
|--------|--------------|--------------------------------------------------------|-------------------------------------------------------|------------------------------------------|--|--|
| Bit(s) | Value        |                                                        | Description                                           |                                          |  |  |
| 7:6    | 00           | Parallel Port D low nibb                               | le interrupt disabled.                                |                                          |  |  |
|        | 01           | Parallel Port D low nibb                               | le interrupt on falling edge.                         |                                          |  |  |
|        | 10           | Parallel Port D low nibb                               | le interrupt on rising edge.                          |                                          |  |  |
|        | 11           | Parallel Port D low nibb                               | le interrupt on both edges.                           |                                          |  |  |
| 5:4    | 00           | Parallel Port E high nibb                              | ele interrupt disabled.                               |                                          |  |  |
|        | 01           | Parallel Port E high nibble interrupt on falling edge. |                                                       |                                          |  |  |
|        | 10           | Parallel Port E high nibb                              | Parallel Port E high nibble interrupt on rising edge. |                                          |  |  |
|        | 11           | Parallel Port E high nibble interrupt on both edges.   |                                                       |                                          |  |  |
| 3:2    | 00           | Parallel Port E low nibbl                              | e interrupt disabled.                                 |                                          |  |  |
|        | 01           | Parallel Port E low nibbl                              | Parallel Port E low nibble interrupt on falling edge. |                                          |  |  |
|        | 10           | Parallel Port E low nibbl                              | e interrupt on rising edge.                           |                                          |  |  |
|        | 11           | Parallel Port E low nibbl                              | e interrupt on both edges.                            |                                          |  |  |
| 1:0    | 00           | This external interrupt is                             | disabled.                                             |                                          |  |  |
|        | 01           | This external interrupt uses Interrupt Priority 1.     |                                                       |                                          |  |  |
|        | 10           | This external interrupt u                              | ses Interrupt Priority 2.                             |                                          |  |  |
|        | 11           | This external interrupt u                              | ses Interrupt Priority 3.                             |                                          |  |  |

| DMA Ma | aster Requ | est 0 Control Register (DMR0CR) (Address = 0x0106)                       |  |  |  |
|--------|------------|--------------------------------------------------------------------------|--|--|--|
| Bit(s) | Value      | Description                                                              |  |  |  |
| 7:6    | 00         | External DMA Request 0 disabled.                                         |  |  |  |
|        | 01         | External DMA Request 0 enabled from Parallel Port D2.                    |  |  |  |
|        | 10         | External DMA Request 0 enabled from Parallel Port E2.                    |  |  |  |
|        | 11         | External DMA Request 0 enabled from Parallel Port E6.                    |  |  |  |
| 5      |            | This bit is reserved and should be written with zero.                    |  |  |  |
| 4:3    | 00         | External DMA Request 0 falling-edge triggered. One transfer per request. |  |  |  |
|        | 01         | External DMA Request 0 rising-edge triggered. One transfer per request.  |  |  |  |
|        | 10         | External DMA Request 0 active low. Transfers continue while low.         |  |  |  |
|        | 11         | External DMA Request 0 active high. Transfers continue while high.       |  |  |  |
| 2:0    | 000        | External DMA Request 0 supplied to DMA Channel 0.                        |  |  |  |
|        | 001        | External DMA Request 0 supplied to DMA Channel 1.                        |  |  |  |
|        | 010        | External DMA Request 0 supplied to DMA Channel 2.                        |  |  |  |
|        | 011        | External DMA Request 0 supplied to DMA Channel 3.                        |  |  |  |
|        | 100        | External DMA Request 0 supplied to DMA Channel 4.                        |  |  |  |
|        | 101        | External DMA Request 0 supplied to DMA Channel 5.                        |  |  |  |
|        | 110        | External DMA Request 0 supplied to DMA Channel 6.                        |  |  |  |
|        | 111        | External DMA Request 0 supplied to DMA Channel 7.                        |  |  |  |

| DMA Ma | aster Requ | uest 1 Control Register (DMR1CR) (Address = 0x0107)                     |  |  |  |
|--------|------------|-------------------------------------------------------------------------|--|--|--|
| Bit(s) | Value      | Description                                                             |  |  |  |
| 7:6    | 00         | External DMA Request 1 disabled.                                        |  |  |  |
|        | 01         | External DMA Request 1 enabled from Parallel Port D3.                   |  |  |  |
|        | 10         | External DMA Request 1 enabled from Parallel Port E3.                   |  |  |  |
|        | 11         | External DMA Request 1 enabled from Parallel Port E7.                   |  |  |  |
| 5      |            | This bit is reserved and should be written with zero.                   |  |  |  |
| 4:3    | 00         | External DMA Request 1 falling edge triggered. One byte per request.    |  |  |  |
|        | 01         | External DMA Request 1 rising edge triggered. One transfer per request. |  |  |  |
|        | 10         | External DMA Request 1 active low. Transfers continue while low.        |  |  |  |
|        | 11         | External DMA Request 1 active high. Transfers continue while high.      |  |  |  |
| 2:0    | 000        | External DMA Request 1 supplied to DMA Channel 0.                       |  |  |  |
|        | 001        | External DMA Request 1 supplied to DMA Channel 1.                       |  |  |  |
|        | 010        | External DMA Request 1 supplied to DMA Channel 2.                       |  |  |  |
|        | 011        | External DMA Request 1 supplied to DMA Channel 3.                       |  |  |  |
|        | 100        | External DMA Request 1 supplied to DMA Channel 4.                       |  |  |  |
|        | 101        | External DMA Request 1 supplied to DMA Channel 5.                       |  |  |  |
|        | 110        | External DMA Request 1 supplied to DMA Channel 6.                       |  |  |  |
|        | 111        | External DMA Request 1 supplied to DMA Channel 7.                       |  |  |  |

| S      | lave Port (                                        | Control Register (SPCR)                                                                                                     | ) (Address = 0x0024)    |  |  |
|--------|----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-------------------------|--|--|
| Bit(s) | Value                                              | Descri                                                                                                                      | ription                 |  |  |
| 7      | 0                                                  | Program fetch as a function of the SMOI                                                                                     | DE pins.                |  |  |
|        | 1                                                  | Ignore the SMODE pins program fetch for                                                                                     | function.               |  |  |
| 6:5    | Read                                               | These bits report the state of the SMODE                                                                                    | E pins.                 |  |  |
|        | Write                                              | These bits are ignored and should be writ                                                                                   | itten with zero.        |  |  |
| 4:2    | 000                                                | Disable the slave port. Parallel Port A is                                                                                  | a byte-wide input port. |  |  |
|        | 001                                                | Disable the slave port. Parallel Port A is a byte-wide output port.                                                         |                         |  |  |
|        | 010                                                | Enable the slave port, with /SCS from Parallel Port E bit 7.                                                                |                         |  |  |
|        | 011                                                | Enable the external I/O bus. Parallel Port A is used for the data bus and Parallel Port B[7:2] is used for the address bus. |                         |  |  |
|        | 100                                                | This bit combination is reserved and should not be used.                                                                    |                         |  |  |
|        | 101                                                | This bit combination is reserved and should not be used.                                                                    |                         |  |  |
|        | 110                                                | Enable the slave port, with /SCS from Pa                                                                                    | arallel Port B bit 6.   |  |  |
|        | 111                                                | Enable the external I/O bus. Parallel Port A is used for the data bus and Parallel Port B[7:0] is used for the address bus. |                         |  |  |
| 1:0    | 00                                                 | Slave port interrupts are disabled.                                                                                         |                         |  |  |
|        | 01                                                 | Slave port interrupts use Interrupt Priorit                                                                                 | ty 1.                   |  |  |
|        | 10 Slave port interrupts use Interrupt Priority 2. |                                                                                                                             |                         |  |  |
|        | 11                                                 | Slave port interrupts use Interrupt Priorit                                                                                 | ty 3.                   |  |  |

| I/O    | Handshak | e Control Register                                                         | (IHCR)                                                                     | (Address = 0x0028) |  |  |
|--------|----------|----------------------------------------------------------------------------|----------------------------------------------------------------------------|--------------------|--|--|
| Bit(s) | Value    | Description                                                                |                                                                            |                    |  |  |
| 7:5    |          | These bits are reserved and should be written with zeros.                  |                                                                            |                    |  |  |
| 4      | 0        | I/O handshake is active low (I/O transaction held until signal goes high). |                                                                            |                    |  |  |
|        | 1        | I/O handshake is active high                                               | I/O handshake is active high (I/O transaction held until signal goes low). |                    |  |  |
| 3      |          | This bit is reserved and should be written with zero.                      |                                                                            |                    |  |  |
| 2:0    | 000      | Use Parallel Port E bit 0 for I                                            | /O handshake.                                                              |                    |  |  |
|        | 001      | Use Parallel Port E bit 1 for I                                            | /O handshake.                                                              |                    |  |  |
|        | 010      |                                                                            |                                                                            |                    |  |  |
|        | 011      | Use Parallel Port E bit 3 for I                                            | /O handshake.                                                              |                    |  |  |
|        | 100      | Use Parallel Port E bit 4 for I                                            | /O handshake.                                                              |                    |  |  |
|        | 101      | Use Parallel Port E bit 5 for I                                            | /O handshake.                                                              |                    |  |  |
|        | 110      | Use Parallel Port E bit 6 for I                                            | /O handshake.                                                              |                    |  |  |
|        | 111      | Use Parallel Port E bit 7 for I                                            | /O handshake.                                                              |                    |  |  |

| I/O                                       | Handshak                                  | ke Select Register                    | (IHSR)      | (Address = 0x0029) |  |  |
|-------------------------------------------|-------------------------------------------|---------------------------------------|-------------|--------------------|--|--|
| Bit(s)                                    | Value                                     | Description                           |             |                    |  |  |
| 7                                         | 0                                         | Disable I/O handshake for I/O Bank 7. |             |                    |  |  |
|                                           | 1                                         | Enable I/O handshake for I/O Bank 7.  |             |                    |  |  |
| 6                                         | 0                                         | Disable I/O handshake for             | I/O Bank 6. |                    |  |  |
|                                           | 1                                         | Enable I/O handshake for I            | O Bank 6.   |                    |  |  |
| 5 0 Disable I/O handshake for I/O Bank 5. |                                           |                                       |             |                    |  |  |
|                                           | 1                                         | Enable I/O handshake for I            |             |                    |  |  |
| 4                                         | 0                                         | Disable I/O handshake for             | I/O Bank 4. |                    |  |  |
|                                           | 1                                         | Enable I/O handshake for I            | O Bank 4.   |                    |  |  |
| 3 0 Disable I/O handshake for I/O Bank 3. |                                           |                                       |             |                    |  |  |
|                                           | 1                                         | Enable I/O handshake for I            | O Bank 3.   |                    |  |  |
| 2                                         | 2 0 Disable I/O handshake for I/O Bank 2. |                                       |             |                    |  |  |
|                                           | 1                                         | Enable I/O handshake for I            | O Bank 2.   |                    |  |  |
| 1                                         | 0                                         | Disable I/O handshake for             | I/O Bank 1. |                    |  |  |
|                                           | 1                                         | Enable I/O handshake for I            | O Bank 1.   |                    |  |  |
| 0                                         | 0                                         | Disable I/O handshake for             | I/O Bank 0. |                    |  |  |
|                                           | 1                                         | Enable I/O handshake for I/O Bank 0.  |             |                    |  |  |

| I/O Handshake Timeout Register |       | Timeout Register                                                                                                                                                                                                                                | (IHTR)               | (Address = 0x002A) |  |
|--------------------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|--------------------|--|
| Bit(s)                         | Value | Description                                                                                                                                                                                                                                     |                      |                    |  |
| 7                              | 0     | No I/O handshake timeout has occurred since the last read of this register.                                                                                                                                                                     |                      |                    |  |
|                                | 1     | An I/O handshake timeout has occurred since the last read of this register. This bit is cleared by a read of this register.                                                                                                                     |                      |                    |  |
| 6                              |       | This bit is reserved and sh                                                                                                                                                                                                                     | ould be written with | zero.              |  |
| 5:0                            |       | Time constant for the I/O handshake timeout counter. This time constant (times 32) selects the number of clocks that the I/O handshake input may delay completion of an I/O transaction before the I/O transaction will complete automatically. |                      |                    |  |

# 13. PARALLEL PORT H

#### 13.1 Overview

Parallel Port H is a byte-wide port with each bit programmable for data direction and drive level. These are simple inputs and outputs controlled and reported in the Port H Data Register (PHDR).

All of the Parallel Port H pins have alternate output functions.

When used as outputs, the Parallel Port H bits are buffered, with the data written to PHDR transferred to the output pins. Each bit can either be programmed as open-drain or driven high and low.

Parallel Port H acts as the upper byte of the data bus when the 16-bit mode is enabled; all other Parallel Port H functionality will be disabled automatically when the 16-bit mode is in effect.

Parallel Port H has no alternate input functionality.

Table 13-1. Parallel Port H Pin Alternate Output Functions

| Pin Name | Alt Out 0 | Alt Out 1 | Alt Out 2 | Alt Out 3 | 16-bit<br>Data Bus |
|----------|-----------|-----------|-----------|-----------|--------------------|
| PH7      | _         | I7        | PWM3      | SCLKC     | D15                |
| PH6      | _         | I6        | PWM2      | TXE       | D14                |
| PH5      | _         | I5        | PWM1      | RCLKE     | D13                |
| PH4      | _         | I4        | PWM0      | TCLKE     | D12                |
| PH3      | _         | I3        | TIMER C3  | SCLKD     | D11                |
| PH2      | _         | I2        | TIMER C2  | TXF       | D10                |
| PH1      | _         | I1        | TIMER C1  | RCLKF     | D9                 |
| PH0      |           | 10        | TIMER C0  | TCLKF     | D8                 |

### 13.1.1 Block Diagram



## 13.1.2 Registers

| Register Name                  | Mnemonic | I/O Address | R/W | Reset    |
|--------------------------------|----------|-------------|-----|----------|
| Port H Data Register           | PHDR     | 0x0034      | R/W | 00000000 |
| Port H Alternate Low Register  | PHALR    | 0x0032      | R/W | 00000000 |
| Port H Alternate High Register | PHAHR    | 0x0033      | R/W | 00000000 |
| Port H Function Register       | PHFR     | 0x0035      | R/W | 00000000 |
| Port H Drive Control Register  | PHDCR    | 0x0036      | R/W | 00000000 |
| Port H Data Direction Register | PHDDR    | 0x0037      | R/W | 00000000 |

### 13.2 Dependencies

#### 13.2.1 I/O Pins

Parallel Port H uses pins PH0 through PH7. These pins can be used individually as data inputs or outputs; as the serial port transmit for Serial Ports E and F; as the clock transmit (internal clock mode) for Serial Ports C–F; as external I/O strobes; or as outputs for the PWM and Timer C peripherals. In addition, Parallel Port H acts as the upper byte of the data bus (D[15:8]) when 16-bit addressing is enabled.

All pins are set as inputs on startup.

The individual bits can be set to be open-drain via PHDCR.

See the associated peripheral chapters for details on how they use Parallel Port H.

### 13.2.2 Clocks

All outputs on Parallel Port H are clocked by the peripheral clock.

### 13.2.3 Other Registers

| Register | Function                |  |
|----------|-------------------------|--|
| MACR     | Enable 16-bit data bus. |  |

## 13.2.4 Interrupts

There are no interrupts associated with Parallel Port H.

# 13.3 Operation

The following steps must be taken before using Parallel Port H.

- 1. Select the desired input/output direction for each pin via PHDDR.
- 2. Select high/low or open-drain functionality for outputs via PHDCR.
- 3. If an alternative peripheral output function is desired for a pin, select it via PHALR or PHAHR and then enable it via PHFR. Refer to the appropriate peripheral chapter for further use of that pin.
- 4. All these settings will be superseded if a 16-bit memory interface is selected since Parallel Port H is used for the upper half of the data bus in that mode.

Once Parallel Port H is set up, data can be read or written by accessing PHDR. The value of an output pin read in from PHDR will reflect its current output value, but any value written to an input pin will not appear on that pin until that pin becomes an output.

# 13.4 Register Descriptions

| Pa     | Parallel Port H Data Register |                                                                                                                                                            | (PHDR) | (Address = 0x0034) |
|--------|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------|
| Bit(s) | Value                         | Description                                                                                                                                                |        |                    |
| 7:0    | Read                          | The current state of Parallel Port H pins PH7–PH0 is reported.                                                                                             |        |                    |
|        | Write                         | The Parallel Port H buffer is written with this value for transfer to the Parallel Port H output register on the next rising edge of the peripheral clock. |        |                    |

| Paralle | I Port H A                                        | Iternate Low Register (PHALR) (Address = 0x0032)     |  |  |
|---------|---------------------------------------------------|------------------------------------------------------|--|--|
| Bit(s)  | Value                                             | Description                                          |  |  |
| 7:6     | 00                                                | This value is reserved and must not be used.         |  |  |
|         | 01                                                | Parallel Port H bit 3 alternate output 1 (I3).       |  |  |
|         | 10                                                | Parallel Port H bit 3 alternate output 2 (TIMER C3). |  |  |
|         | 11                                                | Parallel Port H bit 3 alternate output 3 (SCLKD).    |  |  |
| 5:4     | 00                                                | This value is reserved and must not be used.         |  |  |
|         | 01                                                | Parallel Port H bit 2 alternate output 1 (I2).       |  |  |
|         | 10                                                | Parallel Port H bit 2 alternate output 2 (TIMER C2). |  |  |
|         | 11                                                | Parallel Port H bit 2 alternate output 3 (TXF).      |  |  |
| 3:2     | 00                                                | This value is reserved and must not be used.         |  |  |
|         | 01                                                | Parallel Port H bit 1 alternate output 1 (I1).       |  |  |
|         | 10                                                | Parallel Port H bit 1 alternate output 2 (TIMER C1). |  |  |
|         | 11                                                | Parallel Port H bit 1 alternate output 3 (RCLKF).    |  |  |
| 1:0     | 00                                                | This value is reserved and must not be used.         |  |  |
|         | 01                                                | Parallel Port H bit 0 alternate output 1 (I0).       |  |  |
|         | 10                                                | Parallel Port H bit 0 alternate output 2 (TIMER C0). |  |  |
|         | Parallel Port H bit 0 alternate output 3 (TCLKF). |                                                      |  |  |

| Paralle | l Port H Al | ternate High Register (PHAHR)                     | (Address = 0x0033) |  |  |
|---------|-------------|---------------------------------------------------|--------------------|--|--|
| Bit(s)  | Value       | Description                                       |                    |  |  |
| 7:6     | 00          | This value is reserved and must not be used.      |                    |  |  |
|         | 01          | Parallel Port H bit 7 alternate output 1 (I7).    |                    |  |  |
|         | 10          | Parallel Port H bit 7 alternate output 2 (PWM3).  |                    |  |  |
|         | 11          | Parallel Port H bit 7 alternate output 3 (SCLKC). |                    |  |  |
| 5:4     | 00          | This value is reserved and must not be used.      |                    |  |  |
|         | 01          | Parallel Port H bit 6 alternate output 1 (I6).    |                    |  |  |
|         | 10          | Parallel Port H bit 6 alternate output 2 (PWM2).  |                    |  |  |
|         | 11          | Parallel Port H bit 6 alternate output 3 (TXE).   |                    |  |  |
| 3:2     | 00          | This value is reserved and must not be used.      |                    |  |  |
|         | 01          | Parallel Port H bit 5 alternate output 1 (I5).    |                    |  |  |
|         | 10          | Parallel Port H bit 5 alternate output 2 (PWM1).  |                    |  |  |
|         | 11          | Parallel Port H bit 5 alternate output 3 (RCLKE). |                    |  |  |
| 1:0     | 00          | This value is reserved and must not be used.      |                    |  |  |
|         | 01          | Parallel Port H bit 4 alternate output 1 (I4).    |                    |  |  |
|         | 10          | Parallel Port H bit 4 alternate output 2 (PWM0).  |                    |  |  |
|         | 11          | Parallel Port H bit 4 alternate output 3 (TCLKE). |                    |  |  |

| Para   | Parallel Port H Function Register |                                                | (PHFR)                      | (Address = 0x0035)                 |
|--------|-----------------------------------|------------------------------------------------|-----------------------------|------------------------------------|
| Bit(s) | Value                             | Description                                    |                             |                                    |
| 7:0    | 0                                 | The corresponding port bit functions normally. |                             |                                    |
|        | 1                                 | The corresponding port b                       | it carries its alternate si | gnal as an output. See Table 13-1. |

| Paralle | Parallel Port H Drive Control Register |                                                                   | (PHDCR)                 | (Address = 0x0036) |
|---------|----------------------------------------|-------------------------------------------------------------------|-------------------------|--------------------|
| Bit(s)  | Value                                  | Description                                                       |                         |                    |
| 7:0     | 0                                      | The corresponding port bit, as an output, is driven high and low. |                         | en high and low.   |
|         | 1                                      | The corresponding port bi                                         | t, as an output, is ope | n-drain.           |

| Paralle | l Port H Da | ta Direction Register (PHDDR) (Address = 0x0037) |
|---------|-------------|--------------------------------------------------|
| Bit(s)  | Value       | Description                                      |
| 7:0     | 0           | The corresponding port bit is an input.          |
|         | 1           | The corresponding port bit is an output.         |

| Memo   | ory Alterna | te Control Register (MACR) (Address = 0x001D)                                                                                                     |  |  |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit(s) | Value       | Description                                                                                                                                       |  |  |
| 7      | 0           | Normal 8-bit operation for /CS3. Use MBxCR for wait states. This bit is used only when external memory is present.                                |  |  |
|        | 1           | Normal 16-bit operation for /CS3. Use MBxCR for wait states. When standalone operation is selected (by strapping a pin), this bit is forced high. |  |  |
| 6      |             | This bit is reserved and must not be used.                                                                                                        |  |  |
| 5:4    | 00          | Normal 8-bit operation for /CS2.                                                                                                                  |  |  |
|        | 01          | Page-Mode 8-bit operation for /CS2.                                                                                                               |  |  |
|        | 10          | Normal 16-bit operation for /CS2.                                                                                                                 |  |  |
|        | 11          | Page-Mode 16-bit operation for /CS2.                                                                                                              |  |  |
| 3:2    | 00          | Normal 8-bit operation for /CS1.                                                                                                                  |  |  |
|        | 01          | Page-Mode 8-bit operation for /CS1.                                                                                                               |  |  |
|        | 10          | Normal 16-bit operation for /CS1.                                                                                                                 |  |  |
|        | 11          | Page-Mode 16-bit operation for /CS1.                                                                                                              |  |  |
| 1:0    | 00          | Normal 8-bit operation for /CS0.                                                                                                                  |  |  |
|        | 01          | Page-Mode 8-bit operation for /CS0.                                                                                                               |  |  |
|        | 10          | Normal 16-bit operation for /CS0.                                                                                                                 |  |  |
|        | 11          | Page-Mode 16-bit operation for /CS0.                                                                                                              |  |  |

# 14. TIMER A

### 14.1 Overview

The Timer A peripheral consists of ten separate eight-bit countdown timers, A1–A10. Each counter counts down from a programmed time constant, which is automatically reloaded into the respective counter when the count reaches zero. For example, if the reload register contains 127, then 128 pulses enter on the left before a pulse exits on the right (see Figure 14-1). If the reload register contains zero, then each pulse on the left results in a pulse on the right, that is, there is division by one. The reload register can contain any number in the range from 0 to 255. The counter divides by (n + 1).



Figure 14-1. Reload Register Operation

The output pulses are always one clock wide. Clocking of the timers takes place on the negative edge of these pulses. When the counter reaches zero, the reload register is loaded into the counter on the next input pulse instead of a count being performed. The terminal count condition for Timers A1–A7 is reported in a status register and can be programmed to generate an interrupt. Six of these seven timers (A2–A7) have the option of being cascaded from Timer A1, but the primary clock for all of the timers is the peripheral clock either directly or divided by 2 (the default).

Timers A2–A7 can be used to generate baud rates for Serial Ports A–F, or they can be used as general-purpose timers if the dedicated timers on the Rabbit 5000 serial ports are used. The three remaining timers (A8–A10) serve as prescalers for the input capture, PWM, and quadrature decoder peripherals respectively. The peripherals clocked by these timers can

Chapter 14 Timer A 149

generate interrupts but the timers themselves cannot. Furthermore, these timers cannot be cascaded with Timer A1.

The individual Timer A capabilities are summarized in the table below. There is a bit in the control/status register to disable all ten timers globally.

| Timer | Cascade from A1 | Interrupt | Associated Peripheral          |
|-------|-----------------|-----------|--------------------------------|
| A1    | No              | Yes       | Parallel Ports D–E, Timers B–C |
| A2    | Yes             | Yes       | Serial Port E                  |
| A3    | Yes             | Yes       | Serial Port F                  |
| A4    | Yes             | Yes       | Serial Port A                  |
| A5    | Yes             | Yes       | Serial Port B                  |
| A6    | Yes             | Yes       | Serial Port C                  |
| A7    | Yes             | Yes       | Serial Port D                  |
| A8    | No              | No        | Input Capture                  |
| A9    | No              | No        | Pulse-Width Modulator          |
| A10   | No              | No        | Quadrature Decoder             |

There is one interrupt vector for Timer A and a common interrupt priority. A common status register (TACSR) has bits for Timers A1–A7 that indicate if the output pulse for that timer has taken place since the last read of the status register. These bits are cleared when the status register is read. No bit will be lost. Either it will be read by the status register read or it will be set after the status register read is complete. If a bit is on and the corresponding interrupt is enabled, an interrupt will occur when priorities allow. However, a separate interrupt is not guaranteed for each bit with an enabled interrupt. If the bit is read in the status register, it is cleared and no further interrupt corresponding to that bit will be requested. It is possible that one bit will cause an interrupt, and then one or more additional bits will be set before the status register is read. After these bits are cleared, they cannot cause an interrupt. The proper rule to follow is for the interrupt routine to handle all bits that it sees set.

## 14.1.1 Block Diagram





Chapter 14 Timer A 151

### 14.1.2 Registers

| Register Name                     | Mnemonic | I/O Address | R/W | Reset    |
|-----------------------------------|----------|-------------|-----|----------|
| Timer A Control/Status Register   | TACSR    | 0x00A0      | R/W | 00000000 |
| Timer A Prescale Register         | TAPR     | 0x00A1      | R/W | xxxxxxx1 |
| Timer A Time Constant 1 Register  | TAT1R    | 0x00A3      | R/W | xxxxxxxx |
| Timer A Control Register          | TACR     | 0x00A4      | R/W | 00000000 |
| Timer A Time Constant 2 Register  | TAT2R    | 0x00A5      | R/W | xxxxxxx  |
| Timer A Time Constant 8 Register  | TAT8R    | 0x00A6      | R/W | xxxxxxxx |
| Timer A Time Constant 3 Register  | TAT3R    | 0x00A7      | R/W | xxxxxxx  |
| Timer A Time Constant 9 Register  | TAT9R    | 0x00A8      | R/W | xxxxxxx  |
| Timer A Time Constant 4 Register  | TAT4R    | 0x00A9      | R/W | xxxxxxxx |
| Timer A Time Constant 10 Register | TAT10R   | 0x00AA      | R/W | xxxxxxx  |
| Timer A Time Constant 5 Register  | TAT5R    | 0x00AB      | R/W | xxxxxxx  |
| Timer A Time Constant 6 Register  | TAT6R    | 0x00AD      | R/W | xxxxxxxx |
| Timer A Time Constant 7 Register  | TAT7R    | 0x00AF      | R/W | xxxxxxx  |

## 14.2 Dependencies

### 14.2.1 I/O Pins

The Timer A outputs do not come out directly on any of the I/O pins. They can be used to control when the output occurs on Parallel Ports D–E, and can affect the output times of Serial Ports A–F and the PWM.

### 14.2.2 Clocks

The timers in Timer A can be clocked by either perclk or perclk/2, as selected in TAPR. In addition, Timers A2–A7 can be clocked by the output of Timer A1 by selecting that option in TACSR.

## 14.2.3 Other Registers

| Register | Function                      |
|----------|-------------------------------|
| GCSR     | Select peripheral clock mode. |

### 14.2.4 Interrupts

A Timer A interrupt can be generated whenever Timers A1–A7 decrement to zero by enabling the appropriate bit in TACSR. The interrupt request is cleared when TACSR is read.

The Timer A interrupt vector is in the IIR at offset 0x0A0. It can be set as priority 1, 2, or 3 in TACR

## 14.3 Operation

The following steps explain how to set up a Timer A timer.

- 1. Use the default perclk/2 in TAPR as the Timer A input clock. You may instead select perclk in TAPR.
- 2. Select the source clocks for Timers A2–A7 in TACR.
- 3. Write the desired divider value to TATxR for all timers that will be used.
- 4. Enable Timer A by writing a 1 to bit 0 of TACSR.

### 14.3.1 Handling Interrupts

The following steps explain how an interrupt is set up and used.

- 1. Write the vector to the interrupt service routine to the internal interrupt table.
- 2. Configure TACSR to select which timers will generate an interrupt.
- 3. Configure TACR to select the interrupt priority (note that interrupts will be enabled once this value is set). This should be done last.

The interrupt request is cleared by reading from TACSR.

## 14.3.2 Example ISR

A sample interrupt handler is shown below.

Chapter 14 Timer A 153

# 14.4 Register Descriptions

| Tim              | er A Contr | ol/Status Register                               | (TACSR)                                                                                                                                                                                    | (Address = 0x00A0)       |
|------------------|------------|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|
| Bit(s)           | Value      | Description                                      |                                                                                                                                                                                            |                          |
| 7:1              | 0          | The corresponding Timer                          | A counter has not rea                                                                                                                                                                      | ched its terminal count. |
| (Read-<br>only)  | 1          | 1 0                                              | The corresponding Timer A counter has reached its terminal count. These status bits (not the interrupt enable bits) are cleared by the read of this register, as is the Timer A interrupt. |                          |
| 7:1              | 0          | The corresponding Timer A interrupt is disabled. |                                                                                                                                                                                            |                          |
| (Write-<br>only) | 1          | The corresponding Timer A interrupt is enabled.  |                                                                                                                                                                                            |                          |
| 0                | 0          | The clock input for Timer A is disabled.         |                                                                                                                                                                                            |                          |
|                  | 1          | The clock input for Timer                        | A is enabled.                                                                                                                                                                              |                          |

| Т      | imer A Pre | escale Register                                                               | (TAPR) | (Address = 0x00A1) |  |
|--------|------------|-------------------------------------------------------------------------------|--------|--------------------|--|
| Bit(s) | Value      | Description                                                                   |        |                    |  |
| 7:1    |            | These bits are reserved and should be written with zero.                      |        |                    |  |
| 0      | 0          | The main clock for Timer A is the peripheral clock (perclk).                  |        |                    |  |
|        | 1          | The main clock for Timer A is the peripheral clock divided by two (perclk/2). |        |                    |  |

|        | Timer A Co | ontrol Register               | (TACR)                                      | (Address = 0x00A4) |  |  |
|--------|------------|-------------------------------|---------------------------------------------|--------------------|--|--|
| Bit(s) | Value      |                               | Description                                 |                    |  |  |
| 7      | 0          | Timer A7 clocked by the ma    | in Timer A clock.                           |                    |  |  |
|        | 1          | Timer A7 clocked by the out   | put of Timer A1.                            |                    |  |  |
| 6      | 0          | Timer A6 clocked by the ma    | in Timer A clock.                           |                    |  |  |
|        | 1          | Timer A6 clocked by the out   | put of Timer A1.                            |                    |  |  |
| 5      | 0          | Timer A5 clocked by the ma    | in Timer A clock.                           |                    |  |  |
|        | 1          | Timer A5 clocked by the out   | put of Timer A1.                            |                    |  |  |
| 4      | 0          | Timer A4 clocked by the ma    | in Timer A clock.                           |                    |  |  |
|        | 1          | Timer A4 clocked by the out   | put of Timer A1.                            |                    |  |  |
| 3      | 0          | Timer A3 clocked by the ma    | in Timer A clock.                           |                    |  |  |
|        | 1          | Timer A3 clocked by the out   | Timer A3 clocked by the output of Timer A1. |                    |  |  |
| 2      | 0          | Timer A2 clocked by the ma    | Timer A2 clocked by the main Timer A clock. |                    |  |  |
|        | 1          | Timer A2 clocked by the out   | Timer A2 clocked by the output of Timer A1. |                    |  |  |
| 1:0    | 00         | Timer A interrupts are disab  | Timer A interrupts are disabled.            |                    |  |  |
|        | 01         | Timer A interrupt use Interru | Timer A interrupt use Interrupt Priority 1. |                    |  |  |
|        | 10         | Timer A interrupt use Interru | upt Priority 2.                             |                    |  |  |
|        | 11         | Timer A interrupt use Interru | upt Priority 3.                             |                    |  |  |

| Time   | r A Time C | Constant x Register                                                                                                                                                                                                 | (TAT1R) (TAT2R) (TAT3R) (TAT4R) (TAT5R) (TAT6R) (TAT7R) (TAT7R) (TAT7R) (TAT9R) (TAT10R) | (Address = 0x00A3)<br>(Address = 0x00A5<br>(Address = 0x00A7))<br>(Address = 0x00A9)<br>(Address = 0x00AB)<br>(Address = 0x00AD)<br>(Address = 0x00AF)<br>(Address = 0x00A6)<br>(Address = 0x00A8)<br>(Address = 0x00AA) |  |
|--------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit(s) | Value      | Description                                                                                                                                                                                                         |                                                                                          |                                                                                                                                                                                                                          |  |
| 7:0    |            | Time constant for the Timer A counter. This time constant will take effect the next time that the Timer A counter counts down to zero. The timer counts modulo $n + 1$ , where $n$ is the programmed time constant. |                                                                                          |                                                                                                                                                                                                                          |  |

Chapter 14 Timer A 155

| Glo    | bal Contro | ol/Status Register (GCSR) (Address = 0x0000)                                                                                                                           |  |  |  |
|--------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit(s) | Value      | Description                                                                                                                                                            |  |  |  |
| 4:2    | 000        | Processor clock from the main clock, divided by eight.  Peripheral clock from the main clock, divided by eight.                                                        |  |  |  |
|        | 001        | Processor clock from the main clock, divided by eight. Peripheral clock from the main clock.                                                                           |  |  |  |
|        | 010        | Processor clock from the main clock. Peripheral clock from the main clock.                                                                                             |  |  |  |
|        | 011        | Processor clock from the main clock, divided by two.  Peripheral clock from the main clock, divided by two.                                                            |  |  |  |
|        | 100        | Processor clock from the 32 kHz clock, optionally divided via GPSCR.  Peripheral clock from the 32 kHz clock, optionally divided via GPSCR.                            |  |  |  |
|        | 101        | Processor clock from the 32 kHz clock, optionally divided via GPSCR. Peripheral clock from the 32 kHz clock, optionally divided via GPSCR. The fast clock is disabled. |  |  |  |
|        | 110        | Processor clock from the main clock, divided by four. Peripheral clock from the main clock, divided by four.                                                           |  |  |  |
|        | 111        | Processor clock from the main clock, divided by six.  Peripheral clock from the main clock, divided by six.                                                            |  |  |  |

# 15. TIMER B

### 15.1 Overview

The Timer B peripheral consists of a ten-bit free running up-counter, two match registers, and two step registers. Timer B is driven by perclk/2, by perclk/16, or by the output of Timer A1. Timer B generates an output pulse whenever the counter reaches the match value. This output pulse can generate an interrupt and will set a status bit in the status register. The processor may then write a new value to the match register. This allows Timer B to be used for pulse-width or pulse-position modulation because the outputs of Timer B can clock the outputs on Parallel Ports D and E.

The compare value comes from either the match register or the value internally generated via the step register. When using the match register, a new match value must be written to the match register after each match condition, LSB first. When using the step register, the hardware automatically calculates the next match value by adding the contents of the step register to the current match value. This allows Timer B matches to be generated at regular periods without calculating the new match value during the interrupt service routine.

#### 15.1.1 Block Diagram



Chapter 15 Timer B 157

### 15.1.2 Registers

| Register Name                   | Mnemonic | I/O Address | R/W | Reset    |
|---------------------------------|----------|-------------|-----|----------|
| Timer B Control/Status Register | TBCSR    | 0x00B0      | R/W | xxxx0000 |
| Timer B Control Register        | TBCR     | 0x00B1      | R/W | xx000000 |
| Timer B MSB 1 Register          | TBM1R    | 0x00B2      | R/W | xxxxxxx  |
| Timer B LSB 1 Register          | TBL1R    | 0x00B3      | R/W | xxxxxxx  |
| Timer B MSB 2 Register          | TBM2R    | 0x00B4      | R/W | xxxxxxx  |
| Timer B LSB 2 Register          | TBL2R    | 0x00B5      | R/W | xxxxxxx  |
| Timer B Step LSB 1 Register     | TBSL1R   | 0x00BA      | R/W | xxxxxxx  |
| Timer B Step MSB 1 Register     | TBSM1R   | 0x00BB      | R/W | xxxxxxx  |
| Timer B Step LSB 2 Register     | TBSL2R   | 0x00BC      | R/W | xxxxxxx  |
| Timer B Step MSB 2 Register     | TBSM2R   | 0x00BD      | R/W | xxxxxxx  |
| Timer B Count MSB Register      | TBCMR    | 0x00BE      | R   | xxxxxxx  |
| Timer B Count LSB Register      | TBCLR    | 0x00BF      | R   | xxxxxxx  |

## 15.2 Dependencies

### 15.2.1 I/O Pins

The output of Timer B does not come out directly on any of the I/O pins. It can be used to control when the output occurs on Parallel Ports D–E.

#### 15.2.2 Clocks

The timer in Timer B can be clocked by perclk/2, perclk/16, or by countdown Timer A1 as selected in TBCR.

## 15.2.3 Other Registers

| Register | Function                      |
|----------|-------------------------------|
| GCSR     | Select peripheral clock mode. |

### 15.2.4 Interrupts

A Timer B interrupt can be generated whenever the counter equals one of the match registers by enabling the appropriate bit in TBCSR. The interrupt request is cleared when TBCSR is read.

## 15.3 Operation

The following steps explain how to set up a Timer B countdown timer.

- 1. Select perclk/2, perclk/16, or countdown Timer A1 in TBCR.
- 2. Use TBCR to select whether countdown Timers B1–B2 operate normally with the match registers or whether they use the step registers to calculate match values.
- 3. Enable Timer B by writing a 1 to bit 0 of TBCSR.

### 15.3.1 Handling Interrupts

The following steps explain how an interrupt is set up and used.

- 1. Write the vector to the interrupt service routine to the internal interrupt table.
- 2. Configure TBCSR to select which match register will generate an interrupt.
- 3. Configure TBCR to select the interrupt priority (note that interrupts will be enabled once this value is set; this step should be done last).

The interrupt request is cleared by reading from TBCSR.

### 15.3.2 Example ISR

A sample interrupt handler is shown below.

# 15.4 Register Descriptions

| Time             | er B Contr | ol/Status Register                                                                                                                                                                                   | (TBCSR)              | (Address = 0x00B0)             |
|------------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|--------------------------------|
| Bit(s)           | Value      |                                                                                                                                                                                                      | Description          |                                |
| 7:3              |            | These bits always read as                                                                                                                                                                            | zero.                |                                |
| 2:1              | 0          | The corresponding Timer                                                                                                                                                                              | B comparator has not | encountered a match condition. |
| (Read-<br>only)  | 1          | The corresponding Timer B comparator has encountered a match condition. These status bits (but not the interrupt enable bits) are cleared by the read of this register, as is the Timer B interrupt. |                      |                                |
| 2:1              | 0          | The corresponding Timer B interrupt is disabled.                                                                                                                                                     |                      |                                |
| (Write-<br>only) | 1          | The corresponding Timer B interrupt is enabled.                                                                                                                                                      |                      |                                |
| 0                | 0          | The clock input for Timer B is disabled.                                                                                                                                                             |                      |                                |
|                  | 1          | The clock input for Timer                                                                                                                                                                            | B is enabled.        |                                |

|        | Timer B Co | ontrol Register                                        | (TBCR)                  | (Address = 0x00B1)   |  |  |
|--------|------------|--------------------------------------------------------|-------------------------|----------------------|--|--|
| Bit(s) | Value      |                                                        | Description             |                      |  |  |
| 7:6    |            | These bits are reserved an                             | d should be written w   | rith zero.           |  |  |
| 5      | 0          | Normal Timer B2 operation                              | on using the match re   | gisters.             |  |  |
|        | 1          | Enable Timer B2 to use th                              | e step registers to cal | culate match values. |  |  |
| 4      | 0          | Normal Timer B1 operation                              | on, using the match re  | egisters.            |  |  |
|        | 1          | Enable Timer B1 to use th                              | e step registers to cal | culate match values. |  |  |
| 3:2    | 00         | Timer B clocked by perclk/2.                           |                         |                      |  |  |
|        | 01         | Timer B clocked by the output of Timer A1.             |                         |                      |  |  |
|        | 10         | Timer B clocked by the peripheral clock divided by 16. |                         |                      |  |  |
|        | 11         | Timer B clocked by the peripheral clock divided by 16. |                         |                      |  |  |
| 1:0    | 00         | Timer B interrupts are disabled.                       |                         |                      |  |  |
|        | 01         | Timer B interrupt use Interrupt Priority 1.            |                         |                      |  |  |
|        | 10         | Timer B interrupt use Interrupt Priority 2.            |                         |                      |  |  |
|        | 11         | Timer B interrupt use Inte                             | rrupt Priority 3.       |                      |  |  |

| Timer B Count MSB x Register |       | (TBM1R)<br>(TBM2R)                                                                                                                                              | (Address = 0x00B2)<br>(Address = 0x00B4) |     |
|------------------------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|-----|
| Bit(s)                       | Value | Description                                                                                                                                                     |                                          |     |
| 7:6                          |       | Two MSBs of the compare value for the Timer B comparator. This compare value will be loaded into the actual comparator when the current compare detect a match. |                                          | 1 1 |
| 5:0                          |       | These bits are reserved and should be written with zero.                                                                                                        |                                          |     |

| Tin    | Timer B Count LSB x Register |                                                                                                                                                                   | (TBL1R)<br>(TBL2R) | (Address = 0x00B3)<br>(Address = 0x00B5) |
|--------|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|------------------------------------------|
| Bit(s) | Value                        | Description                                                                                                                                                       |                    |                                          |
| 7:0    |                              | Eight LSBs of the compare value for the Timer B comparator. This compare value will be loaded into the actual comparator when the current compare detect a match. |                    | *                                        |

| Tir    | mer B Step | LSB x Register                                                                                                                                                   | (TBSL1R)<br>(TBSL2R) | (Address = 0x00BA)<br>(Address = 0x00BC) |
|--------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|------------------------------------------|
| Bit(s) | Value      | Description                                                                                                                                                      |                      |                                          |
| 7:0    |            | Eight LSBs of the step size for the Timer B comparator. The new compare valu will be loaded into the actual comparator when the current compare detects a match. |                      |                                          |

| Tiı    | mer B Step | MSB x Register                                                                                                                                                  | (TBSM1R)<br>(TBSM2R) | (Address = 0x00BB)<br>(Address = 0x00BD) |
|--------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|------------------------------------------|
| Bit(s) | Value      | Description                                                                                                                                                     |                      |                                          |
| 7:2    |            | These bits are ignored but should be written with zeros.                                                                                                        |                      |                                          |
| 1:0    |            | Two MSBs of the step size for the Timer B comparator. The new compare value will be loaded into the actual comparator when the current compare detects a match. |                      |                                          |

| Timer B Count MSB Register |       | (TBCMR)                                                               | (Address = 0x00BE) |  |
|----------------------------|-------|-----------------------------------------------------------------------|--------------------|--|
| Bit(s)                     | Value | Description                                                           |                    |  |
| 7:6                        | Read  | The current value of the two MSBs of the Timer B counter is reported. |                    |  |
| 5:0                        |       | These bits are always read as zeros.                                  |                    |  |

Chapter 15 Timer B 161

| Ti     | mer B Cou | nt LSB Register                                                         | (TBCLR)     | (Address = 0x00BF) |
|--------|-----------|-------------------------------------------------------------------------|-------------|--------------------|
| Bit(s) | Value     |                                                                         | Description |                    |
| 7:0    | Read      | The current value of the eight LSBs of the Timer B counter is reported. |             |                    |

| Glo    | bal Contr | ol/Status Register (GCSR) (Address = 0x0000)                                                                                                                             |  |  |  |  |
|--------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Bit(s) | Value     | Description                                                                                                                                                              |  |  |  |  |
| 4:2    | 000       | Processor clock from the main clock, divided by eight.  Peripheral clock from the main clock, divided by eight.                                                          |  |  |  |  |
|        | 001       | Processor clock from the main clock, divided by eight.  Peripheral clock from the main clock.                                                                            |  |  |  |  |
|        | 010       | Processor clock from the main clock. Peripheral clock from the main clock.                                                                                               |  |  |  |  |
|        | 011       | Processor clock from the main clock, divided by two.  Peripheral clock from the main clock, divided by two.                                                              |  |  |  |  |
|        | 100       | Processor clock from the 32 kHz clock, optionally divided via GPSCR.  Peripheral clock from the 32 kHz clock, optionally divided via GPSCR.                              |  |  |  |  |
|        | 101       | Processor clock from the 32 kHz clock, optionally divided via GPSCR.  Peripheral clock from the 32 kHz clock, optionally divided via GPSCR.  The fast clock is disabled. |  |  |  |  |
|        | 110       | Processor clock from the main clock, divided by four.  Peripheral clock from the main clock, divided by four.                                                            |  |  |  |  |
|        | 111       | Processor clock from the main clock, divided by six.  Peripheral clock from the main clock, divided by six.                                                              |  |  |  |  |

# 16. TIMER C

#### 16.1 Overview

The Timer C peripheral is a 16-bit up-counter clocked by the peripheral clock divided by 2, by the peripheral clock divided by 16, or by the output of countdown Timer A1. The counter counts from zero to the limit programmed into the Timer C divider registers and then restarts at zero, so the overall cycle count is the value in the divider registers plus one. There are four Timer C outputs that are called Timers C0–C3. Each output is controlled by a 16-bit set value and a 16-bit reset value. Each output is set to one when the count matches the value in the corresponding set register and is cleared when the count matches the value programmed in the corresponding reset register. This allows the creation of quadrature signals or three-phase signals with a variable frequency for motor-control applications. The values in all of the Timer C registers are transferred to holding registers for use during the count cycle when the counter is reloaded with zeros, allowing the control registers to be reloaded at any time during the count cycle.

Timer C can generate an interrupt when the count limit value is reached.

A separate Timer C Block Access Register (TCBAR) and Timer C Block Pointer Register (TCBPR) are available to allow DMA control of Timer C. The pointer register contains the address of the Timer C register to be accessed via the access register. Each read or write of the access register automatically increments the pointer register through the sequence shown below. Note that only the lower five bits of the pointer actually change. This allows the DMA to write to a fixed internal I/O location but still program all of the relevant Timer registers. The pointer register can be written and read if necessary. Normally the pointer register is initialized to 0x02 (the Timer C Divider Low Register), and the DMA then transfers blocks of 18 bytes to completely reprogram Timer C.

```
0x502 -> 0x503 -> 0x508 -> 0x509 -> 0x50A -> 0x50B -> 0x50C -> 0x50D -> 0x50E -> 0x50F -> 0x518 -> 0x519 -> 0x51A -> 0x51B -> 0x51C -> 0x51D -> 0x51E -> 0x51F ->
```

When the DMA destination address is the TCBAR, the DMA request from Timer C is connected automatically to the DMA.

Chapter 16 Timer C 163

## 16.1.1 Block Diagram



## 16.1.2 Registers

| Register Name                   | Mnemonic | I/O Address | R/W | Reset    |
|---------------------------------|----------|-------------|-----|----------|
| Timer C Control/Status Register | TCCSR    | 0x0500      | R/W | xxxx0000 |
| Timer C Control Register        | TCCR     | 0x0501      | R/W | xx000000 |
| Timer C Divider Low Register    | TCDLR    | 0x0502      | R/W | 00000000 |
| Timer C Divider High Register   | TCDHR    | 0x0503      | R/W | 00000000 |
| Timer C Set 0 Low Register      | TCS0LR   | 0x0508      | R/W | xxxxxxx  |
| Timer C Set 0 High Register     | TCS0HR   | 0x0509      | R/W | xxxxxxx  |
| Timer C Reset 0 Low Register    | TCR0LR   | 0x050A      | R/W | xxxxxxx  |
| Timer C Reset 0 High Register   | TCR0HR   | 0x050B      | R/W | xxxxxxx  |
| Timer C Set 1 Low Register      | TCS1LR   | 0x050C      | R/W | xxxxxxx  |
| Timer C Set 1 High Register     | TCS1HR   | 0x050D      | R/W | xxxxxxxx |
| Timer C Reset 1 Low Register    | TCR1LR   | 0x050E      | R/W | xxxxxxx  |
| Timer C Reset 1 High Register   | TCR1HR   | 0x050F      | R/W | xxxxxxxx |
| Timer C Set 2 Low Register      | TCS2LR   | 0x0518      | R/W | xxxxxxxx |
| Timer C Set 2 High Register     | TCS2HR   | 0x0519      | R/W | xxxxxxx  |
| Timer C Reset 2 Low Register    | TCR2LR   | 0x051A      | R/W | xxxxxxx  |
| Timer C Reset 2 High Register   | TCR2HR   | 0x051B      | R/W | xxxxxxxx |
| Timer C Set 3 Low Register      | TCS3LR   | 0x051C      | R/W | xxxxxxx  |
| Timer C Set 3 High Register     | TCS3HR   | 0x051D      | R/W | xxxxxxx  |
| Timer C Reset 3 Low Register    | TCR3LR   | 0x051E      | R/W | xxxxxxxx |
| Timer C Reset 3 High Register   | TCR3HR   | 0x051F      | R/W | xxxxxxx  |
| Timer C Block Access Register   | TCBAR    | 0x00F8      | W   | xxxxxxx  |
| Timer C Block Pointer Register  | TCBPR    | 0x00F9      | W   | 00000010 |

Chapter 16 Timer C 165

## 16.2 Dependencies

### 16.2.1 I/O Pins

The four Timer C outputs can be directed to PC0-PC3, PD0-PD3, PE0-PE3, pr PH0-PH3.

### 16.2.2 Clocks

The timer in Timer C is a 16-bit up-counter clocked by the peripheral clock divided by 2, by the peripheral clock divided by 16, or by the output of Timer A1 as selected in TCCR.

## 16.2.3 Other Registers

| Register                                                 | Function                        |
|----------------------------------------------------------|---------------------------------|
| GCSR                                                     | Select peripheral clock mode.   |
| PCFR, PCALR<br>PDFR, PDALR<br>PEFR, PEALR<br>PHFR, PHALR | Alternate port output selection |

## 16.2.4 Interrupts

A Timer C interrupt is enabled in TCCR, and will occur whenever the count limit value is reached. The interrupt request is cleared when TCCSR is read.

## 16.3 Operation

The following steps explain how to set up a Timer C timer.

- 1. Select perclk/2, perclk/16, or countdown Timer A1 in TCCR.
- Load the desired upper limit for the counter into TCDLR and TCDHR. The overall clock count per Timer C cycle will be the value loaded into the divider registers plus one.
- 3. Load the desired set and reset values for the Timer C outputs into the set and reset registers (TCSxLR, TCSxHR, TCRxLR, and TCRxHR).
- 4. If you intend to use DMA control of Timer C, use TCBAR to access the Timer C register pointed to by TCBPR.
- 5. Enable the desired output pins for Timer C by writing to the appropriate parallel port function and alternate output registers.
- 6. Enable Timer C by writing a 1 to bit 0 of TCCSR.

### 16.3.1 Handling Interrupts

The following steps explain how an interrupt is used.

- 1. Write the vector to the interrupt service routine to the internal interrupt table.
- 2. Configure TCCR to select the interrupt priority (note that interrupts will be enabled once this value is set).

The interrupt request is cleared by reading from TCCSR.

## 16.3.2 Example ISR

A sample interrupt handler is shown below.

# **16.4 Register Descriptions**

| Tim             | er C Contr | ol/Status Register                                                                                                                   | (TCCSR)         | (Address = 0x0500) |  |
|-----------------|------------|--------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------------|--|
| Bit(s)          | Value      | Description                                                                                                                          |                 |                    |  |
| 7:2             |            | These bits are always read as zero.                                                                                                  |                 |                    |  |
| 1               | 0          | Timer C divider has not reached its maximum value.                                                                                   |                 |                    |  |
| (Read-<br>only) | 1          | Timer C divider has reached its maximum value. This status bit is cleared by the read of this register, as is the Timer C interrupt. |                 |                    |  |
| 0               | 0          | The clock input for Timer C is disabled.                                                                                             |                 |                    |  |
|                 | 1          | The clock input for Time                                                                                                             | r C is enabled. |                    |  |

|        | Timer C Co | entrol Register (TCCR) (Address = 0x0501)                |  |  |  |
|--------|------------|----------------------------------------------------------|--|--|--|
| Bit(s) | Value      | Description                                              |  |  |  |
| 7:4    |            | These bits are reserved and should be written with zero. |  |  |  |
| 3:2    | 00         | Timer C clocked by the peripheral clock divided by 2.    |  |  |  |
|        | 01         | Timer C clocked by the output of Timer A1.               |  |  |  |
|        | 10         | Timer C clocked by the peripheral clock divided by 16.   |  |  |  |
|        | 11         | Timer C clocked by the peripheral clock divided by 16.   |  |  |  |
| 1:0    | 00         | Timer C interrupts are disabled.                         |  |  |  |
|        | 01         | Timer C interrupt uses Interrupt Priority 1.             |  |  |  |
|        | 10         | Timer C interrupt uses Interrupt Priority 2.             |  |  |  |
|        | 11         | Timer C interrupt uses Interrupt Priority 3.             |  |  |  |

| Tin    | ner C Divid | ler Low Register                                                  | (TCDLR)     | (Address = 0x0502) |
|--------|-------------|-------------------------------------------------------------------|-------------|--------------------|
| Bit(s) | Value       |                                                                   | Description |                    |
| 7:0    |             | The eight LSBs of the divider limit value for Timer C are stored. |             |                    |

| Tin    | ner C Divid | er High Register                                                  | (TCDHR)     | (Address = 0x0503) |
|--------|-------------|-------------------------------------------------------------------|-------------|--------------------|
| Bit(s) | Value       |                                                                   | Description |                    |
| 7:0    |             | The eight MSBs of the divider limit value for Timer C are stored. |             |                    |

| Timer C Set x Low Register |       | (TCS0LR)<br>(TCS1LR)<br>(TCS2LR)<br>(TCS3LR)           | (Address = 0x0508)<br>(Address = 0x050C)<br>(Address = 0x0518)<br>(Address = 0x051C) |  |  |
|----------------------------|-------|--------------------------------------------------------|--------------------------------------------------------------------------------------|--|--|
| Bit(s)                     | Value | Description                                            |                                                                                      |  |  |
| 7:0                        |       | Eight LSBs of the match value to set Timer C Output x. |                                                                                      |  |  |

| Timer C Set x High Register |       | (TCS0HR)<br>(TCS1HR)<br>(TCS2HR)<br>(TCS3HR)           | (Address = 0x0509)<br>(Address = 0x050D)<br>(Address = 0x0519)<br>(Address = 0x051D) |  |
|-----------------------------|-------|--------------------------------------------------------|--------------------------------------------------------------------------------------|--|
| Bit(s)                      | Value | Description                                            |                                                                                      |  |
| 7:0                         |       | Eight MSBs of the match value to set Timer C Output x. |                                                                                      |  |

| Timer C Reset x Low Register |       | (TCR0LR)<br>(TCR1LR)<br>(TCR2LR)<br>(TCR3LR)             | (Address = 0x050A)<br>(Address = 0x050E)<br>(Address = 0x051A)<br>(Address = 0x051E) |  |
|------------------------------|-------|----------------------------------------------------------|--------------------------------------------------------------------------------------|--|
| Bit(s)                       | Value | Description                                              |                                                                                      |  |
| 7:0                          |       | Eight LSBs of the match value to reset Timer C Output x. |                                                                                      |  |

| Timer C Reset x High Register |       | (TCR0HR)<br>(TCR1HR)<br>(TCR2HR)<br>(TCR3HR)             | (Address = 0x050B)<br>(Address = 0x050F)<br>(Address = 0x051B)<br>(Address = 0x051F) |  |
|-------------------------------|-------|----------------------------------------------------------|--------------------------------------------------------------------------------------|--|
| Bit(s)                        | Value | Description                                              |                                                                                      |  |
| 7:0                           |       | Eight MSBs of the match value to reset Timer C Output x. |                                                                                      |  |

| Tim    | Timer C Block Access Register |                                                                                                                                       | (TCBAR) | (Address = 0x00F8) |
|--------|-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|---------|--------------------|
| Bit(s) | Value                         | Description                                                                                                                           |         |                    |
| 7:0    |                               | Access the Timer C register pointed to by TCBPR. TCBPR is automatically updated to the next Timer C register address in the sequence. |         |                    |

Chapter 16 Timer C 169

| Timer C Block Pointer Register |       | (TCBPR)                                                                          | (Address = 0x00F9) |  |
|--------------------------------|-------|----------------------------------------------------------------------------------|--------------------|--|
| Bit(s)                         | Value | Description                                                                      |                    |  |
| 7:5                            |       | These bits always read as 0x0.                                                   |                    |  |
| 4:0                            |       | Five least significant bits of the Timer C register address for indirect access. |                    |  |

| Glo    | bal Contro                                                                                                  | ol/Status Register (GCSR) (Address = 0x0000)                                                                                                                           |  |  |
|--------|-------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit(s) | Value                                                                                                       | Description                                                                                                                                                            |  |  |
| 4:2    | 000                                                                                                         | Processor clock from the main clock, divided by eight.  Peripheral clock from the main clock, divided by eight.                                                        |  |  |
|        | 001                                                                                                         | Processor clock from the main clock, divided by eight. Peripheral clock from the main clock.                                                                           |  |  |
|        | 010                                                                                                         | Processor clock from the main clock. Peripheral clock from the main clock.                                                                                             |  |  |
|        | 011                                                                                                         | Processor clock from the main clock, divided by two.  Peripheral clock from the main clock, divided by two.                                                            |  |  |
|        | 100                                                                                                         | Processor clock from the 32 kHz clock, optionally divided via GPSCR.  Peripheral clock from the 32 kHz clock, optionally divided via GPSCR.                            |  |  |
|        | 101                                                                                                         | Processor clock from the 32 kHz clock, optionally divided via GPSCR. Peripheral clock from the 32 kHz clock, optionally divided via GPSCR. The fast clock is disabled. |  |  |
|        | 110                                                                                                         | Processor clock from the main clock, divided by four.  Peripheral clock from the main clock, divided by four.                                                          |  |  |
|        | Processor clock from the main clock, divided by six.  Peripheral clock from the main clock, divided by six. |                                                                                                                                                                        |  |  |

# 17. SERIAL PORTS A – D

#### 17.1 Overview

Serial Ports A, B, C, and D are identical, except for the source of the data clock and the transmit, receive, and clock pins. In addition to being used as a regular serial port, Serial Port A can be used to bootstrap the processor. Each serial port can be used in the asynchronous or the clocked serial mode with an internal or external clock.

In the asynchronous mode, either 7 or 8 data bits can be transferred, and a parity bit and/or a ninth data bit can be appended as well. Parity and the ninth data bits are also detected when they are received. The asynchronous mode is full-duplex, while the clocked mode can be half or full-duplex.

Both transmit and receive have one byte of buffering — a byte may be read while another byte is being received, or the next byte to be transmitted can be loaded while the current byte is still being transferred out.

The status of each serial port is available in its Serial Port Status Register (SxSR), and contains information on whether a received byte is available, the receive buffer was overrun, a parity error was received, the transmit buffer is empty or busy sending a byte, and the state of the ninth data bit (whether it is an address bit or a stop bit). Each serial port has a separate interrupt vector that will be requested whenever the transmit buffer is emptied or the receive buffer contains a full byte.

All four common SPI clock modes are supported, and the bit order of the data may be either MSB or LSB first. The transmit and receive operations are under program control as well.

**NOTE:** The maximum external serial clock rate for the SPI port is 1/6 of the peripheral clock rate.



Figure 17-1. Serial Ports A – D Operation in Clocked Serial Mode

In the asynchronous mode, IrDA-compliant RZI encoding can be enabled to reduce the bit widths to 3/16 the normal width (1/8 the normal width if the serial data clock is 8× instead of 16×), which allows the serial port signal to be connected directly to an IrDA transceiver.

It is possible to select the same pin on Parallel Port C for both transmit and receive operation. This allows glueless support for bidirectional serial protocols.

It is possible to synchronize a clocked serial transfer to the match registers of Timer B to generate precisely timed transmissions.

The serial port data clocks can be generated from the appropriate 8-bit timer from Timer A shown in Table 17-1 or from a dedicated n+1 15-bit divider. In either case, the resulting bit data rate in the asynchronous mode is 1/8 or 1/16 the data clock rate (selectable). However, the bit data rate in the clocked serial mode is equal to the data clock rate as generated from the appropriate Timer A timer or from the dedicated 15-bit divider.

Table 17-1. Timer A Data Clocks

| Serial Port | Data Clock |
|-------------|------------|
| A           | Timer A4   |
| В           | Timer A5   |
| С           | Timer A6   |
| D           | Timer A7   |

When Serial Port A is used in the asynchronous bootstrap mode, the 32 kHz clock is used to generate the expected 2400 bps data rate. An external clock must be supplied for the clocked serial bootstrap mode.

The behavior of the serial port during a break (line held low) is configurable; character assembly can continue during the break condition to allow for timing the break, or character assembly can be inhibited to reduce the interrupt overhead.

## 17.1.1 Block Diagram



# 17.1.2 Registers

| Register Name                       | Mnemonic | I/O Address | R/W | Reset     |
|-------------------------------------|----------|-------------|-----|-----------|
| Serial Port A Data Register         | SADR     | 0x00C0      | R/W | xxxxxxxx  |
| Serial Port A Address Register      | SAAR     | 0x00C1      | W   | xxxxxxxx  |
| Serial Port A Long Stop Register    | SALR     | 0x00C2      | W   | xxxxxxxx  |
| Serial Port A Status Register       | SASR     | 0x00C3      | R   | 0xx00000  |
| Serial Port A Control Register      | SACR     | 0x00C4      | R/W | xx0000000 |
| Serial Port A Extended Register     | SAER     | 0x00C5      | R/W | 00000000  |
| Serial Port A Divider Low Register  | SADLR    | 0x00C6      | R/W | xxxxxxxx  |
| Serial Port A Divider High Register | SADHR    | 0x00C7      | R/W | 0xxxxxxx  |
| Serial Port B Data Register         | SBDR     | 0x00D0      | R/W | xxxxxxxx  |
| Serial Port B Address Register      | SBAR     | 0x00D1      | W   | xxxxxxxx  |
| Serial Port B Long Stop Register    | SBLR     | 0x00D2      | W   | xxxxxxxx  |
| Serial Port B Status Register       | SBSR     | 0x00D3      | R   | 0xx00000  |
| Serial Port B Control Register      | SBCR     | 0x00D4      | R/W | xx000000  |
| Serial Port B Extended Register     | SBER     | 0x00D5      | R/W | 00000000  |
| Serial Port B Divider Low Register  | SBDLR    | 0x00D6      | R/W | xxxxxxxx  |
| Serial Port B Divider High Register | SBDHR    | 0x00D7      | R/W | 0xxxxxxx  |
| Serial Port C Data Register         | SCDR     | 0x00E0      | R/W | xxxxxxxx  |
| Serial Port C Address Register      | SCAR     | 0x00E1      | W   | xxxxxxxx  |
| Serial Port C Long Stop Register    | SCLR     | 0x00E2      | W   | xxxxxxxx  |
| Serial Port C Status Register       | SCSR     | 0x00E3      | R   | 0xx00000  |
| Serial Port C Control Register      | SCCR     | 0x00E4      | R/W | xx000000  |
| Serial Port C Extended Register     | SCER     | 0x00E5      | R/W | 00000000  |
| Serial Port C Divider Low Register  | SCDLR    | 0x00E6      | R/W | xxxxxxxx  |
| Serial Port C Divider High Register | SCDHR    | 0x00E7      | R/W | 0xxxxxxx  |
| Serial Port D Data Register         | SDDR     | 0x00F0      | R/W | xxxxxxxx  |
| Serial Port D Address Register      | SDAR     | 0x00F1      | W   | xxxxxxxx  |
| Serial Port D Long Stop Register    | SDLR     | 0x00F2      | W   | xxxxxxxx  |
| Serial Port D Status Register       | SDSR     | 0x00F3      | R   | 0xx00000  |
| Serial Port D Control Register      | SDCR     | 0x00F4      | R/W | xx000000  |
| Serial Port D Extended Register     | SDER     | 0x00F5      | R/W | 00000000  |
| Serial Port D Divider Low Register  | SDDLR    | 0x00F6      | R/W | xxxxxxxx  |
| Serial Port D Divider High Register | SDDHR    | 0x00F7      | R/W | 0xxxxxxx  |

### 17.2 Dependencies

### 17.2.1 I/O Pins

Serial Port A can transmit on parallel port pins PC7, PC6, or PD6, and can receive on pins PC7, PD7, or PE7. If the clocked serial mode is enabled, the serial clock is either transmitted or received on PB1. When an internal clock is selected in the clocked serial mode, PB1 is automatically enabled as a clock output.

Serial Port B can transmit on parallel port pins PC5, PC4, or PD4, and can receive on pins PC5, PD5, or PE5. If the clocked serial mode is enabled, the serial clock is either transmitted or received on PB0. When an internal clock is selected in the clocked serial mode, PB0 is automatically enabled as a clock output.

Serial Port C can transmit on parallel port pins PC3 or PC2, and can receive on pins PC3, PD3, or PE3. If the clocked serial mode is enabled, the serial clock can be transmitted on PC7, PD7, PD2, or PE7, and can be received on PD2 or PE2.

**NOTE:** When Serial Port C is used as a clocked serial port, the parallel port pin used to transmit the serial clock will not be available for other use.

Serial Port D can transmit on parallel port pins PC1 or PC0, and can receive on pins PC1, PD1, or PE1. If the clocked serial mode is enabled, the serial clock can be transmitted on PC3, PD3, PD0, or PE3, and can be received on PD0 or PE0.

**NOTE:** When Serial Port D is used as a clocked serial port, the parallel port pin used to transmit the serial clock will not be available for other use.

| Function       | Serial Port A | Serial Port B | Serial Port C              | Serial Port D              |
|----------------|---------------|---------------|----------------------------|----------------------------|
| Transmit       | PC7, PC6, PD6 | PC5, PC4, PD4 | PC3, PC2                   | PC1, PC0                   |
| Receive        | PC7, PD7, PE7 | PC5, PD5, PE5 | PC3, PD3, PE3              | PC1, PD1, PE1              |
| Transmit Clock | PB1           | PB0           | PC7, PD7, PD2,<br>PE7, PH7 | PC3, PD3, PD0,<br>PE3, PH3 |
| Receive Clock  | PB1           | PB0           | PD2, PE2                   | PD0, PE0                   |

Table 17-2. Pin Usage Serial Ports A – D

#### 17.2.2 Clocks

The data clocks for Serial Ports A - D are based on the peripheral clock and are divided by either a Timer A divider or a dedicated 15-bit divider. In either case, the overall clock divider will be the value in the appropriate register plus one.

### 17.2.3 Other Registers

| Register                                                       | Function                        |
|----------------------------------------------------------------|---------------------------------|
| TAT4R                                                          | Time constant for Serial Port A |
| TAT5R                                                          | Time constant for Serial Port B |
| TAT6R                                                          | Time constant for Serial Port C |
| TAT7R                                                          | Time constant for Serial Port D |
| PCFR, PCAHR, PCALR<br>PDFR, PDAHR, PDALR<br>PEFR, PEAHR, PEALR | Alternate port output selection |

### 17.2.4 Interrupts

A serial port interrupt can be generated whenever one of the following occurs.

- A byte is available in the receive buffer.
- A byte is moved from the transmit buffer to the transmitter.
- A byte has been sent out of the transmitter and the transmit buffer is empty.

These occurrences correspond to bits 2, 3, and 7 of the Serial Port Status Registers.

The serial port interrupt vectors are located in the IIR as follows.

- Serial Port A at offset 0x0C0
- Serial Port B at offset 0x0D0
- Serial Port C at offset 0x0E0
- Serial Port D at offset 0x0F0

Each of them can be set as Priority 1, 2, or 3 in SxCR, where x is A - D for the four serial ports.

# 17.3 Operation

**TIP:** Remember to set up the serial port bits before commanding the serial port to send or receive any data.

### 17.3.1 Asynchronous Mode

The following steps explain how to set up Serial Ports A - D for asynchronous operation. The serial ports can be used by polling the status byte, but their performance will be better with an interrupt. These instructions also apply to the asynchronous operation of Serial Ports E - F.

- 1. Write the interrupt vector for the interrupt service routine to the internal interrupt table.
- 2. Set up the desired transmit pin by writing to the appropriate parallel port function register (PxFR) and alternate output register (PxALR or PxAHR).
- 3. Select the appropriate mode by writing to SxCR (receive input port and 7 or 8 bits). Also select the interrupt priority.
- 4. Select additional options by writing to SxER (parity, RZI encoding, clock polarity, and behavior during break).
- 5. Write the desired divider value to TATxR for the appropriate serial port, or else write a divider value to the dedicated 15-bit divider in SxDLR and SxDHR. If the dedicated divider is to be used, write a 1 to the most-significant bit of SxDHR to enable it.

A sample asynchronous serial interrupt handler is shown below for Serial Port A.

```
async_sera_isr::
  push af
                    ; save used registers
  ioi ld a, (SASR) ; get status
  bit 7,a
                      ; check if byte ready in RX buffer
                      ; save status for next check
  push af
   jr z, check for tx
rx ready:
   ioi ld a, (SADR) ; read byte and clear interrupt
   ; do something with byte here
check_for_tx:
  pop af
  bit 3,a
                      ; check if TX buffer was emptied
  jr nz, done
   ; get next byte to be transmitted into A here
   ioi ld (SADR), a ; load next byte into TX buffer and clear interrupt
done:
  pop af
                      ; restore used registers
  ipres
```

To transmit with an address (1) bit appended, write the data to SxAR instead of SxDR; to append a stop (0) bit write to SxLR instead.

#### 17.3.2 Clocked Serial Mode

The following steps explain how to set up Serial Ports A - D for the clocked serial mode. When the internal clock is selected, the Rabbit 5000 is in control of all transmit and receive operations. When an external clock is selected the other device controls all transmit and receive operation. For both situations the decision between polling and interrupt-driven methods is application dependent.

- 1. Write the interrupt vector for the interrupt service routine to the internal interrupt table.
- 2. Set up the desired data transmit and clock pins by writing to the appropriate parallel port function register (PxFR) and alternate output register (PxALR or PxAHR).
- 3. Select the appropriate mode by writing to SxCR (receive input port and clock source). Also select the interrupt priority.
- 4. Select additional options by writing to SxER (clock polarity, bit order, and clock source if external).
- 5. Write the desired divider value to TATxR for the appropriate serial port, or else write a divider to the dedicated 15-bit divider in SxDLR and SxDHR. If the dedicated divider is to be used, write a 1 to the most-significant bit of SxDHR to enable it.
- 6. There are two methods to transfer a byte:

write the byte to SxDR and then write 10 (or 11) to bits 6-7 of SxCR to enable the transfer;

write the byte to SxAR which will automatically start the transfer.

If the internal clock is selected, the transmission will begin immediately; if an external clock is selected, the transmission will begin when the clock is detected.

7. There are two methods to receive a byte:

write 01 to bits 6–7 of SxCR to start the receive operation; read the byte from SxAR which will automatically start the transfer based on whether an internal or an external clock was selected.

If the internal clock is selected, the clock will begin immediately and the data will be read; if an external clock is selected, the receive will occur when the clock is detected.

A sample clocked serial interrupt handler is shown below for Serial Port B.

```
clocked serb isr::
  push af
                       ; save used registers
  ioi ld a, (SBSR)
                      ; get status
  bit 7,a
                       ; check if byte ready in RX buffer
  push af
                      ; save status for next check
  jr z, check_for_tx
rx ready:
  ioi ld a, (SBDR)
                    ; read byte and clear interrupt
   ; do something with received byte here
  1d a, 0x4D
                       ; set bits 6-7 to 01, the other bits should
                       ; represent the desired SBCR setup
                       ; (Parallel Port C, internal clock,
                       ; Interrupt Priority 1 in this example)
  ioi ld (SBCR), a
                      ; start a new receive operation
check for tx:
  pop af
  bit 3,a
                      ; check if TX buffer was emptied
  jr nz, done
   ; get next byte to be transmitted into Register A here
  ioi ld (SBDR), a
   ; load TX buffer with next byte and clear interrupt done:
                      ; restore used registers
  ipres
  ret
```

# 17.4 Register Descriptions

| Serial Port x Data Register |       | (SADR)<br>(SBDR)<br>(SCDR)<br>(SDDR)        | (Address = 0x00C0)<br>(Address = 0x00D0)<br>(Address = 0x00E0)<br>(Address = 0x00F0) |  |  |
|-----------------------------|-------|---------------------------------------------|--------------------------------------------------------------------------------------|--|--|
| Bit(s)                      | Value | Description                                 |                                                                                      |  |  |
| 7:0                         | Read  | Returns the contents of the receive buffer. |                                                                                      |  |  |
|                             | Write | Loads the transmit buff                     | Loads the transmit buffer with a data byte for transmission.                         |  |  |

| Ser    | Serial Port x Address Register |                                                                                                                                                                                                                                                                                                       | (SAAR)<br>(SBAR)<br>(SCAR)<br>(SDAR) | (Address = 0x00C1)<br>(Address = 0x00D1)<br>(Address = 0x00E1)<br>(Address = 0x00F1) |
|--------|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|--------------------------------------------------------------------------------------|
| Bit(s) | Value                          | Description                                                                                                                                                                                                                                                                                           |                                      |                                                                                      |
| 7:0    | Read                           | Returns the contents of the receive buffer. Reading the data from this register in the clocked serial mode automatically causes the receiver to start a byte-receive operation, eliminating the need for software to issue the start-receive command.                                                 |                                      |                                                                                      |
|        | Write                          | Loads the transmit buffer with an address byte, marked with a "zero" address bit for transmission. Writing the data to this register in the clocked serial mode causes the transmitter to start a byte-transmit operation, eliminating the need for the software to issue the start-transmit command. |                                      |                                                                                      |

| Serial Port x Long Stop Register |       | (SALR)<br>(SBLR)<br>(SCLR)<br>(SDLR)        | (Address = 0x00C2)<br>(Address = 0x00D2)<br>(Address = 0x00E2)<br>(Address = 0x00F2) |                                  |
|----------------------------------|-------|---------------------------------------------|--------------------------------------------------------------------------------------|----------------------------------|
| Bit(s)                           | Value | Description                                 |                                                                                      |                                  |
| 7:0                              | Read  | Returns the contents of the receive buffer. |                                                                                      |                                  |
|                                  | Write | Loads the transmit buffer for transmission. | with an address byte,                                                                | marked with a "one" address bit, |

|        |       | s Status Register<br>nous Mode Only)                                                                                                                                                                                                                                           | (SASR)<br>(SBSR)<br>(SCSR)<br>(SDSR)                                                                                                                                       | (Address = 0x00C3)<br>(Address = 0x00D3)<br>(Address = 0x00E3)<br>(Address = 0x00F3) |  |  |
|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|--|--|
| Bit(s) | Value |                                                                                                                                                                                                                                                                                | Description                                                                                                                                                                | ı                                                                                    |  |  |
| 7      | 0     | The receive data registe                                                                                                                                                                                                                                                       | er is empty                                                                                                                                                                |                                                                                      |  |  |
|        | 1     | 1                                                                                                                                                                                                                                                                              |                                                                                                                                                                            | port will request an interrupt en the receive buffer is empty.                       |  |  |
| 6      | 0     | The byte in the receive                                                                                                                                                                                                                                                        | buffer is data, received                                                                                                                                                   | with a valid stop bit.                                                               |  |  |
|        | 1     | -                                                                                                                                                                                                                                                                              | The byte in the receive buffer is an address, or a byte with a framing error. If an address bit is not expected, and the data in the buffer is all zeros, this is a break. |                                                                                      |  |  |
| 5      | 0     | The receive buffer was not overrun.                                                                                                                                                                                                                                            |                                                                                                                                                                            |                                                                                      |  |  |
|        | 1     | The receive buffer was overrun. This bit is cleared by reading the receive buffer.                                                                                                                                                                                             |                                                                                                                                                                            |                                                                                      |  |  |
| 4      | 0     | The byte in the receive buffer has no parity error (or was not checked for parity).                                                                                                                                                                                            |                                                                                                                                                                            |                                                                                      |  |  |
|        | 1     | The byte in the receive buffer had a parity error.                                                                                                                                                                                                                             |                                                                                                                                                                            |                                                                                      |  |  |
| 3      | 0     | The transmit buffer is empty.                                                                                                                                                                                                                                                  |                                                                                                                                                                            |                                                                                      |  |  |
|        | 1     | The transmit buffer is not empty. The serial port will request an interrupt when the transmitter takes a byte from the transmit buffer. Transmit interrupts are cleared when the transmit buffer is written, or any value (which will be ignored) is written to this register. |                                                                                                                                                                            |                                                                                      |  |  |
| 2      | 0     | The transmitter is idle.                                                                                                                                                                                                                                                       | The transmitter is idle.                                                                                                                                                   |                                                                                      |  |  |
|        | 1     | The transmitter is sending a byte. An interrupt is generated when the transmitter clears this bit, which occurs only if the transmitter is ready to start sending another byte and the transmit buffer is empty.                                                               |                                                                                                                                                                            |                                                                                      |  |  |
| 1:0    | 00    | These bits are always ze                                                                                                                                                                                                                                                       | ero in the asynchronous                                                                                                                                                    | mode.                                                                                |  |  |

|        |       | s Status Register<br>erial Mode Only)                                                                                                                                                                                                                                          | (SASR)<br>(SBSR)<br>(SCSR)<br>(SDSR)                | (Address = 0x00C3)<br>(Address = 0x00D3)<br>(Address = 0x00E3)<br>(Address = 0x00F3) |  |  |
|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|--------------------------------------------------------------------------------------|--|--|
| Bit(s) | Value |                                                                                                                                                                                                                                                                                | Description                                         |                                                                                      |  |  |
| 7      | 0     | The receive data register                                                                                                                                                                                                                                                      | r is empty                                          |                                                                                      |  |  |
|        | 1     | There is a byte in the rec<br>while this bit is set. The                                                                                                                                                                                                                       | ceive buffer. The serial printerrupt is cleared who | port will request an interrupt en the receive buffer is empty.                       |  |  |
| 6      | 0     | This bit is always zero in                                                                                                                                                                                                                                                     | n the clocked serial mod                            | de.                                                                                  |  |  |
| 5      | 0     | The receive buffer was not overrun.                                                                                                                                                                                                                                            |                                                     |                                                                                      |  |  |
|        | 1     | The receive buffer was overrun. This bit is cleared by reading the receive buffer.                                                                                                                                                                                             |                                                     |                                                                                      |  |  |
| 4      | 0     | This bit is always zero in the clocked serial mode.                                                                                                                                                                                                                            |                                                     |                                                                                      |  |  |
| 3      | 0     | The transmit buffer is empty.                                                                                                                                                                                                                                                  |                                                     |                                                                                      |  |  |
|        | 1     | The transmit buffer is not empty. The serial port will request an interrupt when the transmitter takes a byte from the transmit buffer. Transmit interrupts are cleared when the transmit buffer is written, or any value (which will be ignored) is written to this register. |                                                     |                                                                                      |  |  |
| 2      | 0     | The transmitter is idle.                                                                                                                                                                                                                                                       |                                                     |                                                                                      |  |  |
|        | 1     | The transmitter is sending a byte. An interrupt is generated when the transmitter clears this bit, which occurs only if the transmitter is ready to start sending another byte and the transmit buffer is empty.                                                               |                                                     |                                                                                      |  |  |
| 1:0    | 00    | These bits are always zero in the clocked serial mode.                                                                                                                                                                                                                         |                                                     |                                                                                      |  |  |

| Se     | rial Port x | Control Register                                                                                                                                          | (SACR)<br>(SBCR)<br>(SCCR)<br>(SDCR) | (Address = 0x00C4)<br>(Address = 0x00D4)<br>(Address = 0x00E4)<br>(Address = 0x00F4) |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|--------------------------------------------------------------------------------------|--|
| Bit(s) | Value       |                                                                                                                                                           | Description                          |                                                                                      |  |
| 7:6    | 00          | No operation. These bits are                                                                                                                              | e ignored in the asyn                | chronous mode.                                                                       |  |
|        | 01          | In the clocked serial mode,                                                                                                                               | start a byte-receive of              | operation.                                                                           |  |
|        | 10          | In the clocked serial mode,                                                                                                                               | start a byte-transmit                | operation.                                                                           |  |
|        | 11          | In the clocked serial mode, start a byte-transmit operation and a byte-receive operation simultaneously.                                                  |                                      |                                                                                      |  |
| 5:4    | 00          | Parallel Port C is used for input.                                                                                                                        |                                      |                                                                                      |  |
|        | 01          | Parallel Port D is used for input.                                                                                                                        |                                      |                                                                                      |  |
|        | 10          | Parallel Port E is used for in                                                                                                                            |                                      |                                                                                      |  |
|        | 11          | Disable the receiver input.                                                                                                                               |                                      |                                                                                      |  |
| 3:2    | 00          | Asynchronous mode with 8 bits per character.                                                                                                              |                                      |                                                                                      |  |
|        | 01          | Asynchronous mode with 7 bits per character. In this mode the most significant bit of a byte is ignored for transmit, and is always zero in receive data. |                                      |                                                                                      |  |
|        | 10          | Clocked serial mode with ex                                                                                                                               | kternal clock.                       |                                                                                      |  |
|        | 11          | Clocked serial mode with in                                                                                                                               | ternal clock.                        |                                                                                      |  |
| 1:0    | 00          | The serial port interrupt is disabled.                                                                                                                    |                                      |                                                                                      |  |
|        | 01          | The serial port uses Interrup                                                                                                                             | t Priority 1.                        |                                                                                      |  |
|        | 10          | The serial port uses Interrup                                                                                                                             | ot Priority 2.                       |                                                                                      |  |
|        | 11          | The serial port uses Interrup                                                                                                                             | ot Priority 3.                       |                                                                                      |  |

|        |       | Extended Register<br>ous Mode Only)                                                                                                                        | (SAER)<br>(SBER)<br>(SCER)<br>(SDER)          | (Address = 0x00C5)<br>(Address = 0x00D5)<br>(Address = 0x00E5)<br>(Address = 0x00F5) |  |
|--------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|--------------------------------------------------------------------------------------|--|
| Bit(s) | Value |                                                                                                                                                            | Description                                   |                                                                                      |  |
| 7:5    | 000   | Disable parity generation an                                                                                                                               | d checking.                                   |                                                                                      |  |
|        | 001   | This bit combination is reser                                                                                                                              | rved and should not b                         | oe used.                                                                             |  |
|        | 010   | This bit combination is reser                                                                                                                              | rved and should not b                         | oe used.                                                                             |  |
|        | 011   | This bit combination is reser                                                                                                                              | rved and should not b                         | oe used.                                                                             |  |
|        | 100   | Enable parity generation and                                                                                                                               | d checking with even                          | parity.                                                                              |  |
|        | 101   | Enable parity generation and checking with odd parity.                                                                                                     |                                               |                                                                                      |  |
|        | 110   | Enable parity generation and checking with space (always zero) parity.                                                                                     |                                               |                                                                                      |  |
|        | 111   | Enable parity generation and                                                                                                                               | d checking with mark                          | (always one) parity.                                                                 |  |
| 4      | 0     | Normal asynchronous data encoding.                                                                                                                         |                                               |                                                                                      |  |
|        | 1     | Enable RZI coding (3/16 bit cell IrDA-compliant).                                                                                                          |                                               |                                                                                      |  |
| 3      | 0     | Normal break operation. This option should be selected when address bits are expected.                                                                     |                                               |                                                                                      |  |
|        | 1     | Fast break termination. At the end of break, a dummy character is written to the buffer, and the receiver can start character assembly after one bit time. |                                               |                                                                                      |  |
| 2      | 0     | Asynchronous clock is 16×                                                                                                                                  | data rate.                                    |                                                                                      |  |
|        | 1     | Asynchronous clock is 8× da                                                                                                                                | ata rate.                                     |                                                                                      |  |
| 1      | 0     | Continue character assembly                                                                                                                                | y during break to allo                        | ow timing the break condition.                                                       |  |
|        | 1     | Inhibit character assembly during break. One character (all zeros, with framing error) at start and one character (garbage) at completion.                 |                                               |                                                                                      |  |
| 0      |       | This bit is ignored in the asy                                                                                                                             | This bit is ignored in the asynchronous mode. |                                                                                      |  |

|                                                                                                                                      |       | Extended Register<br>erial Mode Only)                                       | (SAER)<br>(SBER)<br>(SCER)<br>(SDER)                                             | (Address = 0x00C5)<br>(Address = 0x00D5)<br>(Address = 0x00E5)<br>(Address = 0x00F5) |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------|-------|-----------------------------------------------------------------------------|----------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|--|--|
| Bit(s)                                                                                                                               | Value |                                                                             | Description                                                                      |                                                                                      |  |  |
| 7                                                                                                                                    | 0     | Normal clocked serial ope                                                   | eration.                                                                         |                                                                                      |  |  |
|                                                                                                                                      | 1     | Timer-synchronized clock                                                    | ted serial operation.                                                            |                                                                                      |  |  |
| 6                                                                                                                                    | 0     | Timer-synchronized clock                                                    | ced serial uses Timer I                                                          | 31.                                                                                  |  |  |
|                                                                                                                                      | 1     | Timer-synchronized clock                                                    | ted serial uses Timer I                                                          | B2.                                                                                  |  |  |
| 5:4                                                                                                                                  | 00    | Normal clocked serial clo                                                   | Normal clocked serial clock polarity, inactive high. Internal or external clock. |                                                                                      |  |  |
| Normal clocked serial clock polarity, inactive low. Internation 10 Inverted clocked serial clock polarity, inactive low. Internation |       |                                                                             |                                                                                  | ow. Internal clock only.                                                             |  |  |
|                                                                                                                                      |       |                                                                             |                                                                                  | ow. Internal or external clock.                                                      |  |  |
|                                                                                                                                      | 11    | Inverted clocked serial clock polarity, inactive high. Internal clock only. |                                                                                  |                                                                                      |  |  |
| 3                                                                                                                                    | 0     | Normal bit order (LSB first) for transmit and receive.                      |                                                                                  |                                                                                      |  |  |
|                                                                                                                                      | 1     | Reverse bit order (MSB first) for transmit and receive.                     |                                                                                  |                                                                                      |  |  |
| 2                                                                                                                                    | 0     | Serial clock (input mode                                                    | Serial clock (input mode only) from Parallel Port D (SCER and SDER only).        |                                                                                      |  |  |
|                                                                                                                                      | 1     | Serial clock (input mode only) from Parallel Port E (SCER and SDER only).   |                                                                                  |                                                                                      |  |  |
| 1                                                                                                                                    | 0     | No effect on transmitter.                                                   |                                                                                  |                                                                                      |  |  |
|                                                                                                                                      | 1     | Terminate current clocked serial transmission. No effect on buffer.         |                                                                                  |                                                                                      |  |  |
| 0                                                                                                                                    | 0     | No effect on receiver.                                                      | No effect on receiver.                                                           |                                                                                      |  |  |
|                                                                                                                                      | 1     | Terminate current clocked serial reception.                                 |                                                                                  |                                                                                      |  |  |

| Serial Port x Divider Low Register |       | (SADLR)<br>(SBDLR)<br>(SCDLR)<br>(SDDLR)                                                                                                                      | (Address = 0x00C6)<br>(Address = 0x00D6)<br>(Address = 0x00E6)<br>(Address = 0x00F6) |  |
|------------------------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|--|
| Bit(s)                             | Value | Description                                                                                                                                                   |                                                                                      |  |
| 7:0                                |       | Eight LSBs of the divider that generates the serial clock for this channel. This divider is not used unless the MSB of the corresponding SxDHR is set to one. |                                                                                      |  |

| Seria  | l Port x Di | vider High Register                                                                                                                                                | (SADHR)<br>(SBDHR)<br>(SCDHR)<br>(SDDHR) | (Address = 0x00C7)<br>(Address = 0x00D7)<br>(Address = 0x00E7)<br>(Address = 0x00F7) |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|--------------------------------------------------------------------------------------|
| Bit(s) | Value       | Description                                                                                                                                                        |                                          |                                                                                      |
| 7      | 0           | Disable the serial port divider and use the output of Timer A to clock the serial port.                                                                            |                                          |                                                                                      |
|        | 1           | Enable the serial port divider, and use its output to clock the serial port. The serial port divider counts modulo $n + 1$ and is clocked by the peripheral clock. |                                          |                                                                                      |
| 6:0    |             | Seven MSBs of the divide                                                                                                                                           | er that generates the se                 | rial clock for this channel.                                                         |

# 18. SERIAL PORTS E – F

#### 18.1 Overview

Serial Ports E and F are identical to each other, and their asynchronous operation is identical to that of Serial Ports A - D except for the source of the data clock, the buffer sizes, and the transmit, receive, and clock pins. Each serial port can be used in the asynchronous or the HDLC mode with an internal or external clock.

In the asynchronous mode, either 7 or 8 data bits can be transferred, and both a parity bit and/or ninth data bit can be appended as well. Parity and the ninth data bits are also detected when they are received. The asynchronous mode is full-duplex.

The transmit and receive buffers of Serial Ports E and F have 4 bytes each; this reduces the interrupt overhead requirements because an interrupt does not have to be generated as often. A serial port interrupt is generated whenever at least one byte is available in the receive buffer or whenever a byte is shifted out of the transmit buffer.

The status of each serial port is available in its Serial Port Status Register (SxSR), and contains information on whether a received byte is available, the receive buffer was overrun, a parity error was received, the transmit buffer is empty or busy sending a byte, and the state of the ninth data bit (whether it is an address bit or a stop bit).

Serial Ports E and F support the HDLC mode with either an internal or an external clock; separate pins may be used for the transmit and receive clocks, or the transmit and receive clocks may be combined onto a single pin. The HDLC packet flag encapsulation, flag escapes, and CRC calculation and check are handled automatically by the processor. The serial port can detect end-of-frame, short-frame, and CRC errors. Interrupts are generated by the reception of an end-of-frame, at the end of a transmission of a CRC, by an abort sequence, or by a closing flag. Transmit and receive operations are essentially automatic.

The standard CRC-CCITT polynomial  $(x^{16} + x^{12} + x^5 + 1)$  is implemented for the CRC, with the generator and checker preset to all ones.

It is possible to send packets with or without a CRC appended. It is also possible to select whether an abort or flag will be transmitted if the transmitter underflows. A packet under transition can be aborted and the abort pattern sent. The idle condition of the line can be flags or all ones.

Several types of data encoding are available in HDLC mode: NRZ, NRZI, biphase-level (Manchester), biphase-space (FM0), and biphase-mark (FM1). IrDA-compliant RZI

encoding is also available in HDLC mode; it reduces the bit widths to ¼ the normal width, which allows the serial-port signal to be connected directly to an IrDA transceiver.

If an internal clock is selected, the serial port data clocks can be generated from the appropriate 8-bit timer (Timer A2 for Serial Port E and Timer A3 for Serial Port F) or from a dedicated 15-bit divider. In HDLC mode, the bit data rate is equal to the data clock rate divided by 16.

When using an external clock, a  $1 \times$  (same speed as the data rate) clock is supported. In this case, the maximum data rate is 1/6 of the peripheral clock rate. The receive clock is generated from the transitions in the data stream via a digital phase-locked loop (DPLL). The timing of this synchronization is adjusted with each incoming transition, allowing for tracking if the two external clocks differ slightly in frequency. For more on the clock synchronization and data encoding, see Section 18.3.3.

### 18.1.1 Block Diagram



## 18.1.2 Registers

| Register Name                       | Mnemonic | I/O Address | R/W | Reset    |
|-------------------------------------|----------|-------------|-----|----------|
| Serial Port E Data Register         | SEDR     | 0x00C8      | R/W | xxxxxxx  |
| Serial Port E Address Register      | SEAR     | 0x00C9      | W   | xxxxxxx  |
| Serial Port E Long Stop Register    | SELR     | 0x00CA      | W   | xxxxxxx  |
| Serial Port E Status Register       | SESR     | 0x00CB      | R   | 0xx00000 |
| Serial Port E Control Register      | SECR     | 0x00CC      | R/W | xx000000 |
| Serial Port E Extended Register     | SEER     | 0x00CD      | R/W | 00000000 |
| Serial Port E Divider Low Register  | SEDLR    | 0x00CE      | R/W | xxxxxxx  |
| Serial Port E Divider High Register | SEDHR    | 0x00CF      | R/W | 0xxxxxxx |
| Serial Port F Data Register         | SFDR     | 0x00D8      | R/W | xxxxxxx  |
| Serial Port F Address Register      | SFAR     | 0x00D9      | W   | xxxxxxx  |
| Serial Port F Long Stop Register    | SFLR     | 0x00DA      | W   | xxxxxxx  |
| Serial Port F Status Register       | SFSR     | 0x00DB      | R   | 0xx00000 |
| Serial Port F Control Register      | SFCR     | 0x00DC      | R/W | xx000000 |
| Serial Port F Extended Register     | SFER     | 0x00DD      | R/W | 00000000 |
| Serial Port F Divider Low Register  | SFDLR    | 0x00DE      | R/W | xxxxxxx  |
| Serial Port F Divider High Register | SFDHR    | 0x00DF      | R/W | 0xxxxxxx |

## 18.2 Dependencies

#### 18.2.1 I/O Pins

Serial Port E can transmit on parallel port pins PC6, PD6, PE6, or PH6, and can receive on pins PC7, PD7, or PE7. If the HDLC mode is enabled, the transmit serial clock is either transmitted or received on PC4, PD4, or PE4, while the receive serial clock is either transmitted or received on PC5, PD5, or PE5. The transmit and receive clocks can also be transmitted on PH4 or PH0 if internal clock mode is enabled.

Serial Port F can transmit on parallel port pins PC2, PD2, PE2, or PH2, and can receive on pins PC3, PD3, or PE3. If the HDLC mode is enabled, the transmit serial clock is either transmitted or received on PC0, PD0, or PE0, while the receive serial clock is either transmitted or received on PC1, PD1, or PE1. The transmit and receive clocks can also be transmitted on PH5 or PH1 if internal clock mode is enabled.

| Function Serial Port E |                    | Serial Port F      |
|------------------------|--------------------|--------------------|
| Transmit               | PC6, PD6, PE6, PH6 | PC2, PD2, PE2, PH2 |
| Receive                | PC7, PD7, PE7      | PC3, PD3, PE3      |
| Transmit Clock         | PC4, PD4, PE4, PH4 | PC0, PD0, PE0, PH0 |
| Receive Clock          | PC5, PD5, PE5, PH5 | PC1, PD1, PE1, PH1 |

Table 18-1. Serial Ports E and F Pin Usage

#### 18.2.2 Clocks

The data clocks for Serial Ports E - F are based on the peripheral clock and divided by either a Timer A divider or a dedicated 15-bit divider. In either case, the overall clock divider will be the value in the appropriate register plus one.

#### 18.2.3 Other Registers

| Register                                                                             | Function                        |
|--------------------------------------------------------------------------------------|---------------------------------|
| TAT2R                                                                                | Time constant for Serial Port E |
| TAT3R                                                                                | Time constant for Serial Port F |
| PCFR, PCAHR, PCALR<br>PDFR, PDAHR, PDALR<br>PEFR, PEAHR, PEALR<br>PHFR, PHAHR, PHALR | Alternate port output selection |

## 18.2.4 Interrupts

In the asynchronous mode, a serial port interrupt can be generated whenever one of the following occurs.

- A byte is available in the receive buffer.
- A byte is moved from the transmit buffer to the transmitter.
- A byte has been sent out of the transmitter and the transmit buffer is empty.

These occurrences correspond to bits 2, 3, and 7 of the Serial Port Status Registers.

In the HDLC mode, interrupts are also generated by the reception of an end-of-frame (with abort, valid CRC, or CRC error), at the end of a transmission of a CRC, by an abort sequence, or by a closing flag.

The serial port interrupt vectors are located in the IIR as follows.

- Serial Port E at offset 0x1C0
- Serial Port F at offset 0x1D0

Each of them can be set as Priority 1, 2, or 3 in SxCR, where x is E - F for the two serial ports.

## 18.3 Operation

**TIP:** Remember to set up the serial port bits before commanding the serial port to send or receive any data.

## 18.3.1 Asynchronous Mode

The steps to set up Serial Ports E - F for asynchronous operation are identical to those described in Section 17.3.1 to set up Serial Ports A - D.

### **18.3.2 HDLC Mode**

The following steps explain how to set up Serial Ports E – F for the HDLC mode.

- 1. Write the interrupt vector for the interrupt service routine to the internal interrupt table.
- 2. Set up the desired data transmit and clock pins by writing to the appropriate parallel port function register (PxFR) and alternate output register (PxALR or PxAHR).
- 3. Select the appropriate mode by writing to SxCR (receive input port and clock source). Also select the interrupt priority.
- 4. Select additional options by writing to SxER (data encoding, idle line condition, underrun behavior, and combined or separate clocks).
- 5. Write the desired divider value to TATxR for the appropriate serial port, or else write a divider to the dedicated 15-bit divider in SxDLR and SxDHR. If the dedicated divider is to be used, write a 1 to the most-significant bit of SxDHR to enable it. In either case, the overall clock divider will be the value in the appropriate register plus one.
- 6. To start transmission of a packet, write the first byte to SxDR. If internal clock is selected, the transmission will begin immediately; if an external clock is selected the transmission will begin when the clock is detected.
- 7. Continue writing bytes when space is available in the transmit buffer until the final byte of the packet. If a CRC is to be appended to the packet, write the final byte to SxAR. If no CRC is required, write the final byte to SxLR and just a closing flag will be appended. If it is desirable to abort the current packet, write 11 to bits 6–7 of SxCR, and an abort pattern will be transmitted.
- 8. The receiver will be synchronized on flag bytes and will reset the CRC. By monitoring the received bytes, decisions can be made about the incoming packet; if it is not desired (i.e., it is not addressed to this device), writing a 01 to bits 6–7 of SxCR will force the receiver back into the flag search mode.

A sample HDLC interrupt handler is shown below for Serial Port E.

```
hdlc sere isr::
  push af
  ioi ld a, (SESR)
                       ; get status
  bit 7,a
                       ; check if byte ready in RX buffer
  push af
                       ; save status for next check
   jr z, check for tx
rx ready:
   ; check status byte in A for abort or invalid CRC flags
   ioi ld a, (SEDR)
                       ; read byte and clear interrupt
   ; store byte in A here
check for tx:
  pop af
  bit 3,a
                       ; check if TX buffer was emptied
   jr nz, done
   ; check status byte in A for transmit finish reason (CRC, abort, etc.)
   ; get next byte to be transmitted into A here; if it is the last
      byte of the packet, load it into SEAR or SELR instead
   ioi ld (SEDR), a
                      ; load next byte into buffer and clear interrupt
done:
  pop af
  ipres
   ret
```

### 18.3.3 More on Clock Synchronization and Data Encoding

The transmitter is not capable of sending an arbitrary number of bits, but only a multiple of bytes. However, the receiver can receive frames of any bit length. If the last "byte" in the frame is not eight bits, the receiver sets a status flag that is buffered along with this last byte. Software can then use the table below to determine the number of valid data bits in this last "byte." Note that the receiver transfers all bits between the opening and closing flags, except for the inserted zeros, to the receiver data buffer.

| Last Byte Bit Pattern | Valid Data Bits |
|-----------------------|-----------------|
| bbbbbbb0              | 7               |
| bbbbbb01              | 6               |
| bbbbb011              | 5               |
| bbbb0111              | 4               |
| bbb01111              | 3               |
| bb011111              | 2               |
| b0111111              | 1               |

Several types of data encoding are available in the HDLC mode. In addition to the normal NRZ, they are NRZI, biphase-level (Manchester), biphase-space (FM0), and biphase-mark (FM1). Examples of these encodings are shown below. Note that the signal level does not convey information in NRZI, biphase-space, and biphase-mark. Instead it is the placement of the transitions that determine the data. In biphase-level it is the polarity of the transition that determines the data.



Figure 18-1. Examples of Data Encoding In the HDLC Mode

In the HDLC mode the internal clock comes from the output of Timer A2/Timer A3 or the dedicated divider. The timer/divider output is divided by 16 to form the transmit clock, and is fed to the digital phase-locked loop (DPLL) to form the receive clock. The DPLL is basically just a divide-by-16 counter that uses the timing of the transitions on the receive data stream to adjust its count. The DPLL adjusts the count so that the DPLL output will be properly placed in the bit cells to sample the receive data. To work properly, then, transitions are required in the receive data stream. NRZ data encoding does not guarantee transitions in all cases (a long string of zeros, for example), but the other data encodings do. NRZI guarantees transitions because of the inserted zeros, and the biphase encodings all have at least one transition per bit cell.

The DPLL counter normally counts by 16, but if a transition occurs earlier or later than expected, the count will be modified during the next count cycle. If the transition occurs earlier than expected, it means that the bit cell boundaries are early with respect to the DPLL-tracked bit-cell boundaries, so the count is shortened by either one or two counts. If the transition occurs later than expected, it means that the bit-cell boundaries are late with

respect to the DPLL-tracked bit-cell boundaries, so the count is lengthened by either one or two counts. The decision to adjust by one or by two depends on how far off the DPLL-tracked bit cell boundaries are. This tracking allows for minor differences in the transmit and receive clock frequencies.

With NRZ and NRZI data encoding, the DPLL counter runs continuously, and adjusts after every receive data transition. Since NRZ encoding does not guarantee a minimum density of transitions, the difference between the sending data rate and the DPLL output clock rate must be very small, and depends on the longest possible run of zeros in the received frame. NRZI encoding guarantees at least one transition every six bits (with the inserted zeros). Since the DPLL can adjust by two counts every bit cell, the maximum difference between the sending data rate and the DPLL output clock rate is 1/48 (~2%).

With biphase data encoding (either biphase-level, biphase-mark, or biphase-space), the DPLL runs only as long as transitions are present in the receive data stream. Two consecutive missed transitions causes the DPLL to halt operation and wait for the next available transition. This mode of operation is necessary because it is possible for the DPLL to lock onto the optional transitions in the receive data stream. Since they are optional, they will eventually not be present, and the DPLL can attempt to lock onto the required transitions. Since the DPLL can adjust by one count every bit cell, the maximum difference between the sending data rate and the DPLL output clock rate is 1/16 ( $\sim$ 6%).

With biphase data encoding, the DPLL is designed to work in multiple-access conditions where there might not be flags on an idle line. The DPLL will generate an output clock correctly based on the first transition in the leading zero of an opening flag. Similarly, only the completion of the closing flag is necessary for the DPLL to provide the extra two clocks to the receiver to assemble the data correctly. The transition is specified as follows.

- In the biphase-level mode this means the transition that defines the last zero of the closing flag.
- In the biphase-mark and the biphase-space modes this means the transition that defines the end of the last zero of the closing flag.

Figure 18-2 shows the adjustment ranges and output clock for the different modes of operation of the DPLL. Each mode of operation will be described in turn.



Figure 18-2. Adjustment Ranges and Output Clock for Different DPLL Modes

With NRZ and NRZI encoding, all transitions occur on bit-cell boundaries and the data should be sampled in the middle of the bit cell. If a transition occurs after the expected bit-cell boundary (but before the midpoint), the DPLL needs to lengthen the count to line up the bit-cell boundaries. This corresponds to the "add one" and "add two" regions shown. If a transition occurs before the bit-cell boundary (but after the midpoint), the DPLL needs to shorten the count to line up the bit-cell boundaries. This corresponds to the "subtract one" and "subtract two" regions shown. The DPLL makes no adjustment if the bit-cell boundaries are lined up within one count of the divide-by-16 counter. The regions that adjust the count by two allow the DPLL to synchronize faster to the data stream when starting up.

With biphase-level encoding, there is a guaranteed "clock" transition at the center of every bit cell and optional "data" transitions occur at the bit cell boundaries. The DPLL only uses the clock transitions to track the bit-cell boundaries by ignoring all transitions occurring outside a window around the center of the bit cell. This window is half a bit cell wide. Additionally, because the clock transitions are guaranteed, the DPLL requires that they always be present. If no transition is found in the window around the center of the bit cell for two successive bit cells, the DPLL is not in lock and immediately enters the search mode. The search mode assumes that the next transition seen is a clock transition and immediately synchronizes to this transition. No clock output is provided to the receiver during the search operation. Decoding biphase-level data requires that the data be sampled at either the quarter or three-quarter point in the bit cell. The DPLL here uses the quarter point to sample the data.

Biphase-mark encoding and biphase-space encoding are identical as far as the DPLL is concerned, and are similar to biphase-level encoding. The primary difference is the placement of the clock and data transitions. With these encodings the clock transitions are at the bit-cell boundary, the data transitions are at the center of the bit cell, and the DPLL operation is adjusted accordingly. Decoding biphase-mark or biphase-space encoding requires that the data be sampled by both edges of the recovered receive clock.

## 18.4 Register Descriptions

| S      | Serial Port | x Data Register                             | (SEDR)<br>(SFDR)                                             | (Address = 0x00C8)<br>(Address = 0x00D8) |  |
|--------|-------------|---------------------------------------------|--------------------------------------------------------------|------------------------------------------|--|
| Bit(s) | Value       | Description                                 |                                                              |                                          |  |
| 7:0    | Read        | Returns the contents of the receive buffer. |                                                              |                                          |  |
|        | Write       | Loads the transmit buff                     | Loads the transmit buffer with a data byte for transmission. |                                          |  |

| Sei    | rial Port x A | Address Register                                                                                                                                                                                                                   | (SEAR)<br>(SFAR) | (Address = 0x00C9)<br>(Address = 0x00D9) |
|--------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|------------------------------------------|
| Bit(s) | Value         | Description                                                                                                                                                                                                                        |                  |                                          |
| 7:0    | Read          | Returns the contents of the receive buffer.                                                                                                                                                                                        |                  |                                          |
|        | Write         | Loads the transmit buffer with an address byte, marked with a "zero" address to for transmission. In the HDLC mode, the last byte of a frame must be written this register to enable subsequent CRC and closing flag transmission. |                  | yte of a frame must be written to        |

| Seri   | al Port x L | ong Stop Register                                                                                 | (SELR)<br>(SFLR) | (Address = 0x00CA)<br>(Address = 0x00DA) |
|--------|-------------|---------------------------------------------------------------------------------------------------|------------------|------------------------------------------|
| Bit(s) | Value       |                                                                                                   | Description      |                                          |
| 7:0    | Read        | Returns the contents of the receive buffer.                                                       |                  |                                          |
|        | Write       | Loads the transmit buffer with an address byte, marked with a "one" address bit for transmission. |                  |                                          |

|        |       | (SESR) (Address = 0x00CB) rous Mode Only) (SFSR) (Address = 0x00DB)                                                                                                                                                                                                            |  |  |  |
|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit(s) | Value | Description                                                                                                                                                                                                                                                                    |  |  |  |
| 7      | 0     | The receive data register is empty                                                                                                                                                                                                                                             |  |  |  |
|        | 1     | There is a byte in the receive buffer. The serial port will request an interrupt while this bit is set. The interrupt is cleared when the receive buffer is empty.                                                                                                             |  |  |  |
| 6      | 0     | The byte in the receive buffer is data, received with a valid stop bit.                                                                                                                                                                                                        |  |  |  |
|        | 1     | The byte in the receive buffer is an address, or a byte with a framing error. If an address bit is not expected, and the data in the buffer is all zeros, this is a break.                                                                                                     |  |  |  |
| 5      | 0     | The receive buffer was not overrun.                                                                                                                                                                                                                                            |  |  |  |
|        | 1     | The receive buffer was overrun. This bit is cleared by reading the receive buffer.                                                                                                                                                                                             |  |  |  |
| 4      | 0     | The byte in the receive buffer has no parity error (or was not checked for parity).                                                                                                                                                                                            |  |  |  |
|        | 1     | The byte in the receive buffer had a parity error.                                                                                                                                                                                                                             |  |  |  |
| 3      | 0     | The transmit buffer is empty.                                                                                                                                                                                                                                                  |  |  |  |
|        | 1     | The transmit buffer is not empty. The serial port will request an interrupt when the transmitter takes a byte from the transmit buffer. Transmit interrupts are cleared when the transmit buffer is written, or any value (which will be ignored) is written to this register. |  |  |  |
| 2      | 0     | The transmitter is idle.                                                                                                                                                                                                                                                       |  |  |  |
|        | 1     | The transmitter is sending a byte. An interrupt is generated when the transmitter clears this bit, which occurs only if the transmitter is ready to start sending another byte and the transmit buffer is empty.                                                               |  |  |  |
| 1:0    | 00    | These bits are always zero in the asynchronous mode.                                                                                                                                                                                                                           |  |  |  |

| Se                                               |       | status Register<br>Mode Only)                                                                                                                                                                                                                                                                                                           | (SESR)<br>(SFSR)                                                                   | (Address = 0x00CB)<br>(Address = 0x00DB) |  |  |
|--------------------------------------------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|------------------------------------------|--|--|
| Bit(s)                                           | Value | Description                                                                                                                                                                                                                                                                                                                             |                                                                                    |                                          |  |  |
| 7                                                | 0     | The receive data register is empty                                                                                                                                                                                                                                                                                                      |                                                                                    |                                          |  |  |
|                                                  | 1     | There is a byte in the receive while this bit is set. The inter-                                                                                                                                                                                                                                                                        | ort will request an interrupt n the receive buffer is empty.                       |                                          |  |  |
| 6,4                                              | 00    | The byte in the receive buffe                                                                                                                                                                                                                                                                                                           | r is data.                                                                         |                                          |  |  |
|                                                  | 01    | The byte in the receive buffe                                                                                                                                                                                                                                                                                                           | r was followed by a                                                                | n abort.                                 |  |  |
|                                                  | 10    | The byte in the receive buffe                                                                                                                                                                                                                                                                                                           | r is the last in the fra                                                           | ame, with valid CRC.                     |  |  |
|                                                  | 11    | The byte in the receive buffe                                                                                                                                                                                                                                                                                                           | r is the last in the fra                                                           | ame, with a CRC error.                   |  |  |
| 5                                                | 0     | The receive buffer was not o                                                                                                                                                                                                                                                                                                            | verrun.                                                                            |                                          |  |  |
|                                                  | 1     | The receive buffer was overr                                                                                                                                                                                                                                                                                                            | The receive buffer was overrun. This bit is cleared by reading the receive buffer. |                                          |  |  |
| 3                                                | 0     | The transmit buffer is empty                                                                                                                                                                                                                                                                                                            |                                                                                    |                                          |  |  |
|                                                  | 1     | The transmit buffer is not empty. The serial port will request an interrupt when the transmitter takes a byte from the transmit buffer, unless the byte is marked as the last in the frame. Transmit interrupts are cleared when the transmit buffer is written, or when any value (which will be ignored) is written to this register. |                                                                                    |                                          |  |  |
| 2:1                                              | 00    | Transmit interrupt due to but                                                                                                                                                                                                                                                                                                           | fer empty condition                                                                | l.                                       |  |  |
|                                                  | 01    | Transmitter finished sending CRC. An interrupt is generated at the end of the CRC transmission. Data written in response to this interrupt will cause only one flag to be transmitted between frames, and no interrupt will be generated by this flag.                                                                                  |                                                                                    |                                          |  |  |
| Transmitter finished sending abort transmission. |       | nitter finished sending an abort. An interrupt is generated at the end of an ransmission.                                                                                                                                                                                                                                               |                                                                                    |                                          |  |  |
|                                                  | 11    | The transmitter finished sending a closing flag. Data written in response to this interrupt will cause at least two flags to be transmitted between frames.                                                                                                                                                                             |                                                                                    |                                          |  |  |
| 0                                                | 0     | The byte in the receiver buff                                                                                                                                                                                                                                                                                                           | er is 8 bits.                                                                      |                                          |  |  |
|                                                  | 1     | The byte in the receiver buff                                                                                                                                                                                                                                                                                                           | he byte in the receiver buffer is less than 8 bits.                                |                                          |  |  |

| Se     | erial Port x | Control Register (SECR) (Address = 0x00CC) (SFCR) (Address = 0x00DC)                                                                                                                                      |  |  |  |  |
|--------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Bit(s) | Value        | Description                                                                                                                                                                                               |  |  |  |  |
| 7:6    | 00           | No operation. These bits are ignored in the asynchronous mode.                                                                                                                                            |  |  |  |  |
|        | 01           | In HDLC mode, force receiver in flag search mode.                                                                                                                                                         |  |  |  |  |
|        | 10           | No operation.                                                                                                                                                                                             |  |  |  |  |
|        | 11           | In HDLC mode, transmit an abort pattern.                                                                                                                                                                  |  |  |  |  |
| 5:4    | 00           | Parallel Port C is used for data (and optional clock) input.                                                                                                                                              |  |  |  |  |
|        | 01           | Parallel Port D is used for data (and optional clock) input.                                                                                                                                              |  |  |  |  |
|        | 10           | Parallel Port E is used for data (and optional clock) input.                                                                                                                                              |  |  |  |  |
|        | 11           | Disable the receiver data input. Clocks from Parallel Port E.                                                                                                                                             |  |  |  |  |
| 3:2    | 00           | Asynchronous mode with 8 bits per character.                                                                                                                                                              |  |  |  |  |
|        | 01           | Asynchronous mode with 7 bits per character. In this mode the most significant bit of a byte is ignored for transmit, and is always zero in receive data.                                                 |  |  |  |  |
|        | 10           | DLC mode with external clock. The external clocks are supplied via parallel rt pins.                                                                                                                      |  |  |  |  |
|        | 11           | HDLC mode with internal clock. The clock is 16× the data rate, and the DPLL is used to recover the receive clock. If necessary, the receiver and transmitter clocks can be output via parallel port pins. |  |  |  |  |
| 1:0    | 00           | The serial port interrupt is disabled.                                                                                                                                                                    |  |  |  |  |
|        | 01           | The serial port uses Interrupt Priority 1.                                                                                                                                                                |  |  |  |  |
|        | 10           | The serial port uses Interrupt Priority 2.                                                                                                                                                                |  |  |  |  |
|        | 11           | The serial port uses Interrupt Priority 3.                                                                                                                                                                |  |  |  |  |

|        |                                                                                                                                            | Extended Register (SEER) (Address = 0x00CD) rous Mode Only) (SFER) (Address = 0x00DD)  |  |  |  |
|--------|--------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|--|--|--|
| Bit(s) | Value                                                                                                                                      | Description                                                                            |  |  |  |
| 7:5    | 000                                                                                                                                        | Disable parity generation and checking.                                                |  |  |  |
|        | 001                                                                                                                                        | This bit combination is reserved and should not be used.                               |  |  |  |
|        | 010                                                                                                                                        | This bit combination is reserved and should not be used.                               |  |  |  |
|        | 011                                                                                                                                        | This bit combination is reserved and should not be used.                               |  |  |  |
|        | 100                                                                                                                                        | Enable parity generation and checking with even parity.                                |  |  |  |
|        | 101                                                                                                                                        | Enable parity generation and checking with odd parity.                                 |  |  |  |
|        | Enable parity generation and checking with space (always zero) parity.                                                                     |                                                                                        |  |  |  |
|        | 111                                                                                                                                        | Enable parity generation and checking with mark (always one) parity.                   |  |  |  |
| 4      | 0                                                                                                                                          | Normal asynchronous data encoding.                                                     |  |  |  |
|        | 1                                                                                                                                          | Enable RZI coding (3/16 bit cell IrDA-compliant).                                      |  |  |  |
| 3      | 0                                                                                                                                          | Normal break operation. This option should be selected when address bits are expected. |  |  |  |
|        | Fast break termination. At the end of break, a dummy character is buffer, and the receiver can start character assembly after one bit to   |                                                                                        |  |  |  |
| 2      | 0                                                                                                                                          | Asynchronous clock is 16× data rate.                                                   |  |  |  |
|        | 1                                                                                                                                          | Asynchronous clock is 8× data rate.                                                    |  |  |  |
| 1      | 0                                                                                                                                          | Continue character assembly during break to allow timing the break condition.          |  |  |  |
|        | Inhibit character assembly during break. One character (all zeros, with framing error) at start and one character (garbage) at completion. |                                                                                        |  |  |  |
| 0      |                                                                                                                                            | This bit is ignored in the asynchronous mode.                                          |  |  |  |

| Ser    |       | Extended Register (SEER) (Address = 0x00CD)  Mode Only) (SFER) (Address = 0x00DD)                                         |  |  |  |
|--------|-------|---------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit(s) | Value | Description                                                                                                               |  |  |  |
| 7:5    | 000   | NRZ data encoding for HDLC receiver and transmitter.                                                                      |  |  |  |
|        | 010   | NRZI data encoding for HDLC receiver and transmitter.                                                                     |  |  |  |
|        | 100   | Biphase-level (Manchester) data encoding for HDLC receiver and transmitter.                                               |  |  |  |
|        | 110   | Biphase-space data encoding for HDLC receiver and transmitter.                                                            |  |  |  |
|        | 111   | Biphase-mark data encoding for HDLC receiver and transmitter.                                                             |  |  |  |
| 4      | 0     | Normal HDLC data encoding.                                                                                                |  |  |  |
|        | 1     | Enable RZI coding (1/4 bit cell IrDA-compliant). This mode can only be used with an internal clock and NRZ data encoding. |  |  |  |
| 3      | 0     | Idle line condition is flags.                                                                                             |  |  |  |
|        | 1     | Idle line condition is all ones.                                                                                          |  |  |  |
| 2      | 0     | Transmit flag on underrun.                                                                                                |  |  |  |
|        | 1     | Transmit abort on underrun.                                                                                               |  |  |  |
| 1      | 0     | Separate HDLC external receive and transmit clocks.                                                                       |  |  |  |
|        | 1     | Combined HDLC external and transmit clock, from transmit clock pin.                                                       |  |  |  |
| 0      |       | This bit is ignored in HDLC mode.                                                                                         |  |  |  |

| Serial Port x Divider Low Register |       | (SEDLR)<br>(SFDLR)                                                                                                                                            | (Address = 0x00CE)<br>(Address = 0x00DE) |  |  |
|------------------------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|--|--|
| Bit(s)                             | Value |                                                                                                                                                               | Description                              |  |  |
| 7:0                                |       | Eight LSBs of the divider that generates the serial clock for this channel. This divider is not used unless the MSB of the corresponding SxDHR is set to one. |                                          |  |  |

| Serial Port x Divider High Register |       |                                                                                                                                                                    | (SEDHR)<br>(SFDHR) | (Address = 0x00CF)<br>(Address = 0x00DF) |  |
|-------------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|------------------------------------------|--|
| Bit(s)                              | Value | Description                                                                                                                                                        |                    |                                          |  |
| 7                                   | 0     | Disable the serial port divider and use the output of Timer A to clock the serial port.                                                                            |                    |                                          |  |
|                                     | 1     | Enable the serial port divider, and use its output to clock the serial port. The serial port divider counts modulo $n + 1$ and is clocked by the peripheral clock. |                    |                                          |  |
| 6:0                                 |       | Seven MSBs of the divider that generates the serial clock for this channel.                                                                                        |                    |                                          |  |

# 19. SLAVE PORT

#### 19.1 Overview

The slave port is a parallel communication port that can be used to communicate with an external master device. The slave port consists of three data input and data output registers, and a status register.

The data input registers are written by the master (the external device) and are read by the processor. The data output registers are written by the processor and are read by the master. Note that the data registers are named from the point of view of the processor. The slave device can only read the data input registers and write to the data output registers. Similarly, the master device can only read the data input registers and write the data output registers. Both devices can read and write to the status register.

The status register contains the interrupt status bits and a status flag corresponding to each data input or data output register to indicate the empty or full status of the data register. Data registers are marked full when written by the source side of the interface, and are marked empty when read by the destination side of the interface.

The hardware interface to the external master consists of an 8-bit bidirectional data bus with a read strobe, write strobe, and chip select. There are two address lines that select one of the three data registers or the status register.

| Slave Port Address | Slave Port Register |
|--------------------|---------------------|
| 00                 | Data Register 0     |
| 01                 | Data Register 1     |
| 10                 | Data Register 2     |
| 11                 | Status Register     |

Table 19-1. Slave Port Addresses

A slave attention signal is asserted when the processor writes to one of the slave port data registers (SPD0R), and can be deasserted by the master by performing a dummy write to the status register. This signal can be used to interrupt the master to indicate that the master needs to read data from the slave.

The slave port interrupt is asserted when the master writes to SPD0R. The processor clears this interrupt condition by writing to the status register.

The slave port can be used to bootstrap the processor by setting the SMODE pins appropriately. See Chapter 3 for more information on this mode.

# 19.1.1 Block Diagram



# 19.1.2 Registers

| Register Name               | Mnemonic | I/O Address | R/W | Reset    |
|-----------------------------|----------|-------------|-----|----------|
| Slave Port Data 0 Register  | SPD0R    | 0x0020      | R/W | xxxxxxx  |
| Slave Port Data 1 Register  | SPD1R    | 0x0021      | R/W | xxxxxxx  |
| Slave Port Data 2 Register  | SPD2R    | 0x0022      | R/W | xxxxxxx  |
| Slave Port Status Register  | SPSR     | 0x0023      | R   | 00000000 |
| Slave Port Control Register | SPCR     | 0x0024      | R/W | 0xx00000 |

## 19.2 Dependencies

#### 19.2.1 I/O Pins

When the slave port is enabled by writing to SPCR, the following pins are enabled for slave port mode. Note that enabling the slave port mode will override any general-purpose I/O or external I/O bus settings for these pins; when the slave port is enabled they will perform slave port functionality.

Table 19-2. Slave Port Pin Functionality

| Pin(s)  | Slave Port<br>Signal | Direction     | Functionality                    |
|---------|----------------------|---------------|----------------------------------|
| PA0-PA7 | SD0–SD7              | Bidirectional | Slave data bus                   |
| PB7     | /SLVATTN             | Output        | Slave interrupt request (output) |
| PB6     | /SCS                 | Input         | Slave chip select                |
| PB4–PB5 | SA0-SA1              | Input         | Slave address bus                |
| PB3     | /SRD                 | Input         | Slave port read strobe           |
| PB2     | /SWR                 | Input         | Slave port write strobe          |
| PE7     | /SCS                 | Input         | Alternate slave chip select      |

#### 19.2.2 Clocks

All slave port operations are based on the processor clock.

### 19.2.3 Interrupts

If slave port interrupts are enabled, a slave port interrupt will occur on the slave device whenever the master writes to SPD0R. The /SLVATTN pin is asserted whenever the slave device writes to SPD0R. Either if these conditions is cleared when either the master or slave reads or writes any of the slave port registers.

The slave port interrupt vector is in the IIR at offset 0x080. It can be set as Priority 1, 2, or 3 by writing to SPCR.

## 19.3 Operation

Figure 19-1 shows a typical slave port connection between a Rabbit processor as the master and two slaves.



Figure 19-1. Master/Slave Port Connections

These connections are summarized in Table 19-3.

Table 19-3. Typical Slave Port Connections

| Master                                  |       | Slave #1 |         | Slave #2 |         |
|-----------------------------------------|-------|----------|---------|----------|---------|
| Data Bus                                | D0-D7 | SD0-SD7  | PA0-PA7 | SD0-SD7  | PA0-PA7 |
| Address Bus                             | A0-A1 | SA0-SA1  | PB4–PB5 | SA0-SA1  | PB4–PB5 |
| I/O Read Strobe                         | /IORD | /SRD     | PB3     | /SRD     | PB3     |
| I/O Write Strobe                        | /IOWR | /SWR     | PB2     | /SWR     | PB2     |
| Slave #1 Chip Select<br>(I/O strobe I6) | PD6   | /SCS     | PB6     | _        | _       |
| Slave #2 Chip Select<br>(I/O strobe I7) | PD7   | _        | _       | /SCS     | PB6     |
| External Interrupt 0 (from Slave #1)    | PE0   | /SLVATTN | PB7     | _        | _       |
| External Interrupt 1 (from Slave #2)    | PE1   | _        | _       | /SLVATTN | PB7     |

Note that the slave port on the master Rabbit processor is *not* used; the master uses the data bus to send and receive data to the slave port data registers on the slave devices.

In this setup, pins PD6 and PD7 are set up as I/O strobe chip selects for the two slave devices, and PE0 and PE1 are used as external interrupt inputs to monitor the /SLVATTN signals from the slaves.

In this setup, the slave port is used as follows:

- The slave responds to the interrupt and reads the slave port data registers.
- When the slave wishes to send data to the master, it writes the slave port data registers, writing SPD0R last, which enables the /SLVATTN signal.
- When the master detects the change on /SLVATTN, it reads the slave port data registers.

#### 19.3.1 Master Setup

- 1. Enable the I/O strobes on PD6 and PD7 by writing to the appropriate Parallel Port D pin and external I/O registers.
- 2. Enable the external interrupts on PE0 and PE1 by writing to the appropriate external interrupt registers.

#### 19.3.2 Slave Setup

- 1. Write the vector to the interrupt service routine to the internal interrupt table.
- 2. Configure SPCR to select the interrupt priority (note that interrupts will be enabled once this value is set).

#### 19.3.3 Master/Slave Communication

- 1. The master writes data to the appropriate external I/O address on the data bus for the slave device and register desired. For example, in the setup described here, the master would write to register SPD2R on the first slave by writing to the address 0xC002 (0xC000 for the I6 strobe, and 0x0002 for SPD2R on that slave).
- 2. If the master is writing multiple bytes, it should write to SPD0R last since that will trigger an interrupt on the slave device. If only one byte is being sent, it should be written to SPD0R.
- 3. The slave responds to the interrupt, reading the data from the slave port data registers.

#### 19.3.4 Slave/Master Communication

- 1. The slave writes data to the appropriate slave port data register. If it is writing multiple bytes, SPD0R should be written last, which enables the /SLVATTN line.
- 2. The master receives an external interrupt from the /SLVATTN line, and reads the data out of the slave port data registers via external I/O reads on the data bus.

## 19.3.5 Handling Interrupts

The interrupt request on the slave is cleared by either the master or the slave accessing one of the slave port registers. To clear the interrupt without affecting the register values, a dummy write can be made to SPSR.

### 19.3.6 Example ISR

A sample interrupt handler is shown below.

```
slave_isr::
                       ; save used registers
  push af
   ; read the data sent by the master
   ioi ld a, (SPD2R)
  ld (to slv d2), a
   ioi ld a, (SPD1R)
   ld (to slv d1), a
   ioi ld a, (SPDOR)
   ld (to slv d0), a
   ; if a response is required, perform it here
   ld a, (to mas d2)
   ioi ld (SPD2R), a
   ld a, (to mas d1)
   ioi ld (SPD1R), a
   ld a, (to mas d0)
   ioi ld (SPDOR), a
                     ; this write asserts /SLVATTN
   ; the interrupt request is cleared by any read/write of the registers
                       ; restore used registers
  pop af
   ipres
   ret
```

## 19.3.7 Other Configurations

There are other slave port configurations possible:

- The master could use the external I/O bus instead of the memory bus.
- All devices could poll the slave port status register to determine when data is present instead of relying on interrupts.
- The master could write to SPD0R, triggering an interrupt on the slave. The slave could then simply write a response into SPD0R, which the master detects by polling SPSR. This configuration is useful when fewer signals are desired, or the master device has no external interrupts available.

If polling is to be used, it is important to note that not all bits in the status register may be updated at once; it is possible to read a transitional value as the register updates. To guarantee a proper polling read, the status register should be read twice; when the same value is read both times the value is correct.

Similarly, it is possible to receive a scrambled value from a data register if it is read while being written. The protocol used should take account of this and prevent it from occurring (the protocol described above guarantees this will not occur).

## 19.3.8 Timing Diagrams

Figure 19-2 shows the sequence of events when the master reads/writes the slave port registers.



Figure 19-2. Slave Port R/W Timing Diagram

The following table explains the parameters used in Figure 19-2.

| Symbol         | Parameter                        | Minimum<br>(ns) | Maximum<br>(ns) |
|----------------|----------------------------------|-----------------|-----------------|
| Tsu(SCS)       | /SCS Setup Time                  | 5               | _               |
| Th(SCS)        | /SCS Hold Time                   | 0               | _               |
| Tsu(SA)        | SA Setup Time                    | 5               | _               |
| Th(SA)         | SA Hold Time                     | 0               | _               |
| Tw(SRD)        | /SRD Low Pulse Width             | 40              | _               |
| Ten(SRD)       | /SRD to SD Enable Time           | 0               | _               |
| Ta(SRD)        | /SRD to SD Access Time           | <del></del>     | 30              |
| Tdis(SRD)      | /SRD to SD Disable Time          | _               | 15              |
| Tsu(SRW – SRD) | /SWR High to /SRD Low Setup Time | 40              | _               |
| Tw(SWR)        | /SWR Low Pulse Width             | 40              | _               |
| Tsu(SD)        | SD Setup Time                    | 10              | _               |
| Th(SD)         | SD Hold Time                     | 5               | _               |
| Tsu(SRD – SWR) | /SRD High to /SWR Low Setup Time | 40              | _               |

# 19.4 Register Descriptions

| Slave Port Data x Registers |       | (SPD0R)<br>(SPD1R)<br>(SPD2R)                        | (Address = 0x0020)<br>(Address = 0x0021)<br>(Address = 0x0022) |  |
|-----------------------------|-------|------------------------------------------------------|----------------------------------------------------------------|--|
| Bit(s)                      | Value | Description                                          |                                                                |  |
| 7:0                         | Read  | The corresponding byte of the slave port is read.    |                                                                |  |
|                             | Write | The corresponding byte of the slave port is written. |                                                                |  |

| Slave Port Status Register |       |                                                                     | (SPSR)                                                            | (Address = 0x0023) |  |
|----------------------------|-------|---------------------------------------------------------------------|-------------------------------------------------------------------|--------------------|--|
| Bit(s)                     | Value | Description                                                         |                                                                   |                    |  |
| 7                          | 0     | Processor wrote to SPSR.                                            |                                                                   |                    |  |
|                            | 1     | Master wrote to Data Register 0.                                    |                                                                   |                    |  |
| 6                          | 0     | Slave port read byte 2 is empty.                                    |                                                                   |                    |  |
|                            | 1     | Slave port read byte 2 is fu                                        | 11.                                                               |                    |  |
| 5                          | 0     | Slave port read byte 1 is en                                        | Slave port read byte 1 is empty.  Slave port read byte 1 is full. |                    |  |
|                            | 1     | Slave port read byte 1 is fu                                        |                                                                   |                    |  |
| 4                          | 0     | Slave port read byte 0 is en                                        | npty.                                                             |                    |  |
|                            | 1     | Slave port read byte 0 is fu                                        | 11.                                                               |                    |  |
| 3                          | 0     | Master wrote to SPSR.                                               | Master wrote to SPSR.                                             |                    |  |
|                            | 1     | Processor wrote to SPD0R                                            |                                                                   |                    |  |
| 2                          | 0     | Slave port write byte 2 is empty.  Slave port write byte 2 is full. |                                                                   |                    |  |
|                            | 1     |                                                                     |                                                                   |                    |  |
| 1                          | 0     | Slave port write byte 1 is e                                        | mpty.                                                             |                    |  |
|                            | 1     | Slave port write byte 1 is for                                      | ıll.                                                              |                    |  |
| 0                          | 0     | Slave port write byte 0 is e                                        | mpty.                                                             |                    |  |
|                            | 1     | Slave port write byte 0 is fi                                       | ıll.                                                              |                    |  |

| s      | lave Port ( | Control Register (S                                                                                                         | PCR)              | (Address = 0x0024) |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------|-------------------|--------------------|
| Bit(s) | Value       | Description                                                                                                                 |                   |                    |
| 7      | 0           | Program fetch as a function of the SMODE pins.                                                                              |                   |                    |
|        | 1           | Ignore the SMODE pins program f                                                                                             | etch function.    |                    |
| 6:5    | Read        | These bits report the state of the SM                                                                                       | MODE pins.        |                    |
|        | Write       | These bits are ignored and should be                                                                                        | e written with a  | zero.              |
| 4:2    | 000         | Disable the slave port. Parallel Por                                                                                        | t A is a byte-wid | de input port.     |
|        | 001         | Disable the slave port. Parallel Port A is a byte-wide output port.                                                         |                   |                    |
|        | 010         | Enable the slave port, with /SCS from Parallel Port E bit 7.                                                                |                   |                    |
|        | 011         | Enable the external I/O bus. Parallel Port A is used for the data bus and Parallel Port B[7:2] is used for the address bus. |                   |                    |
|        | 100         | This bit combination is reserved and should not be used.                                                                    |                   |                    |
|        | 101         | This bit combination is reserved and should not be used.                                                                    |                   |                    |
|        | 110         | Enable the slave port, with /SCS from Parallel Port B bit 6.                                                                |                   |                    |
|        | 111         | Enable the external I/O bus. Parallel Port A is used for the data bus and Parallel Port B[7:0] is used for the address bus. |                   |                    |
| 1:0    | 00          | Slave port interrupts are disabled.                                                                                         |                   |                    |
|        | 01          | Slave port interrupts use Interrupt Priority 1.                                                                             |                   |                    |
|        | 10          | Slave port interrupts use Interrupt Priority 2.                                                                             |                   |                    |
|        | 11          | Slave port interrupts use Interrupt Priority 3.                                                                             |                   |                    |

# 20. ANALOG COMPONENTS

### 20.1 Overview

The Rabbit 5000 has a 10-bit single-channel A/D converter, a 10-bit two-channel differential-input A/D converter, and a 10-bit two-channel differential-output D/A converter for 802.11 Wi-Fi operation. These analog features are available for customer use when Wi-Fi is not being used. Table 20-1 summarizes the analog features.

Table 20-1. Analog Components

| Component<br>Number | Function         | Sampling Rate                        | Description                                                 | Pin(s)                             |
|---------------------|------------------|--------------------------------------|-------------------------------------------------------------|------------------------------------|
| 0                   | A/D<br>Converter | 10 kilosamples/s to 50 megasamples/s | 2 channels, 10-bit,<br>differential<br>Continuous Operation | VINIP + VININ<br>VINQP + VINQN     |
| 1                   | D/A<br>Converter | Up to 44 megasamples/s               | 2 channels, 10-bit,<br>differential<br>Continuous Operation | VOUTPI + VOUTNI<br>VOUTPQ + VOUTNQ |
| 2                   | A/D<br>Converter | Up to 0.3 megasamples/s              | 1 channel, 10-bit,<br>single-ended<br>Convert on Signal     | VIN8                               |

The actual conversion rates depend on the clock sources used — each analog component can accept a clock from an external I/O pin or divide the peripheral clock by a value between 2 and 256.

Table 20-2 lists the detailed features for each analog component.

Table 20-2. Analog Component Specifications

| Analog Component       | Feature                                                | Specification                                                |
|------------------------|--------------------------------------------------------|--------------------------------------------------------------|
|                        | Resolution                                             | 10 bits                                                      |
|                        | Input Range                                            | 2 Vpp (differential)                                         |
|                        | Operating Current Active Standby Power down            | 56 mA @ 1.8V, 20 mA @ 3.3V<br>2.5 mA @ 1.8 V<br>1 mA @ 1.8 V |
| 0 (fast A/D converter) | Transition Time Standby to active Power down to active | 4 μs<br>1 ms                                                 |
| o (last A/D converter) | Nonlinearity Differential (DNL) Integral (INL)         | ±0.5 LSB typ.<br>±1 LSB typ.                                 |
|                        | Offset Error I to Q Offset Mismatch                    | ±2% of full scale<br>±1% of full scale                       |
|                        | Gain Error I to Q Gain Mismatch                        | ±5% of full scale<br>±1% of full scale                       |
|                        | Channel Isolation                                      | 60 dB typ.                                                   |
|                        | Resolution                                             | 10 bits                                                      |
|                        | Input Range                                            | 2 Vpp (differential)                                         |
|                        | Allowed Common-Mode Voltage                            | 0.9 V to 1.4 V                                               |
|                        | Operating Current Active Standby Power down            | 22 mA @ 3.3 V<br>< 1 mA @ 3.3 V<br>< 1 μA @ 1.8 V            |
| 1 (fast D/A converter) | Transition Time Standby to active Power down to active | 2 μs<br>6 μs                                                 |
|                        | Offset Error I to Q Offset Mismatch                    | ±2% of full scale<br>±1% of full scale                       |
|                        | Gain Error I to Q Gain Mismatch                        | ±5% of full scale<br>±1% of full scale                       |
|                        | Channel Isolation                                      | 60 dB typ.                                                   |

Table 20-2. Analog Component Specifications (continued)

| Analog Component       | Feature                                        | Specification                                         |
|------------------------|------------------------------------------------|-------------------------------------------------------|
|                        | Resolution                                     | 10 bits                                               |
|                        | Input Range                                    | 0 V to 3.3 V                                          |
|                        | Operating Current Active Standby               | 35 μA @ 1.8 V, 62 μA @ 3.3 V<br>< 1 μA @ 1.8 V, 3.3 V |
| 2 (slow A/D converter) | Transition Time Standby to active              | 15 μs                                                 |
|                        | Nonlinearity Differential (DNL) Integral (INL) | ±1 LSB typ.<br>±2 LSB max.                            |
|                        | Offset Error                                   | -1.5 to +2.5 LSB                                      |
|                        | Gain Error                                     | ±2 LSB max                                            |

# 20.2 Block Diagram



## 20.2.1 Registers

| Register Name                       | Mnemonic | I/O Address | R/W | Reset    |
|-------------------------------------|----------|-------------|-----|----------|
| Analog Component 0 I LSB Register   | A0ILR    | 0x0800      | R/W | xxxxxxx  |
| Analog Component 0 I MSB Register   | A0IMR    | 0x0801      | R/W | xxxxxxx  |
| Analog Component 0 Q LSB Register   | A0QLR    | 0x0802      | R/W | xxxxxxx  |
| Analog Component 0 Q MSB Register   | A0QMR    | 0x0803      | R/W | xxxxxxx  |
| Analog Component 0 Control Register | A0CR     | 0x0804      | R/W | 00000000 |
| Analog Component 1 I LSB Register   | A1ILR    | 0x0810      | R/W | xxxxxxx  |
| Analog Component 1 I MSB Register   | A1IMR    | 0x0811      | R/W | xxxxxxxx |
| Analog Component 1 Q LSB Register   | A1QLR    | 0x0812      | R/W | xxxxxxx  |
| Analog Component 1 Q MSB Register   | A1QMR    | 0x0813      | R/W | xxxxxxx  |
| Analog Component 1 Control Register | A1CR     | 0x0814      | R/W | 00000000 |
| Analog Component 2 LSB Register     | A2LR     | 0x0820      | R/W | xxxxxxx  |
| Analog Component 2 MSB Register     | A2MR     | 0x0821      | R/W | xxxxxxx  |
| Analog Component 2 Control Register | A2CR     | 0x0824      | R/W | 00000000 |

# 20.3 Dependencies

### 20.3.1 I/O Pins

The fast A/D converter accepts differential input on the pin pairs VININ/VINIP and VINQN/VINQP. The VREFP, VREFN, ADVCM, and ADVBG pins should be connected as shown in the sample circuit diagrams. The IBIAS pin should remain unconnected.

The fast D/A converter provides differential output on the pin pairs VOUTNI/VOUTPI and VOUTNQ/VOUTPQ. The DAVCM pin should be used to provide the common-mode voltage, which can range from 0.9 V to 1.4 V; see the sample circuit diagram for an example. DAVBG should be connected as shown in the sample circuit diagram.

The slow ADC accepts a single input on the VIN8 pin.

The PD4, PD5, and PD6 pins can be used instead of the peripheral clock as clock inputs for analog component 0, 1, or 2 respectively.

### 20.3.2 Clocks

Each of the analog components can be clocked by the peripheral clock divided by 2, 4, 8, 16, 32, 64, 128, or 256, or by a clock input on PD4, PD5, or PD6, depending on the component. Exercise care when selecting the clock to keep the data rate below the maximum sample rate of the component you are configuring.

# 20.4 Operation

### 20.4.1 Fast A/D Converter

The following steps must be taken to operate the fast A/D converter.

- 1. Select the clock source and enable the fast A/D converter by writing to A0CR.
- 2. Read the channel data in the A0IxR and A0QxR registers. Reading the least-significant bit registers first will lock the value in the most-significant bit register until it is read.
- 3. For faster update, an 8-bit value can be obtained by only reading the most-significant bit registers (A0IMR or A0QMR).
- 4. To reduce power consumption, the fast A/D converter can be put into a standby or sleep mode by writing to A0CR.

### 20.4.2 Fast D/A Converter

The following steps must be taken to operate the fast D/A converter.

- 1. Select the clock source and enable the fast D/A converter by writing to A1CR.
- 2. Write the channel data to the A1IxR and A1QxR registers. Writing the least-significant bit registers first will hold the conversion output until the most-significant bit register is written.
- 3. For faster update, an 8-bit value can be output by only writing the most-significant bit registers (A1IMR or A1QMR).
- 4. To reduce power consumption, the fast D/A converter can be put into a standby or power-down mode by writing to A1CR.

### 20.4.3 Slow A/D Converter

The following steps must be taken to operate the slow A/D converter.

- 1. Select the clock source and enable the slow A/D converter by writing to A2CR.
- 2. Start a conversion by writing to bit 2 of A2CR.
- 3. Monitor bit 3 of A2CR to determine when the conversion is complete, then read the data in the A2LR and A2MR registers. Reading the least-significant bit registers first will lock the value in the most-significant bit register until it is read.
- 4. For faster update, an 8-bit value can be obtained by only reading A2MR.
- 5. To reduce power consumption, the slow A/D converter can be put into a sleep mode by writing to A2CR.

# 20.5 Sample Circuits

Sample circuits are shown below for the analog components. Since each analog component has dedicated power and ground, be sure to allow enough filtering for each block as shown — a range of ferrite beads may be used — we obtained good results with ferrite beads rated at  $120 \Omega$  at 100 MHz.



Figure 20-1. Sample Fast A/D Converter Circuit



Figure 20-2. Sample Fast D/A Converter Circuit



Figure 20-3. Sample Slow A/D Converter Circuit

# 20.6 Register Descriptions

|        | •     | ent 0 I LSB Register<br>ent 0 Q LSB Register | (A0ILR)<br>(A0QLR)      | (Address = 0x0800)<br>(Address = 0x0802)                            |
|--------|-------|----------------------------------------------|-------------------------|---------------------------------------------------------------------|
| Bit(s) | Value |                                              | Description             |                                                                     |
| 7:6    | Read  |                                              | ster locks the value in | its of the fast A/D converter are in the corresponding MSB register |
|        | Write | Writes to these bits are igr                 | ored.                   |                                                                     |
| 5:0    |       | These bits are ignored and                   | will always return ze   | eros when read.                                                     |

| Analog Component 0 I MSB Register Analog Component 0 Q MSB Register |       | (A0IMR)<br>(A0QMR)                                                                           | (Address = 0x0801)<br>(Address = 0x0803) |  |  |  |
|---------------------------------------------------------------------|-------|----------------------------------------------------------------------------------------------|------------------------------------------|--|--|--|
| Bit(s)                                                              | Value | Description                                                                                  |                                          |  |  |  |
| 7:0                                                                 | Read  | The current value of the eight most-significant bits of the fast A/D converter are returned. |                                          |  |  |  |
|                                                                     | Write | Writes to this register are i                                                                | gnored.                                  |  |  |  |

| Analog | Compone | ent 0 Control Register (A0CR) (Address = 0x0804)          |  |  |  |  |
|--------|---------|-----------------------------------------------------------|--|--|--|--|
| Bit(s) | Value   | Description                                               |  |  |  |  |
| 7      | 0       | Use peripheral clock as fast A/D converter clock source.  |  |  |  |  |
|        | 1       | Use Parallel Port PD4 as fast A/D converter clock source. |  |  |  |  |
| 6:4    | 000     | Clock divided by 2.                                       |  |  |  |  |
|        | 001     | Clock divided by 4.                                       |  |  |  |  |
|        | 010     | Clock divided by 8.                                       |  |  |  |  |
|        | 011     | Clock divided by 16.                                      |  |  |  |  |
|        | 100     | Clock divided by 32.                                      |  |  |  |  |
|        | 101     | Clock divided by 64.                                      |  |  |  |  |
|        | 110     | Clock divided by 128.                                     |  |  |  |  |
|        | 111     | Clock divided by 256.                                     |  |  |  |  |
| 3      | 0       | Disable fast A/D converter Q channel.                     |  |  |  |  |
|        | 1       | Enable fast A/D converter Q channel.                      |  |  |  |  |
| 2      | 0       | Disable fast A/D converter I channel.                     |  |  |  |  |
|        | 1       | Enable fast A/D converter I channel.                      |  |  |  |  |
| 1:0    | 00      | Fast A/D converter powered down.                          |  |  |  |  |
|        | 01      | Fast A/D converter in sleep mode.                         |  |  |  |  |
|        | 10      | Fast A/D converter active, outputting unsigned binary.    |  |  |  |  |
|        | 11      | Fast A/D converter active, outputting two's complement.   |  |  |  |  |

|        |       | nent 1 I LSB Register<br>ent 1 Q LSB Register                                                                                                                                                                                    | (A1ILR)<br>(A1QLR)    | (Address = 0x0810)<br>(Address = 0x0812) |  |  |
|--------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|------------------------------------------|--|--|
| Bit(s) | Value | Description                                                                                                                                                                                                                      |                       |                                          |  |  |
| 7:6    | Write | The two least-significant bits for the fast D/A converter are stored. These bits will not be transferred to the fast D/A converter until the corresponding MSB register is written to guarantee that the full 10 bits are valid. |                       |                                          |  |  |
|        | Read  | These bits always return zeros when read.                                                                                                                                                                                        |                       |                                          |  |  |
| 5:0    |       | These bits are ignored and                                                                                                                                                                                                       | will always return ze | eros when read.                          |  |  |

|        |       | ent 1 I MSB Register<br>ent 1 Q MSB Register                                                                                                      | (A1IMR)<br>(A1QMR) | (Address = 0x0811)<br>(Address = 0x0813) |  |  |
|--------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|------------------------------------------|--|--|
| Bit(s) | Value | Description                                                                                                                                       |                    |                                          |  |  |
| 7:0    | Write | The eight most-significant bits for the fast D/A converter are stored. Writing these bits transfers the entire 10 bits to the fast D/A converter. |                    |                                          |  |  |
|        | Read  | These bits always return zeros when read.                                                                                                         |                    |                                          |  |  |

| Analog | Compone | ent 1 Control Register (A1CR) (Address = 0x0814)                                |  |  |  |  |  |
|--------|---------|---------------------------------------------------------------------------------|--|--|--|--|--|
| Bit(s) | Value   | Description                                                                     |  |  |  |  |  |
| 7      | 0       | Use peripheral clock as fast D/A converter clock source.                        |  |  |  |  |  |
|        | 1       | Use Parallel Port PD5 as fast D/A converter clock source.                       |  |  |  |  |  |
| 6:4    | 000     | Clock divided by 2.                                                             |  |  |  |  |  |
|        | 001     | Clock divided by 4.                                                             |  |  |  |  |  |
|        | 010     | Clock divided by 8.                                                             |  |  |  |  |  |
|        | 011     | Clock divided by 16.                                                            |  |  |  |  |  |
|        | 100     | Clock divided by 32.                                                            |  |  |  |  |  |
|        | 101     | Clock divided by 64.                                                            |  |  |  |  |  |
|        | 110     | Clock divided by 128.                                                           |  |  |  |  |  |
|        | 111     | Clock divided by 256.                                                           |  |  |  |  |  |
| 3      | 0       | Disable fast D/A converter Q channel.                                           |  |  |  |  |  |
|        | 1       | Enable fast D/A converter Q channel.                                            |  |  |  |  |  |
| 2      | 0       | Disable fast D/A converter I channel.                                           |  |  |  |  |  |
|        | 1       | Enable fast D/A converter I channel.                                            |  |  |  |  |  |
| 1      |         | This bit is reserved and should be written with zero.                           |  |  |  |  |  |
| 0      | 0       | Fast D/A converter in normal mode (powered down if both channels are disabled). |  |  |  |  |  |
|        | 1       | Fast D/A converter in sleep mode.                                               |  |  |  |  |  |

| Analo  | og Compon | nent 2 LSB Register         | (A2LR)                  | (Address = 0x0820)                                                    |
|--------|-----------|-----------------------------|-------------------------|-----------------------------------------------------------------------|
| Bit(s) | Value     |                             | Description             | 1                                                                     |
| 7:6    | Read      |                             | ister locks the value i | its of the slow A/D converter are<br>n the corresponding MSB register |
|        | Write     | Writes to this register are | ignored.                |                                                                       |
| 5:0    |           | These bits are ignored and  | l will always return z  | eros when read.                                                       |

| Analo  | Analog Component 2 MSB Register |                                                                                              | (A2MR)      | (Address = 0x0821) |  |  |
|--------|---------------------------------|----------------------------------------------------------------------------------------------|-------------|--------------------|--|--|
| Bit(s) | Value                           |                                                                                              | Description |                    |  |  |
| 7:0    | Read                            | The current value of the eight most-significant bits of the slow A/D converter are returned. |             |                    |  |  |
|        | Write                           | Writes to this register are                                                                  | ignored.    |                    |  |  |

| Analog           | Compone | ent 2 Control Register (A2CR) (Address = 0x0824)                                    |  |  |  |  |
|------------------|---------|-------------------------------------------------------------------------------------|--|--|--|--|
| Bit(s)           | Value   | Description                                                                         |  |  |  |  |
| 7                | 0       | Use peripheral clock as slow A/D converter clock source.                            |  |  |  |  |
|                  | 1       | Use Parallel Port PD6 as slow A/D converter clock source.                           |  |  |  |  |
| 6:4              | 000     | Clock divided by 2.                                                                 |  |  |  |  |
|                  | 001     | Clock divided by 4.                                                                 |  |  |  |  |
|                  | 010     | Clock divided by 8.                                                                 |  |  |  |  |
|                  | 011     | Clock divided by 16.                                                                |  |  |  |  |
|                  | 100     | Clock divided by 32.                                                                |  |  |  |  |
|                  | 101     | Clock divided by 64.                                                                |  |  |  |  |
|                  | 110     | Clock divided by 128.                                                               |  |  |  |  |
|                  | 111     | Clock divided by 256.                                                               |  |  |  |  |
| 3                | 0       | Conversion not complete.                                                            |  |  |  |  |
| (Read-<br>only)  | 1       | Conversion complete.                                                                |  |  |  |  |
| 2                | 0       | No effect on slow A/D converter.                                                    |  |  |  |  |
| (Write-<br>only) | 1       | Start conversion.                                                                   |  |  |  |  |
| 1                |         | These bits are reserved. Reads return zeros.                                        |  |  |  |  |
| 0                | 0       | Slow A/D converter in sleep mode. This bit is ignored if Network Port C is enabled. |  |  |  |  |
|                  | 1       | Slow A/D converter active.                                                          |  |  |  |  |

# 21. DMA CHANNELS

### 21.1 Overview

There are eight independent DMA channels on the Rabbit 5000. All eight channels are identical, and are capable of transferring data to or from memory, external I/O, or internal I/O. The priority between the channels can be either fixed or rotating, and the DMA use of the bus can be limited to guarantee interrupt latency or CPU throughput. The DMA channels are capable of special handling for the last byte of data when sending data to selected internal I/O addresses (such as the HDLC serial ports or to the Ethernet peripheral), and can also transfer end-of-frame status after transferring data from selected internal I/O addresses.

The DMA channels can watch the data being transferred, and can terminate a transfer when a particular byte is matched. A mask is available for the byte match to allow termination only on particular bit settings in the data instead of an exact byte match.

Memory-to-memory transfers proceed at the maximum transfer rate unless they are gated by an external request signal or the internal timed request. Transfers to or from a number of internal I/O addresses are controlled by transfer request signals. These transfer request signals are connected automatically as a function of the internal I/O address loaded into the DMA channel. Note that if both the source and the destination are internal I/O, the source transfer request is used by the DMA channel.

The DMA channels are inherently byte-oriented, so while DMA transfers can be done from a 16-bit memory, DMA transfers to a 16-bit memory can only be done if the 16-bit memory is set up to allow byte writes (see Chapter 5 for more information). For memory to memory transfers, a word transfer will occur if both addresses are aligned, but byte writes must still be enabled on the destination memory. The Ethernet and Wi-Fi peripherals are special cases as well — when the 16-bit bus is enabled and the DMA source or destination address is a network port register, the DMA will attempt to transfer words if the memory address is aligned.

There are two inputs available for requests linked to external I/O devices. These two external requests may be assigned to any DMA channel. These requests may also be used by a channel that has an internal I/O as a destination. In this case, the external request acts as a "flow control" signal for the DMA transfers because the external request is "ANDed" with the automatically connected internal request.

To facilitate periodic DMA transfers, there is also an internal *timed request*. This request is generated from a programmable 16-bit counter and may be assigned to any DMA channel. As in the case of the external requests, this request is "ANDed" with any internal or external request that is also assigned to that DMA channel. This periodic request can be programmed to transfer one byte or an entire buffer. The single-byte option is useful for driving an output port to create a sampled waveform, while the entire-buffer option can be used, for example, to send precisely timed serial messages over a serial port.

The DMA operation is controlled by memory structures called buffer descriptors. The current buffer descriptor resides in the registers of the DMA channel, but may have been either placed there by the processor or loaded directly by the DMA channel itself. Buffer descriptors may be used singly to transfer one block of data, or they may be linked together for "scatter-gather" operation. Each DMA channel also contains an "initial address" that points to the first buffer descriptor in memory and allows the DMA channel to rewind itself automatically in the case of a transmit retry by the network port. Each buffer descriptor contains a pair of control bytes, a byte count for the data, a source address, a destination address, and an optional link address. In addition, each DMA channel retains a count of the number of bytes remaining in the buffer to allow software to determine the amount of valid data in a buffer that are terminated early by the source of the data.

A buffer descriptor in memory consists of either 12 or 16 consecutive bytes organized as shown in Table 21-1. The DMA channel uses the information in the control byte to determine the length of the buffer descriptor as well as which information to fetch from the buffer descriptor. If no link address field is present, the buffer descriptor is only 12 bytes long. A memory address for either source or destination causes the DMA channel to fetch three bytes from the corresponding field in the buffer descriptor. An internal I/O or external I/O address for either source or destination causes the DMA channel to fetch two bytes from the corresponding field in the buffer descriptor.

DMA memory addresses are always physical addresses, and are never translated by the MMU. All DMA memory addresses use the memory control signals, wait states, and flipped bits as selected in the Master Memory Bank Control registers. All DMA external I/O addresses use the I/O control signals and wait states as selected in the external I/O registers.

The first byte in the first buffer descriptor (the byte pointed to by the initial address) is reserved for status information when transferring data from an internal serial or network device. This automatic status transfer means that the processor does not need to service any interrupts from a serial or network receiver except in the case of an error condition.

When transferring data to an internal HDLC serial or Ethernet transmitter, the last byte of the last buffer will be written automatically to a special destination address to tag the data as the last in the frame, without processor intervention. However, this function is not available in the case where the buffer contains only one byte of data. If this case should occur, the buffer descriptor must contain the special destination address.

All the DMA channels request interrupts at the same priority level, which is set by a field in the DMA Master Control Register, but each DMA channel has its own interrupt vector location. This speeds up interrupt processing for the DMA interrupts by eliminating the need to resolve which DMA channel is actually requesting an interrupt.

DMA transfers may be programmed to occur at any priority level. If the programmed level is greater than or equal to the current CPU operating level, DMA transfers will occur on demand. When the CPU operating level is greater than the programmed DMA operating level, no DMA transfers can occur. This allows interrupt services routines, or other critical code, to run with a guarantee that there will be no DMA activity during execution. Note that a simultaneous interrupt request and DMA transfer request will be resolved in favor of the DMA transfer request.

Normally all DMA transfers are flow-through, meaning that the DMA does separate read and write transactions to transfer the data. However, the Rabbit 5000 DMA also contains dedicated buses to support fly-by transactions to and from certain internal I/O addresses. A fly-by transfer looks like a single transaction on the internal and external bus, where data are transferred directly to/from the peripheral from/to a memory device. Only the network ports support fly-by transfers, and the DMA automatically recognizes internal I/O addresses that support fly-by transfers.

# 21.1.1 Block Diagram



# 21.1.2 Registers

| Register Name                              | Mnemonic | I/O Address        | R/W | Reset    |
|--------------------------------------------|----------|--------------------|-----|----------|
| DMA Master Control/Status Register         | DMCSR    | 0x0100             | R/W | 00000000 |
| DMA Master Auto-Load Register              | DMALR    | 0x0101             | W   | 00000000 |
| DMA Master Halt Register                   | DMHR     | 0x0102             | W   | 00000000 |
| DMA y Buffer Complete Register             | DyBCR    | 0x01y3             | R   | 00000000 |
| DMA Master Control Register                | DMCR     | 0x0104             | R/W | 00000000 |
| DMA Master Timing Control Register         | DMTCR    | 0x0105             | R/W | 00000000 |
| DMA Master Request 0 Control Register      | DMR0CR   | 0x0106             | R/W | 00000000 |
| DMA Master Request 1 Control Register      | DMR1CR   | 0x0107             | R/W | 00000000 |
| DMA Timed Request Control Register         | DTRCR    | 0x0115             | R/W | 00000000 |
| DMA Timed Request Divider Low Register     | DTRDLR   | 0x0116             | R/W | xxxxxxxx |
| DMA Timed Request Divider High Register    | DTRDHR   | 0x0117             | R/W | xxxxxxx  |
| DMA y Termination Byte Register            | DyTBR    | 0x01y8             | R/W | xxxxxxxx |
| DMA y Termination Mask Register            | DyTMR    | 0x01y9             | R/W | 00000000 |
| DMA y Buffer Unused [7:0] Register         | DyBU0R   | 0x01yA             | R   | 00000000 |
| DMA y Buffer Unused [15:8] Register        | DyBU1R   | 0x01yB             | R   | 00000000 |
| DMA y Initial Address [7:0] Register       | DyIA0R   | 0x01yC             | R/W | xxxxxxxx |
| DMA y Initial Address [15:8] Register      | DyIA1R   | 0x01yD             | R/W | xxxxxxx  |
| DMA y Initial Address [23:16] Register     | DyIA2R   | 0x01yE             | R/W | xxxxxxxx |
| DMA y Special Control Register             | DySCR    | 0x01z0 (z = y + 8) | R/W | 00000000 |
| DMA y Control Register                     | DyCR     | 0x01z1 (z = y + 8) | R/W | 00000000 |
| DMA y Buffer Length [7:0] Register         | DyL0R    | 0x01z2 (z = y + 8) | R/W | xxxxxxxx |
| DMA y Buffer Length [15:8] Register        | DyL1R    | 0x01z3 (z = y + 8) | R/W | xxxxxxx  |
| DMA y Source Address [7:0] Register        | DySA0R   | 0x01z4 (z = y + 8) | W   | xxxxxxx  |
| DMA y Source Address [15:8] Register       | DySA1R   | 0x01z5 (z = y + 8) | W   | xxxxxxxx |
| DMA y Source Address [23:16] Register      | DySA2R   | 0x01z6 (z = y + 8) | W   | xxxxxxxx |
| DMA y Destination Address [7:0] Register   | DyDA0R   | 0x01z8 (z = y + 8) | W   | xxxxxxxx |
| DMA y Destination Address [15:8] Register  | DyDA1R   | 0x01z9 (z = y + 8) | W   | xxxxxxxx |
| DMA y Destination Address [23:16] Register | DyDA2R   | 0x01zA (z = y + 8) | W   | xxxxxxx  |
| DMA y Link Address [7:0] Register          | DyLA0R   | 0x01zC (z = y + 8) | R/W | xxxxxxxx |
| DMA y Link Address [15:8] Register         | DyLA1R   | 0x01zD (z = y + 8) | R/W | xxxxxxxx |
| DMA y Link Address [23:16] Register        | DyLA2R   | 0x01zE(z=y+8)      | R/W | xxxxxxxx |

**NOTE:** The y in "DMA y ..." expresses the DMA channel number (0–7).

# 21.2 Dependencies

### 21.2.1 I/O Pins

External DMA Request 0 can be enabled from pins PD2, PE2, or PE6. External DMA Request 1 can be enabled from pins PD3, PE3, or PE7.

The DMA can use either the memory management unit or the external I/O bus to perform its transfers, and so will use the appropriate pins for each operation.

### 21.2.2 Clocks

The DMA peripheral uses the peripheral clock for all operations. If the timed request option is enabled, then the 16-bit timed request counter will be clocked by the peripheral clock and will provide a DMA request each time it counts down to zero.

# 21.2.3 Interrupts

Each DMA channel has its own dedicated interrupt that can occur at the end of any DMA transfer, as specified in DyCR (normally loaded from the buffer descriptor). The interrupt request is automatically cleared when the interrupt is handled.

The DMA interrupt vectors are in the EIR starting at offset 0x080 for DMA Channel 0 and ending at offset 0x0F0 for DMA Channel 7. They can be set as Priority 1, 2, or 3.

# 21.3 Operation

It is possible to set up and start a DMA operation by writing directly to all the relevant address, length, and control registers, but it is expected that the typical operation would be to create a buffer descriptor in memory, write the address of that descriptor to the initial address registers (DyIAnR), and use a write to DMALR to auto-load the values from memory into the registers and start the transfer. The DMA transfer will then continue reading buffer descriptors until a buffer-marked halt is completed.

The descriptor can be either 12 or 16 bytes in length; a bit in the channel control byte (which corresponds to DyCR) selects whether the link address is present or not. The processor skips the read of those bytes if a 12-byte descriptor is selected, and always skips the reads of the bytes marked "not used."

Byte 1 Byte 3 Byte 0 Byte 2 Special Channel Bytes 0-3 Control / Channel Control Buffer Length [15:0] Frame Status Bytes 4-7 Source Address [23:0] Not Used Bytes 8-11 Destination Address [23:0] Not Used Bytes 12-15 Link Address [23:0] Not Used

Table 21-1. DMA Buffer Descriptor

It is possible to abort a DMA transfer by writing the appropriate bit to the halt register, DMHR. It is also possible to restart a DMA transfer using the already-loaded register values by writing to DMCSR.

The following steps explain how to set up a DMA channel.

- 1. Select the DMA transfer and interrupt priorities by writing to DMCR.
- 2. Select the DMA channel priority, maximum bytes per burst, and minimum clocks between bursts by writing to DMTCR.
- 3. Write the interrupt vector for the interrupt service routine to the external interrupt table.
- 4. Enable an external request line by writing to DMR0CR or DMR1CR. Make sure that the pin selected is set up as an input. Note that this enable will be logical-ANDed to any internal DMA enables if the DMA transfer is to/from an internal peripheral.
- 5. Enable the internal-timed transfer request by writing to DTRCR. Select the divider value by writing to DTRDLR and DTRDHR. Note that this enable will be logical-ANDed to any internal DMA enables if the DMA transfer is to/from an internal peripheral.
- 6. Select a byte to terminate the transfer on by writing to the appropriate DyTBR and DyTMR registers.

- 7. The desired control, length, and address registers should be written to a buffer descriptor (or descriptors) in memory if not done already. Several automatic options (auto-increment, auto-decrement, special peripheral enables) can be overridden by settings in DySCR.
- 8. The initial address registers (DyIAnR) should be loaded with the physical address of the first buffer descriptor.
- 9. The buffer descriptor can be loaded and the DMA transfer started by writing to the appropriate bit of DMALR.

## 21.3.1 Handling Interrupts

The DMA interrupt request is cleared automatically when the interrupt is handled. A DMA interrupt will occur at the end of a transfer for any buffer descriptor that has bit 4 of DyCR set.

# 21.3.2 Example ISR

A sample interrupt handler is shown below.

```
dma_isr::
    push af

; do something with the data in the current buffer
; the interrupt request is automatically cleared

pop af
ipres
ret
```

# 21.3.3 DMA Priority with the Processor

Since the Rabbit 5000 DMA uses the memory management unit to perform transfers, normal code execution cannot occur while the DMA is active. This includes handling interrupts, so it is important to limit the amount of time that the DMA can operate.

This is handled in several ways. First of all, the DMA transfers can be set to take place whenever the processor is operating at one of the four priority levels, 0–3 (note that there is a single priority level for all DMA transfers).

| DMA Transfers at | Operation                                                        |
|------------------|------------------------------------------------------------------|
| Priority 0       | DMA transfers only allowed when processor priority at 0          |
| Priority 1       | DMA transfers only allowed when processor priority at 0 or 1     |
| Priority 2       | DMA transfers only allowed when processor priority at 0, 1, or 2 |
| Priority 3       | DMA transfers allowed at any time                                |

Table 21-2. DMA Transfer Priority

Setting an interrupt priority to something greater than the DMA transfer priority will ensure that no DMA activity occurs during that interrupt handler. Note that when both an interrupt and a DMA transfer are pending, the DMA transfer will be selected for execution first (provided its priority is equal or greater than the current processor priority level).

When a DMA transfer is occurring, normal code execution will not occur until the transfer is completed. To prevent DMA transfers from excessively blocking interrupts or otherwise interfering with normal code execution, two options can be set in DMTCR. First, the maximum limit of a DMA transfer can be set from 1 to 64 bytes, which sets an upper limit on interrupt latency arising from a DMA transfer. Second, the minimum number of clocks before the DMA can be active again can be set from 12 to 512 clocks, guaranteeing processing time for the application.

The values providing roughly equal access to the memory bus for both the processor and the DMA is eight bytes per burst and 64 clocks between bursts.

When starting up, the DMA requires several cycles of overhead. This overhead comes about because the DMA actually uses part of the processor to perform the data transfers, and consists of one instruction fetch time plus three clock cycles. The byte fetched during the instruction fetch time is discarded, and will be refetched at the completion of the DMA burst. At the end of the DMA burst, two clock cycles are required before this first instruction fetch starts. An individual DMA channel transfers data without any overhead between bytes, but there is always one clock cycle of dead time when switching between DMA channels. Table 21-3 shows the effective number of clock cycles required per burst, assuming a single DMA channel transfer, 8-bit memory, and no wait states. Access via 16-bit memory would provide up to twice the throughput, depending on address alignment.

Table 21-3. Maximum DMA Transfer Rates

| Setting            | Total Clocks | Clocks per Byte<br>Transferred |
|--------------------|--------------|--------------------------------|
| 1 byte per burst   | 11 clocks    | 11                             |
| 2 bytes per burst  | 15 clocks    | 7.5                            |
| 3 bytes per burst  | 19 clocks    | 6.3                            |
| 4 bytes per burst  | 23 clocks    | 5.8                            |
| 8 bytes per burst  | 39 clocks    | 4.9                            |
| 16 bytes per burst | 71 clocks    | 4.4                            |
| 32 bytes per burst | 135 clocks   | 4.2                            |
| 64 bytes per burst | 263 clocks   | 4.1                            |

The total number of clocks listed in Table 21-3 is related to the number of bytes per burst by the following formula.

Total Clocks =  $4 \times$  Number of Bytes per Burst + 7 (for overhead)

## 21.3.4 DMA Channel Priority

It is possible to control the priority between separate DMA channels. There are three channel-priority options in the Rabbit 5000. The first is fixed priority after every byte where the priority of each channel is equal to its number, i.e., if both DMA Channels 3 and 4 have a pending transfer request, DMA Channel 4 will always be enabled first. If at any point a channel with higher priority than the one currently transferring has a DMA request pending, the current transfer will be terminated and the new channel's transfer will start. With this setting, DMA Channel 7 will always have priority over all other channels, and DMA Channel 0 will transfer only if no other channels have pending requests.

The other two settings rotate the priority between channels as shown in Table 21-4; after the seventh rotation, the priority sequence restarts at the top of the table. One option is to rotate priority after every byte analogous to the fixed-priority setting. The priority list is updated after each byte transferred, and if a higher priority channel has a pending request, the current transfer will be terminated and the new channel transfer will start. The other option is to rotate after every burst; this will guarantee that reasonable amounts of data are transferred by each channel before a switchover occurs.

Rotation **Channel Priority, High to Low** Initial (and eighth) 7, 6, 5, 4, 3, 2, 1, 0 First 6, 5, 4, 3, 2, 1, 0, 7 Second 5, 4, 3, 2, 1, 0, 7, 6 Third 4, 3, 2, 1, 0, 7, 6, 5 Fourth 3, 2, 1, 0, 7, 6, 5, 4 Fifth 2, 1, 0, 7, 6, 5, 4, 3 Sixth 1, 0, 7, 6, 5, 4, 3, 2 Seventh 0, 7, 6, 5, 4, 3, 2, 1

Table 21-4. Rotating DMA Channel Priority

### 21.3.5 Buffer Descriptor Modes

Flags in the control byte of a buffer descriptor (which gets loaded into DyCR) describe whether to halt on completion of the transfer (or load another descriptor) and whether the next descriptor is adjacent in memory (which implies that the current descriptor is only 12 bytes long) or located at the link address. Each descriptor can also be set to generate an interrupt on completion of the transfer. By using these options in various ways, the Rabbit 5000 DMA can be operated in a number of conventional DMA modes.

The most common options are described here; others are certainly possible by different use of the available linking methods.

### 21.3.5.1 Single Buffer

In the simplest mode, a single descriptor is set to halt and interrupt on completion.



### 21.3.5.2 Buffer Array

In this mode, an array of 12-byte descriptors is set up adjacent in memory; only the last buffer is set to halt on completion. The last buffer is also typically set to interrupt on completion, but other buffer descriptors in the array can also generate interrupts.



The advantage of the buffer array is that its descriptors require less memory than a full 16-byte descriptor.

The simplest version of the buffer array is a double buffer, which is frequently used to provide a reserve buffer in case the application is slow in handling the first buffer once received (in this case, both buffers are enabled to interrupt on completion).

### 21.3.5.3 Linked List

A linked list is similar to a buffer array, except that 16-byte descriptors are used and the descriptors are not necessarily adjacent in memory. The advantage of this mode is the ability to spread descriptors.



#### 21.3.5.4 Circular Queue

A circular queue is a buffer array or linked list where the final buffer is linked back to the first buffer in the sequence. This method allows for continuous reception of transfers without having to reload the initial address for the DMA buffer descriptor sequence.



The "ping-pong buffer," where there are only two buffers, is the simplest version of a circular queue. The application can operate on one buffer while the other buffer is being loaded.

### 21.3.5.5 Linked Array

The linked array is simply a linked list of buffer arrays, where the last buffer in each array is linked to the first buffer in the next array (which can be located anywhere in memory). This method could be useful where a message is broken down into separate transfers, but entire messages could be scattered/gathered from anywhere in memory.

## 21.3.6 DMA with Peripherals

When the DMA is directed towards an internal I/O address, the DMA transfer request signals will be connected as appropriate for that peripheral. For example, when a DMA transfer is performed to Serial Port D's data register, the transfer request will be enabled whenever the serial port transmit buffer is empty, and will be disabled whenever it is not.

#### 21.3.6.1 DMA with HDLC Serial Ports

The HDLC serial ports receive special handing by the DMA. When the DMA destination is Serial Port E's or Serial Port F's data register (SxDR), the final byte of the transfer will be written to the appropriate last data register (SxLDR) as required to complete an HDLC packet and append the CRC value. In addition, the value in the appropriate status register (SxSR) will be written to the status byte in the buffer descriptor pointed to by the initial address registers (not necessarily the buffer descriptor that is currently being used). These features allow an application to automatically send and receive packets via DMA, only requiring direct handling of a packet when an error occurs.

#### 21.3.6.2 DMA with Ethernet

The Ethernet network peripheral also receives special handing by the DMA. When the DMA destination is the network data register (NBDR), the final byte of the transfer will be written to the last data register (NBLDR) as required to complete an Ethernet packet and append the CRC value. The Ethernet network peripheral also has support for DMA fly-by transfers between the peripheral and external memory.

# 21.3.6.3 DMA with Wi-Fi

The Wi-Fi network peripheral has support for DMA fly-by transfers between the peripheral and external memory. However, the Wi-Fi peripheral has a minimum access time of 75 ns, and typically requires wait states, so fly-by DMA may not be the most efficient access method.

#### 21.3.6.4 DMA with PWM and Timer C

The PWM and Timer C peripherals have special support for DMA — the block access and pointer registers in each of these peripherals provide a means for the DMA to update the settings of these peripherals at some desired rate. This allows complex PWM waveforms to be generated by using the DMA timed request to update the PWM duty cycles at regular intervals.

# 21.4 Register Descriptions

| DMA I            | Master Cor | trol/Status Register (DMCSR) (Address = 0x0100)                                                                                                                                                                                                  |  |  |
|------------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit(s)           | Value      | Description                                                                                                                                                                                                                                      |  |  |
| 7:0              | 0          | No effect on the corresponding DMA channel.                                                                                                                                                                                                      |  |  |
| (Write-<br>only) | 1          | Start (or restart) the corresponding DMA channel using the contents of the DMA channel registers. This command should only be issued after all the DMA channel registers (source, destination, length, and link if applicable) have been loaded. |  |  |
| 7:0              | 0          | The corresponding DMA channel is either disabled or has completed the last buffer descriptor.                                                                                                                                                    |  |  |
| (Read-<br>only)  | 1          | The corresponding DMA channel is enabled and active. These bits are set by the start command and remain set until the completion of the last buffer.                                                                                             |  |  |

| DMA    | A Master A | uto-Load Register                                                                                                                                                                                                             | (DMALR)     | (Address = 0x0101) |
|--------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------------|
| Bit(s) | Value      |                                                                                                                                                                                                                               | Description |                    |
| 7:0    | 0          | No effect on the corresponding DMA channel.                                                                                                                                                                                   |             |                    |
|        | 1          | Start (using auto-load) the corresponding DMA channel, using the buffer descriptor in memory addressed by the channel initial address register. This command should only be issued after the initial address has been loaded. |             |                    |

| Γ      | DMA Master Halt Register |                                                                                                                           | (DMHR)      | (Address = 0x0102) |
|--------|--------------------------|---------------------------------------------------------------------------------------------------------------------------|-------------|--------------------|
| Bit(s) | Value                    |                                                                                                                           | Description |                    |
| 7:0    | 0                        | No effect on the corresponding DMA channel.                                                                               |             |                    |
|        | 1                        | Halt the corresponding DMA channel. The DMA registers retain the current state, and the DMA can be restarted using DMCSR. |             |                    |

| DMA    | A y Buffer ( | Complete Register                                                                                                                                                                                                                                                                                                                               | (D0BCR)<br>(D1BCR)<br>(D2BCR)<br>(D3BCR)<br>(D4BCR)<br>(D5BCR)<br>(D6BCR)<br>(D7BCR) | (Address = 0x0103)<br>(Address = 0x0113)<br>(Address = 0x0123)<br>(Address = 0x0133)<br>(Address = 0x0143)<br>(Address = 0x0153)<br>(Address = 0x0163)<br>(Address = 0x0173) |
|--------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit(s) | Value        | Description                                                                                                                                                                                                                                                                                                                                     |                                                                                      |                                                                                                                                                                              |
| 7:0    | Read         | The DMA increments a counter at the start of the next buffer. This count is latched in this register and can be used, along with the <i>buffer unused</i> count, to determine the actual amount of data transferred by the DMA. This counter is initialized by a start command or when the DMA is automatically rewound to the initial address. |                                                                                      |                                                                                                                                                                              |
|        | Write        | Writing to this register loads the counter. This feature is intended only for testing, because the DMA automatically resets the counter to all ones when fetching from the initial address. The counter is incremented whenever the DMA fetches a new buffer length value from a descriptor.                                                    |                                                                                      |                                                                                                                                                                              |

| DN     | <b>MA Master</b> | Control Register (DMCR) (Address = 0x0104)                                               |  |  |
|--------|------------------|------------------------------------------------------------------------------------------|--|--|
| Bit(s) | Value            | Description                                                                              |  |  |
| 7:4    |                  | These bits are reserved and should be written with zeros.                                |  |  |
| 3:2    | 00               | DMA transfers at Priority 0. No DMA transfers while CPU operates at Priority 3, 2, or 1. |  |  |
|        | 01               | DMA transfers at Priority 1. No DMA transfers while CPU operates at Priority 3 or 2.     |  |  |
|        | 10               | DMA transfers at Priority 2. No DMA transfers while CPU operates at Priority 3.          |  |  |
|        | 11               | DMA transfers at Priority 3. DMA transfers at any time.                                  |  |  |
| 1:0    | 00               | DMA interrupts are disabled.                                                             |  |  |
|        | 01               | DMA interrupts use Interrupt Priority 1.                                                 |  |  |
|        | 10               | DMA interrupts use Interrupt Priority 2.                                                 |  |  |
|        | 11               | DMA interrupts use Interrupt Priority 3.                                                 |  |  |

| DMA I  | DMA Master Timing Control Register (DMTCR) (Address = 0x010 |                                                                                                                                                |  |  |  |
|--------|-------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit(s) | Value                                                       | Description                                                                                                                                    |  |  |  |
| 7:6    | 0x                                                          | Fixed DMA channel priority. Higher channel number has higher priority.                                                                         |  |  |  |
|        | 10                                                          | Rotating DMA channel priority. Priority rotates highest channel number to lowest channel number after every byte is transferred.               |  |  |  |
|        | 11                                                          | Rotating DMA channel priority. Priority rotates highest channel number to lowest channel number after the current channel request is serviced. |  |  |  |
| 5:3    | 000                                                         | Maximum one byte per burst.                                                                                                                    |  |  |  |
|        | 001                                                         | Maximum two bytes per burst.                                                                                                                   |  |  |  |
|        | 010                                                         | Maximum three bytes per burst.                                                                                                                 |  |  |  |
|        | 011                                                         | Maximum four bytes per burst.                                                                                                                  |  |  |  |
|        | 100                                                         | Maximum eight bytes per burst.                                                                                                                 |  |  |  |
|        | 101                                                         | Maximum 16 bytes per burst.                                                                                                                    |  |  |  |
|        | 110                                                         | Maximum 32 bytes per burst.                                                                                                                    |  |  |  |
|        | 111                                                         | Maximum 64 bytes per burst.                                                                                                                    |  |  |  |
| 2:0    | 000                                                         | Minimum 12 clocks between bursts.                                                                                                              |  |  |  |
|        | 001                                                         | Minimum 16 clocks between bursts.                                                                                                              |  |  |  |
|        | 010                                                         | Minimum 24 clocks between bursts.                                                                                                              |  |  |  |
|        | 011                                                         | Minimum 32 clocks between bursts.                                                                                                              |  |  |  |
|        | 100                                                         | Minimum 64 clocks between bursts.                                                                                                              |  |  |  |
|        | 101                                                         | Minimum 128 clocks between bursts.                                                                                                             |  |  |  |
|        | 110                                                         | Minimum 256 clocks between bursts.                                                                                                             |  |  |  |
|        | 111                                                         | Minimum 512 clocks between bursts.                                                                                                             |  |  |  |

| DMA Ma | DMA Master Request 0 Control Register (DMR0CR) (Address = 0x0106) |                                                                          |  |  |  |
|--------|-------------------------------------------------------------------|--------------------------------------------------------------------------|--|--|--|
| Bit(s) | Value                                                             | Description                                                              |  |  |  |
| 7:6    | 00                                                                | External DMA Request 0 disabled.                                         |  |  |  |
|        | 01                                                                | External DMA Request 0 enabled from Parallel Port D2.                    |  |  |  |
|        | 10                                                                | External DMA Request 0 enabled from Parallel Port E2.                    |  |  |  |
|        | 11                                                                | External DMA Request 0 enabled from Parallel Port E6.                    |  |  |  |
| 5      |                                                                   | This bit is reserved and should be written with zero.                    |  |  |  |
| 4:3    | 00                                                                | External DMA Request 0 falling-edge triggered. One transfer per request. |  |  |  |
|        | 01                                                                | External DMA Request 0 rising-edge triggered. One transfer per request.  |  |  |  |
|        | 10                                                                | External DMA Request 0 active low. Transfers continue while low.         |  |  |  |
|        | 11                                                                | External DMA Request 0 active high. Transfers continue while high.       |  |  |  |
| 2:0    | 000 External DMA Request 0 supplied to DMA Channel 0.             |                                                                          |  |  |  |
|        | 001                                                               | External DMA Request 0 supplied to DMA Channel 1.                        |  |  |  |
|        | 010                                                               | External DMA Request 0 supplied to DMA Channel 2.                        |  |  |  |
|        | 011                                                               | External DMA Request 0 supplied to DMA Channel 3.                        |  |  |  |
|        | External DMA Request 0 supplied to DMA Channel 4.                 |                                                                          |  |  |  |
|        | External DMA Request 0 supplied to DMA Channel 5.                 |                                                                          |  |  |  |
|        | 110                                                               | External DMA Request 0 supplied to DMA Channel 6.                        |  |  |  |
|        | 111                                                               | External DMA Request 0 supplied to DMA Channel 7.                        |  |  |  |

| DMA Ma | aster Requ | uest 1 Control Register (DMR1CR) (Address = 0x0107)                      |  |  |  |
|--------|------------|--------------------------------------------------------------------------|--|--|--|
| Bit(s) | Value      | Description                                                              |  |  |  |
| 7:6    | 00         | External DMA Request 1 disabled.                                         |  |  |  |
|        | 01         | External DMA Request 1 enabled from Parallel Port D3.                    |  |  |  |
|        | 10         | External DMA Request 1 enabled from Parallel Port E3.                    |  |  |  |
|        | 11         | External DMA Request 1 enabled from Parallel Port E7.                    |  |  |  |
| 5      |            | This bit is reserved and should be written with zero.                    |  |  |  |
| 4:3    | 00         | External DMA Request 1 falling-edge triggered. One transfer per request. |  |  |  |
|        | 01         | External DMA Request 1 rising-edge triggered. One transfer per request.  |  |  |  |
|        | 10         | External DMA Request 1 active low. Transfers continue while low.         |  |  |  |
|        | 11         | External DMA Request 1 active high. Transfers continue while high.       |  |  |  |
| 2:0    | 000        | External DMA Request 1 supplied to DMA Channel 0.                        |  |  |  |
|        | 001        | External DMA Request 1 supplied to DMA Channel 1.                        |  |  |  |
|        | 010        | External DMA Request 1 supplied to DMA Channel 2.                        |  |  |  |
|        | 011        | External DMA Request 1 supplied to DMA Channel 3.                        |  |  |  |
|        | 100        | External DMA Request 1 supplied to DMA Channel 4.                        |  |  |  |
|        | 101        | External DMA Request 1 supplied to DMA Channel 5.                        |  |  |  |
|        | 110        | External DMA Request 1 supplied to DMA Channel 6.                        |  |  |  |
|        | 111        | External DMA Request 1 supplied to DMA Channel 7.                        |  |  |  |

| DMA T  | imed Requ | uest Control Register (DTRCR) (Address = 0x0115)                                                                                   |  |  |  |
|--------|-----------|------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit(s) | Value     | Description                                                                                                                        |  |  |  |
| 7      | 0         | Timed DMA request disabled.                                                                                                        |  |  |  |
|        | 1         | Timed DMA request enabled.                                                                                                         |  |  |  |
| 6:5    |           | These bits are reserved and should be written with zeros.                                                                          |  |  |  |
| 4:3    | 00        | Timed DMA request transfers one byte per request.                                                                                  |  |  |  |
|        | 01        | This bit combination is reserved and should not be used.                                                                           |  |  |  |
|        | 10        | Timed DMA request triggers transfers until current descriptor is complete. DMA channel fetches the next descriptor if appropriate. |  |  |  |
|        | 11        | This bit combination is reserved and should not be used.                                                                           |  |  |  |
| 2:0    | 000       | Timed DMA request supplied to DMA Channel 0.                                                                                       |  |  |  |
|        | 001       | Timed DMA request supplied to DMA Channel 1.                                                                                       |  |  |  |
|        | 010       | Timed DMA request supplied to DMA Channel 2.                                                                                       |  |  |  |
|        | 011       | Timed DMA request supplied to DMA Channel 3.                                                                                       |  |  |  |
|        | 100       | Timed DMA request supplied to DMA Channel 4.                                                                                       |  |  |  |
|        | 101       | Timed DMA request supplied to DMA Channel 5.                                                                                       |  |  |  |
|        | 110       | Timed DMA request supplied to DMA Channel 6.                                                                                       |  |  |  |
|        | 111       | Timed DMA request supplied to DMA Channel 7.                                                                                       |  |  |  |

| DMA Tim | ed Reques | st Divider Low Register                                                       | (DTRDLR) | (Address = 0x0116) |
|---------|-----------|-------------------------------------------------------------------------------|----------|--------------------|
| Bit(s)  | Value     | Description                                                                   |          |                    |
| 7:0     | Write     | The eight LSBs of the limit value for the DMA timed request timer are stored. |          |                    |

| DMA Timed Request Divider High Register |       | (DTRDHR)                                                                      | (Address = 0x0117) |  |
|-----------------------------------------|-------|-------------------------------------------------------------------------------|--------------------|--|
| Bit(s)                                  | Value | Description                                                                   |                    |  |
| 7:0                                     | Write | The eight MSBs of the limit value for the DMA timed request timer are stored. |                    |  |

| DMA y Termination Byte Register |       | tion Byte Register (D0TBR) (D1TBR) (D2TBR) (D3TBR) (D4TBR) (D5TBR) (D5TBR) (D6TBR) (D7TBR) | (Address = 0x0118)<br>(Address = 0x0128)<br>(Address = 0x0138)<br>(Address = 0x0148)<br>(Address = 0x0158)<br>(Address = 0x0168) |  |  |  |
|---------------------------------|-------|--------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit(s)                          | Value | Description                                                                                |                                                                                                                                  |  |  |  |
| 7:0                             |       | Byte value that, if matched, will terminate a buffer.                                      |                                                                                                                                  |  |  |  |

| DMA y Termination Mask Register |       |                                                                                                                                                                                                                                                                                                                                                                      | (D0TMR)<br>(D1TMR)<br>(D2TMR)<br>(D3TMR)<br>(D4TMR)<br>(D5TMR)<br>(D6TMR)<br>(D7TMR) | (Address = 0x0109)<br>(Address = 0x0119)<br>(Address = 0x0129)<br>(Address = 0x0139)<br>(Address = 0x0149)<br>(Address = 0x0159)<br>(Address = 0x0169)<br>(Address = 0x0179) |  |
|---------------------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit(s)                          | Value | Description                                                                                                                                                                                                                                                                                                                                                          |                                                                                      |                                                                                                                                                                              |  |
| 7:0                             |       | Mask for termination byte. A one in a bit position enables the corresponding bit of the termination byte to be used in the compare to generate the termination condition. A zero in a bit position disables the corresponding bit from contributing to the termination condition. A value of all zeros in this register disables the termination-byte match feature. |                                                                                      |                                                                                                                                                                              |  |

| DMA y Buffer Unused[7:0] Register |       |                                                                                                                                                                                                                                                                                                                                                                              | (D0BU0R)<br>(D1BU0R)<br>(D2BU0R)<br>(D3BU0R)<br>(D4BU0R)<br>(D5BU0R)<br>(D6BU0R)<br>(D7BU0R) | (Address = 0x010A)<br>(Address = 0x011A)<br>(Address = 0x012A)<br>(Address = 0x013A)<br>(Address = 0x014A)<br>(Address = 0x015A)<br>(Address = 0x016A)<br>(Address = 0x017A) |  |
|-----------------------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit(s)                            | Value | Description                                                                                                                                                                                                                                                                                                                                                                  |                                                                                              |                                                                                                                                                                              |  |
| 7:0                               |       | Bits 7:0 of the buffer unused length value are stored in this register. The DMA copies the buffer remaining length to this register at the completion of the transfer. Normally the buffer remaining length is zero, but if the transfer terminates early, under source control or because of a termination-byte match, the number of unused bytes in the buffer is written. |                                                                                              |                                                                                                                                                                              |  |

| DMA y Buffer Unused[15:8] Register |       | (D0BU1R)<br>(D1BU1R)<br>(D2BU1R)<br>(D3BU1R)<br>(D4BU1R)<br>(D5BU1R)<br>(D6BU1R)<br>(D7BU1R) | (Address = 0x010B) (Address = 0x011B) (Address = 0x012B) (Address = 0x013B) (Address = 0x014B) (Address = 0x015B) (Address = 0x016B) (Address = 0x017B) |  |  |  |
|------------------------------------|-------|----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit(s)                             | Value | Description                                                                                  |                                                                                                                                                         |  |  |  |
| 7:0                                |       | Bits 15:8 of the buffer unused-length value are stored in this register.                     |                                                                                                                                                         |  |  |  |

| DMA y Initial Addr[7:0] Register |       | (D0IA0R)<br>(D1IA0R)<br>(D2IA0R)<br>(D3IA0R)<br>(D4IA0R)<br>(D5IA0R)<br>(D6IA0R)<br>(D7IA0R) | (Address = 0x010C) (Address = 0x011C) (Address = 0x012C) (Address = 0x013C) (Address = 0x014C) (Address = 0x015C) (Address = 0x016C) (Address = 0x017C) |  |  |  |
|----------------------------------|-------|----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit(s)                           | Value | Description                                                                                  |                                                                                                                                                         |  |  |  |
| 7:0                              |       | Bits 7:0 of the initial address are stored in this register.                                 |                                                                                                                                                         |  |  |  |

| DMA    | y Initial A | Addr[15:8] Register                                           | (D0IA1R)<br>(D1IA1R)<br>(D2IA1R)<br>(D3IA1R)<br>(D4IA1R)<br>(D5IA1R)<br>(D6IA1R)<br>(D7IA1R) | (Address = 0x010D) (Address = 0x011D) (Address = 0x012D) (Address = 0x013D) (Address = 0x014D) (Address = 0x015D) (Address = 0x016D) (Address = 0x017D) |  |  |
|--------|-------------|---------------------------------------------------------------|----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit(s) | Value       | Description                                                   |                                                                                              |                                                                                                                                                         |  |  |
| 7:0    |             | Bits 15:8 of the initial address are stored in this register. |                                                                                              |                                                                                                                                                         |  |  |

| DMA    | y Initial A | ddr[23:16] Register                                            | (D0IA2R)<br>(D1IA2R)<br>(D2IA2R)<br>(D3IA2R)<br>(D4IA2R)<br>(D5IA2R)<br>(D6IA2R)<br>(D7IA2R) | (Address = 0x010E)<br>(Address = 0x011E)<br>(Address = 0x012E)<br>(Address = 0x013E)<br>(Address = 0x014E)<br>(Address = 0x015E)<br>(Address = 0x016E)<br>(Address = 0x017E) |  |  |
|--------|-------------|----------------------------------------------------------------|----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit(s) | Value       | Description                                                    |                                                                                              |                                                                                                                                                                              |  |  |
| 7:0    |             | Bits 23:16 of the initial address are stored in this register. |                                                                                              |                                                                                                                                                                              |  |  |

| DMA y Special Control Register |       |                                                            | (D0SCR)<br>(D1SCR)<br>(D2SCR)<br>(D3SCR)<br>(D4SCR)<br>(D5SCR)<br>(D5SCR)<br>(D6SCR)<br>(D7SCR) | (Address = 0x0180)<br>(Address = 0x0190)<br>(Address = 0x01A0)<br>(Address = 0x01B0)<br>(Address = 0x01C0)<br>(Address = 0x01D0)<br>(Address = 0x01E0)<br>(Address = 0x01F0) |  |  |
|--------------------------------|-------|------------------------------------------------------------|-------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit(s)                         | Value |                                                            | Description                                                                                     |                                                                                                                                                                              |  |  |
| 7:4                            |       | These bits are reserved and will always be read as zeros.  |                                                                                                 |                                                                                                                                                                              |  |  |
| 3                              | 0     | Auto-connect source DMA re                                 | Auto-connect source DMA request.                                                                |                                                                                                                                                                              |  |  |
|                                | 1     | Disconnect source DMA request (full buffer transfer).      |                                                                                                 |                                                                                                                                                                              |  |  |
| 2                              | 0     | Normal source address.                                     |                                                                                                 |                                                                                                                                                                              |  |  |
|                                | 1     | Source address fixed, independent of type.                 |                                                                                                 |                                                                                                                                                                              |  |  |
| 1                              | 0     | Auto-connect destination DMA request.                      |                                                                                                 |                                                                                                                                                                              |  |  |
|                                | 1     | Disconnect destination DMA request (full buffer transfer). |                                                                                                 |                                                                                                                                                                              |  |  |
| 0                              | 0     | Normal destination address.                                |                                                                                                 |                                                                                                                                                                              |  |  |
|                                | 1     | Destination address fixed, inc                             | lependent of type.                                                                              |                                                                                                                                                                              |  |  |

|        | <b>DMA</b> у Со                                                     | ntrol Register                                                                                                                                                                                | (D0CR)<br>(D1CR)<br>(D2CR)<br>(D3CR)<br>(D4CR)<br>(D5CR)<br>(D5CR)<br>(D6CR)<br>(D7CR) | (Address = 0x0181) (Address = 0x0191) (Address = 0x01A1) (Address = 0x01B1) (Address = 0x01C1) (Address = 0x01D1) (Address = 0x01E1) (Address = 0x01F1) |  |  |
|--------|---------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit(s) | Value                                                               |                                                                                                                                                                                               | Description                                                                            |                                                                                                                                                         |  |  |
| 7      | 0                                                                   | Continue to next buffer des                                                                                                                                                                   | criptor.                                                                               |                                                                                                                                                         |  |  |
|        | 1                                                                   | Final buffer descriptor. Stop                                                                                                                                                                 | DMA operation up                                                                       | on completion of this transfer.                                                                                                                         |  |  |
| 6      | 0                                                                   | Use sequential address for a present in this buffer descri                                                                                                                                    |                                                                                        | r. The link address field is not 2 bytes long.                                                                                                          |  |  |
|        | 1                                                                   | Use the link address field as a pointer to the next buffer descriptor. This buffer descriptor is 16 bytes long.                                                                               |                                                                                        |                                                                                                                                                         |  |  |
| 5      | 0                                                                   | No special treatment for las                                                                                                                                                                  | t byte.                                                                                |                                                                                                                                                         |  |  |
|        | 1                                                                   | Internal Source: status byte written to initial buffer descriptor before last data.  Internal Destination: Last byte written to offset address for frame termination.  All others: No effect. |                                                                                        |                                                                                                                                                         |  |  |
| 4      | 0                                                                   | No interrupt on completing this transfer.                                                                                                                                                     |                                                                                        |                                                                                                                                                         |  |  |
|        | 1                                                                   | Interrupt on completing this transfer.                                                                                                                                                        |                                                                                        |                                                                                                                                                         |  |  |
| 3:2    | 00                                                                  | Source address is fixed internal I/O (two-byte) address.                                                                                                                                      |                                                                                        |                                                                                                                                                         |  |  |
|        | 01                                                                  | Source address is fixed exte                                                                                                                                                                  | ernal I/O (two-byte)                                                                   | address.                                                                                                                                                |  |  |
|        | 10                                                                  | Source address is memory (                                                                                                                                                                    | (three-byte) address,                                                                  | auto-decrement.                                                                                                                                         |  |  |
|        | 11                                                                  | Source address is memory (three-byte) address, auto-increment.                                                                                                                                |                                                                                        |                                                                                                                                                         |  |  |
| 1:0    | 00                                                                  | Destination address is fixed                                                                                                                                                                  | l internal I/O (two-by                                                                 | yte) address.                                                                                                                                           |  |  |
|        | 01                                                                  | Destination address is fixed                                                                                                                                                                  | external I/O (two-b                                                                    | yte) address.                                                                                                                                           |  |  |
|        | 10                                                                  | Destination address is mem                                                                                                                                                                    | ory (three-byte) add                                                                   | ress, auto-decrement.                                                                                                                                   |  |  |
|        | Destination address is memory (three-byte) address, auto-increment. |                                                                                                                                                                                               |                                                                                        |                                                                                                                                                         |  |  |

| D      | MA y Leng                                                                                                                                                                                           | th[7:0] Register | (D0L0R)<br>(D1L0R)<br>(D2L0R)<br>(D3L0R)<br>(D4L0R)<br>(D5L0R)<br>(D5L0R)<br>(D7L0R) | (Address = 0x0182)<br>(Address = 0x0192)<br>(Address = 0x01A2)<br>(Address = 0x01B2)<br>(Address = 0x01C2)<br>(Address = 0x01D2)<br>(Address = 0x01E2)<br>(Address = 0x01F2) |  |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|--------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit(s) | Value                                                                                                                                                                                               | Description      |                                                                                      |                                                                                                                                                                              |  |
| 7:0    | Bits 7:0 of the buffer length value are stored in this register. The DMA does transfer followed by a decrement of this register, so an initial value of 0x000 will result in a 65536-byte transfer. |                  |                                                                                      | 8                                                                                                                                                                            |  |

| DN                                                                    | /IA y Lengt              | h[15:8] Register | (D0L1R)<br>(D1L1R)<br>(D2L1R)<br>(D3L1R)<br>(D4L1R)<br>(D5L1R)<br>(D6L1R)<br>(D7L1R) | (Address = 0x0183)<br>(Address = 0x0193)<br>(Address = 0x01A3)<br>(Address = 0x01B3)<br>(Address = 0x01C3)<br>(Address = 0x01D3)<br>(Address = 0x01E3)<br>(Address = 0x01F3) |
|-----------------------------------------------------------------------|--------------------------|------------------|--------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit(s)                                                                | Bit(s) Value Description |                  |                                                                                      |                                                                                                                                                                              |
| 7:0 Bits 15:8 of the buffer length value are stored in this register. |                          |                  | this register.                                                                       |                                                                                                                                                                              |

| DMA    | y Source | Addr[7:0] Register                                          | (D0SA0R)<br>(D1SA0R)<br>(D2SA0R)<br>(D3SA0R)<br>(D4SA0R)<br>(D5SA0R)<br>(D6SA0R)<br>(D6SA0R) | (Address = 0x0184)<br>(Address = 0x0194)<br>(Address = 0x01A4)<br>(Address = 0x01B4)<br>(Address = 0x01C4)<br>(Address = 0x01D4)<br>(Address = 0x01E4)<br>(Address = 0x01F4) |  |
|--------|----------|-------------------------------------------------------------|----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit(s) | Value    | Description                                                 |                                                                                              |                                                                                                                                                                              |  |
| 7:0    |          | Bits 7:0 of the source address are stored in this register. |                                                                                              |                                                                                                                                                                              |  |

| DMA                                                    | y Source | Addr[15:8] Register | (D0SA1R)<br>(D1SA1R)<br>(D2SA1R)<br>(D3SA1R)<br>(D4SA1R)<br>(D5SA1R)<br>(D6SA1R)<br>(D7SA1R) | (Address = 0x0185)<br>(Address = 0x0195)<br>(Address = 0x01A5)<br>(Address = 0x01B5)<br>(Address = 0x01C5)<br>(Address = 0x01D5)<br>(Address = 0x01E5)<br>(Address = 0x01F5) |
|--------------------------------------------------------|----------|---------------------|----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit(s)                                                 | Value    | Value Description   |                                                                                              |                                                                                                                                                                              |
| 7:0 Bits 15:8 of the source address are stored in this |          |                     | register.                                                                                    |                                                                                                                                                                              |

| DMA y Source Addr[23:16] Register  Bit(s) Value |  | (D0SA2R)<br>(D1SA2R)<br>(D2SA2R)<br>(D3SA2R)<br>(D4SA2R)<br>(D5SA2R)<br>(D5SA2R)<br>(D6SA2R)<br>(D7SA2R) | (Address = 0x0186)<br>(Address = 0x0196)<br>(Address = 0x01A6)<br>(Address = 0x01B6)<br>(Address = 0x01C6)<br>(Address = 0x01D6)<br>(Address = 0x01E6)<br>(Address = 0x01F6) |             |
|-------------------------------------------------|--|----------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| Bit(s) Value Description                        |  |                                                                                                          |                                                                                                                                                                              |             |
| 7:0 Bits 23:16 of the source address are s      |  |                                                                                                          | address are stored in thi                                                                                                                                                    | s register. |

| DMA y Destination Addr[7:0] Register |  | (D0DA0R)<br>(D1DA0R)<br>(D2DA0R)<br>(D3DA0R)<br>(D4DA0R)<br>(D5DA0R)<br>(D6DA0R)<br>(D7DA0R) | (Address = 0x0188)<br>(Address = 0x0198)<br>(Address = 0x01A8)<br>(Address = 0x01B8)<br>(Address = 0x01C8)<br>(Address = 0x01D8)<br>(Address = 0x01E8)<br>(Address = 0x01F8) |               |
|--------------------------------------|--|----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| Bit(s) Value Description             |  |                                                                                              |                                                                                                                                                                              |               |
| 7:0 Bits 7:0 of the destination      |  |                                                                                              | address are stored in t                                                                                                                                                      | his register. |

| DMA y Destination Addr[15:8] Register  Bit(s) Value           |  | (D0DA1R)<br>(D1DA1R)<br>(D2DA1R)<br>(D3DA1R)<br>(D4DA1R)<br>(D5DA1R)<br>(D6DA1R)<br>(D7DA1R) | (Address = 0x0189)<br>(Address = 0x0199)<br>(Address = 0x01A9)<br>(Address = 0x01B9)<br>(Address = 0x01C9)<br>(Address = 0x01D9)<br>(Address = 0x01E9)<br>(Address = 0x01F9) |
|---------------------------------------------------------------|--|----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit(s) Value Description                                      |  |                                                                                              |                                                                                                                                                                              |
| 7:0 Bits 15:8 of the destination address are stored in this r |  |                                                                                              | this register.                                                                                                                                                               |

| DMA y Destination Addr[23:16] Register  Bit(s) Value |                          | (D0DA2R)<br>(D1DA2R)<br>(D2DA2R)<br>(D3DA2R)<br>(D4DA2R)<br>(D5DA2R)<br>(D6DA2R)<br>(D7DA2R) | (Address = 0x018A) (Address = 0x019A) (Address = 0x01AA) (Address = 0x01BA) (Address = 0x01CA) (Address = 0x01DA) (Address = 0x01EA) (Address = 0x01FA) |                  |
|------------------------------------------------------|--------------------------|----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| Bit(s)                                               | Bit(s) Value Description |                                                                                              |                                                                                                                                                         |                  |
| 7:0 Bits 23:16 of the destination address are        |                          |                                                                                              | on address are stored i                                                                                                                                 | n this register. |

| DM     | A y Link A | ddr[7:0] Register                                         | (D0LA0R)<br>(D1LA0R)<br>(D2LA0R)<br>(D3LA0R)<br>(D4LA0R)<br>(D5LA0R)<br>(D6LA0R)<br>(D7LA0R) | (Address = 0x018C) (Address = 0x019C) (Address = 0x01AC) (Address = 0x01BC) (Address = 0x01CC) (Address = 0x01DC) (Address = 0x01EC) (Address = 0x01EC) (Address = 0x01FC) |
|--------|------------|-----------------------------------------------------------|----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit(s) | Value      | Description                                               |                                                                                              |                                                                                                                                                                            |
| 7:0    |            | Bits 7:0 of the link address are stored in this register. |                                                                                              |                                                                                                                                                                            |

| DM                                                             | A y Link A        | ddr[15:8] Register | (D0LA1R)<br>(D1LA1R)<br>(D2LA1R)<br>(D3LA1R)<br>(D4LA1R)<br>(D5LA1R)<br>(D6LA1R)<br>(D7LA1R) | (Address = 0x018D) (Address = 0x019D) (Address = 0x01AD) (Address = 0x01BD) (Address = 0x01CD) (Address = 0x01DD) (Address = 0x01ED) (Address = 0x01FD) |
|----------------------------------------------------------------|-------------------|--------------------|----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit(s)                                                         | Value Description |                    |                                                                                              |                                                                                                                                                         |
| 7:0 Bits 15:8 of the link address are stored in this register. |                   |                    | gister.                                                                                      |                                                                                                                                                         |

| DMA    | y Link Ac | ldr[23:16] Register       | (D0LA2R)<br>(D1LA2R)<br>(D2LA2R)<br>(D3LA2R)<br>(D4LA2R)<br>(D5LA2R)<br>(D6LA2R)<br>(D7LA2R) | (Address = 0x018E) (Address = 0x019E) (Address = 0x01AE) (Address = 0x01BE) (Address = 0x01CE) (Address = 0x01DE) (Address = 0x01EE) (Address = 0x01FE) |  |
|--------|-----------|---------------------------|----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit(s) | Value     | Description               |                                                                                              |                                                                                                                                                         |  |
| 7:0    |           | Bits 23:16 of the link ad | dress are stored in this r                                                                   | egister.                                                                                                                                                |  |

# 22. 10/100BASE-T ETHERNET

### 22.1 Overview

Network Port B implements a full 10/100Base-T Ethernet MAC with an industry-standard MII interface for an external PHY chip. The MAC is fully compliant with the IEEE 802.3 Ethernet standard, including support for auto-negotiation, link detection, multicast filtering, and broadcast addresses. A wide variety of transmit and receive options are available, including control over frame size, CRC attachment, maximum allowed frame size, and interpacket gap length.

The receiver and transmitter each have a 2048-byte FIFO that is shared with the Wi-Fi peripheral; the I/O pins are also shared. Because of this, only one of the two network peripherals can be enabled at any time.

The Network Port B receiver transfers both data and status information to memory via the DMA, eliminating the need for receive data or status interrupts and dedicated receive status registers. The network port appends six bytes of status information to the last byte of the received data. Buffer and byte counts in the DMA can be used to find this status information in memory. In cases where a received frame has been discarded because of an error, only these six bytes of status will be transferred to memory. The DMA must be programmed to close a buffer on end-of-frame, as the network port marks the last byte of status this way.

The Network Port B transmitter uses interrupts because the DMA has no way of knowing when (or if) the frame has successfully been sent. Both the receive and transmit FIFOs are capable of DMA fly-by operation.

The network port requires an accurate 25 MHz clock to generate the 100 Mbits/s serial rate of 100Base-T. This clock comes from the external PHY chip, and is input on separate pins for the transmit and receive channels. The clock for the network port may also be disabled to conserve power. The network port contains synchronization circuitry to allow operation from the 25 MHz reference clock while the main system clock runs independently.

The network port transmitter precedes the transmit data automatically with a preamble and start-frame-delimiter, and appends CRC and the end-frame delimiter after the last byte. Frame transmission starts automatically once the transmit FIFO is complete and any interframe gap time or back-off time has expired. Transmission is aborted if a collision is detected, and is retried up to 16 times using the standard random back-off time algorithm. Detection of a collision causes the transmitter to send a 32-bit "jam" pattern of all ones to guarantee that all receivers in the network recognize the collision.

The network port receiver uses the received preamble to synchronize to the phase of the incoming frame, and then waits for the start-frame delimiter. Character assembly begins at this point, and each byte is transferred to the receive FIFO. However, no interrupt or DMA request will occur until after the first six bytes of the frame have been received and checked for an address match. The receiver can receive frames independent of the address (promiscuous mode), or it can receive frames with a physical address match, a broadcast address match, or a multicast address match.

Normal DMA transfers of data begin once an address match occurs, and continue until the end-frame delimiter is recognized or the line goes idle because of a collision. The network receiver calculates the CRC across the entire frame in parallel with character assembly, and reports the result when the end-frame delimiter is recognized. Normally frames with bad CRC are discarded. The receiver also reports misaligned end-frame delimiters (those that do not occur on byte boundaries).

The network port implements the NLP receive link integrity test state machine, which requires link integrity pulses to be detected at certain intervals in the absence of other network activity. If the network receiver enters the NLP Link Test Fail state because of missing link-test pulses, this state machine requires seven successive properly timed link test pulses (or an equal number of FLP bursts) before reporting that the link is again active. The reset state of this state machine is link-inactive. Note that this is a subtle difference relative to the normal 10Base-T receive link-integrity state machine, which requires either link test pulses or carrier sense to make the link active.

The network port implements the auto-negotiation algorithm to determine half-duplex or full-duplex operation. In addition to its normal automatic operation, this feature can be disabled or commanded to execute under software control.

The MII interface consists of 20 pins as specified in IEEE 802.3 standard. Two clocks are provided on the interface, one for transmit and one for receive.

The two A/D converters and single D/A converter are available for customer use when the Ethernet peripheral is enabled.

# 22.1.1 Block Diagram



# 22.1.2 Registers

| Register Name                                    | Mnemonic | I/O Address | R/W | Reset    |
|--------------------------------------------------|----------|-------------|-----|----------|
| Network Port B Data Register                     | NBDR     | 0x0200      | R/W | xxxxxxxx |
| Network Port B Last Data Register                | NBLDR    | 0x0201      | W   | xxxxxxxx |
| Network Port B Transmit Status Register          | NBTSR    | 0x0202      | R   | 00000000 |
| Network Port B Control/Status Register           | NBCSR    | 0x0204      | R/W | 00000000 |
| Network Port B Command Register                  | NBCR     | 0x0206      | W   | 00000000 |
| Network Port B Transmit Pause LSB Register       | NBTPLR   | 0x0208      | R/W | 00000000 |
| Network Port B Transmit Pause MSB Register       | NBTPMR   | 0x0209      | R/W | 00000000 |
| Network Port B Transmit Control Register         | NBTCR    | 0x020A      | R/W | 00000000 |
| Network Port B Receive Control Register          | NBRCR    | 0x020B      | R/W | 00000000 |
| Network Port B Transmit Extra Status Register    | NBTESR   | 0x020C      | R/W | 00000000 |
| Network Port B Phys. Addr. [7:0] Register        | NBPA0R   | 0x0210      | W   | xxxxxxxx |
| Network Port B Phys. Addr. [15:8] Register       | NBPA1R   | 0x0211      | W   | xxxxxxxx |
| Network Port B Phys. Addr. [23:16] Register      | NBPA2R   | 0x0212      | W   | xxxxxxxx |
| Network Port B Phys. Addr. [31:24] Register      | NBPA3R   | 0x0213      | W   | XXXXXXXX |
| Network Port B Phys. Addr. [39:32] Register      | NBPA4R   | 0x0214      | W   | xxxxxxxx |
| Network Port B Phys. Addr. [47:40] Register      | NBPA5R   | 0x0215      | W   | XXXXXXXX |
| Network Port B Multicast Filter [7:0] Register   | NBMF0R   | 0x0218      | R/W | xxxxxxxx |
| Network Port B Multicast Filter [15:8] Register  | NBMF1R   | 0x0219      | R/W | xxxxxxxx |
| Network Port B Multicast Filter [23:16] Register | NBMF2R   | 0x021A      | R/W | xxxxxxx  |
| Network Port B Multicast Filter [31:24] Register | NBMF3R   | 0x021B      | R/W | XXXXXXXX |
| Network Port B Multicast Filter [39:32] Register | NBMF4R   | 0x021C      | R/W | xxxxxxxx |
| Network Port B Multicast Filter [47:40] Register | NBMF5R   | 0x021D      | R/W | XXXXXXXX |
| Network Port B Multicast Filter [55:48] Register | NBMF6R   | 0x021E      | R/W | xxxxxxx  |
| Network Port B Multicast Filter [63:56] Register | NBMF7R   | 0x021F      | R/W | xxxxxxxx |
| Network Port B Direct Rx Register                | NBDRR    | 0x0228      | R   | xxxxxxx  |
| Network Port B Direct Tx Register                | NBDTR    | 0x0229      | W   | xxxxxxxx |
| Network Port B Direct MII Register               | NBDMR    | 0x022A      | R/W | xxxxxxxx |
| Network Port B Configuration 0 Register          | NBCF0R   | 0x0240      | R/W | 00000000 |
| Network Port B Configuration 1 Register          | NBCF1R   | 0x0241      | R/W | 00000000 |
| Network Port B Configuration 2 Register          | NBCF2R   | 0x0242      | R/W | 00000000 |
| Network Port B Configuration 3 Register          | NBCF3R   | 0x0243      | R/W | 00000000 |
| Network Port B Gap 0 Register                    | NBG0R    | 0x0244      | R/W | 00000000 |

| Register Name                                | Mnemonic | I/O Address | R/W | Reset    |
|----------------------------------------------|----------|-------------|-----|----------|
| Network Port B Gap 2 Register                | NBG2R    | 0x0246      | R/W | 00000000 |
| Network Port B Gap 1 Register                | NBG1R    | 0x0247      | R/W | 00000000 |
| Network Port B Retransmit Max Register       | NBRMR    | 0x0248      | R/W | 00000000 |
| Network Port B Collision Window Register     | NBCWR    | 0x0249      | R/W | 00000000 |
| Network Port B Frame Limit LSB Register      | NBFLLR   | 0x024A      | R/W | 00000000 |
| Network Port B Frame Limit MSB Register      | NBFLMR   | 0x024B      | R/W | 00000000 |
| Network Port B MII Configuration Register    | NBMCFR   | 0x0250      | R/W | 00000000 |
| Network Port B MII Reset Register            | NBMRR    | 0x0251      | R/W | 00000000 |
| Network Port B MII Command Register          | NBMCR    | 0x0252      | R/W | 00000000 |
| Network Port B MII Register Address Register | NBMRAR   | 0x0254      | R/W | 00000000 |
| Network Port B MII PHY Address Register      | NBMPAR   | 0x0255      | R/W | 00000000 |
| Network Port B MII Write LSB Register        | NBMWLR   | 0x0256      | W   | 00000000 |
| Network Port B MII Write MSB Register        | NBMWMR   | 0x0257      | W   | 00000000 |
| Network Port B MII Read LSB Register         | NBMRLR   | 0x0258      | R   | 00000000 |
| Network Port B MII Read MSB Register         | NBMRMR   | 0x0259      | R   | 00000000 |
| Network Port B MII Status Register           | NBMSR    | 0x025A      | R/W | 00000000 |
| Network Port B Station Address 0 Register    | NBSA0R   | 0x0260      | R/W | 00000000 |
| Network Port B Station Address 1 Register    | NBSA1R   | 0x0261      | R/W | 00000000 |
| Network Port B Station Address 2 Register    | NBSA2R   | 0x0262      | R/W | 00000000 |
| Network Port B Station Address 3 Register    | NBSA3R   | 0x0263      | R/W | 00000000 |
| Network Port B Station Address 4 Register    | NBSA4R   | 0x0264      | R/W | 00000000 |
| Network Port B Station Address 5 Register    | NBSA5R   | 0x0265      | R/W | 00000000 |
| Enable Network Port Register                 | ENPR     | 0x0430      | R/W | 00000000 |

# 22.2 Dependencies

## 22.2.1 I/O Pins

The network port MII interface has 20 dedicated pins, which are listed in Table 22-1. These pins can be used as general-purpose inputs and outputs if the network port is not being used via NBDRR, NBDTR, and NBDMR.

Table 22-1. Network Port MII Interface

| Section    | Signal   | Direction | Function                       |
|------------|----------|-----------|--------------------------------|
|            | TXD[3:0] | Output    | Transmit data to PHY           |
|            | TX_EN    | Output    | Transmit enable                |
| Transmit   | TX_ER    | Output    | Transmit error                 |
| Transmit   | CRS      | Input     | Carrier sense                  |
|            | COL      | Input     | Collision detect               |
|            | TX_CLK   | Input     | Transmit clock (25 MHz)        |
|            | RXD[3:0] | Input     | Receive data from PHY          |
| Receive    | RX_DV    | Input     | Receive data valid             |
| Receive    | RX_ER    | Input     | Receive data error             |
|            | RX_CLK   | Input     | Receive clock (25 MHz)         |
|            | MDC      | Output    | Management data clock (varies) |
| Management | MDI      | Input     | Management data input          |
|            | MDO      | Output    | Management data output         |
|            | MDOEN    | Output    | Management data output enable  |

### 22.2.2 Clocks

The network port requires a 25 MHz clock input for proper 10/100Base-T operation; this clock is normally supplied separately to the receive and transmit portions of the peripheral on the RX\_CLK and TX\_CLK pins. The management data clock on MDC is generated by the Rabbit 5000 by dividing down the peripheral clock as selected in NBMCFR.

## 22.2.3 Other Registers

| Register | Function                              |
|----------|---------------------------------------|
| EDMR     | Enable 10/100 Ethernet functionality. |

### 22.2.4 Interrupts

The network interrupt can be generated by an Ethernet frame being transmitted correctly, transmitted with an error, or if a transmit pause occurs (control frame is transmitted but not the data). The events that generate an interrupt can be selected in NBCSR.

The receive frame status is attached to the end of the data frame itself, so the DMA interrupt can be used to handle received frame. See Section 22.3 for more details.

The network port interrupt vector is shared with Network Port C, the Wi-Fi network port. It is located in the IIR at offset 0x1E0. It can be set as Priority 1, 2, or 3 by writing to ENPR.

# 22.3 Operation

High-level support for TCP/IP and other protocols is beyond the scope of this manual, but this section will describe the low-level setup and operation of the 10/100Base-T Ethernet peripheral.

The contents of the six status bytes are shown below. Note that any status block marked with RxOV (receive overflow) is invalid, as the FIFO could not hold the entire frame. Only the marked frame is invalid, so any previous frames read from the FIFO are fine. Once an overflow is detected, no subsequent frames can be buffered to the FIFO until a FIFO purge command is written to the NBCR.

| Status Byte | Bit 7                                                      | Bit 6                                                     | Bit 5 | Bit 4     | Bit 3    | Bit 2 | Bit 1 | Bit 0 |
|-------------|------------------------------------------------------------|-----------------------------------------------------------|-------|-----------|----------|-------|-------|-------|
| First       |                                                            |                                                           |       | LSB of Rx | Checksum | l     |       |       |
| Second      |                                                            | MSB of Rx Checksum                                        |       |           |          |       |       |       |
| Third       |                                                            | Receive Status Vector [7:0] (LSB of receive frame length) |       |           |          |       |       |       |
| Fourth      | Receive Status Vector [15:8] (MSB of receive frame length) |                                                           |       |           |          |       |       |       |
| Fifth       | Receive Status Vector [23:16]                              |                                                           |       |           |          |       |       |       |
| Last        | RxOV                                                       | RxOV Receive Status Vector [30:24]                        |       |           |          |       |       |       |

### 22.3.1 Setup

The following steps explain how to set up Network Port B.

- 1. Write the interrupt vector for the interrupt service routine to the external interrupt table.
- 2. Select the desired interrupts and interrupt priority by writing to NBCSR.
- 3. Select the MII interface settings by writing to NBMCFR, NBMRAR, and NBMPAR.
- 4. Select the desired configuration of transmit and receive operation by writing to NBTCR, NBTESR, and MBRCR.
- 5. Write the device's physical MAC address to the physical address (NBPAxR) and station address registers (NBSAxR).
- 6. If desired, write to the multicast filter registers (NBMFxR) to generate a multicast filter.
- 7. Select other options in the configuration registers NBCFxR, NBGxR, NBRMR, NBCWR, and NBFLxR.
- 8. Enable the network port transmitter by writing to NBTCR.
- 9. Enable the network port receiver by writing to NBRCR.

#### 22.3.2 Transmit

The following steps explain how to transmit an Ethernet packet.

- 1. Set up a DMA buffer descriptor that will read the packet data from memory and write it to NBDR. Write the buffer descriptor's address to the DMA's initial address registers (see Chapter 21 for more information).
- 2. Enable the DMA transfer by auto-loading the buffer.
- 3. The packet transmission will proceed automatically. If any interrupts were enabled for any transmitted packet events, they will occur upon completion (or error).

Note that network interrupts will occur when the data appears in the network peripheral, but DMA interrupts will occur when the DMA transfer is complete.

#### 22.3.3 Receive

The following steps explain how to receive an Ethernet packet.

- 1. Set up a DMA buffer descriptor that will read the packet data from NBDR and write it to memory. Write the buffer descriptor's address to the DMA's initial address registers (see Chapter 21 for more information).
- 2. Set up a DMA interrupt to handle the packet once it has been received and copied to memory.
- 3. Enable the DMA transfer by auto-loading the buffer.
- 4. The packet transmission will proceed automatically when data come in. When the DMA transfer is complete, the DMA interrupt can be used to start the packet processing. The status of the received packet is appended to the received data.

## 22.3.4 Handling Interrupts

The network port transmit interrupt is automatically cleared by reading NBCSR; received packets are handled via the DMA interrupt, which is automatically cleared when the ISR is called.

A sample packet transmit interrupt handler is shown below.

```
network isr::
  push af
  ioi ld a, (NBCSR)
                           ; read the interrupt status
  push af
                            ; save status byte for later
  bit 4,a
                            ; did transmit error occur?
  jp nz, handle_tx_err
  bit 4,a
                            ; did transmit pause occur?
   jp nz, handle_pause_err
done:
  pop af
  ipres
  ret
handle tx err:
                           ; get transmitter status
  ioi ld a, (NBTSR)
   ; check why error occurred and respond accordingly
  pop af
  pop af
  ipres
  ret
handle pause err:
   ; handle transmit pause
  pop af
  ipres
```

A sample packet receive interrupt handler is shown below.

```
dma_eth_rx_isr::
    ; interrupt is automatically cleared
    ; check status bytes appended to packet just received
    ipres
    ret
```

## 22.3.5 Multicast Addressing

A physical address match requires that the received frame address is a physical address that matches every bit of the programmed receive address. A broadcast address match requires that all 48 bits of the received frame address be "ones." A multicast address match requires the received frame address to be a multicast address (LSB of the address is one) and a match in the multicast address filter. The multicast address filter uses the six most significant bits of the CRC calculated on the receive address as an index into a 64-by-1 bit table written under program control. A one in the corresponding table entry constitutes a multicast address match as far as the network port is concerned. A table of one set of unique multicast addresses corresponding to each filter bit is shown below. The table shows the least significant byte of the multicast address; the remaining five bytes of the address are all zeros for this set of multicast addresses.

| Register | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|----------|-------|-------|-------|-------|-------|-------|-------|-------|
| NBMF7R   | 0x17  | 0x0B  | 0x05  | 0x19  | 0x85  | 0x99  | 0x97  | 0x8B  |
| NBMF6R   | 0xD9  | 0xC5  | 0xCB  | 0xD7  | 0x4B  | 0x57  | 0x59  | 0x45  |
| NBMF5R   | 0xCF  | 0xD3  | 0xDD  | 0xC1  | 0x5D  | 0x41  | 0x4F  | 0x53  |
| NBMF4R   | 0x01  | 0x1D  | 0x13  | 0x0F  | 0x93  | 0x8F  | 0x81  | 0x9D  |
| NBMF3R   | 0x5F  | 0x43  | 0x4D  | 0x51  | 0xCD  | 0xD1  | 0xDF  | 0xC3  |
| NBMF2R   | 0x91  | 0x8D  | 0x83  | 0x9F  | 0x03  | 0x1F  | 0x11  | 0x0D  |
| NBMF1R   | 0x87  | 0x9B  | 0x95  | 0x89  | 0x15  | 0x09  | 0x07  | 0x1B  |
| NBMF0R   | 0x49  | 0x55  | 0x5B  | 0x47  | 0xDB  | 0xC7  | 0xC9  | 0xD5  |

# 22.4 Register Descriptions

| Ne     | Network Port B Data Register |                                                                                                                                           | (NBDR)      | (Address = 0x0200) |
|--------|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------------|
| Bit(s) | Value                        |                                                                                                                                           | Description |                    |
| 7:0    | Read                         | Returns the contents of the receive buffer. This register is not normally accessed by the processor, but is accessed by the DMA channels. |             |                    |
|        | Write                        | Loads the transmit buffer with a data byte for transmission.                                                                              |             |                    |

| Netw   | ork Port B | Last Data Register                                                                                                                                                                      | (NBLDR) | (Address = 0x0201) |  |  |
|--------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|--------------------|--|--|
| Bit(s) | Value      | Description                                                                                                                                                                             |         |                    |  |  |
| 7:0    | Read       | Returns the contents of the receive buffer. This register is not normally accessed by the processor, but is accessed by the DMA channels.                                               |         |                    |  |  |
|        | Write      | Loads the transmit buffer with the last data byte of a frame to enable the subsequent transmission of the CRC. The DMA automatically writes the last byte of the frame to this address. |         |                    |  |  |

| Network | Port B Tra | ansmit Status Register (NBTSR) (Address = 0x0202)                           |  |  |  |
|---------|------------|-----------------------------------------------------------------------------|--|--|--|
| Bit(s)  | Value      | Description                                                                 |  |  |  |
| 7       | 0          | Frame transmission not complete.                                            |  |  |  |
|         | 1          | Frame transmission complete.                                                |  |  |  |
| 6       | 0          | Frame transmission is not deferring.                                        |  |  |  |
|         | 1          | Frame transmission is deferring.                                            |  |  |  |
| 5       | 0          | No excessive collisions.                                                    |  |  |  |
|         | 1          | Frame transmission aborted due to excessive collisions.                     |  |  |  |
| 4       | 0          | No transmit underrun.                                                       |  |  |  |
|         | 1          | Frame transmission aborted because of a FIFO underrun.                      |  |  |  |
| 3       | 0          | Frame transmission not too long.                                            |  |  |  |
|         | 1          | Frame transmission too long.                                                |  |  |  |
| 2       | 0          | No excessive defers.                                                        |  |  |  |
|         | 1          | Frame transmission deferred excessively.                                    |  |  |  |
| 1       | 0          | No collisions.                                                              |  |  |  |
|         | 1          | Frame transmission encountered at least one collision.                      |  |  |  |
| 0       | 0          | No late collisions.                                                         |  |  |  |
|         | 1          | Frame transmission encountered a late collision (later than one slot time). |  |  |  |

| Networ          | k Port B C | ontrol/Status Register (NBCSR) (Address = 0x0204)                                                                                                    |  |  |  |
|-----------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit(s)          | Value      | Description                                                                                                                                          |  |  |  |
| 7:6             |            | These bits are reserved and will always read as zero.                                                                                                |  |  |  |
| 5:3             | 0          | The corresponding interrupt is disabled.                                                                                                             |  |  |  |
| (Write-only)    | 1          | The corresponding interrupt is enabled.                                                                                                              |  |  |  |
| 5:3             | Read       | These bits, and the Network Port interrupt, are automatically cleared by a read of this register. The individual interrupt enables are not affected. |  |  |  |
| 5               | 0          | No transmit okay interrupt.                                                                                                                          |  |  |  |
| (Read-<br>only) | 1          | Transmit okay interrupt.                                                                                                                             |  |  |  |
| 4               | 0          | No transmit error interrupt.                                                                                                                         |  |  |  |
| (Read-only)     | 1          | Transmit error interrupt.                                                                                                                            |  |  |  |
| 3               | 0          | No transmit pause interrupt.                                                                                                                         |  |  |  |
| (Read-<br>only) | 1          | Transmit pause interrupt (control frame complete).                                                                                                   |  |  |  |
| 2               | 0          | This bit is reserved and will always read as zero.                                                                                                   |  |  |  |
| 1:0             | 00         | The Network Port interrupt is disabled.                                                                                                              |  |  |  |
|                 | 01         | The Network Port uses Interrupt Priority 1.                                                                                                          |  |  |  |
|                 | 10         | The Network Port uses Interrupt Priority 2.                                                                                                          |  |  |  |
|                 | 11         | The Network Port uses Interrupt Priority 3.                                                                                                          |  |  |  |

| Netwo  | ork Port B | Command Register (NBCR) (Address = 0x0206)                    |  |  |  |
|--------|------------|---------------------------------------------------------------|--|--|--|
| Bit(s) | Value      | Description                                                   |  |  |  |
| 7      | 0          | No operation.                                                 |  |  |  |
|        | 1          | Transmit start command.                                       |  |  |  |
| 6      | 0          | No operation.                                                 |  |  |  |
|        | 1          | Transmit PAUSE control frame command.                         |  |  |  |
| 5      | 0          | No operation.                                                 |  |  |  |
|        | 1          | Transmit half-duplex backpressure.                            |  |  |  |
| 4      | 0          | No operation.                                                 |  |  |  |
|        | 1          | Transmit FIFO purge command.                                  |  |  |  |
| 3:1    |            | These bits are ignored and should always be written as zeros. |  |  |  |
| 0      | 0          | No operation.                                                 |  |  |  |
|        | 1          | Receive FIFO purge command.                                   |  |  |  |

| Network Port B Transmit Pause LSB Register |       |                                               | (NBTPLR) | (Address = 0x0208) |  |
|--------------------------------------------|-------|-----------------------------------------------|----------|--------------------|--|
| Bit(s)                                     | Value | Description                                   |          |                    |  |
| 7:0                                        |       | LSB of parameter sent in PAUSE control frame. |          |                    |  |

| Network Po | ort B Trans | mit Pause MSB Register                        | (NBTPMR) | (Address = 0x0209) |  |  |
|------------|-------------|-----------------------------------------------|----------|--------------------|--|--|
| Bit(s)     | Value       | Description                                   |          |                    |  |  |
| 7:0        |             | MSB of parameter sent in PAUSE control frame. |          |                    |  |  |

| Network | Port B Tra | nsmit Control Register (NBTCR) (Address = 0x020A)                              |
|---------|------------|--------------------------------------------------------------------------------|
| Bit(s)  | Value      | Description                                                                    |
| 7:6     | 00         | Disable transmit FIFO.                                                         |
|         | 01         | DMA request when frame transmission is complete.                               |
|         | 10         | Reserved.                                                                      |
|         | 11         | Reserved.                                                                      |
| 5:4     | 00         | Start transmit on command only.                                                |
|         | 01         | Start transmit on command or Last Byte written.                                |
|         | 10         | Start transmit on command, when FIFO is half full, or Last Byte written.       |
|         | 11         | Start transmit on command, when FIFO is one-fourth full, or Last Byte written. |
| 3:0     |            | These bits are reserved and should be written with zeros.                      |

| Network | Network Port B Receive Control Register (NBRCR) (Address = 0x020B) |                                                                                                   |  |  |  |
|---------|--------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|--|--|--|
| Bit(s)  | Value                                                              | Description                                                                                       |  |  |  |
| 7:6     | 00                                                                 | Disable receive FIFO.                                                                             |  |  |  |
|         | 01                                                                 | DMA request when frame reception is complete.                                                     |  |  |  |
|         | 10                                                                 | DMA request when FIFO is half full or frame reception is complete.                                |  |  |  |
|         | 11                                                                 | DMA request when FIFO is one-fourth full or frame reception is complete.                          |  |  |  |
| 5       | 0                                                                  | Normal receiver operation.                                                                        |  |  |  |
|         | 1                                                                  | Place receiver in Monitor Mode. Receiver operates normally, but does not buffer frames to memory. |  |  |  |
| 4       | 4 0 Receive frames less than 64 bytes in length discarded.         |                                                                                                   |  |  |  |
|         | 1                                                                  | Receive frames as short as 8 bytes accepted.                                                      |  |  |  |
| 3       | 0                                                                  | Receive frames with errors discarded. Reclaim buffer space.                                       |  |  |  |
|         | 1                                                                  | Receive frames with errors accepted. Do not reclaim buffer space.                                 |  |  |  |
| 2       | 0                                                                  | Receive frames with broadcast address ignored.                                                    |  |  |  |
|         | 1                                                                  | Receive frames with broadcast address accepted                                                    |  |  |  |
| 1       | 0                                                                  | Receive frames with multicast addresses ignored.                                                  |  |  |  |
|         | 1                                                                  | Receive frames with multicast addresses accepted if passing hashing filter.                       |  |  |  |
| 0       | 0                                                                  | Receive frames with mismatched physical addresses are ignored.                                    |  |  |  |
|         | 1                                                                  | Receive frames with any physical address accepted. Promiscuous mode.                              |  |  |  |

| Network P | Network Port B Transmit Extra Status Register (NBTESR) (Address = 0x020C)) |                                                                 |  |  |  |
|-----------|----------------------------------------------------------------------------|-----------------------------------------------------------------|--|--|--|
| Bit(s)    | Value                                                                      | Description                                                     |  |  |  |
| 7         |                                                                            | This bit is are reserved and will always be read as zero.       |  |  |  |
| 6         | 0                                                                          | No transmit length out-of-range, or not checked.                |  |  |  |
|           | 1                                                                          | Transmit frame had length out-of-range error.                   |  |  |  |
| 5         | 0                                                                          | No transmit length check error, or transmit length not checked. |  |  |  |
|           | 1                                                                          | Transmit frame had length check error.                          |  |  |  |
| 4         | 0                                                                          | No transmit CRC error, or transmit CRC not checked.             |  |  |  |
|           | 1                                                                          | Transmit frame had CRC error.                                   |  |  |  |
| 3:0       |                                                                            | Transmit frame collision count.                                 |  |  |  |

| Network Port B Physical Address x Register |       |                       | (NBPA0R)<br>(NBPA1R)<br>(NBPA2R)<br>(NBPA3R)<br>(NBPA4R)<br>(NBPA5R) | (Address = 0x0210)<br>(Address = 0x0211)<br>(Address = 0x0212)<br>(Address = 0x0213)<br>(Address = 0x0214)<br>(Address = 0x0215) |
|--------------------------------------------|-------|-----------------------|----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| Bit(s)                                     | Value |                       | Description                                                          |                                                                                                                                  |
| 7:0 Write Byte of physical address for     |       | receive address filte | ering.                                                               |                                                                                                                                  |

| Network Port B Multicast Filter x Register |                                                                                                                                                                                                                                                                                |  | (NBMF0R)<br>(NBMF1R)<br>(NBMF2R)<br>(NBMF3R)<br>(NBMF4R)<br>(NBMF5R)<br>(NBMF6R)<br>(NBMF7R) | (Address = 0x0218)<br>(Address = 0x0219)<br>(Address = 0x021A)<br>(Address = 0x021B)<br>(Address = 0x021C)<br>(Address = 0x021D)<br>(Address = 0x021E)<br>(Address = 0x021F) |
|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit(s)                                     | Value                                                                                                                                                                                                                                                                          |  | Description                                                                                  |                                                                                                                                                                              |
| 7:0                                        | Write Eight bits of the multicast filter. At the end of a received multicast address, the upper six bits of CRC are used as an index into this 64-bit table. If the corresponding bit is zero, the frame is discarded. If the corresponding bit is one, the frame is accepted. |  |                                                                                              |                                                                                                                                                                              |

| Netw   | Network Port B Direct Rx Register |                                      | IBDRR) | (Address = 0x0228) |
|--------|-----------------------------------|--------------------------------------|--------|--------------------|
| Bit(s) | Value                             | Description                          |        |                    |
| 7:4    | Read                              | Returns the state of the RXD pins.   |        |                    |
| 3      | Read                              | Returns the state of the RX_ER pin.  |        |                    |
| 2      | Read                              | Returns the state of the RX_DV pin.  |        |                    |
| 1      | Read                              | Returns the state of the RX_CLK pin. |        |                    |
| 0      | Read                              | Returns the state of the CRS pin.    |        |                    |

| Netw   | Network Port B Direct Tx Register |                                                                         | TR) | (Address = 0x0229) |
|--------|-----------------------------------|-------------------------------------------------------------------------|-----|--------------------|
| Bit(s) | Value                             | Description                                                             |     |                    |
| 7:4    | Write                             | Controls the state of the TXD pins if both network ports are disabled.  |     |                    |
| 3      | Write                             | Controls the state of the TX_ER pin if both network ports are disabled. |     |                    |
| 2      | Write                             | Controls the state of the TX_EN pin if both network ports are disabled. |     |                    |
| 1      | Read                              | Returns the state of the TX_CLK pin.                                    |     |                    |
| 0      | Read                              | Returns the state of the COL pin.                                       |     |                    |

| Netw   | Network Port B Direct MII Register |                                                                         | (NBDMR)                | (Address = 0x022A)             |
|--------|------------------------------------|-------------------------------------------------------------------------|------------------------|--------------------------------|
| Bit(s) | Value                              | Description                                                             |                        |                                |
| 7:4    |                                    | These bits are reserved ar                                              | d should be written wi | ith zeros. Reads return zeros. |
| 3      | Write                              | Controls the state of the MDO pin if both network ports are disabled.   |                        |                                |
| 2      | Write                              | Controls the state of the MDOEN pin if both network ports are disabled. |                        |                                |
| 1      | Write                              | Controls the state of the MDC pin if both network ports are disabled.   |                        |                                |
| 0      | Read                               | Returns the state of the M                                              | DI pin.                |                                |

| Network | Port B Co | onfiguration 0 Register (NBCF0R) (Address = 0x0240)            |  |
|---------|-----------|----------------------------------------------------------------|--|
| Bit(s)  | Value     | Description                                                    |  |
| 7:5     |           | These bits are ignored and will always return zeros when read. |  |
| 4       | 0         | Disable loopback.                                              |  |
|         | 1         | Enable loopback.                                               |  |
| 3       | 0         | Disable transmit flow control.                                 |  |
|         | 1         | Enable transmit flow control (PAUSE control frames).           |  |
| 2       | 0         | Disable receive flow control.                                  |  |
|         | 1         | Enable receive flow control (PAUSE control frames).            |  |
| 1       | 0         | Pass normal receive frames only.                               |  |
|         | 1         | Pass all receive frames (normal or control).                   |  |
| 0       | 0         | Disable receiver.                                              |  |
|         | 1         | Enable receiver.                                               |  |

| Network | Port B Co | onfiguration 1 Register (NBCF1R) (Address = 0x0241)            |  |  |
|---------|-----------|----------------------------------------------------------------|--|--|
| Bit(s)  | Value     | Description                                                    |  |  |
| 7       | 0         | No operation.                                                  |  |  |
|         | 1         | Reset entire MAC.                                              |  |  |
| 6       | 0         | No operation.                                                  |  |  |
|         | 1         | Reset transmit random number generator.                        |  |  |
| 5:4     |           | These bits are ignored and will always return zeros when read. |  |  |
| 3       | 0         | No operation.                                                  |  |  |
|         | 1         | Reset MAC control sublayer/receive domain logic.               |  |  |
| 2       | 0         | No operation.                                                  |  |  |
|         | 1         | Reset receiver.                                                |  |  |
| 1       | 0         | No operation.                                                  |  |  |
|         | 1         | Reset MAC control sublayer/transmit domain logic.              |  |  |
| 0       | 0         | No operation.                                                  |  |  |
|         | 1         | Reset transmitter.                                             |  |  |

| Network                                                              | Port B Co | onfiguration 2 Register (NBCF2R) (Address = 0x0242)                                      |
|----------------------------------------------------------------------|-----------|------------------------------------------------------------------------------------------|
| Bit(s)                                                               | Value     | Description                                                                              |
| 7:5                                                                  | xx0       | Disable transmit pad operation. Check CRC if not appended.                               |
|                                                                      | 001       | Pad transmit frames to 60 bytes, append CRC.                                             |
|                                                                      | x11       | Pad transmit frames to 64 bytes, append CRC.                                             |
| Pad transmit frames to 60 bytes (not VLAN tagged) or 64 tappend CRC. |           | Pad transmit frames to 60 bytes (not VLAN tagged) or 64 bytes (VLAN tagged), append CRC. |
| 4                                                                    | 0         | Disable transmit CRC insertion.                                                          |
|                                                                      | 1         | Enable transmit CRC insertion. Must be set if bit 5 is set.                              |
| 3                                                                    | 0         | Normal 802.3 frame structure.                                                            |
|                                                                      | 1         | Enable 4-byte header (ignored by CRC).                                                   |
| 2                                                                    | 0         | Normal 802.3 frame length restrictions.                                                  |
|                                                                      | 1         | Enable huge frames (transmit and receive).                                               |
| 1                                                                    | 0         | Disable frame length checking.                                                           |
|                                                                      | 1         | Enable frame length checking (transmit and receive).                                     |
| 0                                                                    | 0         | Enable half-duplex.                                                                      |
|                                                                      | 1         | Enable full-duplex.                                                                      |

| Network | Port B Co | onfiguration 3 Register (NBCF3R) (Address = 0x0243)            |  |
|---------|-----------|----------------------------------------------------------------|--|
| Bit(s)  | Value     | Description                                                    |  |
| 7       |           | This bit is ignored and will always return zero when read.     |  |
| 6       | 0         | Abort transmit on excessive deferral.                          |  |
|         | 1         | Defer to carrier indefinitely.                                 |  |
| 5       | 0         | Normal transmit operation after back-pressure collision.       |  |
|         | 1         | Enable immediate transmission after back-pressure collision.   |  |
| 4       | 0         | Normal 802.3 back-off operation.                               |  |
|         | 1         | Enable immediate retransmit (no back-off).                     |  |
| 3:2     |           | These bits are ignored and will always return zeros when read. |  |
| 1       | 0         | Disable preamble length limit checking.                        |  |
|         | 1         | Enable preamble length limit checking (12 bytes or less only). |  |
| 0       | 0         | Disable preamble checking.                                     |  |
|         | 1         | Enable preamble checking.                                      |  |

| Net    | Network Port B Gap 0 Register |                                                                                                                                                                                                                           | (NBG0R) | (Address = 0x0244) |  |
|--------|-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|--------------------|--|
| Bit(s) | Value                         | Description                                                                                                                                                                                                               |         |                    |  |
| 7      |                               | This bit is ignored and will always return zero when read.                                                                                                                                                                |         |                    |  |
| 6:0    |                               | Back-to-back interpacket gap. Recommended values are 0x15 for full-duplex operation, and 0x12 for half-duplex operation. These values result in 9.6 μs for 10 Mbits/s and 0.96 μs for 100 Mbits/s, as specified by 802.3. |         |                    |  |

| Net    | Network Port B Gap 2 Register |                                                                                                           | (NBG2R) | (Address = 0x0246) |  |
|--------|-------------------------------|-----------------------------------------------------------------------------------------------------------|---------|--------------------|--|
| Bit(s) | Value                         | Description                                                                                               |         |                    |  |
| 7      |                               | This bit is ignored and will always return zero when read.                                                |         |                    |  |
| 6:0    |                               | Non-back-to-back interpacket gap for carrier deference. Recommended value is 0x0C, as specified by 802.3. |         |                    |  |

| Network Port B Gap 1 Register |       | (NBG1R)                                                                                                                                                      | (Address = 0x0247) |  |  |  |
|-------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|--|--|--|
| Bit(s)                        | Value | Description                                                                                                                                                  |                    |  |  |  |
| 7                             |       | This bit is ignored and will always return zero when read.                                                                                                   |                    |  |  |  |
| 6:0                           |       | Non-back-to-back interpacket gap. Recommended value is 0x12. This value results in 9.6 µs for 10 Mbits/s and 0.96 µs for 100 Mbits/s, as specified by 802.3. |                    |  |  |  |

| Network | Network Port B Retransmit Max Register |                                                                                                                     | (NBRMR) | (Address = 0x0248) |  |
|---------|----------------------------------------|---------------------------------------------------------------------------------------------------------------------|---------|--------------------|--|
| Bit(s)  | Value                                  | Description                                                                                                         |         |                    |  |
| 7:4     |                                        | These bits are ignored and will always return zero when read.                                                       |         |                    |  |
| 3:0     |                                        | Number of retransmission attempts after a collision before aborting. Default (and value specified by 802.3) is 0xF. |         |                    |  |

| Network | Port B Coll | ision Window Register                                                         | (NBCWR) | (Address = 0x0249) |  |
|---------|-------------|-------------------------------------------------------------------------------|---------|--------------------|--|
| Bit(s)  | Value       | Description                                                                   |         |                    |  |
| 7:6     |             | These bits are ignored and will always return zero when read.                 |         |                    |  |
| 5:0     |             | Collision window (slot time). Default (and value specified by 802.3) is 0x37. |         |                    |  |

| Network Port B Frame Limit LSB Register |       | (NBFLLR)                     | (Address = 0x024A) |
|-----------------------------------------|-------|------------------------------|--------------------|
| Bit(s)                                  | Value | Description                  |                    |
| 7:0                                     |       | LSB of maximum frame length. |                    |

| Network | Network Port B Frame Limit MSB Register |                                                                                |                      | (Address = 0x024B)               |  |
|---------|-----------------------------------------|--------------------------------------------------------------------------------|----------------------|----------------------------------|--|
| Bit(s)  | Value                                   | Description                                                                    |                      |                                  |  |
| 7:0     |                                         | MSB of maximum frame le 0x0600.(1536), including pribe less than 0x05EE (1518) | eamble, address, lea | ngth, and CRC fields. Should not |  |

| Network | Port B MII | Configuration Register (NBMCFR) (Address = 0x0250)             |  |  |  |  |
|---------|------------|----------------------------------------------------------------|--|--|--|--|
| Bit(s)  | Value      | Description                                                    |  |  |  |  |
| 7:5     |            | These bits are ignored and will always return zeros when read. |  |  |  |  |
| 4:2     | 000        | MII Management Clock is system clock divided by 4.             |  |  |  |  |
|         | 001        | This value is reserved and should not be used.                 |  |  |  |  |
|         | 010        | MII Management Clock is system clock divided by 6.             |  |  |  |  |
|         | 011        | MII Management Clock is system clock divided by 8.             |  |  |  |  |
|         | 100        | MII Management Clock is system clock divided by 10.            |  |  |  |  |
|         | 101        | MII Management Clock is system clock divided by 14.            |  |  |  |  |
|         | 110        | MII Management Clock is system clock divided by 20.            |  |  |  |  |
|         | 111        | MII Management Clock is system clock divided by 28.            |  |  |  |  |
| 1       | 0          | Enable MII frame preambles.                                    |  |  |  |  |
|         | 1          | Disable MII frame preambles.                                   |  |  |  |  |
| 0       | 0          | Disable MII scan function.                                     |  |  |  |  |
|         | 1          | Enable MII scan function.                                      |  |  |  |  |

| Netw   | Network Port B MII Reset Register |                                                                | (NBMRR) | (Address = 0x0251) |  |
|--------|-----------------------------------|----------------------------------------------------------------|---------|--------------------|--|
| Bit(s) | Value                             | Description                                                    |         |                    |  |
| 7      | 0                                 | No operation.                                                  |         |                    |  |
|        | 1                                 | Reset the MII management module.                               |         |                    |  |
| 6:0    |                                   | These bits are ignored and will always return zeros when read. |         |                    |  |

| Networ | k Port B M | I Command Register (NBMCR) (Address = 0x0252)                  |  |  |  |  |
|--------|------------|----------------------------------------------------------------|--|--|--|--|
| Bit(s) | Value      | Description                                                    |  |  |  |  |
| 7:2    |            | These bits are ignored and will always return zeros when read. |  |  |  |  |
| 1      | 0          | No operation.                                                  |  |  |  |  |
|        | 1          | Enable scan. MII module performs continuous read cycles.       |  |  |  |  |
| 0      | 0          | No operation.                                                  |  |  |  |  |
|        | 1          | Perform one MII read cycle.                                    |  |  |  |  |

| Network Po | Network Port B MII Register Address Register (NBMRAR) (Address = 0x0254) |                                                                |  |  |  |  |
|------------|--------------------------------------------------------------------------|----------------------------------------------------------------|--|--|--|--|
| Bit(s)     | Value Description                                                        |                                                                |  |  |  |  |
| 7:5        |                                                                          | These bits are ignored and will always return zeros when read. |  |  |  |  |
| 4:0        |                                                                          | MII register address.                                          |  |  |  |  |

| Network | Port B MII | PHY Address Register                                           | (NBMPAR) | (Address = 0x0255) |  |
|---------|------------|----------------------------------------------------------------|----------|--------------------|--|
| Bit(s)  | Value      | Description                                                    |          |                    |  |
| 7:5     |            | These bits are ignored and will always return zeros when read. |          |                    |  |
| 4:0     |            | MII PHY address.                                               |          |                    |  |

| Networ | Network Port B MII Write LSB Register |                        | (NBMWLR) | (Address = 0x0256) |
|--------|---------------------------------------|------------------------|----------|--------------------|
| Bit(s) | Value                                 | Description            |          |                    |
| 7:0    |                                       | LSB of MII write data. |          |                    |

| Networ | Network Port B MII Write MSB Register |                                                                              | (NBMWMR) | (Address = 0x0257) |
|--------|---------------------------------------|------------------------------------------------------------------------------|----------|--------------------|
| Bit(s) | Value                                 | Description                                                                  |          |                    |
| 7:0    |                                       | MSB of MII write data. Writing to this register triggers an MII write cycle. |          |                    |

| Network Port B MII Read LSB Register |       | (NBMRLR)              | (Address = 0x0258) |  |
|--------------------------------------|-------|-----------------------|--------------------|--|
| Bit(s)                               | Value |                       | Description        |  |
| 7:0                                  |       | LSB of MII read data. |                    |  |

| Network Port B MII Read MSB Register |       | (NBMRMR)              | (Address = 0x0259) |  |
|--------------------------------------|-------|-----------------------|--------------------|--|
| Bit(s)                               | Value | Description           |                    |  |
| 7:0                                  |       | MSB of MII read data. |                    |  |

| Netw   | ork Port B | MII Status Register (NBMSR) (Address = 0x025A)                 |  |  |  |
|--------|------------|----------------------------------------------------------------|--|--|--|
| Bit(s) | Value      | Description                                                    |  |  |  |
| 7:4    |            | These bits are ignored and will always return zeros when read. |  |  |  |
| 3      | 0          | MII link okay.                                                 |  |  |  |
|        | 1          | MII link fail.                                                 |  |  |  |
| 2      | 0          | MII read data valid.                                           |  |  |  |
|        | 1          | MII read data not valid.                                       |  |  |  |
| 1      | 0          | MII not busy scanning.                                         |  |  |  |
|        | 1          | MII scan operation in progress.                                |  |  |  |
| 0      | 0          | MII not busy performing a read or write cycle.                 |  |  |  |
|        | 1          | MII busy performing a read or write cycle.                     |  |  |  |

| Network Port B Station Address x Register |       | (NBSA0R)<br>(NBSA1R)<br>(NBSA2R)<br>(NBSA3R)<br>(NBSA4R)<br>(NBSA5R) | (Address = 0x0260)<br>(Address = 0x0261)<br>(Address = 0x0262)<br>(Address = 0x0263)<br>(Address = 0x0264)<br>(Address = 0x0265) |  |
|-------------------------------------------|-------|----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|--|
| Bit(s)                                    | Value | Description                                                          |                                                                                                                                  |  |
| 7:0                                       |       | Byte of physical address for transmit control frames.                |                                                                                                                                  |  |

| En     | able Netwo | ork Port Register                                                                                         | (ENPR)                | (Address = 0x0430) |  |  |
|--------|------------|-----------------------------------------------------------------------------------------------------------|-----------------------|--------------------|--|--|
| Bit(s) | Value      |                                                                                                           | Description           | 1                  |  |  |
| 7:6    | 00         | Disable both Network Por                                                                                  | t B and Network Por   | t C.               |  |  |
|        | 01         | Enable Network Port B (th                                                                                 | ne 10/100Base-T Eth   | ernet port).       |  |  |
|        | 10         | Enable Network Port C (the Wi-Fi port). This bit combination is forced whenever either SCFG pin is high.* |                       |                    |  |  |
|        | 11         | This bit combination is reserved and must not be used.                                                    |                       |                    |  |  |
| 5:2    | 0          | These bits are reserved and should be written with zeros.                                                 |                       |                    |  |  |
| 1:0    | 00         | Network Port C interrupts are disabled.                                                                   |                       |                    |  |  |
|        | 01         | Network Port C interrupts use Interrupt Priority 1.                                                       |                       |                    |  |  |
|        | 10         | Network Port C interrupts                                                                                 | use Interrupt Priorit | y 2.               |  |  |
|        | 11         | Network Port C interrupts                                                                                 | use Interrupt Priorit | y 3.               |  |  |

<sup>\*</sup> Customers wishing to incorporate the Wi-Fi peripheral in their own design should contact Rabbit for more information.

# 23. 802.11B/G WIRELESS

### 23.1 Overview

Network Port C implements an 802.11b/g compatible wireless LAN radio. It consists of a baseband processor, high-speed A/D and D/A converters, and an interface for one of several external radio-frequency (RF) transceivers. The external transceiver is responsible for the up-conversion and down-conversion of the RF signal.

The receiver and transmitter each have a 2048-byte FIFO that is shared with the Ethernet peripheral; the I/O pins are also shared. Because of this, only one of the two network peripherals can be enabled at any particular time.

Communication with the external transceiver is accomplished through a 3-wire serial interface. Support is also provided for a parallel automatic gain control feedback loop. Control for multiple antennas is available, providing support for separate receive and transmit antennas or switched antenna diversity reception.

The MAC processing is handed by a combination of the baseband processor and software on the Rabbit; any timing-critical MAC operations are handled automatically by the baseband. These operations include time management and transmission-interval spacing. The MAC also performs the CRC check of all received frames and handles the virtual carrier sense functionality.

The Rabbit 5000 supports both the infrastructure and the ad-hoc modes. Multicast transmissions are supported as well.

The external interface to the external transceiver consists of 20 digital pins and 8 analog pins. A 20 MHz clock is required as an input. A separate low-speed A/D converter is available to monitor the transmit power via software.

The wireless peripheral also contains an AES encryption/decryption engine for both transmitted and received packets. Up to four expanded keys can be stored in the peripheral at one time.

# 23.1.1 Block Diagram



# 23.1.2 Registers

| Register Name                             | Mnemonic | I/O Address | R/W | Reset    |
|-------------------------------------------|----------|-------------|-----|----------|
| Enable Network Port Register              | ENPR     | 0x0430      | R/W | 00000000 |
| Network Port C Version 0 Register         | NCV0R    | 0x0A00      | R   | 00000000 |
| Network Port C Version 1 Register         | NCV1R    | 0x0A01      | R   | 00000001 |
| Network Port C General Control 0 Register | NCGC0R   | 0x0A04      | R/W | 00000000 |
| Network Port C General Control 1 Register | NCGC1R   | 0x0A05      | R/W | 01000000 |
| Network Port C General Control 2 Register | NCGC2R   | 0x0A06      | R/W | 01111111 |
| Network Port C General Control 3 Register | NCGC3R   | 0x0A07      | R   | 00110111 |
| Network Port C General Status 0 Register  | NCGS0R   | 0x0A08      | R   | 00010000 |
| Network Port C General Status 1 Register  | NCGS1R   | 0x0A09      | R/W | 00000000 |
| Network Port C General Status 2 Register  | NCGS2R   | 0x0A0A      | R/W | 00000000 |
| Network Port C General Status 3 Register  | NCGS3R   | 0x0A0B      | R/W | 00110000 |
| Network Port C RSSI 0 Register            | NCRSSI0R | 0x0A0C      | R   | 01111111 |
| Network Port C RSSI 1 Register            | NCRSSI1R | 0x0A0D      | R   | 00000000 |
| Network Port C RSSI 2 Register            | NCRSSI2R | 0x0A0E      | R   | 00000000 |
| Network Port C RSSI 3 Register            | NCRSSI3R | 0x0A0F      | R   | 00000000 |
| Network Port C Interrupt Mask Register    | NCIMR    | 0x0A10      | R/W | 00000000 |
| Network Port C Interrupt Status Register  | NCISR    | 0x0A14      | R/W | 00000000 |
| Network Port C SPI Data 0 Register        | NCSPID0R | 0x0A18      | W   | 00000000 |
| Network Port C SPI Data 1 Register        | NCSPID1R | 0x0A19      | W   | 00000000 |
| Network Port C SPI Data 2 Register        | NCSPID2R | 0x0A1A      | W   | 00000000 |
| Network Port C SPI Data 3 Register        | NCSPID3R | 0x0A1B      | W   | 00000000 |
| Network Port C SPI Control Register       | NCSPICR  | 0x0A1C      | R/W | 00011000 |
| Network Port C Data FIFO 0 Register       | NCDFR    | 0x0A20      | R/W | 00000000 |
| Network Port C Configuration-1 Register 0 | NCC1R0   | 0x0A28      | R/W | 00101100 |
| Network Port C Configuration-1 Register 1 | NCC1R1   | 0x0A29      | R/W | 00000000 |
| Network Port C Configuration-1 Register 2 | NCC1R2   | 0x0A2A      | R/W | 01000011 |
| Network Port C Configuration-1 Register 3 | NCC1R3   | 0x0A2B      | R/W | 10000000 |
| Network Port C Configuration-2 Register 0 | NCC2R0   | 0x0A2C      | R/W | 00010100 |
| Network Port C Configuration-2 Register 1 | NCC2R1   | 0x0A2D      | R/W | 10110011 |
| Network Port C Configuration-2 Register 2 | NCC2R2   | 0x0A2E      | R/W | 10000010 |
| Network Port C Configuration-2 Register 3 | NCC2R3   | 0x0A2F      | R/W | 00001000 |
| Network Port C AES FIFO Register          | NCAFR    | 0x0A30      | R/W | xxxxxxxx |

| Register Name                               | Mnemonic   | I/O Address   | R/W | Reset    |
|---------------------------------------------|------------|---------------|-----|----------|
| Network Port C AES Mode Register            | NCAMR      | 0x0A38        | R/W | 00000000 |
| Network Port C Output Control Register 0    | NCOCR0     | 0x0A3C        | R/W | 00000001 |
| Network Port C Output Control Register 1    | NCOCR1     | 0x0A3D        | R/W | 00000000 |
| Network Port C Output Control Register 2    | NCOCR2     | 0x0A3E        | R/W | 00000000 |
| Network Port C Output Control Register 3    | NCOCR3     | 0x0A3F        | R/W | 00000000 |
| Network Port C Station ID x Register        | NCSTAIDxR  | 0x0A40-0x0A45 | R/W | xxxxxxx  |
| Network Port C BSS ID x Register            | NCBSSIDxR  | 0x0A48-0x0A4D | R/W | xxxxxxxx |
| Network Port C OFDM Basic Rate Set Register | NCOFDMBRSR | 0x0A50        | R/W | xxxxxxxx |
| Network Port C PSK Basic Rate Set Register  | NCPSKBRSR  | 0x0A51        | R/W | xxxxxxxx |
| Network Port C SSID Length Register         | NCSSIDLR   | 0x0A53        | R/W | xxxxxxxx |
| Network Port C Backoff 0 Register           | NCBO0R     | 0x0A56        | R/W | xxxxxxxx |
| Network Port C Backoff 1 Register           | NCBO1R     | 0x0A57        | R/W | xxxxxxxx |
| Network Port C DTIM Period Register         | NCDTIMPR   | 0x0A58        | R/W | xxxxxxxx |
| Network Port C CFP Period Register          | NCCFPPR    | 0x0A59        | R/W | xxxxxxxx |
| Network Port C Listen Interval 0 Register   | NCLI0R     | 0x0A5A        | R/W | xxxxxxxx |
| Network Port C Listen Interval 1 Register   | NCLI1R     | 0x0A5B        | R/W | xxxxxxxx |
| Network Port C Beacon Interval 0 Register   | NCBI0R     | 0x0A5C        | R/W | xxxxxxxx |
| Network Port C Beacon Interval 1 Register   | NCBI1R     | 0x0A5D        | R/W | xxxxxxxx |
| Network Port C CFP Max Duration 0 Register  | NCCFPMD0R  | 0x0A5E        | R/W | xxxxxxxx |
| Network Port C CFP Max Duration 1 Register  | NCCFPMD1R  | 0x0A5F        | R/W | xxxxxxxx |
| Network Port C MAC Status Register          | NCMACSR    | 0x0A6C        | R/W | xxxxxxxx |
| Network Port C MAC Control Register         | NCMACCR    | 0x0A67        | R/W | xxxxxxxx |
| Network Port C Remaining Backoff 0 Register | NCRBO0R    | 0x0A6A        | R/W | xxxxxxxx |
| Network Port C Remaining Backoff 1 Register | NCRBO1R    | 0x0A6B        | R/W | xxxxxxx  |
| Network Port C Beacon Filter Register       | NCBFR      | 0x0A6D        | R/W | xxxxxxx  |
| Network Port C Beacon Backoff 0 Register    | NCBBO0R    | 0x0A6E        | R/W | xxxxxxx  |
| Network Port C Beacon Backoff 1 Register    | NCBBO1R    | 0x0A6F        | R/W | xxxxxxx  |

# 23.2 Dependencies

# 23.2.1 I/O Pins

The wireless network port interface has 28 dedicated pins, as shown in Table 23-1. Of those, 20 are digital and can be used as general-purpose I/O via NBDRR, NBDTR, and NBDMR if the network port is not being used.

Table 23-1. Wireless Port Interface

| Block   | Section    | Signal   | Direction | Function                                                         |
|---------|------------|----------|-----------|------------------------------------------------------------------|
|         |            | VINQP    | Input     | O showed differential innet                                      |
|         |            | VINQN    | Input     | Q channel differential input                                     |
|         | Input      | VINIP    | Input     | I -1                                                             |
|         |            | VININ    | Input     | I channel differential input                                     |
| Analog  |            | VOUTPQ   | Output    | O show all differential autout                                   |
|         | Output     | VOUTNQ   | Output    | Q channel differential output                                    |
|         | Output     | VOUTPI   | Output    | I shownal differential output                                    |
|         |            | VOUTNI   | Output    | I channel differential output                                    |
|         | Clock      | CLK_IN   | Input     | 20 MHz clock input                                               |
|         | Auto Gain  | VGA[4:0] | Output    | Variable gain amplifier setting                                  |
|         | Correction | LNA[1:0] | Output    | Linear amplifier setting                                         |
|         |            | TX_ON    | Output    | Transmit enable                                                  |
|         |            | RX_ON    | Output    | Receive enable                                                   |
|         |            | LOCK     | Input     | Transceiver PLL lock input                                       |
|         |            | RXHP     | Output    | Reserved for future use, may be used as a general-purpose output |
|         | Control    | ANT_SEL  | Output    | Antenna select enable                                            |
| Digital |            | /ANT_SEL | Output    | Antenna select enable                                            |
|         |            | PA2G_ON  | Output    | 2G preamplifier enable                                           |
|         |            | PA5G_ON  | Output    | 5G preamplifier enable                                           |
|         |            | ACT_LED  | Output    | Activity LED control                                             |
|         |            | BOOTMUX  | Output    | General-purpose output                                           |
|         |            | SCLK     | Output    | 3-wire serial clock                                              |
|         | Management | SDATA    | Output    | 3-wire serial data                                               |
|         |            | /SEN     | Output    | 3-wire serial enable                                             |

### 23.3 Clocks

The wireless network port requires a 20 MHz clock input at CLK\_IN for proper operation.

# 23.3.1 Other Registers

| Register | Function                               |
|----------|----------------------------------------|
| EDMR     | Enable Wi-Fi functionality.            |
| NCWR     | Set Network Port C wait states (0–15). |

## 23.3.2 Interrupts

The wireless network interrupt can be generated for any of the following reasons.

- When data are available in the receive FIFO.
- When the transmit FIFO becomes empty.
- When a receive timeout occurs.
- When a transmit abort occurs.
- When an Announcement Traffic Indication Message (ATIM) is received.
- When the receive FIFO is overrun.
- When a complete packet is received.

The events that generate an interrupt can be selected in NCISR.

The wireless network port interrupt vector is shared with the Ethernet network port. It is located in the IIR at offset 0x1E0. It can be set as Priority 1, 2, or 3 by writing to ENPR.

# 23.4 Operation

At the present time, the wireless peripheral is intended to be used only in Rabbit-branded and other products offered by Digi International. The information provided in the *Rabbit* 5000 Microprocessor User's Manual should be sufficient to explain the operation of the wireless peripheral in these products. Customers wishing to incorporate the wireless peripheral in their own design should contact Rabbit for more information.

# 24. INPUT CAPTURE

### 24.1 Overview

The input capture peripheral consists of two channels, each of which contains a 16-bit counter and edge-detection circuitry. The input capture channels are usually used to determine the time between events. An event is signaled by a rising or falling edge (or optionally by either edge) on one of 12 input pins that can be selected as the input for either of the two channels. A digital low-pass filter is present on the inputs, as explained in Section 24.2.4.

Each channel can be used in one of two modes—input capture or input count. In the input-capture mode, the channel starts/stops the counter (clocked by Timer A8) according to the signal edges on various parallel port pins, providing the ability to measure pulse widths and time intervals between external events, time-stamp signal changes on a pin, and measure time intervals between a software start and an external event. An interrupt can also be generated when an edge is detected or when a counter rolls over

In the input-count mode the channel simply increments the counter each time a desired edge is detected. The start condition is enabled by the first Timer A8 clock after the mode is selected and the stop condition generated when the count matches the value written into the counter registers; this allows an interrupt to be generated when a particular count is reached.

A 16 bit counter is used to record the time at which the event takes place. The counter is driven by the output of Timer A8 and can be set to count at a rate ranging from the full clock speed (perclk/2) down to 1/256 the clock speed (perclk/512).

Two events are recognized: a *start condition* and a *stop condition*. The start condition may be used to start counting and the stop condition to stop counting. However, the counter may also run continuously or run until a stop condition is encountered. The start and stop conditions may also be used to latch the current time at the instant the condition occurs rather than actually start or stop the counter. The same pin may be used to detect the start and stop condition—for example a rising edge could be the start condition and a falling edge could be the stop condition. The start and stop condition can also be the input from separate pins.

The input capture channels can be used to measure the width of fast pulses. This is done by starting the counter on the first edge of the pulse and capturing the counter value on the second edge of the pulse. In this case the maximum error in the measurement is approximately 2 periods of the clock used to count the counter. If there is sufficient time between events for an interrupt to take place the unit can be set up to capture the counter value on

either start or stop conditions (or both) and cause an interrupt each time the count is captured. The counter can also be cleared and started under software control and then have its value captured in response to an input.

The capture counter can synchronized with Timer B outputs to load parallel port output registers. This makes it possible to generate an output signal precisely synchronized with an input signal. Usually it will be desired to synchronize one of the input capture counters with the Timer B counter. The count offset can be measured by outputting a pulse at a precise time using Timer B to set the output time and capturing the output pulse with an input capture channel. Once the phase relationship is known between the counters it is then possible to output pulses a precise time delay after an input pulse is captured, provided that the time delay is great enough for the interrupt routine to processes the capture event and set up the output pulse synchronized by Timer B. The minimum time delay needed is probably less than 10 µs if the software is done carefully and the clock speed is reasonably high.

### 24.1.1 Block Diagram



# 24.1.2 Registers

| Register Name                      | Mnemonic | I/O Address | R/W | Reset    |
|------------------------------------|----------|-------------|-----|----------|
| Input Capture Ctrl/Status Register | ICCSR    | 0x0056      | R/W | 00000000 |
| Input Capture Control Register     | ICCR     | 0x0057      | W   | 00000000 |
| Input Capture Trigger 1 Register   | ICT1R    | 0x0058      | R/W | 00000000 |
| Input Capture Source 1 Register    | ICS1R    | 0x0059      | R/W | xxxxxxxx |
| Input Capture LSB 1 Register       | ICL1R    | 0x005A      | R   | xxxxxxxx |
| Input Capture MSB 1 Register       | ICM1R    | 0x005B      | R   | xxxxxxx  |
| Input Capture Trigger 2 Register   | ICT2R    | 0x005C      | R/W | 00000000 |
| Input Capture Source 2 Register    | ICS2R    | 0x005D      | R/W | xxxxxxx  |
| Input Capture LSB 2 Register       | ICL2R    | 0x005E      | R   | xxxxxxx  |
| Input Capture MSB 2 Register       | ICM2R    | 0x005F      | R   | xxxxxxx  |

## 24.2 Dependencies

### 24.2.1 I/O Pins

Each input-capture channel can accept input from one of the following parallel port pins: PC1, PC3, PC5, PC7, PD1, PD3, PD5, PD7, PE1, PE3, PE5, PE7. Use ICTxR to select which input pin to trigger on.

Note that these pins can be used for other peripherals at the same time as the input-capture peripheral. For example, you can use input capture to use measure the pulse width on a serial port input to measure the baud rate.

#### 24.2.2 Clocks

The 16-bit input-capture counters are clocked from the output of Timer A8, and can run at rates from perclk/2 down to perclk/512 by writing the appropriate value to TAT8R.

# 24.2.3 Other Registers

| Register | Function                               |
|----------|----------------------------------------|
| TAT8R    | Time constant for input-capture clock. |

### 24.2.4 Interrupts

Each input capture channel can generate an interrupt whenever a start/stop condition occurs. The interrupt request is cleared when ICCSR is read.

The input capture interrupt vector is in the IIR at offset 0x1A0. It can be set as Priority 1, 2, or 3.

The input-capture channels synchronize their inputs to the peripheral clock (further divided by Timer A8). Since the inputs are only sampled in synch with the peripheral clock, any faster state faster changes cannot be detected, which is akin to a digital low-pass filter functionality on the inputs. Because of this, there is some delay between the input transition and when an interrupt is requested, as shown below. The status bits in ICSxR are set coincident with the interrupt request and are reset when read from the ICSxR.



# 24.3 Operation

### 24.3.1 Input-Capture Channel

The following steps explain how to set up an input-capture channel.

- 1. Configure Timer A8 via TAT8R to provide the desired input-capture clock.
- 2. Configure ICTxR to provide the desired start/stop operation and conditions.
- 3. Configure ICSxR to select the input pins for the start and stop conditions.
- 4. Configure ICCR to select either the count or the capture mode.
- 5. Reset the counter by writing to ICCSR.

### 24.3.2 Handling Interrupts

The following steps explain how an interrupt is used.

- 1. Write the vector to the interrupt service routine to the internal interrupt table
- 2. Configure the Input Capture Control/Status Register (ICCSR) to select events that will generate an interrupt.
- 3. Configure the Input Capture Control Register (ICCR) to select the interrupt priority (note that interrupts will be enabled once this value is set; this step should be done last).

The following actions occur within the interrupt service routine.

- If needed, the current counter value can be read from ICLxR and LCMxR (reading from ICLxR latches the value of ICLxR, so ICLxR should always be read first)
- If the counter is expected to roll over, determine if that is why the interrupt occurred by reading the status bits in ICCSR and adjusting any software counters accordingly
- The interrupt request should be cleared by reading from ICCSR

## 24.3.3 Example ISR

A sample interrupt handler is shown below.

```
ic_isr::
   push af
   ioi ld a, (ICCSR)    ; clear the interrupt request and get status
   ; determine which interrupts have occurred
   ; if rollover, perform any necessary software counter adjustments here
   ; read counter values
   pop af
   ipres
   ret
```

### 24.3.4 Capture Mode

#### **Pulse Width or Time Between Events**

The following steps explain how to measure the pulse width or time between events.

- 1. Select the same input pin to perform a pulse-width measurement between the start and stop conditions, or select two different input pins to measure time between events on those pins.
- 2. Set the counter to start on the start condition and stop on the stop condition, latch on the stop condition, and generate an interrupt on the stop condition.
- 3. In the interrupt handler, read out the counter to determine the pulse width or time interval between the two events.

### **Time-Stamp External Events**

The following steps explain how to time-stamp external events.

- 1. Set the trigger for the desired event type.
- 2. Set the counter to run continuously, latch on the start (and/or stop) condition, and generate an interrupt on the start (and/or stop) condition
- 3. In the interrupt handler, read out the counter as an event timestamp.

#### Measure Time Interval from a Software Start to an External Event

The following steps explain how to measure the time interval between a software start and the occurrence of an external event.

- 1. Set up the counter to run continuously, latch on the stop condition, and generate an interrupt on the stop condition.
- 2. Set up the stop condition for the event of interest.
- 3. Reset the counter via ICCSR at the software start.
- 4. In the interrupt handler, read the counter as a time duration.

#### 24.3.5 Count Mode

The following steps explain how to count pulses when count mode is selected:

- 1. Set the ICTxR register for the counter to run continuously and to latch the count on either the start or stop condition.
- 2. If an interrupt is desired at a particular count, write that value into the LSB and MSB registers.
- 3. Set the start condition for the pulse type desired.
- 4. Reset the counter by writing to ICCSR.
- 5. Reading the latch registers at any time after an initial start pulse is received will return the current count. Until an initial start pulse is received, the latch registers will have a residual value.

# 24.4 Register Descriptions

| Input C       | apture Co | entrol/Status Register (ICCSR) (Address = 0x0056)                                                                                  |  |
|---------------|-----------|------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit(s)        | Value     | Description                                                                                                                        |  |
| 7             | 0         | The Input Capture 2 Start condition has not occurred.                                                                              |  |
| (Read)        | 1         | The Input Capture 2 Start condition has occurred.                                                                                  |  |
| 6             | 0         | The Input Capture 2 Stop condition has not occurred.                                                                               |  |
| (Read)        | 1         | The Input Capture 2 Stop condition has occurred.                                                                                   |  |
| 5             | 0         | The Input Capture 1 Start condition has not occurred.                                                                              |  |
| (Read)        | 1         | The Input Capture 1 Start condition has occurred.                                                                                  |  |
| 4             | 0         | The Input Capture 1 Stop condition has not occurred.                                                                               |  |
| (Read)        | 1         | The Input Capture 1 Stop condition has occurred.                                                                                   |  |
| 3             | 0         | The Input Capture 2 counter has not rolled over to all zeros.                                                                      |  |
| (Read)        | 1         | The Input Capture 2 counter has rolled over to all zeros.                                                                          |  |
| 2             | 0         | The Input Capture 1 counter has not rolled over to all zeros.                                                                      |  |
| (Read)        | 1         | The Input Capture 1 counter has rolled over to all zeros.                                                                          |  |
| 7:2<br>(Read) |           | These status bits (but not the interrupt enable bits) are cleared by the read of this register, as is the Input Capture Interrupt. |  |
| 7:4           | 0         | The corresponding Input Capture interrupt is disabled.                                                                             |  |
| (Write)       | 1         | The corresponding Input Capture interrupt is enabled.                                                                              |  |
| 3             | 0         | No effect on Input Capture 2 counter. This bit always reads as zero.                                                               |  |
| (Write)       | 1         | Reset Input Capture 2 counter to all zeros and clears the rollover latch.                                                          |  |
| 2             | 0         | No effect on Input Capture 1 counter. This bit always reads as zero.                                                               |  |
| (Write)       | 1         | Reset Input Capture 1 counter to all zeros and clears the rollover latch.                                                          |  |
| 1:0           |           | These bits are reserved and should be written with zeros. These bits will always be read as zeros.                                 |  |

| Inp    | ut Capture | e Control Register (ICCR) (Address = 0x0057)             |  |
|--------|------------|----------------------------------------------------------|--|
| Bit(s) | Value      | Description                                              |  |
| 7      | 0          | Input Capture operation for Input Capture 2.             |  |
|        | 1          | Input Count operation for Input Capture 2.               |  |
| 6      | 0          | Input Capture operation for Input Capture 1.             |  |
|        | 1          | Input Count operation for Input Capture 1.               |  |
| 5:2    |            | These bits are reserved and should be written with zero. |  |
| 1:0    | 00         | Input Capture interrupts are disabled.                   |  |
|        | 01         | Input Capture interrupt use Interrupt Priority 1.        |  |
|        | 10         | Input Capture interrupt use Interrupt Priority 2.        |  |
|        | 11         | Input Capture interrupt use Interrupt Priority 3.        |  |

| Inpu   | ıt Capture | Trigger x Register (ICT1R) (Address = 0x0058) (ICT2R) (Address = 0x005C)                                                                   |  |  |
|--------|------------|--------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit(s) | Value      | Description                                                                                                                                |  |  |
| 7:6    | 00         | Disable the counter. Applies even in Counter operation.                                                                                    |  |  |
|        | 01         | The counter runs from the Start condition until the Stop condition.                                                                        |  |  |
|        | 10         | The counter runs continuously.                                                                                                             |  |  |
|        | 11         | The counter runs continuously, until the Stop condition.                                                                                   |  |  |
| 5:4    | 00         | Disable the count latching function. In this case, and with Counter operation only, the ICLxR and ICMxR return the programmed match value. |  |  |
|        | 01         | Latch the count on the Stop condition only.                                                                                                |  |  |
|        | 10         | Latch the count on the Start condition only.                                                                                               |  |  |
|        | 11         | Latch the count on either the Start or Stop condition.                                                                                     |  |  |
| 3:2    | 00         | Ignore the starting input.                                                                                                                 |  |  |
|        | 01         | The Start condition is the rising edge of the starting input.                                                                              |  |  |
|        | 10         | The Start condition is the falling edge of the starting input.                                                                             |  |  |
|        | 11         | The Start condition is either edge of the starting input.                                                                                  |  |  |
| 1:0    | 00         | Ignore the ending input. These two bits are ignored in Counter operation.                                                                  |  |  |
|        | 01         | The Stop condition is the rising edge of the ending input.                                                                                 |  |  |
|        | 10         | The Stop condition is the falling edge of the ending input.                                                                                |  |  |
|        | 11         | The Stop condition is either edge of the ending input.                                                                                     |  |  |

| Inpi   | ut Capture | Source x Register (ICS1R) (Address = (ICS2R) (Address =  | •                                               |  |
|--------|------------|----------------------------------------------------------|-------------------------------------------------|--|
| Bit(s) | Value      | Description                                              |                                                 |  |
| 7:6    | 00         | Parallel Port C used for Start condition input.          | Parallel Port C used for Start condition input. |  |
|        | 01         | Parallel Port D used for Start condition input.          |                                                 |  |
|        | 10         | Parallel Port E used for Start condition input.          |                                                 |  |
|        | 11         | This bit combination is reserved and should not be used. |                                                 |  |
| 5:4    | 00         | Use port bit 1 for Start condition input.                |                                                 |  |
|        | 01         | Use port bit 3 for Start condition input.                |                                                 |  |
|        | 10         | Use port bit 5 for Start condition input.                |                                                 |  |
|        | 11         | Use port bit 7 for Start condition input.                |                                                 |  |
| 3:2    | 00         | Parallel Port C used for Stop condition input.           |                                                 |  |
|        | 01         | Parallel Port D used for Stop condition input.           |                                                 |  |
|        | 10         | Parallel Port E used for Stop condition input.           |                                                 |  |
|        | 11         | This bit combination is reserved and should not be used. |                                                 |  |
| 1:0    | 00         | Use port bit 1 for Stop condition input.                 |                                                 |  |
|        | 01         | Use port bit 3 for Stop condition input.                 |                                                 |  |
|        | 10         | Use port bit 5 for Stop condition input.                 | Use port bit 5 for Stop condition input.        |  |
|        | 11         | Use port bit 7 for Stop condition input.                 |                                                 |  |

| In     | out Capture | e LSB x Register                                                                                                                                                                                                                                                                                                                                              | (ICL1R)<br>(ICL2R)        | (Address = 0x005A)<br>(Address = 0x005E) |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|------------------------------------------|
| Bit(s) | Value       |                                                                                                                                                                                                                                                                                                                                                               | Description               |                                          |
| 7:0    | Read        | The least significant eight bits of the latched Input Capture count are returned. Reading the LSB of the count latches the MSB of the count to avoid reading stale data. Reading the MSB of the count opens these latches on the MSB of the count In Counter operation, if no latching condition is specified the value written to this register is returned. |                           |                                          |
|        | Write       | The eight LSBs of the r                                                                                                                                                                                                                                                                                                                                       | natch value for counter i | mode are stored.                         |

| Inp    | out Capture | e MSB x Register                                                                                                                                                                             | (ICM1R)<br>(ICM2R) | (Address = 0x005B)<br>(Address = 0x005F) |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|------------------------------------------|
| Bit(s) | Value       | Description                                                                                                                                                                                  |                    |                                          |
| 7:0    | Read        | The most significant eight bits of the latched Input capture count are returned. In Counter operation, if no latching condition is specified the value written to this register is returned. |                    |                                          |
|        | Write       | The eight MSBs of the match value for counter mode are stored.                                                                                                                               |                    |                                          |

# 25. QUADRATURE DECODER

#### 25.1 Overview

The Rabbit 5000 has a two-channel Quadrature Decoder that accepts inputs via specific pins on Parallel Ports D and E. Each channel has two inputs, the in-phase (I) input and the 90 degree or quadrature-phase (Q) input. An 8 or 10-bit up/down counter counts encoder steps in the forward and backward directions, and provides interrupts when the count goes from 0x00 to 0xFF or from 0xFF to 0x00. An interrupt can occur each time the count overflows or underflows. The Quadrature Decoder contains digital filters on the inputs to prevent false counts. The external signals are synchronized with an internal clock provided by the output of Timer A10.

Each Quadrature Decoder channel accepts inputs from either the upper nibble or lower nibble of Parallel Ports D and E. The I signal is input on an odd-numbered port bit, while the Q signal is input on an even-numbered port bit. There is also a disable selection, which is guaranteed not to generate a count increment or decrement on either entering or exiting the disabled state.

The operation of the counter as a function of the I and Q inputs is shown below.



The Quadrature Decoders are clocked by the output of Timer A10, giving a maximum clock rate from perclk/2 down to perclk/512. The time constant of Timer A10 must be fast enough to sample the inputs properly. Both the I and Q inputs go through a digital filter that rejects pulses shorter than two clock period wide. In addition, the clock rate must be high enough that transitions on the I and Q inputs are sampled in different clock cycles. Input capture may be used to measure the pulse width on the I inputs because they come from the odd-numbered port bits. The operation of the digital filter is shown below.



The Quadrature Decoder generates an interrupt when the counter increments from 0xFF (0x3FF in 10-bit mode) to 0x00, or when the counter decrements from 0x00 to 0xFF (0x3FF in 10-bit mode). The timing for the interrupt is shown below. Note that the status bits in the QDCSR are set coincident with the interrupt, and the interrupt and status bits are cleared by reading the QDCSR.



# 25.1.1 Block Diagram



# 25.1.2 Registers

| Register Name                     | Mnemonic | I/O Address | R/W | Reset    |
|-----------------------------------|----------|-------------|-----|----------|
| Quad Decode Ctrl/Status Register  | QDCSR    | 0x0090      | R/W | xxxxxxxx |
| Quad Decode Control Register      | QDCR     | 0x0091      | R/W | 00000000 |
| Quad Decode Count 1 Register      | QDC1R    | 0x0094      | R   | xxxxxxx  |
| Quad Decode Count 1 High Register | QDC1HR   | 0x0095      | R   | xxxxxxxx |
| Quad Decode Count 2 Register      | QDC2R    | 0x0096      | R   | xxxxxxx  |
| Quad Decode Count 2 High Register | QDC2HR   | 0x0097      | R   | xxxxxxx  |

### 25.2 Dependencies

### 25.2.1 I/O Pins

Each Quadrature Decoder channel can accept the two encoder inputs from one of three different locations, as shown in the table below. Each channel can select a different input option. Note that these pins can be used for other peripherals at the same time as the Quadrature Decoder peripheral; one example of this use is to use measure pulse width on the I channels with the input capture peripheral.

| Inputs   | Chan | nel 1 | Chan | nel 2 |
|----------|------|-------|------|-------|
| iliputs  | ı    | Q     | - I  | Q     |
| Option 1 | PD1  | PD0   | PD3  | PD2   |
| Option 2 | PE1  | PE0   | PE3  | PE2   |
| Option 3 | PE5  | PE4   | PE7  | PE6   |

#### 25.2.2 Clocks

The 8/10-bit Quadrature Decoder counters are clocked from the output of Timer A10, and can run at rates from the peripheral clock divided by 2 down to the peripheral clock divided by 512 by writing the appropriate value to TAT10R. The clock rate must be high enough that transitions on the inputs are sampled in different clock cycles. In addition, both the I and Q inputs go through a digital filter that rejects pulses shorter than two clock periods wide.

## 25.2.3 Other Registers

| Register | Function                                   |
|----------|--------------------------------------------|
| TAT10R   | Time constant for Quadrature Decoder clock |

## 25.2.4 Interrupts

Each Quadrature Decoder channel can generate an interrupt whenever the counter increments from 0x0FF (0x3FF in 10-bit mode) to 0x00 or when the counter decrements from 0x000 to 0x0FF (0x3FF for 10-bit mode). The interrupt request is cleared when QDCSR is read.

The Quadrature Decoder interrupt vector is in the IIR at offset 0x190. It can be set as Priority 1, 2, or 3.

The status bits in the QDCSR are set coincident with the interrupt request and are reset when QDCSR is read.

# 25.3 Operation

The following steps explain how to set up a Quadrature Decoder channel.

- 1. Configure Timer A10 via TAT10R to provide the desired Quadrature Decoder clock speed.
- 2. Configure QDCR to select the input pins for the two channels.
- 3. Reset the counters by writing to QDCSR.

### 25.3.1 Handling Interrupts

The following steps explain how an interrupt is set up and used.

- 1. Write the vector to the interrupt service routine to the internal interrupt table.
- 2. Configure QDCR to select the interrupt priority (note that interrupts will be enabled once this value is set).

The following actions occur within the interrupt service routine.

- Since a Quadrature Decoder interrupt occurs when the counter rolls over, determine exactly why the interrupt occurred by reading the status bits in QDCSR and adjust any software counters accordingly. This will also clear the interrupt request.
- The current counter value can be read from QDCxR (and QDCxHR if the 10-bit counter is enabled).

### 25.3.2 Example ISR

A sample interrupt handler is shown below.

# 25.4 Register Descriptions

| Quad E           | Decode Co | ontrol/Status Register (QDCSR) (Address = 0x0090)                                                                |  |
|------------------|-----------|------------------------------------------------------------------------------------------------------------------|--|
| Bit(s)           | Value     | Description                                                                                                      |  |
| 7                | 0         | Quadrature Decoder 2 did not increment from the maximum count.                                                   |  |
| (Read-<br>only)  | 1         | Quadrature Decoder 2 incremented from the maximum count to 0x000. This bit is cleared by a read of his register. |  |
| 6                | 0         | Quadrature Decoder 2 did not decrement from zero.                                                                |  |
| (Read-<br>only)  | 1         | Quadrature Decoder 2 decremented from zero to the maximum count. This bit is cleared by a read of this register. |  |
| 5                |           | This bit always reads as zero.                                                                                   |  |
| 4                | 0         | No effect on the Quadrature Decoder 2.                                                                           |  |
| (Write-<br>only) | 1         | Reset Quadrature Decoder 2 to all zeros, without causing an interrupt.                                           |  |
| 3                | 0         | Quadrature Decoder 1 did not increment from the maximum count.                                                   |  |
| (Read-<br>only)  | 1         | Quadrature Decoder 1 incremented from the maximum count to zero. This bit is cleared by a read of this register. |  |
| 2                | 0         | Quadrature Decoder 1 did not decrement from zero.                                                                |  |
| (Read-<br>only)  | 1         | Quadrature Decoder 1 decremented from zero to the maximum count. This bit is cleared by a read of this register. |  |
| 1                |           | This bit always reads as zero.                                                                                   |  |
| 0                | 0         | No effect on the Quadrature Decoder 1.                                                                           |  |
| (Write-only)     | 1         | Reset Quadrature Decoder 1 to all zeros, without causing an interrupt.                                           |  |

| Qu     | ad Decode | Control Register                                                                                                                      | (QDCR)                                                                                                                                | (Address = 0x0091) |  |  |  |
|--------|-----------|---------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|--------------------|--|--|--|
| Bit(s) | Value     |                                                                                                                                       | Description                                                                                                                           |                    |  |  |  |
| 7:6    | 00        | -                                                                                                                                     | Disable Quadrature Decoder 2 inputs. Writing a new value to these bits will not cause Quadrature Decoder 2 to increment or decrement. |                    |  |  |  |
|        | 01        | Quadrature Decoder 2 inpu                                                                                                             | ts from Parallel Port                                                                                                                 | D bits 3 and 2.    |  |  |  |
|        | 10        | Quadrature Decoder 2 inpu                                                                                                             | ts from Parallel Port                                                                                                                 | E bits 3 and 2.    |  |  |  |
|        | 11        | Quadrature Decoder 2 inpu                                                                                                             | ts from Parallel Port                                                                                                                 | E bits 7 and 6.    |  |  |  |
| 5      | 0         | Eight bit quadrature decode                                                                                                           | Eight bit quadrature decoder counters (both channels).                                                                                |                    |  |  |  |
|        | 1         | Ten bit quadrature decoder                                                                                                            | Ten bit quadrature decoder counters (both channels).                                                                                  |                    |  |  |  |
| 4      |           | This bit is reserved and should be written as zero.                                                                                   |                                                                                                                                       |                    |  |  |  |
| 3:2    | 00        | Disable Quadrature Decoder 1 inputs. Writing a new value to these bits will not cause Quadrature Decoder 1 to increment or decrement. |                                                                                                                                       |                    |  |  |  |
|        | 01        | Quadrature Decoder 1 inputs from Parallel Port D bits 1 and 0.                                                                        |                                                                                                                                       |                    |  |  |  |
|        | 10        | Quadrature Decoder 1 inputs from Parallel Port E bits 1 and 0.                                                                        |                                                                                                                                       |                    |  |  |  |
|        | 11        | Quadrature Decoder 1 inputs from Parallel Port E bits 5 and 4.                                                                        |                                                                                                                                       |                    |  |  |  |
| 1:0    | 00        | Quadrature Decoder interrupts are disabled.                                                                                           |                                                                                                                                       |                    |  |  |  |
|        | 01        | Quadrature Decoder interru                                                                                                            | Quadrature Decoder interrupt use Interrupt Priority 1.                                                                                |                    |  |  |  |
|        | 10        | Quadrature Decoder interru                                                                                                            | pt use Interrupt Prio                                                                                                                 | ority 2.           |  |  |  |
|        | 11        | Quadrature Decoder interru                                                                                                            | pt use Interrupt Prio                                                                                                                 | ority 3.           |  |  |  |

| Quad Decode Count Register |       | (QDC1R)<br>(QDC2R)                                                           | (Address = 0x0094)<br>(Address = 0x0096) |  |  |
|----------------------------|-------|------------------------------------------------------------------------------|------------------------------------------|--|--|
| Bit(s)                     | Value | Description                                                                  |                                          |  |  |
| 7:0                        | Read  | The current value of bits 7-0 of the Quadrature Decoder counter is reported. |                                          |  |  |

| Quad Decode Count High Register |       | (QDC1HR)<br>(QDC2HR)                                   | (Address = 0x0095)<br>(Address = 0x0097) |                              |
|---------------------------------|-------|--------------------------------------------------------|------------------------------------------|------------------------------|
| Bit(s)                          | Value | Description                                            |                                          |                              |
| 7:2                             | Read  | These bits are reserved and will always read as zeros. |                                          |                              |
| 1:0                             | Read  | The current value of bits                              | 9-8 of the Quadrature I                  | Decoder counter is reported. |

# 26. Pulse Width Modulator

#### 26.1 Overview

The Pulse Width Modulator (PWM) consists of a 10-bit free running counter and four width registers. A PWM output consists of a train of periodic pulses within a 1024-count frame with a duty cycle that varies from 1/1024 to 1024/1024. Each PWM output is high for n + 1 counts out of the 1024-clock count cycle, where n is the value held in the width register. Any changes to the width registers will not take effect until the next counter roll-over. The PWM is clocked by the output of Timer A9 which is used to set the period.

Each PWM output high time can optionally be spread throughout the cycle to reduce ripple on the externally filtered PWM output. The PWM outputs can be passed through a filter and used as a 10-bit D/A converter. The outputs can also be used to directly drive devices such as motors or solenoids that have intrinsic filtering.

The PWM outputs can trigger a PWM interrupt on every PWM cycle, every other cycle, every fourth cycle, or every eighth cycle. In addition, the PWM output can be suppressed every other cycle, three out of every four cycles, or seven out of every eight cycles. These options provide support for driving servos and to generate audio signals. The setup for this interrupt is done in the PWL0R and PWL1R registers. The timing is shown below.



The spreading function is implemented by dividing each 1024-clock cycle into four quadrants of 256 clocks each. Within each quadrant, the Pulse-Width Modulator uses the eight MSBs of each pulse-width register to select the base width in each of the quadrants. This is the equivalent to dividing the contents of the pulse-width register by four and using this value in each quadrant. To get the exact high time, the Pulse-Width Modulator uses the two LSBs of the pulse-width register to modify the high time in each quadrant according to the table below. The "n/4" term is the base count, formed from the eight MSBs of the pulse-width register.

| Pulse-Width LSBs | 1st     | 2nd     | 3rd     | 4th     |
|------------------|---------|---------|---------|---------|
| 00               | n/4 + 1 | n/4     | n/4     | n/4     |
| 01               | n/4 + 1 | n/4     | n/4 + 1 | n/4     |
| 10               | n/4 + 1 | n/4 + 1 | n/4 + 1 | n/4     |
| 11               | n/4 + 1 | n/4 + 1 | n/4 + 1 | n/4 + 1 |

The diagram below shows a PWM output for several different width values, for both modes of operation. Operation in the spread mode reduces the filtering requirements on the PWM output in most cases.



The DMA channels on the Rabbit 5000 are designed to work with fixed I/O addresses. To allow DMA control of the PWM, a separate PWM Block Access Register (PWBAR) and PWM Block Pointer Register (PWBPR) are available. The pointer register contains the address of the PWM register to be accessed via the access register. Each read or write of the access register automatically increments the pointer register through the sequence shown below. Note that only the lower three bits of the pointer register actually change. This allows the DMA to write to a fixed internal I/O location but still program all of the PWM registers. The pointer register can be written and read if necessary. Normally the

pointer register is initialized to 0x88 (the first PWM register) and the DMA then transfers blocks of eight bytes to completely reprogram the PWM.

$$0x88 \rightarrow 0x89 \rightarrow 0x8A \rightarrow 0x8B \rightarrow 0x8C \rightarrow 0x8D \rightarrow 0x8E \rightarrow 0x8F \rightarrow$$

When the DMA destination address is the PWBAR, the DMA request from the PWM is automatically connected to the DMA.

# 26.1.1 Block Diagram



# 26.1.2 Registers

| Register Name              | Mnemonic | I/O Address | R/W | Reset    |
|----------------------------|----------|-------------|-----|----------|
| PWM LSB 0 Register         | PWL0R    | 0x0088      | R/W | xxxxx00x |
| PWM MSB 0 Register         | PWM0R    | 0x0089      | R/W | xxxxxxx  |
| PWM LSB 1 Register         | PWL1R    | 0x008A      | R/W | xxxxx00x |
| PWM MSB 1 Register         | PWM1R    | 0x008B      | R/W | xxxxxxx  |
| PWM LSB 2 Register         | PWL2R    | 0x008C      | R/W | xxxxx00x |
| PWM MSB 2 Register         | PWM2R    | 0x008D      | R/W | xxxxxxx  |
| PWM LSB 3 Register         | PWL3R    | 0x008E      | R/W | xxxxx00x |
| PWM MSB 3 Register         | PWM3R    | 0x008F      | R/W | xxxxxxx  |
| PWM Block Access Register  | PWBAR    | 0x00E8      | W   | xxxxxxx  |
| PWM Block Pointer Register | PWBPR    | 0x00E9      | W   | 10001000 |

## 26.2 Dependencies

### 26.2.1 I/O Pins

Each PWM channel can be output on up one of three pins, which can be selected via the parallel port alternate output registers.

| PWM       | Output Pins        |
|-----------|--------------------|
| Channel 0 | PC4, PD4, PE4, PH4 |
| Channel 1 | PC5, PD5, PE5, PH5 |
| Channel 2 | PC6, PD6, PE6, PH6 |
| Channel 3 | PC7, PD7, PE7, PH7 |

#### 26.2.2 Clocks

The PWM counter is clocked from the output of Timer A9, and can run at rates from perclk/2 down to perclk/512 by writing the appropriate value to TAT9R.

# 26.2.3 Other Registers

| Register                                                 | Function                        |
|----------------------------------------------------------|---------------------------------|
| TAT9R                                                    | Time constant for PWM clock     |
| PCFR, PCAHR<br>PDFR, PDAHR<br>PEFR, PEAHR<br>PHFR, PHAHR | Alternate port output selection |

### 26.2.4 Interrupts

The PWM can generate an interrupt for every PWM counter rollover, every second rollover, every fourth rollover, or every eighth rollover. This option is selected in PWL1R. The interrupt request is cleared by a write to any PWM register.

The PWM interrupt vector is in the IIR at offset 0x170. It can be set as Priority 1, 2, or 3 by writing to PWL0R.

# 26.3 Operation

The following steps explain how to set up a PWM channel.

- 1. Configure Timer A9 via TAT9R to provide the desired PWM clock frequency.
- 2. Configure PWLxR to select whether to spread the PWM output throughout the cycle.
- 3. Configure PWLxR to select whether to suppress the PWM output.
- 4. Configure the duty cycle by writing to PWLxR and PWMxR. Note that any changes to these registers while the PWM is active will not take effect until the next counter rollover.

### 26.3.1 Handling Interrupts

The following steps explain how an interrupt is set up and used.

- 1. Write the vector to the interrupt service routine to the internal interrupt table.
- 2. Configure PWL0R to select the PWM interrupt priority and PWL1R to select PWM interrupt suppression (if an interrupt is desired).

The following actions occur within the interrupt service routine.

- Any PWM values may be updated.
- The interrupt request should be cleared by writing to any PWM register.

### 26.3.2 Example ISR

A sample interrupt handler is shown below.

# 26.4 Register Descriptions

|        | PWM LS | B 0 Register (PWL0R) (Address = 0x0088)                           |  |  |  |  |
|--------|--------|-------------------------------------------------------------------|--|--|--|--|
| Bit(s) | Value  | Description                                                       |  |  |  |  |
| 7:6    |        | Least significant two bits for the Pulse Width Modulator count.   |  |  |  |  |
| 5:4    | 00     | Normal PWM operation.                                             |  |  |  |  |
|        | 01     | Suppress PWM output seven out of eight iterations of PWM counter. |  |  |  |  |
|        | 10     | Suppress PWM output three out of four iterations of PWM counter.  |  |  |  |  |
|        | 11     | Suppress PWM output one out of two iterations of PWM counter.     |  |  |  |  |
| 3      |        | This bit is ignored and should be written with zero.              |  |  |  |  |
| 2:1    | 00     | Pulse Width Modulator interrupts are disabled.                    |  |  |  |  |
|        | 01     | Pulse Width Modulator interrupts use Interrupt Priority 1.        |  |  |  |  |
|        | 10     | Pulse Width Modulator interrupts use Interrupt Priority 2.        |  |  |  |  |
|        | 11     | Pulse Width Modulator interrupts use Interrupt Priority 3.        |  |  |  |  |
| 0      | 0      | PWM output High for single block.                                 |  |  |  |  |
|        | 1      | Spread PWM output throughout the cycle.                           |  |  |  |  |

|        | PWM LS | SB 1 Register (PWL1R) (Address = 0x008A)                              |  |  |  |  |  |
|--------|--------|-----------------------------------------------------------------------|--|--|--|--|--|
| Bit(s) | Value  | Description                                                           |  |  |  |  |  |
| 7:6    |        | Least significant two bits for the Pulse Width Modulator count.       |  |  |  |  |  |
| 5:4    | 00     | Normal PWM operation.                                                 |  |  |  |  |  |
|        | 01     | Suppress PWM output seven out of eight iterations of PWM counter.     |  |  |  |  |  |
|        | 10     | Suppress PWM output three out of four iterations of PWM counter.      |  |  |  |  |  |
|        | 11     | Suppress PWM output one out of two iterations of PWM counter.         |  |  |  |  |  |
| 3      |        | This bit is ignored and should be written with zero.                  |  |  |  |  |  |
| 2:1    | 00     | Normal PWM interrupt operation.                                       |  |  |  |  |  |
|        | 01     | Suppress PWM interrupts seven out of eight iterations of PWM counter. |  |  |  |  |  |
|        | 10     | Suppress PWM interrupts three out of four iterations of PWM counter.  |  |  |  |  |  |
|        | 11     | Suppress PWM interrupts one out of two iterations of PWM counter.     |  |  |  |  |  |
| 0      | 0      | PWM output High for single block.                                     |  |  |  |  |  |
|        | 1      | Spread PWM output throughout the cycle.                               |  |  |  |  |  |

|        | PWM LS | B x Register                                                      | (PWL2R)<br>(PWL3R)                | (Address = 0x008C)<br>(Address = 0x008E) |  |  |
|--------|--------|-------------------------------------------------------------------|-----------------------------------|------------------------------------------|--|--|
| Bit(s) | Value  |                                                                   | Description                       |                                          |  |  |
| 7:6    |        | Least significant two bits for the Pulse Width Modulator count.   |                                   |                                          |  |  |
| 5:4    | 00     | Normal PWM operation.                                             |                                   |                                          |  |  |
|        | 01     | Suppress PWM output seven out of eight iterations of PWM counter. |                                   |                                          |  |  |
|        | 10     | Suppress PWM output three out of four iterations of PWM counter.  |                                   |                                          |  |  |
|        | 11     | Suppress PWM output one out of two iterations of PWM counter.     |                                   |                                          |  |  |
| 3:1    |        | These bits are ignored and should be written with zero.           |                                   |                                          |  |  |
| 0      | 0      | PWM output High for                                               | PWM output High for single block. |                                          |  |  |
|        | 1      | Spread PWM output to                                              | hroughout the cycle.              |                                          |  |  |

| PWM MSB x Register |       | (PWM0R)<br>(PWM1R)<br>(PWM2R)<br>(PWM3R)                                                                                                                                        | (Address = 0x0089)<br>(Address = 0x008B)<br>(Address = 0x008D)<br>(Address = 0x008F) |  |  |
|--------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|--|--|
| Bit(s)             | Value | Description                                                                                                                                                                     |                                                                                      |  |  |
| 7:0                |       | Most significant eight bits for the Pulse Width Modulator count. With a count of "n", the PWM output will be High for "n + 1" clocks out of the 1024 clocks of the PWM counter. |                                                                                      |  |  |

| PV     | PWM Block Access Register |                                                                                                                                       | (PWBAR) | (Address = 0x00E8) |  |
|--------|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------|---------|--------------------|--|
| Bit(s) | Value                     | Description                                                                                                                           |         |                    |  |
| 7:0    |                           | Access the PWM register pointed to by the PWBPR. The PWBPR is automatically updated to the next PWM register address in the sequence. |         |                    |  |

| PWM Block Pointer Register |       | Pointer Register                                                              | (PWBPR) | (Address = 0x00E9) |
|----------------------------|-------|-------------------------------------------------------------------------------|---------|--------------------|
| Bit(s)                     | Value | Description                                                                   |         |                    |
| 7:3                        |       | These bits are always read as 0x11.                                           |         |                    |
| 2:0                        |       | Three least significant bits of the PWM register address for indirect access. |         |                    |

# 27. EXTERNAL I/O CONTROL

#### 27.1 Overview

The Rabbit 5000's external I/O space consists of 64KB that is accessed by prefixing a read or write instruction with the **IOE** instruction. These accesses can go onto the memory bus or onto the external I/O bus (described below). There are three dedicated signal pins (/IORD, /IOWR, /BUFEN) that toggle for all external I/O accesses, and eight I/O strobes that can be associated with this external I/O space and directed out of Parallel Ports C, D, or E.

In addition, a handshaking signal input can be enabled on a Parallel Port E pin, and can be used to pause an external I/O transaction until the external device is ready to complete the transaction. A timeout period can be defined to ensure that the processor is not held indefinitely by a misbehaving external device.

#### 27.1.1 External I/O Bus

The Rabbit 5000 can enable a separate external I/O bus for external devices to keep bus loading on the memory bus at an acceptable level. This bus consists of eight data lines on Parallel Port A and up to eight address lines on Parallel Port B. This functionality is mutually exclusive with the slave port and regular parallel I/O on Parallel Ports A and B.

When enabled, the address lines of the external I/O bus hold their value until a new value is written to them. The data lines return to a tristate mode after each transaction.

See Section 27.1.2 for memory timing for external I/O accesses.

#### 27.1.2 I/O Strobes

There are eight I/O strobes available in the Rabbit 5000. Each has a separate 8KB address range that can be enabled as a chip select, read strobe, write strobe, or a read/write strobe. The number of wait states can be set to 1, 3, 7, or 15, and the signal can be active high or low.

| Register | External I/O Address Range |
|----------|----------------------------|
| IB0CR    | 0x0000-0x1FFF              |
| IB1CR    | 0x2000-0x3FFF              |
| IB2CR    | 0x5000-0x5FFF              |
| IB3CR    | 0x6000-0x7FFF              |
| IB4CR    | 0x8000-0x9FFF              |
| IB5CR    | 0xA000-0xBFFF              |
| IB6CR    | 0xC000-0xDFFF              |
| IB7CR    | 0xE000-0xFFFF              |

Table 27-1. External I/O Strobes

The I/O strobes can be used for devices on the memory bus or the external I/O bus, and can be enabled to go out on the memory bus alone or both buses. It is also possible to shorten the read strobe by one clock cycle and the write strobe by one-half a clock cycle by pulling in the trailing edge, which guarantees one clock cycle of hold time for transactions.



Figure 27-1. External I/O Bus Cycles

The strobes can be enabled to come out on Parallel Ports C, D, or E.

By default the I/O strobes are configured as read-only chip selects with 15 wait states and normal timing. These settings will affect the /IORD, /IOWR, and /BUFEN signals for external I/O writes even if no other strobe outputs are enabled in the parallel port registers.

#### 27.1.3 I/O Handshake

An external I/O handshake input can be enabled on one of the Parallel Port E pins for any combination of the I/O banks. The external device holds this signal (active high or low) when it is busy and cannot accept a transaction. The Rabbit 5000 will then hold midway through the transaction until either the handshake signal goes inactive or a timeout occurs. The timeout can be defined anywhere from 32 to 2048 clocks. When the timeout occurs, the transaction ends and a status bit is set. This bit must be checked by the program attempting the write; no interrupt is generated.

The I/O handshake signal is sampled at the end of the first wait state (Tw). When the handshake signal is disabled, the transition will start at the beginning of the Tw phase and continue to completion.



Figure 27-2. External I/O Handshake Timing Diagram

# 27.1.4 Block Diagram



# 27.1.5 Registers

| Register Name                  | Mnemonic | I/O Address | R/W | Reset    |
|--------------------------------|----------|-------------|-----|----------|
| I/O Handshake Control Register | IHCR     | 0x0028      | R/W | 00000000 |
| I/O Handshake Select Register  | IHSR     | 0x0029      | R/W | 00000000 |
| I/O Handshake Timeout Register | IHTR     | 0x002A      | R/W | 00000000 |
| I/O Bank 0 Control Register    | IB0CR    | 0x0080      | W   | 00000000 |
| I/O Bank 1 Control Register    | IB1CR    | 0x0081      | W   | 00000000 |
| I/O Bank 2 Control Register    | IB2CR    | 0x0082      | W   | 00000000 |
| I/O Bank 3 Control Register    | IB3CR    | 0x0083      | W   | 00000000 |
| I/O Bank 4 Control Register    | IB4CR    | 0x0084      | W   | 00000000 |
| I/O Bank 5 Control Register    | IB5CR    | 0x0085      | W   | 00000000 |
| I/O Bank 6 Control Register    | IB6CR    | 0x0086      | W   | 00000000 |
| I/O Bank 7 Control Register    | IB7CR    | 0x0087      | W   | 00000000 |

## 27.2 Dependencies

### 27.2.1 I/O Pins

The external I/O bus uses PA0–PA7 for data, and either PB2–PB7 or PB0–PB7 for address lines, depending on the setting in SPCR. Address bits 6 and 7 can also be enabled on pins PD1, PD3, PD5, or PD7, which allows PB0 and PB1 to be used as clocked serial I/O instead of as external I/O.

The /IOWR, /IORD, and /BUFEN pins are dedicated strobes for external I/O accesses.

The I/O strobes can be directed out to pins on Parallel Ports C, D, or E; each bank can be directed to the appropriate pin (bank zero on PC0, PD0, or PE0; bank one on PC1, PD1, or PE1; etc.). The strobes will affect outputs on /IOWR, /IORD, and /BUFEN at all times.

The I/O handshake can be input on any one of the Parallel Port E pins (PE0–PE7).

#### 27.2.2 Clocks

All external I/O accesses, strobes, and handshake timeouts are based on the processor clock.

### 27.2.3 Other Registers

| Register                                                        | Function                                                                                                      |  |
|-----------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|--|
| SPCR                                                            | Enable the external I/O bus.                                                                                  |  |
| PCFR, PCALR, PCAHR<br>PDFR, PDALR, PDAHR,<br>PEFR, PEALR, PEAHR | Select Parallel Port C, D, or E pins as I/O strobe outputs. Select PD1, PD3, PD5, or PD7 as address bits 6-7. |  |

### 27.2.4 Interrupts

There are no interrupts associated with external I/O.

## 27.3 Operation

#### 27.3.1 External I/O Bus

The following steps must be taken before using external I/O bus:

- 1. Enable the external I/O bus by writing to SPCR. Select whether 6 or 8 address bits are desired
- 2. If PB0 and PB1 are needed for clocked serial use and eight address bits are required, enable the alternate outputs of address bits 6 and 7 on Parallel Port D by writing to PDALR, PDAHR, and PDFR.
- 3. Set the I/O timing for a particular device by writing to the appropriate IBxCR register for the I/O bank desired.
- 4. If a strobe other than /IORD, /IOWR, or /BUFEN is required, enable the output of the IBxCR register by writing to the appropriate PxALR, PxAHR, and PxFR registers.

Once the external I/O bus is enabled, all memory read/write instructions prefixed with an IOE will go to either the memory bus or external I/O bus, depending on the setup in that bank's IBxCR register.

#### 27.3.2 I/O Strobes

The following steps must be taken before using an I/O strobe:

- 1. Set the strobe type and timing for a particular device by writing to the appropriate IBxCR register for the I/O bank desired.
- 2. If signals other than /IORD, /IOWR, and /BUFEN are required, enable the output of the IBxCR register by writing to the appropriate PxALR, PxAHR, and PxFR registers.

On startup, the I/O strobes are set as chip selects with 15 wait states, read-only, active-low signaling, and will use the external I/O bus. These settings will be used for the dedicated I/O strobe pins /IORD, /IOWR, and /BUFEN whenever an external I/O write occurs even if not I/O strobe signals are being output on parallel port pins.

### 27.3.3 I/O Handshake

The following steps must be taken before using the I/O handshake:

- 1. Select the active level and desired port E bit to use as input by writing to IHCR.
- 2. Select which I/O banks the handshake is active for by writing to IHSR.
- 3. Select the handshake timeout value by writing to IHTR.

Once enabled, the handshake will be checked for every external I/O transaction in a bank that was enabled in IHSR. After these transactions, the program should check for a time-out by reading IHTR.

# 27.4 Register Descriptions

| I/O    | Handshak | e Control Register                                    | (IHCR)                                                                     | (Address = 0x0028)           |  |  |
|--------|----------|-------------------------------------------------------|----------------------------------------------------------------------------|------------------------------|--|--|
| Bit(s) | Value    | Description                                           |                                                                            |                              |  |  |
| 7:5    |          | These bits are reserved and                           | should be written v                                                        | vith zeros.                  |  |  |
| 4      | 0        | I/O handshake is active low                           | (I/O transaction he                                                        | eld until signal goes high). |  |  |
|        | 1        | I/O handshake is active high                          | I/O handshake is active high (I/O transaction held until signal goes low). |                              |  |  |
| 3      |          | This bit is reserved and should be written with zero. |                                                                            |                              |  |  |
| 2:0    | 000      | Use Parallel Port E bit 0 for I/O handshake.          |                                                                            |                              |  |  |
|        | 001      | Use Parallel Port E bit 1 for I/O handshake.          |                                                                            |                              |  |  |
|        | 010      | Use Parallel Port E bit 2 for I/O handshake.          |                                                                            |                              |  |  |
|        | 011      | Use Parallel Port E bit 3 for I/O handshake.          |                                                                            |                              |  |  |
|        | 100      | Use Parallel Port E bit 4 for I/O handshake.          |                                                                            |                              |  |  |
|        | 101      | Use Parallel Port E bit 5 for I/O handshake.          |                                                                            |                              |  |  |
|        | 110      | Use Parallel Port E bit 6 for                         | I/O handshake.                                                             |                              |  |  |
|        | 111      | Use Parallel Port E bit 7 for I/O handshake.          |                                                                            |                              |  |  |

| I/O Handshake Select Register (IHSR) (Address = 0 |       |                                       |                                      |  |  |
|---------------------------------------------------|-------|---------------------------------------|--------------------------------------|--|--|
| Bit(s)                                            | Value | Description                           |                                      |  |  |
| 7                                                 | 0     | Disable I/O handshake for I/          | O Bank 7.                            |  |  |
|                                                   | 1     | Enable I/O handshake for I/O          | Enable I/O handshake for I/O Bank 7. |  |  |
| 6                                                 | 0     | Disable I/O handshake for I/          | O Bank 6.                            |  |  |
|                                                   | 1     | Enable I/O handshake for I/O          | O Bank 6.                            |  |  |
| 5                                                 | 0     | Disable I/O handshake for I/          | O Bank 5.                            |  |  |
|                                                   | 1     | Enable I/O handshake for I/O          | O Bank 5.                            |  |  |
| 4                                                 | 0     | Disable I/O handshake for I/O Bank 4. |                                      |  |  |
|                                                   | 1     | Enable I/O handshake for I/O          | O Bank 4.                            |  |  |
| 3                                                 | 0     | Disable I/O handshake for I/          | O Bank 3.                            |  |  |
|                                                   | 1     | Enable I/O handshake for I/O          | O Bank 3.                            |  |  |
| 2                                                 | 0     | Disable I/O handshake for I/          | O Bank 2.                            |  |  |
|                                                   | 1     | Enable I/O handshake for I/O          | O Bank 2.                            |  |  |
| 1                                                 | 0     | Disable I/O handshake for I/          | O Bank 1.                            |  |  |
|                                                   | 1     | Enable I/O handshake for I/O          | O Bank 1.                            |  |  |
| 0 0 Disable I/O handsl                            |       | Disable I/O handshake for I/          | O Bank 0.                            |  |  |
|                                                   | 1     | Enable I/O handshake for I/O          | O Bank 0.                            |  |  |

| I/O Handshake Timeout Register |       | Timeout Register                                                                                                                                                                                                                                | (IHTR) | (Address = 0x002A) |
|--------------------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------|
| Bit(s)                         | Value | Description                                                                                                                                                                                                                                     |        |                    |
| 7                              | 0     | No I/O handshake timeout has occurred since the last read of this register.                                                                                                                                                                     |        |                    |
|                                | 1     | An I/O handshake timeout has occurred since the last read of this register. This bit is cleared by a read of this register.                                                                                                                     |        |                    |
| 6                              |       | This bit is reserved and should be written with zero.                                                                                                                                                                                           |        |                    |
| 5:0                            |       | Time constant for the I/O handshake timeout counter. This time constant (times 32) selects the number of clocks that the I/O handshake input may delay completion of an I/O transaction before the I/O transaction will complete automatically. |        |                    |

| 1/0    | O Bank x 0 | Control Register                                                                                                                                                                                                | (IB0CR) (IB1CR) (IB2CR) (IB3CR) (IB4CR) (IB5CR) (IB5CR) (IB6CR) (IB7CR) | (Address = 0x0080)<br>(Address = 0x0081)<br>(Address = 0x0082)<br>(Address = 0x0083)<br>(Address = 0x0084)<br>(Address = 0x0085)<br>(Address = 0x0086)<br>(Address = 0x0087) |
|--------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit(s) | Value      |                                                                                                                                                                                                                 | Description                                                             |                                                                                                                                                                              |
| 7:6    | 00         | Fifteen wait states for accesses                                                                                                                                                                                | s in this bank.                                                         |                                                                                                                                                                              |
|        | 01         | Seven wait states for accesses                                                                                                                                                                                  | in this bank.                                                           |                                                                                                                                                                              |
|        | 10         | Three wait states for accesses                                                                                                                                                                                  | in this bank.                                                           |                                                                                                                                                                              |
|        | 11         | One wait state for accesses in this bank.                                                                                                                                                                       |                                                                         |                                                                                                                                                                              |
| 5:4    | 00         | The I signal is an I/O chip select.                                                                                                                                                                             |                                                                         |                                                                                                                                                                              |
|        | 01         | The I signal is an I/O read strobe.                                                                                                                                                                             |                                                                         |                                                                                                                                                                              |
|        | 10         | The I signal is an I/O write strobe.                                                                                                                                                                            |                                                                         |                                                                                                                                                                              |
|        | 11         | The I signal is an I/O data (rea                                                                                                                                                                                | d or write) strobe.                                                     |                                                                                                                                                                              |
| 3      | 0          | Writes are not allowed to this bank. Transactions are normal in every other way; only the write strobe is inhibited.                                                                                            |                                                                         |                                                                                                                                                                              |
|        | 1          | Writes are allowed to this bank.                                                                                                                                                                                |                                                                         |                                                                                                                                                                              |
| 2      | 0          | Active-low I signal.                                                                                                                                                                                            |                                                                         |                                                                                                                                                                              |
|        | 1          | Inverted (active-high) I signal.                                                                                                                                                                                |                                                                         |                                                                                                                                                                              |
| 1      | 0          | Normal I/O transaction timing.                                                                                                                                                                                  |                                                                         |                                                                                                                                                                              |
|        | 1          | Shorten read strobe by one clock cycle and write strobe by one-half clock cycle. Transaction length remains the same. This guarantees one clock cycle hold time for both address and data for I/O transactions. |                                                                         |                                                                                                                                                                              |
| 0      | 0          | Use I/O bus if enabled.                                                                                                                                                                                         |                                                                         |                                                                                                                                                                              |
|        | 1          | Always use memory data bus.                                                                                                                                                                                     |                                                                         |                                                                                                                                                                              |

| S      | lave Port (                                                        | Control Register (SPCR) (Address = 0x0024)                                                                                  |  |  |
|--------|--------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit(s) | Value                                                              | Description                                                                                                                 |  |  |
| 7      | 0                                                                  | Program fetch as a function of the SMODE pins.                                                                              |  |  |
|        | 1                                                                  | Ignore the SMODE pins program fetch function.                                                                               |  |  |
| 6:5    | Read                                                               | These bits report the state of the SMODE pins.                                                                              |  |  |
|        | Write                                                              | These bits are ignored and should be written with zero.                                                                     |  |  |
| 4:2    | Disable the slave port. Parallel Port A is a byte-wide input port. |                                                                                                                             |  |  |
|        | 001                                                                | Disable the slave port. Parallel Port A is a byte-wide output port.                                                         |  |  |
|        | 010                                                                | Enable the slave port, with /SCS from Parallel Port E bit 7.                                                                |  |  |
|        | 011                                                                | Enable the external I/O bus. Parallel Port A is used for the data bus and Parallel Port B[7:2] is used for the address bus. |  |  |
|        | 100                                                                | This bit combination is reserved and should not be used.                                                                    |  |  |
|        | 101                                                                | This bit combination is reserved and should not be used.                                                                    |  |  |
|        | 110                                                                | Enable the slave port, with /SCS from Parallel Port B bit 6.                                                                |  |  |
|        | 111                                                                | Enable the external I/O bus. Parallel Port A is used for the data bus and Parallel Port B[7:0] is used for the address bus. |  |  |
| 1:0    | 00                                                                 | Slave port interrupts are disabled.                                                                                         |  |  |
|        | 01                                                                 | Slave port interrupts use Interrupt Priority 1.                                                                             |  |  |
|        | 10                                                                 | Slave port interrupts use Interrupt Priority 2.                                                                             |  |  |
|        | 11                                                                 | Slave port interrupts use Interrupt Priority 3.                                                                             |  |  |

| Paralle | I Port C A | Iternate Low Register (PCALR) (Address = 0x0052)     |  |  |  |
|---------|------------|------------------------------------------------------|--|--|--|
| Bit(s)  | Value      | Description                                          |  |  |  |
| 7:6     | 00         | Parallel Port C bit 3 alternate output 0 (TXC).      |  |  |  |
|         | 01         | Parallel Port C bit 3 alternate output 1 (I3).       |  |  |  |
|         | 10         | Parallel Port C bit 3 alternate output 2 (TIMER C3). |  |  |  |
|         | 11         | Parallel Port C bit 3 alternate output 3 (SCLKD).    |  |  |  |
| 5:4     | 00         | Parallel Port C bit 2 alternate output 0 (TXC).      |  |  |  |
|         | 01         | Parallel Port C bit 2 alternate output 1 (I2).       |  |  |  |
|         | 10         | Parallel Port C bit 2 alternate output 2 (TIMER C2). |  |  |  |
|         | 11         | Parallel Port C bit 2 alternate output 3 (TXF).      |  |  |  |
| 3:2     | 00         | Parallel Port C bit 1 alternate output 0 (TXD).      |  |  |  |
|         | 01         | Parallel Port C bit 1 alternate output 1 (I1).       |  |  |  |
|         | 10         | Parallel Port C bit 1 alternate output 2 (TIMER C1). |  |  |  |
|         | 11         | Parallel Port C bit 1 alternate output 3 (RCLKF).    |  |  |  |
| 1:0     | 00         | Parallel Port C bit 0 alternate output 0 (TXD).      |  |  |  |
|         | 01         | Parallel Port C bit 0 alternate output 1 (I0).       |  |  |  |
|         | 10         | Parallel Port C bit 0 alternate output 2 (TIMER C0). |  |  |  |
|         | 11         | Parallel Port C bit 0 alternate output 3 (TCLKF).    |  |  |  |

| Parallel Port C Alternate High Register (PCAHR) (Address = 0x0053 |       |                                                   |  |  |  |
|-------------------------------------------------------------------|-------|---------------------------------------------------|--|--|--|
| Bit(s)                                                            | Value | Description                                       |  |  |  |
| 7:6                                                               | 00    | Parallel Port C bit 7 alternate output 0 (TXA).   |  |  |  |
|                                                                   | 01    | Parallel Port C bit 7 alternate output 1 (I7).    |  |  |  |
|                                                                   | 10    | Parallel Port C bit 7 alternate output 2 (PWM3).  |  |  |  |
|                                                                   | 11    | Parallel Port C bit 7 alternate output 3 (SCLKC). |  |  |  |
| 5:4                                                               | 00    | Parallel Port C bit 6 alternate output 0 (TXA).   |  |  |  |
|                                                                   | 01    | Parallel Port C bit 6 alternate output 1 (I6).    |  |  |  |
|                                                                   | 10    | Parallel Port C bit 6 alternate output 2 (PWM2).  |  |  |  |
|                                                                   | 11    | Parallel Port C bit 6 alternate output 3 (TXE).   |  |  |  |
| 3:2                                                               | 00    | Parallel Port C bit 5 alternate output 0 (TXB).   |  |  |  |
|                                                                   | 01    | Parallel Port C bit 5 alternate output 1 (I5).    |  |  |  |
|                                                                   | 10    | Parallel Port C bit 5 alternate output 2 (PWM1).  |  |  |  |
|                                                                   | 11    | Parallel Port C bit 5 alternate output 3 (RCLKE). |  |  |  |
| 1:0                                                               | 00    | Parallel Port C bit 4 alternate output 0 (TXB).   |  |  |  |
|                                                                   | 01    | Parallel Port C bit 4 alternate output 1 (I4).    |  |  |  |
|                                                                   | 10    | Parallel Port C bit 4 alternate output 2 (PWM0).  |  |  |  |
|                                                                   | 11    | Parallel Port C bit 4 alternate output 3 (TCLKE). |  |  |  |

| Parallel Port C Function Register |       | (PCFR)                                                                                | (Address = 0x0055) |  |
|-----------------------------------|-------|---------------------------------------------------------------------------------------|--------------------|--|
| Bit(s)                            | Value | Description                                                                           |                    |  |
| 7:0                               | 0     | The corresponding port bit functions normally.                                        |                    |  |
|                                   | 1     | The corresponding port bit carries its alternate signal as an output. See Table 10-1. |                    |  |

| Paralle | Parallel Port D Alternate Low Register (PDALR) (Address = 0) |                                                      |  |  |  |
|---------|--------------------------------------------------------------|------------------------------------------------------|--|--|--|
| Bit(s)  | Value                                                        | Description                                          |  |  |  |
| 7:6     | 00                                                           | Parallel Port D bit 3 alternate output 0 (IA7).      |  |  |  |
|         | 01                                                           | Parallel Port D bit 3 alternate output 1 (I3).       |  |  |  |
|         | 10                                                           | Parallel Port D bit 3 alternate output 2 (TIMER C3). |  |  |  |
|         | 11                                                           | Parallel Port D bit 3 alternate output 3 (SCLKD).    |  |  |  |
| 5:4     | 00                                                           | Parallel Port D bit 2 alternate output 0 (SCLKC).    |  |  |  |
|         | 01                                                           | Parallel Port D bit 2 alternate output 1 (I2).       |  |  |  |
|         | 10                                                           | Parallel Port D bit 2 alternate output 2 (TIMER C2). |  |  |  |
|         | 11                                                           | Parallel Port D bit 2 alternate output 3 (TXF).      |  |  |  |
| 3:2     | 00                                                           | Parallel Port D bit 1 alternate output 0 (IA6).      |  |  |  |
|         | 01                                                           | Parallel Port D bit 1 alternate output 1 (I1).       |  |  |  |
|         | 10                                                           | Parallel Port D bit 1 alternate output 2 (TIMER C1). |  |  |  |
|         | 11                                                           | Parallel Port D bit 1 alternate output 3 (RCLKF).    |  |  |  |
| 1:0     | 00                                                           | Parallel Port D bit 0 alternate output 0 (SCLKD).    |  |  |  |
|         | 01                                                           | Parallel Port D bit 0 alternate output 1 (I0).       |  |  |  |
|         | 10                                                           | Parallel Port D bit 0 alternate output 2 (TIMER C0). |  |  |  |
|         | 11                                                           | Parallel Port D bit 0 alternate output 3 (TCLKF).    |  |  |  |

| Parallel Port D Alternate High Register (PDAHR) (Address = 0x0063 |       |                                                   |  |  |
|-------------------------------------------------------------------|-------|---------------------------------------------------|--|--|
| Bit(s)                                                            | Value | Description                                       |  |  |
| 7:6                                                               | 00    | Parallel Port D bit 7 alternate output 0 (IA7).   |  |  |
|                                                                   | 01    | Parallel Port D bit 7 alternate output 1 (I7).    |  |  |
|                                                                   | 10    | Parallel Port D bit 7 alternate output 2 (PWM3).  |  |  |
|                                                                   | 11    | Parallel Port D bit 7 alternate output 3 (SCLKC). |  |  |
| 5:4                                                               | 00    | Parallel Port D bit 6 alternate output 0 (TXA).   |  |  |
|                                                                   | 01    | Parallel Port D bit 6 alternate output 1 (I6).    |  |  |
|                                                                   | 10    | Parallel Port D bit 6 alternate output 2 (PWM2).  |  |  |
|                                                                   | 11    | Parallel Port D bit 6 alternate output 3 (TXE).   |  |  |
| 3:2                                                               | 00    | Parallel Port D bit 5 alternate output 0 (IA6).   |  |  |
|                                                                   | 01    | Parallel Port D bit 5 alternate output 1 (I5).    |  |  |
|                                                                   | 10    | Parallel Port D bit 5 alternate output 2 (PWM1).  |  |  |
|                                                                   | 11    | Parallel Port D bit 5 alternate output 3 (RCLKE). |  |  |
| 1:0                                                               | 00    | Parallel Port D bit 4 alternate output 0 (TXB).   |  |  |
|                                                                   | 01    | Parallel Port D bit 4 alternate output 1 (I4).    |  |  |
|                                                                   | 10    | Parallel Port D bit 4 alternate output 2 (PWM0).  |  |  |
|                                                                   | 11    | Parallel Port D bit 4 alternate output 3 (TCLKE). |  |  |

| Para   | Parallel Port D Function Register |                                                | (PDFR)                       | (Address = 0x0065)                 |
|--------|-----------------------------------|------------------------------------------------|------------------------------|------------------------------------|
| Bit(s) | Value                             | Description                                    |                              |                                    |
| 7:0    | 0                                 | The corresponding port bit functions normally. |                              |                                    |
|        | 1                                 | The corresponding port b                       | oit carries its alternate si | gnal as an output. See Table 11-1. |

| Paralle | Port E Al | ternate Low Register (PEALR) (Address = 0x0072)      |  |  |  |
|---------|-----------|------------------------------------------------------|--|--|--|
| Bit(s)  | Value     | Description                                          |  |  |  |
| 7:6     | 00        | Parallel Port E bit 3 alternate output 0 (I3).       |  |  |  |
|         | 01        | Parallel Port E bit 3 alternate output 1 (A23).      |  |  |  |
|         | 10        | Parallel Port E bit 3 alternate output 2 (TIMER C3). |  |  |  |
|         | 11        | Parallel Port E bit 3 alternate output 3 (SCLKD).    |  |  |  |
| 5:4     | 00        | Parallel Port E bit 2 alternate output 0 (I2).       |  |  |  |
|         | 01        | Parallel Port E bit 2 alternate output 1 (A22).      |  |  |  |
|         | 10        | Parallel Port E bit 2 alternate output 2 (TIMER C2). |  |  |  |
|         | 11        | Parallel Port E bit 2 alternate output 3 (TXF).      |  |  |  |
| 3:2     | 00        | Parallel Port E bit 1 alternate output 0 (I1).       |  |  |  |
|         | 01        | Parallel Port E bit 1 alternate output 1 (A21).      |  |  |  |
|         | 10        | Parallel Port E bit 1 alternate output 2 (TIMER C1). |  |  |  |
|         | 11        | Parallel Port E bit 1 alternate output 3 (RCLKF).    |  |  |  |
| 1:0     | 00        | Parallel Port E bit 0 alternate output 0 (I0).       |  |  |  |
|         | 01        | Parallel Port E bit 0 alternate output 1 (A20).      |  |  |  |
|         | 10        | Parallel Port E bit 0 alternate output 2 (TIMER C0). |  |  |  |
|         | 11        | Parallel Port E bit 0 alternate output 3 (TCLKF).    |  |  |  |

| Parallel Port E Alternate High Register (PEAHR) (Address = 0x0073) |       |                                                   |               |  |  |
|--------------------------------------------------------------------|-------|---------------------------------------------------|---------------|--|--|
| Bit(s)                                                             | Value | Description                                       |               |  |  |
| 7:6                                                                | 00    | Parallel Port E bit 7 alternate output 0 (I7).    |               |  |  |
|                                                                    | 01    | Parallel Port E bit 7 alternate output 1 (/ACT).  |               |  |  |
|                                                                    | 10    | Parallel Port E bit 7 alternate output 2 (PWM3).  |               |  |  |
|                                                                    | 11    | Parallel Port E bit 7 alternate output 3 (SCLKC). | ut 3 (SCLKC). |  |  |
| 5:4                                                                | 00    | Parallel Port E bit 6 alternate output 0 (I6).    |               |  |  |
|                                                                    | 01    | Parallel Port E bit 6 alternate output 1 (—).     |               |  |  |
|                                                                    | 10    | Parallel Port E bit 6 alternate output 2 (PWM2).  |               |  |  |
|                                                                    | 11    | Parallel Port E bit 6 alternate output 3 (TXE).   |               |  |  |
| 3:2                                                                | 00    | Parallel Port E bit 5 alternate output 0 (I5).    |               |  |  |
|                                                                    | 01    | Parallel Port E bit 5 alternate output 1 (/LINK). |               |  |  |
|                                                                    | 10    | Parallel Port E bit 5 alternate output 2 (PWM1).  |               |  |  |
|                                                                    | 11    | Parallel Port E bit 5 alternate output 3 RCLKE).  |               |  |  |
| 1:0                                                                | 00    | Parallel Port E bit 4 alternate output 0 (I4).    |               |  |  |
|                                                                    | 01    | Parallel Port E bit 4 alternate output 1 (/A0).   |               |  |  |
|                                                                    | 10    | Parallel Port E bit 4 alternate output 2 (PWM0).  |               |  |  |
|                                                                    | 11    | Parallel Port E bit 4 alternate output 3 (TCLKE). |               |  |  |

| Para   | Parallel Port E Function Register |                                                | (PEFR)                       | (Address = 0x0075)                 |
|--------|-----------------------------------|------------------------------------------------|------------------------------|------------------------------------|
| Bit(s) | Value                             | Description                                    |                              |                                    |
| 7:0    | 0                                 | The corresponding port bit functions normally. |                              |                                    |
|        | 1                                 | The corresponding port b                       | oit carries its alternate si | gnal as an output. See Table 12-1. |

# 28. BREAKPOINTS

#### 28.1 Overview

The Rabbit 5000 contains seven hardware breakpoints to support debugging. Each hardware breakpoint consists of a 24-bit address match register and a 24-bit mask register. A breakpoint can be generated on an address match for address execution, data read, data write, or any combination thereof. The mask register serves to mask off selected address bits from the address compare. A "one" in a particular bit position in the mask register inhibits the corresponding bit in the address match register from contributing to the address match condition.

When a match occurs, a Level 3 breakpoint interrupt is generated. Note that this means that breakpoints behave differently when the processor is running at Interrupt Priority 3 — the interrupt is generated but will not be handled until the processor drops to a lower priority.

In most cases, a code execution interrupt will be handled at the end of the instruction in which the match occurred. However, because of the time required to perform a 24-bit address match in the processor, a code execution breakpoint that is set on a single-byte, 2-clock instruction will not yet be enabled at the end of that instruction, and the interrupt will instead occur at the end of the next instruction.

Note that a breakpoint may be forced to be pending by setting the corresponding bit in BDCR. This feature allows a breakpoint request to be used as a virtual single-step request by always setting the appropriate bit in the interrupt handler. There is a particular sequence of instructions required to exit properly when the interrupt is left pending.

DMA transfers are treated as normal data reads and writes, although the DMA transfer will complete before the interrupt is taken.

Breakpoints can be enabled for the User Mode, the System Mode, or both.

Another breakpoint feature is the ability to disable the RST 28h instruction. The RST 28h vector was often used as a breakpoint feature by adding that instruction to code; by enabling a bit in BDCR, the RST 28h instruction will execute as a NOP instead, providing an easy way to disable that type of breakpoint.

# 28.1.1 Block Diagram



# 28.1.2 Registers

| Register Name                       | Mnemonic | I/O Address | R/W | Reset    |
|-------------------------------------|----------|-------------|-----|----------|
| Breakpoint Debug/Control Register   | BDCR     | 0x001C      | R/W | 00000000 |
| Breakpoint 0 Control Register       | B0CR     | 0x030B      | R/W | 00000000 |
| Breakpoint 1 Control Register       | B1CR     | 0x031B      | R/W | 00000000 |
| Breakpoint 2 Control Register       | B2CR     | 0x032B      | R/W | 00000000 |
| Breakpoint 3 Control Register       | B3CR     | 0x033B      | R/W | 00000000 |
| Breakpoint 4 Control Register       | B4CR     | 0x034B      | R/W | 00000000 |
| Breakpoint 5 Control Register       | B5CR     | 0x035B      | R/W | 00000000 |
| Breakpoint 6 Control Register       | B6CR     | 0x036B      | R/W | 00000000 |
| Breakpoint 0 Address [0–2] Register | B0AxR    | 0x030C + x  | R/W | 00000000 |
| Breakpoint 1 Address [0–2] Register | B1AxR    | 0x031C + x  | R/W | 00000000 |
| Breakpoint 2 Address [0–2] Register | B2AxR    | 0x032C + x  | R/W | 00000000 |
| Breakpoint 3 Address [0–2] Register | B3AxR    | 0x033C + x  | R/W | 00000000 |
| Breakpoint 4 Address [0–2] Register | B4AxR    | 0x034C + x  | R/W | 00000000 |
| Breakpoint 5 Address [0–2] Register | B5AxR    | 0x035C + x  | R/W | 00000000 |
| Breakpoint 6 Address [0–2] Register | B6AxR    | 0x036C + x  | R/W | 00000000 |
| Breakpoint 0 Mask [0–2] Register    | B0MxR    | 0x0308 + x  | R/W | 00000000 |
| Breakpoint 1 Mask [0–2] Register    | B1MxR    | 0x0318 + x  | R/W | 00000000 |
| Breakpoint 2 Mask [0–2] Register    | B2MxR    | 0x0328 + x  | R/W | 00000000 |
| Breakpoint 3 Mask [0–2] Register    | B3MxR    | 0x0338 + x  | R/W | 00000000 |
| Breakpoint 4 Mask [0–2] Register    | B4MxR    | 0x0348 + x  | R/W | 00000000 |
| Breakpoint 5 Mask [0–2] Register    | B5MxR    | 0x0358 + x  | R/W | 00000000 |
| Breakpoint 6 Mask [0–2] Register    | B6MxR    | 0x0368 + x  | R/W | 00000000 |

## 28.2 Dependencies

#### 28.2.1 I/O Pins

There are no I/O pins associated with breakpoints.

#### 28.2.2 Clocks

There are no clocks associated with breakpoints.

#### 28.2.3 Other Registers

There are no other registers associated with breakpoints.

### 28.2.4 Interrupts

When an enabled address match occurs for a given breakpoint, a breakpoint interrupt occurs. The breakpoint that caused the interrupt must be determined by reading BDCR, which also clears the interrupt. Any of the breakpoint interrupts can be enabled by writing to BDCR.

The breakpoint interrupt vector is in the EIR at offset 0x040. It is always set to Interrupt Priority 3, and is the highest priority interrupt; if two Interrupt Priority 3 vectors are pending, the breakpoint interrupt will always be handled first.

## 28.3 Operation

The following steps must be taken to enable breakpoints:

- 1. Write the vector to the interrupt service routine to the external interrupt table.
- 2. Write the desired breakpoint addresses to the appropriate breakpoint address registers (BxAyR, where x is the breakpoint and y is the byte of the address, 0-2).
- 3. Write an address mask for the given breakpoints (BxMyR).
- 4. Select the breakpoint address match type (execute, data read, data write) by writing to the appropriate BxCR.
- 5. Enable the desired breakpoints by writing to BDCR.

#### 28.3.1 Handling Interrupts

The following actions occur within the interrupt service routine.

- Which breakpoints are pending should be determined by reading BDCR. This also clears the pending breakpoints.
- The desired breakpoint action should be taken.
- If single-step functionality is desired, the breakpoint interrupt should be re-enabled by writing the appropriate bit to BDCR. If this is done, the interrupt handler needs to be exited in a particular manner (see below).

# 28.3.2 Example ISR

A sample interrupt handler is shown below.

# 28.4 Register Descriptions

| Break  | point/Deb | ug Control Register (BDCR) (Address = 0x001C)                                                                                |  |  |
|--------|-----------|------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit(s) | Value     | Description                                                                                                                  |  |  |
| 7      | 0         | Normal RST 0x28 operation.                                                                                                   |  |  |
|        | 1         | RST 0x28h is NOP.                                                                                                            |  |  |
| 6:0    | 0         | The corresponding Breakpoint request is not pending.                                                                         |  |  |
| Read   | 1         | The corresponding Breakpoint request is pending. Reading this register automatically clears all pending breakpoint requests. |  |  |
| 6:0    | 0         | No effect on the corresponding Breakpoint request.                                                                           |  |  |
| Write  | 1         | Make the corresponding Breakpoint request pending.                                                                           |  |  |

| Breakpoint x Control Register                            |                                                    |                                                      | (B0CR)<br>(B1CR)<br>(B2CR)<br>(B3CR)<br>(B4CR)<br>(B5CR)<br>(B6CR) | (Address = 0x030B)<br>(Address = 0x031B)<br>(Address = 0x032B)<br>(Address = 0x033B)<br>(Address = 0x034B)<br>(Address = 0x036B)<br>(Address = 0x037B) |  |
|----------------------------------------------------------|----------------------------------------------------|------------------------------------------------------|--------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit(s)                                                   | Value                                              |                                                      | Description                                                        |                                                                                                                                                        |  |
| 7:6                                                      | 00                                                 | No Breakpoint x on execu                             | ite address match.                                                 |                                                                                                                                                        |  |
|                                                          | 01                                                 | Breakpoint x on User Mo                              | de execute address ma                                              | ntch.                                                                                                                                                  |  |
|                                                          | Breakpoint x on System Mode execute address match. |                                                      |                                                                    |                                                                                                                                                        |  |
|                                                          | 11                                                 | Breakpoint x on System of                            | address match.                                                     |                                                                                                                                                        |  |
| 5:4                                                      | 00                                                 | No breakpoint x on data read address match.          |                                                                    |                                                                                                                                                        |  |
| 01 Breakpoint x on User Mode data read address match.    |                                                    |                                                      |                                                                    | natch.                                                                                                                                                 |  |
|                                                          | 10                                                 | Breakpoint x on System Mode data read address match. |                                                                    |                                                                                                                                                        |  |
|                                                          | 11                                                 | Breakpoint x on System of                            | r User Mode data read                                              | d address match.                                                                                                                                       |  |
| 3:2                                                      | 00                                                 | No breakpoint x on write                             | address match.                                                     |                                                                                                                                                        |  |
|                                                          | 01                                                 | Breakpoint x on User Mo                              | de write address matcl                                             | h.                                                                                                                                                     |  |
|                                                          | 10                                                 | Breakpoint x on System N                             | Mode write address ma                                              | atch.                                                                                                                                                  |  |
| Breakpoint x on System or User Mode write address match. |                                                    |                                                      |                                                                    | dress match.                                                                                                                                           |  |
| 1:0                                                      |                                                    | These bits are reserved an                           | d should be written w                                              | ith zeros.                                                                                                                                             |  |

| Breakpoint x Address 0 Register |       | ddress 0 Register           | (B0A0R)<br>(B1A0R)<br>(B2A0R)<br>(B3A0R)<br>(B4A0R)<br>(B5A0R)<br>(B6A0R) | (Address = 0x030C)<br>(Address = 0x031C)<br>(Address = 0x032C)<br>(Address = 0x033C)<br>(Address = 0x034C)<br>(Address = 0x036C)<br>(Address = 0x037C) |
|---------------------------------|-------|-----------------------------|---------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit(s)                          | Value | Description                 |                                                                           |                                                                                                                                                        |
| 7:0                             |       | Breakpoint x Address [7:0]. |                                                                           |                                                                                                                                                        |

| Breakpoint x Address 1 Register |       | ddress 1 Register            | (B0A1R)<br>(B1A1R)<br>(B2A1R)<br>(B3A1R)<br>(B4A1R)<br>(B5A1R)<br>(B6A1R) | (Address = 0x030D) (Address = 0x031D) (Address = 0x032D) (Address = 0x033D) (Address = 0x034D) (Address = 0x036D) (Address = 0x037D) |
|---------------------------------|-------|------------------------------|---------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| Bit(s)                          | Value | Description                  |                                                                           |                                                                                                                                      |
| 7:0                             |       | Breakpoint x Address [15:8]. |                                                                           |                                                                                                                                      |

| Brea   | Breakpoint x Address 2 Register |                               | (B0A2R)<br>(B1A2R)<br>(B2A2R)<br>(B3A2R)<br>(B4A2R)<br>(B5A2R)<br>(B6A2R) | (Address = 0x030E)<br>(Address = 0x031E)<br>(Address = 0x032E)<br>(Address = 0x033E)<br>(Address = 0x034E)<br>(Address = 0x036E)<br>(Address = 0x037E) |
|--------|---------------------------------|-------------------------------|---------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit(s) | Value                           | Description                   |                                                                           |                                                                                                                                                        |
| 7:0    |                                 | Breakpoint x Address [23:16]. |                                                                           |                                                                                                                                                        |

| Breakpoint x Mask 0 Register |       | (B0M0R)<br>(B1M0R)<br>(B2M0R)<br>(B3M0R)<br>(B4M0R)<br>(B5M0R)<br>(B6M0R)                              | (Address = 0x0308)<br>(Address = 0x0318)<br>(Address = 0x0328)<br>(Address = 0x0338)<br>(Address = 0x0348)<br>(Address = 0x0368)<br>(Address = 0x0378) |  |
|------------------------------|-------|--------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit(s)                       | Value | Description                                                                                            |                                                                                                                                                        |  |
| 7:0                          |       | Breakpoint x Mask [7:0]. (A one in a bit position inhibits the address compare for that bit position.) |                                                                                                                                                        |  |

| Breakpoint x Mask 1 Register |       | Mask 1 Register (B0M1R) (Address = 0x0309) (B1M1R) (Address = 0x0319) (B2M1R) (Address = 0x0329) (B3M1R) (Address = 0x0339) (B4M1R) (Address = 0x0349) (B5M1R) (Address = 0x0369) (B6M1R) (Address = 0x0379) |  |  |
|------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit(s)                       | Value | Description                                                                                                                                                                                                  |  |  |
| 7:0                          |       | Breakpoint x Mask [15:8]. (A one in a bit position inhibits the address compare for that bit position.)                                                                                                      |  |  |

| Breakpoint x Mask 2 Register |       | Mask 2 Register                                                                                         | (B0M2R)<br>(B1M2R)<br>(B2M2R)<br>(B3M2R)<br>(B4M2R)<br>(B5M2R)<br>(B6M2R) | (Address = 0x030A)<br>(Address = 0x031A)<br>(Address = 0x032A)<br>(Address = 0x033A)<br>(Address = 0x034A)<br>(Address = 0x036A)<br>(Address = 0x037A) |
|------------------------------|-------|---------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit(s)                       | Value | Description                                                                                             |                                                                           |                                                                                                                                                        |
| 7:0                          |       | Breakpoint x Mask [23:16]. (A one in a bit position inhibits the address compare for that bit position. |                                                                           |                                                                                                                                                        |

# 29. Low-Power Operation

#### 29.1 Overview

The Rabbit 5000 contains several power-saving features. Since the power consumed by the processor is proportional to the clock speed, the Rabbit 5000 provides 12 clock modes that can go as low as 2 kHz. To further reduce power consumption in those ultra-sleepy modes, various shortened chip select strobes are available to reduce current draw by the attached memory devices.

Figure 29-1 shows a typical current draw as a function of the main clock frequency. The values shown do not include any current consumed by external oscillators or memory. It is assumed that approximately 30 pF is connected to each address line.



Figure 29-1. Typical Current Draw as a Function of the Main Clock Frequency

The typical current draw in the ultra-sleepy modes is 2 mA for  $I_{CORE}$  and 5 mA for  $I_{IO}$ , depending on the pin activity.

# 29.1.1 Registers

| Register Name                      | Mnemonic | I/O Address | R/W | Reset    |
|------------------------------------|----------|-------------|-----|----------|
| Global Control/Status Register     | GCSR     | 0x0000      | R/W | 11000000 |
| Global Power Save Control Register | GPSCR    | 0x000D      | R/W | 00000000 |
| Global Clock Double Register       | GCDR     | 0x000F      | R/W | 00000000 |

# 29.2 Operation

#### 29.2.1 Unused Pins

Input (or bidirectional) pins that are unused in a design can pick up noise that may cause the transistors in the input buffer to switch states quickly, causing unnecessary current draw. To avoid this, all unused pins should be connected to a weak pullup or pulldown resistor (approximately  $100~\text{k}\Omega$ ) and left as inputs. This provides protection from noise when the pin is an input, but also limits the current draw if the pin gets inadvertently enabled as an output.

#### 29.2.2 Clock Rates

The processor and peripheral clocks in the Rabbit 5000 can be run in six different modes using the main oscillator: full speed; divided by 2, 4, 6, or 8; and the processor clock divided by 8 with the peripheral clock at full speed. If the clock doubler is enabled, the options also include twice the main oscillator frequency and the main oscillator divided by 3.

In addition, the 32 kHz clock can be used for the processor and peripheral clocks; the 32 kHz clock can also be divided by 2, 4, 8, or 16, which provides dramatically lower power consumption.

Table 29-1 lists the options for the clock modes and the processor clock frequency.

| Main Oscillator<br>GCSR Setting | Clock<br>Doubler | 32 kHz<br>Divider | Processor Clock<br>Frequency |  |
|---------------------------------|------------------|-------------------|------------------------------|--|
| Full                            | ll On            |                   | 2 × Main Oscillator          |  |
| Full                            | Off              |                   | Main Oscillator              |  |
| Divided by 2                    | On               |                   | Main Oscillator              |  |
| Divided by 2                    | Off              |                   | Main Oscillator / 2          |  |
| Divided by 4                    | On               | N/A               | Main Oscillator / 2          |  |
| Divided by 6                    | On               |                   | Main Oscillator / 3          |  |
| Divided by 4                    | Off              |                   | Main Oscillator / 4          |  |
| Divided by 8                    | On               |                   | Iviaiii Osciliatoi / 4       |  |
| Divided by 6                    | Off              |                   | Main Oscillator / 6          |  |
| Divided by 8                    | Off              |                   | Main Oscillator / 8          |  |
|                                 |                  | Disabled          | 32.768 kHz                   |  |
| Off                             |                  | / 2               | 16.384 kHz                   |  |
| (32 kHz divider                 | N/A              | / 4               | 8.192 kHz                    |  |
| used)                           |                  | / 8               | 4.096 kHz                    |  |
|                                 |                  | / 16              | 2.048 kHz                    |  |

Table 29-1. Clock Modes

Depending on the application, the processor can continue executing code normally when the main oscillator is divided down to a lower value. However, when the processor clock is running off of the 32 kHz clock, it is recommended that the Rabbit 5000 be performing a tight polling loop, waiting for a wake-up event.

## 29.2.3 Short Chip Selects

When running at a reduced clock speed, it is likely that the chip selects for external devices will not need to be active for an entire clock cycle. By reducing the width of the chip select, the power consumption of the memory chip can be reduced without having any affect on the processor itself.

For reduced processor speeds based on the main oscillator, a short chip select can be enabled in GPSCR (this feature is not available when the processor is running at full speed). This feature can be enabled separately for both reads and writes. When enabled, the chip select signals will be the width of two undivided clocks and located at the end of the transaction. The read data in the figures below is sampled by the rising edge of CLKI that terminated the T2 cycle. Wait states are inserted between T1 and T2 so they do not affect the width of the strobe.









When the processor is running off the 32 kHz clock, the short chip select option will produce chip select signal that is the width of a single 32 kHz clock (30.5 microseconds); otherwise the timing is identical to the short chip select options based off the main oscillator. Read strobe figures are shown below.











## 29.2.4 Self-Timed Chip Selects

Self-timed chip selects can be enabled via GPSCR to reduce power consumption even more when running off the 32 kHz oscillator. When self-timed chip selects are enabled, the chip select is only active for a short (selectable) period of time ranging from 110 to 290 ns; this can be enable for both reads and writes, or reads only. A sample read and write timing diagram is shown below.



# 29.3 Register Descriptions

| Glo       | bal Contro                                                                                                                                                               | ol/Status Register (GCSR) (Address = 0x0000)                                                                                                |  |  |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit(s)    | Value                                                                                                                                                                    | Description                                                                                                                                 |  |  |
| 7:6       | 00                                                                                                                                                                       | No reset or watchdog timer timeout since the last read.                                                                                     |  |  |
| (rd-only) | 01                                                                                                                                                                       | The watchdog timer timed out. These bits are cleared by a read of this register.                                                            |  |  |
|           | 10                                                                                                                                                                       | This bit combination is not possible.                                                                                                       |  |  |
|           | 11                                                                                                                                                                       | Reset occurred. These bits are cleared by a read of this register.                                                                          |  |  |
| 5         | 0                                                                                                                                                                        | No effect on the periodic interrupt. This bit will always be read as zero.                                                                  |  |  |
|           | 1                                                                                                                                                                        | Force a periodic interrupt to be pending.                                                                                                   |  |  |
| 4:2       | 000                                                                                                                                                                      | Processor clock from the fast clock, divided by 8. Peripheral clock from the fast clock, divided by 8.                                      |  |  |
|           | 001                                                                                                                                                                      | Processor clock from the fast clock, divided by 8. Peripheral clock from the fats clock.                                                    |  |  |
|           | 010                                                                                                                                                                      | Processor clock from the fast clock. Peripheral clock from the fast clock.                                                                  |  |  |
|           | 011                                                                                                                                                                      | Processor clock from the fast clock, divided by 2. Peripheral clock from the fast clock, divided by 2.                                      |  |  |
|           | 100                                                                                                                                                                      | Processor clock from the 32 kHz clock, optionally divided via GPSCR.  Peripheral clock from the 32 kHz clock, optionally divided via GPSCR. |  |  |
|           | Processor clock from the 32 kHz clock, optionally divided via GPSCR.  Peripheral clock from the 32 kHz clock, optionally divided via GPSCR.  The fast clock is disabled. |                                                                                                                                             |  |  |
|           | 110                                                                                                                                                                      | Processor clock from the fast clock, divided by 4. Peripheral clock from the fast clock, divided by 4.                                      |  |  |
|           | Processor clock from the fast clock, divided by 6. Peripheral clock from the fast clock, divided by 6.                                                                   |                                                                                                                                             |  |  |
| 1:0       | 00                                                                                                                                                                       | Periodic interrupts are disabled.                                                                                                           |  |  |
|           | 01                                                                                                                                                                       | Periodic interrupts use Interrupt Priority 1.                                                                                               |  |  |
|           | 10                                                                                                                                                                       | Periodic interrupts use Interrupt Priority 2.                                                                                               |  |  |
|           | 11                                                                                                                                                                       | Periodic interrupts use Interrupt Priority 3.                                                                                               |  |  |

| Globa                                   | l Power S | ave Control Register (GPSCR) (Address = 0x000D)                          |  |  |  |
|-----------------------------------------|-----------|--------------------------------------------------------------------------|--|--|--|
| Bit(s)                                  | Value     | Description                                                              |  |  |  |
| 7:5                                     | 000       | Self-timed chip selects are disabled.                                    |  |  |  |
|                                         | 001       | 230 ns self-timed chip selects for read and write.                       |  |  |  |
|                                         | 010       | 170 ns self-timed chip selects for read and write.                       |  |  |  |
|                                         | 011       | 110 ns self-timed chip selects for read and write.                       |  |  |  |
|                                         | 100       | 290 ns self-timed chip selects for read only.                            |  |  |  |
|                                         | 101       | 230 ns self-timed chip selects for read only.                            |  |  |  |
|                                         | 110       | 170 ns self-timed chip selects for read only.                            |  |  |  |
|                                         | 111       | 110 ns self-timed chip selects for read only.                            |  |  |  |
| 4                                       | 0         | Normal chip select timing for read cycles.                               |  |  |  |
|                                         | 1         | Short chip select timing for read cycles (not available in full speed).  |  |  |  |
| 3 0 Normal chip select timing for write |           | Normal chip select timing for write cycles                               |  |  |  |
|                                         | 1         | Short chip select timing for write cycles (not available in full speed). |  |  |  |
| 2:0                                     | 000       | The 32 kHz clock divider is disabled.                                    |  |  |  |
|                                         | 001       | This bit combination is reserved and should not be used.                 |  |  |  |
|                                         | 010       | This bit combination is reserved and should not be used.                 |  |  |  |
|                                         | 011       | This bit combination is reserved and should not be used.                 |  |  |  |
|                                         | 100       | 32 kHz clock divided by 2 (16.384 kHz).                                  |  |  |  |
|                                         | 101       | 32 kHz clock divided by 4 (8.192 kHz).                                   |  |  |  |
|                                         | 110       | 32 kHz clock divided by 8 (4.096 kHz).                                   |  |  |  |
|                                         | 111       | 32 kHz clock divided by 16 (2.048 kHz).                                  |  |  |  |

| GI     | obal Clock | Double Register            | (GCDR)                                 | (Address = 0x000F) |  |  |  |
|--------|------------|----------------------------|----------------------------------------|--------------------|--|--|--|
| Bit(s) | Value      |                            | Description                            |                    |  |  |  |
| 7:5    |            | These bits are reserved an | nd should be written w                 | rith zeros.        |  |  |  |
| 4:0    | 00000      | The clock doubler circuit  | The clock doubler circuit is disabled. |                    |  |  |  |
|        | 00001      | 6 ns nominal low time.     | 6 ns nominal low time.                 |                    |  |  |  |
|        | 00010      | 7 ns nominal low time.     |                                        |                    |  |  |  |
|        | 00011      | 8 ns nominal low time.     |                                        |                    |  |  |  |
|        | 00100      | 9 ns nominal low time.     |                                        |                    |  |  |  |
|        | 00101      | 10 ns nominal low time.    |                                        |                    |  |  |  |
|        | 00110      | 11 ns nominal low time.    |                                        |                    |  |  |  |
|        | 00111      | 12 ns nominal low time.    |                                        |                    |  |  |  |
|        | 01000      | 13 ns nominal low time.    |                                        |                    |  |  |  |
|        | 01001      | 14 ns nominal low time.    |                                        |                    |  |  |  |
|        | 01010      | 15 ns nominal low time.    |                                        |                    |  |  |  |
|        | 01011      | 16 ns nominal low time.    |                                        |                    |  |  |  |
|        | 01100      | 17 ns nominal low time.    |                                        |                    |  |  |  |
|        | 01101      | 18 ns nominal low time.    |                                        |                    |  |  |  |
|        | 01110      | 19 ns nominal low time.    |                                        |                    |  |  |  |
|        | 01111      | 20 ns nominal low time.    |                                        |                    |  |  |  |
|        | 10001      | 3 ns nominal low time.     |                                        |                    |  |  |  |
|        | 10010      | 4 ns nominal low time.     |                                        |                    |  |  |  |
|        | 10011      | 5 ns nominal low time.     |                                        |                    |  |  |  |
|        | other      | Any bit combination not    | listed is reserved and i               | must not be used.  |  |  |  |

# 30. SYSTEM/USER MODE

#### 30.1 Overview

The Rabbit 5000 provides support for two tiers of control in the processor: *System Mode*, which provides full access to all processor resources; and *User Mode*, a more restricted mode. Table 30-1 describes the essential differences between the System Mode and the User Mode. The System Mode is essentially the same as the normal operation when the System/User Mode is disabled.

Table 30-1. Differences Between System Mode and User Mode

| System Mode                                                                           | User Mode                                                                            |  |  |
|---------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|--|--|
| All peripherals accessible.                                                           | No peripherals accessible by default.                                                |  |  |
| All processor control registers available.                                            | No processor control registers available.                                            |  |  |
| All interrupt priorities available.                                                   | Interrupt Priority 3 not allowed.                                                    |  |  |
| IDET instruction has no effect.                                                       | IDET instruction causes Priority 3 "System mode violation" interrupt.                |  |  |
| No write protection when 0x00 is written to WPCR (write protection in User mode only) | Write to protected segment causes Priority 3 "write protection violation" interrupt. |  |  |
| Easy to enter user mode (SETUSR instruction).                                         | Difficult to enter system mode (requires interrupt, SYSCALL, or RST instruction).    |  |  |

The main intent of the System/User Mode is to protect critical code (for example, code that performs remote firmware updates), data, and the current processor state (memory setup, peripheral control, etc.) from inadvertent changes by the user's standard code. By removing access to the processor's I/O registers and preventing memory writes to critical regions, the user's code can run without the danger of locking up the processor to the point where it cannot be restarted remotely and/or new code uploaded.

# 30.1.1 Registers

| Register Name                           | Mnemonic | I/O Address | R/W | Reset    |
|-----------------------------------------|----------|-------------|-----|----------|
| Enable Dual-Mode Register               | EDMR     | 0x0420      | W   | 00000000 |
| Real-Time Clock User Enable Register    | RTUER    | 0x0300      | W   | 00000000 |
| Slave Port User Enable Register         | SPUER    | 0x0320      | W   | 00000000 |
| Parallel Port A User Enable Register    | PAUER    | 0x0330      | W   | 00000000 |
| Parallel Port B User Enable Register    | PBUER    | 0x0340      | W   | 00000000 |
| Parallel Port C User Enable Register    | PCUER    | 0x0350      | W   | 00000000 |
| Parallel Port D User Enable Register    | PDUER    | 0x0360      | W   | 00000000 |
| Parallel Port E User Enable Register    | PEUER    | 0x0370      | W   | 00000000 |
| Input Capture User Enable Register      | ICUER    | 0x0358      | W   | 00000000 |
| I/O Bank User Enable Register           | IBUER    | 0x0380      | W   | 00000000 |
| PWM User Enable Register                | PWUER    | 0x0388      | W   | 00000000 |
| Quad Decode User Enable Register        | QDUER    | 0x0390      | W   | 00000000 |
| External Interrupt User Enable Register | IUER     | 0x0398      | W   | 00000000 |
| Timer A User Enable Register            | TAUER    | 0x03A0      | W   | 00000000 |
| Analog User Enable Register             | AUER     | 0x03A8      | W   | 00000000 |
| Timer B User Enable Register            | TBUER    | 0x03B0      | W   | 00000000 |
| Timer C User Enable Register            | TCUER    | 0x3F8       | W   | 00000000 |
| Serial Port A User Enable Register      | SAUER    | 0x03C0      | W   | 00000000 |
| Serial Port B User Enable Register      | SBUER    | 0x3D0       | W   | 00000000 |
| Serial Port C User Enable Register      | SCUER    | 0x3E0       | W   | 00000000 |
| Serial Port D User Enable Register      | SDUER    | 0x3F0       | W   | 00000000 |
| Serial Port E User Enable Register      | SEUER    | 0x03C8      | W   | 00000000 |
| Serial Port F User Enable Register      | SFUER    | 0x3D8       | W   | 00000000 |
| Enable Dual-Mode Register               | EDMR     | 0x0420      | R/W | 00000000 |

# 30.2 Dependencies

### 30.2.1 I/O Pins

There are no pin dependencies for the System/User Mode.

### 30.2.2 Clocks

There are no clock dependencies for the System/User Mode.

# 30.2.3 Other Registers

Any writes to the internal I/O registers listed in Table 30-2 are ignored when the System/User Mode is enabled and the processor is in the User Mode.

Table 30-2. I/O Addresses Inaccessible in User Mode

| Register Name                      | Mnemonic  | I/O Address |
|------------------------------------|-----------|-------------|
| Global Control/Status Register     | GCSR      | 0x0000      |
| Watchdog Timer Control Register    | WDTCR     | 0x0008      |
| Watchdog Timer Test Register       | WDTTR     | 0x0009      |
| Global Clock Modulator 0 Register  | GCM0R     | 0x000A      |
| Global Clock Modulator 1 Register  | GCM1R     | 0x000B      |
| Secondary Watchdog Timer Register  | SWDTR     | 0x000C      |
| Global Power Save Control Register | GPSCR     | 0x000D      |
| Global Output Control Register     | GOCR      | 0x000E      |
| Global Clock Double Register       | GCDR      | 0x000F      |
| MMU Instruction/Data Register      | MMIDR     | 0x0010      |
| Stack Segment Register             | STACKSEG  | 0x0011      |
| Data Segment Register              | DATASEG   | 0x0012      |
| Segment Size Register              | SEGSIZE   | 0x0013      |
| Memory Bank 0 Control Register     | MB0CR     | 0x0014      |
| Memory Bank 1 Control Register     | MB1CR     | 0x0015      |
| Memory Bank 2 Control Register     | MB2CR     | 0x0016      |
| Memory Bank 3 Control Register     | MB3CR     | 0x0017      |
| MMU Expanded Code Register         | MECR      | 0x0018      |
| Memory Timing Control Register     | MTCR      | 0x0019      |
| Stack Segment Low Register         | STACKSEGL | 0x001A      |
| Stack Segment High Register        | STACKSEGH | 0x001B      |
| Breakpoint/Debug Control Register  | BDCR      | 0x001C      |
| Memory Alternate Control Register  | MACR      | 0x001D      |
| Data Segment Low Register          | DATSEGL   | 0x001E      |

Table 30-2. I/O Addresses Inaccessible in User Mode (continued)

| Register Name                        | Mnemonic | I/O Address     |
|--------------------------------------|----------|-----------------|
| Data Segment High Register           | DATSEGH  | 0x001F          |
| DMA registers                        |          | 0x0100 – 0x01FF |
| Network Port B registers             |          | 0x0200 - 0x02FF |
| User Enable and Breakpoint registers |          | 0x0300 - 0x03FF |
| Memory Protection registers          |          | 0x0400 - 0x04FF |
| Network Port C registers             |          | 0x0A00 – 0x0AFF |

## 30.2.4 Interrupts

The System Mode Violation interrupt occurs whenever the IDET instruction is executed while the System/User mode is enabled and the processor is in the User Mode. Its purpose is to trap when system code is being executed while the processor is in the User Mode.

The System Mode Violation interrupt vector is in the IIR at offset 0x180. It always occurs at Priority 3.

Note that Priority 3 is not available while the System/User Mode is enabled and the processor is in the User Mode. If the processor is placed into Priority 3 either by an instruction or an interrupt, it will respond as if it was set to Priority 2.

When the System/User Mode is enabled, it is critical to handle the SU stack in interrupts as well as the IP stack; always perform a **SURES** before the **IPRES** at the end of the interrupt.

## 30.3 Operation

The System/User Mode is designed to work with the memory and stack protection features of the Rabbit 5000 processor to provide a seamless framework for protection of critical code. However, there are many levels at which the System/User Mode can be used — some examples are described here.

## 30.3.1 Memory Protection Only

At the beginning of the user program, all necessary peripherals are enabled, all peripheral interrupts to be used are set up for the User Mode, critical memory regions are protected, stack limits are set, and the various system/memory/stack violation interrupts are enabled. The processor then enters the User Mode and remains in the User Mode for all operations (interrupts can be handled however the user desires). Obviously the critical interrupts can be handled in the System Mode, but at that point the device is typically reset and the error is logged. Figure 30-1 shows an overview of this level of operation.



Figure 30-1. System/User Mode Setup for Memory Protection Only

### 30.3.2 Mixed System/User Mode Operation

This mode is similar to the previous mode, but with some portions of the program written for System Mode — for example, peripheral interrupts where latency is critical. By keeping the System Mode code sections small, potential system crashes are still minimized. Figure 30-2 shows an overview of this level of operation.



Figure 30-2. System/User Mode Setup for Mixed Operation

## 30.3.3 Complete Operating System

This section describes a "full" use of the System/User Mode — separating all common functions into a System Mode "operating system" while letting the application-specific code run in the User Mode. By default, the System Mode handles all peripherals and interrupts, as well as high-level interfaces such as a flash file system. However, the processor will be running the application code in the User Mode most of the time.

The application code can request direct access to a peripheral and/or interrupt from the System Mode. If allowed, the System Mode can create an interrupt vector as described in Section 30.3.7 that will execute the user code interrupt handler.

When the application code wants to perform an action that is controlled by the System Mode, it can request the particular action by loading the appropriate value into HL and executing SYSCALL. This requires generating a list of all the actions that the application code would want to do, assigning values to each action, and implementing a SYSCALL handler in the System Mode that parses the value passed to it and calls the appropriate function.

Write protection should be enabled (User Mode only) for all blocks containing system code and data as well as any critical memory regions.

If any critical interrupts occur (stack limit violation, system mode violation, write protection violation), System Mode handlers can perform any of a number of operations: restart the application code, signal another device, halt operation, and so on.

Figure 30-3 shows an overview of this level of operation.



Figure 30-3. System/User Mode Setup for Operating System

## 30.3.4 Enabling the System/User Mode

The following steps describe how to enable the System/User Mode.

- 1. If a peripheral needs to be accessed while in User Mode, write to the appropriate user enable register to allow that access.
- 2. Write a 1 to bit 0 of EDMR to enable System/User Mode.
- 3. Execute the SETUSR instruction to enter User Mode.

After the User Mode is entered, the limitations described earlier are in effect — writes to protected registers will be ignored, Priority 3 is not available, and executing an IDET will cause a System Mode Violation interrupt. Other features such as write protection may be effect for user mode as well.

### 30.3.5 System/User Mode Instructions

Seven instructions exist primarily to support the System/User Mode, and are listed in Table 30-3. Note that **IDET** shares the value of **LD E, E** in the opcode table, and will always perform that operation (but will have special behavior when the System/User Mode is enabled and the processor is in System Mode). In addition, if the ALTD prefix appears before the instruction, **LD E', E** is always executed and the special behavior does not occur.

Table 30-3. System/User Mode Instructions

| Instruction | Bytes | clk | Α | I | S | Z | ٧ | С | Operation                                                                                                                                               | Priv |
|-------------|-------|-----|---|---|---|---|---|---|---------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| SETUSR      | 2     | 4   |   | - | - | - | - | - | $SU = {SU[5:0], 0x01}$                                                                                                                                  | Yes  |
| PUSH SU     | 2     | 9   |   | - | - | - | - | - | (SP-1) = SU; SP = SP - 1                                                                                                                                | Yes  |
| POP SU      | 2     | 7   |   | - | - | - | - | - | SU = (SP); SP = SP + 1                                                                                                                                  | Yes  |
| SURES       | 2     | 4   |   | - | - | - | - | - | SU = {SU[1:0], SU[7:2]}                                                                                                                                 | Yes  |
| IDET        | 1     | 2   |   | - | _ | - | _ | - | Performs <b>LD E, E</b> , but if (EDMF && SU[0]) then the System Violation interrupt flag is set; if ALTD appears before it always does <b>LD E', E</b> | No   |
| RDMODE      | 2     | 4   |   | - | - | - | - | * | CF = SU[0]                                                                                                                                              | Yes  |
| SYSCALL     | 2     | 10  |   | - | - | - | - | - | $SP = SP - 2$ ; $PC = \{R,v\}$ where $v = SYSCALL$ offset                                                                                               | No   |
| SCALL       | 2     | 15  |   | _ | - | - | _ | - | (SP-1) = PCH; (SP-2) = PCL; (SP-3) = SU;<br>SP = SP - 3; PC = {IIR, 01100000};<br>SU = {SU[5:0], 00}                                                    | No   |
| SRET        | 2     | 12  |   | - | - | - | - | - | SU = (SP); PCL = (SP+1); PCH = (SP+2);<br>SP = SP+3                                                                                                     | No   |
| SETUSRP mn  | 4     | 15  |   | - | - | - | - | - | SU = {SU[7:2], 01}, (SP-1) = m;<br>(SP-2) = n; SP = SP-2                                                                                                | No   |
| SETSYSP mn  | 4     | 12  |   | - | - | - | - | - | SU = {SU[1:0], SU[7:2]}; tmpl = (SP);<br>tmph = (SP+1); SP = SP+2;<br>if {tmp! = mn} System Violation                                                   | No   |

The processor keeps a one-byte stack (called the SU register) that is analogous to the IP register that keeps track of the interrupt priority. Every time **SETUSR** is executed (to enter the User Mode), or an interrupt occurs, or **SYSCALL** or **RST** is executed (to enter System Mode), the current mode is pushed onto the SU register. When a **SURES** is executed, the previous mode is popped off the SU register.

The effects of each instruction are:

- The **SETUSR** instruction puts the processor into the User Mode by pushing the correct value into the SU register.
- PUSH SU and POP SU push and pop the single-byte SU register on/off the SP stack.
- **SURES** pops the current processor mode off the SU register, returning it to the previous mode.
- IDET causes an interrupt if executed in the User Mode, and does nothing in System Mode. It is intended to be placed in system-level code and trap any execution of that code while in the User Mode.
- **RDMODE** returns the current mode in the carry flag (0 for System Mode, 1 for User Mode).
- **SYSCALL** is essentially a new **RST** instruction, and was added to allow User Mode access to the System Mode without using one of the existing **RST** instructions. It will put the processor into the System Mode and execute code in the corresponding interrupt-vector table entry.
- **SCALL** is another **RST** instruction that vectors to the same address as **SYSCALL**. The difference is that it also pushes the value of the SU register as well as the return address onto the stack.
- **SRET** is the companion instruction to **SCALL**; it expects both SU and the return address to be on the stack.
- **SETSYSP** and **SETUSRP** are support functions for handing user mode interrupts. pushes a 16-bit compare value onto the stack and enters user mode. **SETSYSP** pops a 16-bit value off the stack and compares it to the provided value; a system mode violation interrupt occurs if they do not match. These two instructions provide protection for User Mode interrupts by checking for both main stack and SU stack mismatches when the User Mode handler returns.

## 30.3.6 System Mode Violation Interrupt

The following steps describe how to set up the System Mode Violation interrupt.

- 1. Write the vector to the interrupt service routine to the internal interrupt table.
- 2. Enable the system/user mode by writing to EDMR.
- 3. The interrupt request is cleared automatically when handled.

A sample interrupt handler is shown below.

```
sysmode_isr::
   push af
   ; handle the system mode violation here
   pop af
   sures
   ipres
   ret
```

## 30.3.7 Handling Interrupts in the System/User Mode

Interrupts, **RST**s, **SYSCALL**, and **SCALL** all enter the System Mode automatically. There will be times, however, that an interrupt should be handled in the User Mode. The solution to this is for System Mode interrupt vector to reenter the User Mode before calling the User Mode interrupt handler. An example of both system and user interrupt handling is shown in Figure 30-4.

When enabled for User Mode access, a peripheral interrupt (if it is capable of generating an interrupt) can only be requested at Priority 2 or 1.



Figure 30-4. Interrupt Handing in the System/User Mode

Some sample code for both System Mode interrupts and User Mode interrupts is shown below. The use of **SETUSRP** and **SETSYSP** provides checks against stack mismatches and incorrect System/User Modes coming out of the User Mode handler.

```
systemmode_isr:
                              ; jumped to from interrupt vector table
   ... handle interrupt ...
   sures
                              ; reenter previous mode
                              ; restore previous interrupt priority
  ipres
  ret
usermode isr:
                              ; jumped to from interrupt vector table
                                   (still in system mode at this point)
  push su
                              ; preserve current SU stack
  setusrp 0x1234
                              ; enter user mode with stack compare value
  call user_handler
                              ; handle interrupt at user level
  setsysp 0x1234
                              ; return to system mode
  sures
                              ; reenter previous mode
  ipres
                              ; restore previous interrupt priority
  ret
```

### **30.4 Register Descriptions**

| Real-T | Real-Time Clock User Enable Register |                                                                    | (RTUER)               | (Address = 0x0300) |
|--------|--------------------------------------|--------------------------------------------------------------------|-----------------------|--------------------|
| Bit(s) | Value                                | Description                                                        |                       |                    |
| 7      | 0                                    | Disable User Mode access to the RTC (I/O addresses 0x0002–0x0007). |                       |                    |
|        | 1                                    | Enable User Mode access to the RTC (I/O addresses 0x0002–0x0007).  |                       |                    |
| 6:0    |                                      | These bits are reserved and                                        | d should be written w | ith zeros.         |

| Slav   | ve Port Use | er Enable Register                                                        | (SPUER)                 | (Address = 0x0320) |
|--------|-------------|---------------------------------------------------------------------------|-------------------------|--------------------|
| Bit(s) | Value       | Description                                                               |                         |                    |
| 7      | 0           | Disable User Mode access to the slave port (I/O addresses 0x0020–0x0027). |                         |                    |
|        | 1           | Enable User Mode access to the slave port (I/O addresses 0x0020–0x0027).  |                         |                    |
| 6:0    |             | These bits are reserved a                                                 | and should be written w | ith zeros.         |

| Parall | Parallel Port A User Enable Register |                                                                            | (PAUER)               | (Address = 0x0330) |
|--------|--------------------------------------|----------------------------------------------------------------------------|-----------------------|--------------------|
| Bit(s) | Value                                | Description                                                                |                       |                    |
| 7      | 0                                    | Disable User Mode access to Parallel Port A (I/O addresses 0x0030–0x0037). |                       |                    |
|        | 1                                    | Enable User Mode access to Parallel Port A (I/O addresses 0x0030–0x0037).  |                       |                    |
| 6:0    |                                      | These bits are reserved an                                                 | d should be written w | ith zeros.         |

| Parall | Parallel Port H User Enable Register |                                                                            | (PHUER)               | (Address = 0x0332) |
|--------|--------------------------------------|----------------------------------------------------------------------------|-----------------------|--------------------|
| Bit(s) | Value                                | Description                                                                |                       |                    |
| 7      | 0                                    | Disable User Mode access to Parallel Port H (I/O addresses 0x0032–0x0037). |                       |                    |
|        | 1                                    | Enable User Mode access to Parallel Port H (I/O addresses 0x0032–0x0037).  |                       |                    |
| 6:0    |                                      | These bits are reserved and                                                | d should be written w | ith zeros.         |

| Parall | Parallel Port B User Enable Register |                                                                            | (PBUER)               | (Address = 0x0340) |
|--------|--------------------------------------|----------------------------------------------------------------------------|-----------------------|--------------------|
| Bit(s) | Value                                | Description                                                                |                       |                    |
| 7      | 0                                    | Disable User Mode access to Parallel Port B (I/O addresses 0x0040–0x0047). |                       |                    |
|        | 1                                    | Enable User Mode access to Parallel Port B (I/O addresses 0x0040–0x0047).  |                       |                    |
| 6:0    |                                      | These bits are reserved an                                                 | d should be written w | ith zeros.         |

| Parall | Parallel Port C User Enable Register |                                                                            | (PCUER)               | (Address = 0x0350) |
|--------|--------------------------------------|----------------------------------------------------------------------------|-----------------------|--------------------|
| Bit(s) | Value                                | Description                                                                |                       |                    |
| 7      | 0                                    | Disable User Mode access to Parallel Port C (I/O addresses 0x0050–0x0055). |                       |                    |
|        | 1                                    | Enable User Mode access to Parallel Port C (I/O addresses 0x0050–0x0055).  |                       |                    |
| 6:0    |                                      | These bits are reserved an                                                 | d should be written w | ith zeros.         |

| Parall | Parallel Port D User Enable Register |                                                                            | (PDUER)               | (Address = 0x0360) |
|--------|--------------------------------------|----------------------------------------------------------------------------|-----------------------|--------------------|
| Bit(s) | Value                                | Description                                                                |                       |                    |
| 7      | 0                                    | Disable User Mode access to Parallel Port D (I/O addresses 0x0060–0x006F). |                       |                    |
|        | 1                                    | Enable User Mode access to Parallel Port D (I/O addresses 0x0060–0x006F).  |                       |                    |
| 6:0    |                                      | These bits are reserved and                                                | d should be written w | ith zeros.         |

| Parall | Parallel Port E User Enable Register |                                                                            | (PEUER)               | (Address = 0x0370) |
|--------|--------------------------------------|----------------------------------------------------------------------------|-----------------------|--------------------|
| Bit(s) | Value                                | Description                                                                |                       |                    |
| 7      | 0                                    | Disable User Mode access to Parallel Port E (I/O addresses 0x0070–0x007F). |                       |                    |
|        | 1                                    | Enable User Mode access to Parallel Port E (I/O addresses 0x0070–0x007F).  |                       |                    |
| 6:0    |                                      | These bits are reserved and                                                | d should be written w | ith zeros.         |

| Input  | Capture U | ser Enable Register                                                     | (ICUER)               | (Address = 0x0358)        |
|--------|-----------|-------------------------------------------------------------------------|-----------------------|---------------------------|
| Bit(s) | Value     | Description                                                             |                       |                           |
| 7      | 0         | Disable User Mode access                                                | to input capture (I/O | addresses 0x0056–0x005F). |
|        | 1         | Enable User Mode access to input capture (I/O addresses 0x0056–0x005F). |                       |                           |
| 6:0    |           | These bits are reserved and                                             | d should be written w | vith zeros.               |

| I/O    | Bank Use | r Enable Register                                                          | (IBUER)               | (Address = 0x0380)            |
|--------|----------|----------------------------------------------------------------------------|-----------------------|-------------------------------|
| Bit(s) | Value    |                                                                            | Description           |                               |
| 7      | 0        | Disable User Mode access                                                   | to I/O Bank 7 (and ir | nternal I/O address 0x0087).  |
|        | 1        | Enable User Mode access                                                    | to I/O Bank 7 (and in | ternal I/O addresses 0x0087). |
| 6      | 0        | Disable User Mode access                                                   | to I/O Bank 6 (and ir | nternal I/O address 0x0086).  |
|        | 1        | Enable User Mode access                                                    | to I/O Bank 6 (and in | ternal I/O addresses 0x0086). |
| 5      | 0        | Disable User Mode access                                                   | to I/O Bank 5 (and ir | nternal I/O address 0x0085).  |
|        | 1        | Enable User Mode access to I/O Bank 5 (and internal I/O addresses 0x0085). |                       |                               |
| 4      | 0        | Disable User Mode access to I/O Bank 4 (and internal I/O address 0x0084).  |                       |                               |
|        | 1        | Enable User Mode access to I/O Bank 4 (and internal I/O addresses 0x0084). |                       |                               |
| 3      | 0        | Disable User Mode access to I/O Bank 3 (and internal I/O address 0x0083).  |                       |                               |
|        | 1        | Enable User Mode access                                                    | to I/O Bank 3 (and in | ternal I/O addresses 0x0083). |
| 2      | 0        | Disable User Mode access                                                   | to I/O Bank 2 (and ir | nternal I/O address 0x0082).  |
|        | 1        | Enable User Mode access                                                    | to I/O Bank 2 (and in | ternal I/O addresses 0x0082). |
| 1      | 0        | Disable User Mode access                                                   | to I/O Bank 1 (and ir | nternal I/O address 0x0081).  |
|        | 1        | Enable User Mode access                                                    | to I/O Bank 1 (and in | ternal I/O addresses 0x0081). |
| 0      | 0        | Disable User Mode access                                                   | to I/O Bank 0 (and ir | nternal I/O address 0x0080).  |
|        | 1        | Enable User Mode access                                                    | to I/O Bank 0 (and in | ternal I/O addresses 0x0080). |

| Р      | PWM User Enable Register |                                                                                      | (PWUER)                 | (Address = 0x0388) |
|--------|--------------------------|--------------------------------------------------------------------------------------|-------------------------|--------------------|
| Bit(s) | Value                    | Description                                                                          |                         |                    |
| 7      | 0                        | Disable User Mode access to the PWM (I/O addresses 0x0088–0x008F and 0x00E8–0x00E9). |                         |                    |
|        | 1                        | Enable User Mode access to the PWM (I/O addresses 0x0088–0x008F and 0x00E8–0x00E9).  |                         |                    |
| 6:0    |                          | These bits are reserved                                                              | and should be written w | ith zeros.         |

| Quad   | Quad Decode User Enable Register |                                                                                  | (QDUER)                | (Address = 0x0390)            |
|--------|----------------------------------|----------------------------------------------------------------------------------|------------------------|-------------------------------|
| Bit(s) | Value                            | Description                                                                      |                        |                               |
| 7      | 0                                | Disable User Mode acces 0x0097).                                                 | s to the Quadrature De | ecoder (I/O addresses 0x0090– |
|        | 1                                | Enable User Mode access to the Quadrature Decoder (I/O addresses 0x0090–0x0097). |                        |                               |
| 6:0    |                                  | These bits are reserved an                                                       | d should be written w  | ith zeros.                    |

| Externa | I Interrupt | User Enable Register                                                    | (IUER)             | (Address = 0x0398)        |
|---------|-------------|-------------------------------------------------------------------------|--------------------|---------------------------|
| Bit(s)  | Value       | Description                                                             |                    |                           |
| 7:2     |             | These bits are reserved and should be written with zeros.               |                    |                           |
| 1       | 0           | Disable User Mode access to External Interrupt 1 (I/O address 0x0099).  |                    |                           |
|         | 1           | Enable User Mode access to External Interrupt 1 (I/O addresses 0x0099). |                    |                           |
| 0       | 0           | Disable User Mode access to External Interrupt 0 (I/O address 0x0098).  |                    |                           |
|         | 1           | Enable User Mode access to                                              | External Interrupt | 0 (I/O addresses 0x0098). |

| Tir    | Timer A User Enable Register |                                                                    | (TAUER) | (Address = 0x03A0) |
|--------|------------------------------|--------------------------------------------------------------------|---------|--------------------|
| Bit(s) | Value                        | Description                                                        |         |                    |
| 7      | 0                            | Disable User Mode access to Timer A (I/O addresses 0x00A0–0x00AF). |         |                    |
|        | 1                            | Enable User Mode access to Timer A (I/O addresses 0x00A0–0x00AF).  |         |                    |
| 6:0    |                              | These bits are reserved and should be written with zeros.          |         |                    |

| Ar     | nalog User | Enable Register                                                             | (AUER)                 | (Address = 0x03A8)               |
|--------|------------|-----------------------------------------------------------------------------|------------------------|----------------------------------|
| Bit(s) | Value      |                                                                             | Description            | 1                                |
| 7:3    |            | These bits are reserved an                                                  | nd should be written v | vith zeros.                      |
| 2      | 0          | Disable User Mode access to Analog Channel 2 (I/O addresses 0x0820–0x082F). |                        |                                  |
|        | 1          | Enable User Mode access to Analog Channel 2 (I/O addresses 0x0820–0x082F).  |                        |                                  |
| 1      | 0          | Disable User Mode access to Analog Channel 1 (I/O addresses 0x0810–0x081F). |                        |                                  |
|        | 1          | Enable User Mode access to Analog Channel 1 (I/O addresses 0x0810–0x081F).  |                        |                                  |
| 0      | 0          | Disable User Mode acces                                                     | ss to Analog Channel ( | ) (I/O addresses 0x0800–0x080F). |
|        | 1          | Enable User Mode access                                                     | s to Analog Channel 0  | (I/O addresses 0x0800–0x080F).   |

| Tir    | ner B User | Enable Register                                                    | (TBUER)                 | (Address = 0x03B0) |
|--------|------------|--------------------------------------------------------------------|-------------------------|--------------------|
| Bit(s) | Value      | Description                                                        |                         |                    |
| 7      | 0          | Disable User Mode access to Timer B (I/O addresses 0x00B0-0x00BF). |                         |                    |
|        | 1          | Enable User Mode access to Timer B (I/O addresses 0x00B0–0x00BF).  |                         |                    |
| 6:0    |            | These bits are reserved                                            | and should be written w | ith zeros.         |

| Tir    | Timer C User Enable Register |                                                                                      | (TCUER)                 | (Address = 0x03F8) |
|--------|------------------------------|--------------------------------------------------------------------------------------|-------------------------|--------------------|
| Bit(s) | Value                        | Description                                                                          |                         |                    |
| 7      | 0                            | Disable User Mode access to Timer C (I/O addresses 0x0500–0x050F and 0x00F8–0x00F9). |                         |                    |
|        | 1                            | Enable User Mode access to Timer C (I/O addresses 0x0500–0x050F and 0x00F8–0x00F9).  |                         |                    |
| 6:0    |                              | These bits are reserved                                                              | and should be written w | ith zeros.         |

| Seria  | I Port A Us | ser Enable Register                                                      | (SAUER)                | (Address = 0x03C0) |
|--------|-------------|--------------------------------------------------------------------------|------------------------|--------------------|
| Bit(s) | Value       | Description                                                              |                        |                    |
| 7      | 0           | Disable User Mode access to Serial Port A (I/O addresses 0x00C0–0x00C7). |                        |                    |
|        | 1           | Enable User Mode access to Serial Port A (I/O addresses 0x00C0-0x00C7).  |                        |                    |
| 6:0    |             | These bits are reserved an                                               | nd should be written w | ith zeros.         |

| Seria  | I Port B Us | ser Enable Register                                                      | (SBUER)                | (Address = 0x03D0) |
|--------|-------------|--------------------------------------------------------------------------|------------------------|--------------------|
| Bit(s) | Value       | Description                                                              |                        |                    |
| 7      | 0           | Disable User Mode access to Serial Port B (I/O addresses 0x00D0–0x00D7). |                        |                    |
|        | 1           | Enable User Mode access to Serial Port B (I/O addresses 0x00D0–0x00D7).  |                        |                    |
| 6:0    |             | These bits are reserved an                                               | nd should be written w | rith zeros.        |

| Seria  | Serial Port C User Enable Register |                                                                          | (SCUER)                | (Address = 0x03E0) |
|--------|------------------------------------|--------------------------------------------------------------------------|------------------------|--------------------|
| Bit(s) | Value                              | Description                                                              |                        |                    |
| 7      | 0                                  | Disable User Mode access to Serial Port C (I/O addresses 0x00E0–0x00E7). |                        |                    |
|        | 1                                  | Enable User Mode access to Serial Port C (I/O addresses 0x00E0-0x00E7).  |                        |                    |
| 6:0    |                                    | These bits are reserved an                                               | nd should be written w | ith zeros.         |

| Seria  | I Port D Us | ser Enable Register                                                     | (SDUER)                 | (Address = 0x03F0)        |
|--------|-------------|-------------------------------------------------------------------------|-------------------------|---------------------------|
| Bit(s) | Value       | Description                                                             |                         |                           |
| 7      | 0           | Disable User Mode acces                                                 | s to Serial Port D (I/O | addresses 0x00F0–0x00F7). |
|        | 1           | Enable User Mode access to Serial Port D (I/O addresses 0x00F0–0x00F7). |                         |                           |
| 6:0    |             | These bits are reserved an                                              | nd should be written w  | ith zeros.                |

| Seria  | Serial Port E User Enable Register |                                                                          | (SEUER)                | (Address = 0x03C8) |
|--------|------------------------------------|--------------------------------------------------------------------------|------------------------|--------------------|
| Bit(s) | Value                              | Description                                                              |                        |                    |
| 7      | 0                                  | Disable User Mode access to Serial Port E (I/O addresses 0x00C8–0x00CF). |                        |                    |
|        | 1                                  | Enable User Mode access to Serial Port E (I/O addresses 0x00C8–0x00CF).  |                        |                    |
| 6:0    |                                    | These bits are reserved an                                               | nd should be written w | ith zeros.         |

| Seria  | Serial Port F User Enable Register |                                                                          | (SFUER)                | (Address = 0x03D8) |
|--------|------------------------------------|--------------------------------------------------------------------------|------------------------|--------------------|
| Bit(s) | Value                              | Description                                                              |                        |                    |
| 7      | 0                                  | Disable User Mode access to Serial Port F (I/O addresses 0x00D8–0x00DF). |                        |                    |
|        | 1                                  | Enable User Mode access to Serial Port F (I/O addresses 0x00D8–0x00DF).  |                        |                    |
| 6:0    |                                    | These bits are reserved ar                                               | nd should be written w | vith zeros.        |

| E      | nable Dua | I-Mode Register                                           | (EDMR)               | (Address = 0x0420) |
|--------|-----------|-----------------------------------------------------------|----------------------|--------------------|
| Bit(s) | Value     |                                                           | Description          | 1                  |
| 7:6    | 00        | Default (Rabbit 2000/300                                  | 00) instruction set. |                    |
|        | 01        | This bit combination is reserved and must not be used.    |                      |                    |
|        | 10        | This bit combination is reserved and must not be used.    |                      |                    |
|        | 11        | Enhanced (Rabbit 5000) instruction set.                   |                      |                    |
| 5:1    |           | These bits are reserved and should be written with zeros. |                      |                    |
| 0      | 0         | Normal (System Mode only) operation.                      |                      |                    |
|        | 1         | Enable System/User Mod                                    | le operation.        |                    |

## 31. SPECIFICATIONS

#### 31.1 DC Characteristics

Table 31-1. Preliminary DC Electrical Characteristics

|                                | Parameter                                                                                                                                               |                     | Min    | Тур    | Max                                             |
|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|--------|--------|-------------------------------------------------|
| Oper                           | rating Temperature                                                                                                                                      | $T_{A}$             | -40°C  |        | 85°C                                            |
| Storage Temperature            |                                                                                                                                                         | <sup>1</sup> A      | -55°C  |        | 125°C                                           |
|                                | Core Supply Voltage                                                                                                                                     | VDD <sub>CORE</sub> | 1.65 V | 1.8 V  | 1.90 V                                          |
|                                | Core Current @ 100 MHz, Wi-Fi enabled, 25°C                                                                                                             |                     |        | 194 mA |                                                 |
| Core                           | Core Current @ 100 MHz, Wi-Fi disabled, 25°C                                                                                                            | T                   |        | 32 mA  |                                                 |
|                                | Core Current @ 50 MHz, Wi-Fi disabled, 25°C                                                                                                             | $I_{CORE}$          |        | 17 mA  |                                                 |
|                                | Core Current @ 32.768 kHz, Wi-Fi disabled, 25°C                                                                                                         |                     |        | 2 mA   |                                                 |
| I/O Ring Supply Voltage, 3.3 V |                                                                                                                                                         | $VDD_{IO}$          | 3.0 V  | 3.3 V  | 3.6 V                                           |
|                                | I/O Ring Current @ 88.4736 MHz, 25°C  I/O Ring Current @ 29.4912 MHz, 25°C                                                                              |                     |        | 22 mA  |                                                 |
|                                |                                                                                                                                                         |                     |        | 12 mA  |                                                 |
| ing                            | I/O Ring Current @ 32.768 kHz, 25°C                                                                                                                     |                     |        | 5 mA   |                                                 |
| I/O Ring                       | Input Low Voltage                                                                                                                                       | $V_{\rm IL}$        |        |        | 0.8 V                                           |
|                                | Input High Voltage                                                                                                                                      | $V_{\mathrm{IH}}$   | 2.0 V  |        |                                                 |
|                                | Output Low Voltage                                                                                                                                      | V <sub>OL</sub>     |        | 0.0 V  | 0.4 V                                           |
|                                | Output High Voltage                                                                                                                                     | V <sub>OH</sub>     | 2.4 V  | 3.3 V  |                                                 |
|                                | Output drive:  A[19:0], /CS[2:0], /OE[1:0], WE[1:0]  D[7:0]  /IOWR, /IORD, /IOBEN  PA[7:0], PB[7:0], PC[7:0], PD[7:0], PH[7:0]  PE[7:0]  All other pins | I <sub>DRIVE</sub>  |        |        | 16 mA<br>8 mA<br>16 mA<br>8 mA<br>16 mA<br>8 mA |

Table 31-2. Preliminary Battery-Backed DC Electrical Characteristics ( $VDD_{CORE} = 1.8V \pm 10\%$ ,  $VDD_{IO} = 3.3V \pm 10\%$ ,  $T_A = -40^{\circ} C$  to  $85^{\circ} C$ )

|        | Parameter                                                                    | Symbol              | Min              | Тур              | Max            |
|--------|------------------------------------------------------------------------------|---------------------|------------------|------------------|----------------|
|        | VBAT Supply Voltage                                                          | VBAT                | 1.65 V           | 1.8 V            | 1.90 V         |
| VBAT   | VBAT Current (rest of device powered) (rest of device powered down)          | I <sub>VBAT</sub>   |                  | 22 μA<br>290 nA  |                |
| TIO    | VBATIO Supply Voltage (rest of device powered) (rest of device powered down) | VBATIO              | 1.65 V<br>1.65 V | 3.3 V<br>1.8 V   | 3.6 V<br>3.6 V |
| VBATIO | VBATIO Current (rest of device powered) (rest of device powered down)        | I <sub>VBATIO</sub> |                  | 200 nA<br>200 nA |                |

#### 31.2 AC Characteristics

# Table 31-3. Preliminary AC Electrical Characteristics (VDD<sub>CORE</sub> = 1.8 V $\pm$ 10%, VDD<sub>IO</sub> = 3.3 V $\pm$ 10%, T<sub>A</sub> = -40°C to 85°C)

| Parameter                           | Symbol              | Min              | Тур        | Max     |
|-------------------------------------|---------------------|------------------|------------|---------|
| Main Clock Frequency on CLKI        | $f_{main}$          |                  |            | 100 MHz |
| Real-Time Clock Frequency on CLK32K | $f_{RTC}$           |                  | 32.768 kHz |         |
| Ethernet Clock Frequency            | $f_{Eth}$           | 25 MHz ± 100 ppm |            | pm      |
| Wi-Fi Clock Frequency               | $f_{\mathrm{WiFi}}$ | 20 MHz ± 100 ppm |            | pm      |

#### **31.3 Memory Access Times**

All access time measurements are taken at 50% of signal height.

#### 31.3.1 Memory Reads

Table 31-4. Preliminary Memory Read Time Delays (VDD<sub>CORE</sub> = 1.8 V  $\pm$  10%, VDD<sub>IO</sub> = 3.3 V  $\pm$  10%,  $T_A$  = -40°C to 85°C)

| Parameter                         | Symbol             | Min  | Тур  | Max  |
|-----------------------------------|--------------------|------|------|------|
| Clock to Address Delay            | T <sub>adr</sub>   | 3 ns |      | 8 ns |
| Clock to Memory Chip Select Delay | T <sub>CSx</sub>   | 3 ns |      | 6 ns |
| Clock to Memory Read Strobe Delay | T <sub>OEx</sub>   | 3 ns |      | 6 ns |
| Data Setup Time                   | T <sub>setup</sub> |      | 1 ns |      |
| Data Hold Time                    | T <sub>hold</sub>  |      | 0 ns |      |

#### 31.3.2 Memory Writes

Table 31-5. Preliminary Memory Write-Time Delays (VDD<sub>CORE</sub> = 1.8 V  $\pm$  10%, VDD<sub>IO</sub> = 3.3 V  $\pm$  10%,  $T_A$  = -40°C to 85°C)

| Parameter                              | Symbol            | Min  | Тур | Max  |
|----------------------------------------|-------------------|------|-----|------|
| Clock to Address Delay                 | T <sub>adr</sub>  | 3 ns |     | 8 ns |
| Clock to Memory Chip Select Delay      | T <sub>CSx</sub>  | 3 ns |     | 6 ns |
| Clock to Memory Write Strobe Delay     | T <sub>WEx</sub>  | 3 ns |     | 6 ns |
| High Z to Data Valid Relative to Clock | T <sub>DVHZ</sub> | 3 ns |     | 8 ns |
| Data Valid to High Z Relative to Clock | T <sub>DVHZ</sub> | 3 ns |     | 8 ns |



Figure 31-1. Memory Read and Write Cycles



Figure 31-2. Memory Read and Write Cycles—Early Output Enable and Write Enable Timing

#### 31.3.3 External I/O Reads

Table 31-6. Preliminary External I/O Read Time Delays (VDD<sub>CORE</sub> = 1.8 V  $\pm$  10%, VDD<sub>IO</sub> = 3.3 V  $\pm$  10%,  $T_A$  = -40 $^{\circ}$ C to 85 $^{\circ}$ C)

| Parameter                         | Symbol             | Min  | Тур  | Max   |
|-----------------------------------|--------------------|------|------|-------|
| Clock to Address Delay            | T <sub>adr</sub>   | 4 ns |      | 8 ns  |
| Clock to Memory Chip Select Delay | T <sub>CSx</sub>   | 3 ns |      | 6 ns  |
| Clock to I/O Chip Select Delay    | T <sub>IOCSx</sub> | 4 ns |      | 10 ns |
| Clock to I/O Read Strobe Delay    | T <sub>IORD</sub>  | 3 ns |      | 7 ns  |
| Clock to I/O Buffer Enable Delay  | T <sub>BUFEN</sub> | 3 ns |      | 6 ns  |
| Data Setup Time                   | T <sub>setup</sub> |      | 1 ns |       |
| Data Hold Time                    | T <sub>hold</sub>  |      | 1 ns |       |

#### 31.3.4 External I/O Writes

Table 31-7. Preliminary External I/O Write Time Delays (VDD<sub>CORE</sub> = 1.8 V  $\pm$  10%, VDD<sub>IO</sub> = 3.3 V  $\pm$  10%,  $T_A$  = -40°C to 85°C)

| Parameter                              | Symbol             | Min  | Тур | Max   |
|----------------------------------------|--------------------|------|-----|-------|
| Clock to Address Delay                 | T <sub>adr</sub>   | 4 ns |     | 8 ns  |
| Clock to Memory Chip Select Delay      | T <sub>CSx</sub>   | 3 ns |     | 6 ns  |
| Clock to I/O Chip Select Delay         | T <sub>IOCSx</sub> | 4 ns |     | 10 ns |
| Clock to I/O Write Strobe Delay        | $T_{IOWR}$         | 3 ns |     | 7 ns  |
| Clock to I/O Buffer Enable Delay       | T <sub>BUFEN</sub> | 3 ns |     | 6 ns  |
| High Z to Data Valid Relative to Clock | T <sub>DHZV</sub>  | 3 ns |     | 6 ns  |
| Data Valid to High Z Relative to Clock | T <sub>DVHZ</sub>  | 1 ns |     | 2 ns  |



Figure 31-3. I/O Read Cycles—No Extra Wait States

**NOTE:** /IOCSx can be programmed to be active low (default) or active high.



Figure 31-4. I/O Write Cycles—No Extra Wait States

**NOTE:** /IOCSx can be programmed to be active low (default) or active high.

#### 31.3.5 Memory Access Times

In computing memory requirements, the important considerations are the address access time, output-enable access time, and minimum write-pulse required. Increasing the clock doubler delay increases the output-enable time, but decreases the memory write-pulse width. The early write-pulse option can be used to ensure a long-enough write pulse, but then it must be ensured that the write pulse does not begin before the address lines have stabilized.

The clock doubler has an affect on the memory access times. It works by ORing the clock with a delayed version of itself. The nominal delay varies from 3 to 20 ns, and is set under program control. Any asymmetry in the main clock input before it is doubled will result in alternate clocks having slightly different periods. Using the suggested oscillator circuit, the asymmetry is no worse than 52%–48%. This results in a given clock being shortened by the ratio 50/52, or 4% worst-case. The memory access time is not normally affected because the memory bus cycle is two clocks long and includes both a long and a short clock, resulting in no net change arising from asymmetry. However, if an odd number of wait states is used, then the memory access time will be affected slightly.

When the clock spectrum spreader is enabled, clock periods are shortened by a small amount, depending on whether the "normal" or the "strong" spreader setting is used, and depending on the operating voltage. If the clock doubler is used, the spectrum spreader affects every other cycle and reduces the clock high time. If the doubler is not used, then the spreader affects every clock cycle, and the clock low time is reduced. Of course, the spectrum spreader also lengthens clock cycles, but only the worst-case shortening is relevant for calculating worst-case access times. The numbers given for clock shortening with the doubler disabled are the combined shortening for two consecutive clock cycles, worst case.

The required memory address and output-enable access time for some typical clock speeds are given in Table 31-8 below. It is assumed that the clock doubler is used, that the clock spreader is enabled in the normal mode, that the memory early output-enable is on, and that the address bus has a load of 60 pF.

Table 31-8. Preliminary Memory Requirements  $(VDD_{CORE} = 1.8 \text{ V} \pm 10\%, \text{ VDD}_{IO} = 3.3 \text{ V} \pm 10\%, \text{ } T_A = -40^{\circ}\text{C} \text{ to } 85^{\circ}\text{C},$  address bus loading = 60 pF)

| Clock<br>Frequency<br>(MHz) | Period<br>(ns) | Clock Doubler<br>Nominal Delay<br>(ns) | Memory Address<br>Access<br>(ns) | Memory Output-<br>Enable Access<br>(ns) |
|-----------------------------|----------------|----------------------------------------|----------------------------------|-----------------------------------------|
| 22.11                       | 45             | 20                                     | 78                               | 51                                      |
| 29.49                       | 34             | 16                                     | 56                               | 36                                      |
| 44.24                       | 22.5           | 10                                     | 33.5                             | 22                                      |
| 58.98                       | 17             | 6                                      | 22                               | 19                                      |

All important signals on the Rabbit 5000 are output-synchronized with the internal clock. The internal clock is closely synchronized with the external clock, which is available on the CLK pin. The delay in signal output depends on the capacitive load on the output lines. In the case of the address lines, which are critically important for establishing memory access time requirements, the capacitive loading is usually in the range of 25–100 pF, and the load is due to the input capacitance of the memory devices and PC trace capacitance.

Delays are expressed from the waveform midpoint in keeping with the convention used by memory manufacturers.

Table 31-9 lists the delays in gross memory access time for several values of VDD<sub>IO</sub>.

Table 31-9. Preliminary Data and Clock Delays (V<sub>DD</sub> ±10%, Temp. -40°C to 85°C)

| VDD <sub>IO</sub> | Clock to Address<br>Output Delay | Data Setup<br>Time Delay | Spect                          | Worst-Case<br>rum Spreader Delay<br>(ns) |                              |  |
|-------------------|----------------------------------|--------------------------|--------------------------------|------------------------------------------|------------------------------|--|
| (V)               | (ns)                             | (ns)                     | 0.5 ns setting<br>no dbl / dbl | 1 ns setting<br>no dbl / dbl             | 2 ns setting<br>no dbl / dbl |  |
| 3.3               | 6                                | 1                        | 2.3 / 2.3                      | 3 / 4.5                                  | 4.5 / 9                      |  |

When the spectrum spreader is enabled with the clock doubler, every other clock cycle is shortened or lengthened by a maximum amount given in the table above. The shortening takes place by shortening the high part of the clock. If the doubler is not enabled, then every clock is shortened during the low part of the clock period. The maximum shortening for a pair of clocks combined is shown in the table.

The gross memory access time is 2T, where T is the clock period. To calculate the actual memory access time, subtract the clock to address output time, the data in setup time, and the clock period shortening due to the clock spectrum spreader from 2T.

#### **Example Memory Access Time Calculation**

- clock = 29.49 MHz, so T = 34 ns
- clock to address output delay = 6 ns (see Table 31-9)
- data setup time = 1 ns
- spectrum spreader is on in 1 ns mode, resulting in a loss of 3 ns worst-case (see Table 31-9)

The access time is given by

Similarly, the gross output-enable access time is T + minimum clock low time (it is assumed that the early output enable option is enabled). This is reduced by the spectrum

spreader loss, the time from clock to output for the output enable signal, the data setup time, and a correction for the asymmetry of the original oscillator clock.

#### **Example Output-Enable Access Time Calculation**

**NOTE:** There is some process and temperature variation in the clock doubler settings. As a rule of thumb, a 20% variation should be considered. When the doubler is enabled, 80% of the nominal value should be used for the memory access time calculation.

- clock = 29.49 MHz, so T = 34 ns
- the clock doubler has a nominal delay of 16 ns (see Table 31-8), resulting in a minimum clock low time of  $80\% \times 16$  ns = 12.8 ns
- clock to output enable is 5 ns
- spectrum spreader is on in 1 ns mode, resulting in a loss of 4.5 ns worst-case (see Table 31-9)
- main clock asymmetry is 52% / 48%, resulting in a loss of 4% of the clock period, or 1.4 ns

The output enable access time is given by

```
access time = T + (min. clock low) - (clock to output enable) -
(spreader delay) - (asymmetry delay) - (data setup time)
= 34 ns + 12.8 ns - 5 ns - 4.5 ns - 1.4 ns
= 36 ns
```

#### 31.4 Clock Speeds

#### 31.4.1 Recommended Clock/Memory Configurations

The preferred configuration for a Rabbit-based system is to use an external crystal or resonator that has a frequency one-half of the maximum internal clock frequency. The oscillator frequency can be doubled or divided by 2, 4, 6, or 8, giving a variety of operating speeds from the same crystal frequency. In addition, the 32.768 kHz oscillator that drives the battery-backable clock can be used as the main processor clock and, to save the substantial power consumed by the fast oscillator, the fast oscillator can be turned off. This scenario is called the *sleepy mode*, where the clock speed is from 2 kHz to 32 kHz.

Table 31-10 describes some recommended clock and memory configurations for both 8-bit and 16-bit memory devices. Optimal configurations for using 12 ns, 15 ns, 45–55 ns, and 70 ns memories are shown. Note that there is always at least one wait state in the 16-bit mode.

Table 31-10. Some Recommended Clock/Memory Configurations

| Input           | Internal           | Recommended M                                                                                                        | emory Timing                                                                                                       |               |
|-----------------|--------------------|----------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|---------------|
| Frequency (MHz) | Frequency<br>(MHz) | 8-bit Devices 16-bit Devices (1 wait state min.)                                                                     |                                                                                                                    | Optimal Use   |
| 44.2368         | 88.4736            | 12 ns, 0 wait states<br>15 ns, 1 wait state<br>45 ns, 4 wait states<br>55 ns, 4 wait states<br>70 ns not possible    | 12 ns, 1 wait state<br>15 ns, 2 wait state<br>45 ns, 4 wait states<br>55 ns, 5 wait states<br>70 ns, 6 wait states | 12 ns devices |
| 36.8640         | 73.7280            | 12 ns, 0 wait states<br>15 ns, 0 wait states<br>45 ns, 2 wait states<br>55 ns, 4 wait states<br>70 ns, 4 wait states | 12 ns, 1 wait state<br>15 ns, 1 wait state<br>45 ns, 4 wait states<br>55 ns, 4 wait states<br>70 ns, 5 wait states | 15 ns devices |
| 18.4320         | 36.8640            | 12 ns, 0 wait states<br>15 ns, 0 wait states<br>45 ns, 0 wait states<br>55 ns, 1 wait state<br>70 ns, 1 wait state   | 12 ns, 1 wait state<br>15 ns, 1 wait state<br>45 ns, 1 wait state<br>55 ns, 2 wait states<br>70 ns, 2 wait states  | 45 ns devices |
| 14.7456 29.4912 |                    | 12 ns, 0 wait states<br>15 ns, 0 wait states<br>45 ns, 0 wait states<br>55 ns, 0 wait states<br>70 ns, 1 wait state  | 12 ns, 1 wait state<br>15 ns, 1 wait state<br>45 ns, 1 wait state<br>55 ns, 1 wait state<br>70 ns, 2 wait states   | 55 ns devices |

Table 31-10. Some Recommended Clock/Memory Configurations

| Input              | Internal           | Internal Recommended Memory Timing                                                                                   |                                                                                                                 |               |
|--------------------|--------------------|----------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|---------------|
| Frequency<br>(MHz) | Frequency<br>(MHz) | 8-bit Devices                                                                                                        | 16-bit Devices<br>(1 wait state min.)                                                                           | Optimal Use   |
| 11.0592            | 22.1184            | 12 ns, 0 wait states<br>15 ns, 0 wait states<br>45 ns, 0 wait states<br>55 ns, 0 wait states<br>70 ns, 0 wait states | 12 ns, 1 wait state<br>15 ns, 1 wait state<br>45 ns, 1 wait state<br>55 ns, 1 wait state<br>70 ns, 1 wait state | 70 ns devices |

The Rabbit 5000 is rated for a minimum clock period of 10 ns for both commercial and industrial specifications. The commercial rating calls for a  $\pm 5\%$  voltage variation from 3.3 V, and a temperature range from -40 to + 70°C. The industrial ratings stretch the voltage variation to  $\pm 10\%$  over a temperature range from -40 to + 85°C. This corresponds to maximum clock frequencies of about 100 MHz (commercial or industrial). If the clock doubler or spectrum spreader is used, these maximum ratings must be reduced as shown in Table 31-11.

Table 31-11. Preliminary Maximum Clock Speeds (V<sub>DD</sub> ±10%, Temp. -40°C to +85°C)

|                                                                           | Industria                 | I Ratings                     | Duty Cycle                        |
|---------------------------------------------------------------------------|---------------------------|-------------------------------|-----------------------------------|
| Conditions                                                                | Minimum<br>Period<br>(ns) | Maximum<br>Frequency<br>(MHz) | Requirements (ns)                 |
| No Doubler or<br>Spreader                                                 | 17                        | 58.8                          |                                   |
| Spreader Only<br>Normal                                                   | 20                        | 50.0                          |                                   |
| Spreader Only<br>Strong                                                   | 21                        | 47.6                          |                                   |
| Doubler Only (8 ns delay)                                                 | 19                        | 52.6                          | 1 > (clock low - clock high) > 0  |
| Doubler Only<br>(internal 50%<br>clock)                                   | 20                        | 50                            | 1 > (clock low - clock high) > -1 |
| Spreader<br>Normal with<br>Doubler<br>(8 ns delay)                        | 21                        | 47.6                          | 4 > (clock low - clock high) > 2  |
| Spreader<br>Normal with<br>Doubler (8 ns<br>delay), Internal<br>50% Clock | 24                        | 41.6                          | 1 > (clock low - clock high) > -1 |
| Spreader Only<br>Strong                                                   | 21.5                      | 46.5                          |                                   |
| Spreader Strong<br>with Doubler<br>(8 ns delay)                           | 23                        | 43.5                          | 8 > (clock low - clock high) > 6  |

When the doubler is used, the duty cycle of the clock becomes a critical parameter. The duty cycle should be measured at the separate clock output pin (pin 2). The minimum period must be increased by any amount that the clock high time is greater or less than specified in the duty-cycle requirement.

For example, consider a design where the spreader and doubler are enabled, with 8 ns nominal delay in the doubler. The high and low clock are equal to within 1 ns. This violates the duty cycle requirement by 3 ns since (clock low - clock high) can be as small as -1 ns, but the requirement is that it not be less than 2 ns. Thus, 3 ns must be added to the minimum period of 21 ns, giving a minimum period of 24 ns and a maximum frequency of 41.6 MHz (commercial).

Since the built-in high-speed oscillator buffer generates a clock that is very close to having a 50% duty cycle, to obtain the highest clock speeds using the clock doubler you must use an external oscillator buffer that will allow for duty-cycle adjustment by changing the resistance of the power and ground connections as shown below.



Figure 31-5. External Oscillator Buffer

#### 31.5 Power and Current Consumption

Various mechanisms contribute to the current consumption of the Rabbit 5000 processor while it is operating, including current that is proportional to the voltage alone (leakage current) and dependent on both voltage and frequency (switching and crossover current). To reduce current consumption, the clock can be divided down in one of the sleepy modes; see Table 29-1 for more details.

Figure 31-6 shows a typical current draw as a function of the main clock frequency while Wi-Fi is disabled. The values shown do not include any current consumed by external oscillators or memory. It is assumed that approximately 30 pF is connected to each address line.



Figure 31-6. Typical Current Draw as a Function of the Main Clock Frequency (Wi-Fi disabled)

When the 802.11 Wi-Fi peripheral is enabled, the current draw will increase by as much as 210mA, depending on activity.

#### 31.5.1 Sleepy Mode Current Consumption

The Rabbit 5000 supports designs with very low power consumption by using features such as the ultra-sleepy modes and self-timed chip selects. At the low frequencies possible in the ultra-sleepy modes (as low as 2 kHz), the external memory devices become significant factors in the current consumption unless one of the short or self-timed chip selects are used. The I/O current use will vary with pin activity.

Table 31-12. Typical Sleepy Mode Current Consumption (-40°C to +85°C)

| Pin               | Voltage | Current |
|-------------------|---------|---------|
| I <sub>CORE</sub> | 1.8 V   | 2 mA    |
| $I_{IO}$          | 3.3 V   | 5 mA    |

#### 31.5.2 Battery-Backed Clock Current Consumption

For the battery-backed features of the Rabbit 5000 to perform while the processor is powered down, both the VBAT and VBATIO pins need to be supplied properly. The VBAT pin powers the internal real-time clock and the battery-backed SRAM, while VBATIO powers the /RESET, /CS1, CLK32K, and RESOUT pins.

Note that the VBATIO pin can be powered at 1.8 V during powerdown even if the processor is running at 3.3 V normally. A circuit to switch between a 1.8–2.0 V battery and the main power can use the RESOUT pin to switch the power source for the VBATIO pin. R is a current-limiting resistor that should be adjusted for the battery voltage; a good value to use for a 3.0 V battery is 150 k $\Omega$ .



Figure 31-7. Switching Circuit for VBATIO Pin

Table 31-13 shows the typical current consumption for these pins while the remainder of the Rabbit 5000 is powered down.

Table 31-13. Typical Battery-Backed Current Consumption (-40°C to +85°C)

| Pin    | Voltage | Current |
|--------|---------|---------|
| VBAT   | 1.8 V   | 290 nA  |
| VBATIO | 1.8 V   | 200 nA  |

# 32. PACKAGE SPECIFICATIONS AND PINOUT

#### 32.1 Ball Grid Array Packages

#### 32.1.1 Pinout 17 × 17 Ethernet Option



Figure 32-1. Ethernet Option Pinout Looking Through the Top of Package

#### **32.1.2 Pinout 17 × 17 Wi-Fi Option**

|   | 1        | 2         | 3        | 4          | 5          | 6          | 7          | 8      | 9         | 10           | 11       | 12         | 13           | 14              | 15           | 16              | 17       |
|---|----------|-----------|----------|------------|------------|------------|------------|--------|-----------|--------------|----------|------------|--------------|-----------------|--------------|-----------------|----------|
| Α | VDDIO    | O<br>VSS! | VDD!     | VSSIO      | O<br>VGA4  | O<br>VGA1  | O<br>PB4   | LOCK   | SYSCFG    | SMODE0       | ANT_SEL  | B VSSIO    | O<br>PB0     | O<br>PE6        | O<br>A33GND  | O<br>VIN8       | VDDIO    |
| В | O<br>A7  | O<br>A6   | LFT      | O<br>PB7   | O<br>VGA2  | O<br>TX_ON | CLK        | CLKI   | SMODE1    | VSSIO        | VDDIO    | O<br>RX_ON | VDDIO        | O<br>PC7        | O<br>TESTINO | O<br>VDD33      | VSSIO    |
| С | O<br>A8  | O<br>A0   | O<br>PB6 | VSSIO      | O<br>VGA0  | VSSIO      | CLKIEN     | RXHP   | O<br>LNA0 | O<br>PB3     | PA2G_ON  | ACT_LED    | O<br>PB1     | TESTIN1         | O<br>A4      | O<br>PD5        | O<br>PD4 |
| D | VSSIO    | OE1       | O<br>PA0 | O<br>VGA3  | O<br>PB5   | VDDIO      | MDTOUT     | SYSCFG | 0 LNA1    | O<br>ANT_SEL | PB2      | PA5G_ON    | O<br>PE7     | O<br>A3         | O<br>A2      | O<br>A5         | O<br>PE3 |
| E | D13/PH5  | VDDINT    | D14/PH6  | D15/PH7    | VSSIO      | VSSIO      | VSSIO      | VSSIO  | VSSIO     | VSSIO        | VSSIO    | VSSIO      | VSSIO        | VSSINT          | VSSIO        | /STATUS         | VDDIO    |
| F | VDDIO    | D12/PH4   | VSSINT   | VDDIO      | VSSIO      | VSSIO      | VSSIO      | VSSIO  | VSSIO     | VSSIO        | VSSIO    | VSSIO      | VSSIO        | O<br>PE2        | VDDIO        | O<br>PD7        | VDDINT   |
| G | VSSIO    | A19       | O<br>PE4 | VSSIO      | VSSIO      | VSSIO      | VSSIO      | VSSIO  | VSSIO     | VSSIO        | VSSIO    | VSSIO      | VSSIO        | O<br>D0         | O<br>D1      | VSSIO           | O<br>A1  |
| Н | VDDINT   | D9/PH1    | D11/PH3  | D10/PH2    | VSSIO      | VSSIO      | VSSIO      | VSSIO  | VSSIO     | VSSIO        | VSSIO    | VSSIO      | VSSIO        | O<br>D3         | O<br>PE1     | VDDIO           | /CS0     |
| J | CLK_IN   | VSSINT    | D8/PH0   | O<br>A9    | VSSIO      | VSSIO      | VSSIO      | VSSIO  | VSSIO     | VSSIO        | VSSIO    | VSSIO      | VSSIO        | VSSIO           | O<br>D4      | VDDINT          | O<br>D2  |
| K | A11      | O<br>A10  | VDDIO    | SCLK       | VSSIO      | VSSIO      | VSSIO      | VSSIO  | VSSIO     | VSSIO        | VSSIO    | VSSIO      | VSSIO        | O <sub>D6</sub> | O<br>D7      | O <sub>D5</sub> | VSSINT   |
| L | VSSIO    | VDD!      | SDATA    | SENB       | VSSIO      | VSSIO      | VSSIO      | VSSIO  | VSSIO     | VSSIO        | VSSIO    | VSSIO      | VSSIO        | VSSIO           | A17          | /WE1            | O<br>PE0 |
| М | O<br>PE5 | VDDIO     | VSS!     | O<br>A12   | VSSIO      | VSSIO      | VSSIO      | VSSIO  | VSSIO     | VSSIO        | VSSIO    | VSSIO      | VSSIO        | VDDIO           | VDDINT       | O<br>PD6        | VDDIO    |
| N | VSSIO    | O<br>A14  | O<br>A13 | O<br>PA1   | VSSIO      | VSSIO      | VSSIO      | VSSIO  | VSSIO     | VSSIO        | VSSIO    | VSSIO      | VSSIO        | O<br>PD1        | O<br>PD2     | VSSINT          | O<br>PD3 |
| Р | A18      | O<br>PA2  | /CS2     | OE0        | O<br>AVDD! | ADVCM      | VDDINT     | /IOWR  | /RESET    | VBAT         | PC6      | O<br>PC2   | O<br>TESTIN2 | VOUTPI          | O<br>PA7     | O<br>A16        | VSSIO    |
| R | O<br>PA3 | VSSIO     | /WE0     | O<br>VREFN | A33GND!    | VININ      | O<br>AGND! | VDDIO  | VSSIO     | CLK32K       | VSSIO    | O<br>PC3   | VDDIO        | VOUTNI          | AGNDI        | O<br>PD0        | O<br>A15 |
| Т | VDDIO    | AVDD!     | VINQN    | IBIAS      | VINIP      | AVDD!      | O<br>PA4   | /IOBEN | VBATIO    | VSSIO        | O<br>PC4 | O<br>PC0   | DAVBG        | DAVCM           | GND!         | O<br>PA5        | O<br>PA6 |
| U | AGND!    | AGNDREF   | VREFP    | VINQP      | ADVBG      | VSSINT     | /IORD      | /CS1   | RESOUT    | PC5          | O<br>PC1 | VDD!       | AVDD!        | VOUTPQ          | VOUTNQ       | VSSIO           | VDDIO    |

Figure 32-2. Wi-Fi Option Pinout Looking Through the Top of Package

#### 32.1.3 Mechanical Dimensions and Land Pattern



Figure 32-3. BGA Package Outline

Table 32-1. Ball and Land Size Dimensions

| Nominal Ball<br>Diameter<br>(mm) | Tolerance<br>Variation<br>(mm) | Ball Pitch<br>(mm) | Nominal Land<br>Diameter<br>(mm) | Land<br>Variation<br>(mm) |
|----------------------------------|--------------------------------|--------------------|----------------------------------|---------------------------|
| 0.40                             | 0.45-0.35                      | 0.80               | 0.35                             | 0.35-0.30                 |

The design considerations in Table 32-2 are based on 5 mil design rules and assume a single conductor between solder lands.

Table 32-2. Design Considerations (all dimensions in mm)

| Key | Feature                       | Recommendation |
|-----|-------------------------------|----------------|
| A   | Solder Land Diameter          | 0.356 (0.014)  |
| В   | NSMD Defined Land Diameter    | 0.406 (0.016)  |
| С   | Land to Mask Clearance (min.) | 0.076 (0.003)  |
| D   | Conductor Width (max.)        | 0.127 (0.005)  |
| Е   | Conductor Spacing (typ.)      | 0.127 (0.005)  |
| F   | Via Capture Pad (max.)        | 0.406 (0.016)  |
| G   | Via Drill Size (max.)         | 0.203 (0.008)  |



#### 32.2 Rabbit Pin Descriptions

Table 32-3 lists all the pins on the Rabbit 5000 along with the data direction of the pin, its function, and the pin number on the die.

Table 32-3. Rabbit 5000 Pin Descriptions

| Pin Group    | Pin Name         | Direction     | Function                          | LFBGA Ball |
|--------------|------------------|---------------|-----------------------------------|------------|
|              | CLK              | Output        | Internal Clock Output             | В7         |
|              | CLK32K           | Input         | 32 kHz Clock In                   | R10        |
| Hardware     | /RESET           | Input         | Master Reset                      | Р9         |
| Haidware     | RESOUT           | Output        | Reset Output                      | U9         |
|              | CLKI             | Input         | Main Clock In                     | В8         |
|              | CLKIEN           | Output        | Main Clock Enable                 | C7         |
| CPU Buses    | A[19:0]          | Output        | Address Bus                       | various    |
| Cro Buses    | D[9:0]           | Bidirectional | Data Bus                          | various    |
|              | /WDTOUT          | Output        | Watchdog Timer Timeout            | D7         |
| Status &     | STATUS           | Output        | Instruction Fetch First Byte      | E16        |
| Control      | SMODE1<br>SMODE0 | Input         | Bootstrap Mode & Tamper<br>Detect | B9, A10    |
|              | /CS0             | Output        | Memory Chip Select 0              | H17        |
| Chip Selects | /CS1             | Output        | Memory Chip Select 1              | U8         |
|              | /CS2             | Output        | Memory Chip Select 2              | Р3         |
| Output       | /OE0             | Output        | Memory Output Enable 0            | P4         |
| Enables      | /OE1             | Output        | Memory Output Enable 1            | D2         |
| Write        | /WE0             | Output        | Memory Write Enable               | R3         |
| Enables      | /WE1             | Output        | Memory Write Enable               | L16        |
|              | /IOBEN           | Output        | I/O Buffer Enable                 | Т8         |
| I/O Control  | /IORD            | Output        | I/O Read Enable                   | U7         |
|              | /IOWR            | Output        | I/O Write Enable                  | P8         |
|              | PA[7:0]          | Input/Output  | I/O Parallel Port A               | various    |
|              | PB[7:0]          | Input/Output  | I/O Parallel Port B               | various    |
| I/O Ports    | PC[7:0]          | Input/Output  | I/O Parallel Port C               | various    |
| I/O POIIS    | PD[7:0]          | Input/Output  | I/O Parallel Port D               | various    |
|              | PE[7:0]          | Input/Output  | I/O Parallel Port E               | various    |
|              | PH[7:0]          | Input/Output  | I/O Parallel Port H               | various    |

Table 32-3. Rabbit 5000 Pin Descriptions (continued)

| Pin Group | Pin Name                                                                                                     | Direction     | Function                          | LFBGA Ball                                                                                                     |
|-----------|--------------------------------------------------------------------------------------------------------------|---------------|-----------------------------------|----------------------------------------------------------------------------------------------------------------|
|           | MDC<br>MDO<br>MDOEN<br>TXD0<br>TXD1<br>TXD2<br>TXD3<br>TX_EN<br>TX_ER                                        | Output        |                                   | K4<br>L3<br>L4<br>A6<br>B5<br>D4<br>A5<br>B6<br>C5                                                             |
| Ethernet  | COL<br>CRS<br>RX_CLK<br>RX_DV<br>RX_ER<br>RXD0<br>RXD1<br>RXD2<br>RXD3<br>TX_CLK                             | Input         | Media-Independent Interface (MII) | C8<br>C12<br>D12<br>B12<br>C11<br>D10<br>A11<br>C9<br>D9<br>A8                                                 |
|           | MDIO                                                                                                         | Bidirectional |                                   | J1                                                                                                             |
| Wi-Fi     | ACT_LED ANT_SEL ANT_SELB LNA0 LNA1 PA2G_ON PA5G_ON RX_ON RXHP SCLK SDATA SENB TX_ON VGA0 VGA1 VGA2 VGA3 VGA4 | Output        | Wi-Fi Interface                   | C12<br>D10<br>A11<br>C9<br>D9<br>C11<br>D12<br>B17<br>G8<br>K4<br>K3<br>L4<br>B6<br>C5<br>A6<br>B5<br>D4<br>A5 |
|           | CLK_IN<br>LOCK                                                                                               | Input         |                                   | J1<br>A8                                                                                                       |

Table 32-3. Rabbit 5000 Pin Descriptions (continued)

| Pin Group | Pin Name                             | Direction | Function                                | LFBGA Ball               |
|-----------|--------------------------------------|-----------|-----------------------------------------|--------------------------|
|           | VININ<br>VINIP<br>VINQN<br>VINQP     | Input     | Analog Component 0 — Fast A/D Converter | R6<br>T5<br>T3<br>U4     |
|           | PD4                                  | Clock     |                                         | C17                      |
| Analog    | VOUTNI<br>VOUTPI<br>VOUTNQ<br>VOUTPQ | Output    | Analog Component 1 — Fast D/A Converter | R14<br>P14<br>U15<br>U14 |
|           | PD5                                  | Clock     |                                         | C16                      |
|           | VIN8                                 | Input     | Analog Component 2                      | A16                      |
|           | PD6                                  | Clock     | — Slow A/D Converter                    | M16                      |

# APPENDIX A. PARALLEL PORT PINS WITH ALTERNATE FUNCTIONS

#### A.1 Alternate Parallel Port Pin Outputs

Table A-1. Alternate Parallel Port A and B Pin Outputs

|         | Alternate Output Options |                     |            |  |  |  |
|---------|--------------------------|---------------------|------------|--|--|--|
| Pin     | Serial Clock             | External I/O<br>Bus | Slave Port |  |  |  |
| PA[7:0] | _                        | ID[7:0]             | SD[7:0]    |  |  |  |
| PB7     | _                        | IA5                 | /SLVATTN   |  |  |  |
| PB6     | _                        | IA4                 | /SCS       |  |  |  |
| PB5     | _                        | IA3                 | SA1        |  |  |  |
| PB4     | _                        | IA2                 | SA0        |  |  |  |
| PB3     | _                        | IA1                 | /SRD       |  |  |  |
| PB2     | _                        | IA0                 | /SWR       |  |  |  |
| PB1     | SCLKA                    | IA7                 | _          |  |  |  |
| PB0     | SCLKB                    | IA6                 | _          |  |  |  |

Table A-2. Alternate Parallel Port C, D, E, and H Pin Outputs

|     | Alternate Output Option |     |          |       |             |  |  |
|-----|-------------------------|-----|----------|-------|-------------|--|--|
| Pin | 0                       | 1   | 2        | 3     | 16-bit Data |  |  |
| PC7 | TXA                     | I7  | PWM3     | SCLKC | _           |  |  |
| PC6 | TXA                     | I6  | PWM2     | TXE   | _           |  |  |
| PC5 | TXB                     | 15  | PWM1     | RCLKE | _           |  |  |
| PC4 | TXB                     | I4  | PWM0     | TCLKE | _           |  |  |
| PC3 | TXC                     | I3  | TIMER C3 | SCLKD | _           |  |  |
| PC2 | TXC                     | I2  | TIMER C2 | TXF   | _           |  |  |
| PC1 | TXD                     | I1  | TIMER C1 | RCLKF | _           |  |  |
| PC0 | TXD                     | 10  | TIMER C0 | TCLKF | _           |  |  |
| PD7 | IA7                     | I7  | PWM3     | SCLKC | _           |  |  |
| PD6 | TXA                     | I6  | PWM2     | TXE   | _           |  |  |
| PD5 | IA6                     | 15  | PWM1     | RCLKE | _           |  |  |
| PD4 | TXB                     | I4  | PWM0     | TCLKE | _           |  |  |
| PD3 | IA7                     | 13  | TIMER C3 | SCLKD | _           |  |  |
| PD2 | SCLKC                   | I2  | TIMER C2 | TXF   | _           |  |  |
| PD1 | IA6                     | I1  | TIMER C1 | RCLKF | _           |  |  |
| PD0 | SCLKD                   | 10  | TIMER C0 | TCLKF | _           |  |  |
| PE7 | I7                      | _   | PWM3     | SCLKC | _           |  |  |
| PE6 | I6                      |     | PWM2     | TXE   | _           |  |  |
| PE5 | 15                      | _   | PWM1     | RCLKE | _           |  |  |
| PE4 | I4                      | /A0 | PWM0     | TCLKE | _           |  |  |
| PE3 | 13                      | A23 | TIMER C3 | SCLKD | _           |  |  |
| PE2 | I2                      | A22 | TIMER C2 | TXF   | _           |  |  |
| PE1 | I1                      | A21 | TIMER C1 | RCLKF | _           |  |  |
| PE0 | 10                      | A20 | TIMER C0 | TCLKF | _           |  |  |
| PH7 | _                       | I7  | PWM3     | SCLKC | D15         |  |  |
| PH6 |                         | I6  | PWM2     | TXE   | D14         |  |  |
| PH5 |                         | 15  | PWM1     | RCLKE | D13         |  |  |
| PH4 | _                       | I4  | PWM0     | TCLKE | D12         |  |  |
| PH3 |                         | 13  | TIMER C3 | SCLKD | D11         |  |  |
| PH2 |                         | I2  | TIMER C2 | TXF   | D10         |  |  |
| PH1 |                         | I1  | TIMER C1 | RCLKF | D9          |  |  |
| PH0 | _                       | 10  | TIMER C0 | TCLKF | D8          |  |  |

### A.2 Alternate Parallel Port Pin Inputs

Table A-3. Alternate Parallel Port Pin Inputs

| Pin     | Input<br>Capture | I/O<br>Hand-<br>shake | DMA   | External<br>Interrupt | Network | Quad-<br>rature<br>Decoder | Slave Port | Serial<br>Ports<br>A-D | Serial<br>Ports<br>E-F |
|---------|------------------|-----------------------|-------|-----------------------|---------|----------------------------|------------|------------------------|------------------------|
| PA[7:0] | _                |                       | _     | _                     | _       |                            | SD[7:0]    | _                      | _                      |
| PB7     | _                | _                     | _     | _                     | _       | _                          | /SLVATTN   | _                      | _                      |
| PB6     | _                |                       | _     | _                     | _       | _                          | /SCS       | _                      | _                      |
| PB5     | _                |                       | _     | _                     | _       | _                          | SA1        | _                      | _                      |
| PB4     | _                |                       |       | _                     |         | _                          | SA0        |                        | _                      |
| PB3     |                  |                       |       |                       |         | _                          | /SRD       |                        | _                      |
| PB2     | _                |                       |       |                       |         |                            | /SWR       |                        | _                      |
| PB1     |                  |                       |       |                       |         |                            |            | SCLKA                  |                        |
| PB0     | _                |                       | _     | _                     | _       | _                          | _          | SCLKB                  | _                      |
| PC7     | ×                |                       | _     |                       | _       | _                          | _          | RXA                    | RXE                    |
| PC6     | _                | _                     | _     | _                     | _       | _                          | _          | _                      | _                      |
| PC5     | ×                | _                     | _     | _                     | _       | _                          | _          | RXB                    | RCLKE                  |
| PC4     | _                |                       | _     |                       | _       | _                          | _          | _                      | TCLKE                  |
| PC3     | ×                |                       | _     |                       | _       | _                          | _          | RXC                    | RXF                    |
| PC2     | _                | _                     | _     | _                     | _       | _                          | _          | _                      | _                      |
| PC1     | ×                |                       | _     |                       | _       | _                          | _          | RXD                    | RCLKF                  |
| PC0     |                  |                       |       |                       |         | _                          | _          |                        | TCLKF                  |
| PD7     | ×                |                       | _     | _                     | _       | _                          | _          | RXA                    | RXE                    |
| PD6     |                  |                       |       |                       |         | _                          | _          |                        | _                      |
| PD5     | ×                |                       | _     | _                     | _       | _                          | _          | RXB                    | RCLKE                  |
| PD4     | _                |                       | _     | _                     | _       | _                          | _          |                        | TCLKE                  |
| PD3     | ×                |                       | DREQ1 | _                     | _       | QRD2A                      | _          | RXC                    | RXF                    |
| PD2     |                  |                       | DREQ0 |                       | _       | QRD2B                      | _          | SCLKC                  | _                      |
| PD1     | ×                | _                     | _     | INT1                  | _       | QRD1A                      | _          | RXD                    | RCLKF                  |
| PD0     |                  |                       | _     | INT0                  | _       | QRD1B                      | _          | SCLKD                  | TCLKF                  |
| PE7     | ×                | ×                     | DREQ1 | _                     | _       | _                          | /SCS       | RXA                    | RXE                    |
| PE6     | _                | ×                     | DREQ0 | _                     | ECLK    | _                          | _          | _                      | _                      |

Table A-3. Alternate Parallel Port Pin Inputs (continued)

| Pin | Input<br>Capture | I/O<br>Hand-<br>shake | DMA   | External<br>Interrupt | Network | Quad-<br>rature<br>Decoder | Slave Port | Serial<br>Ports<br>A-D | Serial<br>Ports<br>E-F |
|-----|------------------|-----------------------|-------|-----------------------|---------|----------------------------|------------|------------------------|------------------------|
| PE5 | ×                | ×                     | _     | INT1                  | _       | _                          | _          | RXB                    | RCLKE                  |
| PE4 |                  | ×                     | _     | INT0                  | _       | _                          | _          | _                      | TCLKE                  |
| PE3 | ×                | ×                     | DREQ1 | _                     | _       | QRD2A                      | _          | RXC                    | RXF                    |
| PE2 | _                | ×                     | DREQ0 | _                     | _       | QRD2B                      | _          | SCLKC                  | _                      |
| PE1 | ×                | ×                     | _     | INT1                  | _       | QRD1A                      | _          | RXD                    | RCLKF                  |
| PE0 | _                | ×                     | _     | INT0                  | _       | QRD1B                      | _          | SCLKD                  | TCLKF                  |

#### APPENDIX B. RABBIT 5000 ERRATA

The Rabbit 5000 began shipping in 2008 on multiple platforms. Several bugs were found in the design after the chip was released, and are discussed in this appendix.

#### **B.1** Errata

The following bugs have been identified in the Rabbit 5000 design, and are present in all devices currently available. All Dynamic C libraries have been corrected these issues, and the compiler correctly generates operational code from C programs as noted below. However, customers should be aware of them when writing code in assembly.

- 1. **Noise in 802.11b Wi-Fi transmissions** The state machine for 802.11b transmissions can generate extra noise outside the allowed 802.11b frequency range in some situations. To avoid this possibility, the following corrections are implemented in the Dynamic C Wi-Fi library:
  - (a) For 1 and 2 Mbps transmission rates, the noise only exists for certain clock alignments with respect to other clocks in the design. When Wi-Fi is enabled, the Wi-Fi clock is checked for proper alignment and restarted repeatedly until the correct alignment occurs.
  - (b) For 5.5 and 11 Mbps, the noise will not exist for packet lengths that are multiples of 11, again due to clock alignment. The Dynamic C Wi-Fi library will pad all outgoing packets to a safe length to avoid the noise issue. Note that this means that the maximum MTU is actually 1441 bytes and not the standard 1450.
- 2. Instruction alignment issues there are several issues with alignment of particular instructions in 16-bit mode; all instructions function properly in 8-bit mode. Dynamic C will automatically align all instructions appropriately by adding NOP instructions to the generated code. The instructions of concern in 16-bit mode and the required alignment are:
  - (a) LD pd,ps+d must be even-aligned.
  - (b) LD BCDE,d must be odd-aligned.
  - (c) LD HL,(n) must be even-aligned.

Additional instructions need to be odd-aligned to avoid an additional wait state being generated; see issue 4 below.

- 3. **IOI/IOE BIT instruction alignment issue** if the code sequences IOI BIT b,(HL) or IOE BIT b,(HL) are not even-aligned, the effect of the IOI/IOE prefix will be lost and a memory read will occur instead of a register read. Dynamic C does not manage this automatically, but all instances of these code sequences in Dynamic C libraries have been properly aligned.
- 4. **RET cc bug** this instruction requires a single-byte instruction to follow it for proper operation. Dynamic C does not correct this automatically, but it has been corrected in all Dynamic C libraries.
- 5. **Extra wait state generation** the instructions listed below will generate an additional wait state during the operation when even-aligned in 16-bit mode:

| LD A,(ps+d)  | LD (pd+d),A  |
|--------------|--------------|
| LD HL,(ps+d) | LD (pd+d),HL |
| LD HL,(SP+n) | LD (SP+n),HL |
| LD HL,(IX+d) | LD (IX+d),HL |
| JR e         | JR cc,e      |

Dynamic C does nothing to correct for this issue since an additional wait state will not significantly affect code.

6. **Read-modify-write instruction bug** — this bug has been found to exist in all Rabbit 2000, 3000, 4000, and 5000 processors. The bug manifests itself by using the wait state setting of the code memory for the final write to data memory, instead of the correct data memory wait state setting. This misbehavior has the potential of causing memory timing errors if the data memory requires more wait states than the code memory. The instructions are affected in both 8- and 16-bit modes, and are listed here:

| DEC (HL) DEC (IX+d) DEC (IY+d) DEC (pp+d) | RL (HL)<br>RL (IX+d)<br>RL (IY+d)    | RR (HL)<br>RR (IX+d)<br>RR (IY+d)    |                                      |
|-------------------------------------------|--------------------------------------|--------------------------------------|--------------------------------------|
| INC (HL) INC (IX+d) INC (IY+d) INC (pp+d) | RLC (HL)<br>RLC (IX+d)<br>RLC (IY+d) | RRC (HL)<br>RRC (IX+d)<br>RRC (IY+d) | SRA (HL)<br>SRA (IX+d)<br>SRA (IY+d) |
| SET b,(HL)                                | RES b,(HL)                           | CBM                                  |                                      |

In Rabbit-branded products, this only has the potential to affect "fast SRAM" products where code executing in high-speed memory performs a write to the slow battery-backed SRAM. Dynamic C does not generate these instructions from C code, and all instances of them in existing libraries where a potential issue would occur have been

| corrected. Customers writing assembly code that accesses data in battery-backed memory should avoid using these instructions to do so. |
|----------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                        |
|                                                                                                                                        |
|                                                                                                                                        |
|                                                                                                                                        |
|                                                                                                                                        |
|                                                                                                                                        |
|                                                                                                                                        |
|                                                                                                                                        |
|                                                                                                                                        |
|                                                                                                                                        |
|                                                                                                                                        |
|                                                                                                                                        |
|                                                                                                                                        |
|                                                                                                                                        |
|                                                                                                                                        |
|                                                                                                                                        |
|                                                                                                                                        |
|                                                                                                                                        |
|                                                                                                                                        |
|                                                                                                                                        |
|                                                                                                                                        |

## **I**NDEX

| Numerics                | analog components 218       | overview331                  |
|-------------------------|-----------------------------|------------------------------|
| 22 latter alocals 20    | bootstrap                   | register descriptions 336    |
| 32 kHz clock            | breakpoints332              | registers                    |
| oscillator circuit 30   | clocks22                    | bugs                         |
| A                       | DMA channels232             | workarounds                  |
|                         | external I/O control 318    | DMA/HDLC/Ethernet in-        |
| analog components215    | external interrupts85       | teraction 402                |
| block diagram218        | input capture channels 288  | stack protection/DMA inter-  |
| clocks219               | memory management 60        | action 401, 402              |
| dependencies219         | Network Port B259           | С                            |
| fast A/D converter      | Network Port C282           | O                            |
| Analog Component 0 Con- | Parallel Port A89           | clock modes24                |
| trol Register224        | Parallel Port B94           | clocks21                     |
| Analog Component 0 LSB  | Parallel Port C98           | 32 kHz clock30               |
| Registers223            | Parallel Port D107          | oscillator circuit30         |
| Analog Component MSB    | Parallel Port E125          | power consumption 30         |
| Registers223            | Parallel Port H144          | block diagram22              |
| fast D/A converter      | PWM309                      | clock doubler27, 28          |
| Analog Component 1 Con- | Quadrature Decoder 301      | clock modes24                |
| trol Register225        | Rabbit 500016               | clock speeds                 |
| Analog Component 1 LSB  | reset38                     | doubling/dividing21          |
| Registers224            | Serial Ports A – D 173      | EMI mitigation21             |
| Analog Component 1 MSB  | Serial Ports E – F 188      | Ethernet clock               |
| Registers225            | slave port204               | maximum clock speed 29       |
| operation220            | system management46         | operation24                  |
| registers219            | Timer A 151                 | overview21                   |
| sample circuits221      | Timer B                     | power consumption29          |
| slow A/D converter      | Timer C 164                 | register descriptions 32     |
| Analog Component 2 Con- | bootstrap37                 | registers                    |
| trol Register227        | block diagram38             | sleepy clock modes           |
| Analog Component 2 LSB  | dependencies39              | spectrum spreader 21, 378    |
| Register 226            | memory fetch41              | comparison with other Rabbit |
| Analog Component 2 MSB  | onchip-encryption SRAM . 42 | microprocessors 18           |
| Register 226            | register descriptions 44    | -                            |
| specifications216       | registers38                 | D                            |
| fast A/D converter 216  | breakpoints 331             |                              |
| fast D/A converter 216  | block diagram332            | design considerations        |
| slow A/D converter 217  | dependencies 334            | BGA package 392              |
| <b>D</b>                | interrupts 334              | dimensions                   |
| В                       | example ISR335              | BGA package                  |
| block diagram           | operation                   | DMA channels229              |

| block diagram232           | See breakpoints                  | example ISR311                 |
|----------------------------|----------------------------------|--------------------------------|
| buffer descriptor235       | see oreakpoints                  | Quadrature Decoder 300, 302    |
| buffer descriptor modes238 | I                                | example ISR303                 |
| channel priorities238      |                                  | Serial Ports A – D176          |
| clocks234                  | input capture channels287        | Serial Ports E – F191          |
| control230                 | block diagram288                 | slave port203, 205, 208        |
| dependencies234            | clocks290                        | example ISR208                 |
| external requests229       | dependencies290                  | system management45,48,        |
| interrupts231, 234, 236    | interrupts290, 291               | 49                             |
| example ISR236             | example ISR291                   | System/User mode354, 360       |
| memory addresses230        | load parallel port output regis- | Timer A                        |
| operation235               | ters288                          | example ISR153                 |
| overview229                | measure pulse widths287          | Timer B                        |
| priorities236              | modes287                         | example ISR159                 |
| register descriptions243   | input-capture mode287            | Timer C166, 167                |
| registers233               | input-count mode287              | example ISR167                 |
| =                          | operation291                     | example 15K107                 |
| setup                      | input-capture mode292            | L                              |
| timed requests             | input-count mode292              |                                |
| transfer priorities        | overview287                      | land pattern                   |
| transfer priority236       | register descriptions293         | BGA package391                 |
| transfer rates237          | registers289                     | low-power operation339         |
| transfers                  | start and stop events287         | clock rates341                 |
| use with peripherals242    | interrupt priorities84           | clock modes341                 |
| DMA/HDLC/Ethernet in-      | interrupts81                     | handling unused pins341        |
| teraction402               | breakpoints334                   | operation341                   |
| Ethernet                   | example ISR335                   | overview339                    |
| HDLC serial ports242       | DMA channels 231, 234, 236       | register descriptions348       |
| PWM and Timer C242         | example ISR236                   | registers340                   |
| DMA control229             | external interrupt vector table  | self-timed chip selects347     |
| E                          | 83                               | short chip selects342          |
| _                          | external interrupts85, 86        | NA.                            |
| ESD                        | block diagram85                  | M                              |
| ESD sensitivity14          | clocks86                         | memory                         |
| external I/O bus315        | dependencies86                   | read and write cycles (no wait |
| operation320               | example ISR87                    | states)374                     |
| handshake320               | interrupt vectors86              | memory management57            |
| strobes320                 | operation86                      | block diagram60                |
| external I/O control315    | register descriptions88          | clocks62                       |
| block diagram318           | registers86                      | dependencies62                 |
| clocks319                  | input capture channels290,       | interrupts62                   |
| dependencies319            | 291                              | logical memory space58         |
| external I/O bus315        | example ISR291                   | mapping physical memory        |
| handshake317               | internal interrupt vector table  | space                          |
| operation320               | 82                               | MMU operation64                |
| external I/O bus320        | interrupt priorities84           | operation63                    |
| handshake320               | memory management62              | 16-bit and page modes 66       |
| strobes320                 | Network Port B263, 265           | instruction and data space     |
| overview315                | Network Port C286                | 68                             |
| register descriptions321   | operation82                      | memory protection68            |
| registers318               | Parallel Port D109               | MMU63                          |
| strobes316                 | Parallel Port E127               | read and write transactions    |
| Н                          | Parallel Port H145               | 66                             |
| 11                         | priority levels81                | stack protection69             |
| hardware debugging.        | PWM307, 310, 311                 | stack protection/DMA inter-    |
| <i>25 6</i> .              |                                  | 1                              |

| action 401, 402               | block diagram             |      | PHDR setup 143             |
|-------------------------------|---------------------------|------|----------------------------|
| overview57                    | clocks                    |      | register descriptions 146  |
| physical and logical memory   | dependencies              |      | registers144               |
| mapping59                     | external I/O bus          | 93   | peripherals                |
| register descriptions 70      | operation                 | 95   | system management 45       |
| registers 61, 62, 63          | overview                  | 93   | pin descriptions393        |
| memory protection68           | register descriptions     | 95   | alternate pin functions    |
| 11                            | registers                 | 94   | Parallel Port A and B out- |
| N                             | slave port enabled        | 93   | puts 397                   |
| Network Port B                | SPCR setup                | 93   | Parallel Port C, D, and E  |
| block diagram259              | Parallel Port C           | 97   | outputs 398                |
| clock257                      | alternate input functions | 97   | parallel port inputs 399   |
| clocks                        | alternate output function | s 97 | pin functions393           |
| dependencies                  | block diagram             | 98   | alternate pin functions    |
| DMA transfers258              | clocks                    |      | Parallel Port A and B out- |
| interrupts263, 265            | dependencies              | 99   | puts 397                   |
| operation263                  | operation                 |      | Parallel Port C, D, and E  |
| multicast addressing 266      | overview                  |      | outputs 398                |
| receive264                    | PCDR setup                |      | parallel port inputs 399   |
| transmit                      | default                   |      | pinout393                  |
| overview257                   | register descriptions     | 100  | BGA package 389, 390       |
|                               | registers                 |      | power consumption29        |
| receiver                      | Parallel Port D           |      | pulse width modulator.     |
| register descriptions 267     | alternate input functions |      | See PWM                    |
| registers                     | alternate output function |      | PWM 307                    |
| setup                         | block diagram             |      | block diagram309           |
| Network Port C                | clocks                    |      | channels310                |
|                               | dependencies              |      | clocks310                  |
| block diagram                 | interrupts                |      | dependencies310            |
| clocks                        | operation                 |      | DMA channels308            |
| dependencies                  | overview                  |      | interrupts 307, 310, 311   |
| interrupts                    | PDDR setup                |      | example ISR311             |
| operation                     | register descriptions     |      | operation311               |
|                               | registers                 |      | outputs 307, 308           |
| registers283                  | Parallel Port E           |      | overview307                |
| 0                             | alternate input functions |      | register descriptions 312  |
| _                             | alternate output function |      | registers309               |
| opcodes                       | block diagram             |      | spreading function 308     |
| System/User mode 358          | clocks                    |      | -                          |
| В                             | dependencies              |      | Q                          |
| Р                             | interrupts                |      | Orra dustrina Dagadan 200  |
| Parallel Port A89             | operation                 |      | Quadrature Decoder         |
| alternate output functions 89 | overview                  |      | block diagram              |
| block diagram89               | PEDR setup                |      | clocks                     |
| clocks90                      | register descriptions     |      | counter operation          |
| external I/O data bus 89      | registers                 |      | dependencies               |
| operation90                   | Parallel Port H           |      | inputs                     |
| overview89                    | alternate output function |      | interrupts 300, 302, 303   |
| register description95        | block diagram             |      | example ISR                |
| register descriptions 91      | clocks                    |      | operation                  |
| registers                     | dependencies              |      | overview                   |
| slave port data bus89         | interrupts                |      | register descriptions 304  |
| Parallel Port B93             | operation                 |      | registers 301              |
| alternate output functions 93 | overview                  |      |                            |
|                               |                           | -    |                            |

| R                            | DATASEGL       | 71        | IHCR     | 140, 321     |
|------------------------------|----------------|-----------|----------|--------------|
|                              | DMALR          | 243       | IHSR     | 141, 322     |
| Rabbit 200018                | DMCR           | 244       | IHTR     | 141, 322     |
| Rabbit 300018                | DMCSR          | 243       | IUER     | 365          |
| Rabbit 4000                  | DMHR           | 243       | IxCR8    | 88, 119, 136 |
| revision history401          | DMR0CR120,     | 137, 246  | MACR     |              |
| Rabbit 500013                | DMR1CR121,     | 138, 247  | MBxCR    |              |
| block diagram16              | DMTCR          |           | MECR     | 73           |
| comparison with other Rabbit | DTRCR          | 248       | MMIDR    | 70           |
| microprocessors18            | DTRDHR         | 248       | MTCR     | 73           |
| feature summary13            | DTRDLR         | 248       | NBCF0R   |              |
| features14                   | DyBCR          |           | NBCF1R   |              |
| 10/100Base-T Ethernet15      | DyBU0R         |           | NBCF2R   |              |
| EMI mitigation14             | DyBU1R         |           | NBCF3R   |              |
| input-capture channels14     | DyCR           |           | NBCR     |              |
| instruction set14            | DyDA0R         |           | NBCSR    |              |
| memory access14              | DyDA1R         |           | NBCWR    |              |
| onchip-encryption RAM 15     | DyDA2R         |           | NBDMR    |              |
| parallel ports14             | DyIA0R         |           | NBDR     |              |
| protected operating systems  | DyIA1R         |           | NBDRR    |              |
| 15                           | DyIA2R         |           | NBDTR    |              |
| PWM outputs15                | DyL0R          |           | NBFLLR   |              |
| Quadrature-Decoder chan-     | DyLA0R         |           | NBFLMR   |              |
| nels14                       | DyLA1R         |           | NBG0R    |              |
| timers14                     | DyLA2R         |           | NBG1R    |              |
| specifications17             | DyLnR          |           | NBG2R    |              |
| Rabbit Semiconductor         | DySA0R         |           | NBLDR    |              |
| history13                    | DySA1R         |           | NBMCFR   |              |
| registers                    | DySA2R         |           | NBMCR    |              |
| alphabetic listing           | DySCR          |           | NBMFxR   |              |
| A0CR224                      | DyTBR          |           | NBMPAR   |              |
| A0ILR223                     | DyTMR          |           | NBMRAR   |              |
| A0IMR223                     | EDMR           |           | NBMRLR   |              |
| A0QLR223                     | ENPR           |           | NBMRMR   |              |
| A0QMR223                     | GCDR           |           | NBMRR    |              |
| A1CR225                      | GCM0R          |           | NBMSR    |              |
| A1ILR224                     | GCM1R          |           | NBMWLR   |              |
| A1IMR225                     | GCPU           |           | NBMWMR   |              |
| A1QLR224                     | GCSR32, 51, 1  |           | NBPAxR   |              |
| A1QMR225                     | 170, 348       | .50, 102, | NBRCR    |              |
| A2CR227                      | GOCR           | 35 54     | NBRMR    |              |
| A2LR226                      | GPSCR          |           | NBSAxR   |              |
| A2MR226                      | GRAM           |           | NBTCR    |              |
| ACSxCR75                     | GREV           |           | NBTESR   |              |
| AUER365                      | GROM           |           | NBTPLR   |              |
| BDCR336                      | IBUER          |           | NBTPMR   |              |
| BxA0R337                     | IbxCR          |           | NBTSR    |              |
| BxA1R337                     | ICCR           |           | PADR     |              |
| BxA2R337                     | ICCSR          |           | PAUER    |              |
| BxCR336                      | ICLxR          |           | PBDDR    |              |
| BxM0R338                     | ICMxR          |           | PBDR     |              |
| BxM1R338                     | ICSxR103, 117, |           | PBUER    |              |
| BxM2R338                     | ICTxR          |           | PCAHR    |              |
| DATASEG71                    | ICUER          |           | PCALR    |              |
| DATASEGH71                   | ICOLIC         | 505       | 1 C/1LIC | 100, 323     |

| PCDCR  | 101           | QDCxR            | 305           | TBSMxR             | 161        |
|--------|---------------|------------------|---------------|--------------------|------------|
| PCDDR  | 100           | QDUER            | 364           | TBUER              | 365        |
| PCDR   | 100           | RAMSR            | 75            | TCBAR              | 169        |
| PCFR   | 101, 326      | RTCCR            | 52            | TCBPR              | 170        |
| PCUER  | 363           | RTCxR            | 52            | TCCR               | 168        |
| PDAHR  | 112, 328      | RTUER            | 362           | TCCSR              | 168        |
|        | 111, 327      | SAUER            | 366           | TCDHR              | 168        |
|        | 113           | SBUER            |               | TCDLR              |            |
|        | 113           | SCUER            |               | TCRxHR             |            |
|        | 114           | SDUER            |               | TCRxLR             |            |
|        | 114           | SEGSIZ           |               | TCSxHR             |            |
|        | 114           | SEUER            |               | TCSxLR             |            |
|        | 114           | SFUER            |               | TCUER              |            |
|        | 115           | SPCR 44, 91, 96  |               | VRAM00-VRAM        |            |
|        | 115           | 324              | 9, 139, 213,  | WDTCR              |            |
|        | 112           | SPDxR            | 212           | WDTTR              |            |
|        | 113           | SPSR             |               | WPCR               |            |
|        |               | SPUER            |               |                    |            |
|        | 113           |                  |               | WPSxHR             |            |
|        | 111           | STACKSEG         |               | WPSxLR             |            |
|        | 113, 328      | STACKSEGH        |               | WPSxR              |            |
|        | 363           | STACKSEGL        |               | WPxR               |            |
|        | 129, 330      | STKCR            |               | analog components  |            |
|        | 128, 329      | STKHLR           |               | bootstrap          |            |
|        | 130           | STKLLR           |               | breakpoints        |            |
|        | 130           | SWDTR            |               | Breakpoint x Addı  |            |
| PEB2R  | 131           | SxAR             | 180, 197      | Register           | 337        |
| PEB3R  | 131           | SxCR 102, 13     | 3, 183, 200   | Breakpoint x Addı  | ress 1     |
| PEB4R  | 131           | SxCr             | 116           | Register           | 337        |
| PEB5R  | 131           | SxDHR            | 186, 202      | Breakpoint x Addı  | ress 2     |
| PEB6R  | 132           | SxDLR            | 185, 202      | Register           | 337        |
| PEB7R  | 132           | SxDR             | 180, 197      | Breakpoint x Cont  | rol Regis- |
| PECR   | 129           | SxER (asynch m   | ode) 184,     | ter                | 336        |
| PEDCR  | 130           | 201              |               | Breakpoint x Masl  | k 0 Regis- |
| PEDDR  | 130           | SxER (clocked se | erial mode)   | ter                |            |
|        | 128           | 185              | ,             | Breakpoint x Masl  |            |
|        | 130, 330      | SxER (HDLC m     | ode) 202      | ter                | _          |
|        | 363           | SxLR             |               | Breakpoint x Masl  |            |
|        | 147           | SxSR (asynch m   |               | ter                |            |
|        | 146           | 198              | 101,          | Breakpoint/Debug   |            |
|        | 147           | SxSR (clocked se | erial mode)   | Register           |            |
|        | 148           | 182              | eriai illode) | clocks             |            |
|        | 146           | SxSR (HDLC m     | ode) 100      | Global Clock Doul  |            |
|        | 147           | TACR             | · ·           | ter                |            |
|        |               |                  |               |                    |            |
|        | 362           | TACSR            |               | Global Clock Mod   |            |
|        | 313           | TAPR             |               | Register           |            |
|        | 313           | TATXR            |               | Global Clock Mod   |            |
|        | 312           | TAUER            |               | Register           |            |
|        | 312           | TBCLR            |               | Global Control/Sta | _          |
|        | 313           | TBCMR            |               | ister              |            |
|        | 313           | TBCR             |               | Global Output Cor  |            |
|        | 364           | TBCSR            |               | ister              |            |
|        | 118, 135, 305 | TBLxR            |               | DMA channels       |            |
| -      | 304           | TBMxR            |               | DMA Master Auto    |            |
| QDCxHR | 305           | TBSLxR           | 161           | Register           | 243        |
|        |               |                  |               |                    |            |

| DMA Master Control Reg-   | DMA y Source Addr[7:0]       | Global Clock Double Regis-  |
|---------------------------|------------------------------|-----------------------------|
| ister244                  | Register254                  | ter350                      |
| DMA Master Control/Status | DMA y Special Control        | Global Control/Status Reg-  |
| Register243               | Register251                  | ister348                    |
| DMA Master Halt Register  | DMA y Termination Byte       | Global Power Save Control   |
| 243                       | Register249                  | Register349                 |
| DMA Master Request 0      | DMA y Termination Mask       | memory management61, 63     |
| Control Register120,      | Register249                  | Advanced Chip Select x      |
| 137, 246                  | external I/O control318      | Control Register75          |
| DMA Master Request 1      | I/O Bank x Control Register  | Data Segment High Register  |
| Control Register 121,     | 323                          | 71                          |
| 138, 247                  | I/O Handshake Control        | Data Segment Low Register   |
| DMA Master Timing Con-    | Register140, 321             | 71                          |
| trol Register245          | I/O Handshake Select Reg-    | Data Segment Register71     |
| DMA Timed Request Con-    | ister141, 322                | Memory Alternate Control    |
| trol Register248          | I/O Handshake Timeout        | Register74, 148             |
| DMA Timed Request Di-     | Register141, 322             | Memory Bank x Control       |
| vider High Register248    | Parallel Port C Alternate    | Register72                  |
| DMA Timed Request Di-     | High Register326             | Memory Timing Control       |
| vider Low Register248     | Parallel Port C Alternate    | Register73                  |
| DMA y Buffer Complete     | Low Register325              | MMU Expanded Code Reg-      |
| Register244               | Parallel Port C Function     | ister73                     |
| DMA y Buffer Un-          | Register326                  | MMU Instruction/Data        |
| used[15:8] Register250    | Parallel Port D Alternate    | Register70                  |
| DMA y Buffer Unused[7:0]  | High Register328             | RAM Segment Register .75    |
| Register249               | Parallel Port D Alternate    | Segment Size Register 72    |
| DMA y Control Register    | Low Register327              | Stack High Limit Register.  |
| 252                       | Parallel Port D Function     | 80                          |
| DMA y Destination Ad-     | Register328                  | Stack Limit Control Regis-  |
| dr[15:8] Register255      | Parallel Port E Alternate    | ter79                       |
| DMA y Destination Ad-     | High Register330             | Stack Low Limit Register    |
| dr[23:16] Register255     | Parallel Port E Alternate    | 79                          |
| DMA y Destination Ad-     | Low Register329              | Stack Segment High Regis-   |
| dr[7:0] Register255       | Parallel Port E Function     | ter71                       |
| DMA y Initial Addr[15:8]  | Register330                  | Stack Segment Low Regis-    |
| Register250               | Slave Port Control Register  | ter71                       |
| DMA y Initial Addr[23:16] | 324                          | Stack Segment Register .70  |
| Register250               | external interrupts86        | Write Protect Segment x     |
| DMA y Initial Addr[7:0]   | Interrupt x Control Register | High Register79             |
| Register250               | 88, 119, 136                 | Write Protect Segment x     |
| DMA y Length[15:8] Regis- | input capture channels289    | Low Register78              |
| ter253                    | Input Capture Control Reg-   | Write Protect Segment x     |
| DMA y Length[7:0] Regis-  | ister                        | Register                    |
| ter253                    | Input Capture Control/Sta-   | Write Protect x Register 77 |
| DMA y Link Addr[15:8]     | tus Register293              | Write Protection Control    |
| Register                  | Input Capture LSB x Regis-   | Register76                  |
| DMA y Link Addr[23:16]    | ter                          | Network Port B260           |
| Register                  | Input Capture MSB x Regis-   | Enable Network Port Regis-  |
| DMA y Link Addr[7:0]      | ter                          | ter                         |
| Register                  | Input Capture Source x Reg-  | Network Port B Collision    |
| DMA y Source Addr[15:8]   | ister103, 117, 134, 296      | Window Register275          |
| Register                  | Input Capture Trigger x      | Network Port B Command      |
| DMA y Source Addr[23:16]  | Register                     | Register                    |
| Register254               | low-power operation340       | Network Port B Configura-   |
|                           |                              |                             |

| tion 0 Register273         | Control Register 270         | ter114                       |
|----------------------------|------------------------------|------------------------------|
| Network Port B Configura-  | Network Port B Retransmit    | Parallel Port D Bit 4 Regis- |
| tion 1 Register273         | Max Register275              | ter114                       |
| Network Port B Configura-  | Network Port B Station Ad-   | Parallel Port D Bit 5 Regis- |
| tion 2 Register 274        | dress x Register 278         | ter114                       |
| Network Port B Configura-  | Network Port B Transmit      | Parallel Port D Bit 6 Regis- |
| tion 3 Register274         | Control Register 270         | ter115                       |
| Network Port B Control/    | Network Port B Transmit      | Parallel Port D Bit 7 Regis- |
| Status Register 268        | Extra Status Register 271    | ter115                       |
| Network Port B Data Regis- | Network Port B Transmit      | Parallel Port D Control Reg- |
| ter267                     | Pause LSB Register 269       | ister112                     |
| Network Port B Direct MII  | Network Port B Transmit      | Parallel Port D Data Direc-  |
| Register 272               | Pause MSB Register 269,      | tion Register113             |
| Network Port B Direct Rx   | 270                          | Parallel Port D Data Regis-  |
| Register272                | Network Port B Transmit      | ter111                       |
| Network Port B Direct Tx   | Status Register 267          | Parallel Port D Drive Con-   |
| Register272                | Network Port C283            | trol Register 113            |
| Network Port B Frame Lim-  | Parallel Port A              | Parallel Port D Function     |
| it LSB Register 276        | Parallel Port A Data Regis-  | Register113                  |
| Network Port B Frame Lim-  | ter91                        | Parallel Port E 126          |
| it MSB Register 276        | Slave Port Control Register  | Parallel Port E Alternate    |
| Network Port B Gap 0 Reg-  | 91                           | High Register 129            |
| ister275                   | Parallel Port B94            | Parallel Port E Alternate    |
|                            | Parallel Port B Data Direc-  |                              |
| Network Port B Gap 1 Reg-  |                              | Low Register 128             |
| ister                      | tion Register                | Parallel Port E Bit 0 Regis- |
| Network Port B Gap 2 Reg-  | Parallel Port B Data Regis-  | ter                          |
| ister                      | ter                          | Parallel Port E Bit 1 Regis- |
| Network Port B Last Data   | Slave Port Control Register  | ter                          |
| Register                   | 96                           | Parallel Port E Bit 2 Regis- |
| Network Port B MII Com-    | Parallel Port C              | ter                          |
| mand Register 277          | Parallel Port C Alternate    | Parallel Port E Bit 3 Regis- |
| Network Port B MII Config- | High Register 101            | ter                          |
| uration Register 276       | Parallel Port C Alternate    | Parallel Port E Bit 4 Regis- |
| Network Port B MII PHY     | Low Register 100             | ter                          |
| Address Register 277       | Parallel Port C Data Direc-  | Parallel Port E Bit 5 Regis- |
| Network Port B MII Read    | tion Register100             | ter 131                      |
| LSB Register277            | Parallel Port C Data Regis-  | Parallel Port E Bit 6 Regis- |
| Network Port B MII Read    | ter100                       | ter132                       |
| MSB Register278            | Parallel Port C Drive Con-   | Parallel Port E Bit 7 Regis- |
| Network Port B MII Regis-  | trol Register 101            | ter132                       |
| ter Address Register . 277 | Parallel Port C Function     | Parallel Port E Control Reg- |
| Network Port B MII Reset   | Register 101                 | ister 129                    |
| Register276                | Parallel Port D108           | Parallel Port E Data Direc-  |
| Network Port B MII Status  | Parallel Port D Alternate    | tion Register130             |
| Register278                | High Register112             | Parallel Port E Data Regis-  |
| Network Port B MII Write   | Parallel Port D Alternate    | ter128                       |
| LSB Register277            | Low Register111              | Parallel Port E Drive Con-   |
| Network Port B MII Write   | Parallel Port D Bit 0 Regis- | trol Register130             |
| MSB Register277            | ter113                       | Parallel Port E Function     |
| Network Port B Multicast   | Parallel Port D Bit 1 Regis- | Register 130                 |
| Filter x Register 271      | ter113                       | Parallel Port H144           |
| Network Port B Physical    | Parallel Port D Bit 2 Regis- | Parallel Port D Alternate    |
| Address x Register 271     | ter114                       | Low Register146              |
| Network Port B Receive     | Parallel Port D Bit 3 Regis- | Parallel Port H Alternate    |
|                            |                              |                              |

| TT 1 D 1                      |                               | G . /TT 1 250               |
|-------------------------------|-------------------------------|-----------------------------|
| High Register147              | Serial Port x Status Register | System/User mode352         |
| Parallel Port H Data Direc-   | (clocked serial mode) 182     | Analog User Enable Regis-   |
| tion Register148              | Serial Ports E – F            | ter365                      |
| Parallel Port H Data Regis-   | Serial Port x Address Regis-  | Enable Dual-Mode Register   |
| ter146                        | ter197                        | 367                         |
| Parallel Port H Drive Con-    | Serial Port x Control Regis-  | External Interrupt User En- |
| trol Register147              | ter200                        | able Register365            |
| Parallel Port H Function      | Serial Port x Data Register   | I/O Bank User Enable Reg-   |
| Register147                   | 197                           | ister364                    |
| PWM309                        | Serial Port x Divider High    | Input Capture User Enable   |
| PWM Block Access Regis-       | Register202                   | Register363                 |
| ter313                        | Serial Port x Divider Low     | Parallel Port A User Enable |
| PWM Block Pointer Regis-      | Register202                   | Register362                 |
| ter313                        | Serial Port x Extended Reg-   | Parallel Port B User Enable |
| PWM LSB 0 Register312         | ister (asynch mode)201        | Register362                 |
| PWM LSB 1 Register312         | Serial Port x Extended Reg-   | Parallel Port C User Enable |
| PWM LSB x Register313         | ister (HDLC mode)202          | Register363                 |
| PWM MSB x Register .313       | Serial Port x Long Stop       | Parallel Port D User Enable |
| Quadrature Decoder301         | Register197                   | Register363                 |
| Quad Decode Control Reg-      | Serial Port x Status Register | Parallel Port E User Enable |
| ister118, 305                 | (asynch mode)198              | Register363                 |
| Quad Decode Control/Sta-      | Serial Port x Status Register | Parallel Port H User Enable |
| tus Register304               | (HDLC mode)199                | Register362                 |
| Quad Decode Count High        | slave port204                 | PWM User Enable Register    |
| Register305                   | Slave Port Control Register   | 364                         |
| Quad Decode Count Regis-      | 139, 213                      | Quad Decode User Enable     |
| ter305                        | Slave Port Data x Registers   | Register364                 |
| quadrature Decoder            | 212                           | Real-Time Clock User En-    |
| Quad Decode Control Reg-      | Slave Port Status Register .  | able Register362            |
| ister135                      | 212                           | Serial Port A User Enable   |
| reset38                       | system management47           | Register366                 |
| reset/bootstrap               | Battery-Backed Onchip-En-     | Serial Port B User Enable   |
| Slave Port Control Register   | cryption RAM55                | Register366                 |
| 44                            | Global Control/Status Reg-    | Serial Port C User Enable   |
| Serial Ports A – D174         | ister51                       | Register366                 |
| Serial Port x Address Regis-  | Global CPU Register54         | Serial Port D User Enable   |
| ter180                        | Global Output Control Reg-    | Register366                 |
| Serial Port x Control Regis-  | ister54                       | Serial Port E User Enable   |
| ter102, 116, 133, 183         | Global RAM Configuration      | Register367                 |
| Serial Port x Data Register   | Register53                    | Serial Port F User Enable   |
| 180                           | Global Revision Register      | Register367                 |
| Serial Port x Divider High    | 54                            | Slave Port User Enable Reg- |
| Register186                   | Global ROM Configuration      | ister362                    |
| Serial Port x Divider Low     | Register53                    | Timer A User Enable Regis-  |
| Register185                   | Real-Time Clock Control       | ter365                      |
| Serial Port x Extended Reg-   | Register52                    | Timer B User Enable Regis-  |
| ister (asynch mode)184        | Real-Time Clock x Register    | ter365                      |
| Serial Port x Extended Reg-   | 52                            | Timer C User Enable Regis-  |
| ister (clocked serial mode)   | Secondary Watchdog Timer      | ter366                      |
| 185                           | Register53                    | Timer A152                  |
| Serial Port x Long Stop       | Watchdog Timer Control        | Global Control/Status Reg-  |
| Register180                   | Register52                    | ister156                    |
| Serial Port x Status Register | Watchdog Timer Test Reg-      | Timer A Control Register    |
| (asynch mode)181              | ister53                       | 155                         |
|                               |                               |                             |

| Timer A Control/Status      | SMODE pin settings 41          | connections207               |
|-----------------------------|--------------------------------|------------------------------|
| Register 154                | revision history401            | master 207                   |
| Timer A Prescale Register   |                                | master/slave communica-      |
| 154                         | S                              | tion208                      |
| Timer A Time Constant x     | acuial manta                   | slave207                     |
| Register 155                | serial ports                   | slave/master communica-      |
| Timer B                     | clock synchronization and data | tion208                      |
| Global Control/Status Reg-  | encoding193                    | overview                     |
| _                           | Serial Ports A – D 171         |                              |
| ister                       | block diagram 173              | pin use                      |
| Timer B Control Register    | clocks175                      | R/W timing                   |
| 160                         | data clocks 172                | register descriptions 212    |
| Timer B Control/Status      | dependencies175                | registers                    |
| Register 160                | interrupts176                  | slave attention              |
| Timer B Count LSB Regis-    | operation177                   | timing diagrams210           |
| ter162                      | asynchronous mode . 177        | sleepy clock modes31         |
| Timer B Count LSB x Reg-    |                                | SMODE pin settings41         |
| ister161                    | clocked serial mode 172,       | SPCR                         |
| Timer B Count MSB Regis-    | 178                            | Parallel Port A setup 89     |
| ter161                      | overview 171                   | specifications               |
| Timer B Count MSB x Reg-    | pin use175                     | AC characteristics           |
| _                           | register descriptions 180      |                              |
| ister                       | registers 174                  | analog components216         |
| Timer B Step LSB x Regis-   | SPI clock modes 171            | BGA package                  |
| ter161                      | SxSR171                        | dimensions391                |
| Timer B Step MSB x Regis-   | use of clocked Serial Port C   | land pattern 391             |
| ter161                      | 175                            | pinout389, 390               |
| Timer C165                  | use of clocked Serial Port D   | clock speeds381              |
| Global Control/Status Reg-  | 175                            | recommended clock/memo-      |
| ister170                    | Serial Ports E – F 187         | ry configurations 381        |
| Timer C Block Access Reg-   |                                | DC characteristics 369       |
| ister 169                   | asynchronous mode 187          | memory access times 372, 378 |
| Timer C Block Pointer Reg-  | block diagram 188              | external I/O reads 375       |
| ister                       | clocks190                      | external I/O writes 375      |
|                             | dependencies 190               |                              |
| Timer C Control Register    | HDLC data encoding 194         | memory reads                 |
| 168                         | HDLC mode 187                  | memory writes                |
| Timer C Control/Status      | DPLL counter 194               | package                      |
| Register 168                | interrupts 191                 | power and current consump-   |
| Timer C Divider High Reg-   | operation 192                  | tion                         |
| ister168                    | asynchronous mode . 192        | battery-backed clock 387     |
| Timer C Divider Low Reg-    | HDLC mode 192                  | sleep modes                  |
| ister168                    | overview187                    | spectrum spreader21, 25      |
| Timer C Reset x High Reg-   | pin use190                     | stack protection69           |
| ister169                    |                                | system management45          |
| Timer C Reset x Low Regis-  | register descriptions 197      | block diagram46              |
| ter169                      | registers189                   | clocks                       |
| Timer C Set x High Register | SxSR187                        | dependencies                 |
| 169                         | slave port                     | =                            |
|                             | addresses                      | interrupts                   |
| Timer C Set x Low Register  | block diagram204               | onchip-encryption RAM 45     |
| 169                         | bootstrap processor 204        | operation                    |
| reset                       | clocks205                      | periodic interrupt 49        |
| block diagram38             | dependencies205                | real-time clock49            |
| dependencies39              | interrupts 203, 205, 208       | watchdog timer 50            |
| operation40                 | example ISR208                 | other registers45            |
| register descriptions 44    |                                | GCPU register45              |
| registers38                 | operation                      | GOCR register45              |
| 5                           | configurations209              | - <del>G</del>               |

| GREV register45                | clocks166                    |
|--------------------------------|------------------------------|
| periodic interrupt45           | dependencies166              |
| real-time clock45              | DMA control163               |
| register descriptions51        | interrupts166, 167           |
| registers47                    | example ISR167               |
| watchdog timers45              | operation167                 |
| System/User mode351            | overview163                  |
| dependencies353                | register descriptions 168    |
| differences between System     | registers165                 |
| mode and User mode351          | timing diagrams              |
| inaccessible addresses in User | I/O R/W cycles376            |
| mode353                        | memory R/W cycles373         |
| interrupts354, 360             | memory R/W cycles (early     |
| opcodes358                     | output enable and write en-  |
| operation355                   | able)374                     |
| complete operating system      | slave port R/W cycles210,    |
| 356                            | 211                          |
| enabling357                    | 211                          |
| =                              | W                            |
| memory protection355           |                              |
| mixed operation356             | watchdog timer               |
| overview                       | primary watchdog timer50     |
| register descriptions362       | primary/secondary watchdog   |
| registers352                   | timer bug50                  |
| use 255                        | secondary watchdog timer .50 |
| memory protection355           | settings50                   |
| Т                              |                              |
|                                |                              |
| timers                         |                              |
| Timer A149                     |                              |
| block diagram151               |                              |
| capabilities150                |                              |
| clocks152                      |                              |
| dependencies152                |                              |
| interrupts150, 153             |                              |
| example ISR153                 |                              |
| operation153                   |                              |
| overview149                    |                              |
| register descriptions 154      |                              |
| registers152                   |                              |
| reload register operation      |                              |
| 149                            |                              |
| Timer B157                     |                              |
| block diagram157               |                              |
| clocks158                      |                              |
| dependencies158                |                              |
| interrupts158, 159             |                              |
| example ISR159                 |                              |
| operation159                   |                              |
| overview157                    |                              |
| PWM operation157               |                              |
| register descriptions 160      |                              |
| registers158                   |                              |
| Timer C163                     |                              |
| block diagram164               |                              |
| 010411 41461411110T            |                              |