

## S3 Family 8-Bit Microcontrollers

# S3F8S5A

## **Product Specification**

PS032303-0314

PRELIMINARY



Copyright ©2014 Zilog<sup>®</sup>, Inc. All rights reserved. www.zilog.com

## material in Life

ii

#### Warning: DO NOT USE THIS PRODUCT IN LIFE SUPPORT SYSTEMS.

#### LIFE SUPPORT POLICY

ZILOG'S PRODUCTS ARE NOT AUTHORIZED FOR USE AS CRITICAL COMPONENTS IN LIFE SUPPORT DEVICES OR SYSTEMS WITHOUT THE EXPRESS PRIOR WRITTEN APPROVAL OF THE PRESIDENT AND GENERAL COUNSEL OF ZILOG CORPORATION.

#### As used herein

Life support devices or systems are devices which (a) are intended for surgical implant into the body, or (b) support or sustain life and whose failure to perform when properly used in accordance with instructions for use provided in the labeling can be reasonably expected to result in a significant injury to the user. A critical component is any component in a life support device or system whose failure to perform can be reasonably expected to cause the failure of the life support device or system or to affect its safety or effectiveness.

#### **Document Disclaimer**

©2014 Zilog, Inc. All rights reserved. Information in this publication concerning the devices, applications, or technology described is intended to suggest possible uses and may be superseded. ZILOG, INC. DOES NOT ASSUME LIABILITY FOR OR PROVIDE A REPRESENTATION OF ACCURACY OF THE INFORMATION, DEVICES, OR TECHNOLOGY DESCRIBED IN THIS DOCUMENT. ZILOG ALSO DOES NOT ASSUME LIABILITY FOR INTELLECTUAL PROPERTY INFRINGEMENT RELATED IN ANY MANNER TO USE OF INFORMATION, DEVICES, OR TECHNOLOGY DESCRIBED HEREIN OR OTHERWISE. The information contained within this document has been verified according to the general principles of electrical and mechanical engineering.

S3 and Z8 are trademarks or registered trademarks of Zilog, Inc. All other product or service names are the property of their respective owners.



iii

# **Revision History**

Each instance in this document's revision history reflects a change from its previous edition. For more details, refer to the corresponding page(s) or appropriate links furnished in the following table.

| Date        | Revision<br>Level | Description                                                                                                       | Page       |
|-------------|-------------------|-------------------------------------------------------------------------------------------------------------------|------------|
| Mar<br>2014 | 03                | Updated Ordering Information table.                                                                               | <u>374</u> |
| Feb<br>2014 | 02                | Amended incorrect part numbers in Ordering Information table with respect to packaging containers for SDIP parts. | <u>374</u> |
| Dec<br>2013 | 01                | Original Zilog issue.                                                                                             | All        |



#### iv

# **Table of Contents**

| Revision History                  | .iii |
|-----------------------------------|------|
| List of Figures                   | xiii |
| List of Tables                    | viii |
| Overview                          | . 1  |
| S3F8S5A Microcontroller           | . 1  |
| Features                          |      |
| Block Diagram                     |      |
| Pin Assignments                   |      |
| Pin Circuits                      | 11   |
| Address Space                     | 19   |
| Program Memory                    | 19   |
| Smart Option                      | 20   |
| Register Architecture             |      |
| Register Page Pointer             |      |
| Register Set1                     |      |
| Register Set2                     |      |
| Prime Register Space              |      |
| Working Registers                 |      |
|                                   |      |
| Register Pointer Registers        |      |
| Register Addressing               |      |
| Common Working Register Area      |      |
| 4-Bit Working Register Addressing |      |
| 8-Bit Working Register Addressing |      |
| System and User Stack             |      |
| User-Defined Stacks               |      |
| Stack Pointers                    |      |
| Addressing Modes                  |      |
| Register Addressing Mode          |      |
|                                   |      |
| Indirect Register Addressing Mode |      |
| Indexed Addressing Mode           |      |
| Direct Address Mode               | 51   |



| Indirect Address Mode                                      | 53 |
|------------------------------------------------------------|----|
| Relative Address Mode                                      | 54 |
| Immediate Mode                                             | 55 |
| Control Registers                                          | 56 |
| Interrupt Structure                                        | 60 |
| Levels                                                     | 60 |
| Vectors                                                    | 60 |
| Sources                                                    | 60 |
| Interrupt Types                                            | 61 |
| S3F8S5A Interrupt Structure                                | 62 |
| Interrupt Vector Addresses                                 | 63 |
| Enable/Disable Interrupt Instructions                      | 65 |
| System-Level Interrupt Control Registers                   | 65 |
| Interrupt Processing Control Points                        | 66 |
| Peripheral Interrupt Control Registers                     | 68 |
| System Mode Register                                       | 69 |
| Interrupt Mask Register                                    | 70 |
| Interrupt Priority Register                                | 72 |
| Interrupt Request Register                                 | 74 |
| Interrupt Pending Function Types                           | 75 |
| Pending Bits Cleared Automatically by Hardware             | 75 |
| Pending Bits Cleared by the Service Routine                | 76 |
| Interrupt Source Polling Sequence                          |    |
| Interrupt Service Routines                                 |    |
| Generating Interrupt Vector Addresses                      |    |
| Nesting of Vectored Interrupts         Instruction Pointer |    |
| Fast Interrupt Processing                                  |    |
| Procedure for Initiating Fast Interrupts                   |    |
| Fast Interrupt Service Routine                             |    |
| Relationship to Interrupt Pending Bit Types                |    |
| Programming Guidelines                                     | 81 |
| Instruction Set                                            | 82 |
| Data Types                                                 | 82 |
| Register Addressing                                        | 82 |
| Addressing Modes                                           | 82 |
| Instruction Summary                                        | 83 |



|    | Flags Register                           |
|----|------------------------------------------|
|    | Instruction Set Notation                 |
|    |                                          |
| Op | Code Maps                                |
|    | Condition Codes                          |
|    | Instruction Descriptions                 |
|    | Add with Carry                           |
|    | Add                                      |
|    | Logical AND                              |
|    | Bit AND                                  |
|    | Bit Compare                              |
|    | Bit Complement 101                       |
|    | Bit Reset                                |
|    | Bit Set                                  |
|    | Bit OR                                   |
|    | Bit Test, Jump Relative on False         |
|    | Bit Test, Jump Relative on True          |
|    | Bit XOR                                  |
|    | Call Procedure                           |
|    | Complement Carry Flag                    |
|    | Clear                                    |
|    | Complement                               |
|    | Compare                                  |
|    | Compare, Increment, and Jump on Equal    |
|    | Compare, Increment, and Jump on NonEqual |
|    | Decimal Adjust                           |
|    | Decrement                                |
|    | Decrement Word                           |
|    | Disable Interrupts                       |
|    | Divide (Unsigned)                        |
|    | Decrement and Jump if NonZero            |
|    | Enable Interrupts                        |
|    | *                                        |
|    | Enter                                    |
|    | Exit                                     |
|    | Idle Operation                           |
|    | Increment                                |
|    | Increment Word                           |



| Interrupt Return                   |
|------------------------------------|
| Jump                               |
| Jump Relative                      |
| Load                               |
| Load Bit                           |
| Load Memory                        |
| Load Memory and Decrement          |
| Load Memory and Increment          |
| Load Memory with PreDecrement      |
| Load Memory with PreIncrement      |
| Load Word                          |
| Multiply (Unsigned)                |
| Next                               |
| No Operation                       |
| Logical OR                         |
| Pop from Stack                     |
| Pop User Stack (Decrementing) 154  |
| Pop User Stack (Incrementing) 155  |
| Push to Stack                      |
| Push User Stack (Decrementing) 157 |
| Push User Stack (Incrementing) 158 |
| Reset Carry Flag                   |
| Return                             |
| Rotate Left                        |
| Rotate Left through Carry          |
| Rotate Right                       |
| Rotate Right through Carry 166     |
| Select Bank0                       |
| Select Bank1                       |
| Subtract with Carry                |
| Set Carry Flag                     |
| Shift Right Arithmetic 173         |
| Set Register Pointer               |
| Stop Operation                     |
| Subtract                           |
| Swap Nibbles                       |



| Test Complement under Mask           | 180 |
|--------------------------------------|-----|
| Test Under Mask                      | 182 |
| Wait for Interrupt                   | 184 |
| Logical Exclusive OR                 | 185 |
| Clock Circuit                        | 186 |
| System Clock Circuit                 | 187 |
| CPU Clock Notation                   | 187 |
| Clock Status During Power-Down Modes | 188 |
| System Clock Control Register        |     |
| Oscillator Control Register          | 190 |
| Stop Control Register                | 192 |
| Switching the CPU Clock              | 192 |
| Reset and Power-Down                 | 194 |
| System Reset                         |     |
| Normal Mode Reset Operation          | 194 |
| Hardware Reset Values                | 195 |
| Reset Source Indicating Register     | 200 |
| Power-Down Modes                     |     |
| Stop Mode                            |     |
| Idle Mode                            | 202 |
| I/O Ports                            |     |
| Port Data Registers                  |     |
| Port 0                               |     |
| Port 1 Port 2                        |     |
| Port 3                               |     |
| Port 4                               |     |
| Basic Timer                          |     |
| Basic Timer Control Register         |     |
| 8-Bit Timer A/B                      |     |
| 8-Bit Timer A                        |     |
| Timer A Control Register             |     |
| Timer A Function Description         |     |
| Timer A Interrupts                   |     |
| Timer A Interval Timer Mode          |     |
| Timer A Pulse Width Modulation Mode  | 236 |
| Timer A Capture Mode                 | 237 |



| 8-Bit Timer B238Timer B Pulse Width Calculations241                                                                                                                                                   |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8-Bit Timer C                                                                                                                                                                                         |
| 16-Bit Timer D0/D1249Timer D0 Control Register250Timer D0 Function Description252Timer D0 Interrupts252Timer D0 Interval Timer Mode252Timer D0 Pulse Width Modulation Mode253Timer D0 Capture Mode254 |
| 16-Bit Timer D1256Timer D1 Control Register257Timer D1 Function Description259Timer D1 Interrupts259Timer D1 Interval Timer Mode259Timer D1 Pulse Width Modulation Mode260Timer D1 Capture Mode261    |
| Watch Timer263Watch Timer Control Register264                                                                                                                                                         |
| LCD Controller/Driver266LCD RAM Address Area268LCD Control Register269Internal Resistor Bias271Common Signals272Segment Signals272                                                                    |
| 10-Bit Analog-to-Digital Converter279Function Description279Conversion Timing280A/D Converter Control Register280A/D Converter Data Registers282Internal Reference Voltage Levels282                  |
| Serial I/O Interface285Programming Procedure285SIO Control Register285SIO Prescaler Register287                                                                                                       |



| SIO Serial Timing                                      | 288 |
|--------------------------------------------------------|-----|
| UARTO                                                  | 290 |
| Programming Procedure                                  | 290 |
| UART0 High-Byte Control Register                       |     |
| UART0 Low-Byte Control Register                        |     |
| UART0 Interrupt Pending bits                           |     |
| UART0 Data Register                                    |     |
| UART0 Baud Rate Data Register                          |     |
| UART0 Baud Rate Calculations                           |     |
| Mode 0 Baud Rate Calculation                           |     |
| Mode 2 Baud Rate Calculation                           | 296 |
| Modes 1 and 3 Baud Rate Calculation                    | 296 |
| UART0 Mode 0 Function Description                      |     |
| Mode 0 Transmit Procedure                              |     |
| Mode 0 Receive Procedure                               |     |
| Serial Port Mode 1 Function Description                |     |
| Mode 1 Transmit Procedure                              |     |
| Mode 1 Receive Procedure                               |     |
| Serial Port Mode 2 Function Description                |     |
| Mode 2 Receive Procedure                               |     |
| Serial Port Mode 3 Function Description                |     |
| Mode 3 Transmit Procedure                              |     |
| Mode 3 Receive Procedure                               |     |
| Serial Communication for Multiprocessor Configurations | 305 |
| Sample Protocol for Master/Slave Interaction           |     |
| Setup Procedure for Multiprocessor Communications      | 305 |
| UART1                                                  | 307 |
| Programming Procedure                                  | 307 |
| UART1 High-Byte Control Register                       |     |
| UART1 Low-Byte Control Register                        |     |
| UART1 Interrupt Pending Bits                           |     |
| UART1 Data Register                                    |     |
| UART1 Baud Rate Data Register                          |     |
| UART1 Baud Rate Calculations                           |     |
| Mode 0 Baud Rate Calculation                           |     |
| Mode 2 Baud Rate Calculation                           |     |



| Modes 1 and 3 Baud Rate Calculation 312                |
|--------------------------------------------------------|
| UART1 Mode 0 Function Description                      |
| Mode 0 Transmit Procedure                              |
| Mode 0 Receive Procedure 315                           |
| Serial Port Mode 1 Function Description                |
| Mode 1 Transmit Procedure                              |
| Mode 1 Receive Procedure                               |
| Serial Port Mode 2 Function Description                |
| Mode 2 Transmit Procedure 318                          |
| Mode 2 Receive Procedure 319                           |
| Serial Port Mode 3 Function Description                |
| Mode 3 Transmit Procedure                              |
| Mode 3 Receive Procedure                               |
| Serial Communication for Multiprocessor Configurations |
| Sample Protocol for Master/Slave Interaction           |
| Setup Procedure for Multiprocessor Communications      |
| Pattern Generation Module                              |
| 10-Bit Pulse Width Modulation                          |
| PWM Counter   327                                      |
| PWM Data and Extension Registers                       |
| PWM Clock Rate                                         |
| PWM Function Description                               |
| PWM Control Register                                   |
| Embedded Flash Memory Interface                        |
| User Program Mode                                      |
| Flash Memory Control Registers                         |
| Flash Memory Control Register                          |
| Flash Memory User Programming Enable Register          |
| Flash Memory Sector Address Registers                  |
| ISP <sup>™</sup> Onboard Programming Sector            |
| ISP Reset Vector and ISP Sector Size                   |
| Sector Erase Operations                                |
| The Sector Erase Procedure in User Program Mode        |
| Program Operations                                     |
| Read Operations                                        |
| Hard Lock Protection                                   |





# List of Figures

| Figure 1.  | S3F8S5A MCU Block Diagram                                         |
|------------|-------------------------------------------------------------------|
| Figure 2.  | Pin Assignments, 44-QFP Package                                   |
| Figure 3.  | Pin Assignments, 42-Pin SDIP Package                              |
| Figure 4.  | Pin Circuit Type A 11                                             |
| Figure 5.  | Pin Circuit Type B 12                                             |
| Figure 6.  | Pin Circuit Type C 12                                             |
| Figure 7.  | Pin Circuit Type D-2 13                                           |
| Figure 8.  | Pin Circuit Type D-3 13                                           |
| Figure 9.  | Pin Circuit Type F-1 14                                           |
| Figure 10. | Pin Circuit Type F-2         15                                   |
| Figure 11. | Pin Circuit Type H-1 16                                           |
| Figure 12. | Pin Circuit Type H-2 17                                           |
| Figure 13. | Pin Circuit Type H-4 18                                           |
| Figure 14. | Program Memory Address Space                                      |
| Figure 15. | Smart Option                                                      |
| Figure 16. | Internal Register File Organization                               |
| Figure 17. | Set1, Set2, and Prime Area Register, and LCD Data Register Map 28 |
| Figure 18. | 8-Byte Working Register Areas                                     |
| Figure 19. | Contiguous 16-Byte Working Register Block                         |
| Figure 20. | Noncontiguous 16-Byte Working Register Block                      |
| Figure 21. | 16-Bit Register Pair                                              |
| Figure 22. | Register File Addressing                                          |
| Figure 23. | Common Working Register Area                                      |
| Figure 24. | 4-Bit Working Register Addressing                                 |
| Figure 25. | 4-Bit Working Register Addressing Example                         |
| Figure 26. | 8-Bit Working Register Addressing                                 |
| Figure 27. | 8-Bit Working Register Addressing Example                         |
| Figure 28. | Stack Operations                                                  |
| Figure 29. | Register Addressing                                               |
| Figure 30. | Working Register Addressing                                       |
| Figure 31. | Indirect Register Addressing to Register File                     |
| Figure 32. | Indirect Register Addressing to Program Memory                    |
| Figure 33. | Indirect Working Register Addressing to Register File             |



| Figure 34. | Indirect Working Register Addressing to Program or Data Memory | 48  |
|------------|----------------------------------------------------------------|-----|
| Figure 35. | Indexed Addressing to Register File                            | 49  |
| Figure 36. | Indexed Addressing to Program or Data Memory with Short Offset | 50  |
| Figure 37. | Indexed Addressing to Program or Data Memory                   | 51  |
| Figure 38. | Direct Addressing for Load Instructions                        | 52  |
| Figure 39. | Direct Addressing for Call and Jump Instructions               | 53  |
| Figure 40. | Indirect Addressing                                            | 54  |
| Figure 41. | Relative Addressing                                            | 55  |
| Figure 42. | Immediate Addressing                                           | 55  |
| Figure 43. | S3F8 Series Interrupt Types                                    | 61  |
| Figure 44. | S3F8S5A Interrupt Structure                                    | 62  |
| Figure 45. | ROM Vector Address Area                                        | 63  |
| Figure 46. | Interrupt Function Diagram                                     | 67  |
| Figure 47. | Interrupt Request Priority Groups                              | 72  |
| Figure 48. | How to Use an ENTER Statement                                  | 127 |
| Figure 49. | How to Use an EXIT Statement                                   | 128 |
| Figure 50. | Instruction Pointer                                            | 134 |
| Figure 51. | How to Use the NEXT Instruction                                | 149 |
| Figure 52. | Rotate Left                                                    | 161 |
| Figure 53. | Rotate Left through Carry                                      | 162 |
| Figure 54. | Rotate Right                                                   | 164 |
| Figure 55. | Rotate Right through Carry                                     | 166 |
| Figure 56. | Shift Right                                                    | 173 |
| Figure 57. | Swap Nibbles                                                   | 179 |
| Figure 58. | Sample Program Structure                                       | 184 |
| Figure 59. | Crystal/Ceramic Oscillator ( $f_X$ )                           | 186 |
| Figure 60. | External Oscillator ( $f_X$ )                                  | 186 |
| Figure 61. | RC Oscillator ( $f_X$ )                                        | 186 |
| Figure 62. | Crystal Oscillator (f <sub>XT</sub> )                          | 187 |
| Figure 63. | External Oscillator ( $f_{XT}$ )                               | 187 |
| Figure 64. | System Clock Circuit Diagram                                   | 189 |
| Figure 65. | S3F8S5A I/O Port Data Register Format                          | 204 |
| Figure 66. | Basic Timer Block Diagram                                      | 229 |
| Figure 67. | Timer A Functional Block Diagram                               | 233 |
| Figure 68. | Simplified Timer A Function Diagram: Interval Timer Mode       | 236 |
| Figure 69. | Simplified Timer A Function Diagram: PWM Mode                  | 237 |



| Figure 70.  | Simplified Timer A Function Diagram: Capture Mode                                            |
|-------------|----------------------------------------------------------------------------------------------|
| Figure 71.  | Timer B Functional Block Diagram    239                                                      |
| Figure 72.  | Timer B Waveform, Example #1 of 3241                                                         |
| Figure 73.  | Timer B Output Flip-Flop Waveforms in Repeat Mode 243                                        |
| Figure 74.  | Timer B Waveform, Example #2 of 3 244                                                        |
| Figure 75.  | Timer B Waveform, Example #3 of 3 245                                                        |
| Figure 76.  | Timer C Functional Block Diagram                                                             |
| Figure 77.  | Timer D0 Functional Block Diagram                                                            |
| Figure 78.  | Simplified Timer D0 Function Diagram: Interval Timer Mode 253                                |
| Figure 79.  | Simplified Timer D0 Function Diagram: PWM Mode                                               |
| Figure 80.  | Simplified Timer D0 Function Diagram: Capture Mode 255                                       |
| Figure 81.  | Timer D1 Functional Block Diagram                                                            |
| Figure 82.  | Simplified Timer D1 Function Diagram: Interval Timer Mode                                    |
| Figure 83.  | Simplified Timer D1 Function Diagram: PWM Mode                                               |
| Figure 84.  | Simplified Timer D1 Function Diagram: Capture Mode                                           |
| Figure 85.  | Watch Timer Circuit Block Diagram                                                            |
| Figure 86.  | LCD Function Diagram                                                                         |
| Figure 87.  | LCD Circuit                                                                                  |
| Figure 88.  | Internal Resistor Bias Pin Connections                                                       |
| Figure 89.  | Select/No-Select Signal in 1/2 Duty, 1/2 Bias Display Mode 272                               |
| Figure 90.  | Select/No-Select Signal in 1/3 Duty, 1/3 Bias Display Mode 273                               |
| Figure 91.  | LCD Signal Waveforms: 1/2 Duty, 1/2 Bias                                                     |
| Figure 92.  | LCD Signal Waveforms: 1/3 Duty, 1/3 Bias 275                                                 |
| Figure 93.  | LCD Signal Waveforms: 1/4 Duty, 1/3 Bias                                                     |
| Figure 94.  | LCD Signal Waveforms: 1/8 Duty, 1/4 Bias, #1 of 2 277                                        |
| Figure 95.  | LCD Signal Waveforms: 1/8 Duty, 1/4 Bias, #2 of 2 278                                        |
| Figure 96.  | A/D Converter Functional Block Diagram                                                       |
| Figure 97.  | Recommended A/D Converter Circuit for Highest Absolute Accuracy 284                          |
| Figure 98.  | SIO Functional Block Diagram                                                                 |
| Figure 99.  | Serial I/O Timing in Transmit/Receive Mode (T <sub>X</sub> at Falling Edge;<br>SIOCON.4 = 0) |
| Figure 100  | Serial I/O Timing in Transmit/Receive Mode ( $T_X$ at at Rising Edge;                        |
| riguie 100. | $SIOCON.4 = 1) \dots 289$                                                                    |
| Figure 101. | UART0 Functional Block Diagram 298                                                           |
| Figure 102. | UART0 Serial Port Mode 0 Timing 300                                                          |
| Figure 103. | UARTO Serial Port Mode 1 Timing                                                              |



| Figure 104. UARTO Serial Port Mode 2 Timing                         | 303 |
|---------------------------------------------------------------------|-----|
| Figure 105. UART0 Serial Port Mode 3 Timing                         |     |
| Figure 106. UARTO Multiprocessor Serial Data Communications Example | 306 |
| Figure 107. UART1 Functional Block Diagram                          | 314 |
| Figure 108. UART1 Serial Port Mode 0 Timing                         | 316 |
| Figure 109. UART1 Serial Port Mode 1Timing                          | 318 |
| Figure 110. UART1 Serial Port Mode 2 Timing                         | 319 |
| Figure 111. UART1 Serial Port Mode 3 Timing                         | 321 |
| Figure 112. UART1 Multiprocessor Serial Data Communications Example | 323 |
| Figure 113. Pattern Generation Flow                                 | 324 |
| Figure 114. Pattern Generation Circuit Diagram                      | 325 |
| Figure 115. 10-Bit PWM Basic Waveform                               | 329 |
| Figure 116. 10-Bit Extended PWM Waveform                            | 329 |
| Figure 117. PWM Functional Block Diagram                            | 332 |
| Figure 118. Flash Memory Sector Addressing                          | 337 |
| Figure 119. Program Memory Address Space                            | 339 |
| Figure 120. Sector Configurations in User Program Mode              | 341 |
| Figure 121. Input Timing for External Interrupts                    | 351 |
| Figure 122. Input Timing for nRESET                                 | 351 |
| Figure 123. Stop Mode Release Timing Initiated by nRESET            | 352 |
| Figure 124. Stop Mode Release Timing Initiated by Interrupts        | 352 |
| Figure 125. Low Voltage Reset Timing                                | 354 |
| Figure 126. Serial Data Transfer Timing                             | 355 |
| Figure 127. Waveform for UART Timing Characteristics                | 356 |
| Figure 128. Timing Waveform for the UART Module                     | 356 |
| Figure 129. Clock Timing Measurement at X <sub>IN</sub>             | 358 |
| Figure 130. Clock Timing Measurement at XT <sub>IN</sub>            | 359 |
| Figure 131. Operating Voltage Range                                 | 359 |
| Figure 132. Package Dimensions, 44-Pin QFP Package                  | 361 |
| Figure 133. Package Dimensions, 42-pin SDIP Package                 | 362 |
| Figure 134. S3F8S5A Pin Assignments, 44-QFP Package                 | 363 |
| Figure 135. S3F8S5A Pin Assignments, 42-SDIP Package                | 364 |
| Figure 136. RC Delay Circuit                                        | 365 |
| Figure 137. PCB Design Guide for on Board Programming               | 366 |
| Figure 138. Development System Configuration                        |     |
| Figure 139. DIP Switch for the Smart Option                         | 371 |

| Figure | 140. | TB8S5A 48-Pin Connector                      | 372 |
|--------|------|----------------------------------------------|-----|
| Figure | 141. | S3F8S5A Probe Adapter for the 44-Pin Package | 373 |



# List of Tables

| Table 1.  | Pin Descriptions, 44-Pin Device                      |
|-----------|------------------------------------------------------|
| Table 2.  | S3F8S5A Register Types                               |
| Table 3.  | Register Page Pointer                                |
| Table 4.  | Register Pointer 0                                   |
| Table 5.  | Register Pointer 1                                   |
| Table 6.  | Stack Pointer High Byte Register 41                  |
| Table 7.  | Stack Pointer Low Byte Register 41                   |
| Table 8.  | Set1 Registers                                       |
| Table 9.  | Page 4 Registers                                     |
| Table 10. | Set1, Bank0 Registers 57                             |
| Table 11. | Set1, Bank1 Registers 58                             |
| Table 12. | S3F8S5A Interrupt Vectors                            |
| Table 13. | Interrupt Control Register Overview                  |
| Table 14. | Vectored Interrupt Source Control and Data Registers |
| Table 15. | System Mode Register                                 |
| Table 16. | Interrupt Mask Register                              |
| Table 17. | Interrupt Priority Register                          |
| Table 18. | Interrupt Request Register                           |
| Table 19. | Interrupt Pending Register                           |
| Table 20. | Instruction Pointer High Byte Register               |
| Table 21. | Instruction Pointer Low Byte Register                |
| Table 22. | Instruction Group Summary                            |
| Table 23. | Flags Register    86                                 |
| Table 24. | Flag Descriptions                                    |
| Table 25. | Flag Notation Conventions                            |
| Table 26. | Instruction Set Symbols                              |
| Table 27. | Instruction Notation Conventions                     |
| Table 28. | Op Code Quick Reference (0–7) 91                     |
| Table 29. | Op Code Quick Reference (8–F) 92                     |
| Table 30. | Condition Codes1                                     |
| Table 31. | DA Instruction                                       |
| Table 32. | System Clock Control Register 190                    |
| Table 33. | Oscillator Control Register 191                      |
|           |                                                      |



xix

| Table 34. | Stop Control Register                              |
|-----------|----------------------------------------------------|
| Table 35. | Set1 Register Values After RESET 195               |
| Table 36. | Set1, Bank0 Register Values After Reset            |
| Table 37. | Set1, Bank1 Register and Values After RESET 197    |
| Table 38. | Page 4 Register Values After RESET    199          |
| Table 39. | Reset Source Indicating Register                   |
| Table 40. | State of RESETID 200                               |
| Table 41. | S3F8S5A Port Configuration Overview                |
| Table 42. | Port Data Register Summary 204                     |
| Table 43. | Port 0 Control High Byte Register 205              |
| Table 44. | Port 0 Pull-Up Resistor Enable Register            |
| Table 45. | Port 1 Control Register High Byte Register         |
| Table 46. | Port 1 Control Register Low Byte Register 209      |
| Table 47. | Port 1 Interrupt Enable Register                   |
| Table 48. | Port 1 Interrupt Pending Register                  |
| Table 49. | Port 1 Output Pull-Up Resistor Enable Register 212 |
| Table 50. | Port 1 n-Channel Open Drain Mode Register 213      |
| Table 51. | Port 2 Control Register High Byte Register         |
| Table 52. | Port 2 Control Register Low Byte Register 215      |
| Table 53. | Port 2 Pull-Up Resistor Enable Register            |
| Table 54. | Port 2 n-Channel Open Drain Mode Register 217      |
| Table 55. | Port 3 Control High-Byte Register                  |
| Table 56. | Port 3 Control Mid Byte Register 220               |
| Table 57. | Port 3 Control Low Byte Register 221               |
| Table 58. | Port3[4:5] Control Register 222                    |
| Table 59. | Port 3 Output Pull-Up Resistor Enable Register 223 |
| Table 60. | Port 4 Control High Byte Register                  |
| Table 61. | Port 4 Control Low Byte Register                   |
| Table 62. | Port 4 Pull-Up Interrupt Enable Register           |
| Table 63. | Port 4 Interrupt Pending Register                  |
| Table 64. | Port 4 Output Pull-Up Resistor Enable Register     |
| Table 65. | Basic Timer Control Register 230                   |
| Table 66. | Timer A Control Register 234                       |
| Table 67. | Timer B Control Register                           |
| Table 68. | Timer B Clock Selection Register 241               |
| Table 69. | Timer C Control Register                           |



| Table 70.  | Timer D0 Control Register                                 |
|------------|-----------------------------------------------------------|
| Table 71.  | Timer D1 Control Register                                 |
| Table 72.  | Watch Timer Control Register                              |
| Table 73.  | LCD Control Register                                      |
| Table 74.  | LCD Display Data RAM Organization                         |
| Table 75.  | LCD Control Register                                      |
| Table 76.  | A/D Converter Control Register                            |
| Table 77.  | A/D Converter Data High Byte Register                     |
| Table 78.  | A/D Converter Control Register                            |
| Table 79.  | SIO Control Register                                      |
| Table 80.  | SIO Prescaler Register                                    |
| Table 81.  | UART0 Control High Byte Register                          |
| Table 82.  | UART0 Control Low Byte Register                           |
| Table 83.  | UART0 Data Register                                       |
| Table 84.  | UART0 Baud Rate Data Register 295                         |
| Table 85.  | Commonly Used Baud Rates Generated by BRDATA0 297         |
| Table 86.  | UART1 Control High Byte Register                          |
| Table 87.  | UART1 Control Low Byte Register                           |
| Table 88.  | UART1 Data Register                                       |
| Table 89.  | UART1 Baud Rate Data Register                             |
| Table 90.  | Commonly Used Baud Rates Generated by BRDATA1 313         |
| Table 91.  | Pattern Generation Module Control Register                |
| Table 92.  | PWM Control and Data Registers                            |
| Table 93.  | PWM Output Stretch Values for the Extension Data Register |
| Table 94.  | PWM Control Register                                      |
| Table 95.  | Flash Memory Control Register                             |
| Table 96.  | Flash Memory User Programming Enable Register             |
| Table 97.  | Flash Memory Sector Address Register High Byte Register   |
| Table 98.  | Flash Memory Sector Address Register Low Byte Register    |
| Table 99.  | Reset Vector Address                                      |
| Table 100. | ISP Sector Size                                           |
| Table 101. | Absolute Maximum Ratings 348                              |
| Table 102. | DC Electrical Characteristics                             |
| Table 103. | AC Electrical Characteristics                             |
| Table 104. | Input/Output Capacitance                                  |
| Table 105. | Data Retention Supply Voltage in Stop Mode                |



xxi

| Table 106. | A/D Converter Electrical Characteristics                          |
|------------|-------------------------------------------------------------------|
| Table 107. | Low Voltage Reset Electrical Characteristics                      |
| Table 108. | Synchronous SIO Electrical Characteristics                        |
| Table 109. | UART Timing Characteristics in Mode 01 355                        |
| Table 110. | Main Oscillator Characteristics                                   |
| Table 111. | Suboscillation Characteristics                                    |
| Table 112. | Main Oscillation Stabilization Time 358                           |
| Table 113. | Suboscillation Stabilization Time                                 |
| Table 114. | Internal Flash ROM Electrical Characteristics                     |
| Table 115. | Pins Used to Read/Write the Flash ROM                             |
| Table 116. | Circuit Connections                                               |
| Table 117. | Power Selection Settings for the TB8S5A Target Board              |
| Table 118. | SMDS2+ Tool Selection Setting 369                                 |
| Table 119. | Single Header Pins to Select Clock Source/PWM/Operation Mode 370  |
| Table 120. | Single Header Pins as Input Path for External Trigger Sources 371 |
| Table 121. | Ordering Information for the S3F8S5A MCU 374                      |





## **Overview**

Zilog's S3F8 Series of 8-bit single-chip microcontrollers offers a fast and efficient CPU, a wide range of integrated peripherals, and multiple Flash memory sizes. Important CPU features include:

- Efficient register-oriented architecture
- Selectable CPU clock sources
- Idle and Stop power-down mode release by interrupts
- Built-in basic timer with watchdog function

A sophisticated interrupt structure recognizes up to eight interrupt levels. Each level can have one or more interrupt sources and vectors. Fast interrupt processing (within a minimum of four CPU clocks) can be assigned to specific interrupt levels.

## S3F8S5A Microcontroller

The S3F8S5A MCU features 48KB or 32KB of Flash ROM. Using a proven modular design approach, the S3F8S5A MCU was developed by integrating the following peripheral modules with the SAM88 core:

- Five programmable I/O ports, including four 8-bit ports and one 4-bit port for a total of 36 pins
- Eight bit-programmable pins for external interrupts
- One 8-bit basic timer for oscillation stabilization and watchdog functions (system reset)
- Three 8-bit timer/counters and two 16-bit timer/counters with selectable operating modes
- Watch timer for real time
- LCD controller/driver
- A/D converter with 8 selectable input pins
- Synchronous SIO modules
- Two asynchronous UART modules
- Pattern generation module

The S3F8S5A MCU is currently available in a 44-pin QFP package and a 42-pin SDIP package.



2

## **Features**

The S3F8S5A MCU offers the following features:

- SAM88 RC CPU core
- Program memory (full Flash ROM):
  - 48Kx8 bits program memory (S3F8S5AXZZ-QZ8A/S3F8S5AX2A-AQ8A)
  - 32K x 8 bits program memory (S3F8S5AX49-QZ8A/S3F8S5AX29-AQ8A)
  - Internal Flash (program) memory
    - Sector size: 128 bytes
    - 10 years data retention
    - Fast programming time: user program and sector erase available
    - Endurance: 10,000 erase/program cycles
    - External serial programming support
    - Expandable On-Board Program (OBP) sector
- Data memory (RAM)
  - LCD display data memory
  - 1040 x 8 bits data memory
- Instruction set
  - 78 instructions
  - IDLE and STOP instructions added for power-down modes
- 34 I/O pins
  - 12 pins shared with other signal pins
  - 24 pins shared with LCD signal outputs
- Interrupts
  - 8 interrupt levels and 23 interrupt sources
  - Fast interrupt processing feature
- 8-bit basic timer
  - Watchdog timer function
  - 4 types of clock source
- 8-bit Timer/Counter A
  - Programmable 8-bit internal timer
  - External event counter function
  - PWM and capture function
- 8-bit Timer/Counter B



3

- Programmable 8-bit internal timer
- Carrier frequency generator
- 8-bit Timer/Counter C
  - Programmable 8-bit internal timer
  - PWM function
- Two 16-bit Timer/Counters (D0/D1)
  - Programmable 16-bit internal timer
  - External event counter function
  - PWM and capture function
- Watch timer
  - Interval time: 1.995ms, 0.125s, 0.25s, and 0.5s at 32.768kHz
  - 0.5/1/2/4 kHz selectable buzzer output
- LCD controller/driver
  - 18 segments and 8 common terminals
  - 1/2, 1/3, 1/4, and 1/8 duty selectable
  - Resistor bias selectable
- Analog-to-digital converter
  - 8 channel analog input
  - 10-bit conversion resolution
  - 25µs conversion time
- Two UART channels
  - Full-duplex serial I/O interface
  - Four programmable operating modes
  - Autogenerating parity bit
- 8-bit serial I/O interface
  - 8-bit transmit/receive mode
  - 8-bit receive mode
  - LSB-first or MSB-first transmission selectable
  - Internal or external clock source
- 10-bit PWM generator
  - Single PWM output on P2.1
  - Adjustable frequency based on CPU clock
- Pattern generation module
  - Triggered by timer match signal and software



4

- Low Voltage Reset (LVR)
  - Criteria voltage: 1.9V, 2.8V
  - Enable/disable by Smart Option (ROM address: 3Fh)
- Two power-down modes
  - IDLE: only CPU clock stops
  - STOP: selected system clock and CPU clock stop
- Oscillation sources
  - Crystal, ceramic, or RC for main clock
  - Main clock frequency: 0.4–12.0MHz
  - 32.768kHz crystal oscillation circuit for subclock
- Instruction execution times
  - 333 ns at 12.0 MHz f<sub>X</sub> (minimum)
  - 122.1µs at 32.768kHz f<sub>XT</sub> (minimum)
- Internal voltage converter for 5V operations
- Smart Option
  - Low Voltage Reset (LVR) level and enable/disable are at your hard-wired option (ROM address 3Fh)
  - ISP related option selectable (ROM address 3Eh)
- Operating voltage range
  - 1.8V to 5.5V at 0.4–4.2MHz
  - 2.2V to 5.5V at 0.4–12.0MHz
- Operating temperature range:  $40^{\circ}$ C to  $+85^{\circ}$ C
- Packages
  - 40-pin QFP
  - 42-pin SDIP



## **Block Diagram**

Figure 1 shows a block diagram for the S3F8S5A MCU, which is available in a 44-pin QFP package and a 42-pin SDIP package.



Figure 1. S3F8S5A MCU Block Diagram





## **Pin Assignments**

Figure 2 shows the pin assignments for the 44-pin QFP package.



Figure 2. Pin Assignments, 44-QFP Package



Figure 3 illustrates the pin assignments for the 42-pin SDIP package.



Figure 3. Pin Assignments, 42-Pin SDIP Package

Table 1 identifies each pin in the S3F8S5A MCU's 44-pin QFP package.

| Pin<br>Name                  | Pin Description                                                                                                                      | Pin<br>Type | Circuit<br>Type | Pin No.                              | Shared Functions                               |
|------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|-------------|-----------------|--------------------------------------|------------------------------------------------|
| P0.0<br>P0.1<br>P0.2<br>P0.3 | I/O port with bit-programmable pins; Input or push-pull output and software assignable pull-ups.                                     | I/O         | H–2             | 25(29)<br>26(30)<br>27(31)<br>28(32) | COM0/AD0 COM1/<br>AD1 COM2/AD2<br>COM3/AD3     |
| P1.0<br>P1.1                 | I/O port with 1-bit-programmable pins;<br>Schmitt trigger input or push-pull, open-drain<br>output and software assignable pull-ups. | I/O         | H–4             | 1(7)<br>2(8)                         | INT0/TAOUT/<br>TAPWM/SEG20<br>INT1/TACLK/ BUZ/ |
| P1.2<br>P1.3                 | Alternately used for external interrupt input (noise filters, interrupt enable and pending control).                                 |             | D–3             | 3(9)<br>4(10)                        | SEG21 INT2/TACAP<br>INT3/TD1OUT/<br>TD1PWM     |
| Note:                        | Parentheses indicate pin numbers for the 42-pin SDIP p                                                                               | oackage.    |                 |                                      |                                                |



| Pin                                           |                                                                                                                                                                            | Pin  | Circuit    |                                                      |                                                                              |
|-----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|------------------------------------------------------|------------------------------------------------------------------------------|
| Name                                          | Pin Description                                                                                                                                                            | Туре | Туре       | Pin No.                                              | Shared Functions                                                             |
| P1.4<br>P1.5<br>P1.6<br>P1.7                  | I/O port with 1-bit-programmable pins;<br>Schmitt trigger input or push-pull output and<br>software assignable pull-ups. The P1.4 –<br>P1.5 are not in the 42-Pin package. | I/O  | F–1<br>D–2 | 16<br>17<br>10(16)<br>11(17)                         | TD1CLK/AD5<br>TD1CAP/AD6 X <sub>TIN</sub><br>X <sub>TOUT</sub>               |
| P2.0<br>P2.1                                  | I/O port with bit-programmable pins; Input or push-pull output and software assignable                                                                                     | I/O  | D-3        | 13(19)<br>14(20)                                     | TBPWM/TD0CLK<br>PWM/TD0CAP                                                   |
| P2.2                                          | pull-ups.                                                                                                                                                                  |      | F–2        | 15(21)                                               | TD0OUT/ TD0PWM/<br>AD4 AD7/SI                                                |
| P2.3<br>P2.4<br>P2.5<br>P2.6<br>P2.7          |                                                                                                                                                                            |      | H–4        | 18(22)<br>19(23)<br>20(24)<br>21(25)<br>22(26)       | SO/SEG0 SCK/<br>SEG1 RXD0/SEG2<br>TXD0/SEG3                                  |
| P3.0–P3.<br>4                                 | I/O port with bit-programmable pins; Schmitt trigger input or push-pull, open-drain output and software assignable pull-ups.                                               | I/O  | H–4        | 29–33<br>(33–37)<br>34(38)                           | PG0–PG4/<br>SEG4–SEG8<br>TCOUT/TCPWM/                                        |
| P3.1<br>P3.2<br>P3.3                          |                                                                                                                                                                            |      |            | 35(39)<br>36(40)                                     | PG5/SEG9 RXD1/<br>PG6/SEG10 TXD1/<br>PG7/SEG11                               |
| P4.0<br>P4.1<br>P4.2<br>P4.3<br>P4.4-<br>P4.7 | I/O port with bit-programmable pins; Schmitt trigger input or push-pull output and software assignable pull-ups.                                                           | I/O  | H–4        | 37(41)<br>38(42)<br>39(1)<br>40(2)<br>41–44<br>(3–6) | INT4/SEG12 INT5/<br>SEG13 INT6/SEG14<br>INT7/SEG15<br>COM4–COM7/<br>SEG16–19 |
| COM0-<br>COM1                                 | LCD common signal outputs.                                                                                                                                                 | I/O  | H-2        | ```                                                  | P0.0–P0.3/<br>AD0–AD3                                                        |
| COM2-<br>COM7                                 |                                                                                                                                                                            |      | H-4        | 41–44<br>(3–6)                                       | P2.2–P2.7/<br>SEG0–SEG5                                                      |

#### Table 1. Pin Descriptions, 44-Pin Device (Continued)

Note: Parentheses indicate pin numbers for the 42-pin SDIP package.



| Pin            |                                                    | Pin      | Circuit |                  |                                  |
|----------------|----------------------------------------------------|----------|---------|------------------|----------------------------------|
| Name           | Pin Description                                    | Туре     | Туре    | Pin No.          | Shared Functions                 |
| SEG0           | LCD segment signal outputs.                        | I/O      | H–4     | 19(23)           | P2.4/SO                          |
| SEG1           |                                                    |          |         | 20(24)           | P2.5/SCK                         |
| SEG2<br>SEG3   |                                                    |          |         | 21(25)           | P2.6/RXD0<br>P2.7/TXD0           |
| SEG3<br>SEG4–S |                                                    |          |         | 22(26)<br>29–33  | P3.0–P3.4/                       |
| EG8            |                                                    |          |         | (33–37)          |                                  |
|                |                                                    |          |         | 34(38)           | P3.5/TCOUT/                      |
| SEG9           |                                                    |          |         |                  | TCPWM/PG5 P3.6/                  |
|                |                                                    |          |         | 35(39)           | RXD1/PG6 P3.7/                   |
| SEG10          |                                                    |          |         | 36(40)           | TXD1/PG7 P4.0/                   |
| SEG11          |                                                    |          |         | 37(41)           |                                  |
| SEG12<br>SEG13 |                                                    |          |         | 38(42)<br>39(1)  | P4.1/INT5<br>P4.2/INT6           |
| SEG14          |                                                    |          |         | 40(2)            | P4.3/INT7                        |
| SEG15          |                                                    |          |         | 41–44            | P4.4–P4.7/                       |
| SEG16-         |                                                    |          |         | (3–6)            | COM4-COM7 P1.0/                  |
| SEG19          |                                                    |          |         | 1(7)             | INT0/ TAOUT/                     |
| 05000          |                                                    |          |         | 0(0)             | TAPWM P1.1/INT1/                 |
| SEG20          |                                                    |          |         | 2(8)             | TACLK/BUZ                        |
| SEG21          |                                                    |          |         |                  |                                  |
| AD0-AD         | A/D converter analog input channels.               | I/O      | H–2     | 25–28            | P0.0–P0.3/                       |
| 3              |                                                    |          |         | (29–32)          |                                  |
|                |                                                    |          | F–2     | 15(21)           | TDOOUT/ TDOPWM                   |
| AD4            |                                                    |          | F–1     | 16               | P1.4/TD1CLK<br>P1.5/TD1CAP       |
| AD5            |                                                    |          | F=1     | 17               | P2.3/SI                          |
| AD6            |                                                    |          | F–2     | 18(22)           |                                  |
| AD7            |                                                    |          |         | ( )              |                                  |
| SCK            | Serial interface clock.                            | I/O      | H-4     | 20(24)           | P2.5/SEG1                        |
| SO             | Serial interface data output.                      | I/O      | H-4     | 19(23)           | P2.4/SEG0                        |
| SI             | Serial interface data input.                       | I/O      | F-2     | 18(22)           | P2.3/AD7                         |
| BUZ            | Output pin for buzzer signal.                      | I/O      | H-4     | 2(8)             | P1.1/INT1/ TACLK/<br>SEG21       |
| TXD0<br>RXD0   | UART 0 data output, input.                         | I/O      | H-4     | 22(26)<br>21(25) | P2.7/SEG3 P2.6/<br>SEG2          |
| TXD1<br>RXD1   | UART 1 data output, input.                         | I/O      | H-4     | 36(40)<br>35(39) | P3.7/PG7/SEG11<br>P3.6/PG6/SEG10 |
| Note: Par      | rentheses indicate pin numbers for the 42-pin SDIP | package. |         |                  |                                  |

#### Table 1. Pin Descriptions, 44-Pin Device (Continued)



| Pin<br>Name                                                         | Pin Description                           | Pin<br>Type | Circuit<br>Type | Pin No.                            | Shared Functions                                                     |  |
|---------------------------------------------------------------------|-------------------------------------------|-------------|-----------------|------------------------------------|----------------------------------------------------------------------|--|
| PG0–PG<br>4<br>PG5                                                  | Pattern generation output.                | I/O         | H-4             | 29–33<br>(33–37)<br>34(38)         | P3.0–P3.4/<br>SEG4–SEG8<br>P3.5/TCOUT/<br>TCPWM/SEG9 P3.6/           |  |
| PG6<br>PG7                                                          |                                           |             |                 | 35(39)<br>36(40)                   | RXD1/SEG10<br>P3.7/TXD1/SEG11                                        |  |
| TAOUT/<br>TAPWM                                                     | Timer A clock and PWM output.             | I/O         | H-4             | 1(7)                               | P1.0/INT0/SEG20                                                      |  |
| TACLK                                                               | Timer A external clock input.             | I/O         | H-4             | 2(8)                               | P1.1/INT1/                                                           |  |
| TACAP                                                               | Timer A capture input.                    | I/O         | D-3             | 3(9)                               | 3(9)                                                                 |  |
| TBPWM                                                               | Timer B PWM output.                       | I/O         | D-3             | 13(19)                             | 13(19)                                                               |  |
| TCOUT/<br>TCPWM                                                     | Timer C clock and PWM output.             | I/O         | H-4             | 34(38)                             | 34(38)                                                               |  |
| TD0OUT/<br>TD0PWM                                                   | Timer D0 clock and PWM output.            | I/O         | F-2             | 15(21)                             | 15(21)                                                               |  |
| TD0CLK                                                              | Timer D0 external clock input.            | I/O         | D-3             | 13(19)                             | 13(19)                                                               |  |
| TD0CAP                                                              | Timer D0 capture input.                   | I/O         | D-3             | 14(20)                             | 14(20)                                                               |  |
| TD1OUT/<br>TD1PWM                                                   | Timer D1 clock and PWM output.            | I/O         | D-3             | 4(10)                              | 4(10)                                                                |  |
| TD1CLK                                                              | Timer D1 external clock input.            | I/O         | F-1             | 16                                 | 16                                                                   |  |
| TD1CAP                                                              | Timer D1 capture input.                   | I/O         | F-1             | 17                                 | 17                                                                   |  |
| PWM                                                                 | 10-bit PWM generator output.              | I/O         | D-3             | 14(20)                             | 14(20)                                                               |  |
| INT0<br>INT1                                                        | External interrupt input pins.            | I/O         | H-4             | 1(7)<br>2(8)                       | P1.0/TAOUT/<br>TAPWM/SEG20<br>P1.1/TACLK/ BUZ/                       |  |
| INT2<br>INT3                                                        |                                           |             | D-3             | 3(9)<br>4(10)                      | SEG21 P1.2/TACAP<br>P1.3/TD1OUT/<br>TD1PWM P4.0/<br>SEG12 P4.1/SEG13 |  |
| INT4<br>INT5<br>INT6<br>INT7                                        |                                           |             | H-4             | 37(41)<br>38(42)<br>39(1)<br>40(2) | P4.2/SEG14 P4.3/<br>SEG15                                            |  |
| AVREF                                                               | A/D converter reference voltage.          | _           | _               | 23(27)                             | -                                                                    |  |
| nRESET                                                              | System reset pin with a pull-up resistor. | Ι           | _               | 12(18)                             | В                                                                    |  |
| Note: Parentheses indicate pin numbers for the 42-pin SDIP package. |                                           |             |                 |                                    |                                                                      |  |

#### Table 1. Pin Descriptions, 44-Pin Device (Continued)



| Pin<br>Name                           | Pin Description                            | Pin<br>Type | Circuit<br>Type | Pin No.          | Shared Functions |
|---------------------------------------|--------------------------------------------|-------------|-----------------|------------------|------------------|
| XIN<br>XOUT                           | Main oscillator pins.                      | _           | _               | 8(14)<br>7(13)   | -                |
| X <sub>TIN</sub><br>X <sub>TOUT</sub> | Crystal oscillator pins for sub clock.     | -           | -               | 10(16)<br>11(17) | P1.6 P1.7        |
| TEST                                  | Test pin: it must be connected to $V_{SS}$ | Ι           | -               | 9(15)            | -                |
| V <sub>DD</sub>                       | Power supply input pins.                   |             | -               | 5(11)            | _                |
| V <sub>SS</sub>                       | Ground pins.                               | _           | -               | 6(12)            | _                |
| AV <sub>SS</sub>                      | Ground pin.                                | _           | _               | 24(28)           | _                |

#### Table 1. Pin Descriptions, 44-Pin Device (Continued)

## **Pin Circuits**

Figure 4 shows the Type A pin circuit.



Figure 4. Pin Circuit Type A



Figure 5 shows the Type B pin circuit .



Figure 5. Pin Circuit Type B

Figure 6 shows the Type C Pin Circuit.







Figure 7 shows the Type D-2 pin circuit for ports 1.6 to 1.7.



Figure 7. Pin Circuit Type D-2

Figure 8 shows the Type D-3 pin circuit for P1.2–P1.3 and P2.0–P2.1.



Figure 8. Pin Circuit Type D-3



Figure 9 shows the Type F-1 Pin Circuit for P1.4–P1.5.







Figure 10 shows the Type F-2 pin circuit for P2.2 and P2.3.



Figure 10. Pin Circuit Type F-2



Figure 11 shows the Type H-1 pin circuit.



Figure 11. Pin Circuit Type H-1



Figure 12 shows the Type H-2 pin circuit for P0.0–P0.3.



Figure 12. Pin Circuit Type H-2







Figure 13. Pin Circuit Type H-4





# **Address Space**

The S3F8S5A microcontroller features two types of address space:

- Internal program ROM
- Internal register file

A 16-bit address bus supports program memory operations. A separate 8-bit register bus carries addresses and data between the CPU and the register file.

The S3F8S5A features 48KB of internal Flash ROM. The 256-byte physical register space is expanded into an addressable area of 320 bytes using addressing modes.

A 22-byte LCD display register file is implemented.

## **Program Memory**

Program memory (ROM) stores program code or table data. The S3F8S5A MCU features 48KB internal Flash program memory.

The first 256 bytes of the ROM space, 0h-0FFh, are reserved for interrupt vector addresses. Unused locations in this address range can be used as normal program memory. If you use the vector address area to store program code, be careful not to overwrite the vector addresses stored in these locations.

The ROM address at which program execution starts after a reset is 0100h.

The reset address of ROM can be changed by a smart option only in the S3F8S5A (full-Flash device). Refer to the <u>Embedded Flash Memory Interface</u> chapter on page 334 to learn more.

The program memory address space is shown in Figure 14.







Figure 14. Program Memory Address Space

### **Smart Option**

The *Smart Option*, diagrammed in Figure 15, is the ROM option for the start condition of the chip. The ROM address used for the smart option ranges from 003Ch to 003Fh. The S3F8S5A MCU uses only addresses in the range 003Eh to 003Fh.

When any values are written in the Smart Option area (i.e., 003Ch-003Fh) by an LDC instruction, the data in the area may be changed, but the Smart Option is not affected. Smart Option data should be written in this Smart Option area using an OTP/MTP programming tool.







- **Notes:** 1. In Figure 15, by setting ISP reset vector change selection bit (3E.7) to 0, the ISP area becomes available. If this bit is 1, 3Eh.6 and 3Eh.5 are rendered meaningless.
  - 2. If the ISP reset vector change selection bit (3Eh.7) is 0, the user must change the ISP reset vector address from 0100h to an address for which the user wants to set a reset address (i.e., 0200h, 0300h, 0500h, or 0900h). If the reset vector address is 0200h,



the ISP area can be assigned from 0100h to 01FFh (an area of 256 bytes). If 0300h, the ISP area can be assigned from 0100h to 02FFh (512 bytes). If 0500h, the ISP area can be assigned from 0100h to 04FFh (1024 bytes). If 0900h, the ISP area can be assigned from 0100h to 08FFh (2048 bytes).

- 3. If the ISP protection enable/disable bit is 0, user cannot erase or program the ISP area selected by 3Eh.1 and 3Eh.0 in Flash memory.
- 4. The user can select a suitable ISP protection size using 3Eh.1 and 3Eh.0. If the ISP protection enable/disable bit (3Eh.2) is 1, 3Eh.1 and 3Eh.0 are rendered meaning-less.
- 5. After selecting the ISP reset vector address when selecting the ISP protection size, do not select a value greater than the ISP area size.

### **Register Architecture**

In the S3F8S5A implementation, the upper 64-byte area of register files is expanded to two 64-byte areas, called *Set1* and *Set2*. The upper 32-byte area of Set1 is further expanded to two 32-byte register banks (Bank0 and Bank1), and the lower 32-byte area is a single 32-byte common area.

In the S3F8S5A MCU, the total number of addressable 8-bit registers is 1131. Of these 1131 registers, 13 bytes are designated for the CPU and system control registers, 78 bytes are designated for the peripheral control and data registers, 16 bytes are used as shared working registers, and 1024 registers are designated for general-purpose use in Page 0–Page 1 (including 22 bytes for LCD display registers).

Set1 register locations can always be set, regardless of which of the ten register pages is currently selected. A Set1 location, however, can only be addressed using register addressing modes.

The extension of register space into separately addressable areas (sets, banks, and pages) is supported by multiple addressing mode restrictions: the select bank instructions, SB0 and SB1, and the register page pointer (PP).

Specific register types and the area (in bytes) that they occupy in the register file are summarized in Table 2.



#### Table 2. S3F8S5A Register Types

| Register Type                                                                                                                                                                  | Number of<br>Bytes |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|
| General-purpose registers (including the 16-byte common working register area, four 192-byte prime register areas (including LCD data registers), and four 64-byte Set2 areas. | 1040               |
| CPU and system control registers.                                                                                                                                              | 13                 |
| Mapped clock, peripheral, I/O control, and data registers.                                                                                                                     | 78                 |
| Total addressable bytes.                                                                                                                                                       | 1131               |

Figure 16 shows the organization of the internal register file.







Figure 16. Internal Register File Organization





## **Register Page Pointer**

The S3F8 Series architecture supports the logical expansion of the physical 256-byte internal register file (using an 8-bit data bus) into as many as 16 separately-addressable register pages. Page addressing is controlled by the register page pointer (PP; Set1, Bank0, DFh). In the S3F8S5A microcontroller, a paged register file expansion is implemented for LCD data registers, and the register page pointer must be changed to address other pages.

After a reset, the page pointer's source value (i.e., the lower nibble) and the destination value (the upper nibble) are always 0000, automatically. Therefore, the S3F8S5A MCU always selects Page 0 as the source and destination page for register addressing.

The contents of the Register Page Pointer (PP) Register are described in Table 3.

| Bit     | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|---------|-----|-----|-----|-----|-----|-----|-----|-----|
| Reset   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| R/W     | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Address |     |     |     | D   | Fh  |     |     |     |

#### Table 3. Register Page Pointer (PP; Set1)

Register Addressing Mode only

Note: R = read only; R/W = read/write.

| Bit   | Description                                           |
|-------|-------------------------------------------------------|
| [7:4] | Destination Register Page Selection Bits <sup>1</sup> |
|       | 0000: Destination: Page 0.                            |
|       | 0001: Destination: Page 1.                            |
|       | 0010: Destination: Page 2.                            |
|       | 0011: Destination: Page 3.                            |
|       | 0100: Destination: Page 4.                            |
|       | 0101–1111: Reserved.                                  |
| [3:0] | Source Register Page Selection Bits <sup>2</sup>      |
|       | 0000: Destination: Page 0.                            |
|       | 0001: Destination: Page 1.                            |
|       | 0010: Destination: Page 2.                            |
|       | 0011: Destination: Page 3.                            |
|       | 0100: Destination: Page 4.                            |
|       | 0101–1111: Reserved.                                  |

Notes:

Mode

1. In the S3F8S5A microcontroller, the internal register file is configured as three pages (pages 0-4).

2. Pages 0–3 are used for the general purpose register file; Page 3 addresses 00h–15h are also used for the LCD Data Register.



# **Notes:** In Table 3, the internal register file is configured as twelve pages (i.e., pages 0–4). Page 3 includes the LCD Data Register (300h–315h).

The following example indicates how to use the Page Pointer to clear the contents of RAM (i.e., Page 0, Page 1).

| LI              |       |                  | ; | Destination $\leftarrow$ 0, Source $\leftarrow$ 0 |
|-----------------|-------|------------------|---|---------------------------------------------------|
|                 |       | 40C0H            |   |                                                   |
| LI<br>RAMCLO CI |       | RO, HOFFH<br>DRO | ' | Page 0 RAM clear starts                           |
|                 | '     | R0,RAMCLO        |   |                                                   |
|                 |       | •                | ; | R0 = 00H LD PP,#10H ; Destination $\leftarrow$    |
|                 |       |                  | ; | 1, Source $\leftarrow$ 0                          |
| LI              | D F   | R0,#0FFH         | ; | Page 1 RAM clear starts                           |
| RAMCL1 CI       | LR @  | @R0              |   |                                                   |
| DJ              | JNZ F | R0,RAMCL1        |   |                                                   |
| CI              | LR @  | @R0              | ; | R0 = 00h                                          |

**Note:** To learn more about the DJNZ instruction, see <u>page 125</u>.

### **Register Set1**

The term *Set1* refers to the upper 64 bytes of the register file, locations C0h-FFh.

The upper 32-byte area of this 64-byte space (E0h–FFh) is divided into two 32-byte register banks, Bank0 and Bank1. The Set Register's SB0 or SB1 bank instructions are used to address one bank or the other. A hardware reset operation always selects Bank0 addressing.

The upper two 32-byte areas of Set1 (E0h–FFh), Bank0 and Bank1, contain 68 mapped system and peripheral control registers. The lower 32-byte area contains 16 system registers (D0h–DFh) and a 16-byte common working register area (C0h–CFh). Use the common working register area as a *scratch* area for data operations being performed in other areas of the register file.

Registers in the Set1 location are directly accessible at all times using Register Addressing Mode. The 16-byte working register area can only be accessed using working register addressing. To learn more about working register addressing, see the <u>Addressing Modes</u> chapter on page 43.





## **Register Set2**

The same 64-byte physical space that is used for Set1 location C0h-FFh is logically duplicated to add another 64 bytes of register space. This expanded area of the register file is called Set2. In the S3F8S5A MCU, the Set2 C0h-FFh address range is accessible on pages 0–3.

The logical division of Set1 and Set2 is maintained by means of addressing mode restrictions: Use only Register Addressing Mode to access Set1 locations; to access registers in Set2, you must use Register Indirect Addressing Mode or Indexed Addressing Mode. The Set2 register area of Page 0 is commonly used for stack operations.

### **Prime Register Space**

The lower 192 bytes of the S3F8S5A MCU's 256-byte register pages (00h–BFh) is called the *prime register space* or, more simply, the *prime area*. Prime registers can be accessed using any of the seven addressing modes (to learn more, see the <u>Addressing Modes</u> chapter on page 43).

The prime register area on Page 0 is immediately addressable following a reset. To address the prime registers on pages 0 or 1, you must set the register page pointer (PP) to the appropriate source and destination values.







Figure 17. Set1, Set2, and Prime Area Register, and LCD Data Register Map

## **Working Registers**

Instructions can access specific 8-bit registers or 16-bit register pairs using either 4-bit or 8-bit address fields. When 4-bit working register addressing is used, the 256-byte register file can be seen by the programmer as consisting of thirty-two 8-byte register groups, or *slices*. Each slice consists of eight 8-bit registers.

When using the two 8-bit register pointers, RP1 and RP0, two working register slices can be selected at any time to form a 16-byte working register block. When using these register pointers, you can move this 16-byte register block anywhere in the addressable register file, except for the Set2 area.

The terms *slice* and *block* are used in this document to help readers visualize the size and relative locations of selected working register spaces, as follows:

- One working register *slice* is 8 bytes (eight 8-bit working registers; R0–R7 or R8–R15)
- One working register *block* is 16 bytes (sixteen 8-bit working registers; R0–R15)



29

All of the registers in an 8-byte working register slice have the same binary value for their five most significant address bits, thereby making it possible for each register pointer to point to one of the 24 slices in the register file. The base addresses for the two selected 8-byte register slices are contained in register pointers RP0 and RP1.

After a reset, RP0 and RP1 always point to the 16-byte common area in Set1 (C0h–CFh). Figure 18 illustrates the 8-byte working register areas (i.e., slices).



Figure 18. 8-Byte Working Register Areas

### **Using the Register Pointers**

Register pointers RP0 and RP1, mapped to addresses D6h and D7h in Set1, are used to select two movable 8-byte working register slices in the register file. After a reset, they point to the working register common area; RP0 points to addresses C0h–C7h, and RP1 points to addresses C8h–CFh.

To change a register pointer value, load a new value to RP0 and/or RP1 using an SRP or LD instruction; see Figures 19 and 20.







Figure 19. Contiguous 16-Byte Working Register Block





With working register addressing, you can only access those two 8-bit slices of the register file that are currently pointed to by RPO and RP1. You cannot, however, use the register pointers to select a working register space in Set2, COh-FFh, because these locations can be accessed only using the Indirect Register or Indexed addressing modes.

The selected 16-byte working register block usually consists of two contiguous 8-byte slices. As a general programming guideline, Zilog recommends that RP0 point to the lower slice, and that RP1 point to the upper slice; see Figure 19. In some cases, it may be



necessary to define working register areas in different (noncontiguous) areas of the register file. In Figure 20, RP0 points to the upper slice, and RP1 to the lower slice.

Because a register pointer can point to either of the two 8-byte slices in the working register block, the working register area can be flexibly defined to support program requirements.

#### **Setting the Register Pointers**

| SRP  | #70h       | ; RP0 ← 70h, RP1 ← 78h                           |     |
|------|------------|--------------------------------------------------|-----|
| SRP1 | #48h       | ; RP0 $\leftarrow$ no change, RP1 $\leftarrow$ 4 | 8h  |
| SRP0 | #0A0h      | ; RP0 $\leftarrow$ A0h, RP1 $\leftarrow$ no char | ıge |
| CLR  | RP0        | ; RP0 $\leftarrow$ 00h, RP1 $\leftarrow$ no char | ıge |
| LD   | RP1, #0F8h | ; RP0 $\leftarrow$ no change, RP1 $\leftarrow$ 0 | F8h |

#### Using Register Pointers to Calculate the Sum of a Series of Registers

Calculate the sum of registers 80h to 85h using the register pointer. The register addresses 80h through 85h contains the values 10h, 11h, 12h, 13h, 14h, and 15h, respectively:

| SRP0 | #80h  | ; | RP0 ← 80h                   |
|------|-------|---|-----------------------------|
| ADD  | R0,R1 | ; | $R0 \leftarrow R0 + R1$     |
| ADC  | R0,R2 | ; | $R0 \leftarrow R0 + R2 + C$ |
| ADC  | R0,R3 | ; | $R0 \leftarrow R0 + R3 + C$ |
| ADC  | R0,R4 | ; | $R0 \leftarrow R0 + R4 + C$ |
| ADC  | R0,R5 | ; | $R0 \leftarrow R0 + R5 + C$ |

The sum of these six registers, 6Fh, is located in the R0 Register (80h). The instruction string used in this example takes 12 bytes of instruction code, and its execution time is 36 cycles. If the register pointer is not used to calculate the sum of these registers, the following instruction sequence must be used:

| ADD | 80h,81h | ; | 80h $\leftarrow$ | (80h) | + | (81h) |   |   |
|-----|---------|---|------------------|-------|---|-------|---|---|
| ADC | 80h,82h | ; | $80h \leftarrow$ | (80h) | + | (82h) | + | С |
| ADC | 80h,83h | ; | 80h ←            | (80h) | + | (83h) | + | С |
| ADC | 80h,84h | ; | 80h ←            | (80h) | + | (84h) | + | С |
| ADC | 80h,85h | ; | 80h $\leftarrow$ | (80h) | + | (85h) | + | С |

As a result, the sum of the six registers is also located in register 80h. However, this instruction string takes 15 bytes of instruction code rather than 12 bytes, and its execution time is 50 cycles rather than 36 cycles.





## **Register Pointer Registers**

The contents of the Register Pointer 0 (RP0) and Register Pointer 1 (RP1) registers are described in Tables 4 and 5.

| Bit           | 7                | 6           | 5          | 4            | 3          | 2    | 1 | 0 |
|---------------|------------------|-------------|------------|--------------|------------|------|---|---|
| Reset         | 1                | 1           | 0          | 0            | 0          | _    | _ | - |
| R/W           | R/W              | R/W         | R/W        | R/W          | R/W        | _    | _ | _ |
| Address       |                  |             |            | D            | 6h         |      |   |   |
| Mode          |                  |             | Reg        | ister Addres | ssing Mode | only |   |   |
| Note: R = rea | ad only; R/W = r | ead/write.  |            |              |            |      |   |   |
| Bit           | Descriptio       | on          |            |              |            |      |   |   |
| [7:3]         | Register F       | Pointer 0 A | ddress Val | ue           |            |      |   |   |

#### Table 4. Register Pointer 0 (RP0; Set1)

Register pointer 0 can independently point to one of the 256-byte working register areas in the register file. Using register pointers RP0 and RP1, select two 8-byte register slices at one time as the active working register space. After a reset, RP0 points to C0h in register Set1, selecting the 8-byte working register slice C0h–C7h.

|--|

#### Table 5. Register Pointer 1 (RP1; Set1, Bank0)

| Bit           | 7                                          | 6                                              | 5                          | 4                                            | 3                                                           | 2                          | 1                             | 0            |
|---------------|--------------------------------------------|------------------------------------------------|----------------------------|----------------------------------------------|-------------------------------------------------------------|----------------------------|-------------------------------|--------------|
| Reset         | 1                                          | 1                                              | 0                          | 0                                            | 1                                                           | _                          | _                             | -            |
| R/W           | R/W                                        | R/W                                            | R/W                        | R/W                                          | R/W                                                         | _                          | _                             | _            |
| Address       |                                            |                                                |                            | D                                            | 7h                                                          |                            |                               |              |
| Mode          |                                            |                                                | Reg                        | ister Addres                                 | ssing Mode                                                  | only                       |                               |              |
| Note: R = rea | ad only; R/W = r                           | ead/write.                                     |                            |                                              |                                                             |                            |                               |              |
| Bit           | Descriptio                                 | on                                             |                            |                                              |                                                             |                            |                               |              |
| [7:3]         | Register pe<br>in the regis<br>at one time | ointer 1 car<br>ster file. Usi<br>e as the act | ng register<br>ive working | ently point to<br>pointers RF<br>register sp | o one of the<br>20 and RP1<br>ace. After a<br>egister slice | , select two<br>reset, RP1 | o 8-byte reg<br>I points to C | ister slices |
| [2:0]         | Reserved                                   |                                                |                            |                                              |                                                             |                            |                               |              |







## **Register Addressing**

The S3F8 Series register architecture provides an efficient method of working register addressing that takes full advantage of shorter instruction formats to reduce execution time.

With Register (R) Addressing Mode, in which an operand value in contained in a specific register or register pair, you can access all locations in the register file except for Set2. With working register addressing, use a register pointer to specify an 8-byte working register space in the register file and an 8-bit register within that space.

Registers are addressed either as a single 8-bit register or as a paired 16-bit register space. In a 16-bit register pair, the address of the first 8-bit register is always an even number and the address of the next register is always an odd number. The most significant byte of the 16-bit data is always stored in the even-numbered register; the least significant byte is always stored in the next (+ 1) odd-numbered register.

Working register addressing differs from register addressing because it uses a register pointer to identify a specific 8-byte working register space in the internal register file, and a specific 8-bit register within that space; see Figures 21 and 22.



Figure 21. 16-Bit Register Pair



34







## **Common Working Register Area**

After a reset, register pointers RP0 and RP1 automatically select two 8-byte register slices in Set1, locations C0h to CFh, as the active 16-byte working register block, as shown below.

- RP0  $\rightarrow$  C0h-C7h
- RP1  $\rightarrow$  C8h-CFh



35

This 16-byte address range is called the *common working area*. Essentially, locations in this area can be used as working registers by operations that address any location on any page in the register file. Typically, these working registers serve as temporary buffers for data operations. See Figure 23.



Figure 23. Common Working Register Area

#### Addressing the Common Working Register Area

As the following two examples show, you should access working registers in the common area, locations C0h to CFh, using working Register Addressing Mode only.

#### Example 1

LD 0C2h, 40h ; Invalid addressing mode!

Use working register addressing instead:

SRP #0C0h LD R2, 40h ; R2 (C2h)  $\leftarrow$  the value in location 40h

#### Example 2

ADD 0C3h, #45h ; Invalid addressing mode!

Use working register addressing instead:

SRP #0C0h
ADD R3, #45h ; R3 (C3h) ← R3 + 45h

PRELIMINARY



36

### 4-Bit Working Register Addressing

Each register pointer defines a movable 8-byte slice of working register space. The address information stored in a register pointer serves as an addressing window that makes it possible for instructions to access working registers very efficiently using short 4-bit addresses. When an instruction addresses a location in the selected working register area, the address bits are concatenated in the following way to form a complete 8-bit address:

- The high-order bit of the 4-bit address selects one of the register pointers (i.e., 0 selects RP0, 1 selects RP1)
- The five high-order bits in the register pointer select an 8-byte slice of the register space.
- The three low-order bits of the 4-bit address select one of the eight registers in the slice

As shown in Figure 24, the result of this operation is that the five high-order bits from the register pointer are concatenated with the three low-order bits from the instruction address to form the complete address. As long as the address stored in the register pointer remains unchanged, the three bits from the address will always point to an address in the same 8-byte register slice.

Figure 25 shows a typical example of 4-bit working register addressing. The high-order bit of the instruction INC-R6 is 0, which selects RP0. The five high-order bits stored in RP0 (01110b) are concatenated with the three low-order bits of the instruction's 4-bit address (110b) to produce the register address 76h (01110110b).











Figure 25. 4-Bit Working Register Addressing Example



38

## 8-Bit Working Register Addressing

Use 8-bit working register addressing to access registers in a selected working register area. To initiate 8-bit working register addressing, the upper four bits of the instruction address must contain the 4-bit value, 1100b. This value indicates that the remaining four bits have the same effect as 4-bit working register addressing.

As shown in Figure 26, the lower nibble of the 8-bit address is concatenated in much the same way as for 4-bit addressing: bit 3 selects either RP0 or RP1, which then supplies the five high-order bits of the final address. The three low-order bits of the complete address are provided by the original instruction.



Figure 26. 8-Bit Working Register Addressing

Figure 27 shows an example of 8-bit working register addressing. The four high-order bits of the instruction address (1100b) specify 8-bit working register addressing. Bit 4 (1) selects RP1, and the five high-order bits in RP1 (10101b) become the five high-order bits of the register address. The three low-order bits of the register address (011) are provided by the three low-order bits of the 8-bit instruction address. The five-address bits from RP1



DXYS Company 39

and the three address bits from the instruction are concatenated to form the complete register address, OABh (10101011b).



Figure 27. 8-Bit Working Register Addressing Example

## System and User Stack

S3F8 Series microcontrollers use the system stack for subroutine calls and returns and to store data. The PUSH and POP instructions are used to control system stack operations. The S3F8S5A architecture supports stack operations in the internal register file.

### **Stack Operations**

Return addresses for procedure calls, interrupts, and data are stored on the stack. The contents of the PC are saved to stack by a CALL instruction and restored by the RET instruction. When an interrupt occurs, the contents of the PC and the Flags registers are pushed to the stack. The IRET instruction then pops these values back to their original locations. The stack address value is always decreased by one before a push operation and increased by one after a pop operation. The stack pointer (SP) always points to the stack frame stored on the top of the stack, as shown in Figure 28.





Figure 28. Stack Operations

### **User-Defined Stacks**

Stacks in the internal register file can defined as data storage locations. The PUSHUI, PUSHUD, POPUI, and POPUD instructions support user-defined stack operations.

### **Stack Pointers**

Register locations D8h and D9h contain the 8-bit stack pointer (SPL) that is used for system stack operations. The most significant byte of the SP address, SP15–SP8, is stored in the SPH Register (D8h), and the least significant byte, SP7–SP0, is stored in the SPL Register (D9h). After a reset, the SP value is undetermined.

Because only internal memory space is implemented in the S3F8S5A MCU, the SPL must be initialized to an 8-bit value in the range 00h-FFh. The SPH Register is not required and can be used as a general-purpose register, if necessary.

When the SPL Register contains the only stack pointer value (i.e., when it points to a system stack in the register file), you can use the SPH Register as a general-purpose data register. However, if an overflow or underflow condition occurs as a result of increasing or decreasing the stack address value in the SPL Register during normal stack operations, the value in the SPL Register will overflow (or underflow) to the SPH Register, thereby overwriting any other data that is currently stored there. To avoid overwriting data in the SPH Register, initialize the SPL value to FFh instead of 00h.



The contents of the Stack Pointer High Byte (SPH) and Stack Pointer Low Byte (SPL) registers are described in Tables 6 and 7.

#### Table 6. Stack Pointer High Byte Register (SPH; Set1)

| Reset   | х                             |   |   |    | • | - | 1 | 0 |
|---------|-------------------------------|---|---|----|---|---|---|---|
|         | ^                             | х | х | х  | х | х | Х | Х |
| R/W     |                               |   |   | R/ | W |   |   |   |
| Address | D8h                           |   |   |    |   |   |   |   |
| Mode    | Register Addressing Mode only |   |   |    |   |   |   |   |

| Bit   | Description                                                                                                                                                                                                                        |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0] | Stack Pointer Address High Byte                                                                                                                                                                                                    |
|       | The high-byte stack pointer value is the upper eight bits of the 16-bit stack pointer address (SP15–SP8). The lower byte of the stack pointer value is located in register SPL (D9H). The SP value is undefined following a reset. |

#### Table 7. Stack Pointer Low Byte Register (SPL; Set1)

| Bit     | 7                             | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---------|-------------------------------|---|---|---|---|---|---|---|
| Reset   | х                             | Х | Х | Х | Х | Х | Х | Х |
| R/W     | R/W                           |   |   |   |   |   |   |   |
| Address | D9h                           |   |   |   |   |   |   |   |
| Mode    | Register Addressing Mode only |   |   |   |   |   |   |   |

| Bit   | Description                                                                                                                                                                                                                                                              |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0] | Stack Pointer Address Low Byte<br>The low-byte stack pointer value is the lower eight bits of the 16-bit stack pointer address<br>(SP7–SP0). The upper byte of the stack pointer value is located in register SPH (D8H).<br>The SP value is undefined following a reset. |

The following example shows how to perform stack operations in the internal register file using the PUSH and POP instructions.

#### Standard Stack Operations Using PUSH and POP

LD SPL, #0FFh; SPL  $\leftarrow$  FFh; (Normally, the SPL is set to ; 0FFh by the initialization





| •    |     | ; routine)                            |
|------|-----|---------------------------------------|
| •    |     |                                       |
| PUSH | PP  | ; Stack address OFEh $\leftarrow$ PP  |
| PUSH | RP0 | ; Stack address OFDh $\leftarrow$ RPO |
| PUSH | RP1 | ; Stack address OFCh $\leftarrow$ RP1 |
| PUSH | R3  | ; Stack address OFBh $\leftarrow$ R3  |
| •    |     |                                       |
| •    |     |                                       |
| POP  | R3  | ; R3 ← Stack address OFBh             |
| POP  | RP1 | ; RP1 $\leftarrow$ Stack address OFCh |
| POP  | RP0 | ; RPO $\leftarrow$ Stack address OFDh |
| POP  | PP  | ; PP $\leftarrow$ Stack address OFEh  |





# **Addressing Modes**

The program counter is used to fetch instructions that are stored in program memory for execution. Instructions indicate the operation to be performed and the data to be operated on. Addressing Mode is the method used to determine the location of the data operand. The operands specified in instructions may be condition codes, immediate data, or a location in the register file, program memory, or data memory.

The S3F8 Series instruction set supports the following seven explicit addressing modes; not all of these addressing modes are available for each instruction.

- Register (R)
- Indirect Register (IR)
- Indexed (X)
- Direct Address (DA)
- Indirect Address (IA)
- Relative Address (RA)
- Immediate (IM)

## **Register Addressing Mode**

In Register Addressing Mode (R), the operand is the content of a specified register or register pair; see Figure 29. Working register addressing differs from register addressing because it uses a register pointer to specify an 8-byte working register space in the register file and an 8-bit register within that space; see Figure 30.





Sample Instruction:







Figure 30. Working Register Addressing





## **Indirect Register Addressing Mode**

In Indirect Register (IR) Addressing Mode, the contents of the specified register or register pair represent the address of the operand. Depending on the instruction used, the actual address may point to a register in the register file, to program memory (ROM), or to an external memory space, if implemented; see Figures 31 through 34.

Use any 8-bit register to indirectly address another register. Any 16-bit register pair can be used to indirectly address another memory location. Remember, however, that locations C0h–FFh in Set1 cannot be accessed using Indirect Register Addressing Mode.



Sample Instruction:

RL @SHIFT ; Where SHIFT is the label of an 8-bit register address

Figure 31. Indirect Register Addressing to Register File







Figure 32. Indirect Register Addressing to Program Memory





Figure 33. Indirect Working Register Addressing to Register File







Figure 34. Indirect Working Register Addressing to Program or Data Memory

## Indexed Addressing Mode

Indexed (X) Addressing Mode adds an offset value to a base address during instruction execution to calculate the effective operand address; see Figure 35. Use Indexed Addressing Mode to access locations in the internal register file or in external memory (if implemented). You cannot, however, access locations COh–FFh in Set1 using indexed addressing.





Figure 35. Indexed Addressing to Register File

In short offset Indexed Addressing Mode, the 8-bit displacement is treated as a signed integer in the range -128 to +127. This displacement applies to external memory accesses only; see Figure 36.



50



#### Figure 36. Indexed Addressing to Program or Data Memory with Short Offset

For register file addressing, an 8-bit base address provided by the instruction is added to an 8-bit offset contained in a working register. For external memory accesses, the base address is stored in the working register pair designated in the instruction. The 8-bit or 16bit offset provided in the instruction is then added to the base address; see Figure 37.



51



Figure 37. Indexed Addressing to Program or Data Memory

The only instruction that supports Indexed Addressing Mode for the internal register file is the Load instruction (LD). The LDC and LDE instructions support Indexed Addressing Mode for internal program memory and for external data memory (if implemented).

## **Direct Address Mode**

In Direct Address (DA) Mode, the instruction provides the operand's 16-bit memory address. Jump (JP) and Call (CALL) instructions use this addressing mode to specify the 16-bit destination address that is loaded into the PC whenever a JP or CALL instruction is executed.



52

The LDC and LDE instructions can use Direct Address Mode to specify the source or destination address for Load operations to program memory (LDC) or to external data memory (LDE), if implemented. See Figures 38 and 39.



| LDC | R5, 1234H | ; | The values in the program address (1234H)       |
|-----|-----------|---|-------------------------------------------------|
|     |           |   | are loaded into register R5.                    |
| LDE | R5, 1234H | ; | Identical operation to LDC example, except that |
|     |           |   | external program memory is accessed.            |

#### Figure 38. Direct Addressing for Load Instructions



53



Sample Instructions:

| JP   | C,JOB1    | ; Where JOB1 is a 16-bit immediate address  |
|------|-----------|---------------------------------------------|
| CALL | DISPLAY ; | Where DISPLAY is a 16-bit immediate address |

Figure 39. Direct Addressing for Call and Jump Instructions

### **Indirect Address Mode**

In Indirect Address (IA) Mode, the instruction specifies an address located in the lowest 256 bytes of program memory. The selected pair of memory locations contains the actual address of the next instruction to be executed. Only the CALL instruction can use Indirect Address Mode.

Because Indirect Address Mode assumes that the operand is located in the lowest 256 bytes of program memory, only an 8-bit address is supplied in the instruction; the upper bytes of the destination address are assumed to be all zeros. See Figure 40.



54



CALL #40h ; The 16-bit value in program memory addresses 40h and 41h is the subroutine start address.

#### Figure 40. Indirect Addressing

### **Relative Address Mode**

In Relative Address (RA) Mode, a two's-complement signed displacement between -128 and +127 is specified in the instruction. This displacement value is then added to the current PC value. The result is the address of the next instruction to be executed. Before this addition occurs, the PC contains the address of the instruction immediately following the current instruction.

Several program control instructions use Relative Address Mode to perform conditional jumps. The instructions that support RA addressing are BTJRF, BTJRT, DJNZ, CPIJE, CPIJNE, and JR. See Figure 41.







Sample Instructions:

JR ULT,\$+OFFSET ; Where OFFSET is a value in the range +127 to -12

Figure 41. Relative Addressing

#### **Immediate Mode**

In Immediate (IM) Addressing Mode, the operand value used in the instruction is the value supplied in the operand field itself. The operand may be one byte or one word in length, depending on the instruction used. Immediate Addressing Mode is useful for loading constant values into registers. See Figure 42.

| Program Memory |
|----------------|
| OPERAND        |
| OPCODE         |
|                |

(The Operand value is in the instruction)

Sample Instruction:

LD R0,#0AAH

#### Figure 42. Immediate Addressing





# **Control Registers**

This chapter describes the S3F8S5A MCU's control registers. Data and counter registers are not described in this chapter; information about all registers used by a specific peripheral is presented in corresponding chapters.

Table 8 identifies the names, mnemonics, decimal and hex equivalents, and read/write settings of the Set1, Bank0 mapped registers; click to the linked page to review the contents of each. The hardware reset value for each mapped register is described in the <u>Reset and</u> <u>Power-Down</u> chapter on page 194.

| Register Name                 | Page #     | Mnemonic | Decimal | Hex | R/W |
|-------------------------------|------------|----------|---------|-----|-----|
| Basic Timer Control           | <u>230</u> | BTCON    | 211     | D3h | RW  |
| System Clock Control          | <u>190</u> | CLKCON   | 212     | D4h | RW  |
| Flags                         | <u>86</u>  | FLAGS    | 213     | D5h | RW  |
| Register Pointer 0            | <u>32</u>  | RP0      | 214     | D6h | RW  |
| Register Pointer 1            | <u>32</u>  | RP1      | 215     | D7h | RW  |
| Stack Pointer High Byte       | <u>41</u>  | SPH      | 216     | D8h | RW  |
| Stack Pointer Low Byte        | <u>41</u>  | SPL      | 217     | D9h | RW  |
| Instruction Pointer High Byte | <u>79</u>  | IPH      | 218     | DAh | RW  |
| Instruction Pointer Low Byte  | <u>80</u>  | IPL      | 219     | DBh | RW  |
| Interrupt Request             | <u>74</u>  | IRQ      | 220     | DCh | R   |
| Interrupt Mask                | <u>71</u>  | IMR      | 221     | DDh | RW  |
| System Mode                   | <u>70</u>  | SYM      | 222     | DEh | RW  |
| Register Page Pointer         | <u>25</u>  | PP       | 223     | DFh | RW  |

#### Table 8. Set1 Registers

Table 9 identifies the names, mnemonics, decimal and hex equivalents, and read/write settings of the Page 4 registers.

#### Table 9. Page 4 Registers

| Register Name              | Page #     | Mnemonic | Decimal | Hex | R/W |
|----------------------------|------------|----------|---------|-----|-----|
| Reset Source Indicating    | <u>200</u> | RESETID  | 0       | 00h | RW  |
| Timer D0 Control           | <u>251</u> | TD0CON   | 1       | 01h | RW  |
| Timer D0 Counter High Byte | _          | TD0CNTH  | 2       | 02h | R   |
| Timer D0 Counter Low Byte  | _          | TD0CNTL  | 3       | 03h | R   |
| Timer D0 Data High Byte    | -          | TD0DATAH | 4       | 04h | RW  |



#### Table 9. Page 4 Registers (Continued)

| Register Name              | Page #     | Mnemonic | Decimal | Hex | R/W |
|----------------------------|------------|----------|---------|-----|-----|
| Timer D0 Data Low Byte     | -          | TD0DATAL | 5       | 05h | RW  |
| Timer D1 Control           | <u>258</u> | TD1CON   | 10      | 0Ah | RW  |
| Timer D1 Counter High Byte | -          | TD1CNTH  | 6       | 06h | R   |
| Timer D1 Counter Low Byte  | -          | TD1CNTL  | 7       | 07h | R   |
| Timer D1 Data High Byte    | -          | TD1DATAH | 8       | 08h | RW  |
| Timer D1 Data Low Byte     | -          | TD1DATAL | 9       | 09h | RW  |

#### Table 10. Set1, Bank0 Registers

| Register Name                | Page #     | Mnemonic  | Decimal | Hex | R/W |
|------------------------------|------------|-----------|---------|-----|-----|
| A/D Converter Data High Byte | <u>282</u> | ADDATAH   | 208     | D0h | R   |
| A/D Converter Data Low Byte  | <u>282</u> | ADDATAL   | 209     | D1h | R   |
| A/D Converter Control        | <u>281</u> | ADCON     | 210     | D2h | RW  |
| Timer A Counter              | _          | TACNT     | 224     | E0h | R   |
| Timer A Data                 | _          | TADATA    | 225     | E1h | RW  |
| Timer A Control              | <u>234</u> | TACON     | 226     | E2h | RW  |
| Timer B Control              | <u>240</u> | TBCON     | 227     | E3h | RW  |
| Timer B Data High Byte       | _          | TBDATAH   | 228     | E4h | RW  |
| Timer B Data Low Byte        | -          | TBDATAL   | 229     | E5h | RW  |
| Timer B Clock Selection      | <u>241</u> | TBCLKS    | 230     | E6h | RW  |
| SIO Control                  | <u>286</u> | SIOCON    | 231     | E7h | RW  |
| SIO Data                     | _          | SIODATA   | 232     | E8h | RW  |
| SIO prescaler                | <u>287</u> | SIOPS     | 233     | E9h | RW  |
| Timer C Counter              | _          | TCCNT     | 234     | EAh | R   |
| Timer C Data                 | _          | TCDATA    | 235     | EBh | RW  |
| Timer C Control              | <u>248</u> | TCCON     | 236     | ECh | RW  |
| STOP Control                 | <u>192</u> | STPCON    | 237     | EDh | RW  |
| UART 0 Control High Byte     | <u>291</u> | UART0CONH | 238     | EEh | RW  |
| UART 0 Control Low Byte      | <u>294</u> | UART0CONL | 239     | EFh | RW  |
| UART 0 Data                  | <u>295</u> | UDATA0    | 240     | F0h | RW  |
| UART 0 Baud Rate Data        | <u>295</u> | BRDATA0   | 241     | F1h | RW  |
| UART 1 Control High Byte     | <u>308</u> | UART1CONH | 242     | F2h | RW  |
| UART 1 Control Low Byte      | <u>310</u> | UART1CONL | 243     | F3h | RW  |



Table 10. Set1, Bank0 Registers (Continued)

| Register Name                            | Page #     | Mnemonic | Decimal | Hex | R/W |
|------------------------------------------|------------|----------|---------|-----|-----|
| UART 1 Data                              | <u>311</u> | UDATA1   | 244     | F4h | RW  |
| UART 1 Baud Rate Data                    | <u>311</u> | BRDATA1  | 245     | F5h | RW  |
| Flash Memory Sector Address High<br>Byte | <u>337</u> | FMSECH   | 246     | F6h | RW  |
| Flash Memory Sector Address Low Byte     | <u>338</u> | FMSECL   | 247     | F7h | RW  |
| Flash Memory User Programming<br>Enable  | <u>336</u> | FMUSR    | 248     | F8h | RW  |
| Flash Memory Control                     | <u>335</u> | FMCON    | 249     | F9h | RW  |
| Oscillator Control                       | <u>191</u> | OSCCON   | 250     | FAh | RW  |
| Interrupt Pending                        | <u>76</u>  | INTPND   | 251     | FBh | RW  |
| Location FCH is not mapped.              |            |          |         |     |     |
| Basic Timer Counter                      | _          | BTCNT    | 253     | FDh | R   |
| Location FEH is not mapped.              |            |          |         |     |     |
| Interrupt Priority                       | <u>73</u>  | IPR      | 255     | FFh | RW  |

#### Table 11. Set1, Bank1 Registers

| Register Name                    | Page #     | Mnemonic | Decimal | Hex | R/W |
|----------------------------------|------------|----------|---------|-----|-----|
| Port 0 Control                   | <u>205</u> | P0CON    | 208     | D0h | RW  |
| Port 0 Pull-up Resistor Enable   | <u>206</u> | P0PUR    | 209     | D1h | RW  |
| Port 1 n-Channel Open-Drain Mode | <u>213</u> | PNE1     | 210     | D2h | RW  |
| Port 1 Control High Byte         | <u>208</u> | P1CONH   | 224     | E0h | RW  |
| Port 1 Control Low Byte          | <u>209</u> | P1CONL   | 225     | E1h | RW  |
| Port 1 Pull-up Resistor Enable   | <u>212</u> | P1PUR    | 226     | E2h | RW  |
| Port 1 Interrupt Control         | <u>210</u> | P1INT    | 227     | E3h | RW  |
| Port 1 Interrupt Pending         | <u>211</u> | P1PND    | 228     | E4h | RW  |
| Port 2 n-Channel Open-Drain Mode | <u>217</u> | PNE2     | 229     | E5h | RW  |
| Port 2 Control High Byte         | <u>214</u> | P2CONH   | 230     | E6h | RW  |
| Port 2 Control Low Byte          | <u>215</u> | P2CONL   | 231     | E7h | RW  |
| Port 2 Pull-up Resistor Enable   | <u>216</u> | P2PUR    | 232     | E8h | RW  |
| Port 3 n-Channel Open-Drain Mode | <u>223</u> | PNE3     | 233     | E9h | RW  |
| Port 3 Control High Byte         | <u>219</u> | P3CONH   | 234     | EAh | RW  |
| Port 3 Control (Mid Byte)        | <u>220</u> | P3CONM   | 235     | EBh | RW  |



59

| Register Name                  | Page #     | Mnemonic | Decimal | Hex | R/W |
|--------------------------------|------------|----------|---------|-----|-----|
| Port 3 Control Low Byte        | <u>221</u> | P3CONL   | 236     | ECh | RW  |
| Port 3 Pull-up Resistor Enable | <u>222</u> | P3PUR    | 237     | EDh | RW  |
| Port 4 Control High Byte       | <u>224</u> | P4CONH   | 238     | EEh | RW  |
| Port 4 Control Low Byte        | <u>225</u> | P4CONL   | 239     | EFh | RW  |
| Port 0 Data                    | -          | P0       | 240     | F0h | RW  |
| Port 1 Data                    | -          | P1       | 241     | F1h | RW  |
| Port 2 Data                    | -          | P2       | 242     | F2h | RW  |
| Port 3 Data                    | -          | P3       | 243     | F3h | RW  |
| Port 4 Data                    | -          | P4       | 244     | F4h | RW  |
| Port 4 Pull-up Resistor Enable | <u>228</u> | P4PUR    | 245     | F5h | RW  |
| Port 4 Interrupt Control       | <u>226</u> | P4INT    | 246     | F6h | RW  |
| Port 4 Interrupt Pending       | <u>227</u> | P4PND    | 247     | F7h | RW  |
| Pattern Generation Control     | <u>324</u> | PGCON    | 248     | F8h | RW  |
| Pattern Generation Data        | -          | PGDATA   | 249     | F9h | RW  |
| LCD Control                    | <u>266</u> | LCON     | 250     | FAh | RW  |
| PWM Control                    | <u>330</u> | PWMCON   | 251     | FBh | RW  |
| PWM Data High Byte             | -          | PWMDATAH | 252     | FCh | RW  |
| PWM Data Low Byte              | -          | PWMDATAL | 253     | FDh | RW  |
| Watch Timer Control            | <u>265</u> | WTCON    | 254     | FEh | RW  |
| Location FFh is not mapped.    |            |          |         |     |     |

#### Table 11. Set1, Bank1 Registers (Continued)



60

# Interrupt Structure

The S3F8 Series interrupt structure has three basic components: levels, vectors, and sources. The SAM88 RC CPU recognizes up to eight interrupt levels and supports up to 128 interrupt vectors. When a specific interrupt level has more than one vector address, the vector priorities are established in hardware. A vector address can be assigned to one or more sources.

### Levels

Interrupt levels are the main unit for interrupt priority assignment and recognition. All peripherals and I/O blocks can issue interrupt requests. In other words, peripheral and I/O operations are interrupt-driven. There are eight possible interrupt levels: IRQ0–IRQ7, also called *Level 0–Level 7*. Each interrupt level directly corresponds to an interrupt request number (IRQn). The total number of interrupt levels used in the interrupt structure varies from device to device. The S3F8S5A MCU's interrupt structure recognizes eight interrupt levels.

The interrupt level numbers 0 through 7 do not necessarily indicate the relative priority of the levels; they are simply identifiers for the interrupt levels that are recognized by the CPU. The relative priority of different interrupt levels is determined by settings in the Interrupt Priority (IPR) Register. Interrupt group and subgroup logic controlled by IPR Register settings lets you define more complex priority relationships between different levels.

### Vectors

Each interrupt level can have one or more interrupt vectors, or it may have no vector address assigned at all. The maximum number of vectors that can be supported for a given level is 128. (The actual number of vectors used for S3F8 Series devices is always much smaller.) If an interrupt level has more than one vector address, the vector priorities are set in hardware. The S3F8S5A MCU uses 22 vectors.

### Sources

A source is any peripheral that generates an interrupt. For example, a source can be an external pin or a counter overflow. Each vector can have several interrupt sources. In the S3F8S5A MCU's interrupt structure, there are 22 possible interrupt sources.



61

When a service routine starts, the respective pending bit is either cleared automatically by hardware or must be cleared manually by program software. The characteristics of the source's pending mechanism determine which method is used to clear its respective pending bit.

### **Interrupt Types**

The three components of the S3F8 Series interrupt structure described previously – levels, vectors, and sources – are combined to determine the interrupt structure of an individual device and to make full use of its available interrupt logic. There are three possible combinations of interrupt structure components, called interrupt types 1, 2, and 3. These three types differ in the number of vectors and interrupt sources assigned to each level, as follows.

- Type 1: 1 level (IRQn)+1 vector (V1)+one source (S1)
- Type 2: 1 level (IRQn)+1 vector (V1)+multiple sources (S1–Sn)
- Type 3: 1 level (IRQn)+multiple vectors (V1–Vn)+multiple sources (S1–Sn, Sn+1–Sn+m)

In the S3F8S5A microcontroller, all three interrupt types are implemented; see Figure 43.



Figure 43. S3F8 Series Interrupt Types

**Note:** In Figure 43, the number of Sn and Vn values is expandable. In the S3F8S5A implementation, interrupt types 1 and 3 are used.



#### 62

### S3F8S5A Interrupt Structure

The S3F8S5A microcontroller supports 22 interrupt sources. All 2 of the interrupt sources have a corresponding interrupt vector address. Eight interrupt levels are recognized by the CPU in this device-specific interrupt structure, as shown in Figure 44.

When multiple interrupt levels are active, the Interrupt Priority (IPR) Register determines the order in which contending interrupts are to be serviced. If multiple interrupts occur within the same interrupt level, the interrupt with the lowest vector address is usually processed first (The relative priorities of multiple interrupts within a single level are fixed in hardware).

When the CPU grants an interrupt request, interrupt processing starts: All other interrupts are disabled and the program counter value and status flags are pushed to stack. The starting address of the service routine is fetched from the appropriate vector address (plus the next 8-bit value to concatenate the full 16-bit address) and the service routine is executed.

| Levels | Vectors       | Sources                                     | Reset/Clear |
|--------|---------------|---------------------------------------------|-------------|
| nRESET | 100H          | <ul> <li>Basic Timer Overflow</li> </ul>    | H/W         |
| IRQ0 — | CEH           | <ul> <li>Timer A Match/Capture</li> </ul>   | S/W         |
|        | 1 D0Н         | <ul> <li>Timer A Overflow</li> </ul>        | H/W, S/W    |
| IRQ1   | D2H           | <ul> <li>Timer B Match</li> </ul>           | H/W         |
|        | D4H           | <ul> <li>Timer C Match/Overflow</li> </ul>  | H/W, S/W    |
| IRQ2   | └── D6H ────  | <ul> <li>10-bit PWM overflow</li> </ul>     | H/W, S/W    |
|        | D8H           | <ul> <li>Timer D0 Match/Capture</li> </ul>  | S/W         |
| IRQ3 — | DAH           | <ul> <li>Timer D0 Overflow</li> </ul>       | H/W, S/W    |
| INQU   | DCH           | <ul> <li>Timer D1 Match/Capture</li> </ul>  | S/W         |
|        | L DEH         | <ul> <li>Timer D1 Overflow</li> </ul>       | H/W, S/W    |
| IRQ4 — | E4H           | <ul> <li>SIO Interrupt</li> </ul>           | S/W         |
|        | Ъ E6H         | <ul> <li>Watch Timer Overflow</li> </ul>    | S/W         |
|        | E8H           | <ul> <li>UART 0 Data Transmit</li> </ul>    | S/W         |
| IRQ5 — | EAH           | <ul> <li>UART 0 Data Receive</li> </ul>     | S/W         |
|        | ECH           | <ul> <li>UART 1 Data Transmit</li> </ul>    | S/W         |
|        | L EEH         | <ul> <li>UART 1 Data Receive</li> </ul>     | S/W         |
|        | F0H           | <ul> <li>P1.0 External Interrupt</li> </ul> | S/W         |
| IRQ6 — | — F2H —       | <ul> <li>P1.1 External Interrupt</li> </ul> | S/W         |
|        | F4H           | <ul> <li>P1.2 External Interrupt</li> </ul> | S/W         |
|        | └─── F6H ──── | <ul> <li>P1.3 External Interrupt</li> </ul> | S/W         |
|        | F8H           | <ul> <li>P4.0 External Interrupt</li> </ul> | S/W         |
| IRQ7 — | FAH           | <ul> <li>P4.1 External Interrupt</li> </ul> | S/W         |
|        | —— FCH ———    | <ul> <li>P4.2 External Interrupt</li> </ul> | S/W         |
|        | └── FEH ───   | <ul> <li>P4.3 External Interrupt</li> </ul> | S/W         |
|        |               |                                             |             |

Figure 44. S3F8S5A Interrupt Structure





- **Notes:** 1. In Figure 44, within a given interrupt level, the low vector address has high priority. For example, within the IRQ0 level, CEh has higher priority than D0h. Priorities within each level are set at the factory.
  - 2. External interrupts are triggered by a rising or falling edge, depending on the corresponding control register setting.

### **Interrupt Vector Addresses**

All interrupt vector addresses for the S3F8S5A interrupt structure are stored in the vector address area of the internal 48KB ROM, 0h-BFFFh; see Figure 45.



Figure 45. ROM Vector Address Area



Allocate unused locations in the vector address area as normal program memory. However, be careful not to overwrite any of the stored vector addresses, which are listed in Table 12.

| Vector Address   |              |                         | Req                | luest                | Reset/Clear  |              |
|------------------|--------------|-------------------------|--------------------|----------------------|--------------|--------------|
| Decimal<br>Value | Hex<br>Value | <br>Interrupt Source    | Interrupt<br>Level | Priority in<br>Level | Hardware     | Software     |
| 256              | 100h         | Basic Timer overflow    | RESET              | _                    |              |              |
| 206              | CEh          | Timer A match/capture   | IRQ0               | 0                    | $\checkmark$ | $\checkmark$ |
| 208              | D0h          | Timer A overflow        | _                  | 1                    | $\checkmark$ | $\checkmark$ |
| 210              | D2h          | Timer B match           | IRQ1               | _                    | $\checkmark$ |              |
| 212              | D4h          | Timer C match/overflow  | IRQ2               | 0                    | $\checkmark$ | $\checkmark$ |
| 214              | D6h          | 10-bit PWM overflow     | _                  | 1                    | $\checkmark$ | $\checkmark$ |
| 216              | D8h          | Timer D0 match/capture  | IRQ3               | 0                    | $\checkmark$ | $\checkmark$ |
| 218              | DAh          | Timer D0 overflow       | _                  | 1                    |              | $\checkmark$ |
| 220              | DCh          | Timer D1 match/capture  | _                  | 2                    |              | $\checkmark$ |
| 222              | DEh          | Timer D1 overflow       | -                  | 3                    |              | $\checkmark$ |
| 228              | E4h          | SIO interrupt           | IRQ4               | 0                    | _            | $\checkmark$ |
| 230              | E6h          | Watch timer overflow    | _                  | 1                    | _            | $\checkmark$ |
| 232              | E8h          | UART 0 data transmit    | IRQ5               | 0                    | _            | $\checkmark$ |
| 234              | EAh          | UART 0 data receive     | -                  | 1                    | _            | $\checkmark$ |
| 236              | ECh          | UART 1 data transmit    | _                  | 2                    | _            | $\checkmark$ |
| 238              | EEh          | UART 1 data receive     | _                  | 3                    | _            | $\checkmark$ |
| 240              | F0h          | P1.0 external interrupt | IRQ6               | 0                    | _            | $\checkmark$ |
| 242              | F2h          | P1.1 external interrupt | _                  | 1                    | _            | $\checkmark$ |
| 244              | F4h          | P1.2 external interrupt | _                  | 2                    | _            | $\checkmark$ |
| 246              | F6h          | P1.3 external interrupt | -                  | 3                    | _            | $\checkmark$ |
| 248              | F8h          | P4.0 external interrupt | IRQ7               | 0                    | _            | $\checkmark$ |
| 250              | FAh          | P4.1 external interrupt | _                  | 1                    | _            |              |
| 252              | FCh          | P4.2 external interrupt | _                  | 2                    | _            | $\checkmark$ |
| 254              | FEh          | P4.3 external interrupt | _                  | 3                    | _            |              |

#### Table 12. S3F8S5A Interrupt Vectors

Note: Interrupt priorities are identified in inverse order: 0 is the highest priority, 1 is the next highest priority, etc. If two or more interrupts within the same level contend, the interrupt with the lowest vector address usually has priority over an interrupt with a higher vector address. Priorities within a given level are fixed in hardware.





### **Enable/Disable Interrupt Instructions**

Executing the Enable Interrupt (EI) instruction globally enables the interrupt structure. All interrupts are then serviced as they occur, and according to the established priorities.

| • | Note: | The system initialization routine that is executed following a reset must always contain an |
|---|-------|---------------------------------------------------------------------------------------------|
|   |       | EI instruction to globally enable the interrupt structure.                                  |

During normal operation, the Disable Interrupt (DI) instruction can be executed at any time to globally disable interrupt processing. The EI and DI instructions change the value of bit 0 in the SYM Register.

### **System-Level Interrupt Control Registers**

In addition to the control registers for specific interrupt sources, the following four system-level registers control interrupt processing.

- The Interrupt Mask (IMR) Register enables (unmasks) or disables (masks) interrupt levels
- The Interrupt Priority (IPR) Register controls the relative priorities of interrupt levels
- The Interrupt Request (IRQ) Register contains interrupt pending flags for each interrupt level (as opposed to each interrupt source)
- The System Mode (SYM) Register enables or disables global interrupt processing (SYM settings also enable fast interrupts and control the activity of external interface, if implemented)

A summary of these interrupt control registers is provided in Table 13.

| Control<br>Register                                                                                                  | Mnemonic | R/W | Function Description                                                                                                                                                                                                                                     |  |  |
|----------------------------------------------------------------------------------------------------------------------|----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Interrupt Mask<br>Register                                                                                           | IMR      | R/W | Bit settings in the IMR Register enable or disable interrupt processing for each of the eight interrupt levels: IRQ0–IRQ7.                                                                                                                               |  |  |
| Interrupt<br>Priority<br>Register                                                                                    | IPR      | R/W | Controls the relative processing priorities of the interrupt levels.<br>The eight levels of the S3F8S5A MCU are organized into three<br>groups: A, B and C. Group A is IRQ0 and IRQ1, group B is<br>IRQ2, IRQ3, IRQ4 and group C is IRQ5, IRQ6 and IRQ7. |  |  |
| Note: Before an IMR Register value is changed, all interrupts must be disabled; Zilog recommends the DI instruction. |          |     |                                                                                                                                                                                                                                                          |  |  |

#### Table 13. Interrupt Control Register Overview



#### Table 13. Interrupt Control Register Overview (Continued)

| Control<br>Register              | Mnemonic | R/W | Function Description                                                                                                                                                                                         |
|----------------------------------|----------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Interrupt<br>Request<br>Register | IRQ      | R   | This register contains a request pending bit for each interrupt level.                                                                                                                                       |
| System Mode<br>Register          | SYM      | R/W | A dynamic global interrupt processing enables/disables, fast<br>interrupt processing, and external interface control (an external<br>memory interface is not implemented in the S3F8S5A<br>microcontroller). |

## **Interrupt Processing Control Points**

Interrupt processing can be controlled in either of two ways: either globally or by a specific interrupt level and source. The system-level control points in the interrupt structure are:

- Global interrupt enable and disable by EI and DI instructions or by a direct manipulation of SYM.0
- Interrupt-level enable/disable settings (IMR Register)
- Interrupt-level priority settings (IPR Register)
- Interrupt source enable/disable settings in the corresponding peripheral control registers

Figure 46 diagrams the functions of these combined interrupt processes.







**Note:** When writing the part of your application that handles the processing of interrupts, be sure to include the necessary register file address (register pointer) information.



68

### **Peripheral Interrupt Control Registers**

For each interrupt source there is one or more corresponding peripheral control registers that let you control the interrupt generated by that peripheral; see Table 14.

| Interrupt Level Register(s) Location(s) in Set1                                                                    |
|--------------------------------------------------------------------------------------------------------------------|
| ure IRQ0 TACON E2h, Bank0                                                                                          |
| TACNT E0h, Bank0                                                                                                   |
| TADATA E1h, Bank0                                                                                                  |
| IRQ1 TBCON E3h, Bank0                                                                                              |
| TBCLKS E6h, Bank0                                                                                                  |
| TBDATAH E4h, Bank0                                                                                                 |
| TBDATAL E5h, Bank0                                                                                                 |
| flow IRQ2 TCCON ECh, Bank0                                                                                         |
| v TCCNT EAh, Bank0                                                                                                 |
| TCDATA EBh, Bank0                                                                                                  |
| PWMCON FBh, Bank1                                                                                                  |
| PWMDATAH FCh, Bank1                                                                                                |
| PWMDATAL FDh, Bank1                                                                                                |
| ture IRQ3 TD0CON 01h, Page 4                                                                                       |
| TD0CNTH 02h, Page 4                                                                                                |
| ture TD0CNTL 03h, Page 4                                                                                           |
| TD0DATAH 04h, Page 4                                                                                               |
| TD0DATAL 05h, Page 4                                                                                               |
| TD1CON 0Ah, Page 4                                                                                                 |
| TD1CNTH 06h, Page 4                                                                                                |
| TD1CNTL 07h, Page 4                                                                                                |
| TD1DATAH 08h, Page 4                                                                                               |
| TD1DATAL 09h, Page 4                                                                                               |
| IRQ4 SIOCON E7h, Bank0                                                                                             |
| N SIODATA E8h, Bank0                                                                                               |
| SIOPS E9h, Bank0                                                                                                   |
| WTCON FEh, Bank1                                                                                                   |
| hit IRQ5 UART0CONH EEh, Bank0                                                                                      |
| e UART0CONL EFh, Bank0                                                                                             |
| hit UDATA0, BRDATA0 F0h, F1h, Bank0                                                                                |
| e UART1CONH F2h, Bank0                                                                                             |
| UART1CONL F3h, Bank0                                                                                               |
| UDATA1, BRDATA1 F4h, F5h, Bank0                                                                                    |
| UDATA1, BRI<br>is unmasked (i.e., at an enable interrupt level<br>e interrupt should be written after a DI instruc |

#### Table 14. Vectored Interrupt Source Control and Data Registers\*



| Interrupt Source                                   | Interrupt Level | Register(s) | Location(s) in Set1 |
|----------------------------------------------------|-----------------|-------------|---------------------|
| P1.0 external interrupt                            | IRQ6            | P1CONL      | E1h, Bank1          |
| P1.1 external interrupt                            |                 | P1INT       | E3h, Bank1          |
| P1.2 external interrupt<br>P1.3 external interrupt |                 | P1PND       | E4h, Bank1          |
| P4.0 external interrupt                            | IRQ7            | P4CONL      | EFh, Bank1          |
| P4.1 external interrupt                            |                 | P4INT       | F6h, Bank1          |
| P4.2 external interrupt                            |                 | P4PND       | F7h, Bank1          |
| P4.3 external interrupt                            |                 |             |                     |

Note: \*If an interrupt is unmasked (i.e., at an enable interrupt level) in the IMR Register, the pending bit and enable bit of the interrupt should be written after a DI instruction is executed.

### System Mode Register

The System Mode (SYM) Register (DEh, Set1; see Table 15) is used to globally enable and disable interrupt processing and to control fast interrupt processing.

A reset clears SYM.1 and SYM.0 to 0. The 3-bit value, SYM.4–SYM.2, is for fast interrupt level selection and undetermined values after reset.

The instructions EI and DI enable and disable global interrupt processing, respectively, by modifying the bit 0 value of the SYM Register. An Enable Interrupt (EI) instruction must be included in the initialization routine, which follows a reset operation to enable interrupt processing. Although you can manipulate SYM.0 directly to enable and disable interrupts during normal operation, Zilog recommends using the EI and DI instructions for this purpose.

**Notes:** 1. For fast interrupt processing, select only one interrupt level at a time.

- 2. Setting SYM.1 to 1 enables fast interrupt processing for the interrupt level currently selected by SYM.2–SYM.4.
- 3. Following a reset, enable global interrupt processing by executing an EI instruction instead of writing a 1 to SYM.0).





#### Table 15. System Mode Register (SYM; Set1)

| Bit         | 7   | 6 | 5   | 4            | 3          | 2    | 1   | 0   |
|-------------|-----|---|-----|--------------|------------|------|-----|-----|
| Reset       | 0   | _ | -   | х            | х          | х    | 0   | 0   |
| R/W         | R/W | _ | _   | R/W          | R/W        | R/W  | R/W | R/W |
| Address DEh |     |   |     |              |            |      |     |     |
| Mode        |     |   | Reg | jister Addre | ssing Mode | only |     |     |

Note: R = read only; R/W = read/write.

| Bit   | Description                                      |
|-------|--------------------------------------------------|
| [7]   | Reserved                                         |
| [6:5] | Reserved                                         |
| [4:2] | Fast Interrupt Level Selection Bits <sup>1</sup> |
|       | 000: IRQ0.                                       |
|       | 001: IRQ1.                                       |
|       | 010: IRQ2.                                       |
|       | 011: IRQ3.                                       |
|       | 100: IRQ4.                                       |
|       | 101: IRQ5.                                       |
|       | 110: IRQ6.                                       |
|       | 111: IRQ7.                                       |
| [1]   | Fast Interrupt Enable Bit <sup>2</sup>           |
|       | 0: Disable fast interrupt processing.            |
|       | 1: Enable fast interrupt processing.             |
| [0]   | Global Interrupt Enable Bit <sup>3</sup>         |
|       | 0: Disable global interrupt processing.          |
|       | 1: Enable global interrupt processing.           |

1. You can select only one interrupt level at a time for fast interrupt processing.

2. Setting SYM.1 to 1 enables fast interrupt processing for the interrupt level currently selected by SYM.2–SYM.4.

3. Following a reset, you must enable global interrupt processing by executing an EI instruction (not by writing a 1 to SYM.0).

### **Interrupt Mask Register**

The Interrupt Mask (IMR) Register (DDh, Set1; see Table 16) is used to enable or disable interrupt processing for individual interrupt levels. After a reset, all IMR bit values are undetermined and must therefore be written to their required settings by the initialization routine. Before changing values in the IMR Register, first disable all interrupts with the DI instruction.





#### Table 16. Interrupt Mask Register (IMR; Set1)

| Bit         | 7   | 6     | 5   | 4            | 3          | 2    | 1 | 0 |
|-------------|-----|-------|-----|--------------|------------|------|---|---|
| Reset       | х   | х     | х   | х            | х          | х    | х | х |
| R/W         | R/W |       |     |              |            |      |   |   |
| Address     | DDh |       |     |              |            |      |   |   |
| Mode        |     |       | Reg | ister Addres | ssing Mode | only |   |   |
| Nata D. and |     | 1/ 1/ |     |              |            |      |   |   |

Note: R = read only; R/W = read/write.

| Bit   | Description                                                                                                                                |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------|
| [7]   | Interrupt Level 7 (IRQ7) Enable Bit; External Interrupts P4.0–P4.3<br>0: Disable (Mask).<br>1: Enable (Unmask).                            |
| [6]   | Interrupt Level 6 (IRQ6) Enable Bit; External Interrupts P1.0–P1.3<br>0: Disable (Mask).<br>1: Enable (Unmask).                            |
| [5]   | Interrupt Level 5 (IRQ5) Enable Bit; UART0/1 Transmit, UART0/1 Receive<br>0: Disable (Mask).<br>1: Enable (Unmask).                        |
| [4]   | Interrupt Level 4 (IRQ4) Enable Bit; Watch Timer, SIO<br>0: Disable (Mask).<br>1: Enable (Unmask).                                         |
| [3]   | Interrupt Level 3 (IRQ3) Enable Bit; Timer D0/1 Match/Capture or Overflow<br>0: Disable (Mask).<br>1: Enable (Unmask).                     |
| [2]   | Interrupt Level 2 (IRQ2) Enable Bit; Timer C Match/Overflow, 10-bit PWM Overflow<br>Interrupt<br>0: Disable (Mask).<br>1: Enable (Unmask). |
| [1]   | Interrupt Level 1 (IRQ1) Enable Bit; Timer B Match<br>0: Disable (Mask).<br>1: Enable (Unmask).                                            |
| [0]   | Interrupt Level 0 (IRQ0) Enable Bit; Timer A Match/Capture or Overflow<br>0: Disable (Mask).<br>1: Enable (Unmask).                        |
| Note: | When an interrupt level is masked, any interrupt requests that may be issued are not recognized by the CPU.                                |

Each IMR bit corresponds to a specific interrupt level: bit 1 to IRQ1, bit 2 to IRQ2, etc. When the IMR bit of an interrupt level is cleared to 0, interrupt processing for that level is disabled (masked). When setting a level's IMR bit to 1, interrupt processing for the level is enabled (not masked).



DXYS Company

72

The IMR Register is mapped to register location DDh in Set1and Bank0. Bit values can be read and written by instructions using the Register Addressing Mode.

**Note:** Before the IMR Register is changed to any value, all interrupts must be disabled; Zilog recommends using the DI instruction.

### **Interrupt Priority Register**

The interrupt priority register, IPR (FFh, Set1, Bank0; see Table 17), is used to set the relative priorities of the interrupt levels used in the microcontroller's interrupt structure. After a reset, all IPR bit values are undetermined and must therefore be written to their required settings by the initialization routine.

When more than one interrupt source is active, the source with the highest priority level is serviced first. If two sources belong to the same interrupt level, the source with the lower vector address usually has priority; this priority is fixed in hardware.

To support programming of the relative interrupt level priorities, interrupts are organized into groups and subgroups by the interrupt logic. These groups and subgroups are used only by IPR logic for the IPR Register priority definitions, as listed below and shown in Figure 47.

- Group A: IRQ0, IRQ1
- Group B: IRQ2, IRQ3, IRQ4
- Group C: IRQ5, IRQ6, IRQ7



Figure 47. Interrupt Request Priority Groups



Embedded in Life 73

#### Table 17. Interrupt Priority Register (IPR; Set1, Bank0)

| Bit         | 7   | 6   | 5   | 4            | 3          | 2    | 1 | 0 |  |
|-------------|-----|-----|-----|--------------|------------|------|---|---|--|
| Reset       | х   | х   | х   | х            | х          | х    | х | х |  |
| R/W         | R/W |     |     |              |            |      |   |   |  |
| Address     | FFh |     |     |              |            |      |   |   |  |
| Mode        |     |     | Reg | ister Addres | ssing Mode | only |   |   |  |
| Nata D. and |     | 1 / |     |              |            |      |   |   |  |

Note: R = read only; R/W = read/write.

| Bit          | Description                                                                                                                                                                                                                                     |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7, 4, 1]    | Priority Control Bits for Interrupt Groups A, B, and C000: Group priority undefined001: $B > C > A$ .010: $A > B > C$ .011: $B > A > C$ .100: $C > A > B$ .101: $C > B > A$ .110: $A > C > B$ .111: $A > C > B$ .111: Group priority undefined. |
| [6]          | Interrupt Subgroup C Priority Control Bit<br>0: IRQ6 > IRQ7.<br>1: IRQ7 > IRQ6.                                                                                                                                                                 |
| [5]          | Interrupt Group C Priority Control Bit<br>0: IRQ5 > (IRQ6, IRQ7).<br>1: (IRQ6, IRQ7) > IRQ5.                                                                                                                                                    |
| [3]          | Interrupt Subgroup B Priority Control Bit*<br>0: IRQ3 > IRQ4.<br>1: IRQ4 > IRQ3.                                                                                                                                                                |
| [2]          | Interrupt Group B Priority Control Bit*<br>0: IRQ2 > (IRQ3, IRQ4).<br>1: (IRQ3, IRQ4) > IRQ2.                                                                                                                                                   |
| [0]          | Interrupt Group A Priority Control Bit<br>0: IRQ0 > IRQ1.<br>1: IRQ1 > IRQ0.                                                                                                                                                                    |
| Note: Interr | upt group A: IRQ0, IRQ1. Interrupt group B: IRQ2, IRQ3, IRQ4. Interrupt group C: IRQ5, IRQ6, IRQ7.                                                                                                                                              |

In the Interrupt Priority Register, IPR.7, IPR.4, and IPR.1 control the relative priority of interrupt groups A, B, and C. For example, a setting of 001b for these bits would select the group relationship B > C > A; a setting of 101b would select the relationship C > B > A.

The functions of the other IPR bit settings are:



- IPR.5 controls the relative priorities of group C interrupts.
- Interrupt Group C includes a subgroup to provide an additional priority relationship among the interrupt levels 5, 6, and 7. IPR.6 defines the Subgroup C relationship, and IPR.5 controls interrupt Group C.
- IPR.0 controls the relative priority setting of IRQ0 and IRQ1 interrupts.

### **Interrupt Request Register**

Bit values in the Interrupt Request (IRQ) Register (DCh, Set1; see Table 18) can be polled to monitor interrupt request status for all levels in the microcontroller's interrupt structure. Each bit corresponds to the interrupt level of the same number: bit 0 to IRQ0, bit 1 to IRQ1, etc. A 0 indicates that no interrupt request is currently being issued for that level; a 1 indicates that an interrupt request has been generated for that level.

IRQ bit values are read only-addressable using Register Addressing Mode. The contents of the IRQ Register can be read (tested) at any time using bit or byte addressing to determine the current interrupt request status of specific interrupt levels. After a reset, all IRQ status bits are cleared to 0.

IRQ Register values can be polled even if a DI instruction has been executed (i.e., if global interrupt processing is disabled). If an interrupt occurs while the interrupt structure is disabled, the CPU will not service it. You can, however, still detect the interrupt request by polling the IRQ Register. In this way, you can determine which events occurred while the interrupt structure is globally disabled.

| Bit            | 7               | 6         | 5   | 4           | 3          | 2    | 1 | 0 |
|----------------|-----------------|-----------|-----|-------------|------------|------|---|---|
| Reset          | 0               | 0         | 0   | 0           | 0          | 0    | 0 | 0 |
| R/W            |                 |           |     | l           | २          |      |   |   |
| Address        |                 |           |     | D           | Ch         |      |   |   |
| Mode           |                 |           | Reg | ister Addre | ssing Mode | only |   |   |
| Note: R - read | only: $P/M - r$ | ood/write |     |             |            |      |   |   |

Table 18. Interrupt Request Register (IPQ; Set1)

Note: R = read only; R/W = read/write.

| Bit | Description                                                                                         |
|-----|-----------------------------------------------------------------------------------------------------|
| [7] | Level 7 (IRQ7) Request Pending Bit; External Interrupts P4.0–P4.3<br>0: Not pending.<br>1: Pending. |
| [6] | Level 6 (IRQ6) Request Pending Bit; External Interrupts P1.0–P1.3<br>0: Not pending.<br>1: Pending. |



75

| Bit | Description (Continued)                                                                                                        |
|-----|--------------------------------------------------------------------------------------------------------------------------------|
| [5] | Level 5 (IRQ5) Request Pending Bit; UART0/1 Transmit, UART0/1 Receive<br>0: Not pending.<br>1: Pending.                        |
| [4] | Level 4 (IRQ4) Request Pending Bit; Watch Timer, SIO<br>0: Not pending.<br>1: Pending.                                         |
| [3] | Level 3 (IRQ3) Request Pending Bit; Timer D0/1 Match/Capture or Overflow<br>0: Not pending.<br>1: Pending.                     |
| [2] | Level 2 (IRQ2) Request Pending Bit; Timer C Match/Overflow, 10-bit PWM Overflow<br>Interrupt<br>0: Not pending.<br>1: Pending. |
| [1] | Level 1 (IRQ1) Request Pending Bit; Timer B Match<br>0: Not pending.<br>1: Pending.                                            |
| [0] | Level 0 (IRQ0) Request Pending Bit; Timer A Match/Capture or Overflow<br>0: Not pending.<br>1: Pending.                        |

### **Interrupt Pending Function Types**

There are two types of interrupt pending bits: One type is automatically cleared by hardware after the interrupt service routine is acknowledged and executed; the other type must be cleared by the interrupt service routine.

### Pending Bits Cleared Automatically by Hardware

For interrupt pending bits that are cleared automatically by hardware, interrupt logic sets the corresponding pending bit to 1 when a request occurs. It then issues an IRQ pulse to inform the CPU that an interrupt is waiting to be serviced. The CPU acknowledges the interrupt source by sending an IACK, executes the service routine, and clears the pending bit to 0. This type of pending bit is not mapped and cannot, therefore, be read or written by application software.

In the S3F8S5A MCU's interrupt structure, the Timer A overflow interrupt (IRQ0), the Timer B match interrupt (IRQ1), the Timer C overflow interrupt (IRQ2), and the Timer D0/D1 overflow interrupt (IRQ3) belong to this category of interrupts in which a pending condition is cleared automatically by hardware.



### Pending Bits Cleared by the Service Routine

The second type of pending bit must be cleared by program software. The service routine must clear the appropriate pending bit before a return-from-interrupt subroutine (IRET) occurs; i.e., a 0 must be written to the corresponding pending bit location in the source's mode or control register.

In the following examples, a load instruction should be used to clear an interrupt pending bit.

#### Example 1

The contents of the Interrupt Pending (INTPND) Register are described in Table 19. Before changing values in the IMR Register, first disable all interrupts with the DI instruction.

| Bit            | 7               | 6          | 5   | 4            | 3          | 2    | 1 | 0 |
|----------------|-----------------|------------|-----|--------------|------------|------|---|---|
| Reset          | 0               | _          | 0   | 0            | 0          | 0    | 0 | 0 |
| R/W            |                 |            |     | R            | /W         |      |   |   |
| Address        |                 |            |     | D            | Dh         |      |   |   |
| Mode           |                 |            | Reg | ister Addres | ssing Mode | only |   |   |
| Note: R = read | d only; R/W = r | ead/write. |     |              |            |      |   |   |
| D:4            | Descriptio      |            |     |              |            |      |   |   |

#### Table 19. Interrupt Pending Register (INTPND; Set1, Bank0)

| Bit | Description                                                                                                                                       |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------------|
| [7] | Watch Timer Interrupt Pending Bit<br>0: No interrupt pending (when read), clear pending bit (when write).<br>1: Interrupt is pending (when read). |
| [6] | Reserved.                                                                                                                                         |



| Bit | Description (Continued)                                                                                                                                             |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [5] | <b>Timer D1 Match/Capture Interrupt Pending Bit</b><br>0: No interrupt pending (when read), clear pending bit (when write).<br>1: Interrupt is pending (when read). |
| [4] | <b>Timer D1 Overflow Interrupt Pending Bit</b><br>0: No interrupt pending (when read), clear pending bit (when write).<br>1: Interrupt is pending (when read).      |
| [3] | <b>Timer D0 Match/Capture Interrupt Pending Bit</b><br>0: No interrupt pending (when read), clear pending bit (when write).<br>1: Interrupt is pending (when read). |
| [2] | <b>Timer D0 Overflow Interrupt Pending Bit</b><br>0: No interrupt pending (when read), clear pending bit (when write).<br>1: Interrupt is pending (when read).      |
| [1] | <b>Timer A Match/Capture Interrupt Pending Bit</b><br>0: No interrupt pending (when read), clear pending bit (when write).<br>1: Interrupt is pending (when read).  |
| [0] | <b>Timer A Overflow Interrupt Pending Bit</b><br>0: No interrupt pending (when read), clear pending bit (when write).<br>1: Interrupt is pending (when read).       |

### **Interrupt Source Polling Sequence**

Interrupt request polling and servicing occurs via the following sequence:

- 1. A source generates an interrupt request by setting the interrupt request bit to 1.
- 2. The CPU polling procedure identifies a pending condition for that source.
- 3. The CPU checks the interrupt level of the source.
- 4. The CPU generates an interrupt acknowledge signal.
- 5. Interrupt logic determines the interrupt's vector address.
- 6. The service routine starts and the source's pending bit is cleared to 0 (by hardware or by software).
- 7. The CPU continues polling for interrupt requests.

### **Interrupt Service Routines**

Before an interrupt request can be serviced, the following conditions must be met:

- Interrupt processing must be globally enabled (i.e., EI, SYM.0 = 1)
- The interrupt level must be enabled (IMR Register)





- The interrupt level must have the highest priority if more than one level is currently requesting service
- The interrupt must be enabled at the interrupt's source (i.e., the Peripheral Control Register)

When all of the above conditions are met, the interrupt request is acknowledged at the end of the instruction cycle. The CPU then initiates an interrupt machine cycle that completes the following processing sequence:

- 1. Reset (clear to 0) the interrupt enable bit in the SYM Register (SYM.0) to disable all subsequent interrupts.
- 2. Save the program counter (PC) and status flags to the system stack.
- 3. Branch to the interrupt vector to fetch the address of the service routine.
- 4. Pass control to the interrupt service routine.

When the interrupt service routine is completed, the CPU issues an Interrupt Return (IRET). This IRET restores the PC and status flags and sets SYM.0 to 1, allowing the CPU to process the next interrupt request.

### **Generating Interrupt Vector Addresses**

The interrupt vector area in ROM (00h-FFh) contains the addresses of interrupt service routines that correspond to each level in the interrupt structure. Vectored interrupt processing observes the following sequence:

- 1. Push the program counter's low-byte value to the stack.
- 2. Push the program counter's high-byte value to the stack.
- 3. Push the Flags Register values to the stack.
- 4. Fetch the service routine's high-byte address from the vector location.
- 5. Fetch the service routine's low-byte address from the vector location.
- 6. Branch to the service routine specified by the concatenated 16-bit vector address.

**Note:** A 16-bit vector address always begins at an even-numbered ROM address within the range 00h–FFh.



79

### **Nesting of Vectored Interrupts**

It is possible to nest a higher-priority interrupt request while a lower-priority request is being serviced, as shown in the following sequence.

- 1. Push the current 8-bit Interrupt Mask (IMR) Register value to the stack (PUSH IMR).
- 2. Load the IMR Register with a new mask value that enables only the higher-priority interrupt.
- 3. Execute an EI instruction to enable interrupt processing (a higher-priority interrupt will be processed if it occurs).
- 4. When the lower-priority interrupt service routine ends, restore the IMR to its original value by returning the previous mask value from the stack (POP IMR).
- 5. Execute an IRET.

Depending on the application, the above procedure can be simplified to some extent.

### **Instruction Pointer**

The Instruction Pointer (IP) is used by all S3F8 Series microcontrollers to control the optional high-speed interrupt processing feature called *fast interrupts*. The IP consists of register pair DAh and DBh. The IP Register names are IPH (high byte, IP15–IP8) and IPL (low byte, IP7–IP0).

The contents of the Instruction Pointer High Byte (IPH) and Instruction Pointer Low Byte (IPL) registers are described in Tables 20 and 21.

| Bit     | 7   | 6 | 5   | 4            | 3         | 2    | 1 | 0 |
|---------|-----|---|-----|--------------|-----------|------|---|---|
| Reset   | Х   | Х | х   | Х            | х         | х    | х | х |
| R/W     |     |   |     | R/           | W         |      |   |   |
| Address | DAh |   |     |              |           |      |   |   |
| Mode    |     |   | Reg | ister Addres | sing Mode | only |   |   |

| Table | 20          | Instruction | Pointer   | High   | <b>B</b> vte | Register | (IPH · Set1   | ١ |
|-------|-------------|-------------|-----------|--------|--------------|----------|---------------|---|
| Table | <b>ZU</b> . | manuchon    | I OIIIICI | ringii | Dyte         | Negister | (11 11, Set 1 | , |

| Bit   | Description                                                                                                                                                                                                                                   |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0] | Instruction Pointer Address (High Byte)<br>The high-byte instruction pointer value is the upper eight bits of the 16-bit instruction<br>pointer address (IP15–IP8). The lower byte of the IP address is located in the IPL<br>Register (DBh). |



klod In Life

DXYS Company

#### Bit 7 6 5 4 3 2 1 0 Reset х х х х х х х х R/W R/W Address DBh Mode Register Addressing Mode only Note: R = read only; R/W = read/write.

#### Table 21. Instruction Pointer Low Byte Register (IPL; Set1)

| Bit   | Description                                                                                                                        |
|-------|------------------------------------------------------------------------------------------------------------------------------------|
| [7:0] | Instruction Pointer Address (Low Byte)<br>The low-byte instruction pointer value is the lower eight bits of the 16-bit instruction |
|       | pointer address (IP7–IP0). The upper byte of the IP address is located in the IPH Register (DAh).                                  |

### **Fast Interrupt Processing**

This feature lets you specify that an interrupt within a given level be completed in approximately six clock cycles instead of the usual 22 clock cycles. To select a specific interrupt level for fast interrupt processing, you write the appropriate 3-bit value to SYM.4–SYM.2. Then, to enable fast interrupt processing for the selected level, you set SYM.1 to 1.

Two other system registers support fast interrupts processing:

- The instruction pointer (IP) contains the starting address of the service routine (and is later used to swap the program counter values), and
- When a fast interrupt occurs, the contents of the Flags Register are stored in an unmapped, dedicated register called *Flags'* (a.k.a. Flags prime).

**Note:** For the S3F8S5A microcontroller, the service routine for any one of the eight interrupt levels: IRQ0–IRQ7, can be selected for fast interrupt processing.

### **Procedure for Initiating Fast Interrupts**

To initiate fast interrupt processing, follow these steps:

- 1. Load the start address of the service routine into the instruction pointer (IP).
- 2. Load the interrupt level number (IRQn) into the fast interrupt selection field (SYM.4–SYM.2).

>





3. Write a 1 to the fast interrupt enable bit in the SYM Register.

### **Fast Interrupt Service Routine**

When an interrupt occurs in the level selected for fast interrupt processing, the following sequence of events occur:

- 1. The contents of the instruction pointer and the PC are swapped.
- 2. The Flags Register values are written to the Flags' (a.k.a. Flags prime) Register.
- 3. The fast interrupt status bit in the Flags Register is set.
- 4. The interrupt is serviced.
- 5. Assuming that the fast interrupt status bit is set, when the fast interrupt service routine ends, the instruction pointer and PC values are swapped back.
- 6. The content of Flags' is automatically copied back to the Flags Register.
- 7. The fast interrupt status bit in Flags is cleared automatically.

#### **Relationship to Interrupt Pending Bit Types**

As described previously, there are two types of interrupt pending bits; one is automatically cleared by hardware after the interrupt service routine is acknowledged and executed, and the other must be cleared by the application software's interrupt service routine. Fast interrupt processing can be selected for interrupts with either type of pending condition clear function – hardware or software.

### **Programming Guidelines**

Be advised that the only way to enable/disable a fast interrupt is to set/clear the fast interrupt enable bit (SYM.1) in the SYM Register. Executing an EI or DI instruction globally enables or disables all interrupt processing, including fast interrupts. If you use fast interrupts, remember to load the IP with a new start address when the fast interrupt service routine ends.





# **Instruction Set**

The SAM88 instruction set, which comprises 78 instructions, is specifically designed to support the large register files that are typical of most SAM88 microcontrollers.

The powerful data manipulation capabilities and features of the SAM88 instruction set include:

- A full complement of 8-bit arithmetic and logic operations, including multiply and divide
- No special I/O instructions (I/O control/data registers are mapped directly into the register file)
- Decimal adjustment included in binary-coded decimal (BCD) operations
- 16-bit (word) data can be incremented and decremented
- Flexible instructions for bit addressing, rotate, and shift operations

### **Data Types**

The SAM88 CPU performs operations on bits, bytes, BCD digits, and two-byte words. Bits in the register file can be set, cleared, complemented, and tested. Bits within a byte are numbered from 7 to 0, where bit 0 is the least significant (right-most) bit.

### **Register Addressing**

To access an individual register, an 8-bit address in the range 0–255 or the 4-bit address of a working register is specified. Paired registers can be used to construct 16-bit data or 16-bit program memory or data memory addresses. To learn more about register addressing, see the <u>Address Space</u> chapter on page 19.

### **Addressing Modes**

There are seven explicit addressing modes: Register (R), Indirect Register (IR), Indexed (X), Direct (DA), Relative (RA), Immediate (IM) and Indirect (IA). To learn more about these addressing modes, see the <u>Addressing Modes</u> chapter on page 43.



IN DIXYS Company

#### 83

## **Instruction Summary**

All instructions are summarized by type, operand, and description in Table 22.

| Mnemonic                | Operands | Instruction                                 |
|-------------------------|----------|---------------------------------------------|
| Load Instructions       |          |                                             |
| CLR                     | dst      | Clear                                       |
| LD                      | dst,src  | Load                                        |
| LDB                     | dst,src  | Load bit                                    |
| LDE                     | dst,src  | Load external data memory                   |
| LDC                     | dst,src  | Load program memory                         |
| LDED                    | dst,src  | Load external data memory and decrement     |
| LDCD                    | dst,src  | Load program memory and decrement           |
| LDEI                    | dst,src  | Load external data memory and increment     |
| LDCI                    | dst,src  | Load program memory and increment           |
| LDEPD                   | dst,src  | Load external data memory with predecrement |
| LDCPD                   | dst,src  | Load program memory with predecrement       |
| LDEPI                   | dst,src  | Load external data memory with preincrement |
| LDCPI                   | dst,src  | Load program memory with preincrement       |
| LDW                     | dst,src  | Load word                                   |
| POP                     | dst      | Pop from stack                              |
| POPUD                   | dst,src  | Pop user stack (decrementing)               |
| POPUI                   | dst,src  | Pop user stack (incrementing)               |
| PUSH                    | src      | Push to stack                               |
| PUSHUD                  | dst,src  | Push user stack (decrementing)              |
| PUSHUI                  | dst,src  | Push user stack (incrementing)              |
| Arithmetic Instructions |          |                                             |
| ADC                     | dst,src  | Add with carry                              |
| ADD                     | dst,src  | Add                                         |
| СР                      | dst,src  | Compare                                     |
| DA                      | dst      | Decimal adjust                              |
| DEC                     | dst      | Decrement                                   |
| DECW                    | dst      | Decrement word                              |
| DIV                     | dst,src  | Divide                                      |

#### Table 22. Instruction Group Summary





#### Table 22. Instruction Group Summary (Continued)

| Arithmetic Instruction  | s (continued)    |                                          |
|-------------------------|------------------|------------------------------------------|
| INC                     | dst              | Increment                                |
| INCW                    | dst              | Increment word                           |
| MULT                    | dst,src          | Multiply                                 |
| SBC                     | dst,src          | Subtract with carry                      |
| SUB                     | dst,src          | Subtract                                 |
| Logic Instructions      |                  |                                          |
| AND                     | dst,src          | Logical AND                              |
| СОМ                     | dst              | Complement                               |
| OR                      | dst,src          | Logical OR                               |
| XOR                     | dst,src          | Logical exclusive OR                     |
| Mnemonic                | Operands         | Instruction                              |
| Program Control Instr   | ructions         |                                          |
| BTJRF                   | dst,src          | Bit test and jump relative on false      |
| BTJRT                   | dst,src          | Bit test and jump relative on true       |
| CALL                    | dst              | Call procedure                           |
| CPIJE                   | dst,src          | Compare, increment and jump on equal     |
| CPIJNE                  | dst,src          | Compare, increment and jump on non-equal |
| DJNZ                    | r,dst            | Decrement register and jump on non-zero  |
| ENTER                   | Enter            |                                          |
| EXIT                    | Exit             |                                          |
| IRET                    | Interrupt return |                                          |
| JP                      | cc,dst           | Jump on condition code                   |
| JP                      | dst              | Jump unconditional                       |
| JR                      | cc,dst           | Jump relative on condition code          |
| NEXT                    |                  | Next                                     |
| RET                     |                  | Return                                   |
| WFI                     |                  | Wait for interrupt                       |
| Bit Manipulation Instru | uctions          |                                          |
| BAND                    | dst,src          | Bit AND                                  |
| BCP                     | dst,src          | Bit compare                              |
| BITC                    | dst              | Bit complement                           |
| BITR                    | dst              | Bit reset                                |
| BITS                    | dst              | Bit set                                  |
|                         |                  |                                          |





| Bit Manipulation Instructions (continued) |         |                            |  |  |  |
|-------------------------------------------|---------|----------------------------|--|--|--|
| BOR                                       | dst,src | Bit OR                     |  |  |  |
| BXOR                                      | dst,src | Bit XOR                    |  |  |  |
| ТСМ                                       | dst,src | Test complement under mask |  |  |  |
| ТМ                                        | dst,src | Test under mask            |  |  |  |
| Rotate and Shift Instruct                 | tions   |                            |  |  |  |
| RL                                        | dst     | Rotate left                |  |  |  |
| RLC                                       | dst     | Rotate left through carry  |  |  |  |
| RR                                        | dst     | Rotate right               |  |  |  |
| RRC                                       | dst     | Rotate right through carry |  |  |  |
| SRA                                       | dst     | Shift right arithmetic     |  |  |  |
| SWAP                                      | dst     | Swap nibbles               |  |  |  |
| CPU Control Instructions                  |         |                            |  |  |  |
| CCF                                       |         | Complement carry flag      |  |  |  |
| DI                                        |         | Disable interrupts         |  |  |  |
| EI                                        |         | Enable interrupts          |  |  |  |
| IDLE                                      |         | Enter Idle mode            |  |  |  |
| NOP                                       |         | No operation               |  |  |  |
| RCF                                       |         | Reset carry flag           |  |  |  |
| SB0                                       |         | Set Bank0                  |  |  |  |
| SB1                                       |         | Set Bank1                  |  |  |  |
| SCF                                       |         | Set carry flag             |  |  |  |
| SRP                                       | src     | Set register pointers      |  |  |  |
| SRP0                                      | src     | Set register pointer 0     |  |  |  |
| SRP1                                      | src     | Set register pointer 1     |  |  |  |
| STOP                                      |         | Enter Stop Mode            |  |  |  |

#### Table 22. Instruction Group Summary (Continued)

### **Flags Register**

The Flags (FLAGS) Register, shown in Table 23, contains eight bits that describe the current status of CPU operations. Four of these bits, FLAGS.7–FLAGS.4, can be tested and used with conditional jump instructions; two others, FLAGS.3 and FLAGS.2, are used for BCD arithmetic.



86

The Flags Register also contains a bit to indicate the status of fast interrupt processing (FLAGS.1) and a bank address status bit (FLAGS.0) to indicate whether Bank0 or Bank1 is currently being addressed. The Flags Register can be set or reset by instructions as long as its outcome does not affect the flags (e.g., a Load instruction).

Logical and arithmetic instructions such as AND, OR, XOR, ADD, and SUB can affect the Flags Register. For example, the AND instruction updates the Zero, Sign, and Overflow flags based on the outcome of the AND instruction. If the AND instruction uses the Flags Register as the destination, then simultaneously, two writes will occur to the Flags Register, thereby producing an unpredictable result.

|              |                                                                                                                                                                 |                                             |                       |     | •   |              |   |       |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|-----------------------|-----|-----|--------------|---|-------|
| Bit          | 7                                                                                                                                                               | 6                                           | 5                     | 4   | 3   | 2            | 1 | 0     |
| Reset        | Х                                                                                                                                                               | х                                           | х                     | х   | х   | х            | 0 | 0     |
| R/W          | R/W                                                                                                                                                             | R/W                                         | R/W                   | R/W | R/W | R/W          | R | R/W   |
| Address      |                                                                                                                                                                 |                                             |                       | D   | 5h  |              |   |       |
| Mode         | Register Addressing Mode only                                                                                                                                   |                                             |                       |     |     |              |   |       |
| Note: R = re | ad only; R/W = r                                                                                                                                                | ead/write.                                  |                       |     |     |              |   |       |
| Bit          | Description                                                                                                                                                     |                                             |                       |     |     |              |   |       |
| [7]          | <b>Carry Flag Bit (C)</b><br>0: Operation does not generate a carry or borrow condition.<br>1: Operation generates a carry-out or borrow into high-order bit 7. |                                             |                       |     |     |              |   |       |
| [6]          | <b>Zero Flag Bit (Z)</b><br>0: Operation result is a nonzero value.<br>1: Operation result is zero.                                                             |                                             |                       |     |     |              |   |       |
| [5]          | <b>Sign Flag Bit (S)</b><br>0: Operation generates a positive number (MSB = 0).<br>1: Operation generates a negative number (MSB = 1).                          |                                             |                       |     |     |              |   |       |
| [4]          | 0: Operatio                                                                                                                                                     | Flag Bit (V<br>on result is<br>on result is | <u>&lt;</u> +127 or - |     |     |              |   |       |
| [3]          | Decimal Adjust Flag Bit (D)<br>0: Add operation completed.<br>1: Subtraction operation completed.                                                               |                                             |                       |     |     |              |   |       |
| [2]          | 0: No carry                                                                                                                                                     |                                             | 3 or no bori          |     | •   | n or subtrac |   | vit 3 |

#### Table 23. Flags Register (FLAGS; Set1)

1: Addition generated carry-out of bit 3 or subtraction generated borrow into bit 3.



| Bit | Description (Continued)                                                                                                                               |
|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| [1] | Fast Interrupt Status Flag Bit (FIS)<br>0: Interrupt return (IRET) in progress when read.<br>1: Fast interrupt service routine in progress when read. |
| [0] | Bank Address Selection Flag Bit (BA)<br>0: Bank0 is selected.<br>1: Bank1 is selected.                                                                |

Table 24 describes each of the flags managed by the Flags Register.

#### Table 24. Flag Descriptions

| Flag | Description                                                                                                                                                                                                                                                                                                                                                                   |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| С    | <b>Carry Flag (FLAGS.7)</b><br>The C flag is set to 1 if the result from an arithmetic operation generates a carry-out from or a borrow to the bit 7 position (MSB). After rotate and shift operations, it contains the last value shifted out of the specified register. Program instructions can set, clear, or complement the carry flag.                                  |
| Z    | <b>Zero Flag (FLAGS.6)</b><br>For arithmetic and logic operations, the Z flag is set to 1 if the result of the operation is zero. For operations that test register bits, and for shift and rotate operations, the Z flag is set to 1 if the result is logic 0.                                                                                                               |
| S    | <b>Sign Flag (FLAGS.5)</b><br>Following the arithmetic, logic, rotate, or shift operations, the sign bit identifies the state of the MSB of the result. A logic 0 indicates a positive number and a logic 1 indicates a negative number.                                                                                                                                      |
| V    | <b>Overflow Flag (FLAGS.4)</b><br>The V flag is set to 1 when the result of a two's-complement operation is greater than +127 or less than -128. It is also cleared to 0 following logic operations.                                                                                                                                                                          |
| D    | <b>Decimal Adjust Flag (FLAGS.3)</b><br>The DA bit is used to specify what type of instruction is executed last during BCD operations, so that a subsequent decimal adjust operation can execute correctly. The DA bit is not usually accessed by programmers, and cannot be used as a test condition.                                                                        |
| Η    | Half-Carry Flag (FLAGS.2)<br>The H bit is set to 1 whenever an addition generates a carry-out of bit 3, or when a subtraction<br>borrows out of bit 4. It is used by the Decimal Adjust (DA) instruction to convert the binary result of<br>a previous addition or subtraction into the correct decimal (BCD) result. The H flag is seldom<br>accessed directly by a program. |



DXYS Company

88

### Table 24. Flag Descriptions (Continued)

| Flag | Description                                                                                                                                                                                                                                                                                                               |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FIS  | <b>Fast Interrupt Status Flag (FLAGS.1)</b><br>The FIS bit is set during a fast interrupt cycle and reset during the IRET following interrupt servicing. When set, it inhibits all interrupts and causes the fast interrupt return to be executed when the IRET instruction is executed.                                  |
| BA   | Bank Address Flag (FLAGS.0)<br>The BA flag indicates which register bank in the Set1 area of the internal register file is currently<br>selected, Bank0 or Bank1. The BA flag is cleared to 0 (select Bank0) when you execute the SB0<br>instruction and is set to 1 (select Bank1) when you execute the SB1 instruction. |

### **Instruction Set Notation**

Table 25 lists the conventions used for each of the flags managed by the Instruction Set. Symbols for the Instruction Set are listed in Table 26; conditions for these symbols are described in Table 27.

| Flag | Description                            |
|------|----------------------------------------|
| С    | Carry flag.                            |
| Z    | Zero flag.                             |
| S    | Sign flag.                             |
| V    | Overflow flag.                         |
| D    | Decimal-adjust flag.                   |
| Н    | Half-carry flag.                       |
| 0    | Cleared to logic 0.                    |
| 1    | Set to logic 1.                        |
| *    | Set to cleared according to operation. |
| _    | Value is unaffected.                   |
| x    | Value is undefined.                    |

#### Table 25. Flag Notation Conventions

#### Table 26. Instruction Set Symbols

| Symbol | Description                       |
|--------|-----------------------------------|
| dst    | Destination operand.              |
| src    | Source operand.                   |
| @      | Indirect register address prefix. |



89

| Symbol | Description                                   |
|--------|-----------------------------------------------|
| PC     | Program counter.                              |
| IP     | Instruction pointer.                          |
| FLAGS  | Flags register (D5h).                         |
| RP     | Register pointer.                             |
| #      | Immediate operand or register address prefix. |
| Н      | Hexadecimal number suffix.                    |
| D      | Decimal number suffix.                        |
| В      | Binary number suffix.                         |
| орс    | Op code.                                      |
|        |                                               |

#### Table 26. Instruction Set Symbols (Continued)

#### **Table 27. Instruction Notation Conventions**

| Notation | Description                                              | Actual Operand Range                                                     |  |  |  |
|----------|----------------------------------------------------------|--------------------------------------------------------------------------|--|--|--|
| CC       | Condition code                                           | See list of condition codes in Table 30 on page 93                       |  |  |  |
| r        | Working register only                                    | Rn (n= 0–15)                                                             |  |  |  |
| rb       | Bit (b) of working register                              | Rn.b (n = 0–15, b = 0–7)                                                 |  |  |  |
| rO       | Bit 0 (LSB) of working register                          | Rn (n = 0–15)                                                            |  |  |  |
| rr       | Working register pair                                    | RRp (p = 0, 2, 4,, 14)                                                   |  |  |  |
| R        | Register or working register                             | reg or Rn (reg = 0–255, n = 0–15)                                        |  |  |  |
| Rb       | Bit (b) of register or working register                  | reg.b (reg = 0–255, b = 0–7)                                             |  |  |  |
| RR       | Register pair or working register pair                   | reg or RRp (reg = $0-254$ , even number only, in which p = $0, 2,, 14$ ) |  |  |  |
| IA       | Indirect Addressing Mode                                 | addr (addr = 0–254, even number only)                                    |  |  |  |
| lr       | Indirect working register only                           | @Rn (n = 0–15)                                                           |  |  |  |
| IR       | Indirect register or indirect working register           | @Rn or @reg (reg = 0–255, n = 0–15)                                      |  |  |  |
| Irr      | Indirect working register pair only                      | @RRp (p = 0, 2,, 14)                                                     |  |  |  |
| IRR      | Indirect register pair or indirect working register pair | @RRp or @reg (reg = $0-254$ , even only, in which p = 0, 2,, 14)         |  |  |  |
| Х        | Indexed Addressing Mode                                  | #reg [Rn] (reg = 0–255, n = 0–15)                                        |  |  |  |
| XS       | Indexed (Short Offset) Addressing<br>Mode                | #addr [RRp] (addr = range $-128$ to $+127$ , in which $p = 0, 2,, 14$ )  |  |  |  |
| xl       | Indexed (Long Offset) Addressing Mode                    | e #addr [RRp] (addr = range 0–65535, in which p = 0, 2,, 14)             |  |  |  |





#### Table 27. Instruction Notation Conventions (Continued)

| Notation | Description                      | Actual Operand Range                                                                                                 |
|----------|----------------------------------|----------------------------------------------------------------------------------------------------------------------|
| da       | Direct Addressing Mode           | addr (addr = range 0–65535)                                                                                          |
| ra       | Relative Addressing Mode         | addr (addr = number in the range $+127$ to $-128$ that is an offset relative to the address of the next instruction) |
| im       | Immediate Addressing Mode        | #data (data = 0–255)                                                                                                 |
| iml      | Immediate (Long) Addressing Mode | #data (data = range 0–65535)                                                                                         |



91 An DXYS Company

scided in Life

# **Op Code Maps**

Tables 28 and 29 provide quick reference op code maps to addresses 0-7 and 8-F, respectively.

|                   |   |             |               | Ор                    | Code Map          |                 |                  |                 |                     |
|-------------------|---|-------------|---------------|-----------------------|-------------------|-----------------|------------------|-----------------|---------------------|
|                   |   |             |               | Lower                 | Nibble (He        | x)              |                  |                 |                     |
|                   |   | 0           | 1             | 2                     | 3                 | 4               | 5                | 6               | 7                   |
|                   | 0 | DEC<br>R1   | DEC<br>IR1    | ADD<br>r1, r2         | ADD<br>r1, Ir2    | ADD<br>R2, R1   | ADD<br>IR2, R1   | ADD<br>R1, IM   | BOR<br>r0–Rb        |
| _                 | 1 | RLC<br>R1   | RLC<br>IR1    | ADC<br>r1, r2         | ADC<br>r1, Ir2    | ADC<br>R2, R1   | ADC<br>IR2, R1   | ADC<br>R1, IM   | BCP<br>r1.b, R2     |
| _                 | 2 | INC<br>R1   | INC<br>IR1    | SUB<br>r1, r2         | SUB<br>r1, Ir2    | SUB<br>R2, R1   | SUB<br>IR2, R1   | SUB<br>R1, IM   | BXOR<br>r0–Rb       |
| -                 | 3 | JP<br>IRR1  | SRP/0/1<br>IM | SBC<br>r1, r2         | SBC<br>r1, Ir2    | SBC<br>R2, R1   | SBC<br>IR2, R1   | SBC<br>R1, IM   | BTJR<br>r2.b, RA    |
| _                 | 4 | DA<br>R1    | DA<br>IR1     | OR<br>r1, r2          | OR<br>r1, Ir2     | OR<br>R2, R1    | OR<br>IR2, R1    | OR<br>R1, IM    | LDB<br>r0–Rb        |
| _                 | 5 | POP<br>R1   | POP<br>IR1    | AND<br>r1, r2         | AND<br>r1, Ir2    | AND<br>R2, R1   | AND<br>IR2, R1   | AND<br>R1, IM   | BITC<br>r1.b        |
| _                 | 6 | COM<br>R1   | COM<br>IR1    | TCM<br>r1, r2         | TCM<br>r1, Ir2    | TCM<br>R2, R1   | TCM<br>IR2, R1   | TCM<br>R1, IM   | BAND<br>r0–Rb       |
| Upper<br>Nibble - | 7 | PUSH<br>R2  | PUSH<br>IR2   | TM<br>r1, r2          | TM<br>r1, Ir2     | TM<br>R2, R1    | TM<br>IR2, R1    | TM<br>R1, IM    | BIT<br>r1.b         |
| (Hex)             | 8 | DECW<br>RR1 | DECW<br>IR1   | PUSHUD<br>IR1, R2     | PUSHUI<br>IR1, R2 | MULT<br>R2, RR1 | MULT<br>IR2, RR1 | MULT<br>IM, RR1 | LD<br>r1, x, r2     |
| -                 | 9 | RL<br>R1    | RL<br>IR1     | POPUD<br>IR2, R1      | POPUI<br>IR2, R1  | DIV<br>R2, RR1  | DIV<br>IR2, RR1  | DIV<br>IM, RR1  | LD<br>r2, x, r1     |
| =                 | А | INCW<br>RR1 | INCW<br>IR1   | CP<br>r1, r2          | CP<br>r1, Ir2     | CP<br>R2, R1    | CP<br>IR2, R1    | CP<br>R1, IM    | LDC<br>r1, Irr2, xL |
| =                 | В | CLR<br>R1   | CLR<br>IR1    | XOR<br>r1, r2         | XOR<br>r1, lr2    | XOR<br>R2, R1   | XOR<br>IR2, R1   | XOR<br>R1, IM   | LDC<br>r2, Irr2, xL |
| _                 | С | RRC<br>R1   | RRC<br>IR1    | CPIJE<br>Ir, r2, RA   | LDC<br>r1, lrr2   | LDW<br>RR2, RR1 | LDW<br>IR2, RR1  | LDW<br>RR1, IML | LD<br>r1, lr2       |
|                   | D | SRA<br>R1   | SRA<br>IR1    | CPIJNE<br>Irr, r2, RA | LDC<br>r2, Irr1   | CALL<br>IA1     |                  | LD<br>IR1, IM   | LD<br>Ir1, r2       |
| =                 | Е | RR<br>R1    | RR<br>IR1     | LDCD<br>r1, Irr2      | LDCI<br>r1, Irr2  | LD<br>R2, R1    | LD<br>R2, IR1    | LD<br>R1, IM    | LDC<br>r1, Irr2, xs |
|                   | F | SWAP<br>R1  | SWAP<br>IR1   | LDCPD<br>r2, Irr1     | LDCPI<br>r2, Irr1 | CALL<br>IRR1    | LD<br>IR2, R1    | CALL<br>DA1     | LDC<br>r2, Irr1, xs |

#### Table 28. Op Code Quick Reference (0–7)



92

|                   |   |              |              | Ор             | Code Map      |              |              |              |       |
|-------------------|---|--------------|--------------|----------------|---------------|--------------|--------------|--------------|-------|
|                   |   |              |              | Lower          | · Nibble (Hex | :)           |              |              |       |
|                   |   | 8            | 9            | Α              | В             | С            | D            | Е            | F     |
|                   | 0 | LD<br>r1,R2  | LD<br>r2,R1  | DJNZ<br>r1,RA  | JR<br>cc, RA  | LD<br>r1,IM  | JP<br>cc, DA | INC<br>r1    | NEXT  |
| _                 | 1 | $\downarrow$ | Ļ            | $\downarrow$   | Ļ             | Ļ            | $\downarrow$ | Ļ            | ENTER |
| _                 | 2 |              |              |                |               |              |              |              | EXIT  |
| -                 | 3 |              |              |                |               |              |              |              | WFI   |
| _                 | 4 |              |              |                |               |              |              |              | SB0   |
| -                 | 5 |              |              |                |               |              |              |              | SB1   |
|                   | 6 |              |              |                |               |              |              |              | IDLE  |
| Upper             | 7 | $\downarrow$ | $\downarrow$ | $\downarrow$   | $\downarrow$  | $\downarrow$ | $\downarrow$ | $\downarrow$ | STOP  |
| Nibble -<br>(Hex) | 8 |              |              |                |               |              |              |              | DI    |
| _                 | 9 |              |              |                |               |              |              |              | EI    |
| _                 | А |              |              |                |               |              |              |              | RET   |
| -                 | В |              |              |                |               |              |              |              | IRET  |
|                   | С |              |              |                |               |              |              |              | RCF   |
|                   | D | Ļ            | Ļ            | $\downarrow$   | $\downarrow$  | Ļ            | $\downarrow$ | Ļ            | SCF   |
| =                 | E |              |              |                |               |              |              |              | CCF   |
| -                 | F | LD<br>r1, 2  | LD<br>r2, R1 | DJNZ<br>r1, RA | JR<br>cc, RA  | LD<br>r1, IM | JP<br>cc, DA | INC<br>r1    | NOP   |

#### Table 29. Op Code Quick Reference (8–F)



cided in Life

DXYS Company

## **Condition Codes**

The op code of a conditional jump always contains a 4-bit field called the *condition code* (cc) that specifies under which conditions it is to execute the jump. For example, a conditional jump with a condition code of *equal* after a compare operation only jumps if the two operands are equal. The carry (C), zero (Z), sign (S), and overflow (V) flags are used to control the operation of conditional jump instructions.

These condition codes are listed in Table 30.

| Mnemonic         | Binary | Description                    | Flags Set             |
|------------------|--------|--------------------------------|-----------------------|
| F                | 0000   | Always false                   | _                     |
| Т                | 1000   | Always true                    | _                     |
| C <sup>2</sup>   | 0111   | Carry                          | C = 1                 |
| NC <sup>2</sup>  | 1111   | No carry                       | C = 0                 |
| Z <sup>2</sup>   | 0110   | Zero                           | Z = 1                 |
| NZ <sup>2</sup>  | 1110   | Not zero                       | Z = 0                 |
| PL               | 1101   | Plus                           | S = 0                 |
| MI               | 0101   | Minus                          | S = 1                 |
| OV               | 0100   | Overflow                       | V = 1                 |
| NOV              | 1100   | No overflow                    | V = 0                 |
| EQ <sup>2</sup>  | 0110   | Equal                          | Z = 1                 |
| NE <sup>2</sup>  | 1110   | Not equal                      | Z = 0                 |
| GE               | 1001   | Greater than or equal          | (S XOR V) = 0         |
| LT               | 0001   | Less than                      | (S XOR V) = 1         |
| GT               | 1010   | Greater than                   | (Z OR (S XOR V)) = 0  |
| LE               | 0010   | Less than or equal             | (Z OR (S XOR V)) = 1  |
| UGE <sup>2</sup> | 1111   | Unsigned greater than or equal | C = 0                 |
| ULT <sup>2</sup> | 0111   | Unsigned less than             | C = 1                 |
| UGT              | 1011   | Unsigned greater than          | (C = 0 AND Z = 0) = 1 |
| ULE              | 0011   | Unsigned less than or equal    | (C OR Z) = 1          |
| Note:            |        |                                |                       |

#### Table 30. Condition Codes<sup>1</sup>

Note:

1. For operations involving unsigned numbers, the special condition codes UGE, ULT, UGT, and ULE must be used.

 Indicates condition codes that are related to two different mnemonics but which test the same flag. For example, Z and EQ are both true if the zero flag (Z) is set; however, after an ADD instruction, Z would probably be used; after a CP instruction, however, EQ would probably be used.



94

## **Instruction Descriptions**

This section provides programming examples for each instruction in the SAM88 instruction set. Information is arranged in a consistent format for improved readability and for fast referencing.

The following information is included in each instruction description:

- Instruction name (mnemonic)
- Full instruction name
- Source/destination format of the instruction operand
- Shorthand notation of the instruction's operation
- Textual description of the instruction's effect
- Specific flag settings affected by the instruction
- The format of the instruction, its execution time, and addressing mode(s)
- Programming example(s) explaining how to use the instruction





### Add with Carry

| ADC       | dst, src                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
|-----------|------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Operation | dst ↔                                                      | -dst + src + c                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
| Flags     | tinat<br>sour<br>preci                                     | source operand, along with the setting of the carry flag, is added to the des-<br>ion operand and the sum is stored in the destination. The contents of the<br>ce are unaffected. Two's complement addition is performed. In multiple<br>ision arithmetic, this instruction permits the carry from the addition of low-<br>r operands to be carried into the addition of high-order operands.<br>Set if there is a carry from the most significant bit of the result; cleared |  |  |  |  |
| i iugo    | C                                                          | otherwise.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
|           | Ζ                                                          | Set if the result is 0; cleared otherwise.                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
|           | <b>S</b> Set if the result is negative; cleared otherwise. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
|           | V                                                          | Set if arithmetic overflow occurs, i.e., if both operands are of the same sign and the result is of the opposite sign; cleared otherwise.                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |
|           | D                                                          | Always cleared to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
|           |                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |

**H** Set if there is a carry from the most significant bit of the low-order four bits of the result; cleared otherwise.

#### Format

|           |                                              |     | Bytes | Cycles | Op Code | Addres | s Mode |
|-----------|----------------------------------------------|-----|-------|--------|---------|--------|--------|
|           |                                              |     |       |        | (Hex)   | dst    | src    |
| орс       | dst   src                                    |     | 2     | 4      | 12      | r      | r      |
| . <u></u> | <u>.                                    </u> |     |       | 6      | 13      | r      | lr     |
|           |                                              |     |       |        |         |        |        |
| орс       | src                                          | dst | 3     | 6      | 14      | R      | R      |
| . <u></u> |                                              |     |       | 6      | 15      | R      | IR     |
|           |                                              |     |       |        |         |        |        |
| орс       | dst                                          | src | 3     | 6      | 16      | R      | IM     |

**Example** Assume that R1 = 10h, R2 = 03h, C flag = 1, register 01h = 20h, register 02h = 03h, and register 03h = 0Ah.

| ADC | R1, R2    | $\rightarrow$ | R1 = 14h, R2 = 03h                     |
|-----|-----------|---------------|----------------------------------------|
| ADC | R1, @R2   | $\rightarrow$ | R1 = 1Bh, R2 = 03h                     |
| ADC | 01h, 02h  | $\rightarrow$ | Register 01h = 24h, register 02h = 03h |
| ADC | 01h, @02h | $\rightarrow$ | Register 01h = 2Bh, register 02h = 03h |
| ADC | 01h, #11h | $\rightarrow$ | Register 01h = 32h                     |



96

In the first example, destination register R1 contains the value 10h, the carry flag is set to 1, and the source working register R2 contains the value 03h. The *ADC R1, R2* statement adds 03h and the carry flag value (1) to the destination value 10h, leaving 14h in register R1.





### Add

| ADD       | dst,                                                                                                                                                                                  | dst, src                                                                                                                                  |  |  |  |  |  |  |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Operation | dst •                                                                                                                                                                                 | - dst + src                                                                                                                               |  |  |  |  |  |  |
|           | The source operand is added to the destination operand and the sum is stored in the destination. The contents of the source are unaffected. Two's complement additions are performed. |                                                                                                                                           |  |  |  |  |  |  |
| Flags     | С                                                                                                                                                                                     | Set if there is a carry from the most significant bit of the result; cleared otherwise.                                                   |  |  |  |  |  |  |
|           | z                                                                                                                                                                                     | Set if the result is 0; cleared otherwise.                                                                                                |  |  |  |  |  |  |
|           | S                                                                                                                                                                                     | Set if the result is negative; cleared otherwise.                                                                                         |  |  |  |  |  |  |
|           | V                                                                                                                                                                                     | Set if arithmetic overflow occurs, i.e., if both operands are of the same sign and the result is of the opposite sign; cleared otherwise. |  |  |  |  |  |  |
|           | D                                                                                                                                                                                     | Always cleared to 0.                                                                                                                      |  |  |  |  |  |  |
|           |                                                                                                                                                                                       |                                                                                                                                           |  |  |  |  |  |  |

**H** Set if a carry from the low-order nibble occurred.

#### Format

|           |           |     | Bytes | Cycles | Op Code Address |     | s Mode |
|-----------|-----------|-----|-------|--------|-----------------|-----|--------|
|           |           |     |       |        | (Hex)           | dst | src    |
| орс       | dst   src |     | 2     | 4      | 02              | r   | r      |
|           |           |     |       | 6      | 03              | r   | lr     |
|           |           |     |       |        |                 |     |        |
| орс       | src       | dst | 3     | 6      | 04              | R   | R      |
| . <u></u> |           |     |       | 6      | 05              | R   | IR     |
|           |           |     |       |        |                 |     |        |
| орс       | dst       | src | 3     | 6      | 06              | R   | IM     |

**Example** Assume that R1 = 12h, R2 = 03h, register 01h = 21h, register 02h = 03h, register 03h = 0Ah.

| ADC | R1, R2    | $\rightarrow$ | R1 = 15h, R2 = 03h                     |
|-----|-----------|---------------|----------------------------------------|
| ADC | R1, @R2   | $\rightarrow$ | R1 = 1Ch, R2 = 03h                     |
| ADC | 01h, 02h  | $\rightarrow$ | Register 01h = 24h, register 02h = 03h |
| ADC | 01h, @02h | $\rightarrow$ | Register 01h = 2Bh, register 02h = 03h |
| ADC | 01h, #25h | $\rightarrow$ | Register 01h = 46h                     |

In the first example, destination working register R1 contains 12h and the source working register R2 contains 03h. The *ADD R1, R2* statement adds 03h to 12h, leaving the value 15h in register R1.



98

### Logical AND

| AND       | dst, src                                                                                                                                                                                                                                                                                                                                          |          |             |              |           |          |  |  |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------------|--------------|-----------|----------|--|--|
| Operation | dst ← dst AND src<br>The source operand is logically ANDed with the destination operand. The<br>result is stored in the destination. The AND operation results in a 1 bit being<br>stored whenever the corresponding bits in the two operands are both logic 1s;<br>otherwise a 0 bit value is stored. The contents of the source are unaffected. |          |             |              |           |          |  |  |
| Flags     | <ul> <li>C Unaffected.</li> <li>Z Set if the result is 0; cleared otherwise.</li> <li>S Set if the result bit 7 is set; cleared otherwise.</li> <li>V Always cleared to 0.</li> <li>D Unaffected.</li> <li>H Unaffected.</li> </ul>                                                                                                               |          |             |              |           |          |  |  |
| Format    |                                                                                                                                                                                                                                                                                                                                                   | Bytes    | Cycles      | Op Code      | Addres    | s Mode   |  |  |
|           |                                                                                                                                                                                                                                                                                                                                                   |          |             | (Hex)        | dst       | src      |  |  |
|           | opc dst   src                                                                                                                                                                                                                                                                                                                                     | 2        | 4           | 52           | r         | r        |  |  |
|           |                                                                                                                                                                                                                                                                                                                                                   |          | 6           | 53           | r         | lr       |  |  |
|           | opc src dst                                                                                                                                                                                                                                                                                                                                       | 3        | 6           | 54           | R         | R        |  |  |
|           |                                                                                                                                                                                                                                                                                                                                                   |          | 6           | 55           | R         | IR       |  |  |
|           | opc dst src                                                                                                                                                                                                                                                                                                                                       | 3        | 6           | 56           | R         | IM       |  |  |
| Example   | Assume that $\mathbf{P}_1 = 10$ b $\mathbf{P}_2$                                                                                                                                                                                                                                                                                                  | -02h roo | istor 01h - | - 21h ragist | ar 0.2b - | 0.2h rog |  |  |

**Example** Assume that R1 = 12h, R2 = 03h, register 01h = 21h, register 02h = 03h, register 03h = 0Ah.

| AND | R1, R2    | $\rightarrow$ | R1 = 02h, R2 = 03h                     |
|-----|-----------|---------------|----------------------------------------|
| AND | R1, @R2   | $\rightarrow$ | R1 = 02h, R2 = 03h                     |
| AND | 01h, 02h  | $\rightarrow$ | Register 01h = 01h, register 02h = 03h |
| AND | 01h, @02h | $\rightarrow$ | Register 01h = 00h, register 02h = 03h |
| AND | 01h, #25h | $\rightarrow$ | Register 01h = 21h                     |

In the first example, destination working register R1 contains the value 12h and the source working register R2 contains 03h. The *AND R1, R2* statement logically ANDs the source operand 03h with the destination operand value 12h, leaving the value 02h in register R1.







### Bit AND

| BAND      | dst, src.b                                                                                                                                                                                                                                                                    |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BAND      | dst.b, src                                                                                                                                                                                                                                                                    |
| Operation | $dst(0) \leftarrow dst(0) \text{ AND } src(b)$<br>or<br>$dst(b) \leftarrow dst(b) \text{ AND } src(0)$                                                                                                                                                                        |
|           | The specified bit of the source (or the destination) is logically ANDed with the zero bit (LSB) of the destination (or source). The resultant bit is stored in the specified bit of the destination. No other bits of the destination are affected. The source is unaffected. |
| Flags     | C Unaffected.                                                                                                                                                                                                                                                                 |
|           | 7 Set if the result is 0: cleared otherwise                                                                                                                                                                                                                                   |

- **Z** Set if the result is 0; cleared otherwise.
- S Cleared to 0.
- V Undefined.
- D Unaffected.
- H Unaffected.

#### Format

|   |     |             |     | Bytes | Cycles | Op Code | Address Mod |     |
|---|-----|-------------|-----|-------|--------|---------|-------------|-----|
|   |     |             |     |       |        | (Hex)   | dst         | src |
|   | орс | dst   b   0 | src | 3     | 6      | 67      | rO          | Rb  |
| - |     |             |     |       |        |         |             |     |
|   | орс | src   b   1 | dst | 3     | 6      | 67      | Rb          | rO  |

Note: In the second byte of the 3-byte instruction formats, the destination (or source) address is four bits, the bit address b is three bits, and the LSB address value is one bit in length.

Assume that R1 = 07h and register 01h = 05h.

| BAND | R1, 01h.1 | $\rightarrow$ | R1 = 06h, register 01h = 05h |
|------|-----------|---------------|------------------------------|
| BAND | 01h.1, R1 | $\rightarrow$ | Register 01h = 05h, R1 = 07h |

In the first example, source register 01h contains the value 05h (00000101b) and destination working register R1 contains 07h (00000111b). The *BAND* R1, 01h.1 statement ANDs the bit 1 value of the source register (0) with the bit 0 value of register R1 (destination), leaving the value 06h (00000110b) in register R1.





## **Bit Compare**

| BCP       | dst, src.b                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Operation | dst(0)–src(b)                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |
|           | The specified bit of the source is compared to (subtracted from) bit 0 (LSB) of the destination. The zero flag is set if the bits are the same; otherwise it is cleared. The contents of both operands are unaffected by the comparison.                                                                                                                                        |  |  |  |  |  |  |  |
| Flags     | <ul> <li>C Unaffected.</li> <li>Z Set if the two bits are the same; cleared otherwise.</li> <li>S Cleared to 0.</li> <li>V Undefined.</li> <li>D Unaffected.</li> <li>H Unaffected.</li> </ul>                                                                                                                                                                                  |  |  |  |  |  |  |  |
| Format    | Bytes Cycles Op Code Address Mode                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |
|           | opcdstborc0srcopcdstb0src3617r0RbNote:In the second byte of the instruction format, the destination address is four bits, the bit address b is three bits, and the LSB address value is one bit in length.                                                                                                                                                                      |  |  |  |  |  |  |  |
| Example   | Assume that $R1 = 0.7h$ and register $0.1h = 0.1h$ .<br>BCP R1, $0.1h.1 \rightarrow R1 = 0.7h$ , register $0.1h = 0.1h$                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |
|           | If destination working register R1 contains the value $07h (00000111b)$ and the source register $01h$ contains the value $01h (0000001b)$ , the <i>BCP R1, 01h.1</i> statement compares bit 1 of the source register (01h) and bit 0 of the destination register (R1). Because the bit values are not identical, the zero flag bit (Z) is cleared in the Flags Register (0D5h). |  |  |  |  |  |  |  |





## Bit Complement

| BITC      | dst.b                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Operation | $dst(b) \leftarrow NOT dst(b)$                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |
|           | This instruction complements the specified bit within the destination without affecting any other bits in the destination.                                                                                                                                                                    |  |  |  |  |  |  |  |
| Flags     | <ul> <li>C Unaffected.</li> <li>Z Set if the result is 0; cleared otherwise.</li> <li>S Cleared to 0.</li> <li>V Undefined.</li> <li>D Unaffected.</li> <li>H Unaffected.</li> </ul>                                                                                                          |  |  |  |  |  |  |  |
| Format    | Bytes Cycles Op Code Address Mode                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |
|           | (Hex) dst                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |
|           | opcdst   b   02457rbNote:In the second byte of the instruction format, the destination address is four bits,<br>the bit address b is three bits, and the LSB address value is one bit in length.                                                                                              |  |  |  |  |  |  |  |
| Example   | Assume that $R1 = 0.7h$ .                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |
|           | BITC R1.1 $\rightarrow$ R1 = 05h                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |
|           | If working register R1 contains the value 07h (00000111b), the <i>BITC R1.1</i> statement complements bit 1 of the destination and leaves the value 05h (00000101b) in register R1. Because the result of the complement is not 0, the zero flag (Z) in the Flags Register (0D5h) is cleared. |  |  |  |  |  |  |  |



An DXYS Company

### **Bit Reset**

| BITR      | dst.b                                                                                                                                                         |       |        |               |                |  |  |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|---------------|----------------|--|--|
| Operation | $dst(b) \leftarrow 0$                                                                                                                                         |       |        |               |                |  |  |
|           | The BITR instruction clears affecting any other bits in the                                                                                                   | -     |        | hin the desti | nation without |  |  |
| Flags     | No flags are affected.                                                                                                                                        |       |        |               |                |  |  |
| Format    |                                                                                                                                                               | Bytes | Cycles | Op Code       | Address Mode   |  |  |
|           |                                                                                                                                                               |       |        | (Hex)         | dst            |  |  |
|           | opc dst   b   0                                                                                                                                               | 2     | 4      | 77            | rb             |  |  |
|           | Note: In the second byte of the bit address b is three                                                                                                        |       |        |               |                |  |  |
| Example   | Assume that $R1 = 07h$ .                                                                                                                                      |       |        |               |                |  |  |
|           | BITR R1.1 $\rightarrow$                                                                                                                                       | R1 =  | 05h    |               |                |  |  |
|           | If the value of working register R1 is 07h (00000111b), the <i>BITR I</i> ment clears bit 1 of the destination register R1, leaving the value 05 (00000101b). |       |        |               |                |  |  |



An DXYS Company



### Bit Set

| BITS      | dst.b                                                                          |       |        |             |              |
|-----------|--------------------------------------------------------------------------------|-------|--------|-------------|--------------|
| Operation | $dst(b) \leftarrow 1$                                                          |       |        |             |              |
|           | The BITS instruction sets the affecting any other bits in the                  | -     |        | the destina | tion without |
| Flags     | No flags are affected.                                                         |       |        |             |              |
| Format    |                                                                                | Bytes | Cycles | Op Code     | Address Mode |
|           |                                                                                |       |        | (Hex)       | dst          |
|           | opc dst   b   1                                                                | 2     | 4      | 77          | rb           |
|           | Note: In the second byte of the the bit address b is three                     |       |        |             |              |
| Example   | Assume that $R1 = 07h$ .                                                       |       |        |             |              |
|           | BITR R1.3 →                                                                    | R1 =  | 0Fh    |             |              |
|           | If working register R1 conta<br>statement sets bit 3 of the de<br>(00001111b). |       |        |             |              |







### Bit OR

| BOR       | dst, src.b                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| BOR       | dst.b, src                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| Operation | dst(0) ← dst(0) OR src(b)<br>or<br>dst(b) ← dst(b) OR src(0)<br>The specified bit of the source (or the destination) is logically ORed with bit 0<br>(LSB) of the destination (or the source). The resulting bit value is stored in the<br>specified bit of the destination. No other bits of the destination are affected.<br>The source is unaffected.                                                     |  |  |  |
| Flags     | <ul> <li>C Unaffected.</li> <li>Z Set if the result is 0; cleared otherwise.</li> <li>S Cleared to 0.</li> <li>V Undefined.</li> <li>D Unaffected.</li> <li>H Unaffected.</li> </ul>                                                                                                                                                                                                                         |  |  |  |
| Format    | Bytes Cycles Op Code Address Mode                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
|           | opc       dst       b   0       src         opc       dst   b   0       src       3       6       07       r0       Rb         opc       src   b   1       dst       3       6       07       Rb       r0         Note:       In the second byte of the 3-byte instruction formats, the destination (or source) address is four bits, the bit address b is three bits, and the LSB address value is one bit. |  |  |  |

| Example | Assume | that $R1 = 0.7h$ | and regi      | ster $01h = 03h$ .           |
|---------|--------|------------------|---------------|------------------------------|
|         | BOR    | R1, 01h.1        | $\rightarrow$ | R1 = 07h, register 01h = 03h |
|         | BOR    | 01h.2, R1        | $\rightarrow$ | Register 01h = 07h, R1 = 07h |

In the first example, destination working register R1 contains the value 07h (00000111b) and source register 01h the value 03h (00000011b). The *BOR R1*, *01h*.1 statement logically ORs bit 1 of register 01h (source) with bit 0 of R1 (destination). This leaves the same value (07h) in working register R1.

In the second example, destination register 01h contains the value 03h (00000011b) and the source working register R1 the value 07h (00000111b).



The *BOR 01h.2, R1* statement logically ORs bit 2 of register 01h (destination) with bit 0 of R1 (source). This leaves the value 07h in register 01h.





## Bit Test, Jump Relative on False

| BTJRF         | dst, src.b                                                                                                                                                                                                                                                                         |            |              |              |        |        |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|--------------|--------------|--------|--------|
| Operation     | If src(b) is a 0, then PC $\leftarrow$ H                                                                                                                                                                                                                                           | PC + dst   |              |              |        |        |
|               | The specified bit within the source operand is tested. If this bit is 0, the relative address is added to the program counter, and control passes to the statement for which the address is now in the PC; otherwise, the instruction following the BTJRF instruction is executed. |            |              |              |        |        |
| Flags         | No flags are affected.                                                                                                                                                                                                                                                             |            |              |              |        |        |
| Format        |                                                                                                                                                                                                                                                                                    | Bytes      | Cycles       | Op Code      | Addres | s Mode |
|               |                                                                                                                                                                                                                                                                                    |            |              | (Hex)        | dst    | src    |
|               | opc dst   b   1 dst                                                                                                                                                                                                                                                                | 3          | 10           | 37           | RA     | rb     |
|               | Note: In the second byte of the bit address b is three b                                                                                                                                                                                                                           |            |              |              |        |        |
| Example       | Assume that $R1 = 07h$ .                                                                                                                                                                                                                                                           |            |              |              |        |        |
|               | BTJRF SKIP, R1.3 –                                                                                                                                                                                                                                                                 | → PC jı    | umps to Sk   | KIP location |        |        |
|               | If working register R1 contains the value 07h (00000111b), the <i>BTJRF SKIP</i> , <i>R1.3</i> statement tests bit 3. Because it is 0, the relative address is added to the PC and the PC jumps to the memory location pointed to by the SKIP.                                     |            |              |              |        |        |
|               |                                                                                                                                                                                                                                                                                    | •          | •            | •            |        |        |
| Note: The mem | nory location must be within the                                                                                                                                                                                                                                                   | he allowed | l range of - | +127 to −12  | 8.     |        |





## Bit Test, Jump Relative on True

| BTJRT         | dst, src.b                                                                                                                                                                                                                                                                    |             |              |             |        |        |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|-------------|--------|--------|
| Operation     | If src(b) is a 1, then PC $\leftarrow$ 1                                                                                                                                                                                                                                      | PC + dst    |              |             |        |        |
|               | The specified bit within the source operand is tested. If it is a 1, the relative address is added to the program counter and control passes to the statement for which the address is now in the PC; otherwise, the instruction following the BTJRT instruction is executed. |             |              |             |        |        |
| Flags         | No flags are affected.                                                                                                                                                                                                                                                        |             |              |             |        |        |
| Format        |                                                                                                                                                                                                                                                                               | Bytes       | Cycles       | Op Code     | Addres | s Mode |
|               |                                                                                                                                                                                                                                                                               |             |              | (Hex)       | dst    | src    |
|               | opc src   b   1 dst                                                                                                                                                                                                                                                           | 3           | 10           | 37          | RA     | rb     |
|               | Note: In the second byte of the instruction format, the source address is four bits, the bit address b is three bits, and the LSB address value is one bit in length.                                                                                                         |             |              |             |        |        |
| Example       | Assume that $R1 = 07h$ .                                                                                                                                                                                                                                                      |             |              |             |        |        |
|               | BTJRT SKIP, R1.1                                                                                                                                                                                                                                                              |             |              |             |        |        |
|               | If working register R1 contains the value 07h (00000111b), the <i>BTJRT SKIP</i> , <i>R1.1</i> statement tests bit 1 in the source register (R1). Because it is a 1, the relative address is added to the PC and the PC jumps to the memory location pointed to by the SKIP.  |             |              |             |        |        |
| Note: The mem | nory location must be within t                                                                                                                                                                                                                                                | the allowed | l range of - | +127 to -12 | 8.     |        |





### **Bit XOR**

| BXOR      | dst, src.b                                                                                                                                                                                                                                                                   |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BXOR      | dst.b, src                                                                                                                                                                                                                                                                   |
| Operation | $dst(0) \leftarrow dst(0) \text{ XOR } src(b)$<br>or<br>$dst(b) \leftarrow dst(b) \text{ XOR } src(0)$                                                                                                                                                                       |
|           | The specified bit of the source (or the destination) is logically exclusive-ORed with bit 0 (LSB) of the destination (or source). The result bit is stored in the specified bit of the destination. No other bits of the destination are affected. The source is unaffected. |
| Flags     | C Unaffected.                                                                                                                                                                                                                                                                |

- Ζ Set if the result is 0; cleared otherwise.
- S Cleared to 0.
- V Undefined.
- D Unaffected.
- н Unaffected.

#### Format

|     |             |     | Bytes | Cycles | Op Code | Addres | s Mode |
|-----|-------------|-----|-------|--------|---------|--------|--------|
|     |             |     |       |        | (Hex)   | dst    | src    |
| орс | dst   b   0 | src | 3     | 6      | 27      | r0     | Rb     |
|     | i           |     |       |        |         |        |        |
| орс | src  b   1  | dst | 3     | 6      | 27      | Rb     | r0     |

Note: In the second byte of the 3-byte instruction formats, the destination (or source) address is four bits, the bit address b is three bits, and the LSB address value is one bit in length.

#### Example

Assume that R1 = 07h (00000111b) and register 01h = 03h (00000011b).

| BXOR | R1, 01h.1 | $\rightarrow$ | R1 = 06h, register 01h = 03h |
|------|-----------|---------------|------------------------------|
| BXOR | 01h.2, R1 | $\rightarrow$ | Register 01h = 07h, R1 = 07h |

In the first example, destination working register R1 has the value 07h (00000111b) and source register 01h has the value 03h (00000011b). The BXOR R1, 01h.1 statement exclusive-ORs bit 1 of register 01h (source) with bit 0 of R1 (destination). The result bit value is stored in bit 0 of R1, changing its value from 07h to 06h. The value of source register 01h is unaffected.



109

### **Call Procedure**

~ • • •

| dst |                        |                                |
|-----|------------------------|--------------------------------|
| SP  | ←                      | SP-1                           |
| @SP | $\leftarrow$           | PCL                            |
| SP  | $\leftarrow$           | SP-1                           |
| @SP | $\leftarrow$           | PCH                            |
| PC  | $\leftarrow$           | dst                            |
|     | SP<br>@SP<br>SP<br>@SP | SP ←<br>@SP ←<br>SP ←<br>@SP ← |

The current contents of the program counter are pushed onto the top of the stack. The program counter value used is the address of the first instruction following the CALL instruction. The specified destination address is then loaded into the program counter and points to the first instruction of a procedure. At the end of the procedure the return instruction (RET) can be used to return to the original program flow. RET pops the top of the stack back into the program counter.

Flags No flags are affected.

#### Format

|     |     | Bytes | Cycles | Op Code | Address Mode |
|-----|-----|-------|--------|---------|--------------|
|     |     |       |        | (Hex)   | dst          |
| орс | dst | 3     | 14     | F6      | DA           |
|     |     |       |        |         |              |
| орс | dst | 2     | 12     | F4      | IRR          |
|     |     |       |        |         |              |
| орс | dst | 2     | 14     | D4      | IA           |

**Example** Assume that R0 = 35h, R1 = 21h, PC = 1A47h, and SP = 0002h.

| CALL | 3521h | $\rightarrow$ | SP = 0000h<br>(Memory locations 0000h = 1Ah, 0001h =<br>4Ah, in which 4Ah is the address that follows<br>the instruction.) |
|------|-------|---------------|----------------------------------------------------------------------------------------------------------------------------|
| CALL | @RR0  | $\rightarrow$ | SP = 0000h (0000h = 1Ah, 0001h = 49h)                                                                                      |
| CALL | #40h  | $\rightarrow$ | SP = 0000h (0000h = 1Ah, 0001h = 49h)                                                                                      |

In the first example, if the program counter value is 1A47h and the stack pointer contains the value 0002h, the *CALL 3521h* statement pushes the current PC value onto the top of the stack. The stack pointer now points to mem-

Embedded in Life

ory location 0000h. The PC is then loaded with the value 3521h, the address of the first instruction in the program sequence to be executed.

If the contents of the program counter and stack pointer are the same as in the first example, the *CALL* @*RR0* statement produces the same result except that the 49h is stored in stack location 0001h (because the two-byte instruction format is used). The PC is then loaded with the value 3521h, the address of the first instruction in the program sequence to be executed. Assuming that the contents of the program counter and stack pointer are the same as in the first example, if program address 0040h contains 35h and program address 0041h contains 21h, the *CALL #40h* statement produces the same result as in the second example.



## Complement Carry Flag

| CCF       |                                                                                                                                                                     |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation | $C \leftarrow NOT C$                                                                                                                                                |
|           | The carry flag (C) is complemented. If $C = 1$ , the value of the carry flag is changed to logic 0; if $C = 0$ , the value of the carry flag is changed to logic 1. |
| Flags     | C Complemented.<br>No other flags are affected.                                                                                                                     |
| Format    | Bytes Cycles Op Code<br>(Hex)                                                                                                                                       |
|           | opc 1 4 EF                                                                                                                                                          |
| Example   | Assume that the carry $flag = 0$ .                                                                                                                                  |
|           | CCF                                                                                                                                                                 |
|           | If the carry $flag = 0$ , the CCF instruction complements it in the Flags Register                                                                                  |

(0D5h), changing its value from logic 0 to logic 1.



y 112

### Clear

| CCF       | dst                |                                                                                                                                                                                                                                                          |                                                      |            |            |              |                   |  |  |
|-----------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|------------|------------|--------------|-------------------|--|--|
| Operation | $dst \leftarrow 0$ | C                                                                                                                                                                                                                                                        |                                                      |            |            |              |                   |  |  |
|           | The de             | stination location                                                                                                                                                                                                                                       | on is c                                              | cleared to | 0.         |              |                   |  |  |
| Flags     | No flag            | gs are affected.                                                                                                                                                                                                                                         |                                                      |            |            |              |                   |  |  |
| Format    |                    |                                                                                                                                                                                                                                                          |                                                      | Bytes      | Cycles     | Op Code      | Addr Mode         |  |  |
|           |                    |                                                                                                                                                                                                                                                          |                                                      |            |            | (Hex)        | dst               |  |  |
|           | орс                | dst                                                                                                                                                                                                                                                      |                                                      | 2          | 4          | B0           | R                 |  |  |
|           |                    |                                                                                                                                                                                                                                                          |                                                      |            | 4          | B1           | IR                |  |  |
| Example   | Assum              | e that Register                                                                                                                                                                                                                                          | 00h =                                                | 4Fh, regi  | ster 01h = | 02h, and reg | gister 02h = 5Eh. |  |  |
|           | CLR                | 00h                                                                                                                                                                                                                                                      | $\rightarrow$                                        | Regi       | ster 00h = | 00h          |                   |  |  |
|           | CLR                | @01h                                                                                                                                                                                                                                                     | $\rightarrow$ Register 01h = 02h, register 02h = 00h |            |            |              |                   |  |  |
|           | register           | In Register (R) Addressing Mode, the <i>CLR 00h</i> statement clears the destination register 00h value to 00h. In the second example, the <i>CLR @01h</i> statement uses Indirect Register (IR) Addressing Mode to clear the 02h register value to 00h. |                                                      |            |            |              |                   |  |  |





## Complement

| СОМ       | dst                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                              |                          |               |            |            |             |              |  |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|--------------------------|---------------|------------|------------|-------------|--------------|--|
| Operation | $dst \leftarrow NOT dst$                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                              |                          |               |            |            |             |              |  |
|           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | The contents of the destination location are complemented (one's comple-<br>ment); all 1s are changed to 0s, and vice-versa. |                          |               |            |            |             |              |  |
| Flags     | <ul> <li>C Unaffected.</li> <li>Z Set if the result is 0; cleared otherwise.</li> <li>S Set if the result bit 7 is set; cleared otherwise.</li> <li>V Always reset to 0.</li> <li>D Unaffected.</li> <li>H Unaffected.</li> </ul>                                                                                                                                                                                                                                                                   |                                                                                                                              |                          |               |            |            |             |              |  |
| Format    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                              |                          |               | Bytes      | Cycles     | Op Code     | Address Mode |  |
|           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                              |                          |               |            |            | (Hex)       | dst          |  |
|           | ор                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | )C                                                                                                                           | dst                      |               | 2          | 4          | 60          | R            |  |
|           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                              |                          |               |            | 4          | 61          | IR           |  |
| Example   | Assu                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | me t                                                                                                                         | hat $\mathbf{R}1 = 0.71$ | n and r       | egister 07 | h = 0F1h.  |             |              |  |
|           | CON                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Λ                                                                                                                            | R1                       | $\rightarrow$ | → R1 =     | 0F8h       |             |              |  |
|           | CON                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Λ                                                                                                                            | @R1                      |               | • R1 =     | 07h, regis | ter 07h = 0 | Eh           |  |
|           | COM @R1 $\rightarrow$ R1 = 07h, register 07h = 0Eh<br>In the first example, destination working register R1 contains the value 07h<br>(00000111b). The COM R1 statement complements all of the bits in R1: all<br>logic 1s are changed to logic 0s, and vice-versa, leaving the value 0F8h<br>(11111000b).<br>In the second example, Indirect Register (IR) Addressing Mode is used to com-<br>plement the value of destination register 07h (11110001b), leaving the new<br>value 0Eh (00001110b). |                                                                                                                              |                          |               |            |            |             |              |  |





### Compare

| СР        | dst, s                                                                                                                                                                                            | rc                                                                                                                                                                                                                                                   |           |   |       |        |         |          |        |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|---|-------|--------|---------|----------|--------|
| Operation | dst ←                                                                                                                                                                                             | - sr                                                                                                                                                                                                                                                 | c         |   |       |        |         |          |        |
|           | The source operand is compared to (subtracted from) the destination operand,<br>and the appropriate flags are set accordingly. The contents of both operands are<br>unaffected by the comparison. |                                                                                                                                                                                                                                                      |           |   |       |        |         |          |        |
| Flags     | C<br>Z<br>S<br>V<br>D<br>H                                                                                                                                                                        | Set if a borrow occurred (src > dst); cleared otherwise.<br>Set if the result is 0; cleared otherwise.<br>Set if the result is negative; cleared otherwise.<br>Set if arithmetic overflow occurred; cleared otherwise.<br>Unaffected.<br>Unaffected. |           |   |       |        |         |          |        |
| Format    |                                                                                                                                                                                                   |                                                                                                                                                                                                                                                      |           |   | Bytes | Cycles | Op Code | Addres   | s Mode |
|           | on                                                                                                                                                                                                | <u> </u>                                                                                                                                                                                                                                             | dst   src | ] | 2     | 4      | (Hex)   | dst<br>r | src    |

|   | орс | dst   src |     | 2 | 4 | A2 | r | r  |
|---|-----|-----------|-----|---|---|----|---|----|
| · |     |           |     |   | 6 | A3 | r | lr |
|   |     |           |     |   |   |    |   |    |
|   | орс | src       | dst | 3 | 6 | A4 | R | R  |
| • |     |           |     | J | 6 | A5 | R | IR |
|   |     |           |     |   |   |    |   |    |
| • | орс | dst       | SIC | 3 | 6 | A6 | R | IM |
|   | - 1 |           |     | - | - |    |   |    |

#### Example

1. Assume that R1 = 02h and R2 = 03h.

 $\label{eq:CP} \mathsf{CP} \qquad \mathsf{R1}, \mathsf{R2} \qquad \rightarrow \qquad \mathsf{Set \ the \ C \ and \ S \ flags}$ 

Destination working register R1 contains the value 02h and source register R2 contains the value 03h. The *CP R1, R2* statement subtracts the R2 value (source/subtrahend) from the R1 value (destination/minuend). Because a borrow occurs and the difference is negative, C and S are 1.

2. Assume that R1 = 05h and R2 = 0Ah

|      | CP  | R1, R2    |
|------|-----|-----------|
|      | JP  | UGE, SKIP |
|      | INC | R1        |
| SKIP | LD  | R3, R1    |



In this example, destination working register R1 contains the value 05h which is less than the contents of the source working register R2 (0Ah). The *CP R1*, *R2* statement generates C = 1 and the JP instruction does not jump to the SKIP location. After the *LD R3*, *R1* statement executes, the value 06h remains in working register R3.



Embedded in Life An DIXYS Company 116

### Compare, Increment, and Jump on Equal

| CPIJE     | dst, src, RA                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Operation | If $dst - src = 0$ , $PC \leftarrow PC + RA$                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
|           | $Ir \leftarrow Ir + 1$                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
|           | The source operand is compared to (subtracted from) the destination operand.<br>If the result is 0, the relative address is added to the program counter and con-<br>trol passes to the statement for which the address is now in the program coun-<br>ter. Otherwise, the instruction immediately following the CPIJE instruction is<br>executed. In either case, the source pointer is incremented by one before the<br>next instruction is executed.                           |  |  |  |  |  |  |
| Flags     | No flags are affected.                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
| Format    | Bytes Cycles Op Code Address Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
|           | opcdst   srcRA312C2rIrNote:Execution time is 18 cycles if the jump is taken or 16 cycles if it is not taken.                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
| Example   | Assume that $R1 = 02h$ , $R2 = 03h$ , and register $03h = 02h$ .                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
|           | CPIJE R1, @R2, SKIP $\rightarrow$ R2 = 04h, PC jumps to SKIP location                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
|           | In this example, working register R1 contains the value 02h, working register R2 the value 03h, and register 03 contains 02h. The <i>CPIJE R1</i> , @ <i>R2</i> , <i>SKIP</i> statement compares the @R2 value 02h (0000010b) to 02h (00000010b). Because the result of the comparison is equal, the relative address is added to the PC and the PC then jumps to the memory location pointed to by SKIP. The source register (R2) is incremented by one, leaving a value of 04h. |  |  |  |  |  |  |

**Note:** The memory location must be within the allowed range of +127 to -128.



### Compare, Increment, and Jump on NonEqual

| CPIJE     | dst, src, RA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Operation | If $dst - src = 0$ , $PC \leftarrow PC + RA$                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |
|           | $Ir \leftarrow Ir + 1$                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |
|           | The source operand is compared to (subtracted from) the destination operand.<br>If the result is 0, the relative address is added to the program counter and con-<br>trol passes to the statement for which the address is now in the program coun-<br>ter. Otherwise, the instruction immediately following the CPIJE instruction is<br>executed. In either case, the source pointer is incremented by one before the<br>next instruction is executed.                                      |  |  |  |  |  |  |  |
| Flags     | No flags are affected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |
| Format    | Bytes Cycles Op Code Address Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |
|           | (Hex) dst src                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |
|           | opc         dst   src         RA         3         12         C2         r         Ir           Note:         Execution time is 18 cycles if the jump is taken or 16 cycles if it is not taken.                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |
| Example   | Assume that $R1 = 02h$ , $R2 = 03h$ , and register $03h = 02h$ .                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |
|           | CPIJE R1, @R2, SKIP $\rightarrow$ R2 = 04h, PC jumps to SKIP location                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |
|           | Working register R1 contains the value 02h, working register R2 (the source pointer) the value 03h, and general register 03 the value 04h. The <i>CPIJNE I</i> @ <i>R2</i> , <i>SKIP</i> statement subtracts 04h (0000010b) from 02h (00000010b). Because the result of the comparison is nonequal, the relative address is add to the PC and the PC then jumps to the memory location pointed to by SKIP. The source pointer register (R2) is also incremented by one, leaving a value 04h. |  |  |  |  |  |  |  |

**Note:** The memory location must be within the allowed range of +127 to -128.

>





### **Decimal Adjust**

#### DA dst

**Operation** dst  $\leftarrow$  DA dst

The destination operand is adjusted to form two 4-bit BCD digits following an addition or subtraction operation. For addition (ADD, ADC) or subtraction (SUB, SBC), Table 31 indicates the operations performed. These operations are undefined if the destination operand is not the result of a valid addition or subtraction of BCD digits.

| Instruction | Carry<br>Before DA | Bits 4–7<br>Value (Hex) | H Flag<br>Before DA | Bits 0–3<br>Value (Hex) | Number<br>Added to Byte | Carry<br>After DA |
|-------------|--------------------|-------------------------|---------------------|-------------------------|-------------------------|-------------------|
| ADD         | 0                  | 0–9                     | 0                   | 0–9                     | 00                      | 0                 |
| ADC         | 0                  | 0–8                     | 0                   | A–F                     | 06                      | 0                 |
|             | 0                  | 0–9                     | 1                   | 0–3                     | 06                      | 0                 |
|             | 0                  | A–F                     | 0                   | 0–9                     | 60                      | 1                 |
|             | 0                  | 9–F                     | 0                   | A–F                     | 66                      | 1                 |
|             | 0                  | A–F                     | 1                   | 0–3                     | 66                      | 1                 |
|             | 1                  | 0–2                     | 0                   | 0–9                     | 60                      | 1                 |
|             | 1                  | 0–2                     | 0                   | A–F                     | 66                      | 1                 |
|             | 1                  | 0–3                     | 1                   | 0–3                     | 66                      | 1                 |
| SUB         | 0                  | 0–9                     | 0                   | 0–9                     | 00 =00                  | 0                 |
| SBC         | 0                  | 0–8                     | 1                   | 6–F                     | FA =06                  | 0                 |
|             | 1                  | 7–F                     | 0                   | 0–9                     | A0 =60                  | 1                 |
|             | 1                  | 6–F                     | 1                   | 6–F                     | 9A =-66                 | 1                 |

#### Table 31. DA Instruction

#### Flags

- C Set if there is a carry from the most significant bit; cleared otherwise (see Table 31).
- Z Set if result is 0; cleared otherwise.
- S Set if result bit 7 is set; cleared otherwise.
- V Undefined.
- D Unaffected.
- H Unaffected.



| Format  |                                                                                                                                                                                                                          |                        |          |          |            | On Code       | Address Mode  |  |  |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|----------|----------|------------|---------------|---------------|--|--|
|         |                                                                                                                                                                                                                          |                        |          | Bytes    | Cycles     | (Hex)         | dst           |  |  |
|         | орс                                                                                                                                                                                                                      | dst                    |          | 2        | 4          | 40            | R             |  |  |
|         | <u> </u>                                                                                                                                                                                                                 |                        |          |          | 4          | 41            | IR            |  |  |
| Example | Assume that Working register R0 contains the value 15 (BCD), working register R1 contains 27 (BCD), and address 27h contains 46 (BCD).                                                                                   |                        |          |          |            |               |               |  |  |
|         | ADD                                                                                                                                                                                                                      | R1, R0                 | ; C ← 0, | H ← 0,   | Bits 4–7 = | 3, bits 0–3 = | = C, R1 ← 3Ch |  |  |
|         | DA                                                                                                                                                                                                                       | R1                     | ; R1 ← 3 | 8Ch + 06 | i          |               |               |  |  |
|         | If addition is performed using the BCD values 15 and 27, the result should be 42. The sum is incorrect, however, when the binary representations are added in the destination location using standard binary arithmetic: |                        |          |          |            |               |               |  |  |
|         |                                                                                                                                                                                                                          | 000                    | 010 010  | 1        | 15         |               |               |  |  |
|         | +                                                                                                                                                                                                                        | 00                     | 10 011   | 1        | 27         |               |               |  |  |
|         |                                                                                                                                                                                                                          | 00                     | 11 110   | 0 =      | 3Ch        |               |               |  |  |
|         | The DA instruction adjusts this result so that the correct BCD representation is obtained:                                                                                                                               |                        |          |          |            |               |               |  |  |
|         | +                                                                                                                                                                                                                        | 00 <sup>.</sup><br>00( |          |          |            |               |               |  |  |
|         | •                                                                                                                                                                                                                        | 000                    | 50 011   | 0        |            |               |               |  |  |

| Assuming the same values given above, the following statements leave the |
|--------------------------------------------------------------------------|
| value 31 (BCD) in address 27h (@R1).                                     |

=

42

| SUB | 27h, R0 | ; C $\leftarrow$ 0, H $\leftarrow$ 0, Bits 4–7 = 3, bits 0–3 = 1 |
|-----|---------|------------------------------------------------------------------|
| DA  | @R1     | ; @R1 ← 31–0                                                     |

0010

0100





### Decrement

| DEC       | dst                                                                                                                                                                                  |                     |               |           |              |            |              |  |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|---------------|-----------|--------------|------------|--------------|--|
| Operation | $dst \leftarrow dst - 1$                                                                                                                                                             |                     |               |           |              |            |              |  |
|           | The c                                                                                                                                                                                | ontents of the dest | inatic        | on operai | nd are decre | emented by | one.         |  |
| Flags     | <ul> <li>C Unaffected.</li> <li>Z Set if the result is 0; cleared otherwise.</li> <li>S Cleared to 0.</li> <li>V Undefined.</li> <li>D Unaffected.</li> <li>H Unaffected.</li> </ul> |                     |               |           |              |            |              |  |
| Format    |                                                                                                                                                                                      |                     |               | Bytes     | Cycles       | Op Code    | Address Mode |  |
|           |                                                                                                                                                                                      |                     |               |           |              | (Hex)      | dst          |  |
|           | ор                                                                                                                                                                                   | c dst               |               | 2         | 4            | 00         | R            |  |
|           |                                                                                                                                                                                      | ,                   |               |           | 4            | 01         | IR           |  |
| Example   | Assume that $R1 = 03h$ and register $03h = 10h$ .                                                                                                                                    |                     |               |           |              |            |              |  |
|           | DEC                                                                                                                                                                                  | R1                  | $\rightarrow$ | R1 =      | = 02h        |            |              |  |
|           | DEC                                                                                                                                                                                  | @R1                 | $\rightarrow$ | Reg       | ister 03h =  | 0Fh        |              |  |

In the first example, if working register R1 contains the value 03h, the *DEC R1* statement decrements the hexadecimal value by one, leaving the value 02h. In the second example, the *DEC* @*R1* statement decrements the value 10h contained in the destination register 03h by one, leaving the value 0Fh.





### **Decrement Word**

| DECW      | dst                                                                                                                                                                                                                                                                   |      |                                                      |        |         |              |  |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------------------------------------------------|--------|---------|--------------|--|
| Operation | $dst \leftarrow dst - 1$                                                                                                                                                                                                                                              |      |                                                      |        |         |              |  |
|           | The contents of the destination location (which must be an even address) and<br>the operand following that location are treated as a single 16-bit value that is<br>decremented by one.                                                                               |      |                                                      |        |         |              |  |
| Flags     | <ul> <li>C Unaffected.</li> <li>Z Set if the result is 0; cleared otherwise.</li> <li>S Set if the result is negative; cleared otherwise.</li> <li>V Set if arithmetic overflow occurred; cleared otherwise.</li> <li>D Unaffected.</li> <li>H Unaffected.</li> </ul> |      |                                                      |        |         |              |  |
| Format    |                                                                                                                                                                                                                                                                       |      | Bytes                                                | Cycles | Op Code | Address Mode |  |
|           |                                                                                                                                                                                                                                                                       |      |                                                      |        | (Hex)   | dst          |  |
|           | орс                                                                                                                                                                                                                                                                   | dst  | 2                                                    | 8      | 80      | RR           |  |
|           |                                                                                                                                                                                                                                                                       |      |                                                      | 8      | 81      | IR           |  |
| Example   | Assume that $R0 = 12h$ , $R1 = 34h$ , $R2 = 30h$ , register $30h = 0Fh$ , and register $31h = 21h$ .                                                                                                                                                                  |      |                                                      |        |         |              |  |
|           | DECW RR0 $\rightarrow$ R0 = 12h, R1 = 33h                                                                                                                                                                                                                             |      |                                                      |        |         |              |  |
|           | DECW                                                                                                                                                                                                                                                                  | @R2  | $\rightarrow$ Register 30h = 0Fh, register 31h = 20h |        |         |              |  |
|           | In the first example, destination register R0 contains the value 12h and register R1 the value 34h. The <i>DECW RR0</i> statement addresses R0 and the following operand R1 as a 16-bit word and decrements the value of R1 by one, leaving the value 33h.            |      |                                                      |        |         |              |  |
| Note      | A system malfunction may occur if you use a Zero flag (FLAGS.6) result together with a DECW instruction. To avoid this problem, Zilog recommends that you use DECW as shown in the following example:                                                                 |      |                                                      |        |         |              |  |
|           | LOOP:                                                                                                                                                                                                                                                                 | DECW | RR0                                                  |        |         |              |  |
|           |                                                                                                                                                                                                                                                                       | LD   | R2, R1                                               |        |         |              |  |
|           |                                                                                                                                                                                                                                                                       | OR   | R2, R0                                               |        |         |              |  |
|           |                                                                                                                                                                                                                                                                       | JR   | NZ, LOOP                                             |        |         |              |  |





## **Disable Interrupts**

| DI        |                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Operation | SYM (0) ← 0                                                                                                                                                                                                                                                                     |  |  |  |  |  |
|           | Bit 0 of the System Mode Control Register, SYM.0, is cleared to 0, globally disabling all interrupt processing. Interrupt requests will continue to set their respective interrupt pending bits; however, the CPU will not service them while interrupt processing is disabled. |  |  |  |  |  |
| Flags     | No flags are affected.                                                                                                                                                                                                                                                          |  |  |  |  |  |
| Format    | Bytes Cycles Op Code                                                                                                                                                                                                                                                            |  |  |  |  |  |
|           | (Hex)                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|           | opc 1 4 8F                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| Example   | Assume that $SYM = 01h$ .                                                                                                                                                                                                                                                       |  |  |  |  |  |
|           | DI                                                                                                                                                                                                                                                                              |  |  |  |  |  |
|           | If the value of the SYM Register is 01h, the <i>DI</i> statement leaves the new value 00h in the register and clears SYM.0 to 0, disabling interrupt processing.                                                                                                                |  |  |  |  |  |
|           | Execute a DI instruction prior to changing the Interrupt Mask (IMR) Interrupt                                                                                                                                                                                                   |  |  |  |  |  |

Execute a DI instruction prior to changing the Interrupt Mask (IMR), Interrupt Pending (IPR), and Interrupt Request (IRQ) registers.





### Divide (Unsigned)

| DIV       | dst, src                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Operation | dst ÷ src                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |
|           | dst (UPPER) $\leftarrow$ REMAINDER                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |
|           | dst (LOWER) $\leftarrow$ QUOTIENT                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |
|           | The destination operand (16 bits) is divided by the source operand (8 bits). The quotient (8 bits) is stored in the lower half of the destination. The remainder (8 bits) is stored in the upper half of the destination. When the quotient is "d 28, the numbers stored in the upper and lower halves of the destination for quotient and remainder are incorrect. Both operands are treated as unsigned integers. |  |  |  |  |  |  |  |
| Flags     | <ul> <li>C Set if the V flag is set and quotient is between 2<sup>8</sup> and 2<sup>9</sup> – 1; cleared otherwise.</li> <li>Z Set if divisor or quotient = 0; cleared otherwise.</li> <li>S Set if MSB of quotient = 1; cleared otherwise.</li> <li>V Set if quotient is ≥ 28 or if divisor = 0; cleared otherwise.</li> </ul>                                                                                     |  |  |  |  |  |  |  |
|           | <ul><li>D Unaffected.</li><li>H Unaffected.</li></ul>                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |
|           |                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |
| Format    | Bytes Cycles Op Code Address Mode                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |
|           | (Hex) dst src                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |
|           | opc src dst 3 26/10 94 RR R                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |
|           | 26/10 95 RR IR                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |
|           | 26/10 96 RR IM                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |
|           | Note: Execution takes 10 cycles if the divide-by-zero is attempted; otherwise it takes 26 cycles.                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |

**Example** Assume that R0 = 10h, R1 = 03h, R2 = 40h, register 40h = 80h.

| DIV | RR0, R2   | $\rightarrow$ | R0 = 03h, R1 = 40h |
|-----|-----------|---------------|--------------------|
| DIV | RR0, @R2  | $\rightarrow$ | R0 = 03h, R1 = 20h |
| DIV | RR0, #20h | $\rightarrow$ | R0 = 03h, R1 = 80h |

In the first example, destination working register pair RR0 contains the values 10h (R0) and 03h (R1), and register R2 contains the value 40h. The *DIV RR0, R2* statement divides the 16-bit RR0 value by the 8-bit value of the R2 (source) register. After the DIV instruction, R0 contains the value 03h and R1 contains



40h. The 8-bit remainder is stored in the upper half of the destination register RR0 (R0) and the quotient in the lower half (R1).





## Decrement and Jump if NonZero

| DJNZ      | r, dst                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation | $r \leftarrow r - 1$                                                                                                                                                                                                                                                                                                                                                                                                                               |
|           | If $r \neq 0$ , PC $\leftarrow$ PC + dst                                                                                                                                                                                                                                                                                                                                                                                                           |
|           | The working register being used as a counter is decremented. If the contents of the register are not logic 0 after decrementing, the relative address is added to the program counter and control passes to the statement for which the address is now in the PC. The range of the relative address is $+127$ to $-128$ , and the original value of the PC is taken to be the address of the instruction byte following the <i>DJNZ</i> statement. |

**Note:** In case of using DJNZ instruction, the working register being used as a counter should be set at the one of location 0C0h to 0CFh with SRP, SRP0, or SRP1 instruction.

| Flags   | No flags               | are affected.                      |                          |                                        |               |                                                             |
|---------|------------------------|------------------------------------|--------------------------|----------------------------------------|---------------|-------------------------------------------------------------|
| Format  |                        |                                    | Bytes                    | Cycles                                 | Op Code       | Address Mode                                                |
|         |                        |                                    |                          |                                        | (Hex)         | dst                                                         |
|         | r   opc                | dst                                | 2                        | 8 (jump taken)                         | rA            | RA                                                          |
|         |                        |                                    |                          | 8 (no jump)                            | r = 0 to F    |                                                             |
| Example | Assume<br>SRP<br>DJNZ  | that R1 = 02h<br>#0C0h<br>R1, LOOP | and LOC                  | P is the label of                      | a relative ad | ddress.                                                     |
|         | is used a<br>In the ex | s the destination                  | on operan<br>1g register | d instead of a nu                      | meric relati  | nany cases, a label<br>ve address value.<br>and LOOP is the |
|         |                        |                                    |                          | decrements regist<br>of R1 after the o | •             | •                                                           |

jump is taken to the relative address specified by the LOOP label.





# Enable Interrupts

#### ΕI

| Operation | -                           | ced as the ing bit is s | y occur (as<br>et while in | suming they have highest pri-<br>terrupt processing is disabled |
|-----------|-----------------------------|-------------------------|----------------------------|-----------------------------------------------------------------|
| Flags     | No flags are affected.      |                         |                            |                                                                 |
| Format    |                             | Bytes                   | Cycles                     | Op Code                                                         |
|           |                             |                         |                            | (Hex)                                                           |
|           | орс                         | 1                       | 4                          | 9F                                                              |
| Example   | Assume that $SYM = 00h$ .   |                         |                            |                                                                 |
|           | EI                          |                         |                            |                                                                 |
|           | If the SYM Register contain | ns the valu             | e 00h, i.e.                | , if interrupts are currently dis-                              |

(SYM.0 is the enable bit for global interrupt processing.)

abled, the *EI* statement sets the SYM Register to 01h, enabling all interrupts.



klod In Life

IN DIXYS Company

### Enter

#### ENTER

(

| SP  | ←               | SP-2                  |
|-----|-----------------|-----------------------|
| @SP | $\leftarrow$    | IP                    |
| IP  | $\leftarrow$    | PC                    |
| PC  | $\leftarrow$    | @IP                   |
| IP  | $\leftarrow$    | IP + 2                |
|     | @SP<br>IP<br>PC | @SP ←<br>IP ←<br>PC ← |

This instruction is useful when implementing threaded-code languages. The contents of the instruction pointer are pushed to the stack. The program counter (PC) value is then written to the instruction pointer. The program memory word that is pointed to by the instruction pointer is loaded into the PC, and the instruction pointer is incremented by two.

**Flags** No flags are affected.

| Format |     | Bytes | Cycles | Op Code |
|--------|-----|-------|--------|---------|
|        |     |       |        | (Hex)   |
|        | орс | 1     | 14     | 1F      |

Example

Figure 48 shows an example of how to use an ENTER statement.







kloci in Life

IN DIXYS Company

### Exit

#### EXIT

| Operation | IP | $\leftarrow$ | @SP    |
|-----------|----|--------------|--------|
|           | SP | $\leftarrow$ | SP + 2 |
|           | PC | $\leftarrow$ | @IP    |
|           | IP | $\leftarrow$ | IP + 2 |

This instruction is useful when implementing threaded-code languages. The stack value is popped and loaded into the instruction pointer. The program memory word that is pointed to by the instruction pointer is then loaded into the program counter, and the instruction pointer is incremented by two.

#### Flags No flags are affected.

| Format | Bytes | Cycles              | Op Code |
|--------|-------|---------------------|---------|
|        |       |                     | (Hex)   |
| opc    | 1     | 14 (internal stack) | 2F      |
|        |       | 16 (internal stack) |         |

Example

Figure 49 shows an example of how to use an *EXIT* statement.







## any 129

# **Idle Operation**

| IDLE      |                              |          |            |                                                                   |
|-----------|------------------------------|----------|------------|-------------------------------------------------------------------|
| Operation | 1                            |          |            | allowing system clock oscilla-<br>n interrupt request (IRQ) or an |
| Flags     | No flags are affected.       |          |            |                                                                   |
| Format    |                              | Bytes    | Cycles     | Op Code                                                           |
|           |                              |          |            | (Hex)                                                             |
|           | орс                          | 1        | 4          | 6F                                                                |
| Example   | The IDLE instruction stops t | he CPU c | lock but n | ot the system clock.                                              |





### Increment

| INC       | dst                                                                                                                                                                                                                                                                   |                          |                  |               |               |              |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|------------------|---------------|---------------|--------------|
| Operation | dst ← ds                                                                                                                                                                                                                                                              | $dst \leftarrow dst + 1$ |                  |               |               |              |
|           | The cont                                                                                                                                                                                                                                                              | tents of the destin      | nation opera     | and are incre | emented by o  | one.         |
| Flags     | <ul> <li>C Unaffected.</li> <li>Z Set if the result is 0; cleared otherwise.</li> <li>S Set if the result is negative; cleared otherwise.</li> <li>V Set if arithmetic overflow occurred; cleared otherwise.</li> <li>D Unaffected.</li> <li>H Unaffected.</li> </ul> |                          |                  |               |               |              |
| Format    |                                                                                                                                                                                                                                                                       |                          | Bytes            | Cycles        | Op Code       | Address Mode |
|           |                                                                                                                                                                                                                                                                       |                          |                  |               | (Hex)         | dst          |
|           | dst   src                                                                                                                                                                                                                                                             | ;                        | 1                | 4             | rE            | r            |
|           |                                                                                                                                                                                                                                                                       |                          |                  |               | r = 0 to F    |              |
|           | орс                                                                                                                                                                                                                                                                   | dst                      | 2                | 4             | 20            | R            |
|           | <u> </u>                                                                                                                                                                                                                                                              |                          |                  | 4             | 21            | IR           |
| Example   | Assume                                                                                                                                                                                                                                                                | that $R0 = 1Bh$ , re     | egister 00h      | = 0Ch, and    | register 1Bh  | n = 0Fh.     |
|           | INC                                                                                                                                                                                                                                                                   | R0                       | $\rightarrow$ R0 | = 1Ch         |               |              |
|           | INC                                                                                                                                                                                                                                                                   | 00h                      | → Re             | gister 00h =  | 0Dh           |              |
|           | INC                                                                                                                                                                                                                                                                   | @R0                      | $\rightarrow$ R0 | = 1Bh, regis  | ster 01h = 10 | Dh           |
|           | In the first example, if destination working register R0 contains the value 1Bh, the <i>INC R0</i> statement leaves the value 1Ch in that same register.                                                                                                              |                          |                  |               |               |              |
|           | The next example shows the effect an INC instruction has on register 00h, assuming that it contains the value 0Ch.                                                                                                                                                    |                          |                  |               |               |              |

In the third example, INC is used in Indirect Register (IR) Addressing Mode to increment the value of register 1Bh from 0Fh to 10h.





# **Increment Word**

| INCW      | dst                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                       |             |                          |                        |  |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------------------|------------------------|--|
| Operation | $dst \leftarrow dst + 1$                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                       |             |                          |                        |  |
|           |                                                                                                                                                                                                                                                                                                                                                                                                                                       | The contents of the destination (which must be an even address) and the byte following that location are treated as a single 16-bit value that is incremented by one. |             |                          |                        |  |
| Flags     | <ul> <li>C Unaffected.</li> <li>Z Set if the result is 0; cleared otherwise.</li> <li>S Set if the result is negative; cleared otherwise.</li> <li>V Set if arithmetic overflow occurred; cleared otherwise.</li> <li>D Unaffected.</li> <li>H Unaffected.</li> </ul>                                                                                                                                                                 |                                                                                                                                                                       |             |                          |                        |  |
| Format    |                                                                                                                                                                                                                                                                                                                                                                                                                                       | Bytes                                                                                                                                                                 | Cycles      | Op Code                  | Address Mode           |  |
|           | opc dst                                                                                                                                                                                                                                                                                                                                                                                                                               | 2                                                                                                                                                                     | 8<br>8      | <b>(Hex)</b><br>A0<br>A1 | <b>dst</b><br>RR<br>IR |  |
| Example   | Assume that $R0 = 1Ah$ 0FFh.                                                                                                                                                                                                                                                                                                                                                                                                          | ., R1 = 02h, regi                                                                                                                                                     | ister 02h = | = 0Fh, and r             | egister 03h =          |  |
|           | INCW RR0                                                                                                                                                                                                                                                                                                                                                                                                                              | $\rightarrow$ R0 =                                                                                                                                                    | 1Ah, R1 =   | = 03h                    |                        |  |
|           | INCW @R1                                                                                                                                                                                                                                                                                                                                                                                                                              | $\rightarrow$ Regis                                                                                                                                                   | ster 02h =  | 10h, registe             | er 03h = 00h           |  |
|           | In the first example, the working register pair RR0 contains the value 1Ah in register R0 and 02h in register R1. The <i>INCW RR0</i> statement increments the 16-bit destination by one, leaving the value 03h in register R1. In the second example, the <i>INCW @R1</i> statement uses Indirect Register (IR) Addressing Mode to increment the contents of general register 03h from 0FFh to 00h and register 02h from 0Fh to 10h. |                                                                                                                                                                       |             |                          |                        |  |
| with an I | n malfunction may occur<br>NCW instruction. To ave                                                                                                                                                                                                                                                                                                                                                                                    | oid this problem                                                                                                                                                      |             |                          |                        |  |

as shown in the following example:

### S3F8S5A Product Specification



132

| LOOP: | INCW | RR0      |
|-------|------|----------|
|       | LD   | R2, R1   |
|       | OR   | R2, R0   |
|       | JR   | NZ, LOOP |





### Interrupt Return

**IRET** IRET (Normal), IRET (FAST)

| Operation | FLAGS   | ←                 | @SP    |
|-----------|---------|-------------------|--------|
|           | SP      | $\leftarrow$      | SP + 1 |
|           | PC      | $\leftarrow$      | @SP    |
|           | SP      | $\leftarrow$      | SP + 2 |
|           | SYM (0) | $\leftarrow$      | 1      |
|           | PC      | $\leftrightarrow$ | IP     |
|           | FLAGS   | $\leftarrow$      | FLAGS  |
|           | FIS     | $\leftarrow$      | 0      |
|           |         |                   |        |

This instruction is used at the end of an interrupt service routine. It restores the Flags Register and the program counter. It also reenables global interrupts. A *normal IRET* is executed only if the fast interrupt status bit (FIS, bit 1 of the Flags Register, 0D5h) is cleared (= 0). If a fast interrupt occurred, IRET clears the FIS bit that is set at the beginning of the service routine.

**Flags** All flags are restored to their original settings (i.e., the settings before the interrupt occurred).

| Format | IRET (Normal) | Bytes      | Cycles              | Op Code (Hex)        |
|--------|---------------|------------|---------------------|----------------------|
|        | орс           | 1          | 10 (internal stack) | BF                   |
|        |               |            | 12 (internal stack) |                      |
|        | IRET (Fast)   | Bytes<br>1 | Cycles<br>6         | <b>Op Code</b><br>BF |

**Example** In the Figure 50, the instruction pointer is initially loaded with 100h in the main program before interrupts are enabled. When an interrupt occurs, the program counter and instruction pointer are swapped, causing the PC to jump to address 100h and the IP to keep the return address.



DIXYS Company





**Note:** In the fast interrupt example above, if the last instruction is not a jump to IRET, you must pay attention to the order of the last two instructions. The IRET cannot be immediately proceeded by a clearing of the interrupt status (as with a reset of the IPR Register).

The last instruction in the service routine normally is a jump to IRET at address FFh. This causes the instruction pointer to be loaded with 100h again and the program counter to jump back to the main program. Now, the next interrupt can occur and the IP is still correct at 100h.

>





### Jump

| JP        | cc, dst (Conditional)                                                                                                                                                                                                                                                                                                                                                                             |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| JP        | dst (Unconditional)                                                                                                                                                                                                                                                                                                                                                                               |
| Operation | If cc is true, $PC \leftarrow dst$                                                                                                                                                                                                                                                                                                                                                                |
|           | The conditional JUMP instruction transfers program control to the destination address if the condition specified by the condition code (cc) is true; otherwise, the instruction following the JP instruction is executed. The unconditional JP simply replaces the contents of the PC with the contents of the specified register pair. Control then passes to the statement addressed by the PC. |

#### Flags No flags are affected.

#### Format

|                       |     | Bytes <sup>1</sup> | Cycles | Op Code<br>(Hex) | Address Mode<br>dst |
|-----------------------|-----|--------------------|--------|------------------|---------------------|
| cc   opc <sup>2</sup> | dst | 3                  | 8      | ccD              | DA                  |
| ·                     |     |                    | 6      | cc = 0 to F      |                     |
| opc                   | src | 2                  | 8      | 30               | IRR                 |

Notes:

1. The 3-byte format is used for a conditional jump and the 2-byte format for an unconditional jump.

2. In the first byte of the three-byte instruction format (conditional jump), the condition code and the op code are both four bits.

| Example | Assume | that the carry fla | ag (C) =      | = 1, register $00 = 01h$ and register $01 = 20h$ . |
|---------|--------|--------------------|---------------|----------------------------------------------------|
|         | JP     | C, LABEL_W         | $\rightarrow$ | LABEL_W = 1000h, PC = 1000h                        |
|         | JP     | @00h               | $\rightarrow$ | PC = 0120h                                         |

The first example shows a conditional JP. Assuming that the carry flag is set to 1, the *JP C*, *LABEL\_W* statement replaces the contents of the PC with the value 1000h and transfers control to that location. Had the carry flag not been set, control would then have passed to the statement immediately following the JP instruction.

The second example shows an unconditional JP. The JP @00 statement replaces the contents of the PC with the contents of the register pair 00h and 01h, leaving the value 0120h.





# Jump Relative

| JR        | cc, dst                                                                                                                                                                                                                                                                                                                                          |                                       |                  |              |                |                                                          |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|------------------|--------------|----------------|----------------------------------------------------------|
| Operation | If cc is tr                                                                                                                                                                                                                                                                                                                                      | ue, PC $\leftarrow$ PC +              | dst              |              |                |                                                          |
|           | If the condition specified by the condition code (cc) is true, the relative address is added to the program counter and control passes to the statement for which the address is now in the program counter; otherwise, the instruction following the JR instruction is executed; see the list of condition codes in <u>Table 30</u> on page 93. |                                       |                  |              |                |                                                          |
|           | The range of the relative address is $+127$ , $-128$ , and the original value of the program counter is taken to be the address of the first instruction byte following the <i>JR</i> statement.                                                                                                                                                 |                                       |                  |              |                |                                                          |
| Flags     | No flags are affected.                                                                                                                                                                                                                                                                                                                           |                                       |                  |              |                |                                                          |
| Format    |                                                                                                                                                                                                                                                                                                                                                  |                                       | Bytes            | Cycles       | Op Code        | Address Mode                                             |
|           | *                                                                                                                                                                                                                                                                                                                                                |                                       |                  |              | (Hex)          | dst                                                      |
|           | cc   opc                                                                                                                                                                                                                                                                                                                                         | dst                                   | 2                | 6            | ccb            | RA                                                       |
|           |                                                                                                                                                                                                                                                                                                                                                  |                                       |                  |              | cc = 0 to F    |                                                          |
|           |                                                                                                                                                                                                                                                                                                                                                  | the first byte of the are each four l |                  | struction fo | rmat, the cond | ition code and the op                                    |
| Example   | Assume t                                                                                                                                                                                                                                                                                                                                         | hat the carry fla                     | ag = 1 and L     | ABEL_X       | = 1FF7h.       |                                                          |
|           | JR                                                                                                                                                                                                                                                                                                                                               | C, LABEL_X                            | $\rightarrow$ PC | = 1FF7h      |                |                                                          |
|           | statement                                                                                                                                                                                                                                                                                                                                        | passes control                        | to the stater    | ment for w   | hich the addr  | JR C, LABEL_X<br>ress is now in the<br>buld be executed. |



Embedded in Life An DIXYS Company 137

### Load

| LD        | dst, src                                                                                          |                        |     |       |        |            |        |        |
|-----------|---------------------------------------------------------------------------------------------------|------------------------|-----|-------|--------|------------|--------|--------|
| Operation | dst ← src                                                                                         |                        |     |       |        |            |        |        |
|           | The contents of the source are loaded into the destination. The source's contents are unaffected. |                        |     |       |        |            |        |        |
| Flags     | No flags a                                                                                        | No flags are affected. |     |       |        |            |        |        |
| Format    |                                                                                                   |                        |     | Bytes | Cycles | Op Code    | Addres | s Mode |
|           |                                                                                                   |                        |     |       |        | (Hex)      | dst    | src    |
|           | dst   src                                                                                         | src                    |     | 2     | 4      | rC         | r      | IM     |
|           | <u>.</u>                                                                                          |                        |     |       | 4      | r8         | r      | R      |
|           | src   opc                                                                                         | dst                    |     | 2     | 4      | r9         | R      | r      |
|           |                                                                                                   |                        |     |       |        | r = 0 to F |        |        |
|           | орс                                                                                               | dst   src              |     | 2     | 4      | C7         | r      | Ir     |
|           |                                                                                                   |                        |     |       | 4      | D7         | lr     | r      |
|           | орс                                                                                               | src                    | dst | 3     | 6      | E4         | R      | R      |
|           |                                                                                                   |                        |     |       | 6      | E5         | R      | IR     |
|           | орс                                                                                               | dst                    | src | 3     | 6      | E6         | R      | IM     |
|           |                                                                                                   |                        |     |       | 6      | D6         | IR     | IM     |
|           | орс                                                                                               | SrC                    | dst | 3     | 6      | F5         | IR     | R      |
|           | T                                                                                                 |                        |     |       |        |            |        |        |
|           | орс                                                                                               | dst   src              | х   | 3     | 6      | 87         | r      | x[r]   |
|           | орс                                                                                               | src   dst              | Х   | 3     | 6      | 97         | x[r]   | r      |

### Example

Assume that R0 = 01h, R1 = 0Ah, register 00h = 01h, register 01h = 20h, register 02h = 02h, LOOP = 30h and register 3Ah = 0FFh.

| LD | R0, #10h | $\rightarrow$ | R0 = 10h                     |
|----|----------|---------------|------------------------------|
| LD | R0, 01h  | $\rightarrow$ | R0 = 20h, register 01h = 20h |
| LD | 01h, R0  | $\rightarrow$ | Register 01h = 01h, R0 = 01h |

#### S3F8S5A **Product Specification**



| ilug            |     |
|-----------------|-----|
| backlad in Life | 400 |
| XYS Company     | 138 |
|                 |     |

| LD | R1, @R0   | $\rightarrow$ | R1 = 20h, R0 = 01h                          |
|----|-----------|---------------|---------------------------------------------|
| LD | @R0, R1   | $\rightarrow$ | R0 = 01h, $R1 = 0Ah$ , register $01h = 0Ah$ |
| LD | 00h, 01h  | $\rightarrow$ | Register 00h = 20h, register 01h = 20h      |
| LD | 02h, @00h | $\rightarrow$ | Register 02h = 20h, register 00h = 01h      |
| LD | 00h, #0Ah | $\rightarrow$ | Register 00h = 0Ah                          |
|    |           |               |                                             |

- LD @00h, #10h  $\rightarrow$  Register 00h = 01h, register 01h = 10h
- LD @00h, 02h  $\rightarrow$  Register 00h = 01h, register 01h = 02, register 02h = 02h
- LD R0, #LOOP[R1]  $\rightarrow$  R0 = 0FFh, R1 = 0Ah
- LD #LOOP[R0], R1  $\rightarrow$  Register 31h = 0Ah, R0 = 01h, R1 = 0Ah





### Load Bit

| LDB       | dst, src.b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LDB       | dst.b, src                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Operation | dst(0) ← src(b)<br>or<br>dst(b) ← src(0)<br>The specified bit of the source is loaded into bit 0 (LSB) of the destination, or<br>bit 0 of the source is loaded into the specified bit of the destination. No other<br>bits of the destination are affected. The source is unaffected.                                                                                                                                                                                                         |
| Flags     | No flags are affected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Format    | Bytes Cycles Op Code Address Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|           | opc       dst       b   0       src       3       6       47       r0       Rb         opc       src   b   1       dst       3       6       47       Rb       r0         Note:       In the second byte of the instruction formats, the destination (or source) address is four bits, the bit address b is three bits, and the LSB address value is one bit in length.                                                                                                                       |
| Example   | Assume that $R0 = 06h$ and general register $00h = 05h$ .<br>LDB R0, $00h.2 \rightarrow R0 = 07h$ , register $00h = 05h$<br>LDB $00h.0, R0 \rightarrow R0 = 06h$ , register $00h = 04h$<br>In the first example, destination working register R0 contains the value $06h$<br>and the source general register $00h$ the value $05h$ . The <i>LD R0, 00h.2</i> statement<br>loads the bit 2 value of the 00h register into bit 0 of the R0 register, leaving the<br>value $07h$ in register R0. |

In the second example, 00h is the destination register. The *LD 00h.0, R0* statement loads bit 0 of register R0 to the specified bit (bit 0) of the destination register, leaving 04h in general register 00h.





# Load Memory

LDC/LDE dst, src

Operation  $dst \leftarrow src$ 

> This instruction loads a byte from program or data memory into a working register or vice-versa. The source values are unaffected. LDC refers to program memory and LDE to data memory. The assembler causes Irr or rr values to be even numbers for program memory and odd numbers for data memory.

Flags

No flags are affected.

#### Format

|                                  | Bytes             | Cycles | Op Code            | Addres   | s Mode            |
|----------------------------------|-------------------|--------|--------------------|----------|-------------------|
| opc dst   src                    | 2                 | 10     | <b>(Hex)</b><br>C3 | dst<br>r | <b>src</b><br>Irr |
| opc src   dst                    | 2                 | 10     | D3                 | Irr      | r                 |
| opc dst   src XS                 | 3                 | 12     | E7                 | r        | XS[rr]            |
| opc src   dst XS                 | 3                 | 12     | F7                 | XS[rr]   | r                 |
| opc dst   src XLL                | XL <sub>H</sub> 4 | 14     | A7                 | r        | XL[rr]            |
| opc src   dst XLL                | XL <sub>H</sub> 4 | 14     | B7                 | XL[rr]   | r                 |
| opc dst   0000 DA <sub>L</sub> [ | DA <sub>H</sub> 4 | 14     | A7                 | r        | DA                |
| opc src   0000 DA <sub>L</sub> [ | DA <sub>H</sub> 4 | 14     | B7                 | DA       | r                 |
| opc dst   0001 DAL [             | DA <sub>H</sub> 4 | 14     | A7                 | r        | DA                |





|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                              | Bytes                 | Cycles                    | Op Code                                    | Addres                    | s Mode   |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|-----------------------|---------------------------|--------------------------------------------|---------------------------|----------|--|
| opc s                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | src   0001 DA <sub>L</sub> DA <sub>H</sub>                                   | 4                     | 14                        | <b>(Hex)</b><br>B7                         | <b>dst</b><br>DA          | src<br>r |  |
| <ol> <li>Note:         <ol> <li>The source (src) or working register pair[rr] for formats 5 and 6 cannot use register pair 0–1.</li> <li>For formats 3 and 4, the destination address XS[rr] and the source address XS[rr] are each one byte.</li> <li>For formats 5 and 6, the destination address XL[rr] and the source address XL[rr] are each two bytes.</li> </ol> </li> <li>The DA and r source values for formats 7 and 8 are used to address program memory; the second set of values, used in formats 9 and 10, are used to address data memory.</li> </ol> |                                                                              |                       |                           |                                            |                           |          |  |
| tions 02                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | that $R0 = 11h$ , $R1 = 103h = 4Fh$ , $0104h = 2000$ emory locations $0103h$ | 1A, 0105              | h = 6Dh,                  | and 1104h                                  | = 88h. E                  | xternal  |  |
| LDC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | R0, @RR2                                                                     |                       |                           | of program r<br>2 = 01h, R3                | •                         | ocation  |  |
| LDE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | R0, @RR2                                                                     | ; R0 ←                | contents o                | of external o<br>) = 2Ah, R2               | data mem                  | 2        |  |
| LDC*                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | @RR2, R0                                                                     | ; 11h (co<br>memory   | ntents of l<br>location 0 | R0) is loade<br>104h (RR2<br>R3 → no ch    | ed into pro<br>), working | ogram    |  |
| LDE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | @RR2, R0                                                                     | ; 11h (co<br>data mer | ntents of I<br>mory locat | R0) is loade<br>tion 0104h (<br>R3 → no cł | ed into ext<br>(RR2), wo  |          |  |
| LDC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | R0, #01h[RR2]                                                                |                       |                           | of program i<br>), R0 = 6Dh                |                           |          |  |
| LDE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | R0, #01h[RR2]                                                                | ,                     | 0105h (01                 | of external o<br>h + RR2), F               |                           | 2        |  |
| LDC*                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | #01h[RR2], R0                                                                | •                     |                           | R0) is loade<br>105h (01h ·                | •                         | ogram    |  |
| LDE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | #01h[RR2], R0                                                                | ; 11h (co             | ntents of                 | R0) is loade<br>tion 0105h (               | ed into ext               |          |  |
| LDC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | R0, #1000h[RR2]                                                              | ; R0 ←                | contents o                | of program i<br>04h), R0 =                 | memory lo                 | ocation  |  |
| Note '                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | These instructions are n                                                     | ot support            | ad by mask                | ad ROM type                                | o dovices                 |          |  |

Note: \*These instructions are not supported by masked ROM type devices.

Example

#### S3F8S5A Product Specification



| LDE   | R0, #1000h[RR2]         | ; R0 $\leftarrow$ contents of external data memory<br>location 1104h (1000h + 0104h), R0 = 98h, R2 =<br>01h, R3 = 04h |
|-------|-------------------------|-----------------------------------------------------------------------------------------------------------------------|
| LDC   | R0, 1104h               | ; R0 $\leftarrow$ contents of program memory location 1104h, R0 = 88h                                                 |
| LDE   | R0, 1104h               | ; 0 ← contents of external data memory<br>location 1104h, R0 = 98h                                                    |
| LDC*  | 1105h, R0               | ; 11h (contents of R0) is loaded into program memory location 1105h, (1105h) $\leftarrow$ 11h                         |
| LDE   | 1105h, R0               | ; 11h (contents of R0) is loaded into external data memory location 1105h, (1105h) $\leftarrow$ 11h                   |
| Note: | *These instructions are | not supported by masked ROM type devices.                                                                             |





# Load Memory and Decrement

| LDCD/LDED dst, src |                        |  |  |  |
|--------------------|------------------------|--|--|--|
| Operation          | $dst \leftarrow src$   |  |  |  |
|                    | $rr \leftarrow rr - 1$ |  |  |  |

These instructions are used for user stacks or block transfers of data from program or data memory to the register file. The address of the memory location is specified by a working register pair. The contents of the source location are loaded into the destination location. The memory address is then decremented. The contents of the source are unaffected.

LDCD references program memory and LDED references external data memory. The assembler causes Irr to be an even number for program memory and an odd number for data memory.

#### Flags No flags are affected.

| Format  |      |           | Bytes                                                     | Cycles    | Op Code<br>(Hex) | Addres<br>dst | s Mode<br>src |
|---------|------|-----------|-----------------------------------------------------------|-----------|------------------|---------------|---------------|
|         | орс  | dst   src | 2                                                         | 10        | E2               | r             | Irr           |
| Example |      |           | , R7 = 33h, R8 =<br>ata memory loca                       | · •       | 0                | ry locatio    | on 1033h      |
|         | LDCD | R8, @RR6  | ; 0CDh (conte<br>is loaded into<br>= 0CDh, R6 =           | R8 and R  | R6 is decre      | mented b      | by one, R8    |
|         | LDED | R8, @RR6  | ; 0DDh (conte<br>loaded into R8<br>$\leftarrow$ RR6 – 1), | 3 and RR6 | is decreme       | ented by      | one (RR6      |





# Load Memory and Increment

| LDCI/LDEI | dst, src                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                   |                                               |          |              |           |        |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|----------|--------------|-----------|--------|
| Operation | $dst \leftarrow sr$                                                                                                                                                              | $dst \leftarrow src$                                                                                                                                                                                                                                                                                                                                                                              |                                               |          |              |           |        |
|           | $rr \leftarrow rr$ -                                                                                                                                                             | + 1                                                                                                                                                                                                                                                                                                                                                                                               |                                               |          |              |           |        |
|           | gram or<br>specified<br>loaded in                                                                                                                                                | These instructions are used for user stacks or block transfers of data from pro-<br>gram or data memory to the register file. The address of the memory location is<br>specified by a working register pair. The contents of the source location are<br>loaded into the destination location. The memory address is then incremented<br>automatically. The contents of the source are unaffected. |                                               |          |              |           |        |
|           | assemble                                                                                                                                                                         | LDCI refers to program memory and LDEI refers to external data memory. The assembler causes Irr to be an even number for program memory and an odd number for data memory.                                                                                                                                                                                                                        |                                               |          |              |           |        |
| Flags     | No flags                                                                                                                                                                         | are affected.                                                                                                                                                                                                                                                                                                                                                                                     |                                               |          |              |           |        |
| Format    |                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                   | Bytes                                         | Cycles   | Op Code      | Address   | s Mode |
|           |                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                   |                                               |          | (Hex)        | dst       | src    |
|           | орс                                                                                                                                                                              | dst   src                                                                                                                                                                                                                                                                                                                                                                                         | 2                                             | 10       | E3           | r         | Irr    |
| Example   | Assume that $R6 = 10h$ , $R7 = 33h$ , $R8 = 12h$ , program memory locations $1033h = 0$ CDh and $1034h = 0$ C5h, external data memory locations $10330$ DDh and $1034h = 0$ D5h. |                                                                                                                                                                                                                                                                                                                                                                                                   |                                               |          |              |           |        |
|           | LDCI                                                                                                                                                                             | R8, @RR6                                                                                                                                                                                                                                                                                                                                                                                          | ; 0CDh (conte<br>is loaded into<br>(RR6 ← RR6 | R8 and R | R6 is increr | nented by | one    |
|           | LDEI                                                                                                                                                                             | R8, @RR6                                                                                                                                                                                                                                                                                                                                                                                          |                                               |          |              |           |        |





# Load Memory with PreDecrement

| LDCPD/<br>LDEPD | dst, src                                                                   |                                                                                                                                                                                                                                                                                                                                                            |                               |             |        |        |
|-----------------|----------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|-------------|--------|--------|
| Operation       | $rr \leftarrow rr - 1$                                                     |                                                                                                                                                                                                                                                                                                                                                            |                               |             |        |        |
|                 | dst ← src                                                                  |                                                                                                                                                                                                                                                                                                                                                            |                               |             |        |        |
|                 | memory from the regination by a working register plocation are then loaded | These instructions are used for block transfers of data from program or data<br>memory from the register file. The address of the memory location is specified<br>by a working register pair and is first decremented. The contents of the source<br>location are then loaded into the destination location. The contents of the<br>source are unaffected. |                               |             |        |        |
|                 | LDCPD refers to prog<br>ory. The assembler ca<br>an odd number for ext     | uses Irr to be an                                                                                                                                                                                                                                                                                                                                          | even num                      |             |        |        |
| Flags           | No flags are affected.                                                     |                                                                                                                                                                                                                                                                                                                                                            |                               |             |        |        |
| Format          |                                                                            | Bytes                                                                                                                                                                                                                                                                                                                                                      | Cycles                        | Op Code     | Addres | s Mode |
|                 |                                                                            |                                                                                                                                                                                                                                                                                                                                                            |                               | (Hex)       | dst    | src    |
|                 | opc dst   src                                                              | 2                                                                                                                                                                                                                                                                                                                                                          | 14                            | F2          | Irr    | r      |
| Example         | Assume that $R0 = 77$                                                      | n, $\mathbf{R6} = 30\mathbf{h}$ and                                                                                                                                                                                                                                                                                                                        | $\mathbf{R7} = 00 \mathbf{h}$ |             |        |        |
|                 | LDCPD @RR6, R0                                                             | ; (RR6 ← RR6<br>program mem<br>77h, R6 = 2Fh                                                                                                                                                                                                                                                                                                               | ory locatio                   | n 2FFFh (30 | ,      |        |
|                 | LDEPD @RR6, R0                                                             | ; (RR6 ← RR6<br>external data r<br>= 77h, R6 = 21                                                                                                                                                                                                                                                                                                          | nemory loc                    | ation 2FFFI | ,      |        |





# Load Memory with PreIncrement

| LDCPI/<br>LDEPI | dst, src                                                            |                                                                                                                                                                                                                                                                                                                                                       |              |             |        |        |
|-----------------|---------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-------------|--------|--------|
| Operation       | $rr \leftarrow rr + 1$                                              |                                                                                                                                                                                                                                                                                                                                                       |              |             |        |        |
|                 | $dst \leftarrow src$                                                |                                                                                                                                                                                                                                                                                                                                                       |              |             |        |        |
|                 | memory from the reg<br>by a working register                        | These instructions are used for block transfers of data from program or data<br>memory from the register file. The address of the memory location is specified<br>by a working register pair and is first incremented. The contents of the source<br>location are loaded into the destination location. The contents of the source are<br>unaffected. |              |             |        |        |
|                 | LDCPI refers to prog<br>The assembler causes<br>odd number for data | s Irr to be an ever                                                                                                                                                                                                                                                                                                                                   |              |             |        | •      |
| Flags           | No flags are affected                                               | J.                                                                                                                                                                                                                                                                                                                                                    |              |             |        |        |
| Format          |                                                                     | Bytes                                                                                                                                                                                                                                                                                                                                                 | Cycles       | Op Code     | Addres | s Mode |
|                 |                                                                     |                                                                                                                                                                                                                                                                                                                                                       |              | (Hex)       | dst    | src    |
|                 | opc dst   src                                                       | 2                                                                                                                                                                                                                                                                                                                                                     | 14           | F3          | Irr    | r      |
| Example         | Assume that $R0 = 7F$                                               | Fh, R6 = 21h and                                                                                                                                                                                                                                                                                                                                      | R7 = 0FF     | h.          |        |        |
|                 | LDCPI @RR6, R0                                                      | ; (RR6 ← RR6<br>program memo<br>7Fh, R6 = 22h                                                                                                                                                                                                                                                                                                         | ory location | n 2200h (21 | ,      |        |
|                 | LDEPD @RR6, R0                                                      | ) ; (RR6 ← RR6<br>external data n<br>= 7Fh, R6 = 22                                                                                                                                                                                                                                                                                                   | nemory loc   | ation 2200h |        |        |





### Load Word

| LDW       | dst, src |                                                         |               |            |            |                              |            |            |
|-----------|----------|---------------------------------------------------------|---------------|------------|------------|------------------------------|------------|------------|
| Operation | dst ←    | src                                                     |               |            |            |                              |            |            |
|           |          | ntents of the sou<br>f the source are u                 |               |            | loaded in  | to the desti                 | nation. T  | he con-    |
| Flags     | No flag  | gs are affected.                                        |               |            |            |                              |            |            |
| Format    |          |                                                         |               | Bytes      | Cycles     | Op Code                      | Addres     | s Mode     |
|           |          |                                                         |               |            |            | (Hex)                        | dst        | src        |
|           | орс      | src dst                                                 |               | 3          | 8          | C4                           | RR         | RR         |
|           |          |                                                         |               |            | 8          | C5                           | RR         | IR         |
|           | орс      | dst sro                                                 | C             | 4          | 8          | C6                           | RR         | IML        |
| Example   |          | e that $R4 = 06h$ ,<br>lh = 02h, registe                |               |            |            | Ũ                            |            | = Ah, reg  |
|           | LDW      | RR6, RR4                                                | $\rightarrow$ | R6 = 06ł   | n, R7 = 10 | Ch, R4 = 06                  | h, R5 = 1  | Ch         |
|           | LDW      | 00h, 02h                                                | $\rightarrow$ | -          |            | h, register 0<br>r 03h = 0Fh |            | , register |
|           | LDW      | RR2, @R7                                                | $\rightarrow$ | R2 = 03ł   | n, R3 = 0F | ħ                            |            |            |
|           | LDW      | 04h, @01h                                               | $\rightarrow$ | Register   | 04h = 03   | h, register C                | )5h = 0Fh  | l          |
|           | LDW      | RR6, #1234h                                             | $\rightarrow$ | R6 = 12h   | n, R7 = 34 | lh                           |            |            |
|           | LDW      | 02h, #0FEDh                                             | $\rightarrow$ | Register   | 02h = 0F   | h, register (                | )3h = 0ED  | Dh         |
|           | source   | second example,<br>word 02h, 03h i<br>03h in general re | into th       | e destinat | ion word   | 00h, 01h. 7                  | This leave |            |

The other examples show how to use the LDW instruction with multiple addressing modes and formats.





# Multiply (Unsigned)

| MULT      | dst, src                                                                                                                                                                                                                                                             |                                                   |               |           |                          |                     |             |            |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|---------------|-----------|--------------------------|---------------------|-------------|------------|
| Operation | $dst \leftarrow ds$                                                                                                                                                                                                                                                  | $st \times src$                                   |               |           |                          |                     |             |            |
|           | by the so                                                                                                                                                                                                                                                            | t destination<br>ource operand<br>cified by the o | d (8 bits)    | and the p | product (1               | 6 bits) is sto      | ored in the | e register |
| Flags     | <ul> <li>C Set if result is &gt; 255; cleared otherwise.</li> <li>Z Set if the result is 0; cleared otherwise.</li> <li>S Set if MSB of the result is a 1; cleared otherwise.</li> <li>V Cleared.</li> <li>D Unaffected.</li> <li>H Unaffected.</li> </ul>           |                                                   |               |           |                          |                     |             |            |
| Format    |                                                                                                                                                                                                                                                                      |                                                   |               | Bytes     | Cycles                   | Op Code             | Addres      | s Mode     |
|           |                                                                                                                                                                                                                                                                      |                                                   |               | -         | 2                        | (Hex)               | dst         | src        |
|           | орс                                                                                                                                                                                                                                                                  | src                                               | dst           | 3         | 22                       | 84                  | RR          | R          |
|           |                                                                                                                                                                                                                                                                      |                                                   |               |           | 22                       | 85                  | RR          | IR         |
|           |                                                                                                                                                                                                                                                                      |                                                   |               |           | 22                       | 86                  | RR          | IM         |
| Example   | Assume that Register $00h = 20h$ , register $01h = 03h$ , register $02h = 09h$ , register $03h = 06h$ .                                                                                                                                                              |                                                   |               |           |                          | 09h, reg-           |             |            |
|           | MULT                                                                                                                                                                                                                                                                 | 00h, 02h                                          | $\rightarrow$ | -         | ster 00h =<br>er 02h = 0 | 01h, registe<br>)9h | er 01h = 2  | 20h,       |
|           | MULT                                                                                                                                                                                                                                                                 | 00h, @01h                                         | $\rightarrow$ | Regis     | ster 00h =               | 00h, registe        | er 01h = (  | )C0h       |
|           | MULT                                                                                                                                                                                                                                                                 | 01h, @02h                                         | $\rightarrow$ | Regis     | ster 00h =               | 06h, registe        | er 01h = (  | )0h        |
|           | In the first example, the <i>MULT 00h</i> , <i>02h</i> statement multiplies the 8-bit destina-<br>tion operand (in the register 00h of the register pair 00h, 01h) by the source<br>register 02h operand (09h). The 16-bit product, 0120h, is stored in the register |                                                   |               |           |                          |                     |             |            |

pair 00h, 01h.



An DXYS Company



### Next

| NEXT      |                                                                                                                                                                                                                                                  |  |  |  |  |  |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Operation | $PC \leftarrow @ IP$                                                                                                                                                                                                                             |  |  |  |  |  |
|           | $IP \leftarrow IP + 2$                                                                                                                                                                                                                           |  |  |  |  |  |
|           | The NEXT instruction is useful when implementing threaded-code languages.<br>The program memory word that is pointed to by the instruction pointer is<br>loaded into the program counter. The instruction pointer is then incremented by<br>two. |  |  |  |  |  |
| Flags     | No flags are affected.                                                                                                                                                                                                                           |  |  |  |  |  |
| Format    | Bytes Cycles Op Code<br>(Hex)                                                                                                                                                                                                                    |  |  |  |  |  |
|           | opc 1 10 0F                                                                                                                                                                                                                                      |  |  |  |  |  |

**Example** Figure 51 shows an example of how to use the NEXT instruction.







# No Operation

| NOP       |                                                                                                                                                                    |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation | No action is performed when the CPU executes this instruction. Typically, one or more NOPs are executed in sequence to effect a timing delay of variable duration. |
| Flags     | No flags are affected.                                                                                                                                             |
| Format    | Bytes Cycles Op Code<br>(Hex)                                                                                                                                      |
|           | opc 1 4 FF                                                                                                                                                         |
| Example   | When the NOP instruction is encountered in a program, no operation occurs.<br>Instead, there is a delay in instruction execution time.                             |





# Logical OR

| OR        | dst, src                                                                                                                                                                                         |                         |                        |                              |           |        |  |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|------------------------|------------------------------|-----------|--------|--|
| Operation | dst ← dst OR src                                                                                                                                                                                 |                         |                        |                              |           |        |  |
|           | The source operand is logicall<br>result is stored in the destinati<br>The OR operation results in a<br>ing bits in the two operands is                                                          | on. The c<br>1 being st | ontents of<br>ored whe | f the source<br>never either | are unaff | ected. |  |
| Flags     | <ul> <li>C Unaffected.</li> <li>Z Set if the result is 0; clear</li> <li>S Set if the result bit 7 is s</li> <li>V Always cleared to 0.</li> <li>D Unaffected.</li> <li>H Unaffected.</li> </ul> |                         |                        | se.                          |           |        |  |
| Format    |                                                                                                                                                                                                  | Bytes                   | Cycles                 | Op Code                      | Addres    | s Mode |  |
|           |                                                                                                                                                                                                  | -                       | -                      | (Hex)                        | dst       | src    |  |
|           | opc dst   src                                                                                                                                                                                    | 2                       | 4                      | 42                           | r         | r      |  |
|           |                                                                                                                                                                                                  |                         | 6                      | 43                           | r         | lr     |  |
|           | opc src dst                                                                                                                                                                                      | 3                       | 6                      | 44                           | R         | R      |  |
|           |                                                                                                                                                                                                  | J                       | 6                      | 45                           | R         | IR     |  |
|           | opc dst src                                                                                                                                                                                      | ] 3                     | 6                      | 46                           | R         | IM     |  |

#### Example

Assume that R0 = 15h, R1 = 2Ah, R2 = 01h, register 00h = 08h, register 01h = 37h and register 08h = 8Ah.

| OR | R0, R1    | $\rightarrow$ | R0 = 3Fh, R1 = 2Ah                      |
|----|-----------|---------------|-----------------------------------------|
| OR | R0, @R2   | $\rightarrow$ | R0 = 37h, R2 = 01h, register 01h = 37h  |
| OR | 00h, 01h  | $\rightarrow$ | Register 00h = 3Fh, register 01h = 37h  |
| OR | 01h, @00h | $\rightarrow$ | Register 00h = 08h, register 01h = 0BFh |
| OR | 00h, #02h | $\rightarrow$ | Register 00h = 0Ah                      |

In the first example, if working register R0 contains the value 15h and register R1 the value 2Ah, the *OR R0, R1* statement logical-ORs the R0 and R1 register contents and stores the result (3Fh) in destination register R0.



The other examples show the use of the logical OR instruction with multiple addressing modes and formats.





# Pop from Stack

| ADC       | dst                                                                                                                         |                               |                       |                               |                     |  |  |  |  |
|-----------|-----------------------------------------------------------------------------------------------------------------------------|-------------------------------|-----------------------|-------------------------------|---------------------|--|--|--|--|
| Operation | $dst \leftarrow @SP$                                                                                                        |                               |                       |                               |                     |  |  |  |  |
|           | $SP \leftarrow SP + 1$                                                                                                      |                               |                       |                               |                     |  |  |  |  |
|           | The contents of the location destination. The stack point                                                                   |                               | -                     | -                             | re loaded into the  |  |  |  |  |
| Flags     | No flags are affected.                                                                                                      |                               |                       |                               |                     |  |  |  |  |
| Format    |                                                                                                                             | Bytes                         | Cycles                | Op Code                       | Address Mode        |  |  |  |  |
|           |                                                                                                                             |                               |                       | (Hex)                         | dst                 |  |  |  |  |
|           | opc dst                                                                                                                     | 2                             | 8                     | 50                            | R                   |  |  |  |  |
|           |                                                                                                                             |                               | 8                     | 51                            | IR                  |  |  |  |  |
| Example   | Assume that Register 00h = (0D9h) = 0FBh and stack re                                                                       | •                             |                       | 1Bh, SPH (                    | 0D8h) = 00h, SPL    |  |  |  |  |
|           | POP 00h $\rightarrow$ Register 00h = 55h, SP = 00FCh                                                                        |                               |                       |                               |                     |  |  |  |  |
|           | POP @00h $\rightarrow$ Regis                                                                                                | ster 00h = 0                  | 1h, regist            | er 01h = 55l                  | h, SP = 00FCh       |  |  |  |  |
|           | In the first example, general<br>statement loads the contents<br>00h and then increments the<br>the value 55h and the SP po | s of location<br>e stack poin | 00FBh (<br>ter by one | 55h) into de<br>e. Register ( | estination register |  |  |  |  |





# Pop User Stack (Decrementing)

| POPUD     | dst, src                                                                                                                                                                                                                           |             |           |              |            |               |             |          |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-----------|--------------|------------|---------------|-------------|----------|
| Operation | $dst \leftarrow src$                                                                                                                                                                                                               |             |           |              |            |               |             |          |
|           | $IR \leftarrow IR$ -                                                                                                                                                                                                               | - 1         |           |              |            |               |             |          |
|           | This instruction is used for user-defined stacks in the register file. The contents of the register file location addressed by the user stack pointer are loaded into the destination. The user stack pointer is then decremented. |             |           |              |            |               |             |          |
| Flags     | No flags a                                                                                                                                                                                                                         | are affecte | d.        |              |            |               |             |          |
| Format    |                                                                                                                                                                                                                                    |             |           | Bytes        | Cycles     | Op Code       | Address     | s Mode   |
|           |                                                                                                                                                                                                                                    |             |           |              |            | (Hex)         | dst         | src      |
|           | орс                                                                                                                                                                                                                                | SrC         | dst       | 3            | 8          | 92            | R           | IR       |
| Example   | Assume th<br>6Fh and re                                                                                                                                                                                                            | -           |           | 12h (user    | stack poir | nter register | ), register | 42h =    |
|           | POPUD 02h, @00h $\rightarrow$ Register 00h = 41h, register 02h = 6Fh, register 42h = 6Fh                                                                                                                                           |             |           |              |            |               |             | register |
|           | If general                                                                                                                                                                                                                         | register 0  | 0h contai | ns the value | ue 42h an  | d register 4  | 2h the val  | ue 6Fh,  |

the *POPUD 02h*, @00h statement loads the contents of register 42h into the destination register 02h. The user stack pointer is then decremented by one, leaving the value 41h.





# Pop User Stack (Incrementing)

| POPUI     | dst, src                                                                                                                                                                                                                                |             |           |                      |           |               |           |          |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-----------|----------------------|-----------|---------------|-----------|----------|
| Operation | $dst \leftarrow src$                                                                                                                                                                                                                    |             |           |                      |           |               |           |          |
|           | $IR \leftarrow IR$ -                                                                                                                                                                                                                    | + 1         |           |                      |           |               |           |          |
|           | The POPUI instruction is used for user-defined stacks in the register file. The contents of the register file location addressed by the user stack pointer are loaded into the destination. The user stack pointer is then incremented. |             |           |                      |           |               |           |          |
| Flags     | No flags a                                                                                                                                                                                                                              | are affecte | d.        |                      |           |               |           |          |
| Format    |                                                                                                                                                                                                                                         |             |           | Bytes                | Cycles    | Op Code       | Address   | s Mode   |
|           |                                                                                                                                                                                                                                         |             |           |                      |           | (Hex)         | dst       | src      |
|           | орс                                                                                                                                                                                                                                     | src         | dst       | 3                    | 8         | 93            | R         | IR       |
| Example   | Assume th                                                                                                                                                                                                                               | nat Registe | r 00h = 0 | 1h and re            | gister 01 | h = 70h.      |           |          |
|           | POPUI                                                                                                                                                                                                                                   | 02h, @00    | Dh →      | Register<br>02h = 70 |           | n, register 0 | 1h = 70h, | register |
|           |                                                                                                                                                                                                                                         |             |           |                      |           |               |           |          |

If general register 00h contains the value 01h and register 01h the value 70h, the *POPUI 02h*, @00h statement loads the value 70h into the destination general register 02h. The user stack pointer (register 00h) is then incremented by one, changing its value from 01h to 02h.





# Push to Stack

| PUSH      | src                                                                                                                                                                                                                           |            |               |       |                                              |               |                   |  |  |  |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|---------------|-------|----------------------------------------------|---------------|-------------------|--|--|--|
| Operation | $SP \leftarrow SI$                                                                                                                                                                                                            | P – 1      |               |       |                                              |               |                   |  |  |  |
|           | @SP←                                                                                                                                                                                                                          | src        |               |       |                                              |               |                   |  |  |  |
|           | A PUSH instruction decrements the stack pointer value and loads the contents of the source (src) into the location addressed by the decremented stack pointer. The operation then adds the new value to the top of the stack. |            |               |       |                                              |               |                   |  |  |  |
| Flags     | No flags                                                                                                                                                                                                                      | are affect | ed.           |       |                                              |               |                   |  |  |  |
| Format    |                                                                                                                                                                                                                               |            | Byt           | tes   | Cycles                                       | Op Code       | Address Mode      |  |  |  |
|           |                                                                                                                                                                                                                               |            | -             |       | -                                            | (Hex)         | dst               |  |  |  |
|           | орс                                                                                                                                                                                                                           | src        | 2             | 2     | 8 (internal clock)                           | 70            | R                 |  |  |  |
|           |                                                                                                                                                                                                                               |            | 2             |       | 8 (external clock)                           |               |                   |  |  |  |
|           |                                                                                                                                                                                                                               |            |               |       | 8 (internal clock)                           |               |                   |  |  |  |
|           |                                                                                                                                                                                                                               |            |               |       | 8 (external clock)                           | 71            | IR                |  |  |  |
| Example   | Assume<br>00h.                                                                                                                                                                                                                | that Regis | ter 40        | )h =  | 4Fh, register 4Fh =                          | = 0aah, SPH   | = 00h and SPL =   |  |  |  |
|           | PUSH                                                                                                                                                                                                                          | 40h        | $\rightarrow$ |       | gister 40h = 4Fh, sta<br>PFFh, SPL = 0FFh    | ack register  | 0FFh = 4Fh, SPH   |  |  |  |
|           | PUSH                                                                                                                                                                                                                          | @40h       | $\rightarrow$ |       | gister 40h = 4Fh, reg<br>jister 0FFh = 0AAh, | •             |                   |  |  |  |
|           | In the fir                                                                                                                                                                                                                    | st example | e, if tl      | ne st | ack pointer contains                         | s the value 0 | 000h, and general |  |  |  |

In the first example, if the stack pointer contains the value 0000h, and general register 40h the value 4Fh, the *PUSH 40h* statement decrements the stack pointer from 0000 to 0FFFFh. It then loads the contents of register 40h into location 0FFFFh and adds this new value to the top of the stack.





# Push User Stack (Decrementing)

| PUSHUD    | dst, src                                                                                                                                                                         |            |           |           |             |               |             |         |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-----------|-----------|-------------|---------------|-------------|---------|
| Operation | $IR \leftarrow IR$                                                                                                                                                               | - 1        |           |           |             |               |             |         |
|           | $dst \leftarrow src$                                                                                                                                                             |            |           |           |             |               |             |         |
|           | This instruction is used to address user-defined stacks in<br>PUSHUD decrements the user stack pointer and loads<br>source into the register addressed by the decremented stacks |            |           |           |             |               |             |         |
| Flags     | No flags a                                                                                                                                                                       | are affect | ed.       |           |             |               |             |         |
| Format    |                                                                                                                                                                                  |            |           | Bytes     | Cycles      | Op Code       | Address     | s Mode  |
|           |                                                                                                                                                                                  |            |           |           |             | (Hex)         | dst         | src     |
|           | орс                                                                                                                                                                              | dst        | src       | 3         | 8           | 82            | IR          | R       |
| Example   | Assume th                                                                                                                                                                        | nat Regis  | ter 00h = | 03h, regi | ister 01h = | = 05h, and re | egister 021 | n = 1Ah |
|           | PUSHUD @00h, 01h $\rightarrow$ Register 00h = 02h, register 01h = register 02h = 05h                                                                                             |            |           |           |             |               |             | n,      |
|           |                                                                                                                                                                                  | -          |           |           | -           | ole) contains |             |         |

If the user stack pointer (register 00h, for example) contains the value 03h, the *PUSHUD @00h, 01h* statement decrements the user stack pointer by one, leaving the value 02h. The 01h register value, 05h, is then loaded into the register addressed by the decremented user stack pointer.





# Push User Stack (Incrementing)

| PUSHUI    | dst, src                                                                                                                                                                                                                              |           |               |           |                           |                     |             |          |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|---------------|-----------|---------------------------|---------------------|-------------|----------|
| Operation | $\mathrm{IR} \leftarrow \mathrm{IR} +$                                                                                                                                                                                                | 1         |               |           |                           |                     |             |          |
|           | $dst \leftarrow src$                                                                                                                                                                                                                  |           |               |           |                           |                     |             |          |
|           | This instruction is used for user-defined stacks in the register file. PUSHUI increments the user stack pointer and then loads the contents of the source into the register location addressed by the incremented user stack pointer. |           |               |           |                           |                     |             |          |
| Flags     | No flags ar                                                                                                                                                                                                                           | e affecte | ed.           |           |                           |                     |             |          |
| Format    |                                                                                                                                                                                                                                       |           |               | Bytes     | Cycles                    | Op Code             | Address     | s Mode   |
|           |                                                                                                                                                                                                                                       |           |               |           |                           | (Hex)               | dst         | src      |
|           | орс                                                                                                                                                                                                                                   | dst       | src           | 3         | 8                         | 83                  | IR          | R        |
| Example   | Assume that                                                                                                                                                                                                                           | t Regist  | ter $00h = 0$ | 03h, regi | ster 01h =                | = 05h, and re       | egister 041 | n = 2Ah. |
|           | PUSHUI                                                                                                                                                                                                                                | @00h,     | ,01h →        | -         | ter 00h = 0<br>er 04h = 0 | 04h, register<br>5h | 01h = 05ł   | ٦,       |
|           |                                                                                                                                                                                                                                       | -         |               |           |                           | ole) contains       |             |          |

PUSHUI @00h, 01h statement increments the user stack pointer by one, leaving the value 04h. The 01h register value, 05h, is then loaded into the location addressed by the incremented user stack pointer.



# Reset Carry Flag

| RCF       | RCF                                                                                 |  |  |  |  |  |  |
|-----------|-------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Operation | $C \leftarrow 0$                                                                    |  |  |  |  |  |  |
|           | The carry flag is cleared to logic 0, regardless of its previous value.             |  |  |  |  |  |  |
| Flags     | C Cleared to 0.<br>No other flags are affected.                                     |  |  |  |  |  |  |
| Format    | Bytes Cycles Op Code                                                                |  |  |  |  |  |  |
|           | (Hex)                                                                               |  |  |  |  |  |  |
|           | opc 1 4 CF                                                                          |  |  |  |  |  |  |
| Example   | Assume that $C = 1$ or 0. The RCF instruction clears the carry flag (C) to logic 0. |  |  |  |  |  |  |





#### Return

| RET       |                                                                                                                                                            |                                        |                                              |                                        |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|----------------------------------------------|----------------------------------------|
| Operation | $PC \leftarrow @SP$                                                                                                                                        |                                        |                                              |                                        |
|           | $SP \leftarrow SP + 2$                                                                                                                                     |                                        |                                              |                                        |
|           | The RET instruction is norm<br>cedure at the end of a proceed<br>of the location addressed by<br>counter. The next statement<br>new program counter value. | lure enter<br>the stack<br>that is exe | ed by a CALL instru<br>pointer are popped in | ction. The contents<br>nto the program |
| Flags     | No flags are affected.                                                                                                                                     |                                        |                                              |                                        |
| Format    |                                                                                                                                                            | Bytes                                  | Cycles                                       | Op Code<br>(Hex)                       |
|           | орс                                                                                                                                                        | 1                                      | 8 (internal stack)<br>10 (internal stack)    | CF                                     |
| Example   | Assume that $SP = 00FCh$ , (S                                                                                                                              | SP) = 101                              | Ah, and PC = 1234.                           |                                        |
|           | RET $\rightarrow$ PC = 101Al                                                                                                                               | n, SP = 00                             | )FEh                                         |                                        |
|           | The <i>RET</i> statement pops the into the high byte of the progin location 00FEh (1Ah) into                                                               | gram coun                              | ter. The stack pointer                       | r then pops the value                  |

101Ah is executed. The stack pointer now points to memory location 00FEh.





### **Rotate Left**

RL dst

**Operation**  $C \leftarrow dst(7)$ 

 $dst(0) \leftarrow dst(7)$ 

 $dst(n + 1) \leftarrow dst(n), n = 0 - 6$ 

The contents of the destination operand are rotated left one bit position. The initial value of bit 7 is moved to the bit 0 (LSB) position and also replaces the carry flag.

Figure 52 shows how bits rotate left.



Figure 52. Rotate Left

Flags C Set if the bit rotated from the most significant bit position (bit 7) is 1.

- **Z** Set if the result is 0; cleared otherwise.
- **S** Set if the result bit 7 is set; cleared otherwise.
- V Set if arithmetic overflow occurred; cleared otherwise.
- D Unaffected.
- H Unaffected.

#### Format

|     |     |         |         |   | (Hex) | dst                                            |                  |
|-----|-----|---------|---------|---|-------|------------------------------------------------|------------------|
| орс | dst |         | 2       | 4 | 90    | R                                              |                  |
|     |     | Ĺ       |         | 4 | 91    | IR                                             |                  |
|     | орс | opc dst | opc dst |   |       | opc         dst         2         4         90 | opc dst 2 4 90 R |

Bytes Cycles Op Code Address Mode

| Example | Assume that Register $00h = 0AAh$ , register $01h = 02h$ and register $02h = 17h$ |      |               |                                               |  |  |
|---------|-----------------------------------------------------------------------------------|------|---------------|-----------------------------------------------|--|--|
|         | RL                                                                                | 00h  | $\rightarrow$ | Register $00h = 55h, C = 1$                   |  |  |
|         | RL                                                                                | @01h | $\rightarrow$ | Register 01h = 02h, register 02h = 2Eh, C = 0 |  |  |

In the first example, if general register 00h contains the value 0AAh (10101010b), the *RL 00h* statement rotates the 0AAh value left one bit position, leaving the new value 55h (01010101b) and setting the carry and overflow flags.





### Rotate Left through Carry

RCL dst

**Operation**  $dst(0) \leftarrow C$ 

 $C \leftarrow dst(7)$ 

 $dst(n + 1) \leftarrow dst(n), n = 0 - 6$ 

The contents of the destination operand with the carry flag are rotated left one bit position. The initial value of bit 7 replaces the carry flag (C); the initial value of the carry flag replaces bit 0.

Figure 53 shows how bits rotate left through carry.



Figure 53. Rotate Left through Carry

#### Flags C Set if the bit rotated from the most significant bit position (bit 7) is 1.

- **Z** Set if the result is 0; cleared otherwise.
- **S** Set if the result bit 7 is set; cleared otherwise.
- **V** Set if arithmetic overflow occurred, i.e., if the sign of the destination changed during rotation; cleared otherwise.
- D Unaffected.
- H Unaffected.

| Format |     |     | Bytes | Cycles | Op Code | Address Mode |
|--------|-----|-----|-------|--------|---------|--------------|
|        |     |     |       |        | (Hex)   | dst          |
|        | орс | dst | 2     | 4      | 10      | R            |
|        |     |     |       | 4      | 11      | IR           |

| Example | Assume that $\text{Re}$<br>C = 0. | gister 00h = 0AAh, register 01h = 02h, and register 02h = 17h, |
|---------|-----------------------------------|----------------------------------------------------------------|
|         | RLC 00h                           | Register 00h = 54h, C = 1                                      |

| IXLO | 0011 | 1 = 1 = 1 = 1 = 1                                   |
|------|------|-----------------------------------------------------|
| RLC  | @01h | Register $01h = 02h$ , register $02h = 2Eh$ , C = 0 |



163

In the first example, if general register 00h has the value 0AAh (10101010b), the *RLC 00h* statement rotates 0AAh one bit position to the left. The initial value of bit 7 sets the carry flag and the initial value of the C flag replaces bit 0 of register 00h, leaving the value 55h (01010101b). The MSB of register 00h resets the carry flag to 1 and sets the overflow flag.





## Rotate Right

RR dst

**Operation**  $C \leftarrow dst(0)$ 

 $dst(7) \leftarrow dst(0)$ 

 $dst(n) \leftarrow dst(n+1), n = 0 - 6$ 

The contents of the destination operand are rotated right one bit position. The initial value of bit 0 (LSB) is moved to bit 7 (MSB) and also replaces the carry flag (C).

Figure 54 shows how bits rotate right.



Figure 54. Rotate Right

Flags

- **C** Set if the bit rotated from the least significant bit position (bit 0) is 1.
  - Z Set if the result is 0; cleared otherwise.
  - **S** Set if the result bit 7 is set; cleared otherwise.
  - **V** Set if arithmetic overflow occurred, i.e., if the sign of the destination changed during rotation; cleared otherwise.
  - D Unaffected.
  - H Unaffected.

| Format |     |     | Bytes | Cycles | Op Code | Address Mode |
|--------|-----|-----|-------|--------|---------|--------------|
|        |     |     |       |        | (Hex)   | dst          |
|        | орс | dst | 2     | 4      | E0      | R            |
|        |     |     |       | 4      | E1      | IR           |

| Example | Assun | ne that Reg | ister $00h = 31h$ , register $01h = 02h$ , and register $02h = 17h$ . |
|---------|-------|-------------|-----------------------------------------------------------------------|
|         | RR    | 00h         | Register $00h = 98h, C = 1$                                           |
|         | RR    | @01h        | Register 01h = 02h, register 02h = 8Bh, C = 1                         |



165

In the first example, if general register 00h contains the value 31h (00110001b), the *RR 00h* statement rotates this value one bit position to the right. The initial value of bit 0 is moved to bit 7, leaving the new value 98h (10011000b) in the destination register. The initial bit 0 also resets the C flag to 1 and the sign flag and overflow flag are also set to 1.





# Rotate Right through Carry

RRC dst

**Operation**  $dst(7) \leftarrow C$ 

 $C \leftarrow dst(0)$ 

 $dst(n) \leftarrow dst(n+1), n = 0 - 6$ 

The contents of the destination operand and the carry flag are rotated right one bit position. The initial value of bit 0 (LSB) replaces the carry flag; the initial value of the carry flag replaces bit 7 (MSB).

Figure 55 shows how bits rotate right through carry.



Figure 55. Rotate Right through Carry

#### Flags C Set if the bit rotated from the least significant bit position (bit 0) is 1.

- **Z** Set if the result is 0 cleared otherwise.
- **S** Set if the result bit 7 is set; cleared otherwise.
- **V** Set if arithmetic overflow occurred, i.e., if the sign of the destination changed during rotation; cleared otherwise.
- D Unaffected.
- H Unaffected.

| Format |     |     | Bytes | s Cycles | Op Code | Address Mode |
|--------|-----|-----|-------|----------|---------|--------------|
|        |     |     |       |          | (Hex)   | dst          |
|        | орс | dst | 2     | 4        | C0      | R            |
|        |     |     |       | 4        | C1      | IR           |

| Example | Assum $C = 0.$ | e that Reg | gister $00h = 55h$ , register $01h = 02h$ , register $02h = 17h$ , and |
|---------|----------------|------------|------------------------------------------------------------------------|
|         | RRC            | 00h        | Register $00h = 2Ah, C = 1$                                            |

RRC @01h Register 01h = 02h, register 02h = 0Bh, C = 1



167

In the first example, if general register 00h contains the value 55h (01010101b), the *RRC 00h* statement rotates this value one bit position to the right. The initial value of bit 0 (1) replaces the carry flag and the initial value of the C flag (1) replaces bit 7. This leaves the new value 2Ah (0010101b) in destination register 00h. The sign flag and overflow flag are both cleared to 0.





### Select Bank0

| SB0       |                                                                                                                                                                         |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation | $BANK \leftarrow 0$                                                                                                                                                     |
|           | The SB0 instruction clears the bank address flag in the Flags Register (FLAGS.0) to logic 0, selecting Bank0 register addressing in the Set1 area of the register file. |
| Flags     | No flags are affected.                                                                                                                                                  |
| Format    | Bytes Cycles Op Code<br>(Hex)                                                                                                                                           |
|           | opc 1 4 4F                                                                                                                                                              |
| Example   | The SB0 statement clears FLAGS.0 to 0, selecting Bank0 register addressing.                                                                                             |





### Select Bank1

| SB1       |                                                                                                                                                                                                                                        |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation | $BANK \leftarrow 1$                                                                                                                                                                                                                    |
|           | The SB1 instruction sets the bank address flag in the Flags Register (FLAGS.0) to logic 1, selecting Bank1 register addressing in the Set1 area of the register file. (Bank1 is not implemented in some KS88-series microcontrollers.) |
| Flags     | No flags are affected.                                                                                                                                                                                                                 |
| Format    | Bytes Cycles Op Code<br>(Hex)                                                                                                                                                                                                          |
|           | opc 1 4 5F                                                                                                                                                                                                                             |
| Example   | The <i>SB1</i> statement sets FLAGS.0 to 1, selecting Bank1 register addressing, if implemented.                                                                                                                                       |





# Subtract with Carry

| SBC       | dst, src                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                         |                                                                    |                                                          |                                                        |                                                          |                                                                                              |                                                    |                                           |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|--------------------------------------------------------------------|----------------------------------------------------------|--------------------------------------------------------|----------------------------------------------------------|----------------------------------------------------------------------------------------------|----------------------------------------------------|-------------------------------------------|
| Operation | dst ←                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | dst                                     | $-\operatorname{src}-\operatorname{c}$                             |                                                          |                                                        |                                                          |                                                                                              |                                                    |                                           |
|           | from t<br>tents o<br>two's-<br>precis                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | the d<br>of th<br>com<br>ion a<br>f the | lestination<br>e source a<br>plement o<br>arithmetic<br>e low-orde | operand a<br>re unaffect<br>f the sourc<br>, this instru | nd the rest<br>ted. Subtu-<br>te operan-<br>totion per | sult is stor<br>raction is<br>d to the de<br>rmits the o | of the carry<br>red in the de<br>performed l<br>estination op<br>carry borrow<br>rom the sub | stination.<br>by adding<br>berand. In<br>w from th | The con-<br>the<br>multiple<br>e subtrac- |
| Flags     | <ul> <li>C Set if a borrow occurred (src &gt; dst); cleared otherwise.</li> <li>Z Set if the result is 0; cleared otherwise.</li> <li>S Set if the result is negative; cleared otherwise.</li> <li>V Set if arithmetic overflow occurred, i.e., if the operands were of opposite sign and the sign of the result is the same as the sign of the source; cleared otherwise.</li> <li>D Always set to 1.</li> <li>H Cleared if there is a carry from the most significant bit of the low-order four bits of the result; set otherwise, indicating a borrow.</li> </ul> |                                         |                                                                    |                                                          |                                                        |                                                          |                                                                                              |                                                    |                                           |
| Format    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |                                                                    | ·                                                        | Bytes                                                  |                                                          | Op Code                                                                                      |                                                    | s Mode                                    |
| -         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |                                                                    |                                                          | Dytes                                                  | Cycles                                                   | (Hex)                                                                                        | dst                                                | src                                       |
|           | ор                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | С                                       | dst   src                                                          |                                                          | 2                                                      | 4                                                        | 32                                                                                           | r                                                  | r                                         |
|           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |                                                                    |                                                          |                                                        | 6                                                        | 33                                                                                           | r                                                  | lr                                        |
|           | ор                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | с                                       | src                                                                | dst                                                      | 3                                                      | 6                                                        | 34                                                                                           | R                                                  | R                                         |
|           | <u></u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                         | <u> </u>                                                           | J                                                        |                                                        | 6                                                        | 35                                                                                           | R                                                  | IR                                        |
|           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |                                                                    |                                                          |                                                        |                                                          |                                                                                              |                                                    |                                           |

Example

opc

dst

Assume that R1 = 10h, R2 = 03h, C = 1, register 01h = 20h, register 02h = 03h and register 03h = 0Ah.

3

6

36

| SBC | R1, R2   | R1 = 0Ch, R2 = 03h                     |
|-----|----------|----------------------------------------|
| SBC | R1, @R2  | R1 = 05h, R2 = 03h, register 03h = 0Ah |
| SBC | 01h, 02h | Register 01h = 1Ch, register 02h = 03h |

src

R

IM





| SBC | 01h, @02h | Register 01h = 15h, register 02h = 03h, register 03h = 0Ah |
|-----|-----------|------------------------------------------------------------|
| SBC | 01h, #8Ah | Register $01h = 95h$ ; C, S, and V = 1                     |

In the first example, if working register R1 contains the value 10h and register R2 the value 03h, the *SBC R1*, *R2* statement subtracts the source value (03h) and the C flag value (1) from the destination (10h) and then stores the result (0Ch) in register R1.



An DXYS Company

#### 172

### Set Carry Flag

| SCF       |                                                                         |
|-----------|-------------------------------------------------------------------------|
| Operation | $C \leftarrow 1$                                                        |
|           | The carry flag (C) is set to logic 1, regardless of its previous value. |
| Flags     | C Set to 1.<br>No other flags are affected.                             |
| Format    | Bytes Cycles Op Code<br>(Hex)                                           |
|           | opc 1 4 DF                                                              |
| Example   | The SCF statement sets the carry flag to logic 1.                       |





### Shift Right Arithmetic

SRA dst

**Operation**  $dst(7) \leftarrow dst(7)$ 

 $C \leftarrow dst(0)$ 

 $dst(n) \leftarrow dst(n+1), n = 0 - 6$ 

An arithmetic shift-right of one bit position is performed on the destination operand. Bit 0 (the LSB) replaces the carry flag. The value of bit 7 (the sign bit) is unchanged and is shifted into bit position 6.

Figure 56 shows how bits shift right.



Figure 56. Shift Right

| Flags | С | Set if the bit shifted from the LSB position (bit 0) is 1. |
|-------|---|------------------------------------------------------------|
|-------|---|------------------------------------------------------------|

- **Z** Set if the result is 0; cleared otherwise.
- **S** Set if the result is negative; cleared otherwise.
- V Always cleared to 0.
- D Unaffected.
- H Unaffected.

#### Format

|     |     | Byte | s Cycles | Op Code | Address Mode |
|-----|-----|------|----------|---------|--------------|
|     |     |      |          | (Hex)   | dst          |
| орс | dst | 2    | 4        | D0      | R            |
|     |     |      | 4        | D1      | IR           |
|     |     |      |          |         |              |

| Example | Assum $C = 1$ . | Assume that Register $00h = 9Ah$ , register $02h = 03h$ , register $03h = 0BCh$ , and $C = 1$ . |                                                  |  |  |  |  |
|---------|-----------------|-------------------------------------------------------------------------------------------------|--------------------------------------------------|--|--|--|--|
|         | SRA             | 00h                                                                                             | Register $00h = 0CD, C = 0$                      |  |  |  |  |
|         | SRA             | @02h                                                                                            | Register 02h = 03h, register 03h = 0DEh, $C = 0$ |  |  |  |  |



In the first example, if general register 00h contains the value 9Ah (10011010B), the *SRA 00h* statement shifts the bit values in register 00h right one bit position. Bit 0 (0) clears the C flag and bit 7 (1) is then shifted into the bit 6 position (bit 7 remains unchanged). This leaves the value 0CDh (11001101b) in destination register 00h.





# Set Register Pointer

| SRP       | src                                                                                                                                        |                   |                       |                   |                                                            |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-----------------------|-------------------|------------------------------------------------------------|
| SRP0      | src                                                                                                                                        |                   |                       |                   |                                                            |
| SRP1      | src                                                                                                                                        |                   |                       |                   |                                                            |
| Operation | If $src(1) = 1$ and $src(0) = 0$ then<br>If $src(1) = 1$ and $src(0) = 0$ then<br>If $src(1) = 1$ and $src(0) = 0$ then                    | า:                | RP0 (3)               | -7)<br>-7)<br>-7) | src (3–7)<br>src (3–7)<br>src (4–7)<br>0<br>src (4–7)<br>1 |
|           | The sources data bits one and z<br>both of the register pointers, RI<br>pointer are written unless both<br>cleared to logic 0 and RP1.3 is | P0 and R register | P1. Bits 3 pointers a | 3–7 of the s      | elected register                                           |
| Flags     | No flags are affected.                                                                                                                     |                   |                       |                   |                                                            |
| Format    |                                                                                                                                            | Bytes             | Cycles                | Op Code<br>(Hex)  | Address Mode<br>src                                        |
|           | opc src                                                                                                                                    | 2                 | 4                     | 31                | IM                                                         |
| Example   | The <i>SRP</i> #40 <i>h</i> statement sets read and register pointer 1 (RP1) at 1                                                          |                   |                       |                   | ation 0D6h to 40h                                          |

The SRP0 #50h statement sets RP0 to 50h, and the SRP1 #68h statement sets RP1 to 68h.



DIXYS Company

#### 176

# **Stop Operation**

#### STOP Operation The STOP instruction stops the both the CPU clock and system clock and causes the microcontroller to enter Stop Mode. During Stop Mode, the contents of on-chip CPU registers, peripheral registers, and I/O port control and data registers are retained. Stop Mode can be released by an external reset operation or by external interrupts. For the reset operation, the RESET pin must be held to Low level until the required oscillation stabilization interval has elapsed. Flags No flags are affected. Format Bytes Cycles Op Code Address Mode (Hex) dst src 1 4 7F opc \_ \_ Example The STOP statement halts all microcontroller operations.





### Subtract

| SUB       | dst, src                                                                                                                                                                                                                                                                   |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation | $dst \leftarrow dst - src$                                                                                                                                                                                                                                                 |
|           | The source operand is subtracted from the destination operand and the result is<br>stored in the destination. The contents of the source are unaffected. Subtraction<br>is performed by adding the two's complement of the source operand to the des-<br>tination operand. |
| Flags     | <b>C</b> Set if a borrow occurred; cleared otherwise.                                                                                                                                                                                                                      |
|           | <b>Z</b> Set if the result is 0; cleared otherwise.                                                                                                                                                                                                                        |
|           | <b>S</b> Set if the result is negative; cleared otherwise.                                                                                                                                                                                                                 |
|           | <b>V</b> Set if arithmetic overflow occurred, i.e., if the operands were of opposite signs and the sign of the result is of the same as the sign of the source operand; cleared otherwise.                                                                                 |
|           | D Always set to 1.                                                                                                                                                                                                                                                         |
|           | H Cleared if there is a carry from the most significant bit of the low-order four bits of the result; set otherwise indicating a borrow.                                                                                                                                   |
| Format    | Bytes Cycles Op Code Address Mode                                                                                                                                                                                                                                          |
|           | (Hex) dst src                                                                                                                                                                                                                                                              |

|     |           |     |   |   | (Hex) | dst | src |
|-----|-----------|-----|---|---|-------|-----|-----|
| орс | dst   src |     | 2 | 4 | 22    | r   | r   |
|     |           |     |   | 6 | 23    | r   | lr  |
| 1   | 1         |     | 1 |   |       |     |     |
| орс | src       | dst | 3 | 6 | 24    | R   | R   |
|     |           |     |   | 6 | 25    | R   | IR  |
|     | <u>.</u>  |     |   |   |       |     |     |
| орс | dst       | src | 3 | 6 | 26    | R   | IM  |

Example

Assume that R1 = 12h, R2 = 03h, register 01h = 21h, register 02h = 03h, register 03h = 0Ah.

| SUB | R1, R2    | R1 = 0Fh, R2 = 03h                      |
|-----|-----------|-----------------------------------------|
| SUB | R1, @R2   | R1 = 08h, R2 = 03h                      |
| SUB | 01h, 02h  | Register 01h = 1Eh, register 02h = 03h  |
| SUB | 01h, @02h | Register 01h = 17h, register 02h = 03h  |
| SUB | 01h, #90h | Register $01h = 91h$ ; C, S, and V = 1  |
| SUB | 01h, #65h | Register 01h = 0BCh; C and S = 1, V = 0 |



178

In the first example, if working register R1 contains the value 12h and if register R2 contains the value 03h, the *SUB R1, R2* statement subtracts the source value (03h) from the destination value (12h) and stores the result (0Fh) in destination register R1.





i In Li

### Swap Nibbles

SRA dst

**Operation**  $dst(0-3) \leftrightarrow dst(4-7)$ 

The contents of the lower four bits and upper four bits of the destination operand are swapped.

Figure 57 shows how to swap nibbles.



Figure 57. Swap Nibbles

Flags C Undefined.

Z Set if the result is 0; cleared otherwise.

- **S** Set if the result bit 7 is set; cleared otherwise.
- V Undefined.
- D Unaffected.
- H Unaffected.

#### Format

|     |     | Bytes | Cycles | Op Code | Address Mode |
|-----|-----|-------|--------|---------|--------------|
|     |     |       |        | (Hex)   | dst          |
| орс | dst | 2     | 4      | F0      | R            |
|     |     | _     | 4      | F1      | IR           |

**Example** Assume that Register 00h = 3Eh, register 02h = 03h, and register 03h = 0A4h. SWAP 00h Register 00h = 0E3h

| 0117.1 | 0011 |                                        |
|--------|------|----------------------------------------|
| SWAP   | @02h | Register 02h = 03h, register 03h = 4Ah |

In the first example, if general register 00h contains the value 3Eh (00111110b), the *SWAP 00h* statement swaps the lower and upper four bits (nibbles) in the 00h register, leaving the value 0E3h (11100011b).



180

### Test Complement under Mask

| ТСМ       | dst,                       | src                                                                                                                                                       |                                             |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                   |                                      |
|-----------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|--------------------------------------|
| Operation | (NC                        | OT dst) AND src                                                                                                                                           |                                             |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                   |                                      |
|           | The<br>tion<br>nati<br>can | s instruction tests select<br>bits to be tested are sp<br>of the source operand<br>on operand, which is th<br>then be checked to det<br>s are unaffected. | ecified by se<br>(mask). The<br>nen ANDed y | tting a 1 b<br>TCM stat<br>with the so | bit in the contemport of the contemport of the component com | rrespondi<br>plements<br>The zero | ng posi-<br>the desti-<br>o (Z) flag |
| Flags     | C<br>Z<br>S<br>V<br>D<br>H | Unaffected.<br>Set if the result is 0;<br>Set if the result bit 7<br>Always cleared to 0.<br>Unaffected.<br>Unaffected.                                   |                                             |                                        | se.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                   |                                      |
| Format    |                            |                                                                                                                                                           | Bytes                                       | Cycles                                 | Op Code                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Addres                            | s Mode                               |
|           |                            |                                                                                                                                                           |                                             |                                        | (Hex)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | dst                               | src                                  |
|           | C                          | opc dst   src                                                                                                                                             | 2                                           | 4                                      | 62                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | r                                 | r                                    |
|           |                            |                                                                                                                                                           |                                             | 6                                      | 63                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | r                                 | Ir                                   |

| <u></u> | 1   | 1   |   | 6      | 63       | r      | lr      |
|---------|-----|-----|---|--------|----------|--------|---------|
| орс     | src | dst | 3 | 6<br>6 | 64<br>65 | R<br>R | R<br>IR |
| орс     | dst | SrC | 3 | 6      | 66       | R      | IM      |

Example Assume that R0 = 0C7h, R1 = 02h, R2 = 12h, register 00h = 2Bh, register 01h= 02h and register 02h = 23h.

| ТСМ | R0, R1    | R0 = 0C7h, R1 = 02h, Z = 1                                                 |
|-----|-----------|----------------------------------------------------------------------------|
| ТСМ | R0, @R1   | R0 = 0C7h, R1 = 02h, register 02h = 23h, Z = 0                             |
| ТСМ | 00h, 01h  | Register 00h = 2Bh, register 01h = 02h, Z = 1                              |
| ТСМ | 00h, @01h | Register $00h = 2Bh$ , register $01h = 02h$ , register $02h = 23h$ , Z = 1 |
| ТСМ | 00h, #34  | Register $00h = 2Bh, Z = 0$                                                |

Zilog Embudded in Life An DXYS Company 181

In the first example, if working register R0 contains the value 0C7h (11000111b) and register R1 the value 02h (0000010b), the *TCM R0, R1* statement tests bit 1 in the destination register for a 1 value. Because the mask value corresponds to the test bit, the Z flag is set to logic 1 and can be tested to determine the result of the TCM operation.





### **Test Under Mask**

| ТМ        | dst,                       | src                      |                                |                                          |                                |                          |                                         |                                                            |                        |                       |
|-----------|----------------------------|--------------------------|--------------------------------|------------------------------------------|--------------------------------|--------------------------|-----------------------------------------|------------------------------------------------------------|------------------------|-----------------------|
| Operation | dst 4                      | AND                      | src                            |                                          |                                |                          |                                         |                                                            |                        |                       |
|           | The<br>tion<br>and         | bits to<br>of th<br>The  | to be te<br>e sourc<br>zero (2 | sted are<br>ce opera<br>Z) flag c        | e specif<br>and (ma<br>can the | fied by se<br>ask), whic | etting a 1 b<br>ch is ANE<br>ked to det | on operand<br>bit in the co<br>Ded with the<br>termine the | rrespondi<br>destinati | ng posi-<br>ion oper- |
| Flags     | C<br>Z<br>S<br>V<br>D<br>H | Set<br>Set<br>Alw<br>Un: | t if the i                     | result is<br>result bi<br>set to 0<br>d. | it 7 is s                      | ared othe<br>et; cleare  | rwise.<br>d otherwi                     | se.                                                        |                        |                       |
| Format    |                            |                          |                                |                                          |                                | Bytes                    | Cycles                                  | Op Code                                                    | Addres                 | s Mode                |
|           | _                          |                          |                                |                                          |                                |                          |                                         | (Hex)                                                      | dst                    | src                   |
|           | C                          | рс                       | dst                            | src                                      |                                | 2                        | 4                                       | 72                                                         | r                      | r                     |
|           |                            |                          |                                |                                          |                                |                          | 6                                       | 73                                                         | r                      | Ir                    |

|     |     |     |   | 0 | 75 |   |    |
|-----|-----|-----|---|---|----|---|----|
| орс | SIC | dst | 3 | 6 | 74 | R | R  |
|     |     |     | , | 6 | 75 | R | IR |
|     |     |     |   |   |    |   |    |
| орс | dst | src | 3 | 6 | 76 | R | IM |

**Example** Assume that R0 = 0C7h, R1 = 02h, R2 = 18h, register 00h = 2Bh, register 01h = 02h and register 02h = 23h.

| ТМ | R0, R1    | R0 = 0C7h, R1 = 02h, Z = 0                                                   |
|----|-----------|------------------------------------------------------------------------------|
| ТМ | R0, @R1   | R0 = 0C7h, R1 = 02h, register 02h = 23h, Z = 0                               |
| ТМ | 00h, 01h  | Register $00h = 2Bh$ , register $01h = 02h$ , Z = 0                          |
| ТМ | 00h, @01h | Register $00h = 2Bh$ , register $01h = 02h$ , register $02h = 23h$ , $Z = 0$ |
| ТМ | 00h, #54  | Register 00h = 2Bh, Z = 1                                                    |

In the first example, if working register R0 contains the value 0C7h (11000111b) and register R1 the value 02h (00000010b), the *TM R0, R1* 



Embedded in Life An DIXYS Company 183

statement tests bit 1 in the destination register for a 0 value. Because the mask value does not match the test bit, the Z flag is cleared to logic 0 and can be tested to determine the result of the TM operation.



# Wait for Interrupt

| WFI       |                                                                                                                                                                                                                              |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation | The CPU is effectively halted until an interrupt occurs, except that DMA trans-<br>fers can still take place during this wait state. The WFI status can be released by<br>an internal interrupt, including a fast interrupt. |
| Flags     | No flags are affected.                                                                                                                                                                                                       |
| Format    | Bytes         Cycles         Op Code<br>(Hex)           opc         1         4n         3F           Note:         n = 1, 2, 3, etc.         1         1         1                                                          |
| Example   | Figure 58 presents a sample program structure that depicts the sequence of operations that follow a <i>WFI</i> statement.                                                                                                    |
|           | EI (Enable global interrupt)<br>WFI (Wait for interrupt)<br>(Next instruction)<br>Interrupt occurs<br>Interrupt service routine<br>Clear interrupt flag<br>IRET                                                              |
|           | Service routine completed                                                                                                                                                                                                    |

Figure 58. Sample Program Structure





### Logical Exclusive OR

| XOR       | dst, src                                                                                                                                                                                                                                                                                    |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation | dst ← dst XOR src                                                                                                                                                                                                                                                                           |
|           | The source operand is logically exclusive-ORed with the destination operand<br>and the result is stored in the destination. The exclusive-OR operation results in<br>a 1 bit being stored whenever the corresponding bits in the operands are differ-<br>ent; otherwise, a 0 bit is stored. |
| Flags     | <ul> <li>C Unaffected.</li> <li>Z Set if the result is 0; cleared otherwise.</li> <li>S Set if the result bit 7 is set; cleared otherwise.</li> <li>V Always reset to 0.</li> <li>D Unaffected.</li> <li>H Unaffected.</li> </ul>                                                           |
| Format    | Bytes Cycles Op Code Address Mode                                                                                                                                                                                                                                                           |

|     |           |     | Dytes | Cycles | Opcode | Addres | Simoue |
|-----|-----------|-----|-------|--------|--------|--------|--------|
|     |           |     |       |        | (Hex)  | dst    | src    |
| орс | dst   src |     | 2     | 4      | B2     | r      | r      |
|     |           |     |       | 6      | B3     | r      | lr     |
|     |           |     |       |        |        |        |        |
| орс | src       | dst | 3     | 6      | B4     | R      | R      |
|     |           |     |       | 6      | B5     | R      | IR     |
|     |           |     |       |        |        |        |        |
| орс | dst       | src | 3     | 6      | B6     | R      | IM     |

**Example** Assume that R0 = 0C7h, R1 = 02h, R2 = 18h, register 00h = 2Bh, register 01h = 02h and register 02h = 23h.

| XOR | R0, R1    | R0 = 0C5h, R1 = 02h                                                |
|-----|-----------|--------------------------------------------------------------------|
| XOR | R0, @R1   | R0 = 0E4h, R1 = 02h, register 02h = 23h                            |
| XOR | 00h, 01h  | Register 00h = 29h, register 01h = 02h                             |
| XOR | 00h, @01h | Register $00h = 08h$ , register $01h = 02h$ , register $02h = 23h$ |
| XOR | 00h, #54h | Register 00h = 7Fh                                                 |

In the first example, if working register R0 contains the value 0C7h and if register R1 contains the value 02h, the *XOR R0, R1* statement logically exclusive-ORs the R1 value with the R0 value and stores the result (0C5h) in the destination register R0.



DXYS Company

#### 186

# **Clock Circuit**

The S3F8S5A microcontroller features two oscillator circuits: a main clock and a subclock circuit. The CPU and peripheral hardware operate on the system clock frequency supplied through these circuits. The maximum CPU clock frequency of the S3F8S5A MCU is determined by the settings in the CLKCON Register. These main oscillator circuits are shown in Figures 59 through 63.



Figure 59. Crystal/Ceramic Oscillator (f<sub>X</sub>)







Figure 61. RC Oscillator (f<sub>X</sub>)











Figure 63. External Oscillator (f<sub>XT</sub>)

## **System Clock Circuit**

The system clock circuit features the following components:

- External crystal, ceramic resonator, RC oscillation source, or an external clock source
- Oscillator stop and wake-up functions
- Programmable frequency divider for the CPU clock (f<sub>XX</sub> divided by 1, 2, 8, or 16)
- System Clock Control (CLKCON) Register
- Oscillator Control (OSCCON) and Stop Control (STPCON) registers

## **CPU Clock Notation**

In this document, the following notations are used to describe the CPU clock:

•  $f_X = Main clock$ 





- $f_{XT} = Subclock$
- $f_{XX}$  = Selected system clock

# **Clock Status During Power-Down Modes**

Two power-down modes, Stop Mode and Idle Mode, affect the system clock as follows:

- In Stop Mode, the main oscillator is halted. Stop Mode is released, and the oscillator is started, by a reset operation or an external interrupt (with an RC delay noise filter), and can also be released by internal interrupt when the subsystem oscillator is running and the watch timer is operating with the subsystem clock.
- In Idle Mode, the internal clock signal is gated to the CPU, but not to the interrupt structure, timers, and timer/counters. Idle Mode is released by a reset or by an external or internal interrupt.

A block diagram of the system clock circuit is shown in Figure 64.



Embeckhod in Life An DXYS Company 189



Figure 64. System Clock Circuit Diagram



190

## System Clock Control Register

The System Clock Control (CLKCON) Register, shown in Table 32, is located at address D4h, Set1. This register is read/write-addressable and offers an oscillator frequency divide-by value.

After the main oscillator is activated,  $f_{XX}/16$  (the slowest clock speed) is selected as the CPU clock. If necessary, the CPU clock speed can be increased to  $f_{XX}/8$ ,  $f_{XX}/2$ , or  $f_{XX}/1$ .

| Bit         | 7                                                                                                                                                                       | 6                                                                                                                                                | 5         | 4             | 3          | 2    | 1 | 0 |  |  |  |  |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|-----------|---------------|------------|------|---|---|--|--|--|--|
| Reset       | _                                                                                                                                                                       | _                                                                                                                                                | _         | 0             | 0          | _    | _ |   |  |  |  |  |
| R/W         | R/W                                                                                                                                                                     | _                                                                                                                                                | _         | R/W           | R/W        | _    | _ | _ |  |  |  |  |
| Address     |                                                                                                                                                                         |                                                                                                                                                  |           | D             | 4h         |      |   |   |  |  |  |  |
| Mode        |                                                                                                                                                                         |                                                                                                                                                  | Re        | gister Addres | ssing Mode | only |   |   |  |  |  |  |
| Note: R = r | ead only; R/W = re                                                                                                                                                      | ead/write.                                                                                                                                       |           |               |            |      |   |   |  |  |  |  |
| Bit         | Descriptio                                                                                                                                                              | Description                                                                                                                                      |           |               |            |      |   |   |  |  |  |  |
| [7]         | 0: Enable I                                                                                                                                                             | Oscillator IRQ Wake-up Function Bit<br>0: Enable IRQ for main wake-up in Power Down Mode.<br>1: Disable IRQ for main wake-up in Power Down Mode. |           |               |            |      |   |   |  |  |  |  |
| [6:5]       | Reserved                                                                                                                                                                |                                                                                                                                                  |           |               |            |      |   |   |  |  |  |  |
| [4:3]       | <b>CPU Clock</b><br>00: f <sub>XX</sub> /16.<br>01: f <sub>XX</sub> /8.<br>10: f <sub>XX</sub> /2.<br>11: f <sub>XX</sub> /1.                                           | c (System                                                                                                                                        | Clock) Se | lection Bits  | *          |      |   |   |  |  |  |  |
| [2:0]       | Reserved                                                                                                                                                                |                                                                                                                                                  |           |               |            |      |   |   |  |  |  |  |
|             | *After a reset, the slowest clock (divided by 16) is selected as the system clock. To select faster clock speeds, load the appropriate values to CLKCON.3 and CLKCON.4. |                                                                                                                                                  |           |               |            |      |   |   |  |  |  |  |

#### Table 32. System Clock Control Register (CLKCON; Set1)

## **Oscillator Control Register**

The Oscillator Control (OSCCON) Register, shown in Table 33, is located in Set1, Bank0, at address FAh. It is read/write addressable and offers the following functions:

- System clock selection
- Main oscillator control
- Suboscillator control





#### Table 33. Oscillator Control Register (OSCCON; Set1, Bank0)

| Bit     | 7                             | 6 | 5 | 4 | 3   | 2   | 1 | 0   |  |  |
|---------|-------------------------------|---|---|---|-----|-----|---|-----|--|--|
| Reset   | -                             | _ | _ | - | 0   | 0   | _ | 0   |  |  |
| R/W     | -                             | _ | _ | - | R/W | R/W | _ | R/W |  |  |
| Address | FAh                           |   |   |   |     |     |   |     |  |  |
| Mode    | Register Addressing Mode only |   |   |   |     |     |   |     |  |  |

Note: R = read only; R/W = read/write.

| Bit   | Description                                                                                                            |
|-------|------------------------------------------------------------------------------------------------------------------------|
| [7:4] | Reserved                                                                                                               |
| [3]   | Main Oscillator Control Bit<br>0: Main oscillator RUN.<br>1: Main oscillator STOP.                                     |
| [2]   | Suboscillator Control Bit<br>0: Suboscillator RUN.<br>1: Suboscillator STOP.                                           |
| [1]   | Reserved                                                                                                               |
| [0]   | System Clock Selection Bit<br>0: Select main oscillator for system clock.<br>1: Select suboscillator for system clock. |

The OSCCON.0 register settings select the main clock or the subclock as the system clock. After a reset, the main clock is selected for the system clock because the reset value of OSCCON.0 is 0.

The main oscillator can be stopped or run by setting OSCCON.3. The suboscillator can be stopped or run by setting OSCCON.2.





id In Life

# **Stop Control Register**

The Stop Control (STPCON) Register, shown in Table 34, is located in Set1, Bank0, at address EDh. It is read/write addressable and offers an enable/disable STOP instruction. After a reset, this STOP instruction is disabled, because the value of STPCON is *other values*.

| Bit            | 7                             | 6          | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|----------------|-------------------------------|------------|---|---|---|---|---|---|--|--|
| Reset          | 0                             | 0          | 0 | 0 | 0 | 0 | 0 | 0 |  |  |
| R/W            | R/W                           |            |   |   |   |   |   |   |  |  |
| Address        | EDh                           |            |   |   |   |   |   |   |  |  |
| Mode           | Register Addressing Mode only |            |   |   |   |   |   |   |  |  |
| Note: R = read | d only; R/W = r               | ead/write. |   |   |   |   |   |   |  |  |

| Table 34. St | top Control | Register | (STPCON; Se | et1. Bank0)   |
|--------------|-------------|----------|-------------|---------------|
|              |             |          | (,          | ···, _ ·····, |

| Bit   | Description                                                                                                                                                            |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7]   | Stop Control Bits*                                                                                                                                                     |
|       | 10100101: Enable stop instruction.                                                                                                                                     |
|       | All other values: disable stop instruction.                                                                                                                            |
| Note: | *Before executing a stop instruction, this STPCON Register must be set as 10100101b; otherwise, the stop in struction will not execute, and a reset will be generated. |

If necessary, the STOP instruction can be used by setting the value of STPCON to 10100101b, as shown in the following example, which shows how to enter Stop Mode when a main clock is selected as the system clock.

#### Example

| LD   | STOPCON,#1010010b  | ; Enable STOP instruction  |
|------|--------------------|----------------------------|
| STOP |                    | ; Enter Stop Mode          |
| NOP  |                    |                            |
| NOP  |                    |                            |
| NOP  |                    | ; Release STOP mode        |
| LD   | STOPCON, #0000000b | ; Disable STOP instruction |

# Switching the CPU Clock

Data loading in the Oscillator Control (OSCCON) Register determines whether a main clock or a subclock is selected as the CPU clock, and also how this frequency is to be



divided by setting CLKCON. As a result, it is possible to dynamically switch between main and subclocks and to modify operating frequencies.

OSCCON.0 selects the main clock  $(f_X)$  or the subclock  $(f_{XT})$  for the CPU clock. OSC-CON .3 starts or stops the main clock oscillation, and OSCCON.2 starts or stops the subclock oscillation. CLKCON.4–.3 controls the frequency divider circuit and divides the selected  $f_{XX}$  clock by 1, 2, 8, and 16. If the subclock  $(f_{XT})$  is selected as the system clock, CLKCON. 4–.3 must be set to 11.

As an example, if you are using the default CPU clock (i.e., under normal operating mode and with a main clock of  $f_X/16$ ) and you want to switch from the  $f_X$  clock to a subclock and to stop the main clock, you must set CLKCON.4–.3 to 11, OSCCON.0 to 1, and OSC-CON.3 to 1 in sequence. As a result, the clock is switched from  $f_X$  to  $f_{XT}$ , and main clock oscillation is stopped.

The following example presents the steps that must be taken to switch from a subclock to the main clock. First, set OSCCON.3 to 0 to enable main clock oscillation. Next, after a certain number of machine cycles have elapsed, select the main clock by setting OSC-CON.0 to 0.

**Example 1.** The following example shows how to change from the main clock to the subclock.

| MA2SUB OR | CLKCON,#18h | ; Nondivided clock for system clock   |
|-----------|-------------|---------------------------------------|
| LD        | OSCCON,#01h | ; Switches to the subclock            |
| CALL      | DLY16       | ; Delay 16 ms                         |
| OR        | OSCCON,#08h | ; Stop the main clock oscillation RET |

**Example 2.** This next example shows how to change from the subclock to the main clock.

| SUB2MA<br>CALL | DLY16       | ; | Start the main clock oscillation Delay 16 ms |
|----------------|-------------|---|----------------------------------------------|
| AND            | OSCCON,#06h | ; | Switch to the main clock                     |
| RET            |             |   |                                              |
| DLY16          | SRP #0C0h   |   |                                              |
| LD             | R0,#20h     |   |                                              |
| DEL            | NOP         |   |                                              |
| DJNZ           | R0,DEL      |   |                                              |
| RET            |             |   |                                              |



# **Reset and Power-Down**

This chapter discusses system reset and power-down modes.

# **System Reset**

During a power-on reset, the voltage at  $V_{DD}$  goes High and the nRESET pin is forced Low. The nRESET signal is input through a Schmitt trigger circuit, where it is synchronized with the CPU clock. This procedure brings the S3F8S5A MCU into a known operating status.

To allow time for internal CPU clock oscillation to stabilize, the nRESET pin must be held Low for a minimum time interval after the power supply comes within tolerance. The minimum required time of a reset operation for oscillation stabilization is one millisecond.

Whenever a reset occurs during normal operation (i.e., when both  $V_{DD}$  and nRESET are High), the nRESET pin is forced Low, and the reset operation starts. All system and peripheral control registers are then reset to their default hardware values. In summary, the following sequence of events occurs during a reset operation:

- All interrupts are disabled.
- The watchdog (basic timer) function is enabled.
- Ports 0–4 are set to Input Mode, and all pull-up resistors are disabled for the I/O port.
- Peripheral control and data register settings are disabled and reset to their default hardware values.
- The program counter (PC) is loaded with the 0100h program reset address within ROM.
- When the programmed oscillation stabilization time interval has elapsed, the instruction stored at ROM location 0100h (and at 0101h) is fetched and executed in Normal Mode by the Smart Option.
- The reset address in ROM can be changed by the Smart Option in the S3F8S5A fullflash device. Refer to the <u>Embedded Flash Memory Interface</u> chapter on page 334 to learn more.

### **Normal Mode Reset Operation**

In Normal Mode, the Test pin is tied to  $V_{SS}$ . A reset enables access to the 16KB on-chip ROM; the external interface is not automatically configured.



cided in Life

DIXYS Company



**Note:** To program the duration of the oscillation stabilization interval, make the appropriate settings to the Basic Timer Control (BTCON) Register before entering Stop Mode. Additionally, if not using the basic timer watchdog function (which causes a system reset if a basic timer counter overflow occurs), it can be disabled by writing 1010b to the upper nibble of BTCON.

#### **Hardware Reset Values**

Tables 35 through 38 list the reset values for the CPU and system registers, the peripheral control registers, and the peripheral data registers following a reset operation. The following notation is used to represent these reset values:

- A 1 or a 0 shows the reset bit value as logic 1 or logic 0, respectively
- An x means that the bit value is undefined after a reset
- A dash (-) means that the bit is either not used or not mapped (however, a 0 is read from the bit position)

| ON<br>CON<br>GS | <b>Dec</b> 211 212 | Hex<br>D3h<br>D4h                             | 7<br>0<br>0                                                                                                                                       | <b>6</b><br>0                                                                                                                                                                                             | <b>5</b><br>0                                                                                                                                                                                                                                                     | <b>4</b><br>0                                                                                                                                                                                                                                                               | <b>3</b><br>0                                                                                                                                                                                                                                                                                                               | <b>2</b><br>0                                                                                                                                                                                                                                                                                                                                                                                                       | <b>1</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                            | <b>0</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------------|--------------------|-----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CON             | 212                |                                               | -                                                                                                                                                 | 0                                                                                                                                                                                                         | 0                                                                                                                                                                                                                                                                 | 0                                                                                                                                                                                                                                                                           | 0                                                                                                                                                                                                                                                                                                                           | 0                                                                                                                                                                                                                                                                                                                                                                                                                   | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| CON             | 212                |                                               | -                                                                                                                                                 | 0                                                                                                                                                                                                         | 0                                                                                                                                                                                                                                                                 | 0                                                                                                                                                                                                                                                                           | 0                                                                                                                                                                                                                                                                                                                           | 0                                                                                                                                                                                                                                                                                                                                                                                                                   | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Δ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                 |                    | D4h                                           | 0                                                                                                                                                 |                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                     | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| GS              |                    |                                               | 5                                                                                                                                                 | _                                                                                                                                                                                                         | —                                                                                                                                                                                                                                                                 | 0                                                                                                                                                                                                                                                                           | 0                                                                                                                                                                                                                                                                                                                           | -                                                                                                                                                                                                                                                                                                                                                                                                                   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                 | 213                | D5h                                           | Х                                                                                                                                                 | Х                                                                                                                                                                                                         | Х                                                                                                                                                                                                                                                                 | Х                                                                                                                                                                                                                                                                           | Х                                                                                                                                                                                                                                                                                                                           | Х                                                                                                                                                                                                                                                                                                                                                                                                                   | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                 | 214                | D6h                                           | 1                                                                                                                                                 | 1                                                                                                                                                                                                         | 0                                                                                                                                                                                                                                                                 | 0                                                                                                                                                                                                                                                                           | 0                                                                                                                                                                                                                                                                                                                           | -                                                                                                                                                                                                                                                                                                                                                                                                                   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                 | 215                | D7h                                           | 1                                                                                                                                                 | 1                                                                                                                                                                                                         | 0                                                                                                                                                                                                                                                                 | 0                                                                                                                                                                                                                                                                           | 1                                                                                                                                                                                                                                                                                                                           | -                                                                                                                                                                                                                                                                                                                                                                                                                   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                 | 216                | D8h                                           | х                                                                                                                                                 | Х                                                                                                                                                                                                         | Х                                                                                                                                                                                                                                                                 | Х                                                                                                                                                                                                                                                                           | Х                                                                                                                                                                                                                                                                                                                           | Х                                                                                                                                                                                                                                                                                                                                                                                                                   | Х                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | х                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                 | 217                | D9h                                           | х                                                                                                                                                 | Х                                                                                                                                                                                                         | Х                                                                                                                                                                                                                                                                 | Х                                                                                                                                                                                                                                                                           | Х                                                                                                                                                                                                                                                                                                                           | Х                                                                                                                                                                                                                                                                                                                                                                                                                   | Х                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | х                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                 | 218                | DAh                                           | Х                                                                                                                                                 | Х                                                                                                                                                                                                         | Х                                                                                                                                                                                                                                                                 | Х                                                                                                                                                                                                                                                                           | Х                                                                                                                                                                                                                                                                                                                           | Х                                                                                                                                                                                                                                                                                                                                                                                                                   | Х                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | х                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                 | 219                | DBh                                           | х                                                                                                                                                 | Х                                                                                                                                                                                                         | Х                                                                                                                                                                                                                                                                 | Х                                                                                                                                                                                                                                                                           | Х                                                                                                                                                                                                                                                                                                                           | Х                                                                                                                                                                                                                                                                                                                                                                                                                   | Х                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | х                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                 | 220                | DCh                                           | 0                                                                                                                                                 | 0                                                                                                                                                                                                         | 0                                                                                                                                                                                                                                                                 | 0                                                                                                                                                                                                                                                                           | 0                                                                                                                                                                                                                                                                                                                           | 0                                                                                                                                                                                                                                                                                                                                                                                                                   | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                 | 221                | DDh                                           | Х                                                                                                                                                 | Х                                                                                                                                                                                                         | Х                                                                                                                                                                                                                                                                 | Х                                                                                                                                                                                                                                                                           | Х                                                                                                                                                                                                                                                                                                                           | х                                                                                                                                                                                                                                                                                                                                                                                                                   | х                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | х                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                 |                    | 214<br>215<br>216<br>217<br>218<br>219<br>220 | 214       D6h         215       D7h         216       D8h         217       D9h         218       DAh         219       DBh         220       DCh | 214       D6h       1         215       D7h       1         216       D8h       x         217       D9h       x         218       DAh       x         219       DBh       x         220       DCh       0 | 214       D6h       1       1         215       D7h       1       1         216       D8h       x       x         217       D9h       x       x         218       DAh       x       x         219       DBh       x       x         220       DCh       0       0 | 214       D6h       1       1       0         215       D7h       1       1       0         216       D8h       x       x       x         217       D9h       x       x       x         218       DAh       x       x       x         219       DBh       x       x       x | 214       D6h       1       1       0       0         215       D7h       1       1       0       0         216       D8h       x       x       x       x         217       D9h       x       x       x       x         218       DAh       x       x       x       x         219       DBh       x       x       x       x | 214       D6h       1       1       0       0       0         215       D7h       1       1       0       0       1         216       D8h       x       x       x       x       x       x         217       D9h       x       x       x       x       x       x       x         218       DAh       x       x       x       x       x       x         219       DBh       x       x       x       x       x       x | 214       D6h       1       1       0       0       -         215       D7h       1       1       0       0       1       -         216       D8h       x       x       x       x       x       x       x       x         217       D9h       x       x       x       x       x       x       x       x         218       DAh       x       x       x       x       x       x       x         219       DBh       x       x       x       x       x       x       x | 214       D6h       1       1       0       0       0       -       -         215       D7h       1       1       0       0       1       -       -         216       D8h       x       x       x       x       x       x       x       x       x         217       D9h       x       x       x       x       x       x       x       x         218       DAh       x       x       x       x       x       x       x       x         219       DBh       x       x       x       x       x       x       x       x         220       DCh       0       0       0       0       0       0       0 |

#### Table 35. Set1 Register Values After RESET

Notes:

1. An x means that the bit value is undefined following reset.

2. A dash (-) means that the bit is neither used nor mapped, but the bit is read as 0.



### Table 35. Set1 Register Values After RESET (Continued)

|               |          | Address |     |   | Bit Values After Reset |   |   |   |   |   |   |
|---------------|----------|---------|-----|---|------------------------|---|---|---|---|---|---|
| Register Name | Mnemonic | Dec     | Hex | 7 | 6                      | 5 | 4 | 3 | 2 | 1 | 0 |
| System Mode   | SYM      | 222     | DEh | 0 | _                      | _ | Х | Х | Х | 0 | 0 |
| Register Page | PP       | 223     | DFh | 0 | 0                      | 0 | 0 | 0 | 0 | 0 | 0 |

Notes:

An *x* means that the bit value is undefined following reset.
 A dash (-) means that the bit is neither used nor mapped, but the bit is read as 0.

|                                  |           | Add | ress |   | Bi | t Val | ues | After | Res | et |   |
|----------------------------------|-----------|-----|------|---|----|-------|-----|-------|-----|----|---|
| Register Name                    | Mnemonic  | Dec | Hex  | 7 | 6  | 5     | 4   | 3     | 2   | 1  | 0 |
| A/D Converter Data (High Byte)   | ADDATAH   | 208 | D0h  | Х | Х  | х     | х   | Х     | Х   | Х  | х |
| A/D Converter Data (Low Byte)    | ADDATAL   | 209 | D1h  | - | -  | -     | -   | -     | -   | Х  | х |
| A/D Converter Control            | ADCON     | 210 | D2h  | - | 0  | 0     | 0   | 0     | 0   | 0  | 0 |
| Timer A Counter                  | TACNT     | 224 | E0h  | 0 | 0  | 0     | 0   | 0     | 0   | 0  | 0 |
| Timer A Data                     | TADATA    | 225 | E1h  | 1 | 1  | 1     | 1   | 1     | 1   | 1  | 1 |
| Timer A Control                  | TACON     | 226 | E2h  | 0 | 0  | 0     | 0   | 0     | 0   | 0  | 0 |
| Timer B Control                  | TBCON     | 227 | E3h  | - | -  | 0     | 0   | 0     | 0   | 0  | 0 |
| Timer B Data (High Byte)         | TBDATAH   | 228 | E4h  | 1 | 1  | 1     | 1   | 1     | 1   | 1  | 1 |
| Timer B Data (Low Byte)          | TBDATAL   | 229 | E5h  | 1 | 1  | 1     | 1   | 1     | 1   | 1  | 1 |
| Timer B Clock Selection Register | TBCLKS    | 230 | E6h  | - | -  | -     | -   | -     | 0   | 0  | 0 |
| SIO Control                      | SIOCON    | 231 | E7h  | 0 | 0  | 0     | 0   | 0     | 0   | 0  | 0 |
| SIO Data                         | SIODATA   | 232 | E8h  | 0 | 0  | 0     | 0   | 0     | 0   | 0  | 0 |
| SIO Prescaler                    | SIOPS     | 233 | E9h  | 0 | 0  | 0     | 0   | 0     | 0   | 0  | 0 |
| Timer C Counter                  | TCCNT     | 234 | EAh  | 0 | 0  | 0     | 0   | 0     | 0   | 0  | 0 |
| Timer C Data                     | TCDATA    | 235 | EBh  | 1 | 1  | 1     | 1   | 1     | 1   | 1  | 1 |
| Timer C Control                  | TCCON     | 236 | ECh  | 0 | 0  | 0     | 0   | 0     | 0   | 0  | 0 |
| Stop Control                     | STPCON    | 237 | EDh  | 0 | 0  | 0     | 0   | 0     | 0   | 0  | 0 |
| UART0 Control (High Byte)        | UART0CONH | 238 | EEh  | 0 | 0  | 0     | 0   | 0     | 0   | 0  | 0 |
| UART0 Control (Low Byte)         | UART0CONL | 239 | EFh  | 0 | 0  | 0     | 0   | 0     | 0   | 0  | 0 |
| UART0 Data                       | UDATA0    | 240 | F0h  | Х | Х  | Х     | Х   | Х     | Х   | Х  | Х |
| UART0 Baud Rate Data             | BRDATA0   | 241 | F1h  | 1 | 1  | 1     | 1   | 1     | 1   | 1  | 1 |
| UART1 Control (High Byte)        | UART1CONH | 242 | F2h  | 0 | 0  | 0     | 0   | 0     | 0   | 0  | 0 |
| UART1 Control (Low Byte)         | UART1CONL | 243 | F3h  | 0 | 0  | 0     | 0   | 0     | 0   | 0  | 0 |

#### Table 36. Set1, Bank0 Register Values After Reset



|                                            |          | ress | Bit Values After Reset |   |   |   |   |   |   |   |   |
|--------------------------------------------|----------|------|------------------------|---|---|---|---|---|---|---|---|
| Register Name                              | Mnemonic | Dec  | Hex                    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| UART1 Data                                 | UDATA1   | 244  | F4h                    | Х | Х | Х | Х | Х | Х | Х | Х |
| UART1 Baud Rate Data                       | BRDATA1  | 245  | F5h                    | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| Flash Memory Sector Address<br>(High Byte) | FMSECH   | 246  | F6h                    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Flash Memory Sector Address<br>(Low Byte)  | FMSECL   | 247  | F7h                    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Flash Memory User Programming Enable       | FMUSR    | 248  | F8h                    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Flash Memory Control                       | FMCON    | 249  | F9h                    | 0 | 0 | 0 | 0 | 0 | - | - | 0 |
| Oscillator Control                         | OSCCON   | 250  | FAh                    | _ | _ | _ | _ | 0 | 0 | _ | 0 |
| Interrupt pending                          | INTPND   | 251  | FBh                    | _ | - | 0 | 0 | 0 | 0 | 0 | 0 |
| Basic Timer Counter                        | BTCNT    | 253  | FDh                    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Location FEh is not mapped.                |          |      |                        |   |   |   |   |   |   |   |   |
| Interrupt Priority                         | IPR      | 255  | FFh                    | Х | х | х | х | х | х | х | Х |

#### Table 37. Set1, Bank1 Register and Values After RESET

|                                  |          | Add | Bit Values After Reset |   |   |   |   |   |   |   |   |
|----------------------------------|----------|-----|------------------------|---|---|---|---|---|---|---|---|
| Register Name                    | Mnemonic | Dec | Hex                    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Port 0 Control                   | P0CON    | 208 | D0h                    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Port 0 Pull-up Resistor Enable   | P0PUR    | 209 | D1h                    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Port 1 n-Channel Open-Drain Mode | PNE1     | 210 | D2h                    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Port 1 Control (High Byte)       | P1CONH   | 224 | E0h                    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Port 1 Control (Low Byte)        | P1CONL   | 225 | E1h                    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Port 1 Pull-up Resistor Enable   | P1PUR    | 226 | E2h                    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Port 1 Interrupt Control         | P1INT    | 227 | E3h                    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Port 1 Interrupt Pending         | P1PND    | 228 | E4h                    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Port 2 n-Channel Open-Drain Mode | PNE2     | 229 | E5h                    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Port 2 Control (High Byte)       | P2CONH   | 230 | E6h                    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Port 2 Control (Low Byte)        | P2CONL   | 231 | E7h                    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|                                  |          |     |                        |   |   |   |   |   |   |   |   |

Notes:

An *x* means that the bit value is undefined following reset.
 A dash (–) means that the bit is neither used nor mapped, but the bit is read as 0.

zilog sbockbod In Life An DXYS Company

198

|                                     |          | Add | ress |   | В | it Val | ues | After | r Res | set |   |
|-------------------------------------|----------|-----|------|---|---|--------|-----|-------|-------|-----|---|
| Register Name                       | Mnemonic | Dec | Hex  | 7 | 6 | 5      | 4   | 3     | 2     | 1   | 0 |
| Port 2 Pull-Up Resistor Enable      | P2PUR    | 232 | E8h  | 0 | 0 | 0      | 0   | 0     | 0     | 0   | 0 |
| Port 3 n-Channel Open-Drain Mode    | PNE3     | 233 | E9h  | 0 | 0 | 0      | 0   | 0     | 0     | 0   | 0 |
| Port 3 Control (High Byte)          | P3CONH   | 234 | EAh  | 0 | 0 | 0      | 0   | 0     | 0     | 0   | 0 |
| Port 3 Control (Mid Byte)           | P3CONM   | 235 | EBh  | 0 | 0 | 0      | 0   | 0     | 0     | 0   | 0 |
| Port 3 Control (Low Byte)           | P3CONL   | 236 | ECh  | 0 | 0 | 0      | 0   | 0     | 0     | 0   | 0 |
| Port 3 Pull-Up Resistor Enable      | P3PUR    | 237 | EDh  | - | - | 0      | 0   | 0     | 0     | 0   | 0 |
| Port 4 Control (High Byte)          | P4CONH   | 238 | EEh  | - | - | -      | 0   | 0     | 0     | 0   | 0 |
| Port 4 Control (Low Byte)           | P4CONL   | 239 | EFh  | 0 | 0 | 0      | 0   | 0     | 0     | 0   | 0 |
| Port 0 Data                         | P0       | 240 | F0h  | 0 | 0 | 0      | 0   | 0     | 0     | 0   | 0 |
| Port 1 Data                         | P1       | 241 | F1h  | 0 | 0 | 0      | 0   | 0     | 0     | 0   | 0 |
| Port 2 Data                         | P2       | 242 | F2h  | 0 | 0 | 0      | 0   | 0     | 0     | 0   | 0 |
| Port 3 Data                         | P3       | 243 | F3h  | 0 | 0 | 0      | 0   | 0     | 0     | 0   | 0 |
| Port 4 Data                         | P4       | 244 | F4h  | 0 | 0 | 0      | 0   | 0     | 0     | 0   | 0 |
| Port 4 Pull-up Resistor Enable      | P4PUR    | 245 | F5h  | _ | 0 | 0      | 0   | 0     | 0     | 0   | 0 |
| Port 4 n-Channel Open-Drain<br>Mode | PNE4     | 246 | F6h  | _ | 0 | 0      | 0   | 0     | 0     | 0   | 0 |
| Pattern Generation Control          | PGCON    | 247 | F7h  | - | - | -      | -   | 0     | 0     | 0   | 0 |
| Pattern Generation Data             | PGDATA   | 248 | F8h  | 0 | 0 | 0      | 0   | 0     | 0     | 0   | 0 |
| LCD Control                         | LCON     | 249 | F9h  | 0 | 0 | 0      | 0   | 0     | 0     | 0   | 0 |
| LCD Mode Control                    | LMOD     | 250 | FAh  | 0 | 0 | 0      | 0   | _     | _     | _   | 0 |
| Battery Level Detection Control     | BLDCON   | 251 | FBh  | _ | _ | _      | _   | 0     | 0     | 0   | 0 |
| Watch Timer Control                 | WTCON    | 252 | FCh  | 0 | 0 | 0      | 0   | 0     | 0     | 0   | 0 |
| Locations FDh-FFh are not mapped    | ed.      |     |      |   |   |        |     |       |       |     |   |
|                                     |          |     |      |   |   |        |     |       |       |     |   |

## Table 37. Set1, Bank1 Register and Values After RESET (Continued)

Notes:

An *x* means that the bit value is undefined following reset.
 A dash (-) means that the bit is neither used nor mapped, but the bit is read as 0.

Zilog Embackhard in Life An DXYS Company

199

|                              |                | Add | ress |    | Bit Values After Reset |        |      |      |     |   |   |  |
|------------------------------|----------------|-----|------|----|------------------------|--------|------|------|-----|---|---|--|
| Register Name                | Mnemonic       | Dec | Hex  | 7  | 6                      | 5      | 4    | 3    | 2   | 1 | 0 |  |
| Reset Source Indicating      | RESETID        | 0   |      | Se | e <u>Ta</u> l          | ole 40 | ) on | page | 200 |   |   |  |
| Timer D0 Control             | TD0CON         | 1   | 01h  | 0  | 0                      | 0      | 0    | 0    | 0   | 0 | 0 |  |
| Timer D0 Counter (High Byte) | TD0CNTH        | 2   | 02h  | 0  | 0                      | 0      | 0    | 0    | 0   | 0 | 0 |  |
| Timer D0 Counter (Low Byte)  | <b>TD0CNTL</b> | 3   | 03h  | 0  | 0                      | 0      | 0    | 0    | 0   | 0 | 0 |  |
| Timer D0 Data (High Byte)    | TD0DATAH       | 4   | 04h  | 1  | 1                      | 1      | 1    | 1    | 1   | 1 | 1 |  |
| Timer D0 Data (Low Byte)     | TD0DATAL       | 5   | 05h  | 1  | 1                      | 1      | 1    | 1    | 1   | 1 | 1 |  |
| Timer D1 Counter (High Byte) | TD1CNTH        | 6   | 06h  | 0  | 0                      | 0      | 0    | 0    | 0   | 0 | 0 |  |
| Timer D1 Counter (Low Byte)  | TD1CNTL        | 7   | 07h  | 0  | 0                      | 0      | 0    | 0    | 0   | 0 | 0 |  |
| Timer D1 Data (High Byte)    | TD1DATAH       | 8   | 08h  | 1  | 1                      | 1      | 1    | 1    | 1   | 1 | 1 |  |
| Timer D1 Data (Low Byte)     | TD1DATAL       | 9   | 09h  | 1  | 1                      | 1      | 1    | 1    | 1   | 1 | 1 |  |
| Timer D1 Control             | TD1CON         | 10  | 0Ah  | 0  | 0                      | 0      | 0    | 0    | 0   | 0 | 0 |  |



200

## **Reset Source Indicating Register**

The contents of the Reset Source Indicating (RESETID) Register are described in Table 39. The state of the RESETID depends on the source of the reset; see Table 40.

| Bit            | 7                                                            | 6                                                     | 5                                                      | 4                             | 3            | 2                          | 1   | 0   |
|----------------|--------------------------------------------------------------|-------------------------------------------------------|--------------------------------------------------------|-------------------------------|--------------|----------------------------|-----|-----|
| R/W            | —                                                            | _                                                     | _                                                      | R/W                           | _            | R/W                        | R/W |     |
| Address        |                                                              |                                                       |                                                        | 00                            | h            |                            |     |     |
| Mode           |                                                              |                                                       | Reę                                                    | gister Addres                 | sing Mode    | e only                     |     |     |
| Note: $R = re$ | ead only; R/W = r                                            | ead/write.                                            |                                                        |                               |              |                            |     |     |
| Bit            | Descriptio                                                   | on                                                    |                                                        |                               |              |                            |     |     |
| [7:5]          | Reserved                                                     |                                                       |                                                        |                               |              |                            |     |     |
| [4]            | 0: Reset is                                                  | •                                                     | ted by nR                                              | ESET pin wh<br>T pin when r   |              |                            | •   | e). |
| [3]            | Reserved                                                     |                                                       |                                                        |                               |              |                            |     |     |
|                |                                                              | t Indicatin                                           | a Bit                                                  |                               |              |                            |     |     |
| [2]            |                                                              | not genera                                            | ited by WD                                             | )T (when rea<br>when read); r |              |                            |     |     |
|                | 0: Reset is<br>1: Reset is<br><b>LVR Rese</b><br>0: Reset is | not genera<br>generated<br>t Indicating<br>not genera | ited by WE<br>by WDT (\<br><b>g Bit</b><br>ited by LVF |                               | no effect (v | when write).<br>to 0 (when | -   |     |

#### Table 40. State of RESETID

| Bit         | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------------|---|---|---|---|---|---|---|---|
| LVR         | - | _ | _ | 0 | _ | 0 | 1 | - |
| WDT, nReset | - | _ | _ | 3 | _ | 3 | 2 | - |

Notes:

1. To clear an indicating register, write a 0 to the indicating flag bit. Writing a 1 to a reset-indicating flag (RESETID.1–.2 and .4) has no effect.

2. Not affected by any other reset.

3. Bits corresponding to sources that are active at the time of reset will be set.





## **Power-Down Modes**

This section describes the following power-down modes:

- Stop Mode
- Idle Mode

## **Stop Mode**

Stop Mode is invoked by executing the STOP instruction after setting the Stop Control (STOPCON) Register. In Stop Mode, the operation of the CPU and all peripherals is halted. Essentially, the on-chip main oscillator stops and the current consumption can be reduced. All system functions stop when the clock freezes, but data stored in the internal register file is retained. However, the status of internal ring oscillator (ICLK, 15kHz) is configurable. Stop Mode can be released in one of two ways: by a system reset or by an external interrupt. After releasing from Stop Mode, the value of STOPCON is cleared automatically.

**Note:** Do not use Stop Mode if you are using an external clock source, because the  $X_{IN}$  or  $X_{TIN}$  inputs must be restricted internally to  $V_{SS}$  to reduce current leakage.

## Using nRESET to Release Stop Mode

Stop Mode is released when the nRESET signal is released and returns to a high level; all system and peripheral control registers are reset to their default hardware values and the contents of all data registers are retained. A reset operation automatically selects a slow clock (e.g.,  $f_{XX}/16$ ) because CLKCON.3 and CLKCON.4 are cleared to 00b. After the programmed oscillation stabilization interval has elapsed, the CPU starts the system initialization routine by fetching the program instruction stored in ROM location 0100h (and 0101h).

## Using an External Interrupt to Release Stop Mode

External interrupts with an RC-delay noise filter circuit can be used to release Stop Mode. Which interrupt you can use to release Stop Mode in a given situation depends on the microcontroller's current internal operating mode. The external interrupts in the S3F8S5A MCU's interrupt structure that can be used to release Stop Mode are P3.0–P3.6/P0.3 (INT0–VINT7).

Please note the following conditions for Stop Mode release:

• If you release Stop Mode using an external interrupt, the current values in system and peripheral control registers are unchanged except STPCON register.



- If you use an internal or external interrupt for Stop Mode release, you can also program the duration of the oscillation stabilization interval by making the appropriate control and clock settings before entering Stop Mode.
- When Stop Mode is released by external interrupt, the CLKCON.4 and CLKCON.3 bit-pair setting remains unchanged and the currently selected clock value is used.
- The external interrupt is serviced when the Stop Mode release occurs. Following the IRET from the service routine, the instruction immediately following the one that initiated Stop Mode is executed.

### Using an Internal Interrupt to Release Stop Mode

Activate any enabled interrupt to release Stop Mode; all other functions remain the same as if using an external interrupt.

### How to Enter Stop Mode

The following example shows how to handle the STPCON Register then writing a STOP instruction, in the sequential order shown.

```
LD STPCON,#10100101b
STOP
NOP
NOP
```

## Idle Mode

Idle Mode is invoked by the IDLE instruction (op code 6Fh). In Idle Mode, CPU operations are halted while some peripherals remain active. During Idle Mode, the internal clock signal is gated away from the CPU, but all peripheral timers remain active. Port pins retain the mode (input or output) they are operating in at the time Idle Mode is entered.

The following two methods can be used to release Idle Mode:

**Execute a reset.** All system and peripheral control registers are reset to their default values, and the contents of all data registers are retained. The reset automatically selects the slow clock ( $f_{XX}/16$ ) because CLKCON.4 and CLKCON.3 are cleared to 00b. If interrupts are masked, a reset is the only way to release Idle Mode.

Activate any enabled interrupt, causing idle mode to be released. When you use an interrupt to release Idle Mode, the CLKCON.4 and CLKCON.3 register values remain unchanged, and the currently selected clock value is used. The interrupt is then serviced. When the return-from-interrupt (IRET) occurs, the instruction immediately following the one that initiated Idle Mode is executed.



# I/O Ports

The S3F8S5A microcontroller features twelve bit-programmable I/O ports, P0–P4. Port 0 is a 4-bit port, and the others are 8-bit ports, for a total of 36 I/O pins. Each port can be flexibly configured to meet application design requirements.

The CPU accesses these ports by directly writing or reading the port registers; no special I/ O instructions are required. All ports of the S3F8S5A can be configured to input or output mode. All LCD signal pins are shared with normal I/O ports.

Table 41 provides a general overview of the S3F8S5A MCU's I/O port functions.

#### Table 41. S3F8S5A Port Configuration Overview

| Port | Configuration Options                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | 1-bit programmable I/O port: input or push-pull output mode selected by software; software assignable pull-ups. Alternatively, P0.0–P0.3 can be used as AD0–AD3 or LCD COM.                                                                                                                                                                                                                                                               |
| 1    | 1-bit programmable I/O port; Schmitt trigger input or push-pull, open drain output mode selected by software; software assignable pull-ups. P1.0–P3.3 can be used as inputs for external interrupts INT0–INT3 (with noise filter, interrupt enable and pending control). Alternatively, P1.0–P1.7 can be used as X <sub>TOUT</sub> , X <sub>TIN</sub> , TD1CLK, TD1OUT/TD1PWM/TD1CAP, AD5/AD6, TACLK, TAOUT/TAPWM/TACAP, BUZ, or LCD SEG. |
| 2    | 1-bit programmable I/O port; Schmitt trigger input or push-pull, open drain output mode selected by software; software assignable pull-ups. Alternatively, P2.0–P2.7 can be used as TXD0, RXD0, SCK, SO, SI, AD4/AD7, TD0CLK, TD0OUT/TD0PWM/TD0CAP, PWM, TBPWM, or LCD SEG.                                                                                                                                                               |
| 3    | 1-bit programmable I/O port; Schmitt trigger input or push-pull, open drain output mode selected by software; software assignable pull-ups. Alternatively, P3.0–P3.7 can be used as TXD1, RXD1, PG0-PG7, TCOUT/TCPWM, or LCD SEG.                                                                                                                                                                                                         |
| 4    | 1-bit programmable I/O port; Schmitt trigger input or push-pull, open-drain output mode selected by software; software assignable pull-ups. P4.0–P4.3 can be used as inputs for external interrupts INT4–INT7 (with noise filter, interrupt enable and pending control). Alternatively, P4.0–P4.7 can be used as LCD COM and SEG.                                                                                                         |

## **Port Data Registers**

Table 42 provides an overview of the register locations of all twelve S3F8S5A I/O port data registers. Data registers for ports 0, 1, 2, 3, and 4 feature the general format shown in Figure 65.





| Register Name        | Mnemonic | Decimal | Hex | Location    | Read/Write |
|----------------------|----------|---------|-----|-------------|------------|
| Port 0 Data Register | P0       | 240     | F0h | Set1, Bank0 | R/W        |
| Port 1 Data Register | P1       | 241     | F1h | Set1, Bank1 | R/W        |
| Port 2 Data Register | P2       | 242     | F2h | Set1, Bank1 | R/W        |
| Port 3 Data Register | P3       | 243     | F3h | Set1, Bank1 | R/W        |
| Port 4 Data Register | P4       | 244     | F4h | Set1, Bank1 | R/W        |

#### Table 42. Port Data Register Summary

S3F8S5A I/O Port Data Register Format (n = 0-4)



Figure 65. S3F8S5A I/O Port Data Register Format

## Port 0

Port 0 is a 4-bit I/O port with individually-configurable pins that are accessed directly by writing or reading the Port 0 Data Register, P0, at location F0h in Set1, Bank1. P0.0–P0.3 can serve as inputs (with or without pull-ups) and push-pull outputs, or you can configure the following alternative functions:

• Low-byte pins (P0.0–P0.3): COM0-COM3/AD0–AD3

#### **Port 0 Control Registers**

Port 0 provides one 8-bit control register, POCON, for P0.0–P0.3; see Table 43. A reset clears this register to 00h, configuring all pins to Input Mode. Use this control register's settings to select either Input Mode (with or without pull-ups), or to select Push-Pull Output Mode and enable the alternative functions.





#### Table 43. Port 0 Control High Byte Register (P0CON; Set1, Bank1)

| Bit            | 7                             | 6          | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------|-------------------------------|------------|---|---|---|---|---|---|
| Reset          | 0                             | 0          | 0 | 0 | 0 | 0 | 0 | 0 |
| R/W            | R/W                           |            |   |   |   |   |   |   |
| Address        | D0h                           |            |   |   |   |   |   |   |
| Mode           | Register Addressing Mode only |            |   |   |   |   |   |   |
| Note: R = read | d only; R/W = r               | ead/write. |   |   |   |   |   |   |

| Bit   | Description                                                                                                                                                                       |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:6] | <b>P0.7/COM4/AD4 Configuration Bits</b><br>00: Schmitt Trigger Input Mode.<br>01: Output Mode; push-pull.<br>10: Alternative function (AD4).<br>11: Alternative function (COM4).  |
| [5:4] | <b>P0.26/COM5/AD5 Configuration Bits</b><br>00: Schmitt Trigger Input Mode.<br>01: Output Mode; push-pull.<br>10: Alternative function (AD5).<br>11: Alternative function (COM5). |
| [3:2] | P0.5/COM6/AD6 Configuration Bits<br>00: Schmitt Trigger Input Mode.<br>01: Output Mode; push-pull.<br>10: Alternative function (AD6).<br>11: Alternative function (COM6).         |
| [1:0] | P0.4/COM7/AD7 Configuration Bits<br>00: Schmitt Trigger Input Mode.<br>01: Output Mode; push-pull.<br>10: Alternative function (AD7).<br>11: Alternative function (COM7).         |





## Port 0 Pull-Up Resistor Enable Register

When using the Port 0 Pull-Up Resistor Enable (P0PUR) Register (D1h, Set1, Bank1; see Table 44), the pull-up resistors can be configured to individual Port 0 pins.

| Table 44. Port 0 Pull-U | p Resistor Enable Register | (P0PUR; Set1, Bank1) |
|-------------------------|----------------------------|----------------------|
|-------------------------|----------------------------|----------------------|

| Bit           | 7                                                 | 6            | 5                | 4           | 3             | 2            | 1             | 0        |
|---------------|---------------------------------------------------|--------------|------------------|-------------|---------------|--------------|---------------|----------|
| Reset         | 0                                                 | 0            | 0                | 0           | 0             | 0            | 0             | 0        |
| R/W           |                                                   |              |                  | R/          | W             |              |               |          |
| Address       |                                                   |              |                  | D           | 2h            |              |               |          |
| Mode          |                                                   |              | Regis            | ter Addres  | ssing Mode    | only         |               |          |
| Note: R = rea | ad only; R/W = re                                 | ead/write.   |                  |             |               |              |               |          |
| Bit           | Descriptio                                        | n            |                  |             |               |              |               |          |
| [7]           | <b>P0.3 Pull-u</b><br>0: Disable  <br>1: Enable p | pull-up resi |                  |             |               |              |               |          |
| [6]           | <b>P0.2 Pull-U</b><br>0: Disable  <br>1: Enable p | pull-up resi |                  | :           |               |              |               |          |
| [5]           | <b>P0.1 Pull-U</b><br>0: Disable  <br>1: Enable p | pull-up resi |                  | :           |               |              |               |          |
| [4]           | <b>P0.0 Pull-U</b><br>0: Disable  <br>1: Enable p | pull-up resi |                  | :           |               |              |               |          |
| [3]           | <b>P0.3 Pull-l</b><br>0: Disable  <br>1: Enable p | pull-up resi |                  | :           |               |              |               |          |
| [2]           | <b>P0.2 Pull-l</b><br>0: Disable  <br>1: Enable p | pull-up resi |                  | :           |               |              |               |          |
| [1]           | <b>P0.1 Pull-l</b><br>0: Disable  <br>1: Enable p | pull-up resi |                  | :           |               |              |               |          |
| [0]           | <b>P0.0 Pull-l</b><br>0: Disable  <br>1: Enable p | pull-up resi |                  | :           |               |              |               |          |
|               | up resistor of por<br>or alternative fur          |              | atically disable | ed only whe | en the corres | sponding pin | is selected a | s push-p |



#### 207

## Port 1

Port 1 is an 8-bit I/O port with individually-configurable pins that are accessed directly by writing or reading the Port 1 Data (P1) Register at location F1h in Set1, Bank1. P1.0–P1.7 can serve as inputs (with or without pull-ups) and outputs (push-pull or open-drain), and can be configured to the following alternative functions:

- Low-byte pins (P1.0–P1.3): INT0/TAOUT/TAPWM/SEG20, INT1/TACLK/BUZ/ SEG21, INT2/TACAP, INT3/TD10UT/TD1PWM
- High-byte pins (P1.4–P1.7): XTOUT, XTIN, TD1CAP/AD6, TD1CLK/AD5

### **Port 1 Control Registers**

Port 1 has two 8-bit control registers: P1CONH for P1.4–P1.7 and P1CONL for P1.0–P1.3; see Tables 45 and 46. A reset clears the P1CONH and P1CONL registers to 00h, configuring all pins to Input Mode. When P1.0–P1.3 are in Input Mode, the following three selections are available:

- Schmitt trigger input with interrupt generation on falling signal edges
- Schmitt trigger input with interrupt generation on rising signal edges
- Schmitt trigger input with interrupt generation on falling/rising signal edges

Use this control register's settings to select either Input Mode (with or without pull-ups), or to select Push-Pull Output Mode and enable the alternative functions.

When programming the port, note that any alternative peripheral I/O function configured using the Port 1 Control registers must also be enabled in the associated peripheral module.





## Table 45. Port 1 Control Register High Byte Register (P1CONH; Set1,

Bank1)

| <b>6</b>                      | <b>) 4</b> | 3             | L                               |                                      | U                                    |  |
|-------------------------------|------------|---------------|---------------------------------|--------------------------------------|--------------------------------------|--|
| 0                             | n 0        | -             |                                 |                                      |                                      |  |
|                               | J 0        | 0             | 0                               | 0                                    | 0                                    |  |
| R/W                           |            |               |                                 |                                      |                                      |  |
| E0h                           |            |               |                                 |                                      |                                      |  |
| Register Addressing Mode only |            |               |                                 |                                      |                                      |  |
|                               | ead/write. | Register Addr | E0h<br>Register Addressing Mode | E0h<br>Register Addressing Mode only | E0h<br>Register Addressing Mode only |  |

| Bit   | Description                                                                                                                                                                    |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:6] | P1.7/COM0 Configuration Bits<br>00: Schmitt Trigger Input Mode.<br>01: Output Mode.<br>10: Not available.<br>11: Alternative function (COM0).                                  |
| [5:4] | P1.6/COM1 Configuration Bits<br>00: Schmitt Trigger Input Mode.<br>01: Output Mode.<br>10: Not available.<br>11: Alternative function (COM1).                                  |
| [3:2] | P1.5/COM2 Configuration Bits<br>00: Schmitt Trigger Input Mode.<br>01: Output Mode.<br>10: Not available.<br>11: Alternative function (COM2).                                  |
| [1:0] | P1.4/COM3/TCOUT/TCPWM Configuration Bits<br>00: Schmitt Trigger Input Mode.<br>01: Output Mode.<br>10: Alternative function (TCOUT/TCPWM).<br>11: Alternative function (COM3). |





#### Table 46. Port 1 Control Register Low Byte Register (P1CONL; Set1,

Bank1)

| Reset   | 0                             |   |   |   | 5 | 4 | 1 | U |
|---------|-------------------------------|---|---|---|---|---|---|---|
|         | 0                             | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| R/W     | R/W                           |   |   |   |   |   |   |   |
| Address | E1h                           |   |   |   |   |   |   |   |
| Mode    | Register Addressing Mode only |   |   |   |   |   |   |   |

| Bit   | Description                                                                                                                                                                  |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:6] | P1.3/AD0/TXD1 Configuration Bits<br>00: Schmitt Trigger Input Mode.<br>01: Output Mode.<br>10: Alternative function (AD0).<br>11: Alternative function (TXD1).               |
| [5:4] | P1.2/AD1/RXD1 Configuration Bits<br>00: Schmitt Trigger Input Mode (RXD1 In).<br>01: Output Mode.<br>10: Alternative function (AD1).<br>11: Alternative function (RXD1 Out). |
| [3:2] | P1.1/AD2/BUZ Configuration Bits<br>00: Schmitt Trigger Input Mode.<br>01: Output Mode.<br>10: Alternative function (AD2).<br>11: Alternative function (BUZ).                 |
| [1:0] | P1.0/AD3/TBPWM Configuration Bits<br>00: Schmitt Trigger Input Mode.<br>01: Output Mode.<br>10: Alternative function (AD3).<br>11: Alternative function (TBPWM).             |

#### Port 1 Interrupt Enable and Pending Registers

To process external interrupts at the Port 1 pins, two additional control registers are provided: the Port 1 Interrupt Enable (P1INT) Register (E3h, Set1, Bank1) and the Port 1 Interrupt Pending (P1PND) Register (E4h, Set1, Bank1); see Tables 47 and 48.

The Port 1 Interrupt Pending (P1PND) Register lets you check for interrupt pending conditions, and to clear a pending condition when an interrupt service routine has been initiated. The application software detects interrupt requests by polling the P1PND Register at regular intervals.

Zilog Embackhad In Life An DIXYS Company

210

When the interrupt enable bit of any Port 1 pin is 1, a rising or falling signal edge at that pin will generate an interrupt request. The corresponding P1PND bit is then automatically set to 1 and the IRQ level goes Low to signal the CPU that an interrupt request is waiting. When the CPU acknowledges the interrupt request, application software must the clear the pending condition by writing a 0 to the corresponding P1PND bit.

| Table 47. Port 1 | Interrupt Enable | <b>Register (P1II</b> | NT; Set1, Bank1) |
|------------------|------------------|-----------------------|------------------|
|                  |                  |                       | ,,               |

| 7                             | 6             | 5                                 | 4                     | 3 | 2   | 1   | 0   |
|-------------------------------|---------------|-----------------------------------|-----------------------|---|-----|-----|-----|
| 0                             | 0             | 0                                 | 0                     | 0 | 0   | 0   | 0   |
| R/W                           |               |                                   |                       |   |     |     |     |
| E3h                           |               |                                   |                       |   |     |     |     |
| Register Addressing Mode only |               |                                   |                       |   |     |     |     |
|                               | <b>7</b><br>0 | 7         6           0         0 | 7 6 5<br>0 0 0<br>Reg | E | E3h | E3h | E3h |

Note: R = read only; R/W = read/write.

| Bit           | Description                                                                                                                                                                                        |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:6]<br>INT3 | P1.7–P1.6 Interrupt Enable Bit<br>00: Disable interrupt.<br>01: Enable interrupt by falling edge.<br>10: Enable interrupt by rising edge.<br>11: Enable interrupt by both falling and rising edge. |
| [5:4]<br>INT2 | P1.5–P1.4 Interrupt Enable Bit<br>00: Disable interrupt.<br>01: Enable interrupt by falling edge.<br>10: Enable interrupt by rising edge.<br>11: Enable interrupt by both falling and rising edge. |
| [3:2]<br>INT1 | P1.3–P1.2 Interrupt Enable Bit<br>00: Disable interrupt.<br>01: Enable interrupt by falling edge.<br>10: Enable interrupt by rising edge.<br>11: Enable interrupt by both falling and rising edge. |
| [1:0]<br>INTO | P1.1–P1.0 Interrupt Enable Bit<br>00: Disable interrupt.<br>01: Enable interrupt by falling edge.<br>10: Enable interrupt by rising edge.<br>11: Enable interrupt by both falling and rising edge. |





#### Table 48. Port 1 Interrupt Pending Register (P1PND; Set1, Bank1)

| Bit     | 7 | 6   | 5   | 4           | 3          | 2    | 1 | 0 |  |  |  |
|---------|---|-----|-----|-------------|------------|------|---|---|--|--|--|
| Reset   | 0 | 0   | 0   | 0           | 0          | 0    | 0 | 0 |  |  |  |
| R/W     |   | R/W |     |             |            |      |   |   |  |  |  |
| Address |   |     |     | E           | 4h         |      |   |   |  |  |  |
| Mode    |   |     | Reg | ster Addres | ssing Mode | only |   |   |  |  |  |

Note: R = read only; R/W = read/write.

| Bit         | Description                                                                                                                                                                    |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:4]       | Reserved                                                                                                                                                                       |
| [3]<br>PND3 | <ul> <li>P1.3 Interrupt Pending Bit</li> <li>0: An interrupt request is not pending; clear pending bit when write = 0.</li> <li>1: An interrupt request is pending.</li> </ul> |
| [2]<br>PND2 | <ul> <li>P1.2 Interrupt Pending Bit</li> <li>0: An interrupt request is not pending; clear pending bit when write = 0.</li> <li>1: An interrupt request is pending.</li> </ul> |
| [1]<br>PND1 | <ul> <li>P1.1 Interrupt Pending Bit</li> <li>0: An interrupt request is not pending; clear pending bit when write = 0.</li> <li>1: An interrupt request is pending.</li> </ul> |
| [0]<br>PND0 | <ul> <li>P1.0 Interrupt Pending Bit</li> <li>0: An interrupt request is not pending; clear pending bit when write = 0.</li> <li>1: An interrupt request is pending.</li> </ul> |





## Port 1 Pull-Up Resistor Enable Register

When using the Port 1 Pull-Up Resistor Enable (P1PUR) Register (E2h, Set1, Bank1; see Table 49), the pull-up resistors can be configured to individual Port 1 pins.

#### Table 49. Port 1 Output Pull-Up Resistor Enable Register (P1PUR; Set1,

| Bit          | 7                | 6                                                                                                      | 5   | 4            | 3          | 2    | 1 | 0 |  |  |  |
|--------------|------------------|--------------------------------------------------------------------------------------------------------|-----|--------------|------------|------|---|---|--|--|--|
| Reset        | 0                | 0                                                                                                      | 0   | 0            | 0          | 0    | 0 | 0 |  |  |  |
| R/W          |                  |                                                                                                        |     | R/           | W          |      |   |   |  |  |  |
| Address      |                  |                                                                                                        |     | E            | 2h         |      |   |   |  |  |  |
| Mode         |                  |                                                                                                        | Reg | ister Addres | ssing Mode | only |   |   |  |  |  |
| Note: R = re | ad only; R/W = r | ead/write.                                                                                             |     |              |            |      |   |   |  |  |  |
| Bit          | Descriptio       | 'n                                                                                                     |     |              |            |      |   |   |  |  |  |
| [7]          | 0: Disable       | <b>Jp Resisto</b><br>pull-up resi<br>pull-up resis                                                     |     | it           |            |      |   |   |  |  |  |
| [6]          | 0: Disable       | <b>P1.6 Pull-Up Resistor Enable Bit</b><br>0: Disable pull-up resistor.<br>1: Enable pull-up resistor. |     |              |            |      |   |   |  |  |  |
| [5]          | 0: Disable       | <b>Jp Resisto</b><br>pull-up resi<br>pull-up resis                                                     |     | it           |            |      |   |   |  |  |  |
| [4]          | 0: Disable       | <b>Jp Resisto</b><br>pull-up resi<br>pull-up resis                                                     |     | it           |            |      |   |   |  |  |  |
| [3]          | 0: Disable       | <b>Jp Resisto</b><br>pull-up resi<br>pull-up resis                                                     |     | it           |            |      |   |   |  |  |  |
| [2]          | 0: Disable       | <b>Jp Resisto</b><br>pull-up resi<br>pull-up resis                                                     |     | it           |            |      |   |   |  |  |  |
| [1]          | 0: Disable       | <b>Jp Resisto</b><br>pull-up resi<br>pull-up resis                                                     |     | it           |            |      |   |   |  |  |  |
| [0]          | 0: Disable       | <b>Jp Resisto</b><br>pull-up resi<br>pull-up resis                                                     |     | it           |            |      |   |   |  |  |  |



## Port 1 n-Channel Open Drain Mode Register

When using the Port 1 n-Channel Open Drain Mode (PNE1) Register (E3h, Set1, Bank1; see Table 50), the Push-Pull or Open Drain Output Mode can be configured to individual Port 1 pins.

| Bit          | 7                                                                                                      | 6          | 5 | 4      | 3 | 2 | 1 | 0 |  |  |  |  |  |
|--------------|--------------------------------------------------------------------------------------------------------|------------|---|--------|---|---|---|---|--|--|--|--|--|
| Reset        | 0                                                                                                      | 0          | 0 | 0      | 0 | 0 | 0 | 0 |  |  |  |  |  |
| R/W          |                                                                                                        | R/W        |   |        |   |   |   |   |  |  |  |  |  |
| Address      | D2h                                                                                                    |            |   |        |   |   |   |   |  |  |  |  |  |
| Mode         | Register Addressing Mode only                                                                          |            |   |        |   |   |   |   |  |  |  |  |  |
| Note: R = re | ad only; R/W = r                                                                                       | ead/write. |   |        |   |   |   |   |  |  |  |  |  |
| Bit          | Description                                                                                            |            |   |        |   |   |   |   |  |  |  |  |  |
| [7:4]        | Reserved                                                                                               |            |   |        |   |   |   |   |  |  |  |  |  |
| [3]          | <b>P1.3 n-Channel Open Drain Mode Bit</b><br>0: Output Mode, push-pull.<br>1: Output Mode, open-drain. |            |   |        |   |   |   |   |  |  |  |  |  |
| [2]          | 0: Output N                                                                                            |            |   | de Bit |   |   |   |   |  |  |  |  |  |
| [1]          | P1.1 n-Channel Open Drain Mode Bit<br>0: Output Mode, push-pull.<br>1: Output Mode, open-drain.        |            |   |        |   |   |   |   |  |  |  |  |  |
| [0]          | 0: Output N                                                                                            |            | • | de Bit |   |   |   |   |  |  |  |  |  |

#### Table 50. Port 1 n-Channel Open Drain Mode Register (PNE1; Set1, Bank1)

## Port 2

Port 2 is an 8-bit I/O port with individually-configurable pins which are accessed directly by writing or reading the Port 2 Data (P2) Register at location F2h in Set1, Bank1. P2.0–P2.7 can serve as inputs (with or without pull-ups) and outputs (push pull or opendrain), or can be configured to the following alternative functions:

- Low-byte pins (P2.0–P2.3): TD0CLK/TBPWM, TD0CAP/PWM, AD4/TD0OUT/ TD0PWM, SI/AD7
- High-byte pins (P2.4–P2.7): SO/SEG0, SCK/SEG1, RXD0/SEG2, TXD0/SEG3



#### 214

## **Port 2 Control Registers**

Port 2 provides two 8-bit control registers, P2CONH for P2.4–P2.7 and P2CONL for P2.0–P2.3; see Tables 51 and 52. A reset clears these P2CONH and P2CONL registers to 00h, configuring all pins to Input Mode. Use control register settings to select Input Mode (with or without pull-ups) or to select Push-Pull Output Mode and enable the alternative functions.

#### Table 51. Port 2 Control Register High Byte Register (P2CONH; Set1,

| Bit           | 7                                                                                                                                                                                                                                                                                                       | 6 5                                   | 5                          | 4                        | 3  | 2   | 1 | 0 |  |  |  |  |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|----------------------------|--------------------------|----|-----|---|---|--|--|--|--|
| Reset         | 0                                                                                                                                                                                                                                                                                                       | 0                                     | 0                          | 0                        | 0  | 0   | 0 | 0 |  |  |  |  |
| R/W           |                                                                                                                                                                                                                                                                                                         |                                       |                            | R                        | W  |     |   |   |  |  |  |  |
| Address       |                                                                                                                                                                                                                                                                                                         |                                       |                            | E                        | ôh |     |   |   |  |  |  |  |
| Mode          |                                                                                                                                                                                                                                                                                                         | Register Addressing Mode only         |                            |                          |    |     |   |   |  |  |  |  |
| Note: R = rea | ad only; R/W = re                                                                                                                                                                                                                                                                                       | ead/write.                            |                            |                          |    |     |   |   |  |  |  |  |
| Bit           | Description                                                                                                                                                                                                                                                                                             |                                       |                            |                          |    |     |   |   |  |  |  |  |
| [7:6]         | <ul> <li>P2.7/TXD0/SEG3 Configuration Bits</li> <li>00: Schmitt Trigger Input Mode (RXD0 in, SCK in)</li> <li>01: Output Mode.</li> <li>10: Alternative function (TXD0, RXD0 out, SCK out, SO).</li> <li>11: Alternative function (SEG3–SEG0).</li> </ul>                                               |                                       |                            |                          |    |     |   |   |  |  |  |  |
| [5:4]         | 01: Output<br>10: Alterna                                                                                                                                                                                                                                                                               | t Trigger In<br>Mode.<br>tive functio | put Mode (I<br>on (TXD0, R | RXD0 in, S<br>XD0 out, S | ,  | )). |   |   |  |  |  |  |
| [3:2]         | <ul> <li>11: Alternative function (SEG3–SEG0).</li> <li>P2.5/SCK/SEG1 Configuration Bits</li> <li>00: Schmitt Trigger Input Mode (RXD0 in, SCK in)</li> <li>01: Output Mode.</li> <li>10: Alternative function (TXD0, RXD0 out, SCK out, SO).</li> <li>11: Alternative function (SEG3–SEG0).</li> </ul> |                                       |                            |                          |    |     |   |   |  |  |  |  |
| [1:0]         | 01: Output<br>10: Alterna                                                                                                                                                                                                                                                                               | t Trigger In<br>Mode.<br>tive functio | put Mode (                 | RXD0 in, S<br>XD0 out, S | ,  | )). |   |   |  |  |  |  |



An DXYS Company

215

### Table 52. Port 2 Control Register Low Byte Register (P2CONL; Set1,

| Bank1) |  |
|--------|--|
|        |  |

| Bit     | 7                             | 6 | 5 | 4 | 3  | 2 | 1 | 0 |  |  |
|---------|-------------------------------|---|---|---|----|---|---|---|--|--|
| Reset   | 0                             | 0 | 0 | 0 | 0  | 0 | 0 | 0 |  |  |
| R/W     | R/W                           |   |   |   |    |   |   |   |  |  |
| Address |                               |   |   | E | 7h |   |   |   |  |  |
| Mode    | Register Addressing Mode only |   |   |   |    |   |   |   |  |  |

| Bit   | Description                                                                                                                                                                                  |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:6] | <b>P2.3/SI/AD7 Configuration Bits</b><br>00: Schmitt Trigger Input Mode (SI, TD0CAP, TD0CLK).<br>01: Output Mode.<br>10: Alternative function (AD7, PWM, TBPWM).<br>11: Not available.       |
| [5:4] | <b>P2.2 Bit-Pair Configuration Bits</b><br>00: Schmitt Trigger Input Mode.<br>01: Output Mode.<br>10: Alternative function (AD4).<br>11: Alternative function (TD0OUT, TD0PWM).              |
| [3:2] | <b>P2.1/TD0CAP/PWM Configuration Bits</b><br>00: Schmitt Trigger Input Mode (SI, TD0CAP, TD0CLK).<br>01: Output Mode.<br>10: Alternative function (AD7, PWM, TBPWM).<br>11: Not available.   |
| [1:0] | <b>P2.0/TD0CLK/TBPWM Configuration Bits</b><br>00: Schmitt Trigger Input Mode (SI, TD0CAP, TD0CLK).<br>01: Output Mode.<br>10: Alternative function (AD7, PWM, TBPWM).<br>11: Not available. |





## Port 2 Pull-Up Resistor Enable Register

When using the Port 2 Pull-Up Resistor Enable (P2PUR) Register (E8h, Set1, Bank1; see Table 53), the pull-up resistors can be configured to individual Port 2 pins.

| Bit          | 7                                                 | 6            | 5      | 4         | 3           | 2             | 1           | 0        |
|--------------|---------------------------------------------------|--------------|--------|-----------|-------------|---------------|-------------|----------|
| Reset        | 0                                                 | 0            | 0      | 0         | 0           | 0             | 0           | 0        |
| R/W          |                                                   |              |        | R/        | W           |               |             |          |
| Address      |                                                   |              |        | E         | 3h          |               |             |          |
| Mode         |                                                   |              | Regist | er Addres | sing Mode   | only          |             |          |
| Note: R = re | ad only; R/W = re                                 | ead/write.   |        |           |             |               |             |          |
| Bit          | Descriptio                                        | n            |        |           |             |               |             |          |
| [7]          | <b>P2.7 Pull-U</b><br>0: Disable  <br>1: Enable p | pull-up resi |        |           |             |               |             |          |
| [6]          | <b>P2.6 Pull-l</b><br>0: Disable  <br>1: Enable p | pull-up resi |        |           |             |               |             |          |
| [5]          | <b>P2.5 Pull-U</b><br>0: Disable  <br>1: Enable p | pull-up resi |        |           |             |               |             |          |
| [4]          | <b>P2.4 Pull-U</b><br>0: Disable  <br>1: Enable p | pull-up resi |        |           |             |               |             |          |
| [3]          | <b>P2.3 Pull-U</b><br>0: Disable  <br>1: Enable p | pull-up resi |        |           |             |               |             |          |
| [2]          | <b>P2.2 Pull-U</b><br>0: Disable  <br>1: Enable p | pull-up resi |        |           |             |               |             |          |
| [1]          | <b>P2.1 Pull-l</b><br>0: Disable  <br>1: Enable p | pull-up resi |        |           |             |               |             |          |
| [0]          | <b>P2.0 Pull-l</b><br>0: Disable  <br>1: Enable p | pull-up resi |        |           |             |               |             |          |
|              | pull-up resistors<br>or as an alternat            |              |        | only when | the corresp | onding pin is | selected as | a push-p |



## Port 2 n-Channel Open Drain Mode Register

When using the Port 2 n-Channel Open Drain Mode (PNE2) Register (E5h, Set1, Bank1; see Table 54), the Push-Pull or Open Drain Output Mode can be configured to individual Port 2 pins.

|               |                                          |                                                                                                        |        | •            |             | - <b>3</b> (    | ,           | ,,        |  |  |  |  |
|---------------|------------------------------------------|--------------------------------------------------------------------------------------------------------|--------|--------------|-------------|-----------------|-------------|-----------|--|--|--|--|
| Bit           | 7                                        | 6                                                                                                      | 5      | 4            | 3           | 2               | 1           | 0         |  |  |  |  |
| Reset         | 0                                        | 0                                                                                                      | 0      | 0            | 0           | 0               | 0           | 0         |  |  |  |  |
| R/W           |                                          |                                                                                                        |        | R            | /W          |                 |             |           |  |  |  |  |
| Address       |                                          |                                                                                                        |        | E            | 5h          |                 |             |           |  |  |  |  |
| Mode          |                                          |                                                                                                        | Reg    | jister Addre | ssing Mode  | only            |             |           |  |  |  |  |
| Note: R = rea | ad only; R/W = re                        | ead/write.                                                                                             |        |              |             |                 |             |           |  |  |  |  |
| Bit           | Descriptio                               | n                                                                                                      |        |              |             |                 |             |           |  |  |  |  |
| [7]           | 0: Output N                              | <b>P2.7 n-Channel Open Drain Mode Bit</b><br>0: Output Mode, push-pull.<br>1: Output Mode, open-drain. |        |              |             |                 |             |           |  |  |  |  |
| [6]           | P2.6 n-Cha<br>0: Output N<br>1: Output N | Iode, push                                                                                             | -pull. | ode Bit      |             |                 |             |           |  |  |  |  |
| [5]           | P2.5 n-Cha<br>0: Output N<br>1: Output N | Iode, push                                                                                             | -pull. | ode Bit      |             |                 |             |           |  |  |  |  |
| [4]           | P2.4 n-Cha<br>0: Output N<br>1: Output N | Iode, push                                                                                             | -pull. | ode Bit      |             |                 |             |           |  |  |  |  |
| [3]           | P2.3 n-Cha<br>0: Output M<br>1: Output M | Iode, push                                                                                             | -pull. | ode Bit      |             |                 |             |           |  |  |  |  |
| [2]           | P2.2 n-Cha<br>0: Output M<br>1: Output M | /lode, push                                                                                            | -pull. | ode Bit      |             |                 |             |           |  |  |  |  |
| [1]           | P2.1 n-Cha<br>0: Output M<br>1: Output M | Iode, push                                                                                             | -pull. | ode Bit      |             |                 |             |           |  |  |  |  |
| [0]           | P2.0 n-Cha<br>0: Output M<br>1: Output M | Iode, push                                                                                             | -pull. | ode Bit      |             |                 |             |           |  |  |  |  |
|               | pull-up resistors<br>or as an alternat   |                                                                                                        |        | ed only wher | the corresp | onding pin is : | selected as | a push-pu |  |  |  |  |

#### Table 54. Port 2 n-Channel Open Drain Mode Register (PNE2; Set1, Bank1)



## Port 3

Port 3 is an 8-bit I/O port with individually-configurable pins which are accessed directly by writing or reading the Port 3 Data (P3) Register at location F3h in Set1, Bank1. P3.0–P3.7 can serve as inputs (with or without pull-ups) and outputs (push pull or opendrain), or can be configured for the following alternative functions:

- Low-byte pins (P3.0–P3.3): PG0/SEG4, PG1/SEG5, PG2/SEG6, PG3/SEG7
- High-byte pins (P3.4–P3.7): PG4/SEG8, TCOUT/TCPWM/PG5/SEG9, RXD1/PG6/ SEG10, TXD1/PG7/SEG11

### **Port 3 Control Registers**

Port 3 provides two 8-bit control registers, P3CONH for P3.6–P3.7, P3CONM for P3.4–P3.5, and P3CONL for P3.0–P3.3; see Tables 55 through 57. A reset clears these three registers to 00h, configuring all pins to Input Mode. Use these control register's settings to select Input Mode (with or without pull-ups), or to select Output Mode and enable the alternative functions.

When programming Port 3, any alternative peripheral I/O function you configure using the Port 3 Control registers must also be enabled in the associated peripheral module.





## Table 55. Port 3 Control High-Byte Register (P3CONH; Set1, Bank1)

| Bit          | 7                                                     | 6                                                                    | 5                                                                                   | 4                                | 3   | 2   | 1   | 0   |  |  |  |  |  |
|--------------|-------------------------------------------------------|----------------------------------------------------------------------|-------------------------------------------------------------------------------------|----------------------------------|-----|-----|-----|-----|--|--|--|--|--|
| Reset        | _                                                     | _                                                                    | 0                                                                                   | 0                                | 0   | 0   | 0   | 0   |  |  |  |  |  |
| R/W          | _                                                     | _                                                                    | R/W                                                                                 | R/W                              | R/W | R/W | R/W | R/W |  |  |  |  |  |
| Address      |                                                       | EAh                                                                  |                                                                                     |                                  |     |     |     |     |  |  |  |  |  |
| Mode         | Register Addressing Mode only                         |                                                                      |                                                                                     |                                  |     |     |     |     |  |  |  |  |  |
| Note: R = re | ad only; R/W = r                                      | ead/write.                                                           |                                                                                     |                                  |     |     |     |     |  |  |  |  |  |
| Bit          | Descriptio                                            | Description                                                          |                                                                                     |                                  |     |     |     |     |  |  |  |  |  |
| [7:6]        | Reserved                                              |                                                                      |                                                                                     |                                  |     |     |     |     |  |  |  |  |  |
| [5:3]        | 000: Schm<br>001: Outpu<br>010: Altern<br>011: Altern | itt Trigger<br>ut Mode.<br>ative funct<br>ative funct<br>ative funct | i <b>11 Configu</b><br>Input Mode<br>ion (TXD1,<br>ion (PG7, P<br>ion (SEG11<br>le. | (RXD1 in).<br>RXD1 out).<br>G6). |     |     |     |     |  |  |  |  |  |
| [2:0]        | 000: Schm<br>001: Outpu<br>010: Altern<br>011: Altern | itt Trigger<br>ut Mode.<br>ative funct<br>ative funct<br>ative funct | ion (TXD1,<br>ion (TXD1,<br>ion (PG7, P<br>ion (SEG11<br>le.                        | (RXD1 in).<br>RXD1 out).<br>G6). |     |     |     |     |  |  |  |  |  |





## Table 56. Port 3 Control Mid Byte Register (P3CONM; Set1, Bank1)

| Bit          | 7                                                     | 6                                                                    | 5           | 4         | 3   | 2 | 1   | 0   |  |  |
|--------------|-------------------------------------------------------|----------------------------------------------------------------------|-------------|-----------|-----|---|-----|-----|--|--|
| Reset        | _                                                     | _                                                                    | 0           | 0         | 0   | _ | 0   | 0   |  |  |
| R/W          | _                                                     | _                                                                    | R/W         | R/W       | R/W | _ | R/W | R/W |  |  |
| Address      | EBh                                                   |                                                                      |             |           |     |   |     |     |  |  |
| Mode         | Register Addressing Mode only                         |                                                                      |             |           |     |   |     |     |  |  |
| Note: R = re | ad only; R/W = r                                      | ead/write.                                                           |             |           |     |   |     |     |  |  |
| Bit          | Description                                           |                                                                      |             |           |     |   |     |     |  |  |
| [7:6]        | Reserved                                              |                                                                      |             |           |     |   |     |     |  |  |
| [5:3]        | 000: Schm<br>001: Outpu<br>010: Altern<br>011: Altern | itt Trigger<br>ut Mode.<br>ative funct<br>ative funct<br>ative funct | ion (SEG9). | ſ/TCPWM). |     |   |     |     |  |  |
| [2]          | Reserved                                              |                                                                      |             |           |     |   |     |     |  |  |
| [1:0]        | 00: Schmit<br>01: Output<br>10: Alterna               | t Trigger Ir<br>Mode.<br>tive functio                                |             |           |     |   |     |     |  |  |





## Table 57. Port 3 Control Low Byte Register (P3CONL; Set1, Bank1)

| Bit           | 7                                       | 6                                                                   | 5                      | 4            | 3          | 2    | 1   | 0   |
|---------------|-----------------------------------------|---------------------------------------------------------------------|------------------------|--------------|------------|------|-----|-----|
| Reset         | 0                                       | 0                                                                   | 0                      | 0            | 0          | 0    | 0   | 0   |
| R/W           | R/W                                     | R/W                                                                 | R/W                    | R/W          | R/W        | R/W  | R/W | R/W |
| Address       |                                         |                                                                     |                        | E            | Ch         |      |     |     |
| Mode          |                                         |                                                                     | Reg                    | jister Addre | ssing Mode | only |     |     |
| Note: R = rea | ad only; R/W = r                        | ead/write.                                                          |                        |              |            |      |     |     |
| Bit           | Descriptio                              | on                                                                  |                        |              |            |      |     |     |
| [7:6]         | 00: Schmit<br>01: Output<br>10: Alterna | SEG7 Cont<br>t Trigger In<br>Mode.<br>ative functio<br>tive functio | put Mode.<br>n (PG3–PC | G0).         |            |      |     |     |
| [5:4]         | 00: Schmit<br>01: Output<br>10: Alterna | SEG6 Cont<br>t Trigger In<br>Mode.<br>ative functio<br>tive functio | put Mode.<br>n (PG3–PC | GO).         |            |      |     |     |
| [3:2]         | 00: Schmit<br>01: Output<br>10: Alterna | SEG5 Cont<br>t Trigger In<br>Mode.<br>ative functio<br>tive functio | put Mode.<br>n (PG3–PC | G0).         |            |      |     |     |
| [1:0]         | 00: Schmit<br>01: Output<br>10: Alterna | SEG4 Cont<br>t Trigger In<br>Mode.<br>ative functio<br>tive functio | put Mode.<br>n (PG3–PC | GO).         |            |      |     |     |





### Port 3 Pull-Up Resistor Enable Register

When using the Port 3 Pull-Up Resistor Enable (P3PUR) Register (EDh, Set1, Bank1; see Table 58), pull-up resistors can be configured to individual Port 3 pins.

#### Table 58. Port3[4:5] Control Register (P3PUR; Set1, Bank1)

| Bit     | 7   | 6   | 5   | 4            | 3          | 2    | 1   | 0   |
|---------|-----|-----|-----|--------------|------------|------|-----|-----|
| Reset   | 0   | 0   | 0   | 0            | 0          | 0    | 0   | 0   |
| R/W     | R/W | R/W | R/W | R/W          | R/W        | R/W  | R/W | R/W |
| Address |     |     |     | El           | Dh         |      |     |     |
| Mode    |     |     | Reg | ister Addres | ssing Mode | only |     |     |

Note: R = read only; R/W = read/write.

| Bit | Description                                                                                                                                             |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7] | <b>P3.7 Pull-Up Resistor Enable Bit</b><br>0: Pull-up disable.<br>1: Pull-up enable.                                                                    |
| [6] | <b>P3.6 Pull-Up Resistor Enable Bit</b><br>0: Pull-up disable.<br>1: Pull-up enable.                                                                    |
| [5] | <b>P3.5 Pull-Up Resistor Enable Bit</b><br>0: Pull-up disable.<br>1: Pull-up enable.                                                                    |
| [4] | <b>P3.4 Pull-Up Resistor Enable Bit</b><br>0: Pull-up disable.<br>1: Pull-up enable.                                                                    |
| [3] | <b>P3.3 Pull-Up Resistor Enable Bit</b><br>0: Pull-up disable.<br>1: Pull-up enable.                                                                    |
| [2] | <b>P3.2 Pull-Up Resistor Enable Bit</b><br>0: Pull-up disable.<br>1: Pull-up enable.                                                                    |
| [1] | <b>P3.1 Pull-Up Resistor Enable Bit</b><br>0: Pull-up disable.<br>1: Pull-up enable.                                                                    |
| [0] | <b>P3.0 Pull-Up Resistor Enable Bit</b><br>0: Pull-up disable.<br>1: Pull-up enable.                                                                    |
|     | Port 3 pull-up resistors are automatically disabled only when the corresponding pin is selected as a push-pull<br>output or as an alternative function. |



An DXYS Company

### 223

## Port 3 n-Channel Open Drain Mode Register

When using the Port 3 n-Channel Open Drain Mode (PNE3) Register (E9h, Set1, Bank1; see Table 59), the Push-Pull or Open Drain Output Mode can be configured to individual Port 3 pins.

|               |                               |                                                | -      | •   |     |     | •   |     |  |  |
|---------------|-------------------------------|------------------------------------------------|--------|-----|-----|-----|-----|-----|--|--|
| Bit           | 7                             | 6                                              | 5      | 4   | 3   | 2   | 1   | 0   |  |  |
| Reset         | 0                             | 0                                              | 0      | 0   | 0   | 0   | 0   | 0   |  |  |
| R/W           | R/W                           | R/W                                            | R/W    | R/W | R/W | R/W | R/W | R/W |  |  |
| Address       |                               |                                                |        | E   | 9h  |     |     |     |  |  |
| Mode          | Register Addressing Mode only |                                                |        |     |     |     |     |     |  |  |
| Note: R = rea | ad only; R/W = r              | ead/write.                                     |        |     |     |     |     |     |  |  |
| Bit           | Descriptio                    | on                                             |        |     |     |     |     |     |  |  |
| [7]           | 0: Output N                   | <b>ut Mode E</b> i<br>Mode, push<br>Mode, open | -pull. |     |     |     |     |     |  |  |
| [6]           | 0: Output N                   | <b>ut Mode E</b> i<br>Mode, push<br>Mode, open | -pull. |     |     |     |     |     |  |  |
| [5]           | 0: Output                     | <b>ut Mode E</b> i<br>Mode, push<br>Mode, open | -pull. |     |     |     |     |     |  |  |
| [4]           | 0: Output M                   | <b>ut Mode E</b> i<br>Mode, push<br>Mode, open | -pull. |     |     |     |     |     |  |  |
| [3]           | 0: Output M                   | <b>ut Mode E</b><br>Mode, push<br>Mode, open   | -pull. |     |     |     |     |     |  |  |
| [2]           | 0: Output M                   | <b>ut Mode E</b> i<br>Mode, push<br>Mode, open | -pull. |     |     |     |     |     |  |  |
| [1]           | 0: Output N                   | <b>ut Mode E</b> i<br>Mode, push<br>Mode, open | -pull. |     |     |     |     |     |  |  |
| [0]           | 0: Output N                   | <b>ut Mode E</b> i<br>Mode, push<br>Mode, open | -pull. |     |     |     |     |     |  |  |

#### Table 59. Port 3 Output Pull-Up Resistor Enable Register (PNE3; Set1, Bank1)



#### 224

## Port 4

Port 4 is an 7-bit I/O port with individually-configurable pins which are accessed directly by writing or reading the Port 4 Data (P4) Register at location F4h in Set1, Bank1. P4.0–P4.6 can serve as inputs (with or without pull-ups), and outputs (push pull or opendrain), or can be configured to the following alternative functions:

- Low-byte pins (P4.0-P4.3): INT4/SEG12, INT5/SEG13, INT6/SEG14, INT7/SEG15
- High-byte pins (P4.4-P4.7): COM4/SEG16, COM5/SEG17, COM6/SEG18, COM7/ SEG19

### **Port 4 Control Registers**

Port 4 provides two 7-bit control registers, P4CONH for P4.4–P4.7 and P4CONL for P4.0–P4.3; see Tables 60 and 61. A reset clears each of these registers to 00h, configuring all pins to Input Mode. When P4.0–P4.3 are in Input Mode, the following three selections are available:

- Schmitt trigger input with interrupt generation on falling signal edges
- Schmitt trigger input with interrupt generation on rising signal edges
- Schmitt trigger input with interrupt generation on falling/rising signal edges

| Bit     | 7                             | 6 | 5   | 4   | 3   | 2   | 1   | 0   |
|---------|-------------------------------|---|-----|-----|-----|-----|-----|-----|
| Reset   | _                             | _ | 0   | 0   | 0   | 0   | 0   | 0   |
| R/W     | -                             | _ | R/W | R/W | R/W | R/W | R/W | R/W |
| Address |                               |   |     | El  | Ξh  |     |     |     |
| Mode    | Register Addressing Mode only |   |     |     |     |     |     |     |

#### Table 60. Port 4 Control High Byte Register (P4CONH; Set1, Bank1)

| Bit   | Description                              |
|-------|------------------------------------------|
| [7:6] | Reserved                                 |
| [5:4] | P4.6/TD1CLK/SEG14Configuration Bits      |
|       | 00: Schmitt Trigger Input Mode (TD1CLK). |
|       | 01: Output Mode.                         |
|       | 10: Not available.                       |
|       | 11: Alternative function (SEG14).        |



225

| Bit   | Description (Continued)                                                                                                                                                                              |  |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| [3:2] | P4.5/TD1OUT/TD1PWM/TD1CAP/SEG13 Configuration Bits<br>00: Schmitt Trigger Input Mode (TD1CAP).<br>01: Output Mode.<br>10: Alternative function (TD1OUT/TD1PWM).<br>11: Alternative function (SEG13). |  |
| [1:0] | P4.4/TD0CLK/SEG12 Configuration Bits<br>00: Schmitt Trigger Input Mode (TD0CLK).<br>01: Output Mode.<br>10: Not available.<br>11: Alternative function (SEG12).                                      |  |

### Table 61. Port 4 Control Low Byte Register (P4CONL; Set1, Bank1)

| Bit            | 7                             | 6          | 5 | 4 | 3  | 2 | 1 | 0 |
|----------------|-------------------------------|------------|---|---|----|---|---|---|
| Reset          | 1                             | 1          | 1 | 1 | 1  | 1 | 1 | 1 |
| R/W            | R/W                           |            |   |   |    |   |   |   |
| Address        |                               |            |   | E | Fh |   |   |   |
| Mode           | Register Addressing Mode only |            |   |   |    |   |   |   |
| Note: R = read | only; R/W = r                 | ead/write. |   |   |    |   |   |   |

| Bit   | Description                                                                                                                                                                                          |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:6] | P4.3/TD0OUT/TD0PWM/TD0CAP/SEG11 Configuration Bits<br>00: Schmitt Trigger Input Mode (TD0CAP).<br>01: Output Mode.<br>10: Alternative function (TD0OUT/TD0PWM).<br>11: Alternative function (SEG11). |
| [5:4] | P4.2/SCK/SEG2 Configuration Bits<br>00: Schmitt Trigger Input Mode (SCK In).<br>01: Output Mode.<br>10: Alternative function (SCK Out).<br>11: Alternative function (SEG2).                          |
| [3:2] | P4.1/SI/SEG1 Configuration Bits<br>00: Schmitt Trigger Input Mode (SI).<br>01: Output Mode.<br>10: Not available.<br>11: Alternative function (SEG1).                                                |
| [1:0] | P4.0/SO/SEG0 Configuration Bits<br>00: Schmitt Trigger Input Mode.<br>01: Output Mode.<br>10: Alternative function (SO).<br>11: Alternative function (SEG0).                                         |



Use these control register settings to select Input Mode (with or without pull-ups) or to select Push-Pull Output Open-Drain Mode and enable the alternative functions.

When programming the port, note that any alternative peripheral I/O function you configure using the Port 4 Control registers must also be enabled in the associated peripheral module.

#### Port 4 Interrupt Enable and Pending Registers

To process external interrupts at the Port 4 pins, two additional control registers are provided: the Port 4 Interrupt Enable (P4INT) Register (F6h, Set1, Bank1) and the Port 4 Interrupt Pending (P4PND) Register (F7h, Set1, Bank1); see Tables 62 and 63.

The Port 4 Interrupt Pending (P4PND) Register lets you check for interrupt pending conditions, and to clear a pending condition when an interrupt service routine has been initiated. The application software detects interrupt requests by polling the P4PND Register at regular intervals.

When the interrupt enable bit of any Port 4 pin is 1, a rising or falling signal edge at that pin will generate an interrupt request. The corresponding P4PND bit is then automatically set to 1 and the IRQ level goes Low to signal the CPU that an interrupt request is waiting. When the CPU acknowledges the interrupt request, application software must the clear the pending condition by writing a 0 to the corresponding P4PND bit.

| Bit     | 7                             | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |
|---------|-------------------------------|-----|-----|-----|-----|-----|-----|-----|--|
| Reset   | 0                             | 0   | 0   | 0   | 0   | 0   | 0   | 0   |  |
| R/W     | R/W                           | R/W | R/W | R/W | R/W | R/W | R/W | R/W |  |
| Address |                               |     |     | F   | 6h  |     |     |     |  |
| Mode    | Register Addressing Mode only |     |     |     |     |     |     |     |  |

| Table 62. Port 4 Pull-Up Interrupt Enable Register (P4INT; | Set1, Bank1) |
|------------------------------------------------------------|--------------|
|                                                            |              |

| Bit   | Description                                           |
|-------|-------------------------------------------------------|
| [7:6] | P4.7–P4.6 Pull-Up Interrupt Enable Bit                |
| INT7  | 00: Disable interrupt.                                |
|       | 01: Enable interrupt by falling edge.                 |
|       | 10: Enable interrupt by rising edge.                  |
|       | 11: Enable interrupt by both falling and rising edge. |
| [5:4] | P4.5–P4.4 Pull-Up Interrupt Enable Bit                |
| INT6  | 00: Disable interrupt.                                |
|       | 01: Enable interrupt by falling edge.                 |
|       | 10: Enable interrupt by rising edge.                  |
|       | 11: Enable interrupt by both falling and rising edge. |



227

 Bit
 Description (Continued)

 [3:2]
 P4.3–P4.2 Pull-Up Resistor Enable Bit

 INT5
 00: Disable interrupt.

 01: Enable interrupt by falling edge.

 10: Enable interrupt by rising edge.

 11: Enable interrupt by both falling and rising edge.

 [1:0]
 P4.1–P4.0 Pull-Up Resistor Enable Bit

 INT4
 00: Disable interrupt.

 01: Enable interrupt by falling edge.

 (1: Enable interrupt.

 (1: Enable interrupt by falling edge.

- 10: Enable interrupt by rising edge.
  - 11: Enable interrupt by both falling and rising edge.

#### Table 63. Port 4 Interrupt Pending Register (P4PND; Set1, Bank1)

| Bit            | 7                             | 6          | 5 | 4 | 3 | 2 | 1 | 0 |  |
|----------------|-------------------------------|------------|---|---|---|---|---|---|--|
| Reset          | 0                             | 0          | 0 | 0 | 0 | 0 | 0 | 0 |  |
| R/W            | R/W                           |            |   |   |   |   |   |   |  |
| Address        | F7h                           |            |   |   |   |   |   |   |  |
| Mode           | Register Addressing Mode only |            |   |   |   |   |   |   |  |
| Note: R = read | l only; R/W = r               | ead/write. |   |   |   |   |   |   |  |
|                |                               |            |   |   |   |   |   |   |  |

| Bit         | Description                                                                                                                                                                    |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:4]       | Reserved                                                                                                                                                                       |
| [3]<br>PND7 | <ul> <li>P4.3 Interrupt Pending Bit</li> <li>0: An interrupt request is not pending; clear pending bit when write = 0.</li> <li>1: An interrupt request is pending.</li> </ul> |
| [2]<br>PND6 | <ul> <li>P4.2 Interrupt Pending Bit</li> <li>0: An interrupt request is not pending; clear pending bit when write = 0.</li> <li>1: An interrupt request is pending.</li> </ul> |
| [1]<br>PND5 | <ul> <li>P4.1 Interrupt Pending Bit</li> <li>0: An interrupt request is not pending; clear pending bit when write = 0.</li> <li>1: An interrupt request is pending.</li> </ul> |
| [0]<br>PND4 | <ul> <li>P4.0 Interrupt Pending Bit</li> <li>0: An interrupt request is not pending; clear pending bit when write = 0.</li> <li>1: An interrupt request is pending.</li> </ul> |





## Port 4 Pull-Up Resistor Enable Register

When using the Port 4 Pull-Up Resistor Enable (P4PUR) Register (E2h, Set1, Bank1; see Table 49), the pull-up resistors can be configured to individual Port 4 pins.

#### Table 64. Port 4 Output Pull-Up Resistor Enable Register (P4PUR; Set1,

| Bit            | 7                                                            | 6                                            | 5                                | 4            | 3           | 2             | 1           | 0 |
|----------------|--------------------------------------------------------------|----------------------------------------------|----------------------------------|--------------|-------------|---------------|-------------|---|
| Reset          | 0                                                            | 0                                            | 0                                | 0            | 0           | 0             | 0           | 0 |
| R/W            |                                                              |                                              |                                  | R/           | W           |               |             |   |
| Address        |                                                              |                                              |                                  | F:           | 5h          |               |             |   |
| Mode           |                                                              |                                              | Reg                              | ister Addres | ssing Mode  | only          |             |   |
| Note: $R = re$ | ead only; R/W = re                                           | ead/write.                                   |                                  |              |             |               |             |   |
| Bit            | Descriptio                                                   | n                                            |                                  |              |             |               |             |   |
| [7]            | <b>P4.7 Pull-U</b><br>0: Disable <sub>I</sub><br>1: Enable p | pull-up resi                                 | stor.                            | it           |             |               |             |   |
| [6]            | <b>P4.6 Pull-U</b><br>0: Disable  <br>1: Enable p            | pull-up resi                                 | stor.                            | it           |             |               |             |   |
| [5]            | <b>P4.5 Pull-U</b><br>0: Disable p<br>1: Enable p            | pull-up resi                                 | stor.                            | it           |             |               |             |   |
| [4]            | <b>P4.4 Pull-U</b><br>0: Disable  <br>1: Enable p            | pull-up resi                                 | stor.                            | it           |             |               |             |   |
| [3]            | <b>P4.3 Pull-l</b><br>0: Disable  <br>1: Enable p            | pull-up resi                                 | stor.                            | it           |             |               |             |   |
| [2]            | <b>P4.2 Pull-L</b><br>0: Disable  <br>1: Enable p            | pull-up resi                                 | stor.                            | it           |             |               |             |   |
| [1]            | <b>P4.1 Pull-l</b><br>0: Disable <sub>l</sub><br>1: Enable p | pull-up resi                                 | stor.                            | it           |             |               |             |   |
| [0]            | <b>P4.0 Pull-l</b><br>0: Disable  <br>1: Enable p            | pull-up resi                                 | stor.                            | it           |             |               |             |   |
| Note: Port     | 0: Disable                                                   | pull-up resi<br>pull-up resis<br>are automat | stor.<br>stor.<br>ically disable |              | the corresp | onding pin is | selected as | а |

Bank1)



# **Basic Timer**

The S3F8S5A MCU features an 8-bit basic timer (BT) that can be used in the following two ways:

- As a watchdog timer to provide an automatic reset mechanism in the event of a system malfunction
- To signal the end of the required oscillation stabilization interval after a reset or a Stop Mode release

The functional components of the basic timer block are:

- Clock frequency divider ( $f_{XX}$  divided by 4096, 1024, 128, or 16) with multiplexer
- 8-bit Basic Timer Counter (BTCNT) Register (FDh, Set1, Bank0; read-only)
- Basic Timer Control (BTCON) Register (D3h, Set1; read/write)

Figure 66 diagrams the Basic Timer.





## **Basic Timer Control Register**

The Basic Timer Control (BTCON) Register, shown in Table 65, is used to select the input clock frequency, to clear the basic timer counter and frequency dividers, and to enable or



disable the watchdog timer function. It is located in Set1, address D3h, and is read/write addressable using Register Addressing Mode.

#### Table 65. Basic Timer Control Register (BTCON; Set1)

| Bit            | 7                                                                                                                                                                               | 6                                                                                         | 5           | 4 | 3           | 2          | 1        | 0 |  |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|-------------|---|-------------|------------|----------|---|--|
| Reset          | 0                                                                                                                                                                               | 0                                                                                         | 0           | 0 | 0           | 0          | 0        | 0 |  |
| R/W            |                                                                                                                                                                                 |                                                                                           |             | R | /W          |            |          |   |  |
| Address        |                                                                                                                                                                                 |                                                                                           |             | D | 3h          |            |          |   |  |
| Mode           | Register Addressing Mode only                                                                                                                                                   |                                                                                           |             |   |             |            |          |   |  |
| Note: $R = re$ | ead only; R/W = re                                                                                                                                                              | ead/write.                                                                                |             |   |             |            |          |   |  |
| Bit            | Description                                                                                                                                                                     |                                                                                           |             |   |             |            |          |   |  |
| [7:4]          | Watchdog Timer Enable Bits<br>0000–1001b: Enable the watchdog timer function.<br>1010b: Disable the watchdog timer function.<br>1011–1111b: Enable the watchdog timer function. |                                                                                           |             |   |             |            |          |   |  |
| [3:2]          | Basic Timer Input Clock Selection Bits $00: f_{XX}/4096.$ $01: f_{XX}/1024.$ $10: f_{XX}/128.$ $11: f_{XX}/16.$                                                                 |                                                                                           |             |   |             |            |          |   |  |
| [1]            | 0: No effec                                                                                                                                                                     | Basic Timer Counter Clear Bit<br>0: No effect.<br>1: Clear the basic timer counter value. |             |   |             |            |          |   |  |
| [0]            | Clock Free<br>0: No effec<br>1: Clear bo                                                                                                                                        | t.                                                                                        | vider Clear |   | sic Timer a | nd Timer/( | Counters |   |  |

A reset clears BTCON to 00h, enabling the watchdog function and selecting a basic timer clock frequency of  $f_{XX}/4096$ . To disable the watchdog function, write the signature code 1010b to the basic timer register control bits BTCON.7–BTCON.4.

The 8-bit Basic Timer Counter (BTCNT) Register (FDh, Set1, Bank0), can be cleared at any time during normal operation by writing a 1 to BTCON.1. To clear the frequency dividers, write a 1 to BTCON.0.

#### Watchdog Timer Function

The basic timer overflow signal (BTOVF) can be programmed to generate a reset by setting BTCON.7–BTCON.4 to any value other than 1010b. (The 1010b value disables the watchdog function.) A reset clears BTCON to 00h, automatically enabling the watchdog timer function. A reset also selects the CPU clock (as determined by the current CLKCON Register setting) divided by 4096 as the BT clock.



A reset is generated whenever a basic timer counter overflow occurs. During normal operation, application software must prevent the overflow and the accompanying reset operation from occurring by clearing the BTCNT value (i.e., by writing a 1 to BTCON.1) at regular intervals.

If a system malfunction occurs due to circuit noise or some other error condition, the BT counter clear operation will not be executed and a basic timer overflow will occur, initiating a reset. In other words, during normal operation, the basic timer overflow loop (a bit 7 overflow of the 8-bit basic timer counter, BTCNT) is always broken by a BTCNT clear instruction. If a malfunction does occur, a reset is triggered automatically.

### **Oscillation Stabilization Interval Timer Function**

The basic timer can also be used to program a specific oscillation stabilization interval after a reset, or when Stop Mode has been released by an external interrupt.

In Stop Mode, whenever a reset or an external interrupt occurs, the oscillator starts. The BTCNT value then begins increasing at the rate of  $f_{XX}/4096$  (for a reset), or at the rate of the preset clock source (for an external interrupt). When BTCNT.4 overflows, a signal is generated to indicate that the stabilization interval has elapsed and to gate the clock signal off to the CPU so that it can resume normal operation.

In summary, the following events occur when Stop Mode is released:

- 1. During Stop Mode, a power-on reset or an external interrupt occurs to trigger the Stop Mode release, and oscillation begins.
- 2. If a power-on reset occurs, the basic timer counter will increase at the rate of  $f_{XX}$ / 4096. If an interrupt is used to release Stop Mode, the BTCNT value increases at the rate of the preset clock source.
- 3. A clock oscillation stabilization interval begins and continues until bit 4 of the basic timer counter overflows.
- 4. When a BTCNT.4 overflow occurs, normal CPU operation resumes.





# 8-Bit Timer A/B

This chapter discusses the S3F8S5A MCU's two 8-bit timers, Timer A and Timer B.

## 8-Bit Timer A

The 8-bit Timer A is an 8-bit general-purpose timer/counter featuring three operating modes, each of which can be selected using one of the following TACON settings:

- Interval Timer Mode (toggle output at TAOUT pin)
- Capture Input Mode with a rising or falling edge trigger at the TACAP pin
- PWM Mode (TAPWM)

Timer A provides the following functional components:

- Clock frequency divider ( $f_{XX}$  divided by 1024, 256, 64, 8, or 1) with multiplexer
- External clock input pin (TACLK)
- 8-bit counter (TACNT), 8-bit comparator, and 8-bit reference data register (TADATA)
- I/O pins for capture input (TACAP), PWM output (TAPWM), or match output (TAOUT)
- Timer A overflow interrupt (IRQ0 vector D0h) and match/capture interrupt (IRQ0 vector CEh) generation
- Timer A Control (TACON) Register (E2h, Set1, Bank0; read/write)





Figure 67 presents a block diagram of the Timer A function.

Figure 67. Timer A Functional Block Diagram

## **Timer A Control Register**

The Timer A Control (TACON) Register, shown in Table 66, can be used to perform the following tasks:

- Select the Timer A operating mode (Interval Timer, Capture Mode, or PWM Mode)
- Select the Timer A input clock frequency
- Clear the Timer A counter, TACNT
- Enable the Timer A overflow interrupt or Timer A match/capture interrupt





#### Table 66. Timer A Control Register (TACON; Set1, Bank0)

| Bit     | 7                             | 6 | 5 | 4 | 3  | 2 | 1 | 0 |
|---------|-------------------------------|---|---|---|----|---|---|---|
| Reset   | 0                             | 0 | 0 | 0 | 0  | 0 | 0 | 0 |
| R/W     | R/W                           |   |   |   |    |   |   |   |
| Address |                               |   |   | E | 2h |   |   |   |
| Mode    | Register Addressing Mode only |   |   |   |    |   |   |   |

Note: R = read only; R/W = read/write.

| Bit   | Description                                                                                                                                                                                                                                                                                 |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:5] | Timer A Input Clock Selection Bits $000: f_{XX}$ /1024. $001: f_{XX}$ /256. $010: f_{XX}$ /64. $011: f_{XX}$ /8. $100: f_{XX}$ /1. $101:$ External clock (TACLK) falling edge. $110:$ External clock (TACLK) rising edge. $111:$ Counter stop.                                              |
| [4:3] | <b>Timer A Operating Mode Selection Bits</b><br>00: Interval Mode (TAOUT).<br>01: Capture Mode (Capture on rising edge, counter running, OVF can occur).<br>10: Capture Mode (Capture on falling edge, counter running, OVF can occur).<br>11: PWM Mode; OVF and match interrupt can occur. |
| [2]   | <b>Timer A Counter Enable Bit</b><br>0: No effect.<br>1: Clear the Timer A counter (when write).                                                                                                                                                                                            |
| [1]   | <b>Timer A Match/Capture Interrupt Enable Bit</b><br>0: Disable interrupt.<br>1: Enable interrupt.                                                                                                                                                                                          |
| [0]   | <b>Timer A Overflow Interrupt Enable Bit</b><br>0: Disable interrupt.<br>1: Enable interrupt.                                                                                                                                                                                               |

TACON is located in Set1, Bank0 at address E2h, and is read/write addressable using Register Addressing Mode.

A reset clears TACON to 00h, thereby setting Timer A to normal Interval Timer Mode and selecting an input clock frequency of  $f_{XX}/1024$ ; all Timer A interrupts are disabled. The Timer A counter can be cleared at any time during normal operation by writing a 1 to TACON.2.



The IRQ0-level Timer A overflow interrupt (TAOVF) is at vector address D0h. When a Timer A overflow interrupt occurs and is serviced by the CPU, the pending condition is cleared automatically by hardware or must be cleared by software.

To enable the Timer A match/capture interrupt (IRQ0, vector CEh), write a 1 to TACON.1. To detect a match/capture interrupt pending condition, the application software polls INTPND.1. When a 1 is detected, a Timer A match or capture interrupt is pending. When the interrupt request has been serviced, the pending condition must be cleared by software by writing a 0 to the Timer A match/capture interrupt pending bit, INTPND.1.

### **Timer A Function Description**

This section describes the features and functions of the Timer A interrupt.

#### **Timer A Interrupts**

Timer A can generate two interrupts: the Timer A overflow interrupt (TAOVF) and the Timer A match/capture interrupt (TAINT). TAOVF occurs at interrupt level IRQ0, vector D0h. TAINT also occurs at IRQ0, but is assigned the separate vector address CEh.

A Timer A overflow interrupt pending condition is automatically cleared by hardware when it has been serviced, or should be cleared by software in the interrupt service routine by writing a 0 to the INTPND.0 interrupt pending bit. However, a Timer A match/capture interrupt pending condition must be cleared by the application's interrupt service routine by writing a 0 to the INTPND.1 interrupt pending bit.

#### **Timer A Interval Timer Mode**

In Interval Timer Mode, a match signal is generated when the counter value is identical to the value written to the Timer A Reference Data (TADATA) Register. The match signal generates a Timer A match interrupt (TAINT, vector CEh) and clears the counter.

If, for example, you write the value 10h to TADATA, the counter will increment until it reaches 10h. At this point, the Timer A interrupt request is generated, the counter value is reset, and counting resumes. With each match, the level of the signal at the Timer A output pin is inverted; see Figure 68.







Figure 68. Simplified Timer A Function Diagram: Interval Timer Mode

#### **Timer A Pulse Width Modulation Mode**

Pulse Width Modulation (PWM) Mode lets you program the width (duration) of the pulse that is output at the TAPWM pin. As in Interval Timer Mode, a match signal is generated when the counter value is identical to the value written to the Timer A Data Register. In PWM Mode, however, the match signal does not clear the counter. Instead, it runs continuously, overflowing at FFh, then continues incrementing from 00h.

Although the match signal can be used to generate a Timer A overflow interrupt, interrupts are not typically used in PWM-type applications. Instead, the pulse at the TAPWM pin is held Low as long as the reference data value is less than or equal to ( $\leq$ ) the counter value, the pulse is then held High for as long as the data value is greater than (>) the counter value. One pulse width is equal to t<sub>CLK</sub> x 256; see Figure 69.





Figure 69. Simplified Timer A Function Diagram: PWM Mode

### **Timer A Capture Mode**

In Capture Mode, a signal edge that is detected at the TACAP pin opens a gate and loads the current counter value into the Timer A Data Register. Rising or falling edges can be selected to trigger this operation.

Timer A also provides a capture input source: the signal edge at the TACAP pin. Select the capture input by setting the values of the Timer A capture input selection bits in the Port 1 Control Register, P1CONL.4, (E1h, Set1, Bank1). When P1CONL.4 is 0, the TACAP input is selected.

Both kinds of Timer A interrupts can be used in Capture Mode: the Timer A overflow interrupt is generated whenever a counter overflow occurs, and the Timer A match/capture interrupt is generated whenever the counter value is loaded into the Timer A Data Register.

By reading the captured data value in TADATA, and assuming a specific value for the Timer A clock frequency, you can calculate the pulse width (duration) of the signal that is being input at the TACAP pin; see Figure 70.



Figure 70. Simplified Timer A Function Diagram: Capture Mode

#### 8-Bit Timer B

The S3F8S5A microcontroller has an 8-bit counter called Timer B, which can be used to generate the carrier frequency of a remote controller signal. Timer B offers the following two functions:

- As a normal interval timer, generating a Timer B interrupt at programmed time intervals
- To supply a clock source to the 8-bit timer/counter module, Timer B, for generating the Timer B overflow interrupt

S3F8S5A

i In Life

DIXYS Company

238

**Product Specification** 





Figure 71 presents a block diagram of the Timer B function.

Figure 71. Timer B Functional Block Diagram

**Note:** The value of the TBDATAL Register is loaded into the 8-bit counter when the operation of Timer B starts. If A borrow occurs in the counter, the value of The TBDATAH Register is loaded into the 8-bit counter. However, on the next borrow, the value of the TBDATAL Register is loaded into the bit counter.

>





The Timer B Control (TBCON) Register is shown in Table 67.

#### Table 67. Timer B Control Register (TBCON; Set1, Bank0)

| Bit          | 7                                              | 6                               | 5                                          | 4             | 3        | 2                             | 1 | 0 |  |
|--------------|------------------------------------------------|---------------------------------|--------------------------------------------|---------------|----------|-------------------------------|---|---|--|
| Reset        | 0                                              | 0                               | 0                                          | 0             | 0        | 0                             | 0 | 0 |  |
| R/W          |                                                |                                 |                                            | R             | W/W      |                               |   |   |  |
| Address      |                                                |                                 |                                            | E             | 3h       |                               |   |   |  |
| Mode         | Register Addressing Mode only                  |                                 |                                            |               |          |                               |   |   |  |
| Note: R = re | ad only; R/W = re                              | ead/write.                      |                                            |               |          |                               |   |   |  |
| Bit          | Descriptio                                     | on                              |                                            |               |          |                               |   |   |  |
| [7:6]        | Reserved                                       |                                 |                                            |               |          |                               |   |   |  |
|              | 01: Genera                                     | ating after h<br>ating after lo | ow data is b<br>igh data is<br>ow and high | borrowed.     | orrowed. |                               |   |   |  |
| [3]          | <b>Timer B In</b><br>0: Disable<br>1: Enable i | interrupt.                      | able Bit                                   |               |          |                               |   |   |  |
| [2]          | Timer B S<br>0: Stop Tim<br>1: Start Tim       | ner B.                          | lit                                        |               |          |                               |   |   |  |
| [1]          | Timer B M<br>0: One-Sho<br>1: Repeat           |                                 | tion Bit                                   |               |          |                               |   |   |  |
| [0]          | 0: TBOF is                                     | Low (TBP)                       |                                            | vel for low o |          | evel for High<br>evel for Hig | , |   |  |



The Timer B Clock Selection (TBCLKS) Register is shown in Table 68.

Table 68. Timer B Clock Selection Register (TBCLKS; Set1, Bank0)

| Bit           | 7                                                                                                                                                                                        | 6           | 5         | 4            | 3          | 2    | 1 | 0 |  |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-----------|--------------|------------|------|---|---|--|
| Reset         | 0                                                                                                                                                                                        | 0           | 0         | 0            | 0          | 0    | 0 | 0 |  |
| R/W           |                                                                                                                                                                                          | R/W         |           |              |            |      |   |   |  |
| Address       |                                                                                                                                                                                          |             |           | E            | 6h         |      |   |   |  |
| Mode          |                                                                                                                                                                                          |             | Reg       | ister Addres | ssing Mode | only |   |   |  |
| Note: R = rea | ad only; R/W = r                                                                                                                                                                         | ead/write.  |           |              |            |      |   |   |  |
| Bit           | Descriptio                                                                                                                                                                               | Description |           |              |            |      |   |   |  |
| [7:3]         | Reserved                                                                                                                                                                                 |             |           |              |            |      |   |   |  |
| [2:0]         | Timer B C<br>000: f <sub>XX</sub> .<br>001: f <sub>XX</sub> /2<br>001: f <sub>XX</sub> /4<br>001: f <sub>XX</sub> /8<br>001: f <sub>XX</sub> /6<br>001: f <sub>XX</sub> /2<br>001: Not a | 4.<br>56.   | tion Bits |              |            |      |   |   |  |

#### **Timer B Pulse Width Calculations**

Figure 72 presents an example waveform consisting of a low period time,  $t_{LOW}$ , and high period time,  $t_{HIGH}$ .



Figure 72. Timer B Waveform, Example #1 of 3

To generate the waveform in Figure 72, observe the following calculations.

When TBOF = 0:  $t_{LOW} = (TBDATAL + 2) \times 1/f_X$ , 0h < TBDATAL < 100h, where  $f_X =$  the selected clock.  $t_{HIGH} = (TBDATAH + 2) \times 1/f_X$ , 0h < TBDATAH < 100h, where  $f_X =$  the selected clock.

When TBOF = 1:

 $t_{LOW} = (TBDATAH + 2) \ x \ 1/f_X, \ 0h < TBDATAH < 100h, \ where \ f_X = the selected clock.$   $t_{HIGH} = (TBDATAL + 2) \ x \ 1/f_X, \ 0h < TBDATAL < 100h, \ where \ f_X = the selected clock.$ 



To make  $t_{LOW} = 24 \mu s$  and  $t_{HIGH} = 15 \mu s$ .  $f_{OSC} = 4 MHz$ ,  $f_X = 4 MHz/4 = 1 MHz$ 

When TBOF = 1:  $t_{HIGH} = 15\mu s = (TBDATAL + 2) / f_X = (TBDATAL + 2) x 1\mu s$ , TBDATAL = 13.  $t_{LOW} = 24\mu s = (TBDATAH + 2) / f_X = (TBDATAH + 2) x 1\mu s$ , TBDATAH = 22.

Figure 73 presents the waveform output of the Timer B output in Repeat Mode.

S3F8S5A Product Specification



243









Figure 74 presents an example waveform that sets Timer B to Repeat Mode, sets the oscillation frequency as the Timer B clock source, and causes TBDATAH and TBDATAL to establish a 38kHz, 1/3-duty carrier frequency.



Figure 74. Timer B Waveform, Example #2 of 3

To generate the waveform in Figure 74, the following factors form the calculation, which follows.

- Timer B is used in Repeat Mode
- The oscillation frequency is  $4 \text{ MHz} (1 \text{ clock} = 0.25 \mu \text{s})$
- TBDATAH =  $8.795 \mu s/0.25 \mu s = 35.18$ , TBDATAL =  $17.59 \mu s/0.25 \mu s = 70.36$
- P2.0 is set to TBPWM Mode

```
ORG 0100h ;Reset address

START DI

•

•

LD TBDATAL,#(70-2) ;Set 17.5 µs

LD TBDATAH,#(35-2) ;Set 8.75 µs

LD TBCON,#00000111b ;Clock Source ← fxx

;Disable Timer B interrupt.

;Select Repeat Mode for Timer B.

;Start Timer B operation.

;Set Timer B Output flip-flop (TBOF)

;High.

OR P2CONL,#0000011b ;Set P2.0 to TBPWM Mode.

;This command generates 38kHz, 1/3

;duty pulse signal through P2.0.
```

Figure 75 presents an example waveform that sets Timer B to One Shot Mode, sets the oscillation frequency as the Timer B clock source, and causes TBDATAH and TBDATAL to establish a  $40\mu$ s-width pulse.





Figure 75. Timer B Waveform, Example #3 of 3

40 µs

To generate the waveform in Figure 75, the following factors form the calculation, which follows.

►

• Timer B is used in One Shot Mode

-

- The oscillation frequency is  $4 \text{ MHz} (1 \text{ clock} = 0.25 \mu \text{s})$
- TBDATAH =  $40\mu s/0.25\mu s = 160$ , TBDATAL = 1
- P2.0 is set to TBPWM Mode

```
ORG
            0100h
                            ;Reset address
START DI
      ΤD
            TBDATAH,# (160-2);Set 40 µs
      LD
            TBDATAL,# 1
                            ;Set any value except 00H
      LD
            TBCON,#0000001b;Clock Source ← fOSC
                            ;Disable Timer B interrupt.
                             ;Select One Shot Mode for Timer B.
                             ;Stop Timer B operation.
                             ;Set Timer B output flip-flop (TBOF)
                             ;High
      OR P2CONL, #00000011b ;Set P2.0 to TBPWM Mode.
      ٠
Pulse_out: LD TBCON,#00000101b ;Start Timer B operation
                             ;To make the pulse at this point.
                             ;After the instruction is executed,
                             ;0.75 µs is required
      ٠
                             ; before the falling edge of the pulse
      .
                             ;starts.
```





## 8-Bit Timer C

This chapter discusses the S3F8S5A MCU's 8-bit Timer C, an 8-bit general-purpose timer/counter featuring two operating modes, each of can be selected using one of the following two TCCON settings:

- Interval Timer Mode (toggle output at the TCOUT/TCPWM pins), in which only a match interrupt occurs
- PWM Mode (TCOUT/TCPWM pin), in which match and overflow interrupts can occur

Timer C also features the following functional components:

- Clock frequency divider with multiplexer
- 8-bit counter, 8-bit comparator, and 8-bit reference data register (TCDATA)
- PWM or match output (TCOUT/TCPWM)
- Timer C match/overflow interrupt (IRQ2, vector D4h) generation
- Timer C Control (TCCON) Register; Set1, Bank0, ECh, read/write

Figure 76 presents a block diagram of the Timer C function.



Figure 76. Timer C Functional Block Diagram



**Note:** When operating in PWM Mode, the match signal cannot clear the counter.

### **Timer C Control Register**

The Timer C Control (TCCON) Register, shown in Table 69, can be used to perform the following tasks:

- Select the Timer C operating mode ( $f_{XX}/1$  & PWM Mode or  $f_{XX}/64$  & Interval Mode)
- Select the Timer C 3-bits prescaler
- Clear the Timer C counter, TCCNT
- Enable the Timer C match/overflow interrupt
- Start the Timer C

TCCON is located in Set1, Bank0 at address ECh, and is read/write-addressable using Register Addressing Mode. A System Reset clears TCCON, thereby disabling Timer C. The Timer C counter can be cleared at any time during normal operation by writing a 1 to TCCON.3.

To enable the Timer C match/overflow interrupt (IRQ2, vector D4h), write a 1 to TCCON.7 and TCCON.1. To generate the exact time interval, write a 0 to TCCON.3 to clear the counter and the interrupt pending bit. To detect an interrupt pending condition when TCINT is disabled, the application software polls the pending bit, TCCN.0. When a 1 is detected, a Timer C match/overflow interrupt is pending. When the TCINT subroutine has been serviced, the pending condition must be cleared by software by writing a 0 to the Timer C interrupt pending bit, TCCN.0.





#### Table 69. Timer C Control Register (TCCON; Set1, Bank0)

| Bit           | 7                                                                                                                   | 6                                                                    | 5              | 4                    | 3            | 2            | 1 | 0 |  |
|---------------|---------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|----------------|----------------------|--------------|--------------|---|---|--|
| Reset         | 0                                                                                                                   | 0                                                                    | 0              | 0                    | 0            | 0            | 0 | 0 |  |
| R/W           | R/W                                                                                                                 |                                                                      |                |                      |              |              |   |   |  |
| Address       |                                                                                                                     |                                                                      |                | E                    | Ch           |              |   |   |  |
| Mode          |                                                                                                                     |                                                                      | Reg            | ister Addres         | ssing Mode   | only         |   |   |  |
| Note: R = rea | ad only; R/W = re                                                                                                   | ead/write.                                                           |                |                      |              |              |   |   |  |
| Bit           | Descriptio                                                                                                          | n                                                                    |                |                      |              |              |   |   |  |
| [7]           | <b>Timer C Start/Stop Bit</b><br>0: Stop Timer C.<br>1: Start Timer C.                                              |                                                                      |                |                      |              |              |   |   |  |
| [6:4]         | Timer C 3-<br>000: Not di<br>001: Divide<br>010: Divide<br>011: Divide<br>100: Divide<br>110: Divide<br>111: Divide | ed by 2.<br>ed by 3.<br>ed by 4.<br>ed by 5.<br>ed by 6.<br>ed by 7. | ler Bits       |                      |              |              |   |   |  |
| [3]           | 0: No effec                                                                                                         | <b>ounter Cle</b><br>t.<br>e Timer C c                               |                | en write).           |              |              |   |   |  |
| [2]           | 0: f <sub>XX</sub> /1 an                                                                                            | ode Select<br>d PWM Mo<br>nd Interval                                | de.            |                      |              |              |   |   |  |
| [1]           | <b>Timer C In</b><br>0: Disable<br>1: Enable i                                                                      |                                                                      | able Bit       |                      |              |              |   |   |  |
| [0]           | 0: No inter                                                                                                         | terrupt Per<br>rupt pending                                          | g (when rea    | ad), clear pe<br>d). | ending bit ( | when write)  |   |   |  |
| Note: *The T  | CCON.3 value is                                                                                                     | s automatica                                                         | lly cleared to | o 0 after bein       | g cleared by | the counter. |   |   |  |





# 16-Bit Timer D0/D1

This chapter discusses the S3F8S5A MCU's 16-bit Timer D0/D1, a 16-bit general-purpose timer. Timer D0 features the following three operating modes, each of which can be selected using the appropriate TD0CON setting:

- Interval Timer Mode (toggle output at the TD0OUT pin)
- Capture Input Mode with a rising or falling edge trigger at the TD0CAP pin
- PWM Mode (TD0PWM); the PWM output shares its output port with the TD0OUT pin

Timer D0 also features the following functional components:

- Clock frequency divider ( $f_{XX}$  divided by 1024, 256, 64, 8, 1) with multiplexer
- External clock input pin (TD0CLK)
- A 16-bit counter (TD0CNTH/TD0CNTHL), a 16-bit comparator, and two 16-bit reference data registers (TD0DATAH/TD0DATAL)
- I/O pins for capture input (TD0CAP) or match output (TD0OUT)
- Timer D0 overflow interrupt (IRQ3, vector DAh) and match/capture interrupt generation (IRQ3, vector D8h)
- Timer D0 Control (TD0CON) Register (Page 4, 01h; read/write)

Figure 77 presents a block diagram of the Timer D0 function.







Figure 77. Timer D0 Functional Block Diagram

### **Timer D0 Control Register**

Use the Timer D0 Control (TD0CON) Register, shown in Table 70, to perform the following tasks:

- Select the Timer D0 operating mode (Interval Timer, Capture Mode, or PWM Mode)
- Select the Timer D0 input clock frequency
- Clear the Timer D0 counter, TD0CNTH/TD0CNTL
- Enable the Timer D0 overflow interrupt or Timer D0 match/capture interrupt

TD0CON is located in Page 4 at address 01h, and is read/write addressable using Register Addressing Mode.

A reset clears TD0CON to 00h, thereby setting Timer D0 to normal Interval Timer Mode, and selecting an input clock frequency of  $f_{XX}/1024$ ; all Timer D0 interrupts are disabled.





To disable counter operation, set TD0CON.7–.5 to 111b. Clear the Timer D0 counter at any time during normal operation by writing a 1 to TD0CON.2.

#### Table 70. Timer D0 Control Register (TD0CON; Page 4)

| Bit     | 7                             | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---------|-------------------------------|---|---|---|---|---|---|---|
| Reset   | 0                             | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| R/W     | R/W                           |   |   |   |   |   |   |   |
| Address | 01h                           |   |   |   |   |   |   |   |
| Mode    | Register Addressing Mode only |   |   |   |   |   |   |   |

Bit Description [7:5] **Timer D0 Input Clock Selection Bits** 000: f<sub>XX</sub>/1024. 001: f<sub>XX</sub>/256. 010: f<sub>XX</sub>/64. 011: f<sub>XX</sub>/8. 100: f<sub>XX</sub>/1. 101: External clock (TD0CLK) falling edge. 110: External clock (TD0CLK) rising edge. 111: Counter stop. [4:3] **Timer D0 Operating Mode Selection Bits** 00: Interval Mode (TD0OUT). 01: Capture Mode (Capture on rising edge, counter running, OVF can occur). 10: Capture Mode (Capture on falling edge, counter running, OVF can occur. 11: PWM Mode (OVF and match interrupt can occur). **Timer D0 Counter Clear Bit\*** [2] 0: No effect. 1: Clear the Timer D0 counter (when write). [1] **Timer D0 Match/Capture Interrupt Enable Bit** 0: Disable interrupt. 1: Enable interrupt. [0] **Timer D0 Overflow Interrupt Enable Bit** 0: Disable overflow interrupt. 1: Enable overflow interrupt. \*Refer to the Interrupt Pending (INTPND) Register for the Timer D0 pending bits. Note:

The IRQ3-level Timer D0 overflow interrupt (TD0OVF) is at vector address DAh. When a Timer D0 overflow interrupt occurs and is serviced by an interrupt (IRQ3, vector DAh), write a 1 to TD0CON.0. When a Timer D0 overflow interrupt occurs and is serviced by the CPU, the pending condition is cleared automatically by hardware or must be cleared by software.





To enable the Timer D0 match/capture interrupt (IRQ3, vector D8h), write a 1 to TD0CON.1. To detect a match/capture interrupt pending condition, the application software polls INTPND.3. When a 1 is detected, a Timer D0 match or capture interrupt is pending. When the interrupt request has been serviced, the pending condition must be cleared by software by writing a 0 to the Timer D0 match/capture interrupt pending bit, INTPND.3.

### **Timer D0 Function Description**

This section describes the features and functions of the Timer A interrupt.

#### **Timer D0 Interrupts**

Timer D0 can generate two interrupts: the Timer D0 overflow interrupt (TD0OVF) and the Timer D0 match/capture interrupt (TD0INT). TD0OVF is associated to interrupt level IRQ3 at vector DAh. TD0INT is also associated to interrupt level IRQ3, but is assigned the separate vector address, D8h.

A Timer D0 overflow interrupt pending condition is automatically cleared by hardware when it has been serviced or should be cleared by software in the interrupt service routine by writing a 0 to the INTPND.2 interrupt pending bit. However, the Timer D0 match/capture interrupt pending condition must be cleared by the application's interrupt service routine by writing a 0 to the INTPND.3 interrupt pending bit.

#### **Timer D0 Interval Timer Mode**

In Interval Timer Mode, a match signal is generated when the counter value is identical to the value written to the Timer D0 Reference Data Register, TD0DATAH/TD0DATAL. The match signal generates a Timer D0 match interrupt (TD0INT, vector D8h) and clears the counter.

If, for example, you write the value 1087h to TD0DATAH/TD0DATAL, the counter will increment until it reaches 1087h. At this point, the Timer D0 interrupt request is generated, the counter value is reset, and counting resumes. With each match, the level of the signal at the Timer D0 output pin is inverted; see Figure 78.



DXYS Company







#### **Timer D0 Pulse Width Modulation Mode**

Pulse Width Modulation (PWM) Mode lets you program the width (duration) of the pulse that is output at the TD0PWM pin. As in Interval Timer Mode, a match signal is generated when the counter value is identical to the value written to the Timer D0 Data Register. In PWM Mode, however, the match signal does not clear the counter. Instead, it runs continuously, overflowing at FFFFh, then continues incrementing from 0000h.

Although you can use the match signal to generate a Timer D0 overflow interrupt, interrupts are not typically used in PWM-type applications. Instead, the pulse at the TD0PWM pin is held Low as long as the reference data value is less than or equal to ( $\leq$ ) the counter value; the pulse is then held High for as long as the data value is greater than (>) the counter value. One pulse width is equal to t<sub>CLK</sub> x 65536; see Figure 79.



d In Life

DXYS Company



Figure 79. Simplified Timer D0 Function Diagram: PWM Mode

#### **Timer D0 Capture Mode**

In Capture Mode, a signal edge that is detected at the TD0CAP pin opens a gate and loads the current counter value into the Timer D0 Data Register. Rising or falling edges can be selected to trigger this operation.

Timer D0 also provides an capture input source: the signal edge at the TD0CAP pin. Select the capture input by setting the values of the Timer D0 capture input selection bits in the Port 2 Control Register, P2CONL.3–.2 (Set1, Bank1, E7h). When P2CONL.3–.2 is 00, the TD0CAP input is selected.

Both kinds of Timer D0 interrupts can be used in Capture Mode: the Timer D0 overflow interrupt is generated whenever a counter overflow occurs; the Timer D0 match/capture interrupt is generated whenever the counter value is loaded into the Timer D0 Data Register.

By reading the captured data value in TD0DATAH/TD0DATAL, and assuming a specific value for the Timer D0 clock frequency, you can calculate the pulse width (duration) of the signal that is being input at the TD0CAP pin; see Figure 80.



Figure 80. Simplified Timer D0 Function Diagram: Capture Mode





# 16-Bit Timer D1

The 16-bit Timer D1 is a 16-bit general-purpose timer featuring three operating modes, each of which can be selected using one of the following TD1CON settings:

- Interval Timer Mode (toggle output at the TD1OUT pin)
- Capture Input Mode with a rising or falling edge trigger at the TD1CAP pin
- PWM Mode (TD1PWM); PWM output shares its output port with the TD1OUT pin

Timer D1 also features the following functional components:

- Clock frequency divider ( $f_{XX}$  divided by 1024, 256, 64, 8, 1) with multiplexer
- External clock input pin (TD1CLK)
- A 16-bit counter (TD1CNTH/TD1CNTL), a 16-bit comparator, and two 16-bit reference data registers (TD1DATAH/TD1DATAL)
- I/O pins for capture input (TD1CAP), or match output (TD1OUT)
- Timer D1 overflow interrupt (IRQ3, vector DEh) and match/capture interrupt (IRQ3, vector DCh) generation
- Timer D1 Control (TD1CON) Register (Page 4, 0Ah; read/write)

Figure 81 presents a block diagram of the Timer D1 function.







Figure 81. Timer D1 Functional Block Diagram

### **Timer D1 Control Register**

Use the Timer D1 Control (TD1CON) Register, shown in Table 71, to perform the following tasks:

- Select the Timer D1 operating mode (Interval Timer, Capture Mode, or PWM Mode)
- Select the Timer D1 input clock frequency
- Clear the Timer D1 counter, TD1CNTH/T D1CNTL
- Enable the Timer D1 overflow interrupt or Timer D1 match/capture interrupt

TD1CON is located in Set1 and Bank1 at address FBh, and is read/write addressable using Register Addressing Mode.

#### S3F8S5A Product Specification



258

A reset clears TD1CON to 00h, thereby setting Timer D1 to normal Interval Timer Mode, selecting an input clock frequency of  $f_{XX}/1024$ , and disabling all Timer D1 interrupts. To disable the counter operation, set TD1CON.7–.5 to 111b. The Timer D1 counter can be cleared at any time during normal operation by writing a 1 to TD1CON.2. The IRQ3-level Timer D1 overflow interrupt (TD1OVF) is at vector address DEh.

Table 71. Timer D1 Control Register (TD1CON; Page 4)

| D:4          | 7                             | • | F | 4 | • | 2 | 4 | 0 |
|--------------|-------------------------------|---|---|---|---|---|---|---|
| Bit          | 1                             | 0 | 5 | 4 | 3 | 2 | 1 | U |
| Reset        | 0                             | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| R/W          |                               |   |   | R | W |   |   |   |
| Address      | 0Ah                           |   |   |   |   |   |   |   |
| Mode         | Register Addressing Mode only |   |   |   |   |   |   |   |
| Nata: D read |                               |   |   |   |   |   |   |   |

Note: R = read only; R/W = read/write.

| Bit   | Description                                                                                                                                                                                                                                                                                   |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:5] | Timer D1 Input Clock Selection Bits $000: f_{XX}/1024.$ $001: f_{XX}/256.$ $010: f_{XX}/64.$ $011: f_{XX}/8.$ $100: f_{XX}/1.$ $101:$ External clock (TD1CLK) falling edge. $110:$ External clock (TD1CLK) rising edge. $111:$ Counter stop.                                                  |
| [4:3] | <b>Timer D1 Operating Mode Selection Bits</b><br>00: Interval Mode (TD1OUT).<br>01: Capture Mode (Capture on rising edge, counter running, OVF can occur).<br>10: Capture Mode (Capture on falling edge, counter running, OVF can occur.<br>11: PWM Mode (OVF and match interrupt can occur). |
| [2]   | <b>Timer D1 Counter Clear Bit*</b><br>0: No effect.<br>1: Clear the Timer D1 counter (when write).                                                                                                                                                                                            |
| [1]   | <b>Timer D1 Match/Capture Interrupt Enable Bit</b><br>0: Disable interrupt.<br>1: Enable interrupt.                                                                                                                                                                                           |
| [0]   | <b>Timer D1 Overflow Interrupt Enable Bit</b><br>0: Disable overflow interrupt.<br>1: Enable overflow interrupt.                                                                                                                                                                              |
| Note: | *Refer to the Interrupt Pending (INTPND) Register for the Timer D1 pending bits.                                                                                                                                                                                                              |

When a Timer D1 overflow interrupt occurs and is serviced interrupt (IRQ3, vector DEh), write a 1 to TD1CON.0. When a Timer D1 overflow interrupt occurs and is serviced by



the CPU, the pending condition is cleared automatically by hardware or must be cleared by software.

To enable the Timer D1 match/capture interrupt (IRQ3, vector DCh), write a 1 to TD1CON.1. To detect a match/capture interrupt pending condition, the application software polls INTPND.3. When a 1 is detected, a Timer D1 match or capture interrupt is pending. When the interrupt request has been serviced, the pending condition must be cleared by software by writing a 0 to the Timer D1 match/capture interrupt pending bit, INTPND.5.

### **Timer D1 Function Description**

This section describes the features and functions of the Timer D1 interrupt.

#### **Timer D1 Interrupts**

The Timer D1 can generate two interrupts: the Timer D1 overflow interrupt (TD1OVF), and the Timer D1 match/capture interrupt (TD1INT). TD1OVF is associates to interrupt level IRQ3, vector DEh. TD1INT also associates to interrupt level IRQ3, but is assigned the separate vector address, DCh.

A Timer D1 overflow interrupt pending condition is automatically cleared by hardware when it has been serviced, or should be cleared by software in the interrupt service routine by writing a 0 to the INTPND.4 interrupt pending bit. However, the Timer D1 match/capture interrupt pending condition must be cleared by the application's interrupt service routine by writing a 0 to the INTPND.5 interrupt pending bit.

#### **Timer D1 Interval Timer Mode**

In Interval Timer Mode, a match signal is generated when the counter value is identical to the value written to the Timer D1 Reference Data Register, TD1DATAH/TD1DATAL. The match signal generates a Timer D1 match interrupt (TD1INT, vector DCh) and clears the counter.

If, for example, you write the value 1087h to TD1DATAH/TD1DATAL, the counter will increment until it reaches 1087h. At this point, the Timer D1 interrupt request is generated, the counter value is reset, and counting resumes. With each match, the level of the signal at the Timer D1 output pin is inverted; see Figure 82.



DXYS Company

260





#### **Timer D1 Pulse Width Modulation Mode**

Pulse Width Modulation (PWM) Mode lets you program the width (duration) of the pulse that is output at the TD1PWM pin. As in Interval Timer Mode, a match signal is generated when the counter value is identical to the value written to the Timer D1 Data Register. In PWM Mode, however, the match signal does not clear the counter. Instead, it runs continuously, overflowing at FFFFh, then continues incrementing from 0000h.

Although you can use the match signal to generate a Timer D1 overflow interrupt, interrupts are not typically used in PWM-type applications. Instead, the pulse at the TD1PWM pin is held Low as long as the reference data value is less than or equal to ( $\leq$ ) the counter value; the pulse is then held High for as long as the data value is greater than (>) the counter value. One pulse width is equal to t<sub>CLK</sub> x 65536; see Figure 83.



d In LH

DIXYS Company



Figure 83. Simplified Timer D1 Function Diagram: PWM Mode

#### **Timer D1 Capture Mode**

In Capture Mode, a signal edge that is detected at the TD1CAP pin opens a gate and loads the current counter value into the Timer D1 Data Register. Select rising or falling edges to trigger this operation.

Timer D1 also provides a capture input source: the signal edge at the TD1CAP pin. Select the capture input by setting the values of the Timer D1 capture input selection bits in the Port 1 Control Register, P1CONH.3–.2 (Set1, Bank1, E0h). When P1CONH.3–.2 is 00, the TD1CAP input is selected.

Both kinds of Timer D1 interrupts can be used in Capture Mode: the Timer D1 overflow interrupt is generated whenever a counter overflow occurs, and the Timer D1 match/capture interrupt is generated whenever the counter value is loaded into the Timer D1 Data Register.

By reading the captured data value in TD1DATAH/TD1DATAL, and assuming a specific value for the Timer D1 clock frequency, you can calculate the pulse width (duration) of the signal that is being input at the TD1CAP pin; see Figure 84.



Figure 84. Simplified Timer D1 Function Diagram: Capture Mode

S3F8S5A

l O G

An DXYS Company

262

**Product Specification** 





## Watch Timer

The watch timer functions include programmable periodic interrupts, programmable frequency buzzer output, and a clock source for the LCD controller. The time base input for the watch timer can be set to either the main clock divided by 128 or the 32.768kHz subclock.

To start watch timer operation, set bit 1 of the Watch Timer Control Register, WTCON.1, to 1. To enable the watch timer overflow interrupt (IRQ4, vector E6h), set WTCON.0 to 1. After the watch timer starts and the time selected by WTCON.3-.2 elapses, the watch timer interrupt pending bit (INTPND.7) is automatically set to 1, and interrupt requests continue to occur in 1.995 ms, 0.125 s, 0.25 s and 0.5 s intervals.

The watch timer can also generate a programmable frequency for the BUZ output pin for a buzzer function. WTCON.3 and WTCON.2 must be set to 11b, thereby selecting 1.995 ms, and the output frequency can then be selected from 0.5 kHz, 1 kHz, 2 kHz, or 4 kHz with WTCON.4 and .5.

The watch timer supplies the clock frequency for the LCD controller ( $f_{LCD}$ ). Therefore, if the watch timer is disabled, the LCD controller does not operate.

The watch timer provides the following features:

- Periodic interrupt generation (1.995 ms, 0.125 s, 0.25 s or 0.5 s)
- Selectable main clock or subclock for time base
- Provides clock source generation for the LCD controller (f<sub>LCD</sub>)
- I/O pin for buzzer output frequency generator (BUZ)
- Watch timer overflow interrupt (IRQ4, vector E6h) generation
- Watch Timer Control (WTCON) Register (Set1, Bank1, FEh, read/write)







Figure 85 presents a block diagram of the watch timer circuit.

Figure 85. Watch Timer Circuit Block Diagram

## Watch Timer Control Register

The Watch Timer Control (WTCON) Register, shown in Table 72, is used to select the watch timer interrupt time and buzzer signal to enable or disable the watch timer function. It is located in Set1, Bank1 at address FEh, and is read/write addressable using Register Addressing Mode.





#### Table 72. Watch Timer Control Register (WTCON; Set1, Bank1)

| Bit            | 7                             | 6         | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------|-------------------------------|-----------|---|---|---|---|---|---|
| Reset          | 0                             | 0         | 0 | 0 | 0 | 0 | 0 | 0 |
| R/W            | R/W                           |           |   |   |   |   |   |   |
| Address        | FEh                           |           |   |   |   |   |   |   |
| Mode           | Register Addressing Mode only |           |   |   |   |   |   |   |
| Noto: P - road | $ op _{V} \cdot P/M - r$      | and/write |   |   |   |   |   |   |

Note: R = read only; R/W = read/write.

| Bit        | Description                                                                                                                                                                                                   |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:6]      | Watch Timer Clock Selection Bits<br>00: Select main clock divided by $2^7$ ( $f_{XX}/128$ ).<br>01: Select main clock divided by $2^8$ ( $f_{XX}/256$ ).<br>10: Select subclock.<br>11: Not available.        |
| [5:4]      | Buzzer Signal Selection Bits<br>00: 0.5kHz.<br>01: 1kHz.<br>10: 2kHz.<br>11: 4kHz.                                                                                                                            |
| [3:2]      | Watch Timer Speed Selection Bits<br>00: Set watch timer interrupt to 0.5s.<br>01: Set watch timer interrupt to 0.25s.<br>10: Set watch timer interrupt to 0.125s.<br>11: Set watch timer interrupt to 0.391s. |
| [1]        | Watch Timer Enable Bit<br>0: Disable watch timer; clear frequency dividing circuits.<br>1: Enable watch timer.                                                                                                |
| [0]        | Watch Timer Interrupt Enable Bit<br>0: Disable watch timer interrupt.<br>1: Enable watch timer interrupt.                                                                                                     |
| Note: Refe | er to bit 7 of the INTPND Register for the watch timer pending bit.                                                                                                                                           |

A reset clears WTCON to 00h, thereby disabling the watch timer. Therefore, to use the watch timer, write the appropriate value to WTCON.

#### S3F8S5A **Product Specification**



## 266

# LCD Controller/Driver

The S3F8S5A microcontroller can directly drive a 18-segment x 8-common LCD panel up to 144 dots. Its LCD block features the following components:

- LCD controller/driver
- Display RAM (00h-15h) for storing display data in Page 3
- 4 common/segment output pins (COM4/SEG16-COM7/SEG19)
- ۰ 18 segment output pins (SEG0–SEG15/SEG20–SEG21)
- 4 common output pins (COM0–COM3)
- ٠ LCD bias by voltage-dividing resistors

The LCD Control (LCON) Register, shown in Table 73, is used to turn the LCD display on and off and to select the frame frequency, LCD duty, and bias. Data written to LCD display RAM can be automatically transferred to the segment signal pins without any program control. When a subsystem clock is selected as the LCD clock source, the LCD display is enabled even in the main clock stop or idle modes.

LCD data stored in display RAM locations are transferred to the segment signal pins automatically without program control.

| Bit            | 7               | 6          | 5   | 4            | 3         | 2    | 1   | 0   |
|----------------|-----------------|------------|-----|--------------|-----------|------|-----|-----|
| Reset          | 0               | 0          | 0   | 0            | 0         | 0    | 0   | 0   |
| R/W            | R/W             | R/W        | R/W | R/W          | R/W       | R/W  | R/W | R/W |
| Address        |                 |            |     | F            | ōh        |      |     |     |
| Mode           |                 |            | Reg | ister Addres | sing Mode | only |     |     |
| Note: R = read | d only; R/W = r | ead/write. |     |              |           |      |     |     |
| Bit            | Descriptio      | on         |     |              |           |      |     |     |

#### Table 73. LCD Control Register (LCON; Set1, Bank1)

| [7] | COM Pins High Impedance Control Bit |
|-----|-------------------------------------|
|     | 0: Display off.                     |
|     | 1: Turn Display on.                 |
|     |                                     |

S3F8S5A Product Specification



267

| Bit   | Description (Continued)                                                                                                                                                                                          |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [6:4] | LCD Clock Selection Bits                                                                                                                                                                                         |
|       | 000: f <sub>W</sub> /28 (128Hz).                                                                                                                                                                                 |
|       | 001: f <sub>W</sub> /27 (256Hz).                                                                                                                                                                                 |
|       | 010: f <sub>W</sub> /26 (512Hz).                                                                                                                                                                                 |
|       | 011: f <sub>W</sub> /25 (1024Hz).                                                                                                                                                                                |
|       | 100: f <sub>W</sub> /24 (2048Hz).                                                                                                                                                                                |
|       | 101–111: Not available.                                                                                                                                                                                          |
| [3:1] | LCD Duty and Bias Selection Bits                                                                                                                                                                                 |
|       | 000: 1/8 duty, 1/4 bias.                                                                                                                                                                                         |
|       | 001: 1/4 duty, 1/3 bias.                                                                                                                                                                                         |
|       | 010: 1/3 duty, 1/3 bias.                                                                                                                                                                                         |
|       | 011: 1/3 duty, 1/2 bias.                                                                                                                                                                                         |
|       | 1xx: 1/2 duty, 1/2 bias.                                                                                                                                                                                         |
| [0]   | LCD Display Control Bits                                                                                                                                                                                         |
|       | 0: Display off.                                                                                                                                                                                                  |
|       | 1: Turn display on.                                                                                                                                                                                              |
| Note: | The clock and duty cycle for the LCD controller/driver are automatically initialized by hardware whenever the LCON Register data value is rewritten. As a result, the LCON Register does not rewrite frequently. |

Figure 86 presents a block diagram of the LCD function.







Figure 87 presents a diagram of the LCD circuit.





#### LCD RAM Address Area

RAM addresses of 00h-15h in Page 3 are used as LCD data memory. These locations can be addressed by 1-bit or 8-bit instructions. When the bit value of a display segment is 1, the LCD display is turned on; when the bit value is 0, the display is turned off.

Display RAM data are sent out through the segment pins, SEG0–SEG21, using a direct memory access (DMA) method that is synchronized with the  $f_{LCD}$  signal. RAM addresses

PRELIMINARY

in this location that are not used for LCD display can be allocated to general-purpose use; see Table 74.

| СОМ  | Bit | SEG0      | SEG1 | SEG2 | SEG3 | SEG4 | _ | SEG20 | SEG21 |
|------|-----|-----------|------|------|------|------|---|-------|-------|
| COM0 | .0  |           |      |      |      |      |   |       |       |
| COM1 | .1  | _         |      |      |      |      |   |       |       |
| COM2 | .2  | _         |      |      |      |      |   |       |       |
| COM3 | .3  | -<br>200h | 2016 | 2026 | 2026 | 2016 |   | 21.46 | 215h  |
| COM4 | .4  | – 300h    | 301h | 302h | 303h | 304h | _ | 314h  | 315h  |
| COM5 | .5  | _         |      |      |      |      |   |       |       |
| COM6 | .6  | _         |      |      |      |      |   |       |       |
| COM7 | .7  | _         |      |      |      |      |   |       |       |

Table 74. LCD Display Data RAM Organization

## **LCD Control Register**

The LCD Control (LCON) Register, shown in Table 75, is located in Set1, Bank1 at address F9h, and is read/write addressable using Register Addressing Mode. This register features the following control functions:

- LCD duty and bias selection
- LCD clock selection
- LCD display control

The LCON Register is used to turn the LCD display on/off, to select duty and bias, to select the LCD clock. A reset clears the LCON Register to 00h, thereby turning off the LCD display, selecting 1/8 duty and 1/4 bias, and selecting 128Hz for the LCD clock.

The LCD clock signal determines the frequency of the COM signal scan of each segment output; also referred to as the *LCD frame frequency*. Because the LCD clock is generated by the watch timer clock ( $f_W$ ), the watch timer should be enabled when the LCD display is turned on.

# **Note:** The clock and duty for the LCD controller/driver is automatically initialized by hardware whenever the LCON Register data value is rewritten. Therefore, the LCON Register does not rewrite frequently.





#### Table 75. LCD Control Register (LCON; Set1, Bank1)

| Bit   |                            | 7                                   | 6             | 5           | 4           | 3          | 2    | 1   | 0   |
|-------|----------------------------|-------------------------------------|---------------|-------------|-------------|------------|------|-----|-----|
| Reset | t                          | 0                                   | 0             | 0           | 0           | 0          | 0    | 0   | 0   |
| R/W   |                            | R/W                                 | R/W           | R/W         | R/W         | R/W        | R/W  | R/W | R/W |
| Addre | ess                        |                                     |               |             | F.          | Ah         |      |     |     |
| Mode  | 9                          |                                     |               | Reg         | ister Addre | ssing Mode | only |     |     |
| Note: | R = read only;             | R/W = r                             | ead/write.    |             |             |            |      |     |     |
| Bit   | De                         | scriptic                            | on            |             |             |            |      |     |     |
| [7]   |                            |                                     | High Impe     |             | ntrol Bit   |            |      |     |     |
|       |                            |                                     | ignal outpu   |             |             |            |      |     |     |
|       | 1: (                       | COM pir                             | ns high imp   | edance out  | tput.       |            |      |     |     |
| [6:4] | LC                         | D Cloc                              | k Selection   | Bits        |             |            |      |     |     |
|       | 000                        | ): f <sub>\v/</sub> /2 <sup>8</sup> | (128Hz).      |             |             |            |      |     |     |
|       |                            |                                     | (256Hz).      |             |             |            |      |     |     |
|       |                            |                                     | (512Hz).      |             |             |            |      |     |     |
|       | 011                        | l: fŵ/2 <sup>5</sup>                | (1024Hz).     |             |             |            |      |     |     |
|       |                            |                                     | (2048Hz).     |             |             |            |      |     |     |
|       |                            |                                     | Not available | э.          |             |            |      |     |     |
| [3:1] | LC                         | D Duty                              | and Bias S    | Selection E | Bits        |            |      |     |     |
|       |                            | •                                   | uty, 1/4 bias |             |             |            |      |     |     |
|       | 001                        | 1: 1/4 du                           | uty, 1/3 bias |             |             |            |      |     |     |
|       | 010                        | ): 1/3 du                           | uty, 1/3 bias |             |             |            |      |     |     |
|       | 011                        | l: 1/3 du                           | uty, 1/2 bias |             |             |            |      |     |     |
|       |                            |                                     | uty, 1/2 bias |             |             |            |      |     |     |
| [0]   | LC                         | D Displ                             | lay Control   | Bits        |             |            |      |     |     |
|       | 0: A                       | All LCD                             | signals are   | low.        |             |            |      |     |     |
|       | 1: 7                       | Turn dis                            | play on.      |             |             |            |      |     |     |
| Note: | The clock and LCON Registe |                                     |               |             |             |            |      |     |     |



#### **Internal Resistor Bias**

Figure 88 shows the internal bias connections.





Note: In Figure 88,  $V_{LC0}$  and  $V_{LC1}$  should be connected at 1/3 bias;  $V_{LC0}$ ,  $V_{LC1}$ , and  $V_{LC2}$  should be connected at 1/2 bias.





## **Common Signals**

The common signal (COM) output pin selection varies according to the selected duty cycle, as follows:

- In 1/8 Duty Mode, COM0–COM7 (SEG0–SEG15/SEG20–SEG21) pins are selected
- In 1/4 Duty Mode, COM0–COM3 (SEG0–SEG21) pins are selected
- In 1/3 Duty Mode, COM0–COM2 (SEG0–SEG21) pins are selected
- In 1/2 Duty Mode, COM0–COM1 (SEG0–SEG21) pins are selected

## **Segment Signals**

The 22 LCD segment signal pins are connected to their corresponding display RAM locations at Page 3. The bits of the display RAM are synchronized with the common signal output pins.

When the bit value of a display RAM location is 1, a select signal is sent to the corresponding segment pin. When the display bit is 0, a *no-select signal* is sent to the corresponding segment pin. See Figures 89 and 90.



Figure 89. Select/No-Select Signal in 1/2 Duty, 1/2 Bias Display Mode



Figure 90. Select/No-Select Signal in 1/3 Duty, 1/3 Bias Display Mode

Figures 91 through 95 present waveforms of the LCD signal for differing duty and bias configurations.

S3F8S5A

**Product Specification** 



An DXYS Company

274



**Note:** In Figure 91,  $V_{LC0} = V_{LC1}$ ,  $V_{LC2}$ .



An DXYS Company

275



**Note:** In Figure 92,  $V_{LC0} = V_{LC1}$ .









**Note:** In Figure 93,  $V_{LC0} = V_{LC1}$ .









COM0

COM1

COM2

COM3

COM4 COM5 COM6

COM7

SSSSS

EEEEE

G G G G G 6 7 8 9 10



Figure 95. LCD Signal Waveforms: 1/8 Duty, 1/4 Bias, #2 of 2

S3F8S5A

l O G

An DXYS Company

278

**Product Specification** 





## 10-Bit Analog-to-Digital Converter

The 10-bit A/D converter (ADC) module uses successive approximation logic to convert analog levels entering at one of the eight input channels to equivalent 10-bit digital values. The analog input level must lie between the  $AV_{REF}$  and  $V_{SS}$  values.

The A/D converter features the following components:

- Analog comparator with successive approximation logic
- D/A converter logic (resistor string type)
- ADC Control (ADCON) Register
- Eight multiplexed analog data input pins (AD0–AD7)
- 10-bit A/D conversion data output register (ADDATAH/ADDATAL)
- 8-bit digital input port (alternatively, I/O port)
- AV<sub>REF</sub> and V<sub>SS</sub> pins

#### **Function Description**

To initiate an analog-to-digital conversion procedure, set the ADCEN signal for ADC input enable at Ports 0/1; the pin set with the alternative function can be used for ADC analog input. Next, write the channel selection data in ADCON.4–.6 to select one of the eight analog input pins (AD0–AD7), then set the conversion start or disable bit, ADCON.0. The read/write ADCON Register (see <u>Table 76</u> on page 281) is located in Set1, Bank0 at address D2h. The pins that are not used for ADC can be used for normal I/O.

During a normal conversion, ADC logic initially sets the successive approximation register to 200h (the approximate halfway point of a 10-bit register). This register is then updated automatically during each conversion step. The successive approximation block performs 10-bit conversions for one input channel at a time. Different channels can be dynamically selected by manipulating the channel selection bit value (ADCON.6–.4) in the ADCON Register. To start the A/D conversion, set the start bit, ADCON.0. When a conversion is completed, ADCON.3, the end-of-conversion (EOC) bit, is automatically set to 1, and the result is dumped into the ADDATAH/ADDATAL registers (see Tables 77 and 78 on page 282), where it can be read. The A/D converter then enters an idle state. Remember to read the contents of ADDATAH/ADDATAL before another conversion starts; otherwise, the previous result will be overwritten by the next conversion result.





klod In LH

**Note:** Because the A/D converter has no sample-and-hold circuitry, it is very important that fluctuation in the analog level at the AD0–AD7 input pins during a conversion procedure be kept to an absolute minimum. Any change in the input level, perhaps due to noise, will invalidate the result. If the chip enters the STOP or IDLE modes in this conversion process, there will be a leakage current path in the A/D block. Therefore, use the STOP or IDLE modes after ADC operation is finished.

#### **Conversion Timing**

The A/D conversion process requires four steps (i.e., 4 clock edges) to convert each bit and 10 clocks to set up an A/D conversion. Therefore, total of 50 clocks are required to complete a 10-bit conversion: When  $f_{XX}/8$  is selected for conversion clock with an 8MHz  $f_{XX}$  clock frequency, one clock cycle is 1µs.

Each bit conversion requires 4 clocks; the conversion rate is calculated as follows:

4 clocks/bit x 10 bits + set-up time = 50 clocks

50 clocks x  $1\mu s = 50\mu s$  at 1MHz

#### A/D Converter Control Register

The A/D Converter Control (ADCON) Register, shown in Table 76, is located at address D2h in Set1, Bank0, and provides the following functions:

- Analog input pin selection (ADCON.6–.4)
- End-of-conversion status detection (ADCON.3)
- ADC clock selection (ADCON.2–.1)
- A/D operation start or disable (ADCON.0)

After a reset, the start bit is turned off; only one analog input channel at a time can be selected. Other analog input pins (AD0–AD7) can be selected dynamically by manipulating the ADCON.4–.6 bits; analog input pins that remain unused can be used for normal I/O functions.





#### Table 76. A/D Converter Control Register (ADCON; Set1, Bank0)

| Bit            | 7                                                                                                                 | 6                         | 5           | 4            | 3         | 2      | 1   | 0   |
|----------------|-------------------------------------------------------------------------------------------------------------------|---------------------------|-------------|--------------|-----------|--------|-----|-----|
| Reset          | 0                                                                                                                 | 0                         | 0           | 0            | 0         | 0      | 0   | 0   |
| R/W            | R/W                                                                                                               | R/W                       | R/W         | R/W          | R         | R/W    | R/W | R/W |
| Address        |                                                                                                                   |                           |             | D2           | 2h        |        |     |     |
| Mode           |                                                                                                                   |                           | Reg         | ister Addres | sing Mode | e only |     |     |
| Note: R = real | ad only; R/W = r                                                                                                  | ead/write.                |             |              |           |        |     |     |
| Bit            | Descriptio                                                                                                        | on                        |             |              |           |        |     |     |
| [7]            | Reserved;                                                                                                         | Always L                  | ogic 0      |              |           |        |     |     |
| [6:4]          | 000: AD0.<br>001: AD1.<br>010: AD2.<br>011: AD3.<br>100: AD4.<br>101: AD5.<br>110: AD6.<br>111: AD7.<br>End-of-Co | Pin Select                | Bit (Read C | Dnly)        |           |        |     |     |
| [0.4]          | 1: Convers                                                                                                        | ion not con<br>ion comple | te.         |              |           |        |     |     |
| [2:1]          | 00: f <sub>XX</sub> /16.<br>01: f <sub>XX</sub> /8.<br>10: f <sub>XX</sub> /4.<br>11: f <sub>XX</sub> /1.         | ince Select               | ION BITS    |              |           |        |     |     |
| [0]            | Start or Di<br>0: Disable<br>1: Start ope                                                                         | operation.                |             |              |           |        |     |     |



## A/D Converter Data Registers

The contents of the A/D Converter Data High and Low Byte (ADDATAH/ADDATAL) Register are shown in Tables 77 and 78.

| Bank0)         |               | Table 77. A | /D Conver | ter Data Hi  | gh Byte Re | egister (AD | DATAH; Se | et1, |
|----------------|---------------|-------------|-----------|--------------|------------|-------------|-----------|------|
| Bit            | 7             | 6           | 5         | 4            | 3          | 2           | 1         | 0    |
| Reset          | 0             | 0           | 0         | 0            | 0          | 0           | 0         | 0    |
| R/W            | R             | R           | R         | R            | R          | R           | R         | R    |
| Address        |               |             |           | D            | 0h         |             |           |      |
| Mode           |               |             | Reg       | ister Addres | ssing Mode | only        |           |      |
| Note: R = read | only; R/W = r | ead/write.  |           |              |            |             |           |      |

Table 78. A/D Converter Control Register (ADDATAL; Set1, Bank0)

| Bit            | 7             | 6          | 5   | 4            | 3          | 2    | 1 | 0 |
|----------------|---------------|------------|-----|--------------|------------|------|---|---|
| Reset          | 0             | 0          | 0   | 0            | 0          | 0    | 0 | 0 |
| R/W            | R             | R          | R   | R            | R          | R    | R | R |
| Address        |               |            |     | D            | 1h         |      |   |   |
| Mode           |               |            | Reg | ister Addres | ssing Mode | only |   |   |
| Note: R = read | only; R/W = r | ead/write. |     |              | -          | -    |   |   |

#### **Internal Reference Voltage Levels**

In the ADC function block, the analog input voltage level is compared to the reference voltage. This voltage level must remain within the  $V_{SS}$ -to- $AV_{REF}$  range; usually,  $AV_{REF} \leq V_{DD}$ .

Different reference voltage levels are generated internally along the resistor tree during the analog conversion process for each conversion step. The reference voltage level for the first conversion bit is always  $1/2 \text{ AV}_{\text{REF}}$ .





Figure 96 presents a block diagram of the A/D Converter function.

Figure 96. A/D Converter Functional Block Diagram





Figure 97 presents a diagram of the recommended A/D Converter circuit.

Figure 97. Recommended A/D Converter Circuit for Highest Absolute Accuracy

#### S3F8S5A Product Specification



285

## Serial I/O Interface

The serial I/O (SIO) module can interface with various types of external devices that require serial data transfers. The components of each SIO function block are:

- 8-bit control register (SIOCON)
- Clock selector logic
- 8-bit data buffer (SIODATA)
- 8-bit prescaler (SIOPS)
- 3-bit serial clock counter
- Serial data I/O pins (SI, SO)
- Serial clock input/output pins (SCK)

The SIO module can transmit or receive 8-bit serial data at a frequency determined by its corresponding control register settings. To ensure flexible data transmission rates, you can select an internal or external clock source.

## **Programming Procedure**

To program the SIO modules, observe the following basic steps:

- 1. Configure the I/O pins at port (SO, SCK, SI) by loading the appropriate value to the P2CONH and P2CONL registers, if necessary.
- 2. Load an 8-bit value to the SIOCON Control Register to properly configure the serial I/O module. In this operation, SIOCON.2 must be set to 1 to enable the data shifter.
- 3. For interrupt generation, set the serial I/O interrupt enable bit (SIOCON.1) to 1.
- 4. When transmitting data to the serial buffer, write data to SIODATA and set SIOCON.3 to 1; the shift operation starts.
- 5. When the shift operation (transmit/receive) is completed, the SIO pending bit (SIO-CON.0) is set to 1 and an SIO interrupt request is generated.

## **SIO Control Register**

The control register for the serial I/O interface module, SIOCON, shown in Table 79, is located at E7h in Set1, Bank0. This register provides the following control settings for the SIO module:





- Clock source selection (internal or external) for shift clock
- Interrupt enable
- Edge selection for shift operation
- Clear 3-bit counter and start shift operation
- Shift operation (transmit) enable
- Mode selection (transmit/receive or receive-only)
- Data direction selection (MSB-first or LSB-first)

#### Table 79. SIO Control Register (SIOCON; Set1, Bank0)

| Bit          | 7                                       | 6                                        | 5                                            | 4             | 3          | 2    | 1   | 0   |
|--------------|-----------------------------------------|------------------------------------------|----------------------------------------------|---------------|------------|------|-----|-----|
| Reset        | 0                                       | 0                                        | <b>3</b><br>0                                | <b>4</b><br>0 | 0          | 0    | 0   | 0   |
|              |                                         |                                          |                                              |               |            |      |     |     |
| R/W          | R/W                                     | R/W                                      | R/W                                          | R/W           | R/W        | R/W  | R/W | R/W |
| Address      |                                         |                                          |                                              |               | 7h         |      |     |     |
| Mode         |                                         |                                          | Reg                                          | ister Addre   | ssing Mode | only |     |     |
| Note: R = re | ad only; R/W = r                        | ead/write.                               |                                              |               |            |      |     |     |
| Bit          | Descriptio                              | on                                       |                                              |               |            |      |     |     |
| [7]          | 0: Internal                             | Clock Sele<br>clock (P.S<br>l clock (SCI | clock).                                      |               |            |      |     |     |
| [6]          | Data Direc<br>0: MSB-Fir<br>1: LSB-Firs |                                          | ol Bit                                       |               |            |      |     |     |
| [5]          | 0: Receive                              | Selection<br>-Only Mode<br>t/Receive M   | Э.                                           |               |            |      |     |     |
| [4]          | 0: Tx at fal                            | • •                                      | lection Bit<br>Rx at rising<br>Rx at falling |               |            |      |     |     |
| [3]          | 0: No actio                             | n.                                       | nd Shift St<br>and start sl                  |               |            |      |     |     |
| [2]          | 0: Disable                              | shifter and                              | Enable Bit<br>clock coun<br>clock count      | ter.          |            |      |     |     |

S3F8S5A Product Specification



287

| Bit | Description (Continued)                                                                                                                   |
|-----|-------------------------------------------------------------------------------------------------------------------------------------------|
| [1] | SIO Interrupt Enable Bit<br>0: Disable SIO interrupt.<br>1: Enable SIO interrupt.                                                         |
| [0] | <b>SIO Interrupt Pending Bit</b><br>0: No interrupt is pending when read; clear pending condition when write.<br>1: Interrupt is pending. |

A reset clears the SIOCON value to 00h, thereby configuring the corresponding module with an internal clock source at the SCK, selecting a receive-only operating mode, and clearing the 3-bit counter. The data shift operation and the interrupt are disabled. The selected data direction is MSB-first.

#### **SIO Prescaler Register**

The control register for the serial I/O interface module, SIOPS, is located at E9h in Set1, Bank0. The value stored in this SIOPS Register lets you determine the SIO clock rate (baud rate) as follows:

Baud rate = Input clock ( $f_{XX}/4$ )/(Prescaler value + 1), or SCK input clock, in which the input clock is  $f_{XX}/4$ 

The contents of the SIO Prescaler (SIOPS) Register are shown in Table 80.

| Bit           | 7                | 6                                         | 5   | 4            | 3          | 2    | 1   | 0   |
|---------------|------------------|-------------------------------------------|-----|--------------|------------|------|-----|-----|
| Reset         | 0                | 0                                         | 0   | 0            | 0          | 0    | 0   | 0   |
| R/W           | R/W              | R/W                                       | R/W | R/W          | R/W        | R/W  | R/W | R/W |
| Address       |                  |                                           |     | E            | 9h         |      |     |     |
| Mode          |                  |                                           | Reg | ister Addres | ssing Mode | only |     |     |
| Note: R = rea | ad only; R/W = r | ead/write.                                |     |              |            |      |     |     |
| Bit           | Descriptio       | on                                        |     |              |            |      |     |     |
| [7:0]         |                  | aler Config<br>= (f <sub>XX</sub> /4)/(\$ |     | ts           |            |      |     |     |

#### Table 80. SIO Prescaler Register (SIOPS; Set1, Bank0)



Figure 98 presents a block diagram of the SIO function.



Figure 98. SIO Functional Block Diagram

## **SIO Serial Timing**

Figure 99 presents a timing diagrams for Transmit/Receive Mode operation at the falling edge.









Figure 100 presents a timing diagrams for Transmit/Receive Mode operation at the falling edge.





S3F8S5A Product Specification



#### 290

## UART0

The UARTO block features a full-duplex serial port with the following four programmable operating modes – one synchronous mode and three Universal Asynchronous Receiver/ Transmitter (UART) modes:

- Serial I/O with baud rate of  $f_U/(16 \times (BRDATA0+1))$
- 8-bit UART Mode; variable baud rate
- 9-bit UART Mode; f<sub>U</sub>/16
- 9-bit UART Mode, variable baud rate

The UART0 receive and transmit buffers are both accessed via the UDATA0 Data Register, and are located in Set1, Bank0 at address F0h. Writing to the UART data register loads the transmit buffer; reading the UART0 data register accesses a physically separate receive buffer.

When accessing a receive data buffer (i.e., the shift register), reception of the next byte can begin before the previously received byte has been read from the receive register. However, if the first byte has not been read by the time the next byte has been completely received, one of the bytes will be lost.

In all operating modes, transmission begins when any instruction (usually a write operation) uses the UDATA0 Register as its destination address. In Mode 0, serial data reception starts when the receive interrupt pending bit (UART0CONH.0) is 0 and the receive enable bit (UART0CONH.4) is 1. In modes 1, 2, and 3, reception starts whenever an incoming start bit (0) is received and the receive enable bit (UART0CONH.4) is set to 1.

## **Programming Procedure**

To program the UART0 modules, observe the following basic steps:

- 1. Configure P2.6 and P2.7 to alternative function (RxD0 (P2.6), TxD0 (P2.7)) for the UART0 module by setting the P2CONH Register to the appropriate value.
- 2. Load an 8-bit value to the UART0CONH/UART0CONL control registers to properly configure the UART0 I/O module.
- 3. For interrupt generation, set the UART0 I/O interrupt enable bit (UART0CONH.1 or UART0CONL.1) to 1.
- 4. When you transmit data to the UART0 buffer, the data is written to UDATA0, and the shift operation starts.





5. When the shift operation (receive/transmit) is completed, the UART0 pending bit (UART0CONH.0 or UART0CONL.0) is set to 1 and a UART0 interrupt request is generated.

## **UART0 High-Byte Control Register**

The high-byte control register for UART0 is called UART0CONH, and is shown in Table 81. The UART0CONH Register is located at Set1, Bank0 at address EEh, and provides the following control functions:

- Operating mode and baud rate selection
- Multiprocessor communication and interrupt control
- Serial receive enable/disable control
- 9th data bit location for transmit and receive operations (modes 2 and 3 only)
- UART0 receive interrupt control

A reset clears the UART0CONH value to 00h. Therefore, to use the UART0 module, write the appropriate value to UART0CONH.

#### Table 81. UART0 Control High Byte Register (UART0CONH; Set1,

| Bit     | 7 | 6 | 5   | 4            | 3          | 2    | 1 | 0 |
|---------|---|---|-----|--------------|------------|------|---|---|
| Reset   | 0 | 0 | 0   | 0            | 0          | 0    | 0 | 0 |
| R/W     |   |   |     | R/           | W          |      |   |   |
| Address |   |   |     | El           | Ξh         |      |   |   |
| Mode    |   |   | Reg | ister Addres | ssing Mode | only |   |   |

PS032303-0314

Bank0)

S3F8S5A Product Specification



292

| Bit              | Description                                                                                                                                                                                                                                                      |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:6]<br>MS1:MS0 | UART0 Mode Selection Bits <sup>1</sup><br>00: Mode 0: Shift Register ( $f_U$ /(16 x (BRDATA0 + 1))).<br>01: Mode 1: 8-bit UART ( $f_U$ /(16 x (BRDATA0 + 1))).<br>10: Mode 2: 9-bit UART ( $f_U$ /16).<br>11: Mode 3: 9-bit UART ( $f_U$ /(16 x (BRDATA0 + 1))). |
| [5]              | Multiprocessor Communication Enable Bit (modes 2 and 3 only) <sup>2</sup><br>0: Disable.<br>1: Enable.                                                                                                                                                           |
| [4]              | <b>Serial Data Receive Enable Bit</b><br>0: Disable.<br>1: Enable.                                                                                                                                                                                               |
| [3]              | <b>TB8 (only when UART0CONL.7 = 0)</b> <sup>3</sup><br>Location of the 9th data bit to be transmitted in UART0 Mode 2 or 3 (i.e., 0 or 1).                                                                                                                       |
| [2]              | <b>RB8 (only when UART0CONL.7 = 0)<sup>3</sup></b><br>Location of the 9th data bit to be received in UART0 Mode 2 or 3 (i.e., 0 or 1).                                                                                                                           |
| [1]              | UART0 Receive Interrupt Enable Bit<br>0: Disable Rx interrupt.<br>1: Enable Rx interrupt.                                                                                                                                                                        |
| [0]              | <b>UART0 Receive Interrupt Pending Bit</b><br>0: No interrupt pending (when read); clear pending bit (when write).<br>1: Interrupt is pending (when read).                                                                                                       |
| and trans        | criptions for the 8-bit and 9-bit UART modes do not include start and stop bits for the serial data receive smit operations.                                                                                                                                     |

In modes 2 and 3, if the MCE bit is set to 1, then the receive interrupt will not be activated if the received 9th data bit is 0. In mode 1, if MCE = 1, then the receive interrupt will not be activated if a valid stop bit was not received. In Mode 0, the MCE bit should be 0.

3. If UART0CONL.7 = 1, this bit is a *don't care*.

## **UART0 Low-Byte Control Register**

The low-byte control register for UART0 is called UART0CONL, and is shown in Table 82. The UART0CONL Register is located at Set1, Bank0 at address EFh, and provides the following control functions:

- UART0 transmit and receive parity-bit selection
- UART0 clock selection
- UART0 transmit interrupt control

A reset clears the UART0CONL value to 00h. Therefore, to use UART0 module, write the appropriate value to UART0CONL.

#### S3F8S5A Product Specification



293





#### Table 82. UART0 Control Low Byte Register (UART0CONL; Set1,

Bank0)

| Bit     | 7 | 6 | 5   | 4           | 3          | 2    | 1 | 0 |
|---------|---|---|-----|-------------|------------|------|---|---|
| Reset   | 0 | 0 | 0   | 0           | 0          | 0    | 0 | 0 |
| R/W     |   |   |     | R/          | W          |      |   |   |
| Address |   |   |     | El          |            |      |   |   |
| Mode    |   |   | Reg | ster Addres | ssing Mode | only |   |   |

Note: R = read only; R/W = read/write.

| Bit   | Description                                                                       |
|-------|-----------------------------------------------------------------------------------|
| [7]   | UART0 Transmit Parity Autogeneration Enable Bit (modes 2 and 3 only) <sup>1</sup> |
|       | 0: Disable parity bit autogeneration.                                             |
|       | 1: Enable parity bit autogeneration.                                              |
| [6]   | UART0 Transmit Parity Selection Bit (modes 2 and 3 only) <sup>1,2</sup>           |
|       | 0: Even parity bit.                                                               |
|       | 1: Odd parity bit.                                                                |
| [5]   | UART0 Receive Parity Selection Bit (modes 2 and 3 only) <sup>1,2</sup>            |
|       | 0: Even parity bit check.                                                         |
|       | 1: Odd parity bit check.                                                          |
| [4]   | UART0 Receive Parity Error Status Bit (modes 2 and 3 only) <sup>1,2</sup>         |
|       | 0: No parity bit error.                                                           |
|       | 1: Parity bit error.                                                              |
| [3:2] | UART0 Clock Selection Bits                                                        |
|       | 00: f <sub>XX</sub> /8.                                                           |
|       | 01: f <sub>XX</sub> /4.                                                           |
|       | 10: f <sub>XX</sub> /2.                                                           |
|       | 11: f <sub>XX</sub> /1.                                                           |
| [1]   | UART0 Transmit Interrupt Enable Bit                                               |
| TIE   | 0: Disable Tx interrupt.                                                          |
|       | 1: Enable Tx interrupt.                                                           |
| [0]   | UART0 Transmit Interrupt Pending Bit                                              |
| TIP   | 0: No interrupt pending (when read); clear pending bit (when write).              |
|       | 1: Interrupt is pending (when read).                                              |

2. If UART0CONL.7 = 0, this bit is a *don't care*.

#### **UART0 Interrupt Pending bits**

In Mode 0, the receive interrupt pending bit, UART0CONH.0, is set to 1 when the 8th receive data bit has been shifted. In Mode 1, the UART0CONH.0 bit is set to 1 at the half-way point of the stop bit's shift time. In modes 2 or 3, the UART0CONH.0 bit is set to 1 at



the halfway point of the RB8 bit's shift time. When the CPU has acknowledged the receive interrupt pending condition, the UART0CONH.0 bit must then be cleared by software in the interrupt service routine.

In Mode 0, the transmit interrupt pending bit UART0CONL.0 is set to 1 when the 8th transmit data bit has been shifted. In modes 1, 2, or 3, the UART0CONL.0 bit is set at the start of the stop bit. When the CPU has acknowledged the transmit interrupt pending condition, the UART0CONL.0 bit must then be cleared by software in the interrupt service routine.

## **UARTO Data Register**

The UART0 Data (UDATA0) Register is shown in Table 83.

#### Table 83. UART0 Data Register (UDATA0; Set1, Bank0)

| Bit          | 7                                      | 6         | 5     | 4 | 3  | 2 | 1 | 0 |
|--------------|----------------------------------------|-----------|-------|---|----|---|---|---|
| Reset        | 0                                      | 0         | 0     | 0 | 0  | 0 | 0 | 0 |
| R/W          |                                        |           |       | R | /W |   |   |   |
| Address      |                                        |           |       | F | 0h |   |   |   |
| Mode         | Register Addressing Mode only          |           |       |   |    |   |   |   |
| Note: R = re | ead only; R/W = re                     | ad/write. |       |   |    |   |   |   |
| Bit          | Descriptio                             | n         |       |   |    |   |   |   |
| [7:0]        | UART0 Data Register Configuration Bits |           |       |   |    |   |   |   |
|              | Transmit or                            | Receive d | lata. |   |    |   |   |   |

#### **UARTO Baud Rate Data Register**

The value stored in the UARTO Baud Rate Data (BRDATA0) Register, shown in Table 84, lets you determine the UARTO clock rate (baud rate).

#### Table 84. UART0 Baud Rate Data Register (BRDATA0; Set1, Bank0)

| Bit            | 7                             | 6          | 5   | 4 | 3        | 2   | 1 | 0 |
|----------------|-------------------------------|------------|-----|---|----------|-----|---|---|
| Reset          | 0                             | 0          | 0   | 0 | 0        | 0   | 0 | 0 |
| R/W            |                               |            |     | R | W        |     |   |   |
| Address        | F1h                           |            |     |   |          |     |   |   |
| Mode           | Register Addressing Mode only |            |     |   |          |     |   |   |
| Note: R = read | only; R/W = r                 | ead/write. | - 0 |   | <b>J</b> | - , |   |   |





d In Life

| Bit   | Description                                                                   |
|-------|-------------------------------------------------------------------------------|
| [7:0] | UART0 Baud Rate Data Register Configuration Bits<br>Transmit or Receive data. |

#### **UART0 Baud Rate Calculations**

Baud rate calculations for UART0 modes 0 to 3 are described in this section.

#### Mode 0 Baud Rate Calculation

In Mode 0, the baud rate is determined by the UART0 Baud Rate Data (BRDATA0) Register, which is located at Set1, Bank0 at address F1h. The calculation for this baud rate is:

Mode 0 baud rate =  $f_U/(16 \times (BRDATA0 + 1))$ 

#### Mode 2 Baud Rate Calculation

The baud rate in Mode 2 is fixed at the  $f_U$  clock frequency divided by 16, as follows:

Mode 2 baud rate =  $f_U/16$ 

#### Modes 1 and 3 Baud Rate Calculation

In modes 1 and 3, the baud rate is determined by the UARTO Baud Rate Data (BRDATA0) Register, which is located at Set1, Bank0 at address F1h. The calculation for this baud rate is:

Mode 1 and 3 baud rate =  $f_U/(16 \times (BRDATA0 + 1))$ 

Table 85 presents a matrix of commonly used baud rates generated by BRDATA0.

Zilog Embedded in Life An DXYS Company

297

|        |           |                              | BRDATA0 |             |  |
|--------|-----------|------------------------------|---------|-------------|--|
| Mode   | Baud Rate | UART Clock (f <sub>U</sub> ) | Decimal | Hexadecimal |  |
| Mode 2 | 0.5 MHz   | 8MHz                         | Х       | х           |  |
|        | 230,400Hz | 11.0592MHz                   | 02      | 02h         |  |
|        | 115,200Hz | 11.0592 MHz                  | 05      | 05h         |  |
|        | 57,600Hz  | 11.0592 MHz                  | 11      | 0Bh         |  |
|        | 38,400Hz  | 11.0592MHz                   | 17      | 11h         |  |
|        | 19,200Hz  | 11.0592MHz                   | 35      | 23h         |  |
| Mode 0 | 9,600Hz   | 11.0592MHz                   | 71      | 47h         |  |
| Mode 1 | 4,800Hz   | 11.0592MHz                   | 143     | 8Fh         |  |
| Mode 3 | 62,500Hz  | 10MHz                        | 09      | 09h         |  |
|        | 9,615Hz   | 10MHz                        | 64      | 40h         |  |
|        | 38,461 Hz | 8MHz                         | 12      | 0Ch         |  |
|        | 12,500Hz  | 8MHz                         | 39      | 27h         |  |
|        | 19,230Hz  | 4MHz                         | 12      | 0Ch         |  |
|        | 9,615Hz   | 4MHz                         | 25      | 19h         |  |

#### Table 85. Commonly Used Baud Rates Generated by BRDATA0

Figure 101 presents a block diagram of the UART0 function.







Figure 101. UART0 Functional Block Diagram

### **UART0 Mode 0 Function Description**

In Mode 0, UART0 is input and output through the RxD0 (P2.6) pin, and the TxD0 (P2.7) pin outputs the shift clock. Data is transmitted or received in 8-bit units only. The LSB of the 8-bit value is transmitted (or received) first.





#### **Mode 0 Transmit Procedure**

Observe the following procedure to write transmission data via UART0 in Mode 0.

- 1. Select the UART0 clock, UART0CONL.3 and .2.
- 2. Clear the UART0 transmit parity-bit autogeneration enable bit, UART0CONL.7.
- 3. Select Mode 0 by setting UART0CONH.7 and .6 to 00b.
- 4. Write the transmission data to the UDATA0 Shift Register (F0h, Set1, Bank0) to start the transmission operation.

#### Mode 0 Receive Procedure

Observe the following procedure to read receive data via UART0 in Mode 0.

- 1. Select the UART0 clock, UART0CONL.3 and .2.
- 2. Clear the UART0 transmit parity-bit autogeneration enable bit, UART0CONL.7.
- 3. Select Mode 0 by setting UART0CONH.7 and .6 to 00b.
- 4. Clear the receive interrupt pending bit, UART0CONH.0, by writing a 0 to UART0CONH.0.
- 5. Set the UART0 receive enable bit, UART0CONH.4, to 1.
- 6. The shift clock will now be output to the TxD0 (P2.7) pin and will read the data at the RxD0 (P2.6) pin. A UART0 receive interrupt occurs when UART0CONH.1 is set to 1.

Figure 102 shows the timing of the Serial Port Mode 0 operation.





| Write to Shift Register (UDATA0)                                                                        |          |
|---------------------------------------------------------------------------------------------------------|----------|
| Shift                                                                                                   |          |
| RxD0 (Data Out)         D0         D1         D2         D3         D4         D5         D6         D7 | Transmit |
| TxD0 (Shift Clock)                                                                                      | Ļ        |
| TIP                                                                                                     |          |
| Clear RIP and set RE                                                                                    |          |
| RIP                                                                                                     |          |
| RE                                                                                                      | -        |
| Shift                                                                                                   | Receive  |
| RxD0 (Data In)                                                                                          |          |
| TxD0 (Shift Clock)       1       2       3       4       5       6       7       8                      |          |

Figure 102. UART0 Serial Port Mode 0 Timing

#### **Serial Port Mode 1 Function Description**

In Mode 1, 10 bits are transmitted through the TxD0 (P2.7) pin or received through the RxD0 (P2.6) pin. Each data frame provides three components:

- Start bit (0)
- 8 data bits (LSB first)
- Stop bit (1)

The baud rate for Mode 1 is variable.

#### Mode 1 Transmit Procedure

Observe the following procedure to write transmission data via UART0 in Mode 1.





- 1. Select the UART0 clock, UART0CONL.3 and .2.
- 2. Clear the UART0 transmit parity-bit autogeneration enable bit (UART0CONL.7).
- 3. Select the baud rate to be generated by BRDATA0.
- 4. Select Mode 1 (8-bit UART) by setting UARTOCONH bits 7 and 6 to 01b.
- 5. Write transmission data to the UDATA0 Shift Register (F0h, Set1, Bank0). The start and stop bits are generated automatically by hardware.

#### **Mode 1 Receive Procedure**

Observe the following procedure to read receive data via UART0 in Mode 1.

- 1. Select the UART0 clock, UART0CONL.3 and .2.
- 2. Clear the UART0 transmit parity-bit autogeneration enable bit, UART0CONL.7.
- 3. Select the baud rate to be generated by BRDATA0.
- 4. Select Mode 1 and set the Receive Enable (RE) bit in the UARTOCONH Register to 1.
- 5. The start bit Low (0) condition at the RxD0 (P2.6) pin will cause the UART0 module to start the serial data receive operation.

Figure 103 shows the timing of the Serial Port Mode 1 operation.

| Write to Shift Register (UDATA0)                                                                                                |          |
|---------------------------------------------------------------------------------------------------------------------------------|----------|
| Shift                                                                                                                           | iž       |
| TxD0         Start Bit         D0         D1         D2         D3         D4         D5         D6         D7         Stop Bit | Transmit |
| TIP                                                                                                                             | —— F     |
|                                                                                                                                 |          |
|                                                                                                                                 |          |
| RxD0         Start Bit         D0         D1         D2         D3         D4         D5         D6         D7         St       | top Bit  |
|                                                                                                                                 |          |
| Shift                                                                                                                           | Receive  |
| RIP                                                                                                                             | œ        |

Figure 103. UART0 Serial Port Mode 1 Timing





### **Serial Port Mode 2 Function Description**

In Mode 2, 11 bits are transmitted through the TxD0 (P2.7) pin or received through the RxD0 (P2.6) pin. Each data frame features the following four components:

- Start bit (0)
- 8 data bits (LSB first)
- Programmable 9th data bit
- Stop bit (1)

The 9th data bit to be transmitted can be assigned a value of 0 or 1 by writing the TB8 bit, UART0CONH.3. When receiving, the 9th data bit that is received is written to the RB8 bit, UART0CONH.2, while the stop bit is ignored. The baud rate for mode 2 is  $f_U/16$  clock frequency.

#### **Mode 2 Transmit Procedure**

Observe the following procedure to write transmission data via UART0 in Mode 2.

- 1. Select the UART0 clock, UART0CONL.3 and .2.
- 2. Select the UART0 transmit parity-bit autogeneration enable or disable (UART0CONL.7).
- 3. Select Mode 2 (9-bit UART) by setting UART0CONH bits 7 and 6 to 10b. Additionally, select the 9th data bit to be transmitted by writing TB8 to 0 or 1.
- 4. Write the transmission data to the UDATA0 Shift Register (F0h, Set1, Bank0) to start the transmit operation.

#### **Mode 2 Receive Procedure**

Observe the following procedure to read receive data via UART0 in Mode 2.

- 1. Select the UART0 clock, UART0CONL.3 and .2.
- 2. Select the UART0 transmit parity-bit autogeneration enable or disable (UART0CONL.7).
- 3. Select Mode 2 and set the receive enable bit (RE) in the UARTOCONH Register to 1.
- 4. The receive operation starts when the signal at the RxD0 (P2.6) pin goes Low.

Figure 104 shows the timing of the Serial Port Mode 2 operation.



**S3F8S5A** 

n DXYS Company

0 g

303

**Product Specification** 

Figure 104. UART0 Serial Port Mode 2 Timing

#### **Serial Port Mode 3 Function Description**

In Mode 3, 11 bits are transmitted through the TxD0 (P2.7) pin or received through the RxD0 (P2.6) pin. Mode 3 is identical to Mode 2 except for the baud rate, which is variable. Each data frame features the following four components:

- Start bit (0)
- 8 data bits (LSB first)
- Programmable 9th data bit
- Stop bit (1)

#### **Mode 3 Transmit Procedure**

Observe the following procedure to write transmission data via UART0 in Mode 3.

- 1. Select the UART0 clock, UART0CONL.3 and .2.
- 2. Select the UART0 transmit parity-bit autogeneration enable or disable (UART0CONL.7).



TXYS Company



- 3. Select Mode 3 operation (9-bit UART) by setting UART0CONH bits 7 and 6 to 11b. Additionally, select the 9th data bit to be transmitted by writing UART0CONH.3 (TB8) to 0 or 1.
- 4. Write transmission data to the UDATA0 Shift Register (F0h, Set1, Bank0), to start the transmit operation.

#### **Mode 3 Receive Procedure**

Observe the following procedure to read receive data via UART0 in Mode 3.

- 1. Select the UART0 clock, UART0CONL.3 and .2.
- 2. Select the UART0 transmit parity-bit autogeneration enable or disable (UART0CONL.7).
- 3. Select Mode 3 and set the Receive Enable (RE) bit in the UARTOCONH Register to 1.
- 4. The receive operation will be started when the signal at the RxD0 (P2.6) pin goes Low.

Figure 105 shows the timing of the Serial Port Mode 3 operation.

| Write to Shift Register | (UDATA0) |        |      |      |      |      |         |          |             |
|-------------------------|----------|--------|------|------|------|------|---------|----------|-------------|
| Shift                   |          |        |      | Γ    |      |      | <u></u> | Γ        | ji —        |
| TxD0 Start Bit D0       |          | 2 D3   | D4   | D5   | D6   | D7   | ТВ8     | Stop Bit | Transmit    |
| TIP                     |          |        |      |      |      |      |         |          | — F         |
|                         |          |        | ſ    | ſ    | ſ    | ſ    | ſ       |          |             |
| RxD0 Start Bit          | / D0 X D | 1 X D2 | Х D3 | X D4 | X D5 | X D6 | X D7    | X RB8 /S | Stop<br>Bit |
| Bit Detect Sample Time  |          |        |      |      |      |      |         |          |             |
| Shift                   |          |        |      |      |      |      |         |          | <br>Receive |
| RIP                     |          |        |      |      |      |      |         |          | ¥           |

Figure 105. UART0 Serial Port Mode 3 Timing



### **Serial Communication for Multiprocessor Configurations**

The S3F8 Series multiprocessor communication features lets a *master* S3F8S5A MCU send a multiple-frame serial message to a *slave* device in a multi-S3F8S5A configuration without interrupting other slave devices that may be on the same serial line. This feature can be used only in UART modes 2 or 3. In these two modes, 9 data bits are received. The 9th bit value is written to RB8 (UART0CONH.2). The data receive operation is concluded with a stop bit. This function can be programmed such that when the stop bit is received, the serial interrupt will be generated only if RB8 = 1.

To enable this feature, set the MCE bit in the UART0CONH Register. When the MCE bit is 1, serial data frames that are received with the 9th bit = 0 do not generate an interrupt. In this case, the 9th bit simply separates the address from the serial data.

#### **Sample Protocol for Master/Slave Interaction**

When the master device transmits a block of data to one of several slaves on a serial line, it first sends out an address byte to identify the target slave. Note that in this case, an address byte differs from a data byte; in an address byte, the 9th bit is 1, and in a data byte, it is 0.

The address byte interrupts all slaves so that each slave can examine the received byte and determine if it is being addressed. The addressed slave then clears its MCE bit and prepares to receive incoming data bytes.

The MCE bits of slaves that were not addressed remain set, and they continue operating normally while ignoring the incoming data bytes.

While the MCE bit setting has no effect in Mode 0, it can be used in Mode 1 to check the validity of the stop bit. For Mode 1 reception, if MCE is 1, the receive interrupt will be issue unless a valid stop bit is received.

#### **Setup Procedure for Multiprocessor Communications**

Observe the following steps to configure multiprocessor communications.

- 1. Set all S3F8S5A devices (masters and slaves) to UART0 Mode 2 or 3.
- 2. Write the MCE bit of all the slave devices to 1.
- 3. The master device's transmission protocol is:
  - First byte: the address identifying the target slave device (9th bit = 1)
  - Next bytes: data (9th bit = 0)



n DXYS Company

306

4. When the target slave receives the first byte, all of the slaves are interrupted because the 9th data bit is 1. The targeted slave compares the address byte to its own address and then clears its MCE bit to receive incoming data. The other slaves continue operating normally.

Figure 106 shows an example of multiprocessor serial data communications.



Full-Duplex Multi-S3F8S5A Interconnect

#### Figure 106. UART0 Multiprocessor Serial Data Communications Example

S3F8S5A Product Specification



307

# UART1

The UART1 block features a full-duplex serial port with the following four programmable operating modes – one synchronous mode and three Universal Asynchronous Receiver/ Transmitter (UART) modes:

- Serial I/O with baud rate of  $f_U/(16 \times (BRDATA1+1))$
- 8-bit UART Mode; variable baud rate
- 9-bit UART Mode;  $f_U/16$
- 9-bit UART Mode, variable baud rate

The UART1 receive and transmit buffers are both accessed via the UDATA1 Data Register, and are located in Set1, Bank0 at address F4h. Writing to the UART1 Data Register loads the transmit buffer; reading the UART1 Data Register accesses a physically separate receive buffer.

When accessing a receive data buffer (i.e., the shift register), reception of the next byte can begin before the previously received byte has been read from the receive register. However, if the first byte has not been read by the time the next byte has been completely received, one of the bytes will be lost.

In all operating modes, transmission is started when any instruction (usually a write operation) uses the UDATA1 Register as its destination address. In Mode 0, serial data reception starts when the receive interrupt pending bit (UART1CONH.0) is 0 and the receive enable bit (UART1CONH.4) is 1. In modes 1, 2, and 3, reception starts whenever an incoming start bit (0) is received and the receive enable bit (UART1CONH.4) is set to 1.

### **Programming Procedure**

To program the UART1 modules, observe the following basic steps.

- 1. Configure P3.6 and P3.7 to alternative function (RxD1 (P3.6), TxD1 (P3.7)) for the UART1 module by setting the P3CONH Register to an appropriate value.
- 2. Load an 8-bit value to the UART1CONH/UART1CONL control registers to properly configure the UART1 I/O module.
- 3. For interrupt generation, set the UART1 I/O interrupt enable bit (UART1CONH.1 or UART1CONL.1) to 1.
- 4. When transmitting data to the UART1 buffer, write the data to UDATA1; the shift operation starts.





od In Life

TXYS Company

5. When the shift operation (receive/transmit) is completed, the UART1 pending bit (UART1CONH.0 or UART1CONL.0) is set to 1 and an UART1 interrupt request is generated.

### **UART1 High-Byte Control Register**

The control register for UART1 is called UART1CONH, and is shown in Table 86. The UART1CONH Register is located in Set1, Bank0 at address F2h, and provides the following control functions:

- Operating mode and baud rate selection
- Multiprocessor communication and interrupt control
- Serial receive enable/disable control
- 9th data bit location for transmit and receive operations (modes 2 and 3 only)
- UART1 receive interrupt control

A reset clears the UART1CONH value to 00h. Therefore, to use the UART1 module, write the appropriate value to UART1CONH.

#### Table 86. UART1 Control High Byte Register (UART1CONH; Set1,

#### Bank0)

| Bit            | 7               | 6          | 5   | 4            | 3         | 2    | 1 | 0 |  |  |
|----------------|-----------------|------------|-----|--------------|-----------|------|---|---|--|--|
| Reset          | 0               | 0          | 0   | 0            | 0         | 0    | 0 | 0 |  |  |
| R/W            | R/W             |            |     |              |           |      |   |   |  |  |
| Address        |                 | F2h        |     |              |           |      |   |   |  |  |
| Mode           |                 |            | Reg | ister Addres | sing Mode | only |   |   |  |  |
| Note: R = read | only; $R/W = r$ | ead/write. |     |              |           |      |   |   |  |  |

Bit Description UART1 Mode Selection Bits<sup>1</sup> [7:6] MS1:MS0 00: Mode 0: Shift Register ( $f_U/(16 \times (BRDATA1 + 1)))$ . 01: Mode 1: 8-bit UART (f<sub>L</sub>/(16 x (BRDATA1 + 1))). 10: Mode 2: 9-bit UART (f<sub>LI</sub>/16). 11: Mode 3: 9-bit UART (f<sub>U</sub>/(16 x (BRDATA1 + 1))). Multiprocessor Communication Enable Bit (modes 2 and 3 only)<sup>2</sup> [5] 0: Disable. 1: Enable. [4] Serial Data Receive Enable Bit 0: Disable. 1: Enable.



| Bit   | Description (Continued)                                                                                                                                    |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [3]   | <b>TB8 (only when UART1CONL.7 = 0)<sup>3</sup></b><br>Location of the 9th data bit to be transmitted in UART1 Mode 2 or 3 (i.e., 0 or 1).                  |
| [2]   | <b>RB8 (only when UART1CONL.7 = 0)<sup>3</sup></b><br>Location of the 9th data bit to be received in UART1 Mode 2 or 3 (i.e., 0 or 1).                     |
| [1]   | <b>UART1 Receive Interrupt Enable Bit</b><br>0: Disable Rx interrupt.<br>1: Enable Rx interrupt.                                                           |
| [0]   | <b>UART1 Receive Interrupt Pending Bit</b><br>0: No interrupt pending (when read); clear pending bit (when write).<br>1: Interrupt is pending (when read). |
| Mataa |                                                                                                                                                            |

Notes:

- 1. The descriptions for the 8-bit and 9-bit UART modes do not include start and stop bits for the serial data receive and transmit operations.
- In modes 2 and 3, if the MCE bit is set to 1, then the receive interrupt will not be activated if the received 9th data bit is 0. In mode 1, if MCE = 1, then the receive interrupt will not be activated if a valid stop bit was not received. In Mode 0, the MCE bit should be 0.
- 3. If UART1CONL.7 = 1, this bit is a *don't care*.

### **UART1 Low-Byte Control Register**

The control register for the UART1 is called UART1CONL, shown in Table 87. The UART1CONL Register is located in Set1, Bank0 at address F3h, and provides the following control functions:

- UART1 transmit and receive parity-bit selection
- UART1 clock selection
- UART1 transmit interrupt control

A reset clears the UART1CONL value to 00h. Therefore, to use the UART1 module, write the appropriate value to UART1CONL.





#### Table 87. UART1 Control Low Byte Register (UART1CONL; Set1,

Bank0)

| Bit     | 7   | 6 | 5   | 4            | 3         | 2    | 1 | 0 |  |
|---------|-----|---|-----|--------------|-----------|------|---|---|--|
| Reset   | 0   | 0 | 0   | 0            | 0         | 0    | 0 | 0 |  |
| R/W     | R/W |   |     |              |           |      |   |   |  |
| Address | F3h |   |     |              |           |      |   |   |  |
| Mode    |     |   | Reg | ister Addres | sing Mode | only |   |   |  |

Note: R = read only; R/W = read/write.

| Bit   | Description                                                                       |
|-------|-----------------------------------------------------------------------------------|
| [7]   | UART1 Transmit Parity Autogeneration Enable Bit (modes 2 and 3 only) <sup>1</sup> |
|       | 0: Disable parity bit autogeneration.                                             |
|       | 1: Enable parity bit autogeneration.                                              |
| [6]   | UART1 Transmit Parity Selection Bit (modes 2 and 3 only) <sup>1,2</sup>           |
|       | 0: Even parity bit.                                                               |
|       | 1: Odd parity bit.                                                                |
| [5]   | UART1 Receive Parity Selection Bit (modes 2 and 3 only) <sup>1,2</sup>            |
|       | 0: Even parity bit check.                                                         |
|       | 1: Odd parity bit check.                                                          |
| [4]   | UART1 Receive Parity Error Status Bit (modes 2 and 3 only) <sup>1,2</sup>         |
|       | 0: No parity bit error.                                                           |
|       | 1: Parity bit error.                                                              |
| [3:2] | UART1 Clock Selection Bits                                                        |
|       | 00: f <sub>XX</sub> /8.                                                           |
|       | 01: f <sub>XX</sub> /4.                                                           |
|       | 10: f <sub>XX</sub> /2.                                                           |
|       | 11: f <sub>XX</sub> /1.                                                           |
| [1]   | UART1 Transmit Interrupt Enable Bit                                               |
|       | 0: Disable Tx interrupt.                                                          |
|       | 1: Enable Tx interrupt.                                                           |
| [0]   | UART1 Transmit Interrupt Pending Bit                                              |
|       | 0: No interrupt pending (when read); clear pending bit (when write).              |
|       | 1: Interrupt is pending (when read).                                              |

2. If UART1CONL.7 = 0, this bit is a *don't care*.

### **UART1 Interrupt Pending Bits**

In Mode 0, the receive interrupt pending bit, UART0CONH.0, is set to 1 when the 8th receive data bit has been shifted. In Mode 1, the UART0CONH.0 bit is set to 1 at the half-way point of the stop bit's shift time. In modes 2 or 3, the UART0CONH.0 bit is set to 1 at

PRELIMINARY





the halfway point of the RB8 bit's shift time. When the CPU has acknowledged the receive interrupt pending condition, the UART0CONH.0 bit must then be cleared by software in the interrupt service routine.

In Mode 0, the transmit interrupt pending bit, UART1CONL.0, is set to 1 when the 8th transmit data bit has been shifted. In modes 1, 2, or 3, the UART1CONL.0 bit is set at the start of the stop bit. When the CPU has acknowledged the transmit interrupt pending condition, the UART1CONL.0 bit must then be cleared by software in the interrupt service routine.

### **UART1 Data Register**

The UART1 Data (UDATA1) Register is shown in Table 88.

#### Table 88. UART1 Data Register (UDATA1; Set1, Bank0)

| Bit          | 7                             | 6          | 5          | 4          | 3 | 2 | 1 | 0 |  |  |
|--------------|-------------------------------|------------|------------|------------|---|---|---|---|--|--|
| Reset        | 0                             | 0          | 0          | 0          | 0 | 0 | 0 | 0 |  |  |
| R/W          | R/W                           |            |            |            |   |   |   |   |  |  |
| Address      | F4h                           |            |            |            |   |   |   |   |  |  |
| Mode         | Register Addressing Mode only |            |            |            |   |   |   |   |  |  |
| Note: R = re | ad only; R/W = re             | ead/write. |            |            |   |   |   |   |  |  |
| Bit          | Descriptio                    | n          |            |            |   |   |   |   |  |  |
| [7:0]        | UART1 Da                      | ta Registe | r Configur | ation Bits |   |   |   |   |  |  |
|              | Transmit or                   | Receive d  | lata.      |            |   |   |   |   |  |  |

### **UART1 Baud Rate Data Register**

The value stored in the UART1 Baud Rate Data (BRDATA1) Register, shown in Table 89, lets you determine the UART1 clock (baud) rate.

#### Table 89. UART1 Baud Rate Data Register (BRDATA1; Set1, Bank0)

| Bit            | 7               | 6          | 5   | 4            | 3          | 2    | 1 | 0 |  |  |
|----------------|-----------------|------------|-----|--------------|------------|------|---|---|--|--|
| Reset          | 0               | 0          | 0   | 0            | 0          | 0    | 0 | 0 |  |  |
| R/W            | R/W             |            |     |              |            |      |   |   |  |  |
| Address        |                 | F5h        |     |              |            |      |   |   |  |  |
| Mode           |                 |            | Reg | ister Addres | ssing Mode | only |   |   |  |  |
| Note: R = read | only; $R/W = r$ | ead/write. |     |              |            |      |   |   |  |  |



| Description                                      |  |
|--------------------------------------------------|--|
| UART1 Baud Rate Data Register Configuration Bits |  |

### **UART1 Baud Rate Calculations**

Transmit or Receive data.

Bit

[7:0]

Baud rate calculations for UART1 modes 0 to 3 are described below.

#### Mode 0 Baud Rate Calculation

In Mode 0, the baud rate is determined by the UART1 Baud Rate Data (BRDATA1) Register, which is located at Set1, Bank0 at address F5h. The calculation for this baud rate is:

Mode 0 baud rate =  $f_U/(16 \times (BRDATA1 + 1))$ 

#### Mode 2 Baud Rate Calculation

The baud rate in Mode 2 is fixed at the  $f_U$  clock frequency divided by 16, as follows:

Mode 2 baud rate =  $f_U/16$ 

#### Modes 1 and 3 Baud Rate Calculation

In modes 1 and 3, the baud rate is determined by the UART1 Baud Rate Data (BRDATA1) Register, which is located at Set1, Bank0 at address F5h. The calculation for this baud rate is:

Mode 1 and 3 baud rate =  $f_U/(16 \times (BRDATA1 + 1))$ 

Table 90 presents a matrix of commonly used baud rates generated by BRDATA1.

Zilog Embedded In Life An DXYS Company

313

|        |           |                              | BR      | DATA1       |
|--------|-----------|------------------------------|---------|-------------|
| Mode   | Baud Rate | UART Clock (f <sub>U</sub> ) | Decimal | Hexadecimal |
| Mode 2 | 0.5 MHz   | 8MHz                         | Х       | х           |
|        | 230,400Hz | 11.0592MHz                   | 02      | 02h         |
|        | 115,200Hz | 11.0592 MHz                  | 05      | 05h         |
|        | 57,600Hz  | 11.0592 MHz                  | 11      | 0Bh         |
|        | 38,400Hz  | 11.0592MHz                   | 17      | 11h         |
|        | 19,200Hz  | 11.0592MHz                   | 35      | 23h         |
| Mode 0 | 9,600Hz   | 11.0592MHz                   | 71      | 47h         |
| Mode 1 | 4,800Hz   | 11.0592MHz                   | 143     | 8Fh         |
| Mode 3 | 62,500Hz  | 10MHz                        | 09      | 09h         |
|        | 9,615Hz   | 10MHz                        | 64      | 40h         |
|        | 38,461 Hz | 8MHz                         | 12      | 0Ch         |
|        | 12,500Hz  | 8MHz                         | 39      | 27h         |
|        | 19,230Hz  | 4MHz                         | 12      | 0Ch         |
|        | 9,615Hz   | 4MHz                         | 25      | 19h         |

#### Table 90. Commonly Used Baud Rates Generated by BRDATA1

Figure 107 presents a block diagram of the UART1 function.







Figure 107. UART1 Functional Block Diagram



### **UART1 Mode 0 Function Description**

In Mode 0, UART1 is input and output through the RxD1 (P3.6) pin, and TxD1 (P3.7) pin outputs the shift clock. Data is transmitted or received in 8-bit units only. The LSB of the 8-bit value is transmitted (or received) first.

#### Mode 0 Transmit Procedure

Observe the following procedure to write transmission data via UART1 in Mode 0.

- 1. Select the UART1 clock, UART1CONL.3 and .2.
- 2. Clear the UART1 transmit parity-bit autogeneration enable bit, UART1CONL.7.
- 3. Select Mode 0 by setting UART1CONH.7 and .6 to 00b.
- 4. Write the transmission data to the UDATA1 Shift Register (F4h, Set1, Bank0) to start the transmission operation.

#### Mode 0 Receive Procedure

Observe the following procedure to read receive data via UART1 in Mode 0.

- 1. Select the UART1 clock, UART1CONL.3 and .2.
- 2. Clear the UART1 transmit parity-bit autogeneration enable bit, UART1CONL.7.
- 3. Select Mode 0 by setting UART1CONH.7 and .6 to 00b.
- 4. Clear the receive interrupt pending bit, UART1CONH.0, by writing a 0 to UART1CONH.0.
- 5. Set the UART1 receive enable bit, UART1CONH.4, to 1.
- 6. The shift clock will now be output to the TxD1 (P3.7) pin and will read the data at the RxD1 (P3.6) pin. A UART1 receive interrupt occurs when UART1CONH.1 is set to 1.

Figure 108 shows the timing of the UART1 Serial Port Mode 0 operation.



| Write to Shift Register (UDATA1)                                                                                   |          |
|--------------------------------------------------------------------------------------------------------------------|----------|
| Shift                                                                                                              |          |
| RxD1 (Data Out)         D0         D1         D2         D3         D4         D5         D6         D7         P1 | Transmit |
| TxD1 (Shift Clock)                                                                                                 | 1        |
| TIP                                                                                                                |          |
| RIP                                                                                                                |          |
| RE                                                                                                                 |          |
| Shift                                                                                                              |          |
| RxD1 (Data In)                                                                                                     |          |
| TxD1 (Shift Clock)       1       2       3       4       5       6       7       8                                 |          |

Figure 108. UART1 Serial Port Mode 0 Timing

### **Serial Port Mode 1 Function Description**

In Mode 1, 10-bits are transmitted through the TxD1 (P3.7) pin or received through the RxD1 (P3.6) pin. Each data frame features the following three components:

- Start bit (0)
- 8 data bits (LSB first)
- Stop bit (1)

The baud rate for Mode 1 is variable.



klod In Life

#### **Mode 1 Transmit Procedure**

Observe the following procedure to write transmission data via UART1 in Mode 1.

- 1. Select the UART1 clock, UART1CONL.3 and .2.
- 2. Clear the UART1 transmit parity-bit autogeneration enable bit (UART1CONL.7).
- 3. Select the baud rate to be generated by BRDATA1.
- 4. Select Mode 1 (8-bit UART) by setting UART1CONH bits 7 and 6 to 01b.
- 5. Write transmission data to the UDATA1 Shift Register (F4h, Set1, Bank0). The start and stop bits are generated automatically by hardware.

#### **Mode 1 Receive Procedure**

Observe the following procedure to read receive data via UART1 in Mode 1.

- 1. Select the UART1 clock, UART1CONL.3 and .2.
- 2. Clear the UART1 transmit parity-bit autogeneration enable bit (UART1CONL.7).
- 3. Select the baud rate to be generated by BRDATA1.
- 4. Select Mode 1 and set the Receive Enable (RE) bit in the UART1CONH Register to 1.
- 5. The start bit low (0) condition at the RxD1 (P3.6) pin will cause the UART1 module to start the serial data receive operation.

Figure 109 shows the timing of the UART1 Serial Port Mode 10peration.



**S3F8S5A** 

n DXYS Company

318

**Product Specification** 

Figure 109. UART1 Serial Port Mode 1Timing

### **Serial Port Mode 2 Function Description**

In Mode 2, 11 bits are transmitted through the TxD1 (P3.7) pin. Each data frame features the following three components:

- Start bit (0)
- 8 data bits (LSB first)
- Programmable 9th data bit
- Stop bit (1)

The 9th data bit to be transmitted can be assigned a value of 0 or 1 by writing the TB8 bit, UART1CONH.3. When receiving, the 9th data bit that is received is written to the RB8 bit, UART1CONH.2, while the stop bit is ignored. The baud rate for mode 2 is  $f_U/16$  clock frequency.

#### Mode 2 Transmit Procedure

Observe the following procedure to write transmission data via UART1 in Mode 2.

1. Select the UART1 clock, UART0CONL.3 and .2.



- 2. Select the UART1 transmit parity-bit autogeneration enable or disable (UART0CONL.7).
- 3. Select Mode 2 (9-bit UART) by setting UART1CONH bits 7 and 6 to 10b. Additionally, select the 9th data bit to be transmitted by writing TB8 to 0 or 1.
- 4. Write the transmission data to the UDATA1 Shift Register (F4h, Set1, Bank0) to start the transmit operation.

#### **Mode 2 Receive Procedure**

Observe the following procedure to read receive data via UART1 in Mode 2.

- 1. Select the UART1 clock, UART0CONL.3 and .2.
- 2. Select the UART1 transmit parity-bit autogeneration enable or disable (UART0CONL.7).
- 3. Select Mode 2 and set the receive enable bit (RE) in the UART1CONH Register to 1.
- 4. The receive operation starts when the signal at the RxD1 (P1.2) pin goes Low.

Figure 104 shows the timing of the Serial Port Mode 2 operation.

| Tx<br>Clock    |                      |            |    |    |    |    |    |    |     |      |          |          |
|----------------|----------------------|------------|----|----|----|----|----|----|-----|------|----------|----------|
| v              | Vrite to Shift Regis | ter (UDATA | 1) |    |    |    |    |    |     |      |          |          |
| Shift          |                      |            |    |    |    |    |    |    |     |      |          | lit      |
| TxD1           | Start Bit D          | 0 D1       | D2 | D3 | D4 | D5 | D6 | D7 | ТВ8 | Stop | Bit      | Transmit |
| TIP            |                      |            |    |    |    |    |    |    |     |      |          | -        |
|                |                      |            |    |    |    |    |    |    |     |      |          |          |
| Rx<br>Clock    |                      |            |    |    |    |    |    |    |     |      |          |          |
| RxD1           | Start B              | it D0      | D1 | D2 | D3 | D4 | D5 | D6 | D7  | RB8  | Stop Bit |          |
| Bit Detect San | nple Time            |            |    |    |    |    |    |    |     |      |          |          |
| Shift          |                      |            |    |    |    |    |    |    |     |      |          | Receive  |
| RIP            |                      |            |    |    |    |    |    |    |     |      |          | -        |

Figure 110. UART1 Serial Port Mode 2 Timing





### **Serial Port Mode 3 Function Description**

In Mode 3, 11 bits are transmitted through the TxD1 (P3.7) pin or received through the RxD0 (P3.6) pin. Mode 3 is identical to Mode 2 except for the baud rate, which is variable. Each data frame features the following four components:

- Start bit (0)
- 8 data bits (LSB first)
- Programmable 9th data bit
- Stop bit (1)

#### **Mode 3 Transmit Procedure**

Observe the following procedure to write transmission data via UART1 in Mode 3.

- 1. Select the UART1 clock, UART1CONL.3 and .2.
- 2. Select the UART1 transmit parity-bit autogeneration enable or disable (UART1CONL.7).
- 3. Select Mode 3 operation (9-bit UART) by setting UART1CONH bits 7 and 6 to 11b. Additionally, select the 9th data bit to be transmitted by writing UART1CONH.3 (TB8) to 0 or 1.
- 4. Write transmission data to the UDATA1 Shift Register (F4h, Set1, Bank0), to start the transmit operation.

#### **Mode 3 Receive Procedure**

Observe the following procedure to read receive data via UART1 in Mode 3.

- 1. Select the UART1 clock, UART1CONL.3 and .2.
- 2. Select the UART1 transmit parity-bit autogeneration enable or disable (UART1CONL.7).
- 3. Select Mode 3 and set the Receive Enable (RE) bit in the UART1CONH Register to 1.
- 4. The receive operation will be started when the signal at the RxD1 (P1.2) pin goes Low.

Figure 111 shows the timing of the Serial Port Mode 3 operation.

Τх Clock Write to Shift Register (UDATA1) Shift **Fransmit** TxD1 D0 D1 D2 D3 D4 D5 D6 D7 TB8 Stop Bit Start Bit TIP Rx Clock RxD1 Stop D0 D1 D2 D3 D4 D5 D6 D7 RB8 Start Bit Bit Bit Detect Sample Time Receive Shift RIP

S3F8S5A

od In LM

DIXYS Company

321

**Product Specification** 

Figure 111. UART1 Serial Port Mode 3 Timing

## **Serial Communication for Multiprocessor Configurations**

The S3F8 Series multiprocessor communication features lets a *master* S3F8S5A MCU send a multiple-frame serial message to a *slave* device in a multi-S3F8S5A configuration without interrupting other slave devices that may be on the same serial line. This feature can be used only in UART modes 2 or 3. In these two modes, 9 data bits are received. The 9th bit value is written to RB8 (UART1CONH.2). The data receive operation is concluded with a stop bit. This function can be programmed such that when the stop bit is received, the serial interrupt will be generated only if RB8 = 1.

To enable this feature, set the MCE bit in the UART1CONH Register. When the MCE bit is 1, serial data frames that are received with the 9th bit = 0 do not generate an interrupt. In this case, the 9th bit simply separates the address from the serial data.

### Sample Protocol for Master/Slave Interaction

When the master device device transmits a block of data to one of several slaves on a serial line, it first sends out an address byte to identify the target slave. Note that in this



case, an address byte differs from a data byte; in an address byte, the 9th bit is 1, and in a data byte, it is 0.

The address byte interrupts all slaves so that each slave can examine the received byte and determine if it is being addressed. The addressed slave then clears its MCE bit and prepares to receive incoming data bytes.

The MCE bits of slaves that were not addressed remain set, and they continue operating normally while ignoring the incoming data bytes.

While the MCE bit setting has no effect in Mode 0, it can be used in Mode 1 to check the validity of the stop bit. For Mode 1 reception, if MCE is 1, the receive interrupt will be issue unless a valid stop bit is received.

#### **Setup Procedure for Multiprocessor Communications**

Observe the following steps to configure multiprocessor communications.

- 1. Set all S3F8S5A devices (masters and slaves) to UART1 Mode 2 or 3.
- 2. Write the MCE bit of all the slave devices to 1.
- 3. The master device's transmission protocol is:
  - First byte: the address identifying the target slave device (9th bit = 1)
  - Next bytes: data (9th bit = 0)
- 4. When the target slave receives the first byte, all of the slaves are interrupted because the 9th data bit is 1. The targeted slave compares the address byte to its own address and then clears its MCE bit to receive incoming data. The other slaves continue operating normally.

Figure 112 shows an example of multiprocessor serial data communications.



Full-Duplex Multi-S3F8S5A Interconnect



TxD1

RxD1

Slave 2

S3F8S5A

TxD1

. . .

RxD1

Slave n

S3F8S5A

PS032303-0314

TxD1

Master

S3F8S5A

RxD1

TxD1

RxD1

Slave 1

S3F8S5A





# **Pattern Generation Module**

Up to 8 bits can be output through P3.0–P3.7 by tracing the sequence shown in Figure 113. First, PGDATA must be changed into a desired output.



Figure 113. Pattern Generation Flow

Next, the PGCON Register, shown in Table 91, must be set to enable the pattern generation module and select the triggering signal. At this point, the PGDATA bits are in the range P3.0–P3.7 whenever the selected triggering signal occurs.

| Bank1)  |   |   |     |             | ule Control |      | ,   | ,   |
|---------|---|---|-----|-------------|-------------|------|-----|-----|
| Bit     | 7 | 6 | 5   | 4           | 3           | 2    | 1   | 0   |
| Reset   | - | _ | _   | _           | 0           | 0    | 0   | 0   |
| R/W     | _ | _ | _   | _           | R/W         | R/W  | R/W | R/W |
| Address |   |   |     | F           | 7h          |      |     |     |
| Mode    |   |   | Reg | ister Addre | ssing Mode  | only |     |     |

| Bit   | Description                                                                            |
|-------|----------------------------------------------------------------------------------------|
| [7:4] | Reserved                                                                               |
| [3]   | Software Trigger Start Bit<br>0: No effect.<br>1: Software trigger start (auto clear). |

S3F8S5A Product Specification



325

 Bit
 Description (Continued)

 [2]
 Pattern Generation Operation Disable/Enable Selection Bit

 0: Pattern generation disable.
 1: Pattern generation enable.

 [1:0]
 Detection Voltage Selection Bits

 00: Timer A match signal triggering.
 01: Timer B overflow signal triggering.

 10: Timer D0 match signal triggering.
 11: Software triggering.

Figure 114 presents a diagram of the pattern generation circuit.





The following routine presents an example of pattern generation.

ORG 0000h ORG 0100h INITIAL: SB0

#### S3F8S5A Product Specification



326

```
SYM, #00h
IMR, #01h
                            ; Disable Global/Fast interrupt \rightarrow SYM
  LD
  LD
                            ; Enable IRQ0 interrupt
  LD
          SPH, #0h
                            ; High byte of stack pointer \rightarrow SPH
  LD
          SPL, \#0FFh ; Low byte of stack pointer \rightarrow SPL
  LD
          BTCON, #10100011b ; Disable Watchdog
 LD
          CLKCON, #00011000b; Non-divided (fxx)
  SB1
  LD
          P2CONH, #10101010b ; Enable PG output
  LD
          P2CONL,#10101010b ; Enable PG output SB0
  ΕI
MAIN:
 NOP
 NOP
  SB1
          PGDATA, #10101010b; PG data setting
 LD
  OR
          PGCON, #00000100b ; Triggering by Timer A match then
                             ; pattern data are output
  SB0
  NOP
 NOP
 JR
          T,MAIN
  .END
```





klod In Life

# **10-Bit Pulse Width Modulation**

The S3F8S5A microcontroller features a 10-bit PWM circuit. The operation of all PWM circuits is controlled by a single control register, PWMCON.

The PWM counter is a 10-bit incrementing counter used by the 10-bit PWM circuits. To start the counter and enable these PWM circuits, set PWMCON.2 to 1. If the counter is stopped, it retains its current count value; when restarted, it resumes counting from the retained count value. When clearing the counter is required, set PWMCON.3 to 1.

Select a clock for the PWM counter by setting PWMCON.6–.7. Selectable clocks are  $f_{XX}/64$ ,  $f_{XX}/8$ ,  $f_{XX}/2$ , and  $f_{XX}/1$ .

The 10-bit PWM circuits offer the following components:

- 8-bit comparator and extension cycle circuit
- 8-bit reference data register (PWMDATAH .7–.0)
- 2-bit extension data register (PWMDATAL .1–.0)
- PWM output pins (P2.1/PWM)

#### **PWM Counter**

To determine the PWM module's base operating frequency, the upper 8 bits of the counter are compared to the PWM data (PWMDATAH .7–.0). To achieve higher resolutions, the lower 2 bits of the PWMDATAL counter can be used to modulate the *stretch cycle*; i.e., to control the *stretching* of the PWM output duty cycle.

#### **PWM Data and Extension Registers**

The PWM (duty) data registers, which are located in Set1, Bank1 at addresses FBh-FDh, determine the output value generated by each 10-bit PWM circuit.

To program the required PWM output, load the appropriate initialization values into the 8bit reference data register (PWMDATAH .7–.0) and the 2-bit extension data register (PWMDATAL .1–.0). To start the PWM counter, or to resume counting, set PWMCON.2 to 1.

A reset operation disables all PWM output. The current counter value is retained when the counter stops. When the counter starts, counting resumes at the retained value.





### **PWM Clock Rate**

The timing characteristics of the PWM output are based on thef<sub>OSC</sub> clock frequency. The PWM counter clock value is determined by the setting of PWMCON.6–.7; see Table 92.

| Register Name         | Mnemonic       | Address          | Function                                                         |
|-----------------------|----------------|------------------|------------------------------------------------------------------|
| PWM data registers    | PWMDATAH .7–.0 | FCh, Set1, Bank1 | 8-bit PWM basic cycle frame value.                               |
|                       | PWMDATAL .10   | FDh, Set1, Bank1 | 2-bit extension ("stretch") value.                               |
| PWM control registers | PWMCON         | FBh, Set1, Bank1 | PWM counter stop/start (resume), and PWM counter clock settings. |

#### Table 92. PWM Control and Data Registers

### **PWM Function Description**

The PWM output signal toggles to a low level whenever the 8-bit counter matches the PWM-DATAH Reference Data Register. If the value in this register is not zero, an overflow of the 8 counter bits causes the PWM output to toggle to a high level. In effect, the reference value written to the reference data register determines the module's base duty cycle.

The value in the lower 2 bits of the PWMDATAL counter is compared with the extension settings in the 2-bit Extension Data Register, PWMDATAL .1–.0. These lower 2 bits of the counter value, together with extension logic and the PWM module's Extension Data Register, is then used to *stretch* the duty cycle of the PWM output. This *stretch value* is one extra clock period at specific intervals, or cycles; see Table 93.

#### Table 93. PWM Output Stretch Values for the Extension Data Register (PWMDATAL

.1–.0)

| PWMDATAL Bit<br>(bit[1]–bit[0]) | "Stretched" Cycle<br>Number |
|---------------------------------|-----------------------------|
| 00                              | -                           |
| 01                              | 2                           |
| 10                              | 1,3                         |
| 11                              | 1,2,3                       |

If, for example, the value in the PWMDATAH Extension Register is 00b and the value in the PWMDATAL Register is 01b, the 2nd cycle will be one pulse longer than the other 3 cycles. If the base duty cycle is 50%, the duty of the 2nd cycle will therefore be stretched to approximately 51% of duty. Furthermore, if you write 10b to the Extension Data Register, all odd-numbered pulses will be one cycle longer. If you write 11h to the Extension Data Register, all pulses will be stretched by one cycle, with the exception of the 4th pulse. PWM output goes to



an output buffer and then to the corresponding PWM output pin. In effect, high output resolution can be obtained at high frequencies. See Figures 115 and 116.













uckloud In Life

### **PWM Control Register**

The control register for the PWM module, PWMCON, shown in Table 94, is located at register address FBh. PWMCON is used for the10-bit PWM modules. Bit settings in the PWMCON Register control the following functions:

- PWM counter clock selection
- PWM data reload interval selection
- ۲ PWM counter clear
- PWM counter stop/start (or resume) operation
- PWM counter overflow (10-bit counter overflow) interrupt control

A reset clears all PWMCON bits to logic zero, thereby disabling the entire PWM module.

| Bit     | 7   | 6                             | 5 | 4   | 3   | 2   | 1   | 0   |  |  |  |
|---------|-----|-------------------------------|---|-----|-----|-----|-----|-----|--|--|--|
| Reset   | 0   | _                             | _ | 0   | 0   | 0   | 0   | 0   |  |  |  |
| R/W     | R/W | R/W                           | _ | R/W | R/W | R/W | R/W | R/W |  |  |  |
| Address |     |                               |   | FE  | 3h  |     |     |     |  |  |  |
| Mode    |     | Register Addressing Mode only |   |     |     |     |     |     |  |  |  |

Table 94. PWM Control Register (PWMCON; Set1, Bank1)

| Bit   | Description                                                                                                                                   |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| [7:6] | PWM Input Clock Selection Bits<br>$00: f_{XX}/64.$<br>$01: f_{XX}/8.$<br>$10: f_{XX}/2.$<br>$11: f_{XX}/1.$                                   |
| [5]   | Reserved                                                                                                                                      |
| [4]   | <b>PWMDATA Reload Interval Selection Bit</b><br>0: Reload from the 10-bit upcounter overflow.<br>1: Reload from the 8-bit upcounter overflow. |
| [3]   | <b>PWM Counter Clear Bit</b><br>0: No effect.<br>1: Clear the PWM counter.                                                                    |
| [2]   | <b>PWM Counter Enable Bit</b><br>0: Stop counter.<br>1: Start/resume counting.                                                                |

S3F8S5A Product Specification



331

 
 Bit
 Description (Continued)

 [1]
 PWM OVF Interrupt Enable Bit 0: Disable interrupt. 1: Enable interrupt.

 [0]
 PWM OVF Interrupt Pending Bit 0: No interrupt is pending when read; clear pending condition when write. 1: An interrupt is pending.

Figure 117 presents a block diagram of the PWM function.



Figure 117. PWM Functional Block Diagram

PS032303-0314

S3F8S5A

ZILOG Embedded in Life

An DXYS Company

332

**Product Specification** 



An DXYS Company

333

The following routine presents an example for programming the PWM module to sample specifications.

```
;----- << Interrupt Vector Address >>
 ORG 0000h
 VECTOR 0DAh, INT_PWM
;-----<< Initialize System and Peripherals >>
ORG 0100h
RESET: DI
                            ; disable interrupt
        LD BTCON,#10100011b ; Watchdog disable
•
 LD P2CONL,#00000100b ; Configure P2.1 PWM output
LD PWMCON,#00000110b ; fOSC/64, counter/interrupt enable
 LD PWMDATAH,,#80h
 LD PWMDATAL,#0
٠
EI ; Enable interrupt
;-----<< Main loop >>
Main:
٠
•
 JR t,MAIN
;-----<< Interrupt Service Routines >>
INT_PWM:
                           ; PWM interrupt service routine
•
 AND PWMCON,#11111110b ; pending bit clear IRET
END
```





# **Embedded Flash Memory Interface**

The S3F8S5A MCU features internal on-chip Flash memory instead of masked ROM. This Flash memory is accessed by an LDC instruction. With sector erase and byte-programmable Flash, data can be programmed into a Flash memory space at any time. The S3F8S5A MCU's embedded 48KB of memory offers the following two operating features:

- User Program Mode
- Tool Program Mode see the <u>S3F8S5A Flash MCU</u> chapter on page 363

#### **User Program Mode**

User Program Mode supports sector erase, byte programming, byte read, and one protection mode, Hard Lock protection; read protection is available only in Tool Program Mode. To read-protect the chip, select a read protection option when you initially program your code in Tool Program Mode by using a programming tool.

The S3F8S5A MCU also features an internal pumping circuit; therefore, 12.5V into a  $V_{PP}$  (test) pin is not required. To program Flash memory in this mode, several control registers are used. There are four functions: programming, reading, sector erase, and hard lock protection.

**Note:** 1. User Program Mode cannot be used when the CPU operates with the subsystem clock.

- 2. Be sure to execute the DI instruction before starting User Program Mode, which checks the Interrupt Request Register (IRQ). If an interrupt request is generated, User Program Mode is stopped.
- 3. User Program Mode is also stopped by an interrupt request that is masked even in the DI status. To prevent this situation, disable the interrupt by using the each peripheral interrupt enable bit.

### **Flash Memory Control Registers**

This section describes the use of the Flash Memory Control (FMCON), Flash Memory User Programming Enable, and Flash Memory Sector Address registers when operating in User Program Mode.

#### S3F8S5A Product Specification



335

### **Flash Memory Control Register**

The Flash Memory Control (FMCON) Register, shown in Table 95, is available only in User Program Mode to select the operational mode of Flash memory, as well as the sector erase and byte programming functions, and to protect the Flash memory space with the Hard Lock function.

|                                                                  | 6                                                                                                                                                                                                                                                                                                                                | 5                                                                                                                                                                                                                                                                                                                                                                                   | 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                                                                | 0                                                                                                                                                                                                                                                                                                                                | 0                                                                                                                                                                                                                                                                                                                                                                                   | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| R/W                                                              | R/W                                                                                                                                                                                                                                                                                                                              | R/W                                                                                                                                                                                                                                                                                                                                                                                 | R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                                                  |                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                     | F9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                                  |                                                                                                                                                                                                                                                                                                                                  | Reg                                                                                                                                                                                                                                                                                                                                                                                 | ister Addres                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | sing Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | only                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| ad only; R/W = r                                                 | ead/write.                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Descriptio                                                       | on                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0001–0100<br>0101: Prog<br>0110: Harc<br>0111–1001<br>1010: Sect | D: Reserved<br>gramming M<br>Lock Mod<br>Reserved<br>tor Erase M                                                                                                                                                                                                                                                                 | l.<br>lode.<br>e.<br>ode.                                                                                                                                                                                                                                                                                                                                                           | Bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0: Sector e                                                      | erase succe                                                                                                                                                                                                                                                                                                                      | SS.                                                                                                                                                                                                                                                                                                                                                                                 | Only)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Reserved                                                         |                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0: Operatio                                                      | on stop.                                                                                                                                                                                                                                                                                                                         | rt Bit*                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                                  | R/W           ad only; R/W = r           Descriptic           Flash Mer           0001–0100           0101: Prog           0110: Harc           0111–1001           1010: Sect           1011–1111           Sector Era           0: Sector e           1: Sector e           Reserved           Flash Ope           0: Operatio | R/W       R/W         ad only; R/W = read/write.         Description         Flash Memory Mode         0001–0100: Reserved         0101: Programming M         0110: Hard Lock Mode         0111–1001: Reserved         1010: Sector Erase M         1011–1111: Reserved         Sector Erase Status         0: Sector erase succe         1: Sector erase failure         Reserved | R/W       R/W       R/W         Reg       Reg         ad only; R/W = read/write.       Reg         Description       Flash Memory Mode Selection         0001–0100: Reserved.       0101: Programming Mode.         0110: Hard Lock Mode.       0111–1001: Reserved.         1010: Sector Erase Mode.       1011–1111: Reserved.         Sector Erase Status Bit (Read       0: Sector erase success.         1: Sector erase failure.       Reserved         Flash Operation Start Bit*       0: Operation stop. | R/W       R/W       R/W       Fg         Register Address         ad only; R/W = read/write.         Description         Flash Memory Mode Selection Bits         0001–0100: Reserved.         0111 - Programming Mode.         0111 - Programming Mode.         0111 - Programming Mode.         0111 - 1001: Reserved.         1010: Sector Erase Mode.         1010: Sector Erase Mode.         1011 - 1111: Reserved.         Sector Erase Status Bit (Read Only)         0: Sector erase success.         1: Sector erase failure.         Reserved         Flash Operation Start Bit*         0: Operation stop. | R/W       R/W       R/W       R/W       R         F9h         Register Addressing Mode         ad only; R/W = read/write.         Description         Flash Memory Mode Selection Bits         0001–0100: Reserved.         0111: Programming Mode.         0111: Programming Mode.         0111: Programming Mode.         0111-1001: Reserved.         1010: Sector Erase Mode.         1011–1111: Reserved.         Sector Erase Status Bit (Read Only)         0: Sector erase success.         1: Sector erase failure.         Reserved         Flash Operation Start Bit*         0: Operation stop. | R/W       R/W       R/W       R/W       R       -         F9h         Register Addressing Mode only         ad only; R/W = read/write.         Description         Flash Memory Mode Selection Bits         0001–0100: Reserved.         0101: Programming Mode.         0110: Reserved.         0111–1001: Reserved.         1011–1111: Reserved.         Sector Erase Mode.         1011–1111: Reserved.         Sector Erase Status Bit (Read Only)         0: Sector erase success.         1: Sector erase failure.         Reserved         Flash Operation Start Bit*         0: Operation stop. | R/W       R/W       R/W       R       -       -         F9h         Register Addressing Mode only         ad only; R/W = read/write.         Description         Flash Memory Mode Selection Bits         00010100: Reserved.       00010100: Reserved.         0101: Programming Mode.       0101: Programming Mode.         0110: Hard Lock Mode.       01111001: Reserved.         1010: Sector Erase Mode.       10111111: Reserved.         Sector Erase Status Bit (Read Only)         0: Sector erase success.       1: Sector erase failure.         Reserved         Flash Operation Start Bit*         0: Operation stop.       0: Operation stop. |

#### Table 95. Flash Memory Control Register (FMCON; Set1, Bank0)

Bit 0 of the FMCON Register, FMCON.0, is a start bit for both the Erase and Hard Lock operation modes. Therefore, operation of the Erase and Hard Lock modes is activated when setting FMCON.0 to 1. Additionally, a waiting period for the Erase (sector erase) or Hard Lock modes to complete their operations must occur before performing a byte programming or byte read operation of the same sector area by with the LDC instruction. When reading or programming a byte data from or into Flash memory, this bit is not required to be manipulated.

The sector erase status bit is read only. Even if the IMR bits are 0, the interrupt is serviced during the operation of a sector erase, when each peripheral interrupt enable bit is set to 1,





and when the interrupt pending bit is set to 1. If an interrupt is requested during a sector erase operation, the operation of this sector erase is discontinued, and the interrupt is serviced by the CPU. Therefore, the sector erase status bit should be checked after executing a sector erase. The sector erase operation is successful if the bit is logic 0, and is a failure if the bit is logic 1.

**Caution:** When the A5h ID code is written to the FMUSR Register, it is possible that the sector erase, user program, and hard lock modes may be executed; therefore caution is necessary.

#### Flash Memory User Programming Enable Register

The Flash Memory User Programming Enable (FMUSR) Register, shown in Table 96, manages the safe operation of Flash memory. This register will protect undesired erase or program operations from CPU malfunctions caused by electrical noise. After reset, User Program Mode is disabled because the value of FMUSR is 0000000b as a result of the reset operation. If it is necessary to operate Flash memory, enable User Program Mode by setting the value of FMUSR to 10100101b. Any value written to FMUSR other than 10100101b disables User Program Mode.

|                               |                                                                                  | ,                                                                                                                 | - <b>J</b>                                                                                                                                                            | 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | j                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | , ,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|-------------------------------|----------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 7                             | 6                                                                                | 5                                                                                                                 | 4                                                                                                                                                                     | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 2                                                                                                                                                                                                  | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| 0                             | 0                                                                                | 0                                                                                                                 | 0                                                                                                                                                                     | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0                                                                                                                                                                                                  | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| R/W                           |                                                                                  |                                                                                                                   |                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
| F8h                           |                                                                                  |                                                                                                                   |                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
| Register Addressing Mode only |                                                                                  |                                                                                                                   |                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
| ad only; R/W = read           | /write.                                                                          |                                                                                                                   |                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
| Description                   |                                                                                  |                                                                                                                   |                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
| 00000001–10<br>10100101: Er   | 100100<br>nable Us                                                               | : Disable User<br>er Program M                                                                                    | Program<br>ode.                                                                                                                                                       | Mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
|                               | ad only; R/W = read<br>Description<br>Flash Memor<br>00000001–10<br>10100101: Er | 0 0<br>ad only; R/W = read/write.<br>Description<br>Flash Memory User<br>00000001–10100100<br>10100101: Enable Us | 0 0 0<br>Register<br>ad only; R/W = read/write.<br>Description<br>Flash Memory User Programming<br>00000001–10100100: Disable User<br>10100101: Enable User Program M | 0         0         0         0           Register Address         Register Address           ad only; R/W = read/write.         Image: Comparison of the second s | 0 0 0 0 0 R/W<br>R/W<br>F8h<br>Register Addressing Mode<br>ad only; R/W = read/write.<br>Description<br>Flash Memory User Programming Enable Bits<br>00000001–10100100: Disable User Program Mode. | 0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         Register         R/W         F8h         Register Addressing Mode only         ad only; R/W = read/write.         Description         F1ash Memory User Programming Enable Bits         00000001–10100100: Disable User Program Mode.         10100101: Enable User Program Mode.         Description | 0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0 |  |  |  |

#### Table 96. Flash Memory User Programming Enable Register (FMUSR; Set1,

#### **Flash Memory Sector Address Registers**

There are two sector address registers used to select a particular sector. The Flash Memory Address Sector High Byte (FMSECH) Register and the Flash Memory Sector Address



Low Byte (FMSECL) Register are combined to generate the most significant bits of the 16-bit base address for the sector to be selected. FMSECH represents the bits 8 through 15 of the 16-bit address, and FMSECL represents bit 7 of the 16-bit base address. The S3F8S5A MCU provides 384 sectors, and each sector is 128 bytes, in effect meaning that the lower 7 bits of FMSECL have no effect; see the example in Figure 118.

|    | FMSECH |    |    |    |    |    |    | FMSECL |    |    |    |    |    |    |    |
|----|--------|----|----|----|----|----|----|--------|----|----|----|----|----|----|----|
| .7 | .6     | .5 | .4 | .3 | .2 | .1 | .0 | .7     | .6 | .5 | .4 | .3 | .2 | .1 | .0 |

|     |     |     |     |     |     | 16 | 6-Bit A | ddre | SS |   |   |   |   |   |   |
|-----|-----|-----|-----|-----|-----|----|---------|------|----|---|---|---|---|---|---|
| .15 | .14 | .13 | .12 | .11 | .10 | .9 | .8      | .7   | Х  | Х | Х | Х | Х | Х | Х |

#### Figure 118. Flash Memory Sector Addressing

As shown in Tables 97 and 98, the Flash Memory Sector Address Register High Byte (FMSECH) Register indicates the high byte of the sector address, and the Flash Memory Sector Address Register Low Byte (FMSECL) Register indicates the low byte of the sector address.

| Bit          | 7                 | 6                             | 5            | 4            | 3    | 2 | 1 | 0 |  |  |  |
|--------------|-------------------|-------------------------------|--------------|--------------|------|---|---|---|--|--|--|
| Reset        | 0                 | 0                             | 0            | 0            | 0    | 0 | 0 | 0 |  |  |  |
| R/W          |                   |                               |              | R            | W    |   |   |   |  |  |  |
| Address      | F6h               |                               |              |              |      |   |   |   |  |  |  |
| Mode         |                   | Register Addressing Mode only |              |              |      |   |   |   |  |  |  |
| Note: R = re | ead only; R/W = r | ead/write.                    |              |              |      |   |   |   |  |  |  |
| Bit          | Descriptio        | on                            |              |              |      |   |   |   |  |  |  |
| [7:0]        |                   | -                             |              | (High Byte   | •    |   |   |   |  |  |  |
|              | The 15th-         | Bth bits to s                 | elect a sect | tor of Flash | ROM. |   |   |   |  |  |  |

Note: The high-byte Flash memory sector address pointer value is the upper eight bits of the 16-bit pointer address.



| Bit            | 7                             | 6                         | 5 | 4 | 3  | 2 | 1 | 0 |  |  |  |
|----------------|-------------------------------|---------------------------|---|---|----|---|---|---|--|--|--|
| Reset          | 0                             | 0                         | 0 | 0 | 0  | 0 | 0 | 0 |  |  |  |
| R/W            |                               |                           |   | R | W  |   |   |   |  |  |  |
| Address        |                               |                           |   | F | 7h |   |   |   |  |  |  |
| Mode           | Register Addressing Mode only |                           |   |   |    |   |   |   |  |  |  |
| Note: R = real | ad only; R/W = r              | ead/write.                |   |   |    |   |   |   |  |  |  |
| Bit            | Descriptio                    | on                        |   |   |    |   |   |   |  |  |  |
| [7]            |                               | nory Secto<br>to select a |   | • | )  |   |   |   |  |  |  |
|                |                               |                           |   |   |    |   |   |   |  |  |  |
| [6:0]          | Don't Car                     | e                         |   |   |    |   |   |   |  |  |  |

#### Table 98. Flash Memory Sector Address Register Low Byte Register (FMSECL; Set1, Bank0)

When programming Flash memory, write the data after loading the sector base address located in the target address into the FMSECH and FMSECL registers. If the next operation is also a data write operation, check to determine if the next address is located in the same sector. In the case of other sectors, you must load the sector address to the FMSECH and FMSECL registers according to the sector.

#### **ISP™** Onboard Programming Sector

 $ISP^{TM}$  sectors located in the program memory space can store onboard program software (i.e., boot program code for upgrading application code by interfacing with an I/O port pin). These  $ISP^{TM}$  sectors cannot be erased or programmed by an LDC instruction for the safety of onboard program software.

ISP sectors are available only when the ISP enable/disable bit is set to 0, i.e., ISP is enabled using the Smart Option. If you prefer not to use the ISP sector method, this area can be used as normal program memory (i.e., it can be erased or programmed using the LDC instruction) by setting the ISP disable bit (1) with the Smart Option. Even if the ISP sector is selected, the ISP sector can be erased or programmed in Tool Program Mode using a serial programming tool.

The size of the ISP sector can be adjusted using Smart Option settings; see Figure 119. Additionally, refer to <u>Table 100</u> on page 340 to choose an appropriate ISP sector size according to the size of the onboard program software.







Figure 119. Program Memory Address Space





## **ISP Reset Vector and ISP Sector Size**

If you use ISP sectors by setting the ISP enable/disable bit to 0 and the reset vector selection bit to 0 at the Smart Option (see Figure 15 on page 21), you can choose the reset vector address of the CPU as shown in Table 99 by setting the ISP reset vector address selection bits; also see the list of ISP sector sizes in Table 100.

| Smart Option (003Eh)<br>ISP Reset Vector Address Selection Bi |             | • | Reset Vector<br>Address after | Usable Area for |                 |  |
|---------------------------------------------------------------|-------------|---|-------------------------------|-----------------|-----------------|--|
| Bit 7                                                         | Bit 6 Bit 5 |   | POR                           | ISP Sector      | ISP Sector Size |  |
| 1                                                             | х           | х | 0100h                         | 0               | 0               |  |
| 0                                                             | 0           | 0 | 0200h                         | 100h–1FFh       | 256 bytes       |  |
| 0                                                             | 0           | 1 | 0300h                         | 100h–2FFh       | 512 bytes       |  |
| 0                                                             | 1           | 0 | 0400h                         | 100h–4FFh       | 1024 bytes      |  |
| 0                                                             | 1           | 1 | 0500h                         | 100h-8FFh       | 2048 bytes      |  |

#### Table 99. Reset Vector Address

#### Table 100. ISP Sector Size

| Smart Option     | (003Eh) ISP Size     | Selection Bit      |                                 |                    |
|------------------|----------------------|--------------------|---------------------------------|--------------------|
| Bit 2            | Bit 1                | Bit 0              | Area of ISP Sector              | ISP Sector Size    |
| 1                | Х                    | х                  | 0                               | 0                  |
| 0                | 0                    | 0                  | 100h–1FFh (256 bytes)           | 256 bytes          |
| 0                | 0                    | 1                  | 100h–2FFh (512 bytes)           | 512 bytes          |
| 0                | 1                    | 0                  | 100h–4FFh (1024 bytes)          | 1024 bytes         |
| 0                | 1                    | 1                  | 100h–8FFh (2048 bytes)          | 2048 bytes         |
| ote: The area of | the ISP sector selec | ted by Smart Optio | n bits (003Eh.2–003Eh.0) cannot | be erased and pro- |

grammed by the LDC instruction in User Program Mode.

# **Sector Erase Operations**

Flash memory can be partially erased by using the sector erase functions in User Program Mode only. Sectors are the only units of Flash memory that can be erased in User Program Mode.

### S3F8S5A Product Specification

Zilog Embedded in Life An DIXYS Company

341

Program memory on the S3F8S5A MCU is divided into 384 sectors for erase and program operations; every sector is 128 bytes. Each sector should be first be erased prior to programming a new data byte into Flash memory. A minimum of 10ms delay time is required prior to an erase and after setting the sector address and triggering the erase start bit (FMCON.0). The sector erase function is not supported in Tool Program modes (i.e., when using an MDS mode too or programming tool).

Figure 120 portrays how sectors are mapped in User Program Mode.

| Sector 383      | BFFFh |
|-----------------|-------|
| (128 byte)      | BF80h |
|                 | 0780h |
| Sector 14       | 077Fh |
| (128 byte)      | 0700h |
| Sector 13       |       |
| (128 byte)      | 0680h |
| Sector 12       |       |
| (128 byte)      | 0600h |
| Sector 11       |       |
| (128 byte)      | 0580h |
| Sector 10       |       |
| (128 byte)      | 0500h |
|                 |       |
| Sector 0-9      | 04FFh |
| (128 byte x 10) | 0000h |
|                 |       |

S3F8S5A

#### Figure 120. Sector Configurations in User Program Mode

## The Sector Erase Procedure in User Program Mode

Observe the following procedure to perform a sector erase in User Program Mode.

- 1. If the sector erase procedure must be stopped by any interrupt, set the appropriate bit in the Interrupt Mask Enable Register (IMR) and the appropriate peripheral interrupt enable bit. Otherwise, clear all bits in the Interrupt Mask Enable Register (IMR) and all peripheral interrupt enable bits.
- 2. Set the Flash Memory User Programming Enable (FMUSR) Register to 10100101b.
- 3. Set the Flash Memory Sector Address (FMSECH and FMSECL) registers.
- 4. Check the user's ID code (written by user).





5. Set the Flash Memory Control (FMCON) Register to 10100001b.

6. Set the Flash Memory User Programming Enable (FMUSR) Register to 0000000b.

7. Check the sector erase status bit to determine if the sector erase is successful.

The following routine presents an example of a successful sector erase.

| •                |                    |   |                                   |
|------------------|--------------------|---|-----------------------------------|
| •                |                    |   |                                   |
| SB0              | LD FMUSR, Temp0    |   | User Program mode enable          |
| IELIASE.         | Tempo Phose, Tempo |   | Temp0 = $\#0A5H$                  |
|                  |                    |   | Temp0 variable is must be setting |
|                  |                    |   | another routine                   |
| LD               | FMSECH,#10h        | , |                                   |
| LD               | FMSECL,#00h        | ; | Set sector address (1000h-107Fh)  |
| CP UserID        | Code, #User value  |   | Check user's ID code (written by  |
|                  | _ /* _             |   | user)                             |
|                  |                    | ; | User_value is any value by user   |
| JR               | NE,Not_ID_Code     | ; | If not equal, jump to Not_ID_Code |
| LD               | FMCON,Temp1        | ; | Start sector erase                |
|                  |                    | ; | Temp1 = #0A1h                     |
|                  |                    | ; | Temp1 variable is must be setting |
|                  |                    | ; | another routine                   |
| NOP              |                    |   | Dummy instruction - required      |
| NOP              |                    |   | Dummy instruction - required      |
| LD               | FMUSR,#0           |   | User Program Mode disable         |
| TM FMCO          | N,#00001000b       |   | Check "sector erase status bit"   |
| JR               | NZ,reErase         | ; | Jump to reErase if fail           |
| •                |                    |   |                                   |
| •                |                    |   |                                   |
| •                |                    |   |                                   |
| •                | 1.                 |   |                                   |
| Not_ID_Co<br>SB0 | dei                |   |                                   |
| LD               | FMUSR,#0           |   | User Program Mode disable         |
| LD               | FMCON, #0          |   | Sector Erase Mode disable         |
| <u>д</u> п       | FMCON, #0          | ' | Sector mase Mode disable          |
| •                |                    |   |                                   |
| •                |                    |   |                                   |
| •                |                    |   |                                   |
|                  |                    |   |                                   |



**Note:** In the case of Flash User Mode, the Temp0 to Temp1 data values must set another routine. Temp0 to Temp(n) variables should be defined by the user.

## **Program Operations**

After a sector erase, Flash memory is programmed in one-byte units. For the sake of programming safety, FMSECH and FMSECL must each be set to the Flash memory sector value.

### **Programming in User Program Mode**

Observe the following procedure to program Flash memory in User Program Mode.

- 1. Erase all target sectors before programming.
- 2. Set the Flash Memory User Programming Enable (FMUSR) Register to 10100101b.
- 3. Set the Flash Memory Sector Address registers (FMSECH and FMSECL) to the sector base address of the destination address to write data.
- 4. Load the Flash memory upper address into the upper register of the working register pair.
- 5. Load the Flash memory lower address into the lower register of the working register pair.
- 6. Load transmission data into a working register.
- 7. Check the user's ID code (written by user).
- 8. Set the Flash Memory Control Register (FMCON) to 01010001b.
- 9. Load transmission data to a Flash memory location using the LDC instruction via Indirect Addressing Mode.
- 10. Set the Flash Memory User Programming Enable (FMUSR) Register to 0000000b.

The following routine presents an example of a successful programming operation.

```
•

•

SB0

LD FMUSR,Temp0 ; User Program Mode enable

; Temp0 = #0A5H

; Temp0 variable is must be setting

; another routine
```





| LD        | FMSECH,#17h       |    |                                      |
|-----------|-------------------|----|--------------------------------------|
| LD        | FMSECL,#80h       | ;  | Set sector address (1780h-17FFh)     |
| LD        | R2,#17h           | ;  | Set a ROM address in the same sector |
|           |                   | ;  | 1780h-17FFh                          |
| LD        | R3,#84h           |    |                                      |
| LD        | R4,#78h           | ;  | Temporary data                       |
| CP        | UserID_Code,#User | _v | alue ; Check user's ID code (written |
|           |                   | ;  | by user)                             |
|           |                   | ;  | User_value is any value by user      |
| JR        | NE,Not_ID_Code    | ;  | If not equal, jump to Not_ID_Code    |
| LD        | FMCON,Templ       | ;  | Start program                        |
|           |                   | ;  | Temp1 = #51H                         |
|           |                   | ;  | Templ variable is must be setting    |
|           |                   | ;  | another routine                      |
| LDC       | @RR2,R4           | ;  | Write the data to a address of same  |
|           |                   | ;  | sector(1784h)                        |
| NOP       |                   | ;  | Dummy instruction - required         |
| LD        | FMUSR,#0          | ;  | User Program Mode disable            |
| •         |                   |    |                                      |
| •         |                   |    |                                      |
| •         |                   |    |                                      |
| •         |                   |    |                                      |
| Not_ID_Co | ode:              |    |                                      |
| SB0       |                   |    |                                      |
| LD        | FMUSR,#0          | ;  | User Program Mode disable            |
| LD        | FMCON, #0         | ;  | Programming Mode disable             |
|           |                   |    |                                      |

**Note:** In the case of Flash User Mode, the Temp0 to Temp1 data values must set another routine. Temp0 to Temp(n) variables should be defined by the user.

# **Read Operations**

The read operation is initiated by the LDC instruction. Observe the following procedure to program read operations in User Program Mode.

- 1. Load an upper Flash memory address into the upper register of the working register pair.
- 2. Load a lower Flash memory address into the lower register of the working register pair.



3. Load the receive data from the Flash memory space using the LDC instruction via Indirect Addressing Mode.

The following example shows how to perform read programming.

| •         |         |                                        |
|-----------|---------|----------------------------------------|
| LD        | R2,#3h  | ; Load Flash memory upper address      |
|           |         | ; to upper of pair working register    |
| LD        | R3,#0   | ; Load Flash memory lower address      |
|           |         | ; to lower pair working register       |
| LOOP: LDC | R0,@RR2 | ; Read data from Flash memory location |
|           |         | ; (Between 300h and 3FFh)              |
| INC       | R3      |                                        |
| CP        | R3,#0h  |                                        |
| JP        | NZ,LOOP |                                        |
| •         |         |                                        |
| •         |         |                                        |
| •         |         |                                        |
| •         |         |                                        |

## **Hard Lock Protection**

•

The Hard Lock Protection function prevents changes to data in Flash memory. It can be set by writing 0110b to FMCON.7–.4. If this function is enabled, the user cannot write or erase the data within Flash memory. This protection can be released by executing a chip erase in Tool Program Mode.

Hard Lock Protection can be enabled by the application software when User Program Mode is enabled, or with a Serial Programmer while in Tool Program Mode. Refer to the documentation that accompanies the Serial Programmer you are using to enable Hard Lock Protection in Tool Program Mode.

To enable Hard Lock protection with application software, observe the following procedure.

- 1. Set the Flash Memory User Programming Enable (FMUSR) Register to 10100101b.
- 2. Check the user's ID code (written by user).
- 3. Set the Flash Memory Control (FMCON) Register to 01100001b.
- 4. Set the Flash Memory User Programming Enable (FMUSR) Register to 0000000b.

The following example shows how to set Hard Lock protection.

SB0

## S3F8S5A Product Specification



346

| LD        | FMUSR,Temp0        | ;  | User Program Mode enable             |
|-----------|--------------------|----|--------------------------------------|
|           |                    | ;  | Temp0 = #0A5h                        |
|           |                    | ;  | Temp0 variable is must be setting    |
|           |                    | ;  | another routine                      |
| CP        | UserID_Code,#User_ | _v | alue ; Check user's ID code (written |
|           |                    | ;  | by user)                             |
|           |                    | ;  | User_value is any value by user      |
| JR        | NE,Not_ID_Code     | ;  | If not equal, jump to Not_ID_Code    |
| LD        | FMCON,Temp1        | ;  | Hard Lock Mode set & start           |
|           |                    | ;  | Temp1 = #61H                         |
|           |                    | ;  | Temp1 variable is must be setting    |
|           |                    | ;  | another routine                      |
| NOP       |                    | ;  | Dummy Instruction - required         |
| LD        | FMUSR,#0           | ;  | User Program Mode disable            |
| •         |                    |    | 5                                    |
| •         |                    |    |                                      |
| •         |                    |    |                                      |
| •         |                    |    |                                      |
| Not ID Co | de:                |    |                                      |
| SB0       |                    |    |                                      |
| LD        | FMUSR,#0           | ;  | User Program Mode disable            |
| LD        | FMCON, #0          |    | Hard Lock Protection Mode disable    |
| •         | ,                  |    |                                      |
| •         |                    |    |                                      |
| •         |                    |    |                                      |
| •         |                    |    |                                      |
| -         |                    |    |                                      |

**Note:** In the case of Flash User Mode, the Temp0 to Temp1 data values must set another routine. Temp0 to Temp(n) variables should be defined by the user.

#### S3F8S5A Product Specification



### 347

# **Electrical Characteristics**

In this chapter, the S3F8S5A MCU's electrical characteristics are presented in tables and charts. This information is arranged in the following order:

- 1. Absolute Maximum Ratings see Table 101
- 2. DC Electrical Characteristics see Table 102
- 3. AC Electrical Characteristics see <u>Table 103</u> on page 350
- 4. Input Timing for External Interrupts, Ports 0 and 2 see Figure 121 on page 351
- 5. Input Timing for Reset (nRESET Pin) see Figure 122 on page 351
- 6. Input/Output Capacitance see <u>Table 104</u> on page 351
- 7. Data Retention Supply Voltage see <u>Table 105</u> on page 351
- 8. Stop Mode Release Timing Initiated by nRESET see <u>Table 105</u> on page 351
- 9. Stop Mode Release Timing Initiated by Interrupts see Table 105 on page 351
- 10. A/D Converter Electrical Characteristics see Table 106 on page 353
- 11. Low Voltage Reset Electrical Characteristics see Table 107 on page 353
- 12. Low Voltage Reset Timing see Figure 125 on page 354
- 13. Synchronous SIO Electrical Characteristics see Table 108 on page 354
- 14. Serial Data Transfer Timing see Figure 126 on page 355
- 15. UART Timing Characteristics in Mode 0 see Table 109 on page 355
- 16. Waveform for UART Timing Characteristics see Figure 127 on page 356
- 17. Timing Waveform for the UART Module see Figure 128 on page 356
- 18. Main Oscillator Characteristics see Table 110 on page 357
- 19. Suboscillation Characteristics see <u>Table 111</u> on page 357
- 20. Main Oscillation Stabilization Time see Table 112 on page 358
- 21. Clock Timing Measurement at  $X_{IN}$  see Figure 129 on page 358
- 22. Suboscillation Stabilization Time see Table 113 on page 358
- 23. Clock Timing Measurement at X<sub>TIN</sub> see Figure 130 on page 359
- 24. Operating Voltage Range see Figure 131 on page 359
- 25. Internal Flash ROM Electrical Characteristics see Figure 114 on page 360



| Parameter             | Symbol           | Conditions                  | Rating TBD                   | Unit |
|-----------------------|------------------|-----------------------------|------------------------------|------|
| Supply Voltage        | V <sub>DD</sub>  | -                           | -0.3 to +6.5                 | V    |
| Input Voltage         | VI               | Ports 0–4                   | –0.3 to V <sub>DD</sub> +0.3 | V    |
| Output Voltage        | Vo               | -                           | –0.3 to V <sub>DD</sub> +0.3 | V    |
| Output Current High   | I <sub>OH</sub>  | One I/O pin active          | -5                           | mA   |
|                       |                  | All I/O pins active         | -60                          |      |
| Output Current Low    | I <sub>OL</sub>  | One I/O pin active          | +30 (peak value)             | mA   |
|                       |                  | Total pin current for ports | +100 (peak value)            |      |
| Operating Temperature | T <sub>A</sub>   | -                           | -40 to +85                   | °C   |
| Storage Temperature   | T <sub>STG</sub> | _                           | -65 to +150                  | °C   |
|                       |                  |                             |                              |      |

### Table 101. Absolute Maximum Ratings ( $T_A = 25^{\circ}C$ )

| Parameter              | Symbol           | Conditions                                                                | Min.                 | Тур.                 | Max.                | Unit |
|------------------------|------------------|---------------------------------------------------------------------------|----------------------|----------------------|---------------------|------|
| Operating              | $V_{DD}$         | $f_X = 0.4 - 4.2 MHz$                                                     | 1.8                  | _                    | 5.5                 | V    |
| Voltage                |                  | $f_X = 0.4 - 12.0 \text{ MHz}$                                            | 2.2                  | _                    | 5.5                 | V    |
| Input High             | V <sub>IH1</sub> | All ports except for V <sub>IH2</sub>                                     | $0.8V_{DD}$          | _                    | V <sub>DD</sub>     | V    |
| Voltage                | V <sub>IH2</sub> | X <sub>IN</sub> , X <sub>OUT</sub> , X <sub>TIN</sub> , X <sub>TOUT</sub> | V <sub>DD</sub> -0.1 | _                    | V <sub>DD</sub>     | V    |
| Input Low              | V <sub>IL1</sub> | All ports except V <sub>IL2</sub>                                         | _                    | _                    | 0.2 V <sub>DD</sub> | V    |
| Voltage                | V <sub>IL2</sub> | X <sub>IN,</sub> X <sub>OUT,</sub> X <sub>TIN,</sub> X <sub>TOUT</sub>    | _                    | _                    | 0.1                 | _    |
| Output High<br>Voltage | V <sub>OH1</sub> | V <sub>DD</sub> = 2.4V, P1.0–P1.1, P3.4–P3.6; I <sub>OH</sub><br>= –1mA   | V <sub>DD</sub> -0.7 | V <sub>DD</sub> -0.7 | -                   | V    |
|                        | V <sub>OH2</sub> | $V_{DD} = 5V; P2; I_{OH} = -4mA$                                          | V <sub>DD</sub> -1.0 | V <sub>DD</sub> -1.0 | _                   | V    |
|                        | V <sub>OH3</sub> | $V_{DD} = 5V$ ; the other ports; $I_{OH} = -1 \text{ mA}$                 | V <sub>DD</sub> -1.0 | V <sub>DD</sub> -1.0 | _                   | V    |
| Output Low<br>Voltage  | V <sub>OL1</sub> | V <sub>DD</sub> = 2.4V; P1.0–P1.1, P3.4–P3.6; I <sub>OL</sub><br>= 12mA   | -                    | 0.3                  | 0.5                 | V    |
|                        | V <sub>OL2</sub> | V <sub>DD</sub> = 5V; P2; I <sub>OL</sub> = 15mA                          | _                    | 0.4                  | 2.0                 | V    |
|                        | V <sub>OL3</sub> | $V_{DD} = 5V$ ; the other ports; IOL = 4mA                                | -                    | 0.4                  | 2.0                 | V    |

#### Notes:

1. Every value in this table is measured when bits 4-3 of the System Clock Control Register (CLKCON.4-.3) is set to 11b.

2. Supply current does not include current drawn through internal pull-up resistors, LCD voltage-dividing resistors, the LVR block, and external output current loads.

- I<sub>DD1</sub> and I<sub>DD2</sub> include a power consumption of subclock oscillation.
   I<sub>DD3</sub> and I<sub>DD4</sub> are the current when the main clock oscillation stops and the subclock is used.
   I<sub>DD5</sub> is the current when the main and subclock oscillation stops.



| Parameter                                               | Symbol            | Conditions                                                                                   |                           | Min. | Тур. | Max. | Unit |
|---------------------------------------------------------|-------------------|----------------------------------------------------------------------------------------------|---------------------------|------|------|------|------|
| Input High                                              | I <sub>LIH1</sub> | $V_{IN} = V_{DD}$ ; all input pins exc                                                       | ept for I <sub>LIH2</sub> | -    | -    | 3    | μA   |
| Leakage<br>Current                                      | I <sub>LIH2</sub> | $V_{IN} = V_{DD}; X_{IN}, X_{OUT}, X_{TIN}, X_{TOUT}$                                        |                           | -    | _    | 20   | μA   |
| Input Low<br>Leakage                                    | I <sub>LIL1</sub> | V <sub>IN</sub> = 0V; all input pins exce<br>nRESET, I <sub>LIL2</sub>                       | pt for                    | -    | -    | -3   | μA   |
| Current                                                 | I <sub>LIL2</sub> | V <sub>IN =</sub> 0V; X <sub>IN</sub> , X <sub>OUT</sub> , X <sub>TIN</sub> , X <sub>T</sub> | OUT                       | _    | _    | -20  |      |
| Output High<br>Leakage<br>Current                       | I <sub>LOH</sub>  | $V_{OUT} = V_{DD}$ ; all output pins                                                         |                           | -    | -    | 3    | μA   |
| Output Low<br>Leakage<br>Current                        | I <sub>LOL</sub>  | V <sub>OUT</sub> = 0V; all output pins                                                       |                           | -    | -    | -3   | μA   |
| Pull-Up<br>Resistors                                    | R <sub>L1</sub>   | $VI = 0V; T_A = 25^{\circ}C, Ports 0-4$                                                      | 1 V <sub>DD</sub> = 5V    | 25   | 50   | 100  | kΩ   |
|                                                         |                   |                                                                                              | $V_{DD} = 3V$             | 50   | 100  | 150  | kΩ   |
|                                                         | $R_{L2}$          | $V_{IN} = 0 V, T_A = 25^{\circ}C,$                                                           | $V_{DD} = 5V$             | 150  | 250  | 400  | kΩ   |
|                                                         |                   | nRESET                                                                                       | $V_{DD} = 3V$             | 300  | 500  | 700  | kΩ   |
| Oscillator<br>Feedback                                  | R <sub>OSC1</sub> | $V_{DD} = 5V, T_A = 25^{\circ}C, X_{IN} = X_{OUT} = 0V$                                      | V <sub>DD</sub> ,         | 420  | 850  | 1700 | kΩ   |
| Resistors                                               | R <sub>OSC2</sub> | $V_{DD} = 5 V$ , $T_A = 25^{\circ}C$ , $X_{IN} = X_{TIN} = V_{DD}$ , $X_{OUT} = 0 V$         | V <sub>DD</sub> ,         | 2200 | 4500 | 9000 | kΩ   |
| LCD Voltage<br>Dividing<br>Resistor                     | R <sub>LCD</sub>  | T <sub>A</sub> = 25°C                                                                        |                           | 45   | 75   | 100  |      |
| VLCD-COMi<br>Voltage<br>Drop (i = 0<br>to 7)            | V <sub>DC</sub>   | –15µA per common pin                                                                         |                           | _    | -    | 120  |      |
| V <sub>LCD</sub> –SEGx<br>Voltage<br>Drop (x =<br>0–18) | V <sub>DS</sub>   | –15µA per segment pin                                                                        |                           | _    | -    | 120  | mV   |

### Table 102. DC Electrical Characteristics $(T_A = -40^{\circ}C \text{ to } +85^{\circ}C, V_{DD} = 1.8 \text{ V to } 5.5 \text{ V})^1$

1. Every value in this table is measured when bits 4–3 of the System Clock Control Register (CLKCON.4–.3) is set to 11b.

2. Supply current does not include current drawn through internal pull-up resistors, LCD voltage-dividing resistors, the LVR block, and external output current loads.

I<sub>DD1</sub> and I<sub>DD2</sub> include a power consumption of subclock oscillation.
 I<sub>DD3</sub> and I<sub>DD4</sub> are the current when the main clock oscillation stops and the subclock is used.
 I<sub>DD5</sub> is the current when the main and subclock oscillation stops.



| Parameter                      | Symbol                        | Conditions                                                                    |                       | Min.                         | Тур.                 | Max.                         | Unit |
|--------------------------------|-------------------------------|-------------------------------------------------------------------------------|-----------------------|------------------------------|----------------------|------------------------------|------|
| Middle<br>Output<br>Voltage    | V <sub>LC1</sub>              | $V_{DD}$ = 2.7 V to 5.5 V,<br>LCD clock = 0Hz, $V_{LC0}$ = $V_{DI}$           | <sub>D</sub> , ¼ Bias | 0.75<br>V <sub>DD</sub> –0.2 | 0.75 V <sub>DD</sub> | 0.75<br>V <sub>DD</sub> +0.2 | V    |
|                                | V <sub>LC2</sub>              | -                                                                             |                       | 0.5<br>V <sub>DD</sub> -0.2  | 0.5 V <sub>DD</sub>  | 0.5<br>V <sub>DD</sub> +0.2  | V    |
|                                | V <sub>LC3</sub>              | -                                                                             |                       | 0.25<br>V <sub>DD</sub> -0.2 | 0.25 V <sub>DD</sub> | 0.25<br>V <sub>DD</sub> +0.2 | V    |
| Supply<br>Current <sup>2</sup> | $I_{DD1}^{3}$                 | Run Mode; V <sub>DD</sub> = 5.0V;                                             | 4.2MHz                | _                            | 1.2                  | 2.0                          | mA   |
|                                |                               | crystal oscillator C1 = C2 = 22pF                                             | 12.0MHz               | -                            | 2.2                  | 4.0                          | mA   |
|                                |                               | V <sub>DD</sub> = 3.0V                                                        | 4.2MHz                | _                            | 0.8                  | 1.5                          | mA   |
|                                | I <sub>DD2</sub> <sup>3</sup> | Idle Mode; V <sub>DD</sub> = 5.0V;                                            | 4.2MHz                | -                            | 0.8                  | 1.5                          | mA   |
|                                |                               | crystal oscillator C1 = C2 = 22pF                                             | 12.0MHz               | _                            | 1.3                  | 2.3                          | mA   |
|                                |                               | $V_{DD} = 3.0 V$                                                              | 4.2MHz                | _                            | 0.4                  | 0.8                          | mA   |
|                                | I <sub>DD3</sub> <sup>4</sup> | Suboperating Mode; 32,768Hz crystal oscillator, $V_{DD}$ = 3.0V, $T_A$ = 25°C |                       | -                            | 80.0                 | 120.0                        | μA   |
|                                | $I_{DD4}^{4}$                 | Subidle Mode; 32,768 Hz crys oscillator, $V_{DD}$ = 3.0 V, $T_A$ = 2          |                       | -                            | 6.0                  | 15.0                         | μA   |
|                                | $I_{DD5}^{5}$                 | Stop Mode; $V_{DD} = 5.0 V$                                                   |                       | -                            | 0.3                  | 6.0                          | μA   |

### Table 102. DC Electrical Characteristics $(T_A = -40^{\circ}C \text{ to } +85^{\circ}C, V_{DD} = 1.8 \text{ V to } 5.5 \text{ V})^1$

Notes:

1. Every value in this table is measured when bits 4–3 of the System Clock Control Register (CLKCON.4–.3) is set to 11b.

2. Supply current does not include current drawn through internal pull-up resistors, LCD voltage-dividing resistors, Supply current does not include current drawn tinough internal pull-up resistors, LCD voltage-the LVR block, and external output current loads.
 I<sub>DD1</sub> and I<sub>DD2</sub> include a power consumption of subclock oscillation.
 I<sub>DD3</sub> and I<sub>DD4</sub> are the current when the main clock oscillation stops and the subclock is used.
 I<sub>DD5</sub> is the current when the main and subclock oscillation stops.

| Parameter                                         | Symbol                                   | Conditions                                | Min.*                | Тур.       | Max.       | Unit  |
|---------------------------------------------------|------------------------------------------|-------------------------------------------|----------------------|------------|------------|-------|
| Interrupt input<br>high, low width<br>(P3.0–P3.7) | t <sub>INTH</sub> ,<br>t <sub>INTL</sub> | All interrupt, $V_{DD} = 5V$              | 500                  | -          | -          | ns    |
| nRESET input<br>low width                         | t <sub>RSL</sub>                         | Input, $V_{DD} = 5V$                      | 10                   | -          | -          | ns    |
|                                                   |                                          | ot or reset pulse is greater than the mir | imum value, the puls | se is alwa | ays recogi | nized |







Figure 121. Input Timing for External Interrupts



Figure 122. Input Timing for nRESET

| Parameter          | Symbol           | Conditions                                          | Min. | Тур. | Max. | Unit |
|--------------------|------------------|-----------------------------------------------------|------|------|------|------|
| Input capacitance  | C <sub>IN</sub>  | f = 1 MHz; unmeasured pins are returned to $V_{SS}$ | _    | _    | 10   | pF   |
| Output capacitance | C <sub>OUT</sub> | -                                                   | _    | _    | _    | _    |
| I/O capacitance    | CIO              | -                                                   | _    | _    | _    | _    |

Table 105. Data Retention Supply Voltage in Stop Mode ( $T_A = -40^{\circ}C$  to +85°C)

| Parameter                                      | Symbol            | Conditions                                                 | Min. | Тур. | Max. | Unit |
|------------------------------------------------|-------------------|------------------------------------------------------------|------|------|------|------|
| Data retention supply voltage                  | V <sub>DDDR</sub> | _                                                          | 1.8  | _    | 5.5  | V    |
| Data retention supply current I <sub>DDI</sub> |                   | Stop Mode, T <sub>A</sub> = 25°C, V <sub>DDDR</sub> = 1.8V | -    | _    | 1    | μA   |





Figure 123. Stop Mode Release Timing Initiated by nRESET

**Note:** In Figure 123,  $t_{WAIT}$  is the same as 4096 x 16 x 1 ÷  $f_{XX}$ .





**Note:** In Figure 124,  $t_{WAIT}$  is the same as 16 x 1 /  $f_{BT}$ ;  $f_{BT}$  = the basic timer clock selection.

## S3F8S5A **Product Specification**

zilog cided in Life DXYS Company

353

| Parameter                         | Symbol            | Conditions                                           | Min.            | Тур. | Max.              | Unit |
|-----------------------------------|-------------------|------------------------------------------------------|-----------------|------|-------------------|------|
| Resolution                        | _                 | _                                                    | _               | 10   | _                 | bit  |
| Total accuracy                    | _                 | -                                                    | _               | _    | ±3                | LSB  |
| Integral linearity error          | ILE               | $V_{DD} = 5.120 V$                                   | -               |      | ±2                | LSB  |
| Differential linearity error      | DLE               | $V_{SS} = 0V CPU$                                    | _               |      | ±1                | LSB  |
| Offset error of top               | EOT               | $-\operatorname{clock} = 12.0 \mathrm{MHz}$          | _               |      | ±3                | LSB  |
| Offset error of bottom            | EOB               |                                                      |                 |      | ±3                | LSB  |
| Conversion time <sup>1</sup>      | T <sub>CON</sub>  | -                                                    | 25              | _    | _                 | μs   |
| Analog input voltage              | V <sub>IAN</sub>  | -                                                    | V <sub>SS</sub> | _    | AV <sub>REF</sub> | V    |
| Analog input impedance            | R <sub>AN</sub>   | _                                                    | 2               | 1000 | -                 | MΩ   |
| Analog reference voltage          | AV <sub>REF</sub> | _                                                    | 1.8             | _    | V <sub>DD</sub>   | V    |
| Analog input current              | I <sub>ADIN</sub> | $V_{DD} = 5.0 V$                                     | _               | _    | 10                | μA   |
| Analog block current <sup>2</sup> | I <sub>ADC</sub>  | $V_{DD} = 5.0 V$                                     | _               | 0.5  | 1.5               | mA   |
|                                   |                   | V <sub>DD</sub> = 5.0V<br>when in Power<br>Down Mode | -               | 100  | 500               | nA   |

## Table 106. A/D Converter Electrical Characteristics ( $T_A = -40^{\circ}C$ to +85°C, $V_{DD} = 1.8V$ to 5.5V, $V_{SS} = 0V$ )

Notes:

Conversion time is the time required from the moment a conversion operation starts until it ends.
 I<sub>ADC</sub> is an operating current during A/D converter.

| Parameter                           | Symbol           | Conditions             |   | Min. | Тур. | Max. | Unit |
|-------------------------------------|------------------|------------------------|---|------|------|------|------|
| Voltage of LVR                      | V <sub>LVR</sub> | $T_A = 25^{\circ}C$    |   | 1.8  | 1.9  | 2.0  | V    |
|                                     |                  |                        |   | 2.6  | 2.8  | 3.0  | V    |
| V <sub>DD</sub> voltage rising time | t <sub>R</sub>   |                        | _ | 10   | -    | _    | μs   |
| V <sub>DD</sub> voltage off time    | t <sub>OFF</sub> |                        | _ | 0.5  | -    | -    | S    |
| Hysteresis                          | ΔV               |                        | _ | _    | 50   | 150  | mV   |
| Current<br>consumption of<br>LVR    | I <sub>LVR</sub> | V <sub>DD</sub> = 3.0V |   | -    | 30   | 60   | μA   |



An DXYS Company

354



Figure 125. Low Voltage Reset Timing

| Parameter            | Symbol                            | Conditions          | Min.                   | Тур. | Max. | Unit |
|----------------------|-----------------------------------|---------------------|------------------------|------|------|------|
| SCK cycle time       | t <sub>KCY</sub>                  | External SCK source | 1000                   | -    | -    | ns   |
|                      |                                   | Internal SCK source | 1000                   | -    | -    | ns   |
| SCK high, low width  | t <sub>KH</sub> , t <sub>KL</sub> | External SCK source | 500                    | _    | _    | ns   |
|                      |                                   | Internal SCK source | t <sub>KCY</sub> /2–50 | -    | _    | ns   |
| SI setup time to SCK | t <sub>SIK</sub>                  | External SCK source | 250                    | _    | _    | ns   |
| high                 |                                   | Internal SCK source | 250                    | -    | _    | ns   |
| SI hold time to SCK  | t <sub>KSI</sub>                  | External SCK source | 400                    | _    | _    | ns   |
| high                 |                                   | Internal SCK source | 400                    | -    | _    | ns   |
| Output delay for     | t <sub>KSO</sub>                  | External SCK source | _                      | _    | 300  | ns   |
| SCK to SO            |                                   | Internal SCK source | _                      | -    | 250  | ns   |









Table 109. UART Timing Characteristics in Mode  $0^1$  (12.0 MHz; T<sub>A</sub> = -40°C to +85°C, V<sub>DD</sub> = 1.8V to 5.5V; Load Capacitance = 80pF)

| Parameter                                             | Symbol                               | Min.                 | Тур.                  | Max. | Unit |
|-------------------------------------------------------|--------------------------------------|----------------------|-----------------------|------|------|
| Serial port clock cycle time <sup>2</sup>             | t <sub>SCK</sub>                     | 1160                 | t <sub>CPU</sub> x 16 | 1500 | ns   |
| Output data setup to clock rising edge                | t <sub>S1</sub>                      | 500                  | t <sub>CPU</sub> x 13 | _    | ns   |
| Clock rising edge to input data valid                 | t <sub>S2</sub>                      | _                    | _                     | 500  | ns   |
| Output data hold after clock rising edge <sup>2</sup> | t <sub>H1</sub>                      | t <sub>CPU</sub> –50 | t <sub>CPU</sub>      | _    | ns   |
| Input data hold after clock rising edge               | t <sub>H2</sub>                      | 0                    | _                     | _    | ns   |
| Serial port clock High, Low level width <sup>2</sup>  | t <sub>HIGH</sub> , t <sub>LOW</sub> | 450                  | t <sub>CPU</sub> x 8  | 890  | ns   |

Notes:

1. All timings are in nanoseconds (ns) and assume a 12.0MHz CPU clock frequency.

2.  $t_{CPU} = 1$  UART clock period.







Figure 127. Waveform for UART Timing Characteristics



Figure 128. Timing Waveform for the UART Module

**Notes:** The symbols shown in Figure 128 are defined as:

- $f_{SCK}$  = Serial port clock cycle time.
- $t_{S1}$  = Output data setup to clock rising edge.
- $t_{S2}$  = Clock rising edge to input data valid.01
- $t_{H1}$  = Output data hold after clock rising edge.
- $t_{H2}$  = Input data hold after clock rising edge.



DXYS Company

357

## Table 110. Main Oscillator Characteristics ( $T_A = -40^{\circ}C$ to +85°C, $V_{DD} = 1.8V$ to 5.5V)

|            |                     |                          | Test      |      |      |      |      |
|------------|---------------------|--------------------------|-----------|------|------|------|------|
| Oscillator | Clock Configuration | Parameter                | Condition | Min. | Тур. | Max. | Unit |
| Crystal    | C1                  | Main                     | 2.2V–5.5V | 0.4  | _    | 12.0 | MHz  |
|            |                     | oscillation<br>frequency | 1.8V–5.5V | 0.4  | _    | 4.2  | MHz  |
| Ceramic    | C1                  | Main                     | 2.2V–5.5V | 0.4  | _    | 12.0 | MHz  |
| oscillator |                     | oscillation<br>frequency | 1.8V–5.5V | 0.4  | -    | 4.2  | MHz  |
| External   | ► <b>Γ</b>          | X <sub>IN</sub> input    | 2.2V–5.5V | 0.4  | -    | 12.0 | MHz  |
| clock      |                     | frequency                | 1.8V–5.5V | 0.4  | _    | 4.2  | MHz  |
| RC         |                     | Frequency                | 5.0V      | 0.4  | -    | 2.0  | MHz  |
| oscillator |                     |                          | 3.0V      | 0.4  | _    | 1.0  | MHz  |

## Table 111. Suboscillation Characteristics (T<sub>A</sub> = $-40^{\circ}$ C to $+85^{\circ}$ C, V<sub>DD</sub> = 1.8V to 5.5V)

| Oscillator        | Clock Configuration | Parameter                   | Test<br>Condition | Min. | Тур.   | Max. | Unit |
|-------------------|---------------------|-----------------------------|-------------------|------|--------|------|------|
| Crystal           |                     | Suboscillation<br>frequency | 1.8V–5.5V         | _    | 32.768 | -    | kHz  |
| External<br>clock |                     | X <sub>TIN</sub> frequency  | 1.8V–5.5V         | 32   | -      | 100  | kHz  |



an DXYS Company 358

## Table 112. Main Oscillation Stabilization Time ( $T_A = -40^{\circ}C$ to +85°C, $V_{DD} = 1.8V$ to 5.5V)

| Parameter      | Test Condition                                                                | Min. | Тур. | Max. | Unit |
|----------------|-------------------------------------------------------------------------------|------|------|------|------|
| Crystal        | $f_X > 1 MHz$ ; oscillation stabilization                                     | _    | -    | 40   | ms   |
| Ceramic        | occurs when V <sub>DD</sub> is equal to the minimum oscillator voltage range. | -    | -    | 10   | ms   |
| External clock | $X_{IN}$ input high and low width ( $t_{XH}$ , $t_{XL}$ )                     | 62.5 | -    | 1250 | ns   |



Figure 129. Clock Timing Measurement at X<sub>IN</sub>

| Parameter      | Test Condition                                                            | Min. | Тур. | Max. | Unit |
|----------------|---------------------------------------------------------------------------|------|------|------|------|
| Crystal        | -                                                                         | _    | _    | 10   | S    |
| External clock | $X_{TIN}$ input high and low width (t <sub>XTH</sub> , t <sub>XTL</sub> ) | 5    | _    | 15   | μs   |







Figure 130. Clock Timing Measurement at XT<sub>IN</sub>



CPU Clock =  $1/4n \times 0$  scillator frequency (n = 1, 2, 8, 16)

Figure 131. Operating Voltage Range





### Table 114. Internal Flash ROM Electrical Characteristics ( $T_A = -40^{\circ}C$ to +85°C, $V_{DD} = 1.8 V$ to 5.5 V)

| Parameter                        | Symbol  | Conditions | Min. | Тур. | Max.               | Unit  |
|----------------------------------|---------|------------|------|------|--------------------|-------|
| Programming time <sup>1</sup>    | Ftp     | -          | 20   | 25   | 30                 | μs    |
| Chip erasing time <sup>2</sup>   | Ftp1    | -          | 32   | 50   | 70                 | ms    |
| Sector erasing time <sup>3</sup> | Ftp2    | -          | 4    | 8    | 12                 | ms    |
| Number of writes/erases          | $FN_WE$ | -          | -    | -    | 10000 <sup>4</sup> | times |

Notes:

1. Programming time = the time during which one byte (8-bit) is programmed.

2. Chip erasing time = the time during which the entire 64KB block is erased.

3. Sector erasing time = the time during which the entire 128-byte block is erased.

4. Chip erasing is available in Tool Program Mode only.



# **Mechanical Data**

The S3F8S5A microcontroller is currently available in 44-pin QFP and 42-pin SDIP packages. A mechanical drawing of the 44-pin QFP package is shown in Figure 132.



Figure 132. Package Dimensions, 44-Pin QFP Package

**Note:** Dimensions in Figure 132 are expressed in millimeters.

>



A mechanical drawing of the 42-pin SDIP package is shown in Figure 133.



Note: Dimensions in Figure 133 are expressed in millimeters.





# S3F8S5A Flash MCU

This chapter describes Tool Program Mode operation for the S3F8S5A Flash MCU. To learn more about User Program Mode operation, refer to the <u>Embedded Flash Memory</u> <u>Interface</u> chapter on page 334.

The S3F8S5A microcontroller features an on-chip Flash MCU ROM which is accessed by serial data format.

Pin assignments for the 44-pin QFP package are shown in Figure 134.



Figure 134. S3F8S5A Pin Assignments, 44-QFP Package



Pin assignments for the 42-pin SDIP package are shown in Figure 135.





| Main Chip       |                 |        |        | Duri | ing Programming                                                                                                                                                                                                                                                   |
|-----------------|-----------------|--------|--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 |                 | Pi     | ns     |      |                                                                                                                                                                                                                                                                   |
| Pin Name        | Pin Name        | 44-Pin | 42-Pin | I/O  | Function                                                                                                                                                                                                                                                          |
| P1.2            | SDAT            | 3      | 9      | I/O  | Serial data pin; output port when reading and input<br>port when writing. Can be assigned as an input/<br>push-pull output port.                                                                                                                                  |
| P1.3            | SCLK            | 4      | 10     | I/O  | Serial clock pin; input only.                                                                                                                                                                                                                                     |
| TEST            | V <sub>PP</sub> | 9      | 15     | Ι    | Tool Mode selection when TEST/ $V_{PP}$ pin sets<br>logic value 1. If using Flash writer in Tool Mode<br>(e.g., spw2+, etc.), connect the TEST/ $V_{PP}$ pin to<br>$V_{DD}$ . The S3F8S5A MCU supplies 12.5V via the<br>internal high-voltage generation circuit. |
| nRESET          | nRESET          | 12     | 18     | I    | Chip initialization.                                                                                                                                                                                                                                              |
| V <sub>DD</sub> | V <sub>DD</sub> | 5      | 11     | _    | Power supply pin for logic circuit. $V_{DD}$ should be                                                                                                                                                                                                            |
| V <sub>SS</sub> | V <sub>SS</sub> | 6      | 12     | _    | tied to 5V during programming.                                                                                                                                                                                                                                    |

#### Table 115. Pins Used to Read/Write the Flash ROM



## **Test Pin Voltage**

The TEST pin on the socket board for the MTP Writer must be connected to  $V_{DD}$  (5.0V) with RC delay as shown in Figure 136 (only when SPW 2+ and GW-pro2 are used). The TEST pin on this socket board must not be connected to  $V_{PP}$  (12.5V), which is generated from the MTP Writer. Therefore, the specific socket board for the S3F8S5A MCU must be used when writing or erasing using the MTP Writer.



Figure 136. RC Delay Circuit

## **Onboard Writing**

The S3F8S5A requires only six signal lines, including the  $V_{DD}$  and  $V_{SS}$  pins, for writing internal Flash memory with the serial protocol. Therefore, onboard writing is possible if the writing signal lines are considered when the application board is designed.

## **Circuit Design Guide**

As Flash memory is being written to, the writing tool requires the following six signal lines:  $V_{SS}$ ,  $V_{DD}$ , nRESET, TEST, SDAT, and SCLK. When designing the PCB circuits, consider how these signal lines will be used for onboard writing operations. The TEST pin is normally connected to  $V_{SS}$ ; however, in writing mode, a resistor should be inserted between the TEST pin and  $V_{SS}$ . The nRESET, SDAT, and SCLK lines should be treated with the same consideration.

when designing your application board, be careful that you design the circuitry related to these signal pins, because the rise and fall timing of the  $V_{PP}$ , SCLK, and SDAT lines will be very important for proper programming. See Figure 137.

## **S3F8S5A Product Specification**





366



Figure 137. PCB Design Guide for on Board Programming

**Note:** If the writer tool you are using is the SPW 2+ or the GW-pro2, refer to Figure 136.

| Pin Name               | I/O Mode in<br>Application | Resistor Required? | Required Value                                                                        |
|------------------------|----------------------------|--------------------|---------------------------------------------------------------------------------------|
| V <sub>PP</sub> (TEST) | Input                      | Yes                | $RV_{PP}$ is $10k\Omega$ to $50k\Omega$ .<br>$CV_{PP}$ is $0.01\mu$ F to $0.02\mu$ F. |
| nRESET                 | Input                      | Yes                | RnRESET is $2k\Omega$ to $5k\Omega$ .<br>CnRESET is $0.01 \mu$ F to $0.02 \mu$ F      |
| SDAT(I/O)              | Input                      | Yes                | RSDAT is $2k\Omega$ to $5k\Omega$ .                                                   |
|                        | Output                     | No                 | -                                                                                     |
| SCLK(I/O)              | Input                      | Yes                | RSDAT is $2k\Omega$ to $5k\Omega$ .                                                   |
|                        | Output                     | No                 | _                                                                                     |

#### **Table 116. Circuit Connections**

Note: In Onboard Writing Mode, a very high-speed signal will be provided to the SCLK and SDAT pins that can cause damage to the application circuits connected to the SCLK or SDAT ports if the application circuit is designed for high-speed response, such as a relay control circuit. If possible, the I/O configuration of the SDAT and SCLK pins must set to Input Mode. The value of R, C in this table is the recommended value; this value varies with the system circuitry.





# **Development Tools**

Zilog provides a powerful and easy-to-use development support system on a turnkey basis. This development support system is composed of a host system, debugging tools, and supporting software. For a host system, any standard computer that employs Win95/ 98/2000/XP as its operating system can be used.

A sophisticated debugging tool is provided in both hardware and software formats: the powerful OPENice-i500/i2000 in-circuit emulator and the SK-1200 SmartKit. Zilog also offers supporting software that includes a debugger, an assembler, and a program for setting options.





# **Development System Configuration**

Figure 138 shows the basic configuration of the development system.



Figure 138. Development System Configuration

# **Target Board**

The TB8S5A Target Board is specific to the S3F8S5A MCU, and ships complete with all target system cables and adapters. This target board is operated as a target CPU with an emulator (OPENIce I-500/2000, SK-1200).





Table 117 shows the TB8S5A Target Board's power selection settings.

Table 117. Power Selection Settings for the TB8S5A Target Board



## **SMDS2+ Selection**

To write data into the available program memory in the SMDS2+ C Compiler, select the target board for SMDS2+ through a switch. Otherwise, the program memory writing function is not available. Table 118 depicts the SMDS2+ tool selection setting.

| Table 118 | . SMDS2+ | Tool | Selection | Setting |
|-----------|----------|------|-----------|---------|
|-----------|----------|------|-----------|---------|





Table 119 depicts the use of single header pins to select clock source, PWM, or operation mode.

| Target Board Part                              | Description                                                                                                               |
|------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|
| Board CLK<br>JP 5<br>Clock Source<br>Inner CLK | Uses the SMDS2/SMDS2+ internal clock source as the system clock; default setting.                                         |
| Board CLK<br>JP 5<br>Clock Source<br>Inner CLK | Uses an external crystal or a ceramic oscillator as the system clock.                                                     |
| Main Mode<br>JP 2<br>EVA Mode                  | The S3E8S50 evaluation chip runs in Main Mode; a debug interface is not available.                                        |
| Main Mode<br>JP 2<br>O<br>EVA Mode             | The S3E8S50 evaluation chip runs in EVA Mode. When running a debug program, set the jumper to this mode; default setting. |



Table 120 depicts the use of single header pins as the input path for external trigger sources.

| Target Board Part                  | Description                                                                                                                                                |
|------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| External<br>Triggers<br>O Ch1(TP3) | Connector from<br>External Trigger<br>Sources of the<br>Application System                                                                                 |
| O Ch2(TP4)                         |                                                                                                                                                            |
|                                    | You can connect an external trigger source to one of the two external trigger channels (CH1 or CH2) for the SK-1000/SMDS2+ breakpoint and trace functions. |

Figure 139 depicts the DIP switch for the Smart Option.



Figure 139. DIP Switch for the Smart Option

**Note:** In Figure 139, particularly for the EVA chip, the Smart Option is determined by the DIP switch, not the software. The reserved bits should remain at their default values; i.e., High.

## **Target Board LEDs**

**IDLE LED.** This LED is ON when the S3E8S50 evaluation chip is in Idle Mode. **STOP LED.** This LED is ON when the S3E8S50 evaluation chip is in Stop Mode.



S2 ADC4/P0.4 C 1 50 □ P0.5/ADC5 INT3/ADC3/P0.3 2 49 □ P0.6/ADC6 INT2/ADC2/P0.2 □ P0.7/ADC7 3 48 **50-PIN SOCKET** P1.7/ADC9 INT1/ADC1/P0.1 4 47 INT0/ADC0/P0.0 □ 5 46 □ P1.6/ADC8 VDD 6 45 □ P1.5/VLC3 VSS □ 7 44 □ P1.4/VLC2 XOUT □ 8 43 □ P1.3/VLC1 XIN C 9 42 P1.2/VL0 (VPP)TEST □ 10 41 □ P1.1/CB XTIN C 11 □ P1.0/CA 40 XTOUT □ 12 39 □ P4.7/SEG21/RXD0 Nreset ⊏ 38 P4.6/SEG20/TXD0 13 COM0/P2.0 □ P4.5/SEG19/RX1 14 37 COM1/P2.1 □ 36 P4.4/SEG18/TXD1 15 SEG0/COM2/P2.2 □ 35 □ P4.3/SEG17/TAOUT/TACAP 16 SEG1/COM3/P2.3 C 34 P4.2/SEG16/TACLK 17 SEG2/COM4/P2.4 □ 18 33 □ P4.1/SEG15/TBOUT SEG3/COM5/P2.5 □ 32 □ P4.0/SEG14/T0OUT 19 SEG4/COM6/P2.6 □ □ P3.7/SEG13/INT7/T1OUT/T1CAP 20 31 SEG5/COM7/P2.7 □ □ P3.6/SEG12/INT6/T1CLK/SCL 21 30 SEG6/MISO/P3.0 22 29 P3.5/SEG11/INT5/T2CLK/SDA SEG7/MOSI/P3.1 □ 23 28 P3.4/SEG10/INT4/T2OUT/T2CAP SEG8/SCK/P3.2 24 27 P3.3/SEG9/NSS VSS C 25 26 J VSS

Figure 140 shows the pin assignments for the TB8S5A Target Board's 48-pin connector.





Target Board S2 S0-Pin Connector Target Cable for 50-Pin Connector 25 26 Target Cable for 50-Pin Connector 25 26

Figure 141 shows the S3F8S5A MCU's probe adapter for the 48-pin package.

Figure 141. S3F8S5A Probe Adapter for the 44-Pin Package

## **Third Parties for Development Tools**

Zilog provides a complete line of development tools that support the S3 Family of Microcontrollers. With long experience in developing MCU systems, these third party firms are bonafide leaders in MCU development tool technology.

In-circuit emulators:

- OPENice-i500/2000
- SK-1200 SmartKit

**OTP/MTP** Programmers:

- SPW-uni
- GW-uni (8-gang programmer)
- AS-pro

To obtain the S3 Family development tools that will satisfy your S3F8S5A development objectives, contact your local <u>Zilog Sales Office</u>, or visit Zilog's <u>Third Party Tools page</u> to review our list of third party tool suppliers.





# **Ordering Information**

Table 121 identifies the basic features and package styles available for the S3F8S5A MCU.

| Device          | Flash Size | RAM<br>Size | LCD    | GPIO | ADC | Package     |
|-----------------|------------|-------------|--------|------|-----|-------------|
| S3F8S5AXZZ-QZ8A | 48KB       | 1040B       | 18 x 8 | 34   | 8   | 44-Pin QFP  |
| S3F8S5AXZZ-AQ9A | 48KB       | 1040B       | 18 x 8 | 32   | 6   | 42-Pin SDIP |

Table 121. Ordering Information for the S3F8S5A MCU

## Part Number Suffix Designations

Zilog part numbers consist of a number of components. For example, part number S3F8S5AXZZ-QZ8A is an unmasked 8-bit MCU with 48KB of Flash memory in a 44-pin QFP package and built using lead-free solder.







# **Customer Support**

To share comments, get your technical questions answered, or report issues you may be experiencing with our products, please visit Zilog's Technical Support page at <a href="http://support.zilog.com">http://support.zilog.com</a>.

To learn more about this product, find additional documentation, or to discover other facets about Zilog product offerings, please visit the Zilog Knowledge Base at <u>http://</u> <u>zilog.com/kb</u> or consider participating in the Zilog Forum at <u>http://zilog.com/forum</u>.

This publication is subject to replacement by a later edition. To determine whether a later edition exists, please visit the Zilog website at <u>http://www.zilog.com</u>.